Skip to main content

An efficient APNs Client Library for Python/asyncio

Project description

https://github.com/Fatal1ty/aioapns/workflows/tests/badge.svg https://img.shields.io/pypi/v/aioapns.svg https://img.shields.io/pypi/pyversions/aioapns.svg https://img.shields.io/badge/License-Apache%202.0-blue.svg

aioapns is a library designed specifically for sending push-notifications to iOS devices via Apple Push Notification Service. aioapns provides an efficient client through asynchronous HTTP2 protocol for use with Python’s asyncio framework.

aioapns requires Python 3.6 or later.

Performance

In my testing aioapns allows you to send on average 1.3k notifications per second on a single core.

Features

  • Internal connection pool which adapts to the current load

  • Support for certificate and token based connections

  • Ability to set TTL (time to live) for notifications

  • Ability to set priority for notifications

  • Ability to set collapse-key for notifications

  • Ability to use production or development APNs server

Installation

Use pip to install:

$ pip install aioapns

Basic Usage

import asyncio
from uuid import uuid4
from aioapns import APNs, NotificationRequest, PushType


async def run():
    apns_cert_client = APNs(
        client_cert='/path/to/apns-cert.pem',
        use_sandbox=False,
    )
    apns_key_client = APNs(
        key='/path/to/apns-key.p8',
        key_id='<KEY_ID>',
        team_id='<TEAM_ID>',
        topic='<APNS_TOPIC>',  # Bundle ID
        use_sandbox=False,
    )
    request = NotificationRequest(
        device_token='<DEVICE_TOKEN>',
        message = {
            "aps": {
                "alert": "Hello from APNs",
                "badge": "1",
            }
        },
        notification_id=str(uuid4()),  # optional
        time_to_live=3,                # optional
        push_type=PushType.ALERT,      # optional
    )
    await apns_cert_client.send_notification(request)
    await apns_key_client.send_notification(request)

loop = asyncio.get_event_loop()
loop.run_until_complete(run())

License

aioapns is developed and distributed under the Apache 2.0 license.

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

aioapns-3.1.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

aioapns-3.1-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file aioapns-3.1.tar.gz.

File metadata

  • Download URL: aioapns-3.1.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.1

File hashes

Hashes for aioapns-3.1.tar.gz
Algorithm Hash digest
SHA256 0544912030317952a566d79880665990c7149fa840a357d609bb997076575215
MD5 012009517fcf729cfa03b05845b69f60
BLAKE2b-256 2abf45b7028ed859ba4345329115a9f7eac8b8149d858a5038b7e0cd149704ba

See more details on using hashes here.

File details

Details for the file aioapns-3.1-py3-none-any.whl.

File metadata

  • Download URL: aioapns-3.1-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.1

File hashes

Hashes for aioapns-3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6220827c156be7f7aceb40cc388b0129c6a33221b06cc73399b39a7d2997c338
MD5 9f0c16d82543ba32bd6d00fe75c0f206
BLAKE2b-256 217dd8dfaf16b4814f0afd86f19197b3cb0d187db763dc0293ed40f45457d076

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