2017-12-03 08:00:23 +01:00
![Apprise Logo ](http://repo.nuxref.com/pub/img/logo-apprise.png )
2017-11-25 22:51:46 +01:00
< hr / >
**ap·prise** / *verb* < br />
To inform or tell (someone). To make one aware of something.
< hr / >
2018-10-15 01:47:01 +02:00
*Apprise* allows you to send a notification to *almost* all of the most popular *notification* services available to us today such as: Telegram, Pushbullet, Slack, Twitter, etc.
2018-10-11 15:26:40 +02:00
* One notification library to rule them all.
* A common and intuitive notification syntax.
* Supports the handling of images (to the notification services that will accept them).
2019-02-01 03:28:18 +01:00
System owners who wish to provide a notification service no longer need to research each and every new one as they appear. They just need to include this one library and then they can immediately gain access to almost all of the notifications services available to us today.
2018-10-11 15:26:40 +02:00
2018-10-15 01:47:01 +02:00
System Administrators who wish to send a notification from a scheduled task or from the command line also no longer need to find the right tool for the job. Everything is already wrapped and supported within the *apprise* script that ships with this product.
2017-11-25 22:51:46 +01:00
2019-02-05 02:28:03 +01:00
[![Paypal ](https://img.shields.io/badge/paypal-donate-green.svg )](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick& hosted_button_id=MHANV39UZNQ5E)
2019-04-21 18:01:19 +02:00
[![Beerpay ](https://img.shields.io/beerpay/caronc/apprise.svg?color=green )](https://beerpay.io/caronc/apprise)< br />
2019-03-23 00:58:45 +01:00
[![Discord ](https://img.shields.io/discord/558793703356104724.svg?colorB=7289DA&label=Discord&logo=Discord&logoColor=7289DA&style=flat-square )](https://discord.gg/MMPeN2D)
[![Python ](https://img.shields.io/pypi/pyversions/apprise.svg?style=flat-square )](https://pypi.org/project/apprise/)
2017-12-03 08:00:23 +01:00
[![Build Status ](https://travis-ci.org/caronc/apprise.svg?branch=master )](https://travis-ci.org/caronc/apprise)
[![CodeCov Status ](https://codecov.io/github/caronc/apprise/branch/master/graph/badge.svg )](https://codecov.io/github/caronc/apprise)
2019-02-05 02:28:03 +01:00
[![PyPi ](https://img.shields.io/pypi/dm/apprise.svg?style=flat-square )](https://pypi.org/project/apprise/)
2017-11-29 05:25:25 +01:00
2017-11-25 22:51:46 +01:00
## Supported Notifications
2018-12-16 21:44:28 +01:00
The section identifies all of the services supported by this library. [Check out the wiki for more information on the supported modules here ](https://github.com/caronc/apprise/wiki ).
2017-11-25 22:51:46 +01:00
### Popular Notification Services
The table below identifies the services this tool supports and some example service urls you need to use in order to take advantage of it.
| Notification Service | Service ID | Default Port | Example Syntax |
| -------------------- | ---------- | ------------ | -------------- |
2019-02-02 19:11:51 +01:00
| [AWS SNS ](https://github.com/caronc/apprise/wiki/Notify_sns ) | sns:// | (TCP) 443 | sns://AccessKeyID/AccessSecretKey/RegionName/+PhoneNo< br /> sns://AccessKeyID/AccessSecretKey/RegionName/+PhoneNo1/+PhoneNo2/+PhoneNoN< br /> sns://AccessKeyID/AccessSecretKey/RegionName/Topic< br /> sns://AccessKeyID/AccessSecretKey/RegionName/Topic1/Topic2/TopicN
2017-12-11 03:28:00 +01:00
| [Boxcar ](https://github.com/caronc/apprise/wiki/Notify_boxcar ) | boxcar:// | (TCP) 443 | boxcar://hostname< br /> boxcar://hostname/@tag< br /> boxcar://hostname/device_token< br /> boxcar://hostname/device_token1/device_token2/device_tokenN< br /> boxcar://hostname/@tag/@tag2/device_token
2018-02-26 01:59:37 +01:00
| [Discord ](https://github.com/caronc/apprise/wiki/Notify_discord ) | discord:// | (TCP) 443 | discord://webhook_id/webhook_token< br /> discord://avatar@webhook_id/webhook_token
2019-02-03 07:39:14 +01:00
| [Dbus ](https://github.com/caronc/apprise/wiki/Notify_dbus ) | dbus://< br /> qt://< br /> glib://< br /> kde:// | n/a | dbus://< br /> qt://< br /> glib://< br /> kde://
2018-03-05 03:06:41 +01:00
| [Emby ](https://github.com/caronc/apprise/wiki/Notify_emby ) | emby:// or embys:// | (TCP) 8096 | emby://user@hostname/< br /> emby://user:password@hostname
2017-11-25 22:51:46 +01:00
| [Faast ](https://github.com/caronc/apprise/wiki/Notify_faast ) | faast:// | (TCP) 443 | faast://authorizationtoken
2019-03-18 00:27:34 +01:00
| [Flock ](https://github.com/caronc/apprise/wiki/Notify_flock ) | flock:// | (TCP) 443 | flock://token< br /> flock://botname@token< br /> flock://app_token/u:userid< br /> flock://app_token/g:channel_id< br /> flock://app_token/u:userid/g:channel_id
2019-03-25 03:45:44 +01:00
| [Gitter ](https://github.com/caronc/apprise/wiki/Notify_gitter ) | gitter:// | (TCP) 443 | gitter://token/room< br /> gitter://token/room1/room2/roomN
2019-01-30 02:09:32 +01:00
| [Gnome ](https://github.com/caronc/apprise/wiki/Notify_gnome ) | gnome:// | n/a | gnome://
2019-03-12 02:17:55 +01:00
| [Gotify ](https://github.com/caronc/apprise/wiki/Notify_gotify ) | gotify:// or gotifys:// | (TCP) 80 or 443 | gotify://hostname/token< br /> gotifys://hostname/token?priority=high
2018-02-26 02:47:07 +01:00
| [Growl ](https://github.com/caronc/apprise/wiki/Notify_growl ) | growl:// | (UDP) 23053 | growl://hostname< br /> growl://hostname:portno< br /> growl://password@hostname< br /> growl://password@hostname:port</ br > **Note**: you can also use the get parameter _version_ which can allow the growl request to behave using the older v1.x protocol. An example would look like: growl://hostname?version=1
2019-02-17 19:51:35 +01:00
| [IFTTT ](https://github.com/caronc/apprise/wiki/Notify_ifttt ) | ifttt:// | (TCP) 443 | ifttt://webhooksID/Event< br /> ifttt://webhooksID/Event1/Event2/EventN< br /> ifttt://webhooksID/Event1/?+Key=Value< br /> ifttt://webhooksID/Event1/?-Key=value1
2017-11-25 22:51:46 +01:00
| [Join ](https://github.com/caronc/apprise/wiki/Notify_join ) | join:// | (TCP) 443 | join://apikey/device< br /> join://apikey/device1/device2/deviceN/< br /> join://apikey/group< br /> join://apikey/groupA/groupB/groupN< br /> join://apikey/DeviceA/groupA/groupN/DeviceN/
| [KODI ](https://github.com/caronc/apprise/wiki/Notify_kodi ) | kodi:// or kodis:// | (TCP) 8080 or 443 | kodi://hostname< br /> kodi://user@hostname< br /> kodi://user:password@hostname:port
2019-04-27 23:41:20 +02:00
| [Mailgun ](https://github.com/caronc/apprise/wiki/Notify_mailgun ) | mailgun:// | (TCP) 443 | mailgun://user@hostname/apikey< br /> mailgun://user@hostname/apikey/email< br /> mailgun://user@hostname/apikey/email1/email2/emailN< br /> mailgun://user@hostname/apikey/?name="From%20User"
2019-03-17 19:20:51 +01:00
| [Matrix ](https://github.com/caronc/apprise/wiki/Notify_matrix ) | matrix:// or matrixs:// | (TCP) 80 or 443 | matrix://hostname< br /> matrix://user@hostname< br /> matrixs://user:pass@hostname:port/#room_alias< br /> matrixs://user:pass@hostname:port/!room_id< br /> matrixs://user:pass@hostname:port/#room_alias/!room_id/#room2< br /> matrixs://token@hostname:port/?webhook=matrix< br /> matrix://user:token@hostname/?webhook=slack& format=markdown
2017-11-25 22:51:46 +01:00
| [Mattermost ](https://github.com/caronc/apprise/wiki/Notify_mattermost ) | mmost:// | (TCP) 8065 | mmost://hostname/authkey< br /> mmost://hostname:80/authkey< br /> mmost://user@hostname:80/authkey< br /> mmost://hostname/authkey?channel=channel< br /> mmosts://hostname/authkey< br /> mmosts://user@hostname/authkey< br />
2019-04-04 04:39:51 +02:00
| [Microsoft Teams ](https://github.com/caronc/apprise/wiki/Notify_msteams ) | msteams:// | (TCP) 443 | msteams://TokenA/TokenB/TokenC/
2017-11-25 22:51:46 +01:00
| [Prowl ](https://github.com/caronc/apprise/wiki/Notify_prowl ) | prowl:// | (TCP) 443 | prowl://apikey< br /> prowl://apikey/providerkey
| [PushBullet ](https://github.com/caronc/apprise/wiki/Notify_pushbullet ) | pbul:// | (TCP) 443 | pbul://accesstoken< br /> pbul://accesstoken/#channel< br /> pbul://accesstoken/A_DEVICE_ID< br /> pbul://accesstoken/email@address.com< br /> pbul://accesstoken/#channel/#channel2/email@address.net/DEVICE
2019-02-09 07:02:05 +01:00
| [Pushjet ](https://github.com/caronc/apprise/wiki/Notify_pushjet ) | pjet:// or pjets:// | (TCP) 80 or 443 | pjet://secret@hostname< br /> pjet://secret@hostname:port< br /> pjets://secret@hostname< br /> pjets://secret@hostname:port
2019-01-31 06:15:50 +01:00
| [Pushed ](https://github.com/caronc/apprise/wiki/Notify_pushed ) | pushed:// | (TCP) 443 | pushed://appkey/appsecret/< br /> pushed://appkey/appsecret/#ChannelAlias< br /> pushed://appkey/appsecret/#ChannelAlias1/#ChannelAlias2/#ChannelAliasN< br /> pushed://appkey/appsecret/@UserPushedID< br /> pushed://appkey/appsecret/@UserPushedID1/@UserPushedID2/@UserPushedIDN
2019-03-05 05:33:02 +01:00
| [Pushover ](https://github.com/caronc/apprise/wiki/Notify_pushover ) | pover:// | (TCP) 443 | pover://user@token< br /> pover://user@token/DEVICE< br /> pover://user@token/DEVICE1/DEVICE2/DEVICEN< br /> **Note**: you must specify both your user_id and token
2017-11-25 22:51:46 +01:00
| [Rocket.Chat ](https://github.com/caronc/apprise/wiki/Notify_rocketchat ) | rocket:// or rockets:// | (TCP) 80 or 443 | rocket://user:password@hostname/RoomID/Channel< br /> rockets://user:password@hostname:443/Channel1/Channel1/RoomID< br /> rocket://user:password@hostname/Channel
2019-02-09 23:24:32 +01:00
| [Ryver ](https://github.com/caronc/apprise/wiki/Notify_ryver ) | ryver:// | (TCP) 443 | ryver://Organization/Token< br /> ryver://botname@Organization/Token
2019-05-11 21:02:56 +02:00
| [Slack ](https://github.com/caronc/apprise/wiki/Notify_slack ) | slack:// | (TCP) 443 | slack://TokenA/TokenB/TokenC/< br /> slack://TokenA/TokenB/TokenC/Channel< br /> slack://botname@TokenA/TokenB/TokenC/Channel< br /> slack://user@TokenA/TokenB/TokenC/Channel1/Channel2/ChannelN
2017-11-25 22:51:46 +01:00
| [Telegram ](https://github.com/caronc/apprise/wiki/Notify_telegram ) | tgram:// | (TCP) 443 | tgram://bottoken/ChatID< br /> tgram://bottoken/ChatID1/ChatID2/ChatIDN
2019-05-09 16:06:20 +02:00
| [Twilio ](https://github.com/caronc/apprise/wiki/Notify_twilio ) | twilio:// | (TCP) 443 | twilio://AccountSid:AuthToken@FromPhoneNo< br /> twilio://AccountSid:AuthToken@FromPhoneNo/ToPhoneNo< br /> twilio://AccountSid:AuthToken@FromPhoneNo/ToPhoneNo1/ToPhoneNo2/ToPhoneNoN/< br /> twilio://AccountSid:AuthToken@ShortCode/ToPhoneNo< br /> twilio://AccountSid:AuthToken@ShortCode/ToPhoneNo1/ToPhoneNo2/ToPhoneNoN/
2017-11-25 22:51:46 +01:00
| [Twitter ](https://github.com/caronc/apprise/wiki/Notify_twitter ) | tweet:// | (TCP) 443 | tweet://user@CKey/CSecret/AKey/ASecret
| [XBMC ](https://github.com/caronc/apprise/wiki/Notify_xbmc ) | xbmc:// or xbmcs:// | (TCP) 8080 or 443 | xbmc://hostname< br /> xbmc://user@hostname< br /> xbmc://user:password@hostname:port
2019-03-21 03:41:32 +01:00
| [XMPP ](https://github.com/caronc/apprise/wiki/Notify_xmpp ) | xmpp:// or xmpps:// | (TCP) 5222 or 5223 | xmpp://password@hostname< br /> xmpp://user:password@hostname< br /> xmpps://user:password@hostname:port?jid=user@hostname/resource< br /> xmpps://password@hostname/target@myhost, target2@myhost/resource
2018-07-01 18:40:56 +02:00
| [Windows Notification ](https://github.com/caronc/apprise/wiki/Notify_windows ) | windows:// | n/a | windows://
2019-04-06 06:33:44 +02:00
| [Webex Teams (Cisco) ](https://github.com/caronc/apprise/wiki/Notify_wxteams ) | wxteams:// | (TCP) 443 | wxteams://Token
2018-07-01 18:40:56 +02:00
2017-11-25 22:51:46 +01:00
### Email Support
| Service ID | Default Port | Example Syntax |
| ---------- | ------------ | -------------- |
2019-01-26 20:51:37 +01:00
| [mailto:// ](https://github.com/caronc/apprise/wiki/Notify_email ) | (TCP) 25 | mailto://userid:pass@domain.com< br /> mailto://domain.com?user=userid& pass=password< br /> mailto://domain.com:2525?user=userid& pass=password< br /> mailto://user@gmail.com& pass=password< br /> mailto://mySendingUsername:mySendingPassword@example.com?to=receivingAddress@example.com< br /> mailto://userid:password@example.com?smtp=mail.example.com& from=noreply@example.com& name=no%20reply
| [mailtos:// ](https://github.com/caronc/apprise/wiki/Notify_email ) | (TCP) 587 | mailtos://userid:pass@domain.com< br /> mailtos://domain.com?user=userid& pass=password< br /> mailtos://domain.com:465?user=userid& pass=password< br /> mailtos://user@hotmail.com& pass=password< br /> mailtos://mySendingUsername:mySendingPassword@example.com?to=receivingAddress@example.com< br /> mailtos://userid:password@example.com?smtp=mail.example.com& from=noreply@example.com& name=no%20reply
2017-11-25 22:51:46 +01:00
2018-12-06 18:00:55 +01:00
Apprise have some email services built right into it (such as yahoo, fastmail, hotmail, gmail, etc) that greatly simplify the mailto:// service. See more details [here ](https://github.com/caronc/apprise/wiki/Notify_email ).
2017-11-25 22:51:46 +01:00
### Custom Notifications
| Post Method | Service ID | Default Port | Example Syntax |
| -------------------- | ---------- | ------------ | -------------- |
| [JSON ](https://github.com/caronc/apprise/wiki/Notify_Custom_JSON ) | json:// or jsons:// | (TCP) 80 or 443 | json://hostname< br /> json://user@hostname< br /> json://user:password@hostname:port< br /> json://hostname/a/path/to/post/to
| [XML ](https://github.com/caronc/apprise/wiki/Notify_Custom_XML ) | xml:// or xmls:// | (TCP) 80 or 443 | xml://hostname< br /> xml://user@hostname< br /> xml://user:password@hostname:port< br /> xml://hostname/a/path/to/post/to
2017-11-30 01:51:18 +01:00
## Installation
2019-02-01 03:28:18 +01:00
The easiest way is to install this package is from pypi:
2017-11-30 01:51:18 +01:00
```bash
pip install apprise
```
## Command Line
2018-03-14 00:26:51 +01:00
A small command line tool is also provided with this package called *apprise* . If you know the server url's you wish to notify, you can simply provide them all on the command line and send your notifications that way:
2017-11-30 01:51:18 +01:00
```bash
2019-03-29 05:12:12 +01:00
# Send a notification to as many servers as you want
# as you can easily chain one after another:
2018-03-14 00:26:51 +01:00
apprise -t 'my title' -b 'my notification body' \
2017-11-30 01:51:18 +01:00
'mailto://myemail:mypass@gmail.com' \
'pbul://o.gn5kj6nfhv736I7jC3cj3QLRiyhgl98b'
# If you don't specify a --body (-b) then stdin is used allowing
# you to use the tool as part of your every day administration:
2018-03-14 00:26:51 +01:00
cat /proc/cpuinfo | apprise -t 'cpu info' \
2017-11-30 01:51:18 +01:00
'mailto://myemail:mypass@gmail.com'
2019-03-29 05:12:12 +01:00
# The title field is totally optional
uptime | apprise \
'discord:///4174216298/JHMHI8qBe7bk2ZwO5U711o3dV_js'
2017-11-30 01:51:18 +01:00
```
2019-03-05 05:33:02 +01:00
### Configuration Files
No one wants to put there credentials out for everyone to see on the command line. No problem *apprise* also supports configuration files. It can handle both a specific [YAML format ](https://github.com/caronc/apprise/wiki/config_yaml ) or a very simple [TEXT format ](https://github.com/caronc/apprise/wiki/config_text ). You can also pull these configuration files via an HTTP query too! More information concerning Apprise configuration can be found [here ](https://github.com/caronc/apprise/wiki/config )
```bash
# By default now if no url or configuration is specified aprise will
# peek for this data in:
# ~/.apprise
# ~/.apprise.yml
# ~/.config/apprise
# ~/.config/apprise.yml
# If you loaded one of those files, your command line gets really easy:
apprise -t 'my title' -b 'my notification body'
# Know the location of the configuration source? No problem, just
# specify it.
apprise -t 'my title' -b 'my notification body' \
--config=/path/to/my/config.yml
# Got lots of configuration locations? No problem, specify them all:
apprise -t 'my title' -b 'my notification body' \
--config=/path/to/my/config.yml \
--config=https://localhost/my/apprise/config
```
2017-11-30 01:51:18 +01:00
## Developers
To send a notification from within your python application, just do the following:
```python
import apprise
2019-03-05 05:33:02 +01:00
# Create an Apprise instance
2017-12-03 08:00:23 +01:00
apobj = apprise.Apprise()
2017-11-30 01:51:18 +01:00
# Add all of the notification services by their server url.
# A sample email notification
apobj.add('mailto://myemail:mypass@gmail.com')
# A sample pushbullet notification
apobj.add('pbul://o.gn5kj6nfhv736I7jC3cj3QLRiyhgl98b')
# Then notify these services any time you desire. The below would
# notify all of the services loaded into our Apprise object.
apobj.notify(
body='what a great notification service!',
2019-02-18 04:21:59 +01:00
title='my notification title',
2017-11-30 01:51:18 +01:00
)
```
2018-12-16 21:44:28 +01:00
2019-03-05 05:33:02 +01:00
### Configuration Files
2019-03-29 05:12:12 +01:00
Developers need access to configuration files too. The good news is their use just involves declaring another object (called *AppriseConfig* ) that the *Apprise* object can ingest. You can also freely mix and match config and notification entries as often as you wish!
2019-03-05 05:33:02 +01:00
```python
import apprise
# Create an Apprise instance
apobj = apprise.Apprise()
# Create an Config instance
2019-03-06 01:40:36 +01:00
config = apprise.AppriseConfig()
2019-03-05 05:33:02 +01:00
# Add a configuration source:
config.add('/path/to/my/config.yml')
# Add another...
config.add('https://myserver:8080/path/to/config')
# Make sure to add our config into our apprise object
apobj.add(config)
# You can mix and match; add an entry directly if you want too
2019-03-29 05:12:12 +01:00
# In this entry we associate the 'admin' tag with our notification
apobj.add('mailto://myemail:mypass@gmail.com', tag='admin')
2019-03-05 05:33:02 +01:00
# Then notify these services any time you desire. The below would
2019-03-06 01:40:36 +01:00
# notify all of the services loaded into our Apprise object; this includes
# all items identified in the configuration files.
2019-03-05 05:33:02 +01:00
apobj.notify(
body='what a great notification service!',
title='my notification title',
)
2019-03-06 01:40:36 +01:00
# If you're using tagging, then you can load all of your notifications
2019-03-29 05:12:12 +01:00
# but only selectively notify the ones associated with one or more
# matched tags:
2019-03-06 01:40:36 +01:00
apobj.notify(
body='send a notification to our admin group'
title='Attention Admins',
2019-03-29 05:12:12 +01:00
# notify any services tagged with the 'admin' tag
2019-03-06 01:40:36 +01:00
tag='admin',
)
2019-03-05 05:33:02 +01:00
```
2019-03-29 05:12:12 +01:00
If you're interested in reading more about this and other methods on how to customize your own notifications, please check out the wiki at https://github.com/caronc/apprise/wiki/Development_API