A complete wrapper for v3 and v4 of the TMDB's API (TheMovieDb - https://www.themoviedb.org/)
Get details about a movie:
ITmdbClient client = new TmdbClient("Token");
MovieDetail movie = await client.GetMovieDetailsAsync(693134);
Search for movies:
ITmdbClient client = new TmdbClient("Token");
ResultContainer<Movie> movies = await client.DiscoverMoviesAsync(new DiscoverMovieRequest()
{
Language = Iso639_1.English,
Year = 2024
});
Get additional informations about a movie in a single request:
ITmdbClient client = new TmdbClient("Token");
MovieDetail movie = await client.GetMovieDetailsAsync(693134,
MovieInformation.Videos | MovieInformation.Images);
foreach (Video video in movie.Videos.Results)
{}
foreach (ImageBase image in movie.Images.Posters)
{}
Note
To use the V4 Api, you need to use the TmdbV4Client
.
Add media items to a list:
ITmdbV4Client client = new TmdbV4Client("Token");
ItemsResponse response = await client.AddItemsToListAsync(139699, new ItemsRequest<ItemRequest>()
{
Media = new List<ItemRequest>()
{
new ItemRequest("movie", 550),
new ItemRequest("movie", 244786),
new ItemRequest("tv", 1396)
}
});
- Refit (Interfaces to define the api endpoints)
- RD.Extensions.Enum (Decorate enum values with additional data)
- All methods provide a
CancellationToken
to cancel the request. TmdbClient
contains all methods for the v3 api.TmdbClient
provide public properties to set default values for the Language and Country (Default is set to English and United States).- Methods and Requests support enum values for easy usage like
Iso639_1
for the language andIso3166_1
for countries. - Most static values like languages, countries, genres, etc. are provided as enums.
RD.TMDB.Client is licensed under the MIT License. See the LICENSE file for more informations.
- Add Unit Tests
- Add examples
- Add method documentations
The TMDB api is divided into different categories. Each category is represented by an interface. The TmdbClient
and TmdbV4Client
classes implement all interfaces.
The categories are as example Account, Authentication, Movies, TvShows, etc.
Append to the category name the word Provider
to get the interface name.
To get the interfaces, you can define it like this:
ITmdbClient client = new TmdbClient("Token");
IMovieProvider movieProvider = client;
//or
IMovieProvider movieProvider = new TmdbClient("Token");
MovieDetail movie = await movieProvider.GetMovieDetailsAsync(693134);