ferogram 0.5.1

Production-grade async Telegram MTProto client: updates, bots, flood-wait, dialogs, messages
Documentation
// Copyright (c) Ankit Chaubey <ankitchaubey.dev@gmail.com>
//
// ferogram: async Telegram MTProto client in Rust
// https://github.com/ankit-chaubey/ferogram
//
// Licensed under either the MIT License or the Apache License 2.0.
// See the LICENSE-MIT or LICENSE-APACHE file in this repository:
// https://github.com/ankit-chaubey/ferogram
//
// Feel free to use, modify, and share this code.
// Please keep this notice when redistributing.

//! Generate a string session for serverless deployments.
//!
//! Logs in once via a local session file, exports a compact session string,
//! then prints it. Store the string in SESSION_STRING and use it with the
//! serverless_userbot example to connect without a session file.
//!
//! Run:
//!   cargo run --example string_session_gen
//!
//! Keep the string private. It gives full access to your account.

use ferogram::Client;

const API_ID: i32 = 0; // fill in from https://my.telegram.org
const API_HASH: &str = ""; // fill in from https://my.telegram.org

#[tokio::main]
async fn main() {
    if let Err(e) = run().await {
        eprintln!("error: {e}");
        std::process::exit(1);
    }
}

async fn run() -> Result<(), Box<dyn std::error::Error>> {
    if API_ID == 0 || API_HASH.is_empty() {
        eprintln!("Fill in API_ID and API_HASH at the top of string_session_gen.rs");
        std::process::exit(1);
    }

    let (client, _shutdown) = Client::quick_connect("gen.session", API_ID, API_HASH).await?;

    // export_session_string calls get_me() internally
    let session_string = client.export_session_string().await?;

    println!("Your session string:\n");
    println!("{session_string}");
    println!("\nSet SESSION_STRING to this value and run the serverless_userbot example.");
    println!("Keep it private. It gives full access to your account.");

    Ok(())
}