Discover
parent
e4dc8e9465
commit
45caa4d14d
@ -0,0 +1,23 @@
|
|||||||
|
package com.omertron.themoviedbapi.enumeration;
|
||||||
|
|
||||||
|
public enum SortBy {
|
||||||
|
|
||||||
|
POPULARITY_ASC,
|
||||||
|
POPULARITY_DESC,
|
||||||
|
RELEASE_DATE_ASC,
|
||||||
|
RELEASE_DATE_DESC,
|
||||||
|
REVENUE_ASC,
|
||||||
|
REVENUE_DESC,
|
||||||
|
PRIMARY_RELEASE_DATE_ASC,
|
||||||
|
PRIMARY_RELEASE_DATE_DESC,
|
||||||
|
ORIGINAL_TITLE_ASC,
|
||||||
|
ORIGINAL_TITLE_DESC,
|
||||||
|
VOTE_AVERAGE_ASC,
|
||||||
|
VOTE_AVERAGE_DESC,
|
||||||
|
VOTE_COUNT_ASC,
|
||||||
|
VOTE_COUNT_DESC;
|
||||||
|
|
||||||
|
public String getPropertyString() {
|
||||||
|
return this.name().toLowerCase().replace("_asc", ".asc").replaceAll("_desc", ".desc");
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,248 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2004-2015 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;private either version 3 of the License;private or
|
|
||||||
* any later version.
|
|
||||||
*
|
|
||||||
* TheMovieDB API is distributed in the hope that it will be useful;private
|
|
||||||
* 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;private see <http://www.gnu.org/licenses/>.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package com.omertron.themoviedbapi.model.discover;
|
|
||||||
|
|
||||||
import com.omertron.themoviedbapi.tools.Param;
|
|
||||||
import com.omertron.themoviedbapi.tools.TmdbParameters;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Generate a discover object for use in the MovieDbApi
|
|
||||||
* <p/>
|
|
||||||
* This allows you to just add the search components you are concerned with
|
|
||||||
*
|
|
||||||
* @author stuart.boston
|
|
||||||
*/
|
|
||||||
public class Discover {
|
|
||||||
|
|
||||||
private final TmdbParameters params = new TmdbParameters();
|
|
||||||
|
|
||||||
private static final int YEAR_MIN = 1900;
|
|
||||||
private static final int YEAR_MAX = 2100;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the parameters
|
|
||||||
* <p/>
|
|
||||||
* This will be used to construct the URL in the API
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public TmdbParameters getParams() {
|
|
||||||
return params;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Minimum value is 1 if included.
|
|
||||||
*
|
|
||||||
* @param page
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover page(int page) {
|
|
||||||
params.add(Param.PAGE, page);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ISO 639-1 code
|
|
||||||
*
|
|
||||||
* @param language
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover language(String language) {
|
|
||||||
params.add(Param.LANGUAGE, language);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Available options are <br>
|
|
||||||
* vote_average.desc<br>
|
|
||||||
* vote_average.asc<br>
|
|
||||||
* release_date.desc<br>
|
|
||||||
* release_date.asc<br>
|
|
||||||
* popularity.desc<br>
|
|
||||||
* popularity.asc
|
|
||||||
*
|
|
||||||
* @param sortBy
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover sortBy(String sortBy) {
|
|
||||||
params.add(Param.SORT_BY, sortBy);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Toggle the inclusion of adult titles
|
|
||||||
*
|
|
||||||
* @param includeAdult
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover includeAdult(boolean includeAdult) {
|
|
||||||
params.add(Param.ADULT, includeAdult);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Filter the results release dates to matches that include this value.
|
|
||||||
*
|
|
||||||
* @param year
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover year(int year) {
|
|
||||||
if (checkYear(year)) {
|
|
||||||
params.add(Param.YEAR, year);
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Filter the results so that only the primary release date year has this
|
|
||||||
* value
|
|
||||||
*
|
|
||||||
* @param primaryReleaseYear
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover primaryReleaseYear(int primaryReleaseYear) {
|
|
||||||
if (checkYear(primaryReleaseYear)) {
|
|
||||||
params.add(Param.PRIMARY_RELEASE_YEAR, primaryReleaseYear);
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Only include movies that are equal to, or have a vote count higher than
|
|
||||||
* this value
|
|
||||||
*
|
|
||||||
* @param voteCountGte
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover voteCountGte(int voteCountGte) {
|
|
||||||
params.add(Param.VOTE_COUNT_GTE, voteCountGte);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Only include movies that are equal to, or have a higher average rating
|
|
||||||
* than this value
|
|
||||||
*
|
|
||||||
* @param voteAverageGte
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover voteAverageGte(float voteAverageGte) {
|
|
||||||
params.add(Param.VOTE_AVERAGE_GTE, voteAverageGte);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Only include movies with the specified genres.
|
|
||||||
* <p/>
|
|
||||||
* Expected value is an integer (the id of a genre).
|
|
||||||
* <p/>
|
|
||||||
* Multiple values can be specified.
|
|
||||||
* <p/>
|
|
||||||
* Comma separated indicates an 'AND' query, while a pipe (|) separated
|
|
||||||
* value indicates an 'OR'
|
|
||||||
*
|
|
||||||
* @param withGenres
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover withGenres(String withGenres) {
|
|
||||||
params.add(Param.WITH_GENRES, withGenres);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The minimum release to include.
|
|
||||||
* <p/>
|
|
||||||
* Expected format is YYYY-MM-DD.
|
|
||||||
*
|
|
||||||
* @param releaseDateGte
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover releaseDateGte(String releaseDateGte) {
|
|
||||||
params.add(Param.RELEASE_DATE_GTE, releaseDateGte);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The maximum release to include.
|
|
||||||
* <p/>
|
|
||||||
* Expected format is YYYY-MM-DD.
|
|
||||||
*
|
|
||||||
* @param releaseDateLte
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover releaseDateLte(String releaseDateLte) {
|
|
||||||
params.add(Param.RELEASE_DATE_LTE, releaseDateLte);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Only include movies with certifications for a specific country.
|
|
||||||
* <p/>
|
|
||||||
* When this value is specified, 'certificationLte' is required.
|
|
||||||
* <p/>
|
|
||||||
* A ISO 3166-1 is expected
|
|
||||||
*
|
|
||||||
* @param certificationCountry
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover certificationCountry(String certificationCountry) {
|
|
||||||
params.add(Param.CERTIFICATION_COUNTRY, certificationCountry);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Only include movies with this certification and lower.
|
|
||||||
* <p/>
|
|
||||||
* Expected value is a valid certification for the specified
|
|
||||||
* 'certificationCountry'.
|
|
||||||
*
|
|
||||||
* @param certificationLte
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover certificationLte(String certificationLte) {
|
|
||||||
params.add(Param.CERTIFICATION_LTE, certificationLte);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Filter movies to include a specific company.
|
|
||||||
* <p/>
|
|
||||||
* Expected value is an integer (the id of a company).
|
|
||||||
* <p/>
|
|
||||||
* They can be comma separated to indicate an 'AND' query
|
|
||||||
*
|
|
||||||
* @param withCompanies
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Discover withCompanies(String withCompanies) {
|
|
||||||
params.add(Param.WITH_COMPANIES, withCompanies);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* check the year is between the min and max
|
|
||||||
*
|
|
||||||
* @param year
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
private boolean checkYear(int year) {
|
|
||||||
return year >= YEAR_MIN && year <= YEAR_MAX;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -0,0 +1,506 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2004-2015 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;private either version 3 of the License;private or
|
||||||
|
* any later version.
|
||||||
|
*
|
||||||
|
* TheMovieDB API is distributed in the hope that it will be useful;private
|
||||||
|
* 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;private see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package com.omertron.themoviedbapi.model2.discover;
|
||||||
|
|
||||||
|
import com.omertron.themoviedbapi.enumeration.SortBy;
|
||||||
|
import com.omertron.themoviedbapi.tools.Param;
|
||||||
|
import com.omertron.themoviedbapi.tools.TmdbParameters;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a discover object for use in the MovieDbApi
|
||||||
|
* <p/>
|
||||||
|
* This allows you to just add the search components you are concerned with
|
||||||
|
*
|
||||||
|
* @author stuart.boston
|
||||||
|
*/
|
||||||
|
public class Discover {
|
||||||
|
|
||||||
|
private final TmdbParameters params = new TmdbParameters();
|
||||||
|
|
||||||
|
private static final int YEAR_MIN = 1900;
|
||||||
|
private static final int YEAR_MAX = 2100;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the parameters
|
||||||
|
* <p/>
|
||||||
|
* This will be used to construct the URL in the API
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public TmdbParameters getParams() {
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Minimum value is 1 if included.
|
||||||
|
*
|
||||||
|
* @param page
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover page(int page) {
|
||||||
|
params.add(Param.PAGE, page);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ISO 639-1 code
|
||||||
|
*
|
||||||
|
* @param language
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover language(String language) {
|
||||||
|
params.add(Param.LANGUAGE, language);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Available options are <br>
|
||||||
|
* vote_average.desc<br>
|
||||||
|
* vote_average.asc<br>
|
||||||
|
* release_date.desc<br>
|
||||||
|
* release_date.asc<br>
|
||||||
|
* popularity.desc<br>
|
||||||
|
* popularity.asc
|
||||||
|
*
|
||||||
|
* @param sortBy
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover sortBy(SortBy sortBy) {
|
||||||
|
params.add(Param.SORT_BY, sortBy.getPropertyString());
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle the inclusion of adult titles
|
||||||
|
*
|
||||||
|
* @param includeAdult
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover includeAdult(boolean includeAdult) {
|
||||||
|
params.add(Param.ADULT, includeAdult);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle the inclusion of items marked as a video.
|
||||||
|
*
|
||||||
|
* Expected value is a boolean, true or false. Default is true.
|
||||||
|
*
|
||||||
|
* @param includeVideo
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover includeVideo(boolean includeVideo) {
|
||||||
|
params.add(Param.INCLUDE_VIDEO, includeVideo);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the results release dates to matches that include this value.
|
||||||
|
*
|
||||||
|
* @param year
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover year(int year) {
|
||||||
|
if (checkYear(year)) {
|
||||||
|
params.add(Param.YEAR, year);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the results so that only the primary release date year has this value
|
||||||
|
*
|
||||||
|
* @param primaryReleaseYear
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover primaryReleaseYear(int primaryReleaseYear) {
|
||||||
|
if (checkYear(primaryReleaseYear)) {
|
||||||
|
params.add(Param.PRIMARY_RELEASE_YEAR, primaryReleaseYear);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that are equal to, or have a vote count higher than this value
|
||||||
|
*
|
||||||
|
* @param voteCountGte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover voteCountGte(int voteCountGte) {
|
||||||
|
params.add(Param.VOTE_COUNT_GTE, voteCountGte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that are equal to, or have a vote count higher than this value
|
||||||
|
*
|
||||||
|
* @param voteCountLte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover voteCountLte(int voteCountLte) {
|
||||||
|
params.add(Param.VOTE_COUNT_LTE, voteCountLte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that are equal to, or have a higher average rating than this value
|
||||||
|
*
|
||||||
|
* @param voteAverageGte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover voteAverageGte(float voteAverageGte) {
|
||||||
|
params.add(Param.VOTE_AVERAGE_GTE, voteAverageGte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that are less than or equal to this value
|
||||||
|
*
|
||||||
|
* @param voteAverageLte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover voteAverageLte(float voteAverageLte) {
|
||||||
|
params.add(Param.VOTE_AVERAGE_LTE, voteAverageLte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The minimum release to include.
|
||||||
|
* <p/>
|
||||||
|
* Expected format is YYYY-MM-DD.
|
||||||
|
*
|
||||||
|
* @param releaseDateGte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover releaseDateGte(String releaseDateGte) {
|
||||||
|
params.add(Param.RELEASE_DATE_GTE, releaseDateGte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The maximum release to include.
|
||||||
|
* <p/>
|
||||||
|
* Expected format is YYYY-MM-DD.
|
||||||
|
*
|
||||||
|
* @param releaseDateLte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover releaseDateLte(String releaseDateLte) {
|
||||||
|
params.add(Param.RELEASE_DATE_LTE, releaseDateLte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with certifications for a specific country.
|
||||||
|
* <p/>
|
||||||
|
* When this value is specified, 'certificationLte' is required.
|
||||||
|
* <p/>
|
||||||
|
* A ISO 3166-1 is expected
|
||||||
|
*
|
||||||
|
* @param certificationCountry
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover certificationCountry(String certificationCountry) {
|
||||||
|
params.add(Param.CERTIFICATION_COUNTRY, certificationCountry);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with this certification and lower.
|
||||||
|
* <p/>
|
||||||
|
* Expected value is a valid certification for the specified 'certificationCountry'.
|
||||||
|
*
|
||||||
|
* @param certificationLte
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover certificationLte(String certificationLte) {
|
||||||
|
params.add(Param.CERTIFICATION_LTE, certificationLte);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with this certification.
|
||||||
|
*
|
||||||
|
* Expected value is a valid certification for the specified 'certificationCountry'.
|
||||||
|
*
|
||||||
|
* @param certification
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover certification(String certification) {
|
||||||
|
params.add(Param.CERTIFICATION, certification);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that have this person id added as a cast member.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id of a person).
|
||||||
|
*
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'
|
||||||
|
*
|
||||||
|
* @param withCast
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCast(String withCast) {
|
||||||
|
params.add(Param.WITH_CAST, withCast);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include media that have these person IDs added as cast members.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withCast
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCast(WithBuilder withCast) {
|
||||||
|
return withCast(withCast.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that have this person id added as a crew member.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id of a person).
|
||||||
|
*
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'.
|
||||||
|
*
|
||||||
|
* @param withCrew
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCrew(String withCrew) {
|
||||||
|
params.add(Param.WITH_CREW, withCrew);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include media that have these person IDs added as crew members.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withCrew
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCrew(WithBuilder withCrew) {
|
||||||
|
return withCrew(withCrew.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter movies to include a specific company.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id of a company).
|
||||||
|
*
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'
|
||||||
|
*
|
||||||
|
* @param withCompanies
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCompanies(String withCompanies) {
|
||||||
|
params.add(Param.WITH_COMPANIES, withCompanies);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter movies to include a specific company.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withCompanies
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withCompanies(WithBuilder withCompanies) {
|
||||||
|
return withCompanies(withCompanies.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with the specified genres.
|
||||||
|
* <p/>
|
||||||
|
* Expected value is an integer (the id of a genre).
|
||||||
|
* <p/>
|
||||||
|
* Multiple values can be specified.
|
||||||
|
* <p/>
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'
|
||||||
|
*
|
||||||
|
* @param withGenres
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withGenres(String withGenres) {
|
||||||
|
params.add(Param.WITH_GENRES, withGenres);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with the specified genres.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withGenres
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withGenres(WithBuilder withGenres) {
|
||||||
|
return withGenres(withGenres.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with the specified genres.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id of a genre).
|
||||||
|
*
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'.
|
||||||
|
*
|
||||||
|
* @param withKeywords
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withKeywords(String withKeywords) {
|
||||||
|
params.add(Param.WITH_KEYWORDS, withKeywords);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies with the specified genres.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withKeywords
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withKeywords(WithBuilder withKeywords) {
|
||||||
|
return withKeywords(withKeywords.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that have these person id's added as a cast or crew member.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id or ids of a person).
|
||||||
|
*
|
||||||
|
* Comma separated indicates an 'AND' query, while a pipe (|) separated value indicates an 'OR'.
|
||||||
|
*
|
||||||
|
* @param withPeople
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withPeople(String withPeople) {
|
||||||
|
params.add(Param.WITH_PEOPLE, withPeople);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only include movies that have these person id's added as a cast or crew member.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withPeople
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withPeople(WithBuilder withPeople) {
|
||||||
|
return withPeople(withPeople.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the air dates that match this year
|
||||||
|
*
|
||||||
|
* Expected value is a year.
|
||||||
|
*
|
||||||
|
* @param year
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover firstAirDateYear(int year) {
|
||||||
|
if (checkYear(year)) {
|
||||||
|
params.add(Param.FIRST_AIR_DATE_YEAR, year);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the air dates to years that are greater than or equal to this year
|
||||||
|
*
|
||||||
|
* @param year
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover firstAirDateYearGte(int year) {
|
||||||
|
if (checkYear(year)) {
|
||||||
|
params.add(Param.FIRST_AIR_DATE_GTE, year);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the air dates to years that are less than or equal to this year
|
||||||
|
*
|
||||||
|
* @param year
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover firstAirDateYearLte(int year) {
|
||||||
|
if (checkYear(year)) {
|
||||||
|
params.add(Param.FIRST_AIR_DATE_LTE, year);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter TV shows to include a specific network.
|
||||||
|
*
|
||||||
|
* Expected value is an integer (the id of a network).
|
||||||
|
*
|
||||||
|
* They can be comma separated to indicate an 'AND' query.
|
||||||
|
*
|
||||||
|
* @param withNetworks
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withNetworks(String withNetworks) {
|
||||||
|
params.add(Param.WITH_NETWORKS, withNetworks);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter TV shows to include a specific network.
|
||||||
|
*
|
||||||
|
* Use the WithBuilder to generate the list,e.g.
|
||||||
|
*
|
||||||
|
* new WithBuilder(1).and(2).and(3)
|
||||||
|
*
|
||||||
|
* @param withNetworks
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Discover withNetworks(WithBuilder withNetworks) {
|
||||||
|
return withNetworks(withNetworks.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* check the year is between the min and max
|
||||||
|
*
|
||||||
|
* @param year
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private boolean checkYear(int year) {
|
||||||
|
return year >= YEAR_MIN && year <= YEAR_MAX;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,112 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2004-2015 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.model2.discover;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class to create a String for the "with???" parameters of the Discover method
|
||||||
|
*
|
||||||
|
* @author Stuart
|
||||||
|
*/
|
||||||
|
public class WithBuilder {
|
||||||
|
|
||||||
|
StringBuilder value = new StringBuilder();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create the first ID in the string
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
*/
|
||||||
|
public WithBuilder(int id) {
|
||||||
|
value.append(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create the first ID in the string
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
*/
|
||||||
|
public WithBuilder(String id) {
|
||||||
|
value.append(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate the string to pass to the method
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String build() {
|
||||||
|
return value.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate the string to pass to the method
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return build();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an "AND ID"
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WithBuilder and(int id) {
|
||||||
|
value.append(",").append(id);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an "AND ID"
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WithBuilder and(String id) {
|
||||||
|
value.append(",").append(id);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an "OR ID"
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WithBuilder or(int id) {
|
||||||
|
value.append("|").append(id);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an "OR ID"
|
||||||
|
*
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WithBuilder or(String id) {
|
||||||
|
value.append("|").append(id);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue