TheMovieDbWrapper is a C# wrapper for themoviedb.org API providing cross-platform support for Xamarin, iOS, Android, and all flavors of .NET.
A nuget package is available directly through Visual Studio: https://www.nuget.org/packages/TheMovieDbWrapper/
The current release supports common requests for movie and other miscellaneous information, such as:
- themoviedb.org configuration information
- Movie information
- Movie rating information
- TV show information
- Movie and TV genres
- Movie/TV industry specific professions
- Production company information
- People information
In order to use any feature of the wrapper, a concrete implementation of the IMovieDbSettings interface must be created. The interface only contains 2 properties:
- ApiKey: a private key required to query themoviedb.org API.
- ApiUrl: the URL used for api calls to themoviedb.org. This URL should be static, but is included in case an alternative URL is ever provided. The current URL is
http://api.themoviedb.org/3/
Once the IMovieDbSettings
interface has been implemented, it can be used to register your settings with the MovieDbFactory
.
Note: There is an overloaded method on the MovieDbFactory
which allows you to register your settings as parameters to the method.
The MovieDbFactory
provides access to all exposed operations for retrieving information from themoviedb.org. The factory exposes the following methods (other methods may be exposed, but these are the important ones):
void MovieDbFactory.RegisterSettings( IMovieDbSettings settings )
: Registers your themoviedb.org specific API key with the factory.void MovieDbFactory.RegisterSettings( string apiKey, string apiUrl = "http://api.themoviedb.org/3/" )
: Registers your themoviedb.org specific API key with the factory.Lazy<T> MovieDbFactory.Create<T>() where T : IApiRequest
: Creates the specific API requested. See below (Usages - Interfaces) for all exposed interfaces. One of theRegisterSettings
methods must be called prior to creating anything from the factory.
The following interfaces can be used to retrieve information:
IApiConfigurationRequest
: Provides access for retrieving themoviedb.org configuration information.IApiMovieRequest
: Provides access for retrieving information about Movies.IApiMovieRatingRequest
: Provides access for retrieving movie rating information.IApiTVShowRequest
: Provides access for retrieving information about TV shows.IApiGenreRequest
: Provides access for retrieving Movie and TV genres.IApiCompanyRequest
: Provides access for retrieving production company information.IApiProfessionRequest
: Provides access for retrieving information about Movie/TV industry specific professions.IApiPeopleRequest
: Provides access for retrieving information about People.
Register your settings first:
// registration with an implementation of IMovieDbSettings
//, i.e., public class YourMovieDbSettings : IMoveDbSettings { // implementation }
MovieDbFactory.RegisterSettings( new YourMovieDbSettings() )
// alternative method of registration
MovieDbFactory.RegisterSettings( "your-apiKey", "http://api.themoviedb.org/3/" )
Retrieve an API request interface (see Usage - Interfaces above for available interfaces):
// as the factory returns a Lazy<T> instance, simply grab the Value out of the Lazy<T>
// and assign to a local variable.
var movieApi = MovieDbFactory.Create<IApiMovieRequest>().Value
Use the API request interface to retrieve information:
ApiSearchResponse<MovieInfo> response = await _api.SearchByTitleAsync( "Star Trek" );
The ApiSearchResponse<T>
provides rich information about the results of the search:
IReadOnlyList<T> Results
: The list of results from the search.int PageNumber
: The current page number of the search result.int TotalPages
: The total number of pages found from the search result.int TotalResults
: The total number of results from the search.ToString()
: returns "Page x of y (z total results)".ApiError Error
: Contains specific error information if an error was encountered during the API call to themoviedb.org.ApiRateLimit RateLimit
: Contains the current rate limits from your most recent API call to themoviedb.org.
Other methods querying on specific Id's, such as IApiMovieRequest.FindByIdAsync( movieId )
will return an ApiQueryResponse<T>
with a single result as well as some common information seen in the ApiSearchResponse
:
T Item
: The item returned from the API call, where T is the specific query such asMovieInfo
,Movie
,MovieCredit
, etc..ToString()
: returns the ToString method of the Item.ApiError Error
: Contains specific error information if an error was encountered during the API call to themoviedb.org.ApiRateLimit RateLimit
: Contains the current rate limits from your most recent API call to themoviedb.org.
// RegisterSettings only needs to be called one time when your application starts-up.
MovieDbFactory.RegisterSettings( new YourMovieDbSettings() )
var movieApi = MovieDbFactory.Create<IApiMovieRequest>().Value;
ApiSearchResponse<MovieInfo> response = await movieApi.SearchByTitleAsync( "Star Trek" );
foreach( MovieInfo info in response.Results )
{
Console.WriteLine( "{0} ({1}): {2}" info.Title, info.ReleaseDate, info.Overview );
}
See the MovieInfo class for all available information from a movie search response.
var movieApi = MovieDbFactory.Create<IApiMovieRequest>().Value;
int pageNumber = 1;
int totalPages;
do
{
ApiSearchResponse<MovieInfo> response = await movieApi.SearchByTitleAsync( "Harry", pageNumber );
// alternatively, just call response.ToString() which will provide the same paged information format as below:
Console.WriteLine( "Page {0} of {1} ({2} total results)", response.PageNumber, response.TotalPages, response.TotalResults );
foreach( MovieInfo info in response.Results )
{
Console.WriteLine( "{0} ({1}): {2}", info.Title, info.ReleaseDate, info.Overview );
}
totalPages = response.TotalPages;
} while( pageNumber++ < totalPages );
- The API we've exposed should be fairly straight forward. All interfaces, classes, methods, properties, etc... have full intellisense support. If you need more detailed examples, just ask!
- You may also browse the suite of integration tests covering all usages of the API.