A robust client library for Apple's push notification service.
This is a client library for Apple’s push notification service. It is not the first such library for Python, but, as is often the way, the existing options didn’t quite meet our needs:
- No dependencies (other than six).
- Fire and forget. APNs is a quirky binary protocol that frequently requires reconnecting to the service and re-sending notifications after an error.
- Robust. We don’t do quick and dirty here. Readability, tests, and documentation are not optional.
An APNs client is by nature stateful. The default apns-worker backend uses Python threads to asynchronously process a queue of messages to send to the service. Most users will want to maintain a global ApnsManager instance to process messages. Note that if your own program is threaded, you may need to take care to create this global instance safely.
from apns_worker import ApnsManager apns = None def init_apns(key_path, cert_path): """ Call this once at program init time. """ global apns apns = ApnsManager(key_path, cert_path) def send_badge(token, badge=1): """ Badge the app on a single device. """ apns.send_aps([token], badge=badge)
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, Size & Hash SHA256 Hash Help||File Type||Python Version||Upload Date|
(22.6 kB) Copy SHA256 Hash SHA256
|Wheel||py2.py3||Oct 18, 2015|
(26.8 kB) Copy SHA256 Hash SHA256
|Source||None||Oct 7, 2015|