14 releases (9 breaking)

Uses new Rust 2024

new 0.11.0 Mar 12, 2026
0.9.0 Feb 21, 2026

#233 in HTTP client


Used in 3 crates (2 directly)

MIT license

765KB
11K SLoC

hero pane

Crates.io Documentation MIT License PRs Welcome

Features · Installation · Quickstart · Running the CLI Examples · Documentation · Contributing · Support · License


Features

  • Authentication:

    • Full registration flow (account creation + email verification)
    • Login (supports both v1 and v2/PBKDF2 authentication)
    • Session management and caching
    • Password Change (change_password)
  • Filesystem:

    • Fetch filesystem tree
    • List files and directories
    • Get node information (stat)
    • Create directories (mkdir)
    • Remove files/folders (rm)
    • Rename files/folders (rename)
    • Move files/folders (mv)
    • Access Public Folders (open_folder)
  • File Transfer:

    • File upload with optional resume support
    • File download with resume support
    • Parallel transfer workers support
    • Progress callbacks for monitoring transfers
    • Text/Video/Image streaming support
    • Automatic thumbnail generation on upload
    • Public link generation (export, export_many)
    • Proxy support (HTTP/HTTPS/SOCKS5)
  • Node Operations:

    • Get node by handle
    • Check ancestor relationships
    • Check write permissions
  • Sharing & Contacts:

    • Share folders with other users by path (share_folder)
    • List contacts (list_contacts)
    • Access incoming shared folders

Installation

Add this to your Cargo.toml:

[dependencies]
megalib = "0.8.1"
tokio = { version = "1", features = ["full"] }

Quickstart

Minimal login + list to confirm everything works:

use megalib::SessionHandle;

#[tokio::main]
async fn main() -> megalib::Result<()> {
    let session = SessionHandle::login("user@example.com", "password").await?;
    session.refresh().await?;

    // Cloud Drive paths are rooted at /Root
    for node in session.list("/Root", false).await? {
        println!("{} ({} bytes)", node.name, node.size);
    }

    Ok(())
}

Examples

Run any command as shown (replace placeholder values with your own).

# Auth + listing
cargo run --example login -- --email you@example.com --password "your-password"
cargo run --example ls -- --email you@example.com --password "your-password" --path /Root
cargo run --example cached_session -- --email you@example.com --password "your-password"

# Upload / download
cargo run --example upload -- --email you@example.com --password "your-password" ./local-file.txt /Root
cargo run --example download -- --email you@example.com --password "your-password" /Root/remote-file.txt ./downloaded-file.txt

# Resume transfers
cargo run --example upload_resume -- --email you@example.com --password "your-password" ./large-file.bin /Root
cargo run --example download_resume -- --email you@example.com --password "your-password" /Root/large-file.bin ./large-file.bin

# Sharing + links
cargo run --example export -- --email you@example.com --password "your-password" --path /Root/file.txt
cargo run --example share -- --email you@example.com --password "your-password" --folder /Root/shared --recipient friend@example.com --level 0

# Filesystem operations
cargo run --example stat -- --email you@example.com --password "your-password" --path /Root/file.txt
cargo run --example mkdir -- --email you@example.com --password "your-password" /Root/new-folder
cargo run --example rm -- --email you@example.com --password "your-password" /Root/old-file.txt
cargo run --example rename -- --email you@example.com --password "your-password" /Root/file.txt file-renamed.txt
cargo run --example mv -- --email you@example.com --password "your-password" /Root/file.txt /Root/destination-folder

# Public links / folders
cargo run --example folder -- "https://mega.nz/folder/<FOLDER_ID>#<KEY>"
cargo run --example download_public -- "https://mega.nz/file/<FILE_ID>#<KEY>" ./public-file.bin

# In-memory / reader uploads
cargo run --example upload_bytes -- --email you@example.com --password "your-password" /Root
cargo run --example upload_reader -- --email you@example.com --password "your-password" /Root

# Account management
cargo run --example passwd -- --email you@example.com --password "current-password" --new "new-password"
cargo run --example register -- --email you@example.com --password "your-password" --name "Your Name"
cargo run --example verify -- --state "SESSION_KEY_FROM_STEP_1" --link "CONFIRMATION_LINK_OR_FRAGMENT"

# Full workflow demo
cargo run --example sequence -- --email you@example.com --password "your-password"

--proxy <PROXY_URL> is also supported on credential-based examples.

Documentation

For detailed API documentation, visit docs.rs/megalib.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/cool-feature)
  3. Commit your changes (git commit -m 'Add some cool feature')
  4. Push to the branch (git push origin feature/cool-feature)
  5. Open a Pull Request

Support

If this crate saves you time or helps your work, support is appreciated:

Ko-fi

License

This project is licensed under the MIT License; see the license for details.

Disclaimer

This is an unofficial client library and is not affiliated with, associated with, authorized by, endorsed by, or in any way officially connected with Mega Limited.

Dependencies

~18–37MB
~463K SLoC