eiga

CI crates.io docs.rs license

eiga is a WIP TMDB API client.

Usage

Add eiga as a dependency in your Cargo.toml:

toml [dependencies] eiga = "0.1.0"

To send a request, the Client trait and Tmdb, the client, need to be in scope:

rs use eiga::{Client, Tmdb};

Example

This example shows how to fetch details about a movie. You can find other examples in the examples folder.

```rs use std::env; use std::error::Error;

use serde::Deserialize;

use eiga::{movie, Client, Tmdb};

// eiga doesn't provide types for endpoint responses. Instead, users provider // their own structs to deserialize into.

[derive(Deserialize)]

struct MovieDetails { release_date: String, title: String, }

fn main() -> Result<(), Box> { // Create a TMDB client by providing an API access token. Here, the token // is stored in the TMDBTOKEN environment variable. let token = env::var("TMDBTOKEN")?; let tmdb = Tmdb::new(token);

// Build an endpoint to fetch details about "Tokyo Drifter" (1966). Each
// endpoint has setter methods to set optional query string parameters.
let tokyo_drifter_id = 45706;
let movie_details_endpoint =
    movie::Details::new(tokyo_drifter_id).language("en-US");

// Send the request! Type annotations are required because `send` can
// deserialize the response to any type that implements `Deserialize`.
let movie_details: MovieDetails = tmdb.send(&movie_details_endpoint)?;

assert_eq!(movie_details.title, "Tokyo Drifter");
assert_eq!(movie_details.release_date, "1966-04-10");

Ok(())

} ```

Acknowledgements