Zapier
By ActivitySmith
Use the ActivitySmith CLI when you want shell-native commands for Push Notifications and Live Activity lifecycle control.
npm i -g activitysmith-cliSend an immediate notification for a completed task or event:

activitysmith push \ --title "New subscription 💸" \ --message "Customer upgraded to Pro plan"Send images, videos, or audio with your push notifications, press and hold to preview media directly from the notification, then tap through to open the linked content.

activitysmith push \ --title "Homepage ready" \ --message "Your agent finished the redesign." \ --media "https://cdn.example.com/output/homepage-v2.png" \ --redirection "https://github.com/acme/web/pull/482"
.jpg, .png, .gif, etc..mp3, .m4a, etc..mp4, .mov, etc.Content-Type, even if the path has no extension--media can be combined with --redirection, but not with --actions.
Push notification redirection and actions are optional and can be used to redirect the user to a specific URL when they tap the notification or to trigger a specific action when they long-press the notification. Webhooks are executed by ActivitySmith backend.

activitysmith push \ --title "Build Failed 🚨" \ --message "CI pipeline failed on main branch" \ --redirection "https://github.com/org/repo/actions/runs/123456789" \ --actions '[{"title":"Open Failing Run","type":"open_url","url":"https://github.com/org/repo/actions/runs/123456789"},{"title":"Create Incident","type":"webhook","url":"https://hooks.example.com/incidents/create","method":"POST","body":{"service":"payments-api","severity":"high","source":"activitysmith-cli"}}]'
There are three types of Live Activities:
metrics: best for live operational stats like server CPU and memory, queue depth, or replica lagsegmented_progress: best for step-based workflows like deployments, backups, and ETL pipelinesprogress: best for continuous jobs like uploads, reindexes, and long-running migrations tracked as a percentageWhen working with Live Activities via our API, you have two approaches tailored to different needs. First, the stateless mode is the simplest path - one API call can initiate or update an activity, and another ends it - no state tracking on your side.
This is ideal if you want minimal complexity, perfect for automated workflows like cron jobs.
In contrast, if you need precise lifecycle control, the classic approach offers distinct calls for start, updates, and end, giving you full control over the activity's state.
In the following sections, we'll break down how to implement each method so you can choose what fits your use case best.
Use a stable stream_key to identify the system or workflow you are tracking, such as a server, deployment, or build pipeline. This is especially useful for cron jobs and other scheduled tasks where you do not want to store activity_id between runs.
Run activitysmith activity stream <stream-key> ... again with the same stream_key whenever the state changes.

activitysmith activity stream prod-web-1 \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 9, "unit": "%" }, { "label": "MEM", "value": 45, "unit": "%" } ] }'
activitysmith activity stream nightly-backup \ --content-state '{ "title": "Nightly Backup", "subtitle": "upload archive", "type": "segmented_progress", "numberOfSteps": 3, "currentStep": 2 }'
activitysmith activity stream search-reindex \ --content-state '{ "title": "Search Reindex", "subtitle": "catalog-v2", "type": "progress", "percentage": 42 }'Use this when the tracked process is finished and you no longer want the Live Activity on devices. content_state is optional here; include it if you want to end the stream with a final state.
If you later send another activity stream request with the same stream_key, ActivitySmith starts a new Live Activity for that stream again.
activitysmith activity end-stream prod-web-1 \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 7, "unit": "%" }, { "label": "MEM", "value": 38, "unit": "%" } ] }'Stream responses include an operation field:
started: ActivitySmith started a new Live Activity for this stream_keyupdated: ActivitySmith updated the current Live Activityrotated: ActivitySmith ended the previous Live Activity and started a new onenoop: the incoming state matched the current state, so no update was sentpaused: the stream is paused, so no Live Activity was started or updatedended: returned by activity end-stream after the stream is endedUse these commands when you want to manage the Live Activity lifecycle yourself:
activitysmith activity start ....activity_id.activitysmith activity update ... as progress changes.activitysmith activity end ... when the work is finished.Use metrics when you want to keep a small set of live stats visible, such as server health, queue pressure, or database load.

activitysmith activity start \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 9, "unit": "%" }, { "label": "MEM", "value": 45, "unit": "%" } ] }'
activitysmith activity update \ --activity-id "<activityId>" \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 76, "unit": "%" }, { "label": "MEM", "value": 52, "unit": "%" } ] }'
activitysmith activity end \ --activity-id "<activityId>" \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 7, "unit": "%" }, { "label": "MEM", "value": 38, "unit": "%" } ], "autoDismissMinutes": 2 }'Use segmented_progress for jobs and workflows that move through clear steps or phases, such as backups, deployments, ETL pipelines, and checklists. number_of_steps is dynamic, so you can increase or decrease it later if the workflow changes.

activitysmith activity start \ --content-state '{ "title": "Nightly database backup", "subtitle": "create snapshot", "numberOfSteps": 3, "currentStep": 1, "type": "segmented_progress", "color": "yellow" }' \ --channels "devs,ops"
activitysmith activity update \ --activity-id "<activityId>" \ --content-state '{ "title": "Nightly database backup", "subtitle": "upload archive", "currentStep": 2 }'
activitysmith activity end \ --activity-id "<activityId>" \ --content-state '{ "title": "Nightly database backup", "subtitle": "verify restore", "currentStep": 3, "autoDismissMinutes": 2 }'Use progress when the state is naturally continuous. It fits charging, downloads, sync jobs, uploads, timers, and any flow where a percentage or numeric range is the clearest signal.

activitysmith activity start \ --content-state '{ "title": "EV Charging", "subtitle": "Added 30 mi range", "percentage": 15, "type": "progress", "color": "lime" }'
activitysmith activity update \ --activity-id "<activityId>" \ --content-state '{ "title": "EV Charging", "subtitle": "Added 120 mi range", "percentage": 60 }'
activitysmith activity end \ --activity-id "<activityId>" \ --content-state '{ "title": "EV Charging", "subtitle": "Added 200 mi range", "percentage": 100, "autoDismissMinutes": 2 }'Just like Actionable Push Notifications, Live Activities can have a button that opens provided URL in a browser or triggers a webhook. Webhooks are executed by the ActivitySmith backend.

activitysmith activity start \ --content-state '{ "title": "Server Health", "subtitle": "prod-web-1", "type": "metrics", "metrics": [ { "label": "CPU", "value": 76, "unit": "%" }, { "label": "MEM", "value": 52, "unit": "%" } ] }' \ --action '{ "title": "Open Dashboard", "type": "open_url", "url": "https://ops.example.com/servers/prod-web-1" }'
activitysmith activity update \ --activity-id "<activityId>" \ --content-state '{ "title": "Reindexing product search", "subtitle": "Shard 7 of 12", "numberOfSteps": 12, "currentStep": 7 }' \ --action '{ "title": "Pause Reindex", "type": "webhook", "url": "https://ops.example.com/hooks/search/reindex/pause", "method": "POST", "body": { "job_id": "reindex-2026-03-19", "requested_by": "activitysmith-cli" } }'Keep your team aligned with immediate event delivery across incidents, business signals, and automation outcomes.
Connect ActivitySmith to automation and delivery platforms, then route runtime events to Push Notifications and Live Activities on your iOS devices.
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith

By ActivitySmith
By ActivitySmith
By ActivitySmith

By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith
By ActivitySmith