imgbb

Crates.ioimgbb
lib.rsimgbb
version1.2.1
sourcesrc
created_at2023-06-29 15:51:18.423393
updated_at2023-07-06 14:10:11.746968
descriptionImgBB API wrapper for Rust
homepage
repositoryhttps://github.com/phusitsom/imgbb-rs
max_upload_size
id903411
size46,957
Phusit Somboonyingsuk (lazykern)

documentation

README

imgbb-rs

ImgBB API wrapper for rust

Getting Started

  1. Register/Log in to ImbBB
  2. Obtain the API Key
  3. Use the API Key in with the library

Usage

Straightforward

use imgbb::ImgBB;
use tokio;

#[tokio::main]
async fn main() {
    let imgbb = ImgBB::new("<API KEY>");


    let res = match imgbb.upload_file_with_expiration("<PATH>", <SECONDS>).await {
        Ok(res) => res,
        Err(err) => {
            println!("{}", err);
            return;
        }
    };

    println!("{:#?}", res);
}

With uploader

use imgbb::ImgBB;
use tokio;

#[tokio::main]
async fn main() {

    let imgbb = ImgBB::new("<API KEY>");

    let ul = imgbb
        .read_file("<PATH>").expect("Unable to read file")
        .expiration(<SECONDS>);

    let res = match ul.upload().await {
        Ok(res) => res,
        Err(err) => {
            println!("{}", err);
            return;
        }
    };

    println!("{:#?}", res);
}

Supported data types

  • File & Path
    imgbb.read_file("PATH").expect("Unable to read file").upload().await
    // or
    imgbb.upload_file("PATH").await
  • Bytes (AsRef<u8>)
    imgbb.read_bytes(&[u8]).upload().await
    // or
    imgbb.upload_bytes(&[u8]).await
  • Base64 String
    imgbb.read_base64("BASE64").upload().await
    // or
    imgbb.upload_base64("BASE64").await

License

imgbb-rs is licensed under the GNU GPL v3.0

Commit count: 30

cargo fmt