What is Pushover?
Pushover is a notification service that makes it easy to send real-time push notifications to the user’s phone from scripts and applications. Users can wrap the service in a few lines of shell and get real-time notifications for automated tasks. Some examples include docker container health checks, zpool status reports, and the outcome of shell commands.
The service has native applications for iOS and Android, and a browser-based client for desktop users. There is also a growing list of plugins for popular applications. Pushover provides a simple HTTP API. Used in combination with the mobile application, users can build simple but effective notification systems.
Cost and Limitations
The API allows up to 10,000 messages per month at no additional cost. Once that limit is reached, blocks of additional capacity can be purchased. The mobile application itself has a 30-day free trial, after which there is a one-time fee of $5 per platform.
Getting Set Up
To get started the user will need a Pushover account. Head to pushover.net and register. The user key is displayed in the dashboard after registration and identifies where notifications will be delivered. Install the mobile application and log in to start receiving notifications on the phone.
Next the user needs to create an application. In the Pushover dashboard, click “Create an Application/API Token”. Give it a name like “server-scripts” and submit the form. Pushover will generate an API token for that application.
The user will need both the user key and the API token to send notifications. Keep them somewhere safe.
Sending the First Notification
The simplest way to send a Pushover notification is with curl. This is a
good way to verify the credentials are working before integrating
notifications into scripts.
curl -s \
--form-string "token=YOUR_API_TOKEN" \
--form-string "user=YOUR_USER_KEY" \
--form-string "message=hello world" \
https://api.pushover.net/1/messages.json
Replace YOUR_API_TOKEN and YOUR_USER_KEY with the values from the
Pushover dashboard. If everything is configured correctly, a notification
will appear on the phone within seconds.
Pushover’s API supports a number of additional parameters, including message title, priority, and sound. See the Pushover example code page for examples in other languages.
Custom Notification Script
Rather than including the full curl command in every script, it can be wrapped
in a shell script of its own. This gives a reusable command that can be called
from any other script on the system.
#!/bin/sh
PUSHOVER_TOKEN="YOUR_API_TOKEN"
PUSHOVER_USER="YOUR_USER_KEY"
/usr/bin/curl -s \
--form-string "token=$PUSHOVER_TOKEN" \
--form-string "user=$PUSHOVER_USER" \
--form-string "title=$1" \
--form-string "message=$2" \
https://api.pushover.net/1/messages.json
Save this as notify.sh and make it executable:
chmod +x notify.sh
Place it in a directory that is in the path of the user that will be running
the notification scripts. On Linux ~/.local/bin is a common choice. On
macOS /usr/local/bin is typical. Run echo $PATH to see what directories
are currently in the user’s path.
With the script in place, sending a notification looks like this:
notify.sh "Testing notifications" "My first notification!"
Keep this script private and never commit it to a public repository. It contains the user’s Pushover credentials.
A Note on Sensitive Data
The API token and user key should be considered sensitive information.
For a script that lives only on the user’s own machine and is never shared,
storing them directly in the script is acceptable. If the user plans to share
the script or commit it to a repository, use environment variables instead.
Set them in a private file like ~/.pushover:
export PUSHOVER_TOKEN="your-token"
export PUSHOVER_USER="your-user-key"
Source that file in the shell profile so the variables are available to scripts:
source ~/.pushover
Then remove the hardcoded values from the script and reference the variables directly. The script is then safe to share publicly.
Practical Example
Call notify.sh at the end of any script to confirm it ran. Here it is
used with a simple backup:
#!/bin/sh
rsync -a /home/$USER/ /mnt/backup/
if [ $? -eq 0 ]; then
notify.sh "Backup" "Backup completed successfully"
else
notify.sh "Backup" "Backup failed"
fi
Conclusion
With a Pushover account and a small shell script, the user has a notification system that works from anywhere a shell command can be run. Adding a notification to an existing script is a simple process. This makes it easy to stay informed about what is happening on the systems without having to check manually.