[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-2727":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":20,"compositeScore":21,"rankGlobal":10,"rankLanguage":10,"license":22,"archived":23,"fork":23,"defaultBranch":24,"hasWiki":25,"hasPages":23,"topics":26,"createdAt":10,"pushedAt":10,"updatedAt":37,"readmeContent":38,"aiSummary":39,"trendingCount":16,"starSnapshotCount":16,"syncStatus":40,"lastSyncTime":41,"discoverSource":42},2727,"apprise","caronc\u002Fapprise","caronc","Apprise - Push Notifications that work with just about every platform!","https:\u002F\u002Fhub.docker.com\u002Fr\u002Fcaronc\u002Fapprise",null,"Python",16720,608,74,23,0,9,45,177,38,43.35,"BSD 2-Clause \"Simplified\" License",false,"master",true,[27,5,28,29,30,31,32,33,34,35,36],"alerts","framework","notification-api","notification-hub","notification-service","notifications","notifier","notify","push-notifications","python","2026-06-12 02:00:43","![Apprise Logo](https:\u002F\u002Fraw.githubusercontent.com\u002Fcaronc\u002Fapprise\u002Fmaster\u002Fapprise\u002Fassets\u002Fthemes\u002Fdefault\u002Fapprise-logo.png)\n\n\u003Chr\u002F>\n\n**ap·prise** \u002F *verb*\u003Cbr\u002F>\nTo inform or tell (someone). To make one aware of something.\n\u003Chr\u002F>\n\n*Apprise* allows you to send a notification to *almost* all of the most popular *notification* services available to us today such as: Telegram, Discord, Slack, Amazon SNS, Gotify, etc.\n\n* One notification library to rule them all.\n* A common and intuitive notification syntax.\n* Supports the handling of images and attachments (_to the notification services that will accept them_).\n* It's incredibly lightweight.\n* Amazing response times because all messages sent asynchronously.\n\nDevelopers who wish to provide a notification service no longer need to research each and every one out there. They no longer need to try to adapt to the new ones that comeout thereafter. 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.\n\nSystem Administrators and DevOps who wish to send a notification now no longer need to find the right tool for the job. Everything is already wrapped and supported within the `apprise` command line tool (CLI) that ships with this product.\n\n[![Paypal](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fpaypal-donate-green.svg)](https:\u002F\u002Fwww.paypal.com\u002Fdonate\u002F?hosted_button_id=CR6YF7KLQWQ5E)\n[![Follow](https:\u002F\u002Fimg.shields.io\u002Ftwitter\u002Ffollow\u002Fl2gnux)](https:\u002F\u002Ftwitter.com\u002Fl2gnux\u002F)\u003Cbr\u002F>\n[![Discord](https:\u002F\u002Fimg.shields.io\u002Fdiscord\u002F558793703356104724.svg?colorB=7289DA&label=Discord&logo=Discord&logoColor=7289DA&style=flat-square)](https:\u002F\u002Fdiscord.gg\u002FMMPeN2D)\n[![Python](https:\u002F\u002Fimg.shields.io\u002Fpypi\u002Fpyversions\u002Fapprise.svg?style=flat-square)](https:\u002F\u002Fpypi.org\u002Fproject\u002Fapprise\u002F)\n[![Build Status](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise\u002Factions\u002Fworkflows\u002Ftests.yml\u002Fbadge.svg)](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise\u002Factions\u002Fworkflows\u002Ftests.yml)\n[![Lines of Code](https:\u002F\u002Fraw.githubusercontent.com\u002Fcaronc\u002Fapprise\u002Fmaster\u002F.github\u002Fbadges\u002Floc.svg)](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise\u002Factions\u002Fworkflows\u002Floc-badge.yml)\n[![CodeCov Status](https:\u002F\u002Fcodecov.io\u002Fgithub\u002Fcaronc\u002Fapprise\u002Fbranch\u002Fmaster\u002Fgraph\u002Fbadge.svg)](https:\u002F\u002Fcodecov.io\u002Fgithub\u002Fcaronc\u002Fapprise)\n[![PyPi Downloads](https:\u002F\u002Fimg.shields.io\u002Fpepy\u002Fdt\u002Fapprise.svg?style=flat-square)](https:\u002F\u002Fpypi.org\u002Fproject\u002Fapprise\u002F)\n\n# Table of Contents\n\u003C!--ts-->\n* [Supported Notifications](#supported-notifications)\n  * [Productivity Based Notifications](#productivity-based-notifications)\n  * [SMS Notifications](#sms-notifications)\n  * [Desktop Notifications](#desktop-notifications)\n  * [Email Notifications](#email-notifications)\n  * [Custom Notifications](#custom-notifications)\n* [Installation](#installation)\n* [Command Line Usage](#command-line-usage)\n  * [Configuration Files](#cli-configuration-files)\n  * [File Attachments](#cli-file-attachments)\n  * [Loading Custom Notifications\u002FHooks](#cli-loading-custom-notificationshooks)\n  * [Environment Variables](#cli-environment-variables)\n* [Developer API Usage](#developer-api-usage)\n  * [Configuration Files](#api-configuration-files)\n  * [File Attachments](#api-file-attachments)\n  * [Loading Custom Notifications\u002FHooks](#api-loading-custom-notificationshooks)\n* [Persistent Storage](#persistent-storage)\n* [More Supported Links and Documentation](#want-to-learn-more)\n\u003C!--te-->\n\nVisit the [Official Documentation](https:\u002F\u002Fappriseit.com\u002Fgetting-started\u002F) site for more information on Apprise.\n\n# Supported Notifications\n\nThe section identifies all of the services supported by this library. [Check out the wiki for more information on the supported modules here](https:\u002F\u002Fappriseit.com\u002F).\n\n## Productivity Based Notifications\n\nThe table below identifies the services this tool supports and some example service urls you need to use in order to take advantage of it. Click on any of the services listed below to get more details on how you can configure Apprise to access them. If you're having trouble constructing your own URL; try our [Apprise URL Builder](https:\u002F\u002Fappriseit.com\u002Ftools\u002Furl-builder\u002F) out.\n\n| Notification Service | Service ID | Default Port | Example Syntax |\n| -------------------- | ---------- | ------------ | -------------- |\n| [Apprise API](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fapprise_api\u002F)  | apprise:\u002F\u002F or apprises:\u002F\u002F | (TCP) 80 or 443 | apprise:\u002F\u002Fhostname\u002FToken\n| [AWS SES](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fses\u002F)  | ses:\u002F\u002F   | (TCP) 443   | ses:\u002F\u002Fuser@domain\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u003Cbr\u002F>ses:\u002F\u002Fuser@domain\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u002Femail1\u002Femail2\u002FemailN\n| [Bark](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fbark\u002F)  | bark:\u002F\u002F   | (TCP) 80 or 443   | bark:\u002F\u002Fhostname\u003Cbr \u002F>bark:\u002F\u002Fhostname\u002Fdevice_key\u003Cbr \u002F>bark:\u002F\u002Fhostname\u002Fdevice_key1\u002Fdevice_key2\u002Fdevice_keyN\u003Cbr\u002F>barks:\u002F\u002Fhostname\u003Cbr \u002F>barks:\u002F\u002Fhostname\u002Fdevice_key\u003Cbr \u002F>barks:\u002F\u002Fhostname\u002Fdevice_key1\u002Fdevice_key2\u002Fdevice_keyN\n| [Blink(1)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fblink1\u002F) | blink1:\u002F\u002F | USB | blink1:\u002F\u002F\u003Cbr \u002F>blink1:\u002F\u002Fserial\u002F\n| [BlueSky](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fbluesky\u002F) | bluesky:\u002F\u002F  | (TCP) 443   | bluesky:\u002F\u002FHandle:AppPw\u003Cbr \u002F>bluesky:\u002F\u002FHandle:AppPw\u002FTargetHandle\u003Cbr \u002F>bluesky:\u002F\u002FHandle:AppPw\u002FTargetHandle1\u002FTargetHandle2\u002FTargetHandleN\n| [Brevo](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fbrevo\u002F) | brevo:\u002F\u002F  | (TCP) 443   | brevo:\u002F\u002FAPIToken:FromEmail\u002F\u003Cbr \u002F>brevo:\u002F\u002FAPIToken:FromEmail\u002FToEmail\u003Cbr \u002F>brevo:\u002F\u002FAPIToken:FromEmail\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\n| [Chanify](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fchanify\u002F) | chantify:\u002F\u002F    | (TCP) 443    | chantify:\u002F\u002Ftoken\n| [Discord](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fdiscord\u002F)  | discord:\u002F\u002F   | (TCP) 443   | discord:\u002F\u002Fwebhook_id\u002Fwebhook_token\u003Cbr \u002F>discord:\u002F\u002Favatar@webhook_id\u002Fwebhook_token\n| [Dot.](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fdot\u002F)  | dot:\u002F\u002F | (TCP) 443 | dot:\u002F\u002Fapikey@device_id\u002Ftext\u002F\u003Cbr \u002F>dot:\u002F\u002Fapikey@device_id\u002Fimage\u002F\u003Cbr \u002F>**Note**: `device_id` is the Quote\u002F0 hardware serial\n| [Emby](https:\u002F\u002Fappriseit.com\u002Fservices\u002Femby\u002F)  | emby:\u002F\u002F or embys:\u002F\u002F | (TCP) 8096 | emby:\u002F\u002Fuser@hostname\u002F\u003Cbr \u002F>emby:\u002F\u002Fuser:password@hostname\n| [Enigma2](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fenigma2\u002F)  | enigma2:\u002F\u002F or enigma2s:\u002F\u002F | (TCP) 80 or 443 | enigma2:\u002F\u002Fhostname\n| [Evolution API](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fevolution\u002F) | evolution:\u002F\u002F or evolutions:\u002F\u002F | (TCP) 80 or 443 | evolution:\u002F\u002Fapikey@hostname\u002Finstance\u002FToPhoneNo\u003Cbr\u002F>evolution:\u002F\u002Fapikey@hostname:port\u002Finstance\u002FToPhoneNo\u003Cbr\u002F>evolution:\u002F\u002Fapikey@hostname\u002Finstance\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [FCM](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ffcm\u002F) | fcm:\u002F\u002F    | (TCP) 443    | fcm:\u002F\u002Fproject@apikey\u002FDEVICE_ID\u003Cbr \u002F>fcm:\u002F\u002Fproject@apikey\u002F#TOPIC\u003Cbr\u002F>fcm:\u002F\u002Fproject@apikey\u002FDEVICE_ID1\u002F#topic1\u002F#topic2\u002FDEVICE_ID2\u002F\n| [Feishu](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ffeishu\u002F) | feishu:\u002F\u002F    | (TCP) 443    | feishu:\u002F\u002Ftoken\n| [Flock](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fflock\u002F) | flock:\u002F\u002F    | (TCP) 443    | flock:\u002F\u002Ftoken\u003Cbr\u002F>flock:\u002F\u002Fbotname@token\u003Cbr\u002F>flock:\u002F\u002Fapp_token\u002Fu:userid\u003Cbr\u002F>flock:\u002F\u002Fapp_token\u002Fg:channel_id\u003Cbr\u002F>flock:\u002F\u002Fapp_token\u002Fu:userid\u002Fg:channel_id\n| [Google Chat](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fgooglechat\u002F) | gchat:\u002F\u002F    | (TCP) 443    | gchat:\u002F\u002Fworkspace\u002Fkey\u002Ftoken\n| [Gotify](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fgotify\u002F) | gotify:\u002F\u002F or gotifys:\u002F\u002F   | (TCP) 80 or 443    | gotify:\u002F\u002Fhostname\u002Ftoken\u003Cbr \u002F>gotifys:\u002F\u002Fhostname\u002Ftoken?priority=high\n| [Growl](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fgrowl\u002F)  | growl:\u002F\u002F   | (UDP) 23053   | growl:\u002F\u002Fhostname\u003Cbr \u002F>growl:\u002F\u002Fhostname:portno\u003Cbr \u002F>growl:\u002F\u002Fpassword@hostname\u003Cbr \u002F>growl:\u002F\u002Fpassword@hostname:port\u003C\u002Fbr>**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:\u002F\u002Fhostname?version=1\n| [Guilded](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fguilded\u002F)  | guilded:\u002F\u002F   | (TCP) 443   | guilded:\u002F\u002Fwebhook_id\u002Fwebhook_token\u003Cbr \u002F>guilded:\u002F\u002Favatar@webhook_id\u002Fwebhook_token\n| [Home Assistant](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fhomeassistant\u002F)       | hassio:\u002F\u002F or hassios:\u002F\u002F   | (TCP) 8123 or 443 | hassio:\u002F\u002Fhostname\u002Faccesstoken\u003Cbr \u002F>hassio:\u002F\u002Fuser@hostname\u002Faccesstoken\u003Cbr \u002F>hassio:\u002F\u002Fuser:password@hostname:port\u002Faccesstoken\u003Cbr \u002F>hassio:\u002F\u002Fhostname\u002Foptional\u002Fpath\u002Faccesstoken\n| [IFTTT](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fifttt\u002F) | ifttt:\u002F\u002F    | (TCP) 443    | ifttt:\u002F\u002FwebhooksID\u002FEvent\u003Cbr \u002F>ifttt:\u002F\u002FwebhooksID\u002FEvent1\u002FEvent2\u002FEventN\u003Cbr\u002F>ifttt:\u002F\u002FwebhooksID\u002FEvent1\u002F?+Key=Value\u003Cbr\u002F>ifttt:\u002F\u002FwebhooksID\u002FEvent1\u002F?-Key=value1\n| [IRC](https:\u002F\u002Fappriseit.com\u002Fservices\u002Firc\u002F) | irc:\u002F\u002F or ircs:\u002F\u002F   | (TCP) 6667 or 6697 | ircs:\u002F\u002Fuser:pass@irc.server\u002F@user\u003Cbr \u002F> ircs:\u002F\u002Fuser:pass@irc.server\u002F#channel?join=true&mode=nickserv\u003Cbr\u002F>ircs:\u002F\u002Fuser:pass@znc.server\u002F@user1\u002F@user2\u002F@user3\u002F#channel1\n| [Jellyfin](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fjellyfin\u002F)  | jellyfin:\u002F\u002F or jellyfins:\u002F\u002F | (TCP) 8096 | jellyfin:\u002F\u002Fuser@hostname\u002F\u003Cbr \u002F>jellyfins:\u002F\u002Fuser:password@hostname\n| [Jira](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fjira\u002F) | jira:\u002F\u002F | (TCP) 443 | jira:\u002F\u002FAPIKey\u003Cbr\u002F>jira:\u002F\u002FAPIKey\u002F@UserID\u003Cbr\u002F>jira:\u002F\u002FAPIKey\u002F#Team\u003Cbr\u002F>jira:\u002F\u002FAPIKey\u002F\\*Schedule\u003Cbr\u002F>jira:\u002F\u002FAPIKey\u002F^Escalation\n| [Join](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fjoin\u002F) | join:\u002F\u002F   | (TCP) 443    | join:\u002F\u002Fapikey\u002Fdevice\u003Cbr \u002F>join:\u002F\u002Fapikey\u002Fdevice1\u002Fdevice2\u002FdeviceN\u002F\u003Cbr \u002F>join:\u002F\u002Fapikey\u002Fgroup\u003Cbr \u002F>join:\u002F\u002Fapikey\u002FgroupA\u002FgroupB\u002FgroupN\u003Cbr \u002F>join:\u002F\u002Fapikey\u002FDeviceA\u002FgroupA\u002FgroupN\u002FDeviceN\u002F\n| [KODI](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fkodi\u002F) | kodi:\u002F\u002F or kodis:\u002F\u002F    | (TCP) 8080 or 443   | kodi:\u002F\u002Fhostname\u003Cbr \u002F>kodi:\u002F\u002Fuser@hostname\u003Cbr \u002F>kodi:\u002F\u002Fuser:password@hostname:port\n| [Kumulos](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fkumulos\u002F) | kumulos:\u002F\u002F | (TCP) 443 | kumulos:\u002F\u002Fapikey\u002Fserverkey\n| [LaMetric Time](https:\u002F\u002Fappriseit.com\u002Fservices\u002Flametric\u002F) | lametric:\u002F\u002F | (TCP) 443 | lametric:\u002F\u002Fapikey@device_ipaddr\u003Cbr\u002F>lametric:\u002F\u002Fapikey@hostname:port\u003Cbr\u002F>lametric:\u002F\u002Fclient_id@client_secret\n| [Lark](https:\u002F\u002Fappriseit.com\u002Fservices\u002Flark\u002F) | lark:\u002F\u002F  | (TCP) 443   | lark:\u002F\u002FBotToken\n| [Line](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fline\u002F) | line:\u002F\u002F | (TCP) 443 | line:\u002F\u002FToken@User\u003Cbr\u002F>line:\u002F\u002FToken\u002FUser1\u002FUser2\u002FUserN\n| [Mailgun](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmailgun\u002F) | mailgun:\u002F\u002F | (TCP) 443 | mailgun:\u002F\u002Fuser@hostname\u002Fapikey\u003Cbr \u002F>mailgun:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail\u003Cbr \u002F>mailgun:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail1\u002Femail2\u002FemailN\u003Cbr \u002F>mailgun:\u002F\u002Fuser@hostname\u002Fapikey\u002F?name=\"From%20User\"\n| [Mastodon](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmastodon\u002F) | mastodon:\u002F\u002F or mastodons:\u002F\u002F| (TCP) 80 or 443  | mastodon:\u002F\u002Faccess_key@hostname\u003Cbr \u002F>mastodon:\u002F\u002Faccess_key@hostname\u002F@user\u003Cbr \u002F>mastodon:\u002F\u002Faccess_key@hostname\u002F@user1\u002F@user2\u002F@userN\n| [Matrix](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmatrix\u002F) | matrix:\u002F\u002F or matrixs:\u002F\u002F  | (TCP) 80 or 443 | matrix:\u002F\u002Fhostname\u003Cbr \u002F>matrix:\u002F\u002Fuser@hostname\u003Cbr \u002F>matrixs:\u002F\u002Fuser:pass@hostname:port\u002F#room_alias\u003Cbr \u002F>matrixs:\u002F\u002Fuser:pass@hostname:port\u002F!room_id\u003Cbr \u002F>matrixs:\u002F\u002Fuser:pass@hostname:port\u002F#room_alias\u002F!room_id\u002F#room2\u003Cbr \u002F>matrixs:\u002F\u002Ftoken@hostname:port\u002F?webhook=matrix\u003Cbr \u002F>matrix:\u002F\u002Fuser:token@hostname\u002F?webhook=slack&format=markdown\n| [Mattermost](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmattermost\u002F) | mmost:\u002F\u002F or mmosts:\u002F\u002F | (TCP) 8065 | mmost:\u002F\u002Fhostname\u002Fauthkey\u003Cbr \u002F>mmost:\u002F\u002Fhostname:80\u002Fauthkey\u003Cbr \u002F>mmost:\u002F\u002Fuser@hostname:80\u002Fauthkey\u003Cbr \u002F>mmost:\u002F\u002Fhostname\u002Fauthkey?channel=channel\u003Cbr \u002F>mmosts:\u002F\u002Fhostname\u002Fauthkey\u003Cbr \u002F>mmosts:\u002F\u002Fuser@hostname\u002Fauthkey\u003Cbr \u002F>\n| [Microsoft Power Automate \u002F Workflows (MSTeams)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fworkflows\u002F) | workflows:\u002F\u002F  | (TCP) 443   | workflows:\u002F\u002FWorkflowID\u002FSignature\u002F\n| [Microsoft Teams](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmsteams\u002F) | msteams:\u002F\u002F  | (TCP) 443   | msteams:\u002F\u002FTokenA\u002FTokenB\u002FTokenC\u002F\n| [Misskey](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmisskey\u002F) | misskey:\u002F\u002F or misskeys:\u002F\u002F| (TCP) 80 or 443  | misskey:\u002F\u002Faccess_token@hostname\n| [MQTT](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmqtt\u002F) | mqtt:\u002F\u002F  or mqtts:\u002F\u002F | (TCP) 1883 or 8883   | mqtt:\u002F\u002Fhostname\u002Ftopic\u003Cbr \u002F>mqtt:\u002F\u002Fuser@hostname\u002Ftopic\u003Cbr \u002F>mqtts:\u002F\u002Fuser:pass@hostname:9883\u002Ftopic\n| [Nextcloud](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnextcloud\u002F) | ncloud:\u002F\u002F or nclouds:\u002F\u002F | (TCP) 80 or 443 | ncloud:\u002F\u002Fadminuser:pass@host\u002FUser\u003Cbr\u002F>nclouds:\u002F\u002Fadminuser:pass@host\u002FUser1\u002FUser2\u002FUserN\n| [NextcloudTalk](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnextcloudtalk\u002F) | nctalk:\u002F\u002F or nctalks:\u002F\u002F | (TCP) 80 or 443 | nctalk:\u002F\u002Fuser:pass@host\u002FRoomId\u003Cbr\u002F>nctalks:\u002F\u002Fuser:pass@host\u002FRoomId1\u002FRoomId2\u002FRoomIdN\n| [Notica](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnotica\u002F) | notica:\u002F\u002F  | (TCP) 443   | notica:\u002F\u002FToken\u002F\n| [NotificationAPI](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnotificationapi\u002F) | napi:\u002F\u002F  | (TCP) 443   | napi:\u002F\u002FClientID\u002FClientSecret\u002FTarget\u003Cbr \u002F>napi:\u002F\u002FClientID\u002FClientSecret\u002FTarget1\u002FTarget2\u002FTargetN\u003Cbr \u002F>napi:\u002F\u002FMessageType@ClientID\u002FClientSecret\u002FTarget\n| [Notifiarr](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnotifiarr\u002F) | notifiarr:\u002F\u002F | (TCP) 443 | notifiarr:\u002F\u002Fapikey\u002F#channel\u003Cbr \u002F>notifiarr:\u002F\u002Fapikey\u002F#channel1\u002F#channel2\u002F#channeln\n| [Notifico](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fnotifico\u002F) | notifico:\u002F\u002F  | (TCP) 443   | notifico:\u002F\u002FProjectID\u002FMessageHook\u002F\n| [ntfy](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fntfy\u002F) | ntfy:\u002F\u002F  | (TCP) 80 or 443   | ntfy:\u002F\u002Ftopic\u002F\u003Cbr\u002F>ntfys:\u002F\u002Ftopic\u002F\n| [Octopush](https:\u002F\u002Fappriseit.com\u002Fservices\u002Foctopush\u002F) | octopush:\u002F\u002F | (TCP) 443 | octopush:\u002F\u002FAPILogin\u002FAPIKey\u002FTargetPhoneNo\u003Cbr \u002F>octopush:\u002F\u002FSender:APILogin\u002FAPIKey\u002FTargetPhoneNo\u003Cbr \u002F>octopush:\u002F\u002FSender:APILogin\u002FAPIKey\u002FTargetPhoneNo1\u002FTargetPhoneNo2\u002FTargetPhoneNoN\n| [Office 365](https:\u002F\u002Fappriseit.com\u002Fservices\u002Foffice365\u002F) | o365:\u002F\u002F  | (TCP) 443   | o365:\u002F\u002FTenantID:AccountEmail\u002FClientID\u002FClientSecret\u003Cbr \u002F>o365:\u002F\u002FTenantID:AccountEmail\u002FClientID\u002FClientSecret\u002FTargetEmail\u003Cbr \u002F>o365:\u002F\u002FTenantID:AccountEmail\u002FClientID\u002FClientSecret\u002FTargetEmail1\u002FTargetEmail2\u002FTargetEmailN\n| [OneSignal](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fonesignal\u002F) | onesignal:\u002F\u002F | (TCP) 443 | onesignal:\u002F\u002FAppID@APIKey\u002FPlayerID\u003Cbr\u002F>onesignal:\u002F\u002FTemplateID:AppID@APIKey\u002FUserID\u003Cbr\u002F>onesignal:\u002F\u002FAppID@APIKey\u002F#IncludeSegment\u003Cbr\u002F>onesignal:\u002F\u002FAppID@APIKey\u002FEmail\n| [Opsgenie](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fopsgenie\u002F) | opsgenie:\u002F\u002F | (TCP) 443 | opsgenie:\u002F\u002FAPIKey\u003Cbr\u002F>opsgenie:\u002F\u002FAPIKey\u002FUserID\u003Cbr\u002F>opsgenie:\u002F\u002FAPIKey\u002F#Team\u003Cbr\u002F>opsgenie:\u002F\u002FAPIKey\u002F\\*Schedule\u003Cbr\u002F>opsgenie:\u002F\u002FAPIKey\u002F^Escalation\n| [PagerDuty](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpagerduty\u002F) | pagerduty:\u002F\u002F | (TCP) 443 | pagerduty:\u002F\u002FIntegrationKey@ApiKey\u003Cbr\u002F>pagerduty:\u002F\u002FIntegrationKey@ApiKey\u002FSource\u002FComponent\n| [PagerTree](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpagertree\u002F) | pagertree:\u002F\u002F | (TCP) 443 | pagertree:\u002F\u002Fintegration_id\n| [ParsePlatform](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fparseplatform\u002F) | parsep:\u002F\u002F or parseps:\u002F\u002F | (TCP) 80 or 443 | parsep:\u002F\u002FAppID:MasterKey@Hostname\u003Cbr\u002F>parseps:\u002F\u002FAppID:MasterKey@Hostname\n| [PopcornNotify](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpopcornnotify\u002F) | popcorn:\u002F\u002F  | (TCP) 443   | popcorn:\u002F\u002FApiKey\u002FToPhoneNo\u003Cbr\u002F>popcorn:\u002F\u002FApiKey\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\u003Cbr\u002F>popcorn:\u002F\u002FApiKey\u002FToEmail\u003Cbr\u002F>popcorn:\u002F\u002FApiKey\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\u003Cbr\u002F>popcorn:\u002F\u002FApiKey\u002FToPhoneNo1\u002FToEmail1\u002FToPhoneNoN\u002FToEmailN\n| [Postmark](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpostmark\u002F) | postmark:\u002F\u002F  | (TCP) 443   | postmark:\u002F\u002FAPIToken:FromEmail\u002F\u003Cbr \u002F>postmark:\u002F\u002FAPIToken:FromEmail\u002FToEmail\u003Cbr \u002F>postmark:\u002F\u002FAPIToken:FromEmail\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\n| [Prowl](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fprowl\u002F) | prowl:\u002F\u002F   | (TCP) 443    | prowl:\u002F\u002Fapikey\u003Cbr \u002F>prowl:\u002F\u002Fapikey\u002Fproviderkey\n| [PushBullet](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushbullet\u002F) | pbul:\u002F\u002F    | (TCP) 443    | pbul:\u002F\u002Faccesstoken\u003Cbr \u002F>pbul:\u002F\u002Faccesstoken\u002F#channel\u003Cbr\u002F>pbul:\u002F\u002Faccesstoken\u002FA_DEVICE_ID\u003Cbr \u002F>pbul:\u002F\u002Faccesstoken\u002Femail@address.com\u003Cbr \u002F>pbul:\u002F\u002Faccesstoken\u002F#channel\u002F#channel2\u002Femail@address.net\u002FDEVICE\n| [Pushjet](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushjet\u002F) | pjet:\u002F\u002F or pjets:\u002F\u002F | (TCP) 80 or 443 | pjet:\u002F\u002Fhostname\u002Fsecret\u003Cbr \u002F>pjet:\u002F\u002Fhostname:port\u002Fsecret\u003Cbr \u002F>pjets:\u002F\u002Fsecret@hostname\u002Fsecret\u003Cbr \u002F>pjets:\u002F\u002Fhostname:port\u002Fsecret\n| [Push (Techulus)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ftechulus\u002F) | push:\u002F\u002F    | (TCP) 443    | push:\u002F\u002Fapikey\u002F\n| [Pushed](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushed\u002F) | pushed:\u002F\u002F    | (TCP) 443    | pushed:\u002F\u002Fappkey\u002Fappsecret\u002F\u003Cbr\u002F>pushed:\u002F\u002Fappkey\u002Fappsecret\u002F#ChannelAlias\u003Cbr\u002F>pushed:\u002F\u002Fappkey\u002Fappsecret\u002F#ChannelAlias1\u002F#ChannelAlias2\u002F#ChannelAliasN\u003Cbr\u002F>pushed:\u002F\u002Fappkey\u002Fappsecret\u002F@UserPushedID\u003Cbr\u002F>pushed:\u002F\u002Fappkey\u002Fappsecret\u002F@UserPushedID1\u002F@UserPushedID2\u002F@UserPushedIDN\n| [PushMe](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushme\u002F) | pushme:\u002F\u002F  | (TCP) 443   | pushme:\u002F\u002FToken\u002F\n| [Pushover](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushover\u002F)  | pover:\u002F\u002F   | (TCP) 443   | pover:\u002F\u002Fuser@token\u003Cbr \u002F>pover:\u002F\u002Fuser@token\u002FDEVICE\u003Cbr \u002F>pover:\u002F\u002Fuser@token\u002FDEVICE1\u002FDEVICE2\u002FDEVICEN\u003Cbr \u002F>**Note**: you must specify both your user_id and token\n| [Pushplus](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushplus\u002F) | pushplus:\u002F\u002F  | (TCP) 443   | pushplus:\u002F\u002FToken\n| [PushSafer](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushsafer\u002F)  | psafer:\u002F\u002F or psafers:\u002F\u002F  | (TCP) 80 or 443  | psafer:\u002F\u002Fprivatekey\u003Cbr \u002F>psafers:\u002F\u002Fprivatekey\u002FDEVICE\u003Cbr \u002F>psafer:\u002F\u002Fprivatekey\u002FDEVICE1\u002FDEVICE2\u002FDEVICEN\n| [Pushy](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushy\u002F)  | pushy:\u002F\u002F  | (TCP) 443  | pushy:\u002F\u002Fapikey\u002FDEVICE\u003Cbr \u002F>pushy:\u002F\u002Fapikey\u002FDEVICE1\u002FDEVICE2\u002FDEVICEN\u003Cbr \u002F>pushy:\u002F\u002Fapikey\u002FTOPIC\u003Cbr \u002F>pushy:\u002F\u002Fapikey\u002FTOPIC1\u002FTOPIC2\u002FTOPICN\n| [PushDeer](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fpushdeer\u002F) | pushdeer:\u002F\u002F or pushdeers:\u002F\u002F | (TCP) 80 or 443 | pushdeer:\u002F\u002FpushKey\u003Cbr \u002F>pushdeer:\u002F\u002Fhostname\u002FpushKey\u003Cbr \u002F>pushdeer:\u002F\u002Fhostname:port\u002FpushKey\n| [QQ Push](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fqq\u002F) | qq:\u002F\u002F  | (TCP) 443   | qq:\u002F\u002FToken\n| [Reddit](https:\u002F\u002Fappriseit.com\u002Fservices\u002Freddit\u002F) | reddit:\u002F\u002F | (TCP) 443   | reddit:\u002F\u002Fuser:password@app_id\u002Fapp_secret\u002Fsubreddit\u003Cbr \u002F>reddit:\u002F\u002Fuser:password@app_id\u002Fapp_secret\u002Fsub1\u002Fsub2\u002FsubN\n| [Resend](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fresend\u002F) | resend:\u002F\u002F  | (TCP) 443   | resend:\u002F\u002FAPIToken:FromEmail\u002F\u003Cbr \u002F>resend:\u002F\u002FAPIToken:FromEmail\u002FToEmail\u003Cbr \u002F>resend:\u002F\u002FAPIToken:FromEmail\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\n| [Revolt](https:\u002F\u002Fappriseit.com\u002Fservices\u002Frevolt\u002F) | revolt:\u002F\u002F | (TCP) 443   |  revolt:\u002F\u002Fbottoken\u002FChannelID\u003Cbr \u002F>revolt:\u002F\u002Fbottoken\u002FChannelID1\u002FChannelID2\u002FChannelIDN |\n| [Rocket.Chat](https:\u002F\u002Fappriseit.com\u002Fservices\u002Frocketchat\u002F) | rocket:\u002F\u002F or rockets:\u002F\u002F  | (TCP) 80 or 443   | rocket:\u002F\u002Fuser:password@hostname\u002FRoomID\u002FChannel\u003Cbr \u002F>rockets:\u002F\u002Fuser:password@hostname:443\u002F#Channel1\u002F#Channel1\u002FRoomID\u003Cbr \u002F>rocket:\u002F\u002Fuser:password@hostname\u002F#Channel\u003Cbr \u002F>rocket:\u002F\u002Fwebhook@hostname\u003Cbr \u002F>rockets:\u002F\u002Fwebhook@hostname\u002F@User\u002F#Channel\n| [RSyslog](https:\u002F\u002Fappriseit.com\u002Fservices\u002Frsyslog\u002F) | rsyslog:\u002F\u002F  | (UDP) 514 | rsyslog:\u002F\u002Fhostname\u003Cbr \u002F>rsyslog:\u002F\u002Fhostname\u002FFacility\n| [Ryver](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fryver\u002F) | ryver:\u002F\u002F  | (TCP) 443   | ryver:\u002F\u002FOrganization\u002FToken\u003Cbr \u002F>ryver:\u002F\u002Fbotname@Organization\u002FToken\n| [SendGrid](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsendgrid\u002F) | sendgrid:\u002F\u002F  | (TCP) 443   | sendgrid:\u002F\u002FAPIToken:FromEmail\u002F\u003Cbr \u002F>sendgrid:\u002F\u002FAPIToken:FromEmail\u002FToEmail\u003Cbr \u002F>sendgrid:\u002F\u002FAPIToken:FromEmail\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\n| [SendPulse](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsendpulse\u002F) | sendpulse:\u002F\u002F  | (TCP) 443   | sendpulse:\u002F\u002Fuser@host\u002FClientId\u002FClientSecret\u003Cbr \u002F>sendpulse:\u002F\u002Fuser@host\u002FClientId\u002FclientSecret\u002FToEmail\u003Cbr \u002F>sendpulse:\u002F\u002Fuser@host\u002FClientId\u002FClientSecret\u002FToEmail1\u002FToEmail2\u002FToEmailN\u002F\n| [ServerChan](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fserverchan\u002F) | schan:\u002F\u002F   | (TCP) 443    | schan:\u002F\u002Fsendkey\u002F\n| [Signal API](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsignal\u002F) | signal:\u002F\u002F  or signals:\u002F\u002F | (TCP) 80 or 443  | signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u003Cbr\u002F>signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [SIGNL4](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsignl4\u002F) | signl4:\u002F\u002F  | (TCP) 80 or 443  | signl4:\u002F\u002Fhostname\n| [SimplePush](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsimplepush\u002F) | spush:\u002F\u002F   | (TCP) 443    | spush:\u002F\u002Fapikey\u003Cbr \u002F>spush:\u002F\u002Fsalt:password@apikey\u003Cbr \u002F>spush:\u002F\u002Fapikey?event=Apprise\n| [Slack](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fslack\u002F) | slack:\u002F\u002F  | (TCP) 443   | slack:\u002F\u002FTokenA\u002FTokenB\u002FTokenC\u002F\u003Cbr \u002F>slack:\u002F\u002FTokenA\u002FTokenB\u002FTokenC\u002FChannel\u003Cbr \u002F>slack:\u002F\u002Fbotname@TokenA\u002FTokenB\u002FTokenC\u002FChannel\u003Cbr \u002F>slack:\u002F\u002Fuser@TokenA\u002FTokenB\u002FTokenC\u002FChannel1\u002FChannel2\u002FChannelN\n| [SMTP2Go](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsmtp2go\u002F) | smtp2go:\u002F\u002F | (TCP) 443 | smtp2go:\u002F\u002Fuser@hostname\u002Fapikey\u003Cbr \u002F>smtp2go:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail\u003Cbr \u002F>smtp2go:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail1\u002Femail2\u002FemailN\u003Cbr \u002F>smtp2go:\u002F\u002Fuser@hostname\u002Fapikey\u002F?name=\"From%20User\"\n| [SparkPost](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsparkpost\u002F) | sparkpost:\u002F\u002F | (TCP) 443 | sparkpost:\u002F\u002Fuser@hostname\u002Fapikey\u003Cbr \u002F>sparkpost:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail\u003Cbr \u002F>sparkpost:\u002F\u002Fuser@hostname\u002Fapikey\u002Femail1\u002Femail2\u002FemailN\u003Cbr \u002F>sparkpost:\u002F\u002Fuser@hostname\u002Fapikey\u002F?name=\"From%20User\"\n| [Spike.sh](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fspike\u002F) | spike:\u002F\u002F  | (TCP) 443   | spike:\u002F\u002FToken\n| [Splunk](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsplunk\u002F) | splunk:\u002F\u002F or victorops:\u002F | (TCP) 443 | splunk:\u002F\u002Froute_key@apikey\u003Cbr \u002F>splunk:\u002F\u002Froute_key@apikey\u002Fentity_id\n| [Spug Push](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fspugpush\u002F) | spugpush:\u002F\u002F  | (TCP) 443   | spugpush:\u002F\u002FToken\n| [Streamlabs](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fstreamlabs\u002F) | strmlabs:\u002F\u002F | (TCP) 443 | strmlabs:\u002F\u002FAccessToken\u002F\u003Cbr\u002F>strmlabs:\u002F\u002FAccessToken\u002F?name=name&identifier=identifier&amount=0&currency=USD\n| [Synology Chat](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsynology_chat\u002F) | synology:\u002F\u002F or synologys:\u002F\u002F |  (TCP) 80 or 443 | synology:\u002F\u002Fhostname\u002Ftoken\u003Cbr \u002F>synology:\u002F\u002Fhostname:port\u002Ftoken\n| [Syslog](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsyslog\u002F) | syslog:\u002F\u002F  | n\u002Fa | syslog:\u002F\u002F\u003Cbr \u002F>syslog:\u002F\u002FFacility\n| [Telegram](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ftelegram\u002F) | tgram:\u002F\u002F  | (TCP) 443   | tgram:\u002F\u002Fbottoken\u002FChatID\u003Cbr \u002F>tgram:\u002F\u002Fbottoken\u002FChatID1\u002FChatID2\u002FChatIDN\n| [Twitter](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ftwitter\u002F) | twitter:\u002F\u002F  | (TCP) 443   | twitter:\u002F\u002FCKey\u002FCSecret\u002FAKey\u002FASecret\u003Cbr\u002F>twitter:\u002F\u002Fuser@CKey\u002FCSecret\u002FAKey\u002FASecret\u003Cbr\u002F>twitter:\u002F\u002FCKey\u002FCSecret\u002FAKey\u002FASecret\u002FUser1\u002FUser2\u002FUser2\u003Cbr\u002F>twitter:\u002F\u002FCKey\u002FCSecret\u002FAKey\u002FASecret?mode=tweet\n| [Twist](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ftwist\u002F) | twist:\u002F\u002F  | (TCP) 443   | twist:\u002F\u002Fpasword:login\u003Cbr\u002F>twist:\u002F\u002Fpassword:login\u002F#channel\u003Cbr\u002F>twist:\u002F\u002Fpassword:login\u002F#team:channel\u003Cbr\u002F>twist:\u002F\u002Fpassword:login\u002F#team:channel1\u002Fchannel2\u002F#team3:channel\n| [Vapid (WebPush)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fvapid\u002F) | vapid:\u002F\u002F    | (TCP) 443    | vapid:\u002F\u002Fsubscriber\u002Ftarget\u003Cbr\u002F>vapid:\u002F\u002Fsubscriber\u002Ftarget?subfile=path&keyfile=path\n| [Viber](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fviber\u002F) | viber:\u002F\u002F    | (TCP) 443    | viber:\u002F\u002Ftoken\u002Ftarget\n| [Webex Teams (Cisco)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fwxteams\u002F) | wxteams:\u002F\u002F  | (TCP) 443   | wxteams:\u002F\u002FToken\n| [WeCom Bot](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fwecombot\u002F) | wecombot:\u002F\u002F  | (TCP) 443   | wecombot:\u002F\u002FBotKey\n| [WhatsApp](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fwhatsapp\u002F) | whatsapp:\u002F\u002F  | (TCP) 443   | whatsapp:\u002F\u002FAccessToken@FromPhoneID\u002FToPhoneNo\u003Cbr\u002F>whatsapp:\u002F\u002FTemplate:AccessToken@FromPhoneID\u002FToPhoneNo\n| [WxPusher](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fwxpusher\u002F) | wxpusher:\u002F\u002F  | (TCP) 443   | wxpusher:\u002F\u002FAppToken@UserID1\u002FUserID2\u002FUserIDN\u003Cbr\u002F>wxpusher:\u002F\u002FAppToken@Topic1\u002FTopic2\u002FTopic3\u003Cbr\u002F>wxpusher:\u002F\u002FAppToken@UserID1\u002FTopic1\u002F\n| [XBMC](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fxbmc\u002F) | xbmc:\u002F\u002F or xbmcs:\u002F\u002F    | (TCP) 8080 or 443   | xbmc:\u002F\u002Fhostname\u003Cbr \u002F>xbmc:\u002F\u002Fuser@hostname\u003Cbr \u002F>xbmc:\u002F\u002Fuser:password@hostname:port\n| [XMPP](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fxmpp\u002F) | xmpp:\u002F\u002F or xmpps:\u002F\u002F    | (TCP) 5222 or 5223   | xmpp:\u002F\u002Fuser:pass@hostname\u003Cbr \u002F>xmpps:\u002F\u002Fuser:pass@hostname\u002Fjid\u003Cbr \u002F>xmpps:\u002F\u002Fuser:pass@hostname\u002Fjid1\u002Fjid2@example.ca\n| [Zoom](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fzoom\u002F) | zoom:\u002F\u002F  | (TCP) 443   | zoom:\u002F\u002FWebhookID\u002FToken\n| [Zulip Chat](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fzulip\u002F) | zulip:\u002F\u002F  | (TCP) 443   | zulip:\u002F\u002Fbotname@Organization\u002FToken\u003Cbr \u002F>zulip:\u002F\u002Fbotname@Organization\u002FToken\u002FStream\u003Cbr \u002F>zulip:\u002F\u002Fbotname@Organization\u002FToken\u002FEmail\n\n## SMS Notifications\n\nSMS Notifications for the most part do not have a both a `title` and `body`.  They consist of a single `body` which is usually no more then 160 characters in length.  When using Apprise, the `title` and `body` are therefore combined into a single message prior to their transmission.\n\n| Notification Service | Service ID | Default Port | Example Syntax |\n| -------------------- | ---------- | ------------ | -------------- |\n| [46elks](https:\u002F\u002Fappriseit.com\u002Fservices\u002F46elks\u002F) | 46elks:\u002F\u002F  | (TCP) 443   | 46elks:\u002F\u002Fuser:password@FromPhoneNo\u003Cbr\u002F>46elks:\u002F\u002Fuser:password@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>46elks:\u002F\u002Fuser:password@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Africas Talking](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fafricas_talking\u002F) | atalk:\u002F\u002F  | (TCP) 443   | atalk:\u002F\u002FAppUser@ApiKey\u002FToPhoneNo\u003Cbr\u002F>atalk:\u002F\u002FAppUser@ApiKey\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Automated Packet Reporting System (ARPS)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Faprs\u002F)  | aprs:\u002F\u002F | (TCP) 10152 | aprs:\u002F\u002Fuser:pass@callsign\u003Cbr\u002F>aprs:\u002F\u002Fuser:pass@callsign1\u002Fcallsign2\u002FcallsignN\n| [AWS SNS](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsns\u002F)  | sns:\u002F\u002F   | (TCP) 443   | sns:\u002F\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u002F+PhoneNo\u003Cbr\u002F>sns:\u002F\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u002F+PhoneNo1\u002F+PhoneNo2\u002F+PhoneNoN\u003Cbr\u002F>sns:\u002F\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u002FTopic\u003Cbr\u002F>sns:\u002F\u002FAccessKeyID\u002FAccessSecretKey\u002FRegionName\u002FTopic1\u002FTopic2\u002FTopicN\n| [BulkSMS](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fbulksms\u002F) | bulksms:\u002F\u002F  | (TCP) 443   | bulksms:\u002F\u002Fuser:password@ToPhoneNo\u003Cbr\u002F>bulksms:\u002F\u002FUser:Password@ToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [BulkVS](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fbulkvs\u002F) | bulkvs:\u002F\u002F  | (TCP) 443   | bulkvs:\u002F\u002Fuser:password@FromPhoneNo\u003Cbr\u002F>bulkvs:\u002F\u002Fuser:password@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>bulkvs:\u002F\u002Fuser:password@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Burst SMS](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fburstsms\u002F) | burstsms:\u002F\u002F  | (TCP) 443   | burstsms:\u002F\u002FApiKey:ApiSecret@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>burstsms:\u002F\u002FApiKey:ApiSecret@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Clickatell](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fclickatell\u002F)                         | clickatell:\u002F\u002F               | (TCP) 443       | clickatell:\u002F\u002FApiKey\u002FToPhoneNo\u003Cbr\u002F>clickatell:\u002F\u002FFromPhoneNo@ApiKey\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [ClickSend](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fclicksend\u002F) | clicksend:\u002F\u002F  | (TCP) 443   | clicksend:\u002F\u002Fuser:pass@PhoneNo\u003Cbr\u002F>clicksend:\u002F\u002Fuser:pass@ToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [DAPNET](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fdapnet\u002F) | dapnet:\u002F\u002F  | (TCP) 80   | dapnet:\u002F\u002Fuser:pass@callsign\u003Cbr\u002F>dapnet:\u002F\u002Fuser:pass@callsign1\u002Fcallsign2\u002FcallsignN\n| [D7 Networks](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fd7networks\u002F) | d7sms:\u002F\u002F  | (TCP) 443   | d7sms:\u002F\u002Ftoken@PhoneNo\u003Cbr\u002F>d7sms:\u002F\u002Ftoken@ToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [DingTalk](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fdingtalk\u002F)  | dingtalk:\u002F\u002F   | (TCP) 443   | dingtalk:\u002F\u002Ftoken\u002F\u003Cbr \u002F>dingtalk:\u002F\u002Ftoken\u002FToPhoneNo\u003Cbr \u002F>dingtalk:\u002F\u002Ftoken\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNo1\u002F\n| [Exotel](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fexotel\u002F) | exotel:\u002F\u002F  | (TCP) 443   | exotel:\u002F\u002Fsid:token@FromPhoneNo\u003Cbr\u002F>exotel:\u002F\u002Fsid:token@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>exotel:\u002F\u002Fsid:token@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [Free-Mobile](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ffreemobile\u002F)  | freemobile:\u002F\u002F   | (TCP) 443   | freemobile:\u002F\u002Fuser@password\u002F\n| [httpSMS](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fhttpsms\u002F) | httpsms:\u002F\u002F  | (TCP) 443   | httpsms:\u002F\u002FApiKey@FromPhoneNo\u003Cbr\u002F>httpsms:\u002F\u002FApiKey@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>httpsms:\u002F\u002FApiKey@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Kavenegar](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fkavenegar\u002F) | kavenegar:\u002F\u002F  | (TCP) 443   | kavenegar:\u002F\u002FApiKey\u002FToPhoneNo\u003Cbr\u002F>kavenegar:\u002F\u002FFromPhoneNo@ApiKey\u002FToPhoneNo\u003Cbr\u002F>kavenegar:\u002F\u002FApiKey\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [MessageBird](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmessagebird\u002F) | msgbird:\u002F\u002F  | (TCP) 443   | msgbird:\u002F\u002FApiKey\u002FFromPhoneNo\u003Cbr\u002F>msgbird:\u002F\u002FApiKey\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>msgbird:\u002F\u002FApiKey\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [MSG91](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmsg91\u002F) | msg91:\u002F\u002F  | (TCP) 443   | msg91:\u002F\u002FTemplateID@AuthKey\u002FToPhoneNo\u003Cbr\u002F>msg91:\u002F\u002FTemplateID@AuthKey\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Plivo](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fplivo\u002F) | plivo:\u002F\u002F  | (TCP) 443   | plivo:\u002F\u002FAuthID@Token@FromPhoneNo\u003Cbr\u002F>plivo:\u002F\u002FAuthID@Token\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>plivo:\u002F\u002FAuthID@Token\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Seven](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fseven\u002F)                                   | seven:\u002F\u002F                    | (TCP) 443   | seven:\u002F\u002FApiKey\u002FFromPhoneNo\u003Cbr\u002F>seven:\u002F\u002FApiKey\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>seven:\u002F\u002FApiKey\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Société Française du Radiotéléphone (SFR)](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsfr\u002F) | sfr:\u002F\u002F   | (TCP) 443    | sfr:\u002F\u002Fuser:password>@spaceId\u002FToPhoneNo\u003Cbr\u002F>sfr:\u002F\u002Fuser:password>@spaceId\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Signal API](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsignal\u002F) | signal:\u002F\u002F  or signals:\u002F\u002F | (TCP) 80 or 443  | signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u003Cbr\u002F>signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>signal:\u002F\u002Fhostname:port\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Sinch](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsinch\u002F) | sinch:\u002F\u002F  | (TCP) 443   | sinch:\u002F\u002FServicePlanId:ApiToken@FromPhoneNo\u003Cbr\u002F>sinch:\u002F\u002FServicePlanId:ApiToken@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>sinch:\u002F\u002FServicePlanId:ApiToken@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\u003Cbr\u002F>sinch:\u002F\u002FServicePlanId:ApiToken@ShortCode\u002FToPhoneNo\u003Cbr\u002F>sinch:\u002F\u002FServicePlanId:ApiToken@ShortCode\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [SMPP](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsmpp\u002F)    | smpp:\u002F\u002F or smpps:\u002F\u002F  | (TCP) 443  | smpp:\u002F\u002Fuser:password@hostname:port\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>smpps:\u002F\u002Fuser:password@hostname:port\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\n| [SMSEagle](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsmseagle\u002F) | smseagle:\u002F\u002F or smseagles:\u002F\u002F | (TCP) 80 or 443  | smseagles:\u002F\u002Fhostname:port\u002FToPhoneNo\u003Cbr\u002F>smseagles:\u002F\u002Fhostname:port\u002F@ToContact\u003Cbr\u002F>smseagles:\u002F\u002Fhostname:port\u002F#ToGroup\u003Cbr\u002F>smseagles:\u002F\u002Fhostname:port\u002FToPhoneNo1\u002F#ToGroup\u002F@ToContact\u002F\n| [SMS Manager](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fsms_manager\u002F) | smsmgr:\u002F\u002F  | (TCP) 443   | smsmgr:\u002F\u002FApiKey@ToPhoneNo\u003Cbr\u002F>smsmgr:\u002F\u002FApiKey@ToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Threema Gateway](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fthreema\u002F) | threema:\u002F\u002F  | (TCP) 443   | threema:\u002F\u002FGatewayID@secret\u002FToPhoneNo\u003Cbr\u002F>threema:\u002F\u002FGatewayID@secret\u002FToEmail\u003Cbr\u002F>threema:\u002F\u002FGatewayID@secret\u002FToThreemaID\u002F\u003Cbr\u002F>threema:\u002F\u002FGatewayID@secret\u002FToEmail\u002FToThreemaID\u002FToPhoneNo\u002F...\n| [Twilio](https:\u002F\u002Fappriseit.com\u002Fservices\u002Ftwilio\u002F) | twilio:\u002F\u002F  | (TCP) 443   | twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u002FToPhoneNo?apikey=Key\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@ShortCode\u002FToPhoneNo\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@ShortCode\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u002FToPhoneNo?method=call\u003Cbr\u002F>twilio:\u002F\u002FAccountSid:AuthToken@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN?method=call\n| [Voipms](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fvoipms\u002F) | voipms:\u002F\u002F  | (TCP) 443   | voipms:\u002F\u002Fpassword:email\u002FFromPhoneNo\u003Cbr\u002F>voipms:\u002F\u002Fpassword:email\u002FFromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>voipms:\u002F\u002Fpassword:email\u002FFromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n| [Vonage](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fvonage\u002F) (formerly Nexmo) | vonage:\u002F\u002F  | (TCP) 443   | vonage:\u002F\u002FApiKey:ApiSecret@FromPhoneNo\u003Cbr\u002F>vonage:\u002F\u002FApiKey:ApiSecret@FromPhoneNo\u002FToPhoneNo\u003Cbr\u002F>vonage:\u002F\u002FApiKey:ApiSecret@FromPhoneNo\u002FToPhoneNo1\u002FToPhoneNo2\u002FToPhoneNoN\u002F\n\n## Desktop Notifications\n\n| Notification Service | Service ID | Default Port | Example Syntax |\n| -------------------- | ---------- | ------------ | -------------- |\n| [Linux DBus Notifications](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fdbus\u002F)  | dbus:\u002F\u002F\u003Cbr \u002F>qt:\u002F\u002F\u003Cbr \u002F>glib:\u002F\u002F\u003Cbr \u002F>kde:\u002F\u002F  | n\u002Fa  | dbus:\u002F\u002F\u003Cbr \u002F>qt:\u002F\u002F\u003Cbr \u002F>glib:\u002F\u002F\u003Cbr \u002F>kde:\u002F\u002F\n| [Linux Gnome Notifications](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fgnome\u002F) | gnome:\u002F\u002F    |        n\u002Fa          | gnome:\u002F\u002F\n| [MacOS X Notifications](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fmacosx\u002F) | macosx:\u002F\u002F    |        n\u002Fa          | macosx:\u002F\u002F\n| [Windows Notifications](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fwindows\u002F) | windows:\u002F\u002F    |        n\u002Fa          | windows:\u002F\u002F\n\n## Email Notifications\n\n| Service ID | Default Port | Example Syntax |\n| ---------- | ------------ | -------------- |\n| [mailto:\u002F\u002F](https:\u002F\u002Fappriseit.com\u002Fservices\u002Femail\u002F)  |  (TCP) 25    | mailto:\u002F\u002Fuserid:pass@domain.com\u003Cbr \u002F>mailto:\u002F\u002Fdomain.com?user=userid&pass=password\u003Cbr\u002F>mailto:\u002F\u002Fdomain.com:2525?user=userid&pass=password\u003Cbr \u002F>mailto:\u002F\u002Fuser@gmail.com&pass=password\u003Cbr \u002F>mailto:\u002F\u002FmySendingUsername:mySendingPassword@example.com?to=receivingAddress@example.com\u003Cbr \u002F>mailto:\u002F\u002Fuserid:password@example.com?smtp=mail.example.com&from=noreply@example.com&name=no%20reply\n| [mailtos:\u002F\u002F](https:\u002F\u002Fappriseit.com\u002Fservices\u002Femail\u002F) |  (TCP) 587   | mailtos:\u002F\u002Fuserid:pass@domain.com\u003Cbr \u002F>mailtos:\u002F\u002Fdomain.com?user=userid&pass=password\u003Cbr\u002F>mailtos:\u002F\u002Fdomain.com:465?user=userid&pass=password\u003Cbr \u002F>mailtos:\u002F\u002Fuser@hotmail.com&pass=password\u003Cbr \u002F>mailtos:\u002F\u002FmySendingUsername:mySendingPassword@example.com?to=receivingAddress@example.com\u003Cbr \u002F>mailtos:\u002F\u002Fuserid:password@example.com?smtp=mail.example.com&from=noreply@example.com&name=no%20reply\n\nApprise have some email services built right into it (such as yahoo, fastmail, hotmail, gmail, etc) that greatly simplify the mailto:\u002F\u002F service.  See more details [here](https:\u002F\u002Fappriseit.com\u002Fservices\u002Femail\u002F).\n\n## Custom Notifications\n\n| Post Method          | Service ID | Default Port | Example Syntax |\n| -------------------- | ---------- | ------------ | -------------- |\n| [Form](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fform\u002F)       | form:\u002F\u002F or forms:\u002F\u002F   | (TCP) 80 or 443 | form:\u002F\u002Fhostname\u003Cbr \u002F>form:\u002F\u002Fuser@hostname\u003Cbr \u002F>form:\u002F\u002Fuser:password@hostname:port\u003Cbr \u002F>form:\u002F\u002Fhostname\u002Fa\u002Fpath\u002Fto\u002Fpost\u002Fto\n| [JSON](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fjson\u002F)       | json:\u002F\u002F or jsons:\u002F\u002F   | (TCP) 80 or 443 | json:\u002F\u002Fhostname\u003Cbr \u002F>json:\u002F\u002Fuser@hostname\u003Cbr \u002F>json:\u002F\u002Fuser:password@hostname:port\u003Cbr \u002F>json:\u002F\u002Fhostname\u002Fa\u002Fpath\u002Fto\u002Fpost\u002Fto\n| [XML](https:\u002F\u002Fappriseit.com\u002Fservices\u002Fxml\u002F)         | xml:\u002F\u002F or xmls:\u002F\u002F   | (TCP) 80 or 443 | xml:\u002F\u002Fhostname\u003Cbr \u002F>xml:\u002F\u002Fuser@hostname\u003Cbr \u002F>xml:\u002F\u002Fuser:password@hostname:port\u003Cbr \u002F>xml:\u002F\u002Fhostname\u002Fa\u002Fpath\u002Fto\u002Fpost\u002Fto\n\n# Installation\n\nThe easiest way is to install Apprise from PyPI:\n```bash\npip install apprise\n```\n\nApprise is also packaged as an RPM and available through [EPEL](https:\u002F\u002Fdocs.fedoraproject.org\u002Fen-US\u002Fepel\u002F) supporting CentOS, Redhat, Rocky, Oracle Linux, etc.\n```bash\n# Follow instructions on https:\u002F\u002Fdocs.fedoraproject.org\u002Fen-US\u002Fepel\n# to get your system connected up to EPEL and then:\n# Redhat\u002FCentOS 7.x users\nyum install apprise\n\n# Redhat\u002FRocky Linux 8.x+ and\u002For Fedora Users\ndnf install apprise\n```\n\nYou can also check out the [Graphical version of Apprise](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise-api) to centralize your configuration and notifications through a manageable webpage.\n\n# Command Line Usage\n\nA small command line interface (CLI) tool is also provided with this package called *apprise*. If you know the server urls you wish to notify, you can simply provide them all on the command line and send your notifications that way:\n```bash\n# Send a notification to as many servers as you want\n# as you can easily chain one after another (the -vv provides some\n# additional verbosity to help let you know what is going on):\napprise -vv -t 'my title' -b 'my notification body' \\\n   'mailto:\u002F\u002Fmyemail:mypass@gmail.com' \\\n   'pbul:\u002F\u002Fo.gn5kj6nfhv736I7jC3cj3QLRiyhgl98b'\n\n# If you don't specify a --body (-b) then stdin is used allowing\n# you to use the tool as part of your every day administration:\ncat \u002Fproc\u002Fcpuinfo | apprise -vv -t 'cpu info' \\\n   'mailto:\u002F\u002Fmyemail:mypass@gmail.com'\n\n# The title field is totally optional\nuptime | apprise -vv \\\n   'discord:\u002F\u002F\u002F4174216298\u002FJHMHI8qBe7bk2ZwO5U711o3dV_js'\n```\n\n## CLI Configuration Files\n\nNo one wants to put their 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 or a very simple TEXT format. You can also pull these configuration files via an HTTP query too! Read more about the expected structure of the configuration files [here](https:\u002F\u002Fappriseit.com\u002Fconfig\u002F).\n\n```bash\n# By default if no url or configuration is specified apprise will attempt to load\n# configuration files (if present) from:\n#  ~\u002F.apprise\n#  ~\u002F.apprise.yaml\n#  ~\u002F.config\u002Fapprise.conf\n#  ~\u002F.config\u002Fapprise.yaml\n#  \u002Fetc\u002Fapprise.conf\n#  \u002Fetc\u002Fapprise.yaml\n\n# Also a subdirectory handling allows you to leverage plugins\n#  ~\u002F.apprise\u002Fapprise\n#  ~\u002F.apprise\u002Fapprise.yaml\n#  ~\u002F.config\u002Fapprise\u002Fapprise.conf\n#  ~\u002F.config\u002Fapprise\u002Fapprise.yaml\n#  \u002Fetc\u002Fapprise\u002Fapprise.yaml\n#  \u002Fetc\u002Fapprise\u002Fapprise.conf\n\n# Windows users can store their default configuration files here:\n#  %APPDATA%\u002FApprise\u002Fapprise.conf\n#  %APPDATA%\u002FApprise\u002Fapprise.yaml\n#  %LOCALAPPDATA%\u002FApprise\u002Fapprise.conf\n#  %LOCALAPPDATA%\u002FApprise\u002Fapprise.yaml\n#  %ALLUSERSPROFILE%\\Apprise\\apprise.conf\n#  %ALLUSERSPROFILE%\\Apprise\\apprise.yaml\n#  %PROGRAMFILES%\\Apprise\\apprise.conf\n#  %PROGRAMFILES%\\Apprise\\apprise.yaml\n#  %COMMONPROGRAMFILES%\\Apprise\\apprise.conf\n#  %COMMONPROGRAMFILES%\\Apprise\\apprise.yaml\n\n# The configuration files specified above can also be identified with a `.yml`\n# extension or even just entirely removing the `.conf` extension altogether.\n\n# If you loaded one of those files, your command line gets really easy:\napprise -vv -t 'my title' -b 'my notification body'\n\n# If you want to deviate from the default paths or specify more than one,\n# just specify them using the --config switch:\napprise -vv -t 'my title' -b 'my notification body' \\\n   --config=\u002Fpath\u002Fto\u002Fmy\u002Fconfig.yml\n\n# Got lots of configuration locations? No problem, you can specify them all:\n# Apprise can even fetch the configuration from over a network!\napprise -vv -t 'my title' -b 'my notification body' \\\n   --config=\u002Fpath\u002Fto\u002Fmy\u002Fconfig.yml \\\n   --config=https:\u002F\u002Flocalhost\u002Fmy\u002Fapprise\u002Fconfig\n```\n\n## CLI Tagging Support\n\nApprise allows you to tag your services in your configuration to organize them (e.g., `family`, `devops`, `critical`). You can then filter which services to notify using the `--tag` (`-g`) switch.\n\nIt is important to understand how Apprise handles multiple tags:\n\n* **OR Logic (Union)**: To notify services that have *either* Tag A **OR** Tag B, specify the `-g` switch multiple times.\n* **AND Logic (Intersection)**: To notify services that have *both* Tag A **AND** Tag B, separate the tags with a comma.\n\n```bash\n# OR Logic: Notify any service tagged 'devops' OR 'admin'\napprise -vv -t \"Union Test\" \\\n   --config=~\u002Fapprise.yml \\\n   -g devops -g admin\n\n# AND Logic: Notify only services tagged with BOTH 'devops' AND 'critical'\napprise -vv -t \"Intersection Test\" \\\n   --config=~\u002Fapprise.yml \\\n   -g devops,critical\n\n## CLI File Attachments\n\nApprise also supports file attachments too! Specify as many attachments to a notification as you want.\n```bash\n# Send a funny image you found on the internet to a colleague:\napprise -vv --title 'Agile Joke' \\\n        --body 'Did you see this one yet?' \\\n        --attach https:\u002F\u002Fi.redd.it\u002Fmy2t4d2fx0u31.jpg \\\n        'mailto:\u002F\u002Fmyemail:mypass@gmail.com'\n\n# Easily send an update from a critical server to your dev team\napprise -vv --title 'system crash' \\\n        --body 'I do not think Jim fixed the bug; see attached...' \\\n        --attach \u002Fvar\u002Flog\u002Fmyprogram.log \\\n        --attach \u002Fvar\u002Fdebug\u002Fcore.2345 \\\n        --tag devteam\n```\n\n## CLI Loading Custom Notifications\u002FHooks\n\nTo create your own custom `schema:\u002F\u002F` hook so that you can trigger your own custom code,\nsimply include the `@notify` decorator to wrap your function.\n```python\nfrom apprise.decorators import notify\n#\n# The below assumes you want to catch foobar:\u002F\u002F calls:\n#\n@notify(on=\"foobar\", name=\"My Custom Foobar Plugin\")\ndef my_custom_notification_wrapper(body, title, notify_type, *args, **kwargs):\n    \"\"\"My custom notification function that triggers on all foobar:\u002F\u002F calls\n    \"\"\"\n    # Write all of your code here... as an example...\n    print(\"{}: {} - {}\".format(notify_type.upper(), title, body))\n\n    # Returning True\u002FFalse is a way to relay your status back to Apprise.\n    # Returning nothing (None by default) is always interpreted as a Success\n```\n\nOnce you've defined your custom hook, you just need to tell Apprise where it is at runtime.\n```bash\n# By default if no plugin path is specified apprise will attempt to load\n# all plugin files (if present) from the following directory paths:\n#  ~\u002F.apprise\u002Fplugins\n#  ~\u002F.config\u002Fapprise\u002Fplugins\n#  \u002Fvar\u002Flib\u002Fapprise\u002Fplugins\n\n# Windows users can store their default plugin files in these directories:\n#  %APPDATA%\u002FApprise\u002Fplugins\n#  %LOCALAPPDATA%\u002FApprise\u002Fplugins\n#  %ALLUSERSPROFILE%\\Apprise\\plugins\n#  %PROGRAMFILES%\\Apprise\\plugins\n#  %COMMONPROGRAMFILES%\\Apprise\\plugins\n\n# If you placed your plugin file within one of the directories already defined\n# above, then your call simply needs to look like:\napprise -vv --title 'custom override' \\\n        --body 'the body of my message' \\\n        foobar:\\\\\n\n# However you can override the path like so\napprise -vv --title 'custom override' \\\n        --body 'the body of my message' \\\n        --plugin-path \u002Fpath\u002Fto\u002Fmy\u002Fplugin.py \\\n        foobar:\\\\\n```\n\nYou can read more about creating your own custom notifications and\u002For hooks [here](https:\u002F\u002Fappriseit.com\u002Flibrary\u002Fextending\u002Fdecorator\u002F).\n\n## CLI Environment Variables\n\nThose using the Command Line Interface (CLI) can also leverage environment variables to pre-set the default settings:\n\n| Variable                | Description       |\n|------------------------ | ----------------- |\n| `APPRISE_URLS`          |  Specify the default URLs to notify IF none are otherwise specified on the command line explicitly. If the `--config` (`-c`) is specified, then this will overrides any reference to this variable. Use white space and\u002For a comma (`,`) to delimit multiple entries.\n|  `APPRISE_CONFIG_PATH`  | Explicitly specify the config search path to use (overriding the default). The path(s) defined here must point to the absolute filename to open\u002Freference. Use a semi-colon (`;`), line-feed (`\\n`), and\u002For carriage return (`\\r`) to delimit multiple entries.\n|  `APPRISE_PLUGIN_PATH`  | Explicitly specify the custom plugin search path to use (overriding the default). Use a semi-colon (`;`), line-feed (`\\n`), and\u002For carriage return (`\\r`) to delimit multiple entries.\n|  `APPRISE_STORAGE_PATH` | Explicitly specify the persistent storage path to use (overriding the default).\n\n# Developer API Usage\n\nTo send a notification from within your python application, just do the following:\n```python\nimport apprise\n\n# Create an Apprise instance\napobj = apprise.Apprise()\n\n# Add all of the notification services by their server url.\n# A sample email notification:\napobj.add('mailto:\u002F\u002Fmyuserid:mypass@gmail.com')\n\n# A sample pushbullet notification\napobj.add('pbul:\u002F\u002Fo.gn5kj6nfhv736I7jC3cj3QLRiyhgl98b')\n\n# Then notify these services any time you desire. The below would\n# notify all of the services loaded into our Apprise object.\napobj.notify(\n    body='what a great notification service!',\n    title='my notification title',\n)\n```\n\n## API Configuration Files\n\nDevelopers 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! You can read more about the expected structure of the configuration files [here](https:\u002F\u002Fappriseit.com\u002Fgetting-started\u002Fconfiguration\u002F).\n```python\nimport apprise\n\n# Create an Apprise instance\napobj = apprise.Apprise()\n\n# Create an Config instance\nconfig = apprise.AppriseConfig()\n\n# Add a configuration source:\nconfig.add('\u002Fpath\u002Fto\u002Fmy\u002Fconfig.yml')\n\n# Add another...\nconfig.add('https:\u002F\u002Fmyserver:8080\u002Fpath\u002Fto\u002Fconfig')\n\n# Make sure to add our config into our apprise object\napobj.add(config)\n\n# You can mix and match; add an entry directly if you want too\n# In this entry we associate the 'admin' tag with our notification\napobj.add('mailto:\u002F\u002Fmyuser:mypass@hotmail.com', tag='admin')\n\n# Then notify these services any time you desire. The below would\n# notify all of the services that have not been bound to any specific\n# tag.\napobj.notify(\n    body='what a great notification service!',\n    title='my notification title',\n)\n\n# Tagging allows you to specifically target only specific notification\n# services you've loaded:\napobj.notify(\n    body='send a notification to our admin group',\n    title='Attention Admins',\n    # notify any services tagged with the 'admin' tag\n    tag='admin',\n)\n\n# If you want to notify absolutely everything (regardless of whether\n# it's been tagged or not), just use the reserved tag of 'all':\napobj.notify(\n    body='send a notification to our admin group',\n    title='Attention Admins',\n    # notify absolutely everything loaded, regardless on whether\n    # it has a tag associated with it or not:\n    tag='all',\n)\n```\n\n## API File Attachments\n\nAttachments are very easy to send using the Apprise API:\n```python\nimport apprise\n\n# Create an Apprise instance\napobj = apprise.Apprise()\n\n# Add at least one service you want to notify\napobj.add('mailto:\u002F\u002Fmyuser:mypass@hotmail.com')\n\n# Then send your attachment.\napobj.notify(\n    title='A great photo of our family',\n    body='The flash caused Jane to close her eyes! hah! :)',\n    attach='\u002Flocal\u002Fpath\u002Fto\u002Fmy\u002FDSC_003.jpg',\n)\n\n# Send a web based attachment too! In the below example, we connect to a home\n# security camera and send a live image to an email. By default remote web\n# content is cached, but for a security camera we might want to call notify\n# again later in our code, so we want our last image retrieved to expire(in\n# this case after 3 seconds).\napobj.notify(\n    title='Latest security image',\n    attach='http:\u002F\u002Fadmin:password@hikvision-cam01\u002FISAPI\u002FStreaming\u002Fchannels\u002F101\u002Fpicture?cache=3'\n)\n```\n\nTo send more than one attachment, just use a list, set, or tuple instead:\n```python\nimport apprise\n\n# Create an Apprise instance\napobj = apprise.Apprise()\n\n# Add at least one service you want to notify\napobj.add('mailto:\u002F\u002Fmyuser:mypass@hotmail.com')\n\n# Now add all of the entries we're interested in:\nattach = (\n    # ?name= allows us to rename the actual jpeg as found on the site\n    # to be another name when sent to our receipient(s)\n    'https:\u002F\u002Fi.redd.it\u002Fmy2t4d2fx0u31.jpg?name=FlyingToMars.jpg',\n\n    # Now add another:\n    '\u002Fpath\u002Fto\u002Ffunny\u002Fjoke.gif',\n)\n\n# Send your multiple attachments with a single notify call:\napobj.notify(\n    title='Some good jokes.',\n    body='Hey guys, check out these!',\n    attach=attach,\n)\n```\n\n## API Loading Custom Notifications\u002FHooks\n\nBy default, no custom plugins are loaded at all for those building from within the Apprise API.\nIt's at the developers discretion to load custom modules. But should you choose to do so, it's as easy\nas including the path reference in the `AppriseAsset()` object prior to the initialization of your `Apprise()`\ninstance.\n\nFor example:\n```python\nfrom apprise import Apprise\nfrom apprise import AppriseAsset\n\n# Prepare your Asset object so that you can enable the custom plugins to\n# be loaded for your instance of Apprise...\nasset = AppriseAsset(plugin_paths=\"\u002Fpath\u002Fto\u002Fscan\")\n\n# OR You can also generate scan more then one file too:\nasset = AppriseAsset(\n    plugin_paths=[\n        # Iterate over all python libraries found in the root of the\n        # specified path. This is NOT a recursive (directory) scan; only\n        # the first level is parsed. HOWEVER, if a directory containing\n        # an __init__.py is found, it will be included in the load.\n        \"\u002Fdir\u002Fcontaining\u002Fmany\u002Fpython\u002Flibraries\",\n\n        # An absolute path to a plugin.py to exclusively load\n        \"\u002Fpath\u002Fto\u002Fplugin.py\",\n\n        # if you point to a directory that has an __init__.py file found in\n        # it, then only that file is loaded (it's similar to point to a\n        # absolute .py file. Hence, there is no (level 1) scanning at all\n        # within the directory specified.\n        \"\u002Fpath\u002Fto\u002Fdir\u002Flibrary\"\n    ]\n)\n\n# Now that we've got our asset, we just work with our Apprise object as we\n# normally do\naobj = Apprise(asset=asset)\n\n# If our new custom `foobar:\u002F\u002F` library was loaded (presuming we prepared\n# one like in the examples above).  then you would be able to safely add it\n# into Apprise at this point\naobj.add('foobar:\u002F\u002F')\n\n# Send our notification out through our foobar:\u002F\u002F\naobj.notify(\"test\")\n```\n\nYou can read more about creating your own custom notifications and\u002For hooks [here](https:\u002F\u002Fappriseit.com\u002Flibrary\u002Fextending\u002Fdecorator\u002F).\n\n# Persistent Storage\n\nPersistent storage allows Apprise to cache re-occurring actions optionaly to disk. This can greatly reduce the overhead used to send a notification.\n\nThere are 3 Persistent Storage operational states Apprise can operate using:\n1. `auto`:  Flush gathered cache information to the filesystem on demand.  This option is incredibly light weight.  This is the default behavior for all CLI usage.\n   * Developers who choose to use this operational mode can also force cached information manually if they choose.\n   * The CLI will use this operational mode by default.\n1. `flush`: Flushes any cache information to the filesystem during every transaction.\n1. `memory`: Effectively disable Persistent Storage.  Any caching of data required by each plugin used is done in memory.  Apprise effectively operates as it always did before peristent storage was available. This setting ensures no content is every written to disk.\n   * By default this is the mode Apprise will operate under for those developing with it unless they configure it to otherwise operate as `auto` or `flush`.  This is done through the `AppriseAsset()` object and is explained further on in this documentation.\n\n## CLI Persistent Storage Commands\n\nYou can provide the keyword `storage` on your CLI call to see the persistent storage options available to you.\n```bash\n# List all of the occupied space used by Apprise's Persistent Storage:\napprise storage list\n\n# list is the default option, so the following does the same thing:\napprise storage\n\n# You can prune all of your storage older then 30 days\n# and not accessed for this period like so:\napprise storage prune\n\n# You can do a hard reset (and wipe all persistent storage) with:\napprise storage clean\n\n```\n\nYou can also filter your results by adding tags and\u002For URL Identifiers.  When you get a listing (`apprise storage list`), you may see:\n```\n   # example output of 'apprise storage list':\n   1. f7077a65                                             0.00B    unused\n      - matrixs:\u002F\u002Fabcdef:****@synapse.example12.com\u002F%23general?image=no&mode=off&version=3&msgtype...\n      tags: team\n\n   2. 0e873a46                                            81.10B    active\n      - tgram:\u002F\u002FW...U\u002F\u002F?image=False&detect=yes&silent=no&preview=no&content=before&mdv=v1&format=m...\n      tags: personal\n\n   3. abcd123                                             12.00B    stale\n\n```\nThe (persistent storage) cache states are:\n - `unused`: This plugin has not commited anything to disk for reuse\u002Fcache purposes\n - `active`: This plugin has written content to disk.  Or at the very least, it has prepared a persistent storage location it can write into.\n - `stale`: The system detected a location where a URL may have possibly written to in the past, but there is nothing linking to it using the URLs provided.  It is likely wasting space or is no longer of any use.\n\nYou can use this information to filter your results by specifying _URL ID_ (UID) values after your command.  For example:\n```bash\n# The below commands continue with the example already identified above\n# the following would match abcd123 (even though just ab was provided)\n# The output would only list the 'stale' entry above\napprise storage list ab\n\n# knowing our filter is safe, we could remove it\n# the below command would not obstruct our other to URLs and would only\n# remove our stale one:\napprise storage clean ab\n\n# Entries can be filtered by tag as well:\napprise storage list --tag=team\n\n# You can match on multiple URL ID's as well:\n# The followin would actually match the URL ID's of 1. and .2 above\napprise storage list f 0\n```\nWhen using the CLI, Persistent storage is set to the operational mode of `auto` by default, you can change this by providing `--storage-mode=` (`-SM`) during your calls.  If you want to ensure it's always set to a value of your choice.\n\nFor more information on persistent storage, [visit here](https:\u002F\u002Fappriseit.com\u002Fcli\u002Fpersistent-storage\u002F).\n\n## API Persistent Storage Commands\nFor developers, persistent storage is set in the operational mode of `memory` by default.\n\nIt's at the developers discretion to enable it (by switching it to either `auto` or `flush`). Should you choose to do so: it's as easy as including the information in the `AppriseAsset()` object prior to the initialization of your `Apprise()` instance.\n\nFor example:\n```python\nfrom apprise import Apprise\nfrom apprise import AppriseAsset\nfrom apprise import PersistentStoreMode\n\n# Prepare a location the persistent storage can write it's cached content to.\n# By setting this path, this immediately assumes you wish to operate the\n# persistent storage in the operational 'auto' mode\nasset = AppriseAsset(storage_path=\"\u002Fpath\u002Fto\u002Fsave\u002Fdata\")\n\n# If you want to be more explicit and set more options, then you may do the\n# following\nasset = AppriseAsset(\n    # Set our storage path directory (minimum requirement to enable it)\n    storage_path=\"\u002Fpath\u002Fto\u002Fsave\u002Fdata\",\n\n    # Set the mode... the options are:\n    # 1. PersistentStoreMode.MEMORY\n    #       - disable persistent storage from writing to disk\n    # 2. PersistentStoreMode.AUTO\n    #       - write to disk on demand\n    # 3. PersistentStoreMode.FLUSH\n    #       - write to disk always and often\n    storage_mode=PersistentStoreMode.FLUSH\n\n    # The URL IDs are by default 8 characters in length. You can increase and\n    # decrease it's value here.  The value must be > 2. The default value is 8\n    # if not otherwise specified\n    storage_idlen=8,\n)\n\n# Now that we've got our asset, we just work with our Apprise object as we\n# normally do\naobj = Apprise(asset=asset)\n```\n\nFor more information on persistent storage, [visit here](https:\u002F\u002Fappriseit.com\u002Flibrary\u002Fpersistent-storage\u002F).\n\n# Want To Learn More?\n\nIf you're interested in reading more about this and other methods on how to customize your own notifications, please check out the following links:\n* 📣 [Using the CLI](https:\u002F\u002Fappriseit.com\u002Fcli\u002F)\n* 🛠️ [Development API](https:\u002F\u002Fappriseit.com\u002Flibrary\u002F)\n* ⚙️ [Configuration File Help](https:\u002F\u002Fappriseit.com\u002Fgetting-started\u002Fconfiguration\u002F)\n* ⚡ [Create Your Own Custom Notifications](https:\u002F\u002Fappriseit.com\u002Flibrary\u002Fextending\u002Fdecorator\u002F)\n* 🌎 [Apprise API\u002FWeb Interface](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise-api\u002F)\n* 📖 [Apprise Documentation Source](https:\u002F\u002Fgithub.com\u002Fcaronc\u002Fapprise-docs\u002F)\n* 🔧 [Troubleshooting](https:\u002F\u002Fappriseit.com\u002Fqa\u002F)\n* 🎉 [Showcase](https:\u002F\u002Fappriseit.com\u002Fcontributing\u002Fshowcase\u002F)\n\nWant to help make Apprise better?\n* 💡 [Contribute to the Apprise Code Base](https:\u002F\u002Fappriseit.com\u002Fcontributing\u002F)\n* ❤️ [Sponsorship and Donations](https:\u002F\u002Fappriseit.com\u002Fcontributing\u002Fsponsors\u002F)\n","Apprise 是一个支持多种平台的推送通知库。它提供了一个统一且直观的通知语法，能够向包括 Telegram、Discord、Slack 和 Amazon SNS 在内的几乎所有主流通知服务发送消息，并且支持处理图片和附件（对于接受这些内容的服务）。Apprise 极其轻量级，通过异步发送消息来保证快速响应时间。无论是开发者希望在项目中集成通知功能，还是系统管理员及 DevOps 人员需要发送运维警报或状态更新，Apprise 都能作为一个全能型解决方案满足需求。",2,"2026-06-11 02:51:03","top_language"]