#pure #fetching #basic #blocking #link #request #dagpi

dagpirs

A pure rust wrapper for dagpi, with image manipulation and data fetching

7 releases

0.1.7 Aug 2, 2021
0.1.6 Jun 5, 2021
0.1.5 May 4, 2021
0.1.3 Mar 18, 2021

#448 in Images

MIT license

48KB
1K SLoC

Dagpi.rs

License Chat crate Rust Report Actions Docs Codacy Badge

A pure rust wrapper for dagpi.


Crate: link

Docs: link

Discord: link

Please Note this was inspired by Ksoft.rs. License

Async Useage


Cargo.toml

[dependencies]
version="1.0.0"


[dependencies.tokio]
version = "1.0"
features = ["macros"]

Basic Client

Data Request

Uses a very basic Data Endpoint to fetch data from the api.


use dagpi::Client;

#[tokio::main]
async fn main() {
    let client =
        Client::new("TOKEN").unwrap();
    match client.data.fact().await.unwrap() {
        Ok(f) => println!("{}", f.fact),
        Err(e) => println!("{:?}", e),
    };
}

Image Request

Uses the image client ot process and save an image to file based on it;s format!

use dagpi::Client;

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

    let client =
        Client::new("TOKEN").unwrap();
    match client.image.image_proess("https://cdn.discordapp.com/avatars/716323270982631476/fa9fed1ed0d51eb4a15b654f3ae08215.png".to_string(), dagpi::models::ImageManipulation::Wanted).await.unwrap() {
        Ok(v) => {
            let buff: Bytes = v.bytes;
            let mut f = fs::File::create(format!("memes.{}", v.format)).unwrap();
            f.write_all(buff.to_vec().as_slice()).unwrap();
        }
        Err(s) => println!("{}", s),
    };
}

Complex Image Request: Discord

use dagpi::Client;
#[tokio::main]
async fn main() {
    let client =
        Client::new("").unwrap();
    match client.data.fact().await.unwrap() {
        Ok(f) => println!("{}", f.fact),
        Err(e) => println!("{:?}", e),
    };

    match client.image.yt("https://cdn.discordapp.com/avatars/716323270982631476/fa9fed1ed0d51eb4a15b654f3ae08215.png".to_string(), "daggy", "Tweeting using dagpi.xyz is so much fun!. Goes great with dagpi.rs", false).await.unwrap() {
        Ok(v) => {
            let buff: Bytes = v.bytes;
            let mut f = fs::File::create(format!("discord.{}", v.format)).unwrap();
            f.write_all(buff.to_vec().as_slice()).unwrap();
        }
        Err(s) => println!("{}", s),
    };
}

Blocking Useage


Basic blocking usecase.

Cargo.toml BLocking

[dependencies.dagpirs]
version="1.0.0"
default-features=false
features = ["blocking"]

Basic Blocking Client

Data Request Blocking

Uses a very basic Data Endpoint to fetch data from the api.


use dagpi::Client;

fn main() {
    let client =
        Client::new("TOKEN").unwrap();
    match client.data.roast().unwrap() {
        Ok(f) => println!("{}", f.roast),
        Err(e) => println!("{:?}", e),
    };
}

Image Request Blocking

Uses the image client ot process and save an image to file based on it;s format!

use dagpi::Client;

fn main() {

    let client =
        Client::new("TOKEN").unwrap();
    match client.image.image_proess("https://cdn.discordapp.com/avatars/716323270982631476/fa9fed1ed0d51eb4a15b654f3ae08215.png".to_string(), dagpi::models::ImageManipulation::Wasted).unwrap() {
        Ok(v) => {
            let buff: Bytes = v.bytes;
            let mut f = fs::File::create(format!("memes.{}", v.format)).unwrap();
            f.write_all(buff.to_vec().as_slice()).unwrap();
        }
        Err(s) => println!("{}", s),
    };
}

Complex Image Request: Pride

use dagpi::Client;
fn main() {
    let client =
        Client::new("").unwrap();
    match client.image.pride("https://cdn.discordapp.com/avatars/716323270982631476/fa9fed1ed0d51eb4a15b654f3ae08215.png".to_string(), dagpi::models::Pride::Bisexual).unwrap() {
        Ok(v) => {
            let buff: Bytes = v.bytes;
            let mut f = fs::File::create(format!("discord.{}", v.format)).unwrap();
            f.write_all(buff.to_vec().as_slice()).unwrap();
        }
        Err(s) => println!("{}", s),
    };
}

Docs for more examples.

Or the Examples folder in the repo.

Dependencies

~7–18MB
~255K SLoC