HTTP/2 Apple Push Notification Service for Rust using Tokio and async sending.
Serialize
, allowing use of structs or dynamic hashmaps..p12
certificate databases to connect using a custom certificate..p8
private keys to connect using authentication tokens.Add this to Cargo.toml
:
[dependencies]
a2 = "0.3"
tokio = "0.1"
futures = "0.1"
then add to your crate root:
rust
extern crate a2;
extern crate tokio;
extern crate futures;
The library supports connecting to Apple Push Notification service either using a certificate with a password or a private key with a team id and key id. Both are available from your Apple account and with both it is possible to send push notifications to one application.
We've been pushing some millions of notifications daily through this library and are quite happy with it. Some things to know, if you're evaluating the library for production use:
Do not open new connections for every request. Apple will treat it as Denial of Service attack and block the sending IP address. When using the same Client
for multiple requests, the Client
keeps the connection alive if pushing steady traffic through it.
For one app, one connection is quite enough already for certain kind of loads. With http2 protocol, the events are asynchronous and the pipeline can hold several outgoing requests at the same time. The biggest reason to open several connections is for redundancy, running your sender service on different machines.
It seems to be Apple doesn't like when sending tons of notifications with
faulty device tokens and it might lead to ConnectionError
s. Do not send more
notifications with tokens that return Unregistered
, BadDeviceToken
or
DeviceTokenNotForTopic
.
cargo test