/* * Copyright (c) 2004-2016 Stuart Boston * * This file is part of TheMovieDB API. * * TheMovieDB API is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * TheMovieDB API is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with TheMovieDB API. If not, see <http://www.gnu.org/licenses/>. * */ package com.omertron.themoviedbapi.methods; import com.omertron.themoviedbapi.MovieDbException; import com.omertron.themoviedbapi.model.person.CreditInfo; import com.omertron.themoviedbapi.tools.ApiUrl; import com.omertron.themoviedbapi.tools.HttpTools; import com.omertron.themoviedbapi.tools.MethodBase; import com.omertron.themoviedbapi.tools.Param; import com.omertron.themoviedbapi.tools.TmdbParameters; import java.io.IOException; import java.net.URL; import org.yamj.api.common.exception.ApiExceptionType; /** * Class to hold the Credit Methods * * @author stuart.boston */ public class TmdbCredits extends AbstractMethod { /** * Constructor * * @param apiKey * @param httpTools */ public TmdbCredits(String apiKey, HttpTools httpTools) { super(apiKey, httpTools); } /** * Get the detailed information about a particular credit record. * <p> * This is currently only supported with the new credit model found in TV. * <br/> * These IDs can be found from any TV credit response as well as the * TV_credits and combined_credits methods for people. <br/> * The episodes object returns a list of episodes and are generally going to * be guest stars. <br/> * The season array will return a list of season numbers. <br/> * Season credits are credits that were marked with the "add to every * season" option in the editing interface and are assumed to be "season * regulars". * * @param creditId * @param language * @return * @throws MovieDbException */ public CreditInfo getCreditInfo(String creditId, String language) throws MovieDbException { TmdbParameters parameters = new TmdbParameters(); parameters.add(Param.ID, creditId); parameters.add(Param.LANGUAGE, language); URL url = new ApiUrl(apiKey, MethodBase.CREDIT).buildUrl(parameters); String webpage = httpTools.getRequest(url); try { return MAPPER.readValue(webpage, CreditInfo.class); } catch (IOException ex) { throw new MovieDbException(ApiExceptionType.MAPPING_FAILED, "Failed to get credit info", url, ex); } } }