fcm-rs

Crates.iofcm-rs
lib.rsfcm-rs
version0.2.0
sourcesrc
created_at2024-06-12 09:40:10.344712
updated_at2024-07-20 14:25:10.579279
descriptionA Rust crate for easy interaction with Firebase Cloud Messaging API (V1).
homepage
repositoryhttps://github.com/calalalizade/fcm-rs
max_upload_size
id1269450
size14,640
Jalal Alizadeh (calalalizade)

documentation

README

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.

Commit count: 4

cargo fmt