You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
235 lines
5.8 KiB
235 lines
5.8 KiB
<?php
|
|
namespace nzedb;
|
|
|
|
use nzedb\utility\Misc;
|
|
|
|
/**
|
|
* Fetches and returns JSON documents from the Rotten Tomato API using a supplied API key.
|
|
*
|
|
* Class RottenTomato
|
|
*/
|
|
class RottenTomato
|
|
{
|
|
/**
|
|
* Main link for all the methods.
|
|
*/
|
|
const API_URL = 'http://api.rottentomatoes.com/api/public/v1.0/';
|
|
|
|
/**
|
|
* RT Api key.
|
|
* @var string
|
|
*/
|
|
private $_apikey;
|
|
|
|
/**
|
|
* @param string $apiKey RT Api Key.
|
|
*/
|
|
public function __construct($apiKey)
|
|
{
|
|
$this->_apikey = $apiKey;
|
|
}
|
|
|
|
/**
|
|
* Displays Top Box Office Earning Movies, Sorted by Most Recent Weekend Gross Ticket Sales.
|
|
*
|
|
* @param int $limit Limits the number of box office movies returned.
|
|
* @param string $country Provides localized data for the selected country (ISO 3166-1 alpha-2) if available.
|
|
* Otherwise, returns US data.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getBoxOffice($limit = 10, $country = 'us')
|
|
{
|
|
return $this->_makeCall(
|
|
'lists/movies/box_office.json',
|
|
[
|
|
'limit' => $limit,
|
|
'country' => $country
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Retrieves movies currently in theaters.
|
|
*
|
|
* @param int $limit The amount of movies in theaters to show per page.
|
|
* @param int $page The selected page of in theaters movies.
|
|
* @param string $country Provides localized data for the selected country (ISO 3166-1 alpha-2) if available.
|
|
* Otherwise, returns US data.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getInTheaters($limit = 16, $page = 1, $country = 'us')
|
|
{
|
|
return $this->_makeCall(
|
|
'lists/movies/in_theaters.json',
|
|
[
|
|
'page_limit' => $limit,
|
|
'page' => $page,
|
|
'country' => $country
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Retrieves current opening movies.
|
|
*
|
|
* @param int $limit Limits the number of opening movies returned.
|
|
* @param string $country Provides localized data for the selected country (ISO 3166-1 alpha-2) if available.
|
|
* Otherwise, returns US data.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getOpening($limit = 16, $country = 'us')
|
|
{
|
|
return $this->_makeCall(
|
|
'lists/movies/opening.json',
|
|
[
|
|
'limit' => $limit,
|
|
'country' => $country
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Retrieves upcoming movies. Results are paginated if they go past the specified page limit.
|
|
*
|
|
* @param int $limit The amount of upcoming movies to show per page.
|
|
* @param int $page The selected page of upcoming movies.
|
|
* @param string $country Provides localized data for the selected country (ISO 3166-1 alpha-2) if available.
|
|
* Otherwise, returns US data.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getUpcoming($limit = 16, $page = 1, $country = 'us')
|
|
{
|
|
return $this->_makeCall(
|
|
'lists/movies/upcoming.json',
|
|
[
|
|
'page_limit' => $limit,
|
|
'page' => $page,
|
|
'country' => $country
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Shows the DVD lists RT has available.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getDVDReleases()
|
|
{
|
|
return $this->_makeCall('lists/dvds/new_releases.json');
|
|
}
|
|
|
|
/**
|
|
* The movies search endpoint for plain text queries. Allows you to search for movies!
|
|
*
|
|
* @param string $title The plain text search query to search for a movie. Remember to URI encode this!
|
|
* @param int $limit The amount of movie search results to show per page.
|
|
* @param int $page The selected page of movie search results.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function searchMovie($title, $limit = 50, $page = 1)
|
|
{
|
|
return $this->_makeCall(
|
|
'movies.json',
|
|
[
|
|
'q' => $title,
|
|
'page_limit' => $limit,
|
|
'page' => $page
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Detailed information on a specific movie specified by Id.
|
|
* You can use the movies search endpoint or peruse the lists of movies/dvds to get the urls to movies.
|
|
*
|
|
* @param int $ID The RT ID.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getMovie($ID)
|
|
{
|
|
return $this->_makeCall('movies/' . $ID . '.json');
|
|
}
|
|
|
|
/**
|
|
* Retrieves the reviews for a movie.
|
|
* Results are paginated if they go past the specified page limit.
|
|
*
|
|
* @param int $ID The RT ID.
|
|
* @param string $type Three different review types are possible:
|
|
* "all", "top_critic" and "dvd".
|
|
* "top_critic" shows all the Rotten Tomatoes designated top critics.
|
|
* "dvd" pulls the reviews given on the DVD of the movie.
|
|
* "all" as the name implies retrieves all reviews.
|
|
* @param int $limit The number of reviews to show per page.
|
|
* @param int $page The selected page of reviews.
|
|
* @param string $country Provides localized data for the selected country (ISO 3166-1 alpha-2) if available.
|
|
* Otherwise, returns US data.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getReviews($ID, $type = 'top_critic', $limit = 20, $page = 1, $country = 'us')
|
|
{
|
|
return $this->_makeCall(
|
|
'movies/' . $ID . '/reviews.json',
|
|
[
|
|
'review_type' => $type,
|
|
'page_limit' => $limit,
|
|
'page' => $page,
|
|
'country' => $country
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Pulls the complete movie cast for a movie.
|
|
*
|
|
* @param int $ID The RT ID.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getCast($ID)
|
|
{
|
|
return $this->_makeCall('movies/' . $ID . '/cast.json');
|
|
}
|
|
|
|
/**
|
|
* Make a request to RT.
|
|
*
|
|
* @param string $function The type of request.
|
|
* @param array $params Extra HTTP parameters.
|
|
*
|
|
* @return string JSON data from RT.
|
|
*/
|
|
private function _makeCall($function, $params = [])
|
|
{
|
|
return trim(
|
|
Misc::getUrl([
|
|
'url' => RottenTomato::API_URL .
|
|
$function .
|
|
'?limit=' .
|
|
mt_rand(15, 20) .
|
|
'&apikey=' .
|
|
$this->_apikey .
|
|
(!empty($params) ? ('&' . http_build_query($params)) : '')
|
|
]
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get the RT api key.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getApiKey()
|
|
{
|
|
return $this->_apikey;
|
|
}
|
|
}
|
|
|