Crates.io | rustnao |
lib.rs | rustnao |
version | 0.3.4 |
source | src |
created_at | 2019-06-09 03:03:16.740598 |
updated_at | 2024-07-25 04:36:25.807989 |
description | A Rust implementation of a wrapper for the SauceNAO API. |
homepage | |
repository | https://github.com/ClementTsang/RustNAO |
max_upload_size | |
id | 139896 |
size | 259,507 |
A Rust implementation of a wrapper for the SauceNAO API.
Add the following to your Cargo.toml
file:
[dependencies]
rustnao = "0.3.4"
Here's a simple example:
use rustnao::{HandlerBuilder, Sauce};
fn main() {
let api_key = "your_api_key";
let file = "https://i.imgur.com/W42kkKS.jpg";
// Specifying our key, test_mode set to 0, only want to see Pixiv and Sankaku using a mask, nothing excluded, no one specific source, and 15 results at most
let handle = HandlerBuilder::default().api_key(api_key).db_mask([Handler::PIXIV, Handler::SANKAKU_CHANNEL].to_vec()).num_results(15).build();
// Set the minimum similarity to 45.
handle.set_min_similarity(45);
// Returns a vector of Sauce objects if successful
let result: Vec<Sauce> = handle.get_sauce(file, None, None).unwrap();
// Or perhaps you prefer a JSON output
let result_json: String = handle.get_sauce_as_pretty_json(file, None, None).unwrap();
// Or maybe you wish to only get 5 results with a min similarity of 50.0
let result_json_filtered: String = handle.get_sauce_as_pretty_json(file, Some(5), Some(50 as f64)).unwrap();
}
See more examples here.
Further documentation can be found here. You can also see SauceNAO's API documentation here.
Interested in helping? Found a problem/bug? Let me know!
I was inspired by Sagiri, so I have to give a shoutout that project. Furthermore, thanks to SauceNAO which provides this amazing functionality for free.
Also, credit to Pixiv user リン ☆ ユウ@1 日目 西れ 44b for this image I used frequently for examples and tests. I couldn't seem to find the image I used for local testing (SauceNAO failed me), if anyone knows let me know so I can credit them.