eiga
is a WIP TMDB API client.
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};
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.
struct MovieDetails { release_date: String, title: String, }
fn main() -> Result<(), Box
// 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(())
} ```
eiga
is mostly based on the design of the
gitlab
crate. There's a nice writeup on its design
here.