sauce-api

documentation crates.io

sauce-api is an API for finding the source image for low-quality or cropped images.
Currently it only works with anime-styled images, but I hope to makeit capable of doing other kinds of images as well.

Asynchronous due to the usage of reqwest, and works best with Tokio.

Supported Sources

If you wish to see more, please submit PRs or a request in an issue!

Usage

IQDB

```rust use sauceapi::source::{Output, iqdb::Iqdb, Source}; use sauceapi::error::Error;

async fn find_source(url: &str) { let source = Iqdb::create(()).await.unwrap(); let res: Result = source.check(url).await; // Can take some time as IQDB is a bit slow.

match res {
    Ok(result) => {
        println!("Found results! {:?}", result);
    }
    Err(e) => {
        eprintln!("Unable to find results: {}", e);
    }
}

} ```

SauceNao

```rust use sauceapi::source::{Output, saucenao::SauceNao, Source}; use sauceapi::error::Error;

async fn findsource(url: &str, apikey: &str) { let source = SauceNao::create(apikey.tostring()).await.unwrap(); let res: Result = source.check(url).await;

match res {
    Ok(result) => {
        println!("Found results! {:?}", result);
    }
    Err(e) => {
        eprintln!("Unable to find results: {}", e);
    }
}

} ```

Requirements

sauce-api by default uses the native TLS framework, see this for specific details. You may opt-in to using rustls if you would like to by enabling the rustls feature like this:

toml sauce-api = { version = "1.0.0", features = ["rustls"] }