Skip to main content

A python library for interacting with the Apple Push Notification Service via HTTP/2 protocol

Project description

PyAPNs2

PyPI version PyPI version Build Status

Python library for interacting with the Apple Push Notification service (APNs) via HTTP/2 protocol

Installation

Either download the source from GitHub or use pip:

$ pip install apns2-plus

Sample usage

from apns2.client import APNsClient
from apns2.payload import Payload

token_hex = 'b5bb9d8014a0f9b1d61e21e796d78dccdf1352f23cd32812f4850b87'
payload = Payload(alert="Hello World!", sound="default", badge=1)
topic = 'com.example.App'
client = APNsClient('key.pem', use_sandbox=False, use_alternative_port=False)
client.send_notification(token_hex, payload, topic)

# To send multiple notifications in a batch
Notification = collections.namedtuple('Notification', ['token', 'payload'])
notifications = [Notification(payload=payload, token=token_hex)]
client.send_notification_batch(notifications=notifications, topic=topic)

# To use token based authentication
from apns2.credentials import TokenCredentials

auth_key_path = 'path/to/auth_key'
auth_key_id = 'app_auth_key_id'
team_id = 'app_team_id'
token_credentials = TokenCredentials(auth_key_path=auth_key_path, auth_key_id=auth_key_id, team_id=team_id)
client = APNsClient(credentials=token_credentials, use_sandbox=False)
client.send_notification_batch(notifications=notifications, topic=topic)

Further Info

iOS Reference Library: Local and Push Notification Programming Guide

Contributing

To develop PyAPNs2, check out the code and install dependencies. It's recommended to use a virtualenv to isolate dependencies:

# Clone the source code.
git clone https://github.com/Pr0Ger/PyAPNs2.git
cd PyAPNs2
# Create a virtualenv and install dependencies.
virtualenv venv
. venv/bin/activate
pip install -e .[tests]

To run the tests:

pytest

You can use tox for running tests with all supported Python versions:

pyenv install 3.5.6; pyenv install 3.6.7; pyenv install 3.7.1; pyenv install 3.8.0
pyenv local 3.8.0 3.7.1 3.6.7 3.5.6
pip install tox
tox

To run the linter:

pip install pylint
pylint --reports=n apns2 test

License

PyAPNs2 is distributed under the terms of the MIT license.

See LICENSE file for the complete license details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

apns2_plus-0.7.2.1.tar.gz (10.5 kB view details)

Uploaded Source

Built Distribution

apns2_plus-0.7.2.1-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file apns2_plus-0.7.2.1.tar.gz.

File metadata

  • Download URL: apns2_plus-0.7.2.1.tar.gz
  • Upload date:
  • Size: 10.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.9.18 Linux/6.2.0-39-generic

File hashes

Hashes for apns2_plus-0.7.2.1.tar.gz
Algorithm Hash digest
SHA256 fa810c9cf19f49a686f58b394736fdf84c21a4a5e7af4a1ed9cb96d994061d72
MD5 766e116e187d7316e51cde6f428f86e9
BLAKE2b-256 45cb2cd04bd16dfbe72287773b2105ff378218f29ce5be5b3adc4d76d40313f1

See more details on using hashes here.

File details

Details for the file apns2_plus-0.7.2.1-py3-none-any.whl.

File metadata

  • Download URL: apns2_plus-0.7.2.1-py3-none-any.whl
  • Upload date:
  • Size: 10.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.9.18 Linux/6.2.0-39-generic

File hashes

Hashes for apns2_plus-0.7.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 681156e8487cda580f9d2d729c6daca10cce7ec57e43e404a1be17ff6a7ef940
MD5 3cd7ddcf47fa3f7874ad61f059568855
BLAKE2b-256 c243c747975990508b6b8d0844aad1765358e6996c02befc818171415ab70b5b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page