#firebase #push-notifications #fcm #send-notifications #api-bindings #rust

fcm-rs

A Rust crate for easy interaction with Firebase Cloud Messaging API (V1)

2 unstable releases

0.2.0 Jul 20, 2024
0.1.0 Jun 12, 2024

#1523 in Web programming

Download history 111/week @ 2024-06-09 17/week @ 2024-06-16 1/week @ 2024-06-23 1/week @ 2024-07-07 86/week @ 2024-07-14 43/week @ 2024-07-21 10/week @ 2024-07-28 16/week @ 2024-08-18 11/week @ 2024-08-25 31/week @ 2024-09-01 47/week @ 2024-09-08 77/week @ 2024-09-15

168 downloads per month

MIT license

13KB
138 lines

Firebase Cloud Messaging API v1 Rust Crate

This Rust crate provides a convenient way to send notifications using Firebase Cloud Messaging (FCM) API v1. It leverages async/await for asynchronous operations and supports loading service account credentials from a JSON file.

Installation

Add this crate to your Cargo.toml:

[dependencies]
fcm-rs = "0.2.0"

Usage

Below is an example of how to use this crate to send a notification:

use fcm_rs::{ client::FcmClient, models::{ Message, Notification } };

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let service_account_path = "path/to/service_account";

    // Create a new FCM client
    let client = FcmClient::new(service_account_path).await?;

    // Define the message with the target device token and notification details
    let message = Message {
        token: Some("your_device_token".to_string()),
        notification: Some(Notification {
            title: Some("Hello from Rust!".to_string()),
            body: Some("This is a test notification.".to_string()),
        }),
        data: None,
    };

    // Send the message and handle the response
    let response = client.send(message).await?;
    println!("FCM response: {:?}", response);

    Ok(())
}

Contribution

Contributions are welcome! Feel free to submit issues or pull requests.

Contact

For any queries or suggestions, please open an issue on the GitHub repository.

Dependencies

~12–24MB
~365K SLoC