18 releases (4 breaking)
new 0.6.0 | Jan 2, 2025 |
---|---|
0.5.2 | Dec 29, 2024 |
0.5.1 | Nov 4, 2024 |
0.3.5 | Jun 17, 2024 |
0.1.0 |
|
#359 in Web programming
430 downloads per month
57KB
1.5K
SLoC
Expo Push Notification Client for Rust
This is an official Expo Push Notification Client for Rust.
Client (ReactNative with Expo)
You need to get Expo Push Token from Expo SDK and send it to Expo server first. See docs for more details.
Server (Rust)
Install
cargo add expo_push_notification_client
Usage
use expo_push_notification_client::{Expo, ExpoClientOptions, ExpoPushMessage};
// Initialize Expo client
let expo = Expo::new(ExpoClientOptions {
access_token: Some(access_token),
});
// Define Expo Push Tokens to send notifications to
let expo_push_tokens = ["ExponentPushToken[xxxxxxxxxxxxxxxxxxxxxx]"];
// Build Expo Push Message with specified tokens
let expo_push_message = ExpoPushMessage::builder(expo_push_tokens).build()?;
// Send push notifications using Expo client
let tickets = expo.send_push_notifications(expo_push_message).await;
// Extract push notification IDs from tickets
let mut expo_push_ids = vec![];
for ticket in tickets {
match ticket {
ExpoPushTicket::Ok(ticket) => {
expo_push_ids.push(ticket.id);
}
ExpoPushTicket::Error(e) => {
// Handle error
}
}
}
// Retrieve push notification receipts using Expo client
expo.get_push_notification_receipts(expo_push_ids).await;
Additionally, you can further customize the ExpoPushMessage by adding more options. Refer to the docs for more details.
// Build Expo Push Message with detailed configurations
#[derive(Serialize)]
struct Data {
data: String,
}
let expo_push_message = ExpoPushMessage::builder(["ExponentPushToken[xxxxxxxxxxxxxxxxxxxxxx]"])
.body("body")
.data(&Data { data: "data".to_string()})?
.ttl(100)
.expiration(100)
.priority("high")
.subtitle("subtitle")
.sound("default")
.badge(1)
.channel_id("channel_id")
.category_id("category_id")
.mutable_content(true)
.title("title")
.build()?;
Changing TLS Backend
This crate uses Reqwest with its default features. However, you can change tls backend by disabling the default features and enabling the rustls-tls
feature, which uses a Rust implementation of TLS. This approach may offer better compatibility across different environments.
expo_push_notification_client = { version = "0.5.0", default-features = false, features = ["rustls-tls"] }
Dependencies
~9–23MB
~351K SLoC