| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246 |
- <?php
- namespace Kryptonit3\CouchPotato;
- use GuzzleHttp\Client;
- use Kryptonit3\CouchPotato\Exceptions\InvalidException;
- class CouchPotato
- {
- protected $url;
- protected $apiKey;
- protected $httpAuthUsername;
- protected $httpAuthPassword;
- public $options;
- public function __construct($url, $apiKey, $httpAuthUsername = null, $httpAuthPassword = null, $options = [])
- {
- $this->url = rtrim($url, '/\\'); // Example: http://127.0.0.1:5050 (no trailing forward-backward slashes)
- $this->apiKey = $apiKey;
- $this->httpAuthUsername = $httpAuthUsername;
- $this->httpAuthPassword = $httpAuthPassword;
- $this->options = $options;
- }
- /**
- * Check if app available.
- *
- * @return string
- * @throws InvalidException
- */
- public function getAppAvailable()
- {
- $uri = 'app.available';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Restart the app.
- *
- * @return string
- * @throws InvalidException
- */
- public function getAppRestart()
- {
- $uri = 'app.restart';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Shutdown the app.
- *
- * @return string
- * @throws InvalidException
- */
- public function getAppShutdown()
- {
- $uri = 'app.shutdown';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get version.
- *
- * @return string
- * @throws InvalidException
- */
- public function getAppVersion()
- {
- $uri = 'app.version';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * List all available categories
- *
- * @return string
- * @throws InvalidException
- */
- public function getCategoryList()
- {
- $uri = 'category.list';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Return the directory list of a given directory
- *
- * @param null $path
- * @param bool|true $showHidden
- * @return string
- * @throws InvalidException
- */
- public function getDirectoryList($path = null, $showHidden = true)
- {
- $uri = 'directory.list';
- $uriData = [];
- if ($path) {
- $uriData['path'] = $path;
- }
- if ($showHidden) {
- $uriData['show_hidden'] = true;
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Remove all the log files
- *
- * @return string
- * @throws InvalidException
- */
- public function getLoggingClear()
- {
- $uri = 'logging.clear';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get the full log file by number
- *
- * @param int $nr Number of the log to get.
- * @return string
- * @throws InvalidException
- */
- public function getLoggingGet($nr = 0)
- {
- $uri = 'logging.get';
- $uriData = [
- 'nr' => $nr
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * @param string $type Type of logging, default "error" | info, debug
- * @param array $args All other params will be printed in the log string.
- * @return string
- * @throws InvalidException
- */
- public function getLoggingLog($type = 'error', array $args)
- {
- $uri = 'logging.log';
- $uriData = [
- 'type' => $type,
- 'args' => array_flatten($args)
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get a partial log
- *
- * @param int $lines Number of lines. Last to first. Default 30
- * @param string $type Type of log | all(default), error, info, debug
- * @return string
- * @throws InvalidException
- */
- public function getLoggingPartial($lines = 30, $type = 'all')
- {
- $uri = 'logging.partial';
- $uriData = [
- 'lines' => $lines,
- 'type' => $type
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get the progress of current manage update
- *
- * @return string
- * @throws InvalidException
- */
- public function getManageProgress()
- {
- $uri = 'manage.progress';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Update the library by scanning for new movies
- *
- * @param bool|false $full Do a full update or just recently changed/added movies.
- * @return string
- * @throws InvalidException
- */
- public function getManageUpdate($full = false)
- {
- $uri = 'manage.update';
- $uriData = [];
- if ($full) {
- $uriData['full'] = true;
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Delete a media from the wanted list
- *
- * @param int $id media ID(s) you want to delete. (comma separated)
- * @param string $deleteFrom all (default), wanted, manage
- * @return string
- * @throws InvalidException
- */
- public function getMediaDelete($id, $deleteFrom = 'all')
- {
- $uri = 'media.delete';
- $uriData = [
- 'id' => $id,
- 'delete_from' => $deleteFrom
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get media by id
- *
- * @param int $id The id of the media
- * @return string
- * @throws InvalidException
- */
- public function getMediaGet($id)
- {
- $uri = 'media.get';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * List media
- *
- * OPTIONAL PARAMETERS
- * status (array or csv) Filter media by status. Example:"active,done"
- * search (string) Search media title
- * release_status (array or csv) Filter media by status of its releases. Example:"snatched,available"
- * limit_offset (string) Limit and offset the media list. Examples: "50" or "50,30"
- * type (string) Media type to filter on.
- * starts_with (string) Starts with these characters. Example: "a" returns all media starting with the letter "a"
- *
- * @param array $params
- * @return string
- * @throws InvalidException
- */
- public function getMediaList(array $params = [])
- {
- $uri = 'media.list';
- $uriData = [];
- if (array_key_exists('status', $params)) {
- $uriData['status'] = $params['status'];
- }
- if (array_key_exists('search', $params)) {
- $uriData['search'] = $params['search'];
- }
- if (array_key_exists('release_status', $params)) {
- $uriData['release_status'] = $params['release_status'];
- }
- if (array_key_exists('limit_offset', $params)) {
- $uriData['limit_offset'] = $params['limit_offset'];
- }
- if (array_key_exists('type', $params)) {
- $uriData['type'] = $params['type'];
- }
- if (array_key_exists('starts_with', $params)) {
- $uriData['starts_with'] = $params['starts_with'];
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Refresh a any media type by ID
- *
- * @param int $id Movie, Show, Season or Episode ID(s) you want to refresh. (comma separated)
- * @return string
- * @throws InvalidException
- */
- public function getMediaRefresh($id)
- {
- $uri = 'media.refresh';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Add new movie to the wanted list
- *
- * PARAMETERS
- * profile_id (string) ID of quality profile you want the add the movie in. If empty will use the default profile.
- * title (string) Movie title to use for searches. Has to be one of the titles returned by movie.search.
- * identifier (string) IMDB id of the movie your want to add.
- * category_id (string) ID of category you want the add the movie in. If empty will use no category.
- * force_readd (string) Force re-add even if movie already in wanted or manage. Default: True
- *
- * @param array $params
- * @return string
- * @throws InvalidException
- */
- public function getMovieAdd(array $params)
- {
- $uri = 'movie.add';
- $uriData = [];
- if (array_key_exists('profile_id', $params)) {
- $uriData['profile_id'] = $params['profile_id'];
- }
- if (array_key_exists('title', $params)) {
- $uriData['title'] = $params['title'];
- }
- if (array_key_exists('identifier', $params)) {
- $uriData['identifier'] = $params['identifier'];
- }
- if (array_key_exists('category_id', $params)) {
- $uriData['category_id'] = $params['category_id'];
- }
- if (array_key_exists('force_readd', $params)) {
- $uriData['force_readd'] = $params['force_readd'];
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Delete a movie from the wanted list
- *
- * @param int $id Movie ID(s) you want to delete. (comma separated)
- * @param string $deleteFrom Delete movie from this page all (default), wanted, manage
- * @return string
- * @throws InvalidException
- */
- public function getMovieDelete($id, $deleteFrom = 'all')
- {
- $uri = 'movie.delete';
- $uriData = [
- 'id' => $id,
- 'delete_from' => $deleteFrom
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Edit Movies
- *
- * PARAMETERS
- * profile_id (string) ID of quality profile you want the edit the movie to.
- * default_title (string) Movie title to use for searches. Has to be one of the titles returned by movie.search.
- * id (string) Movie ID(s) you want to edit. (comma separated)
- * category_id (string) ID of category you want the add the movie in. If empty will use no category.
- *
- * @param array $params
- * @return string
- * @throws InvalidException
- */
- public function getMovieEdit(array $params)
- {
- $uri = 'movie.edit';
- $uriData = [];
- if (array_key_exists('profile_id', $params)) {
- $uriData['profile_id'] = $params['profile_id'];
- }
- if (array_key_exists('default_title', $params)) {
- $uriData['default_title'] = $params['default_title'];
- }
- if (array_key_exists('id', $params)) {
- $uriData['id'] = $params['id'];
- }
- if (array_key_exists('category_id', $params)) {
- $uriData['category_id'] = $params['category_id'];
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * List Movies
- *
- * OPTIONAL PARAMETERS
- * status (array or csv) Filter movie by status. Example:"active,done"
- * search (string) Search movie title
- * release_status (array or csv) Filter movie by status of its releases. Example:"snatched,available"
- * limit_offset (string) Limit and offset the movie list. Examples: "50" or "50,30"
- * starts_with (string) Starts with these characters. Example: "a" returns all movies starting with the letter "a"
- *
- * @param array $params
- * @return string
- * @throws InvalidException
- */
- public function getMovieList(array $params = [])
- {
- $uri = 'movie.list';
- $uriData = [];
- if (array_key_exists('status', $params)) {
- $uriData['status'] = $params['status'];
- }
- if (array_key_exists('search', $params)) {
- $uriData['search'] = $params['search'];
- }
- if (array_key_exists('release_status', $params)) {
- $uriData['release_status'] = $params['release_status'];
- }
- if (array_key_exists('limit_offset', $params)) {
- $uriData['limit_offset'] = $params['limit_offset'];
- }
- if (array_key_exists('starts_with', $params)) {
- $uriData['starts_with'] = $params['starts_with'];
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Starts a full search for all wanted movies
- *
- * @return string
- * @throws InvalidException
- */
- public function getMovieSearcherFull()
- {
- $uri = 'movie.searcher.full_search';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get the progress of current full search
- *
- * @return string
- * @throws InvalidException
- */
- public function getMovieSearcherProgress()
- {
- $uri = 'movie.searcher.progress';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Marks the snatched results as ignored and try the next best release
- *
- * @param int $id The id of the media
- * @return string
- * @throws InvalidException
- */
- public function getMovieSearcherTryNext($id)
- {
- $uri = 'movie.searcher.try_next';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get list of notifications
- *
- * @param string|null $limit Limit and offset the notification list. Examples: "50" or "50,30"
- * @return string
- * @throws InvalidException
- */
- public function getNotificationList($limit = null)
- {
- $uri = 'notification.list';
- $uriData = [];
- if ( $limit ) { $uriData['limit_offset'] = $limit; }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Mark notifications as read
- *
- * @param int $id Notification id you want to mark as read. All if ids is empty.
- * @return string
- * @throws InvalidException
- */
- public function getNotificationMarkRead($id = null)
- {
- $uri = 'notification.markread';
- $uriData = [];
- if ( $id ) { $uriData['id'] = $id; }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * List all available profiles
- *
- * @return string
- * @throws InvalidException
- */
- public function getProfileList()
- {
- $uri = 'profile.list';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * List all available qualities
- *
- * @return string
- * @throws InvalidException
- */
- public function getQualityList()
- {
- $uri = 'quality.list';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Delete releases
- *
- * @param int $id ID of the release object in release-table
- * @return string
- * @throws InvalidException
- */
- public function getReleaseDelete($id)
- {
- $uri = 'release.delete';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Toggle ignore, for bad or wrong releases
- *
- * @param int $id ID of the release object in release-table
- * @return string
- * @throws InvalidException
- */
- public function getReleaseIgnore($id)
- {
- $uri = 'release.ignore';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Send a release manually to the downloaders
- *
- * @param int $id ID of the release object in release-table
- * @return string
- * @throws InvalidException
- */
- public function getReleaseManualDownload($id)
- {
- $uri = 'release.manual_download';
- $uriData = [
- 'id' => $id
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get the progress of current renamer scan
- *
- * @return string
- * @throws InvalidException
- */
- public function getRenamerProgress()
- {
- $uri = 'renamer.progress';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * For the renamer to check for new files to rename in a folder
- *
- * OPTIONAL PARAMETERS
- * files (string) Provide the release files if more releases are in the same media_folder, delimited with a '|'. Note that no dedicated release folder is expected for releases with one file.
- * base_folder (string) The folder to find releases in. Leave empty for default folder.
- * download_id (string) The nzb/torrent ID of the release in media_folder. 'downloader' is required with this option.
- * status (string) The status of the release: 'completed' (default) or 'seeding'
- * to_folder (string) The folder to move releases to. Leave empty for default folder.
- * async (int) Set to 1 if you dont want to fire the renamer.scan asynchronous.
- * media_folder (string) The folder of the media to scan. Keep empty for default renamer folder.
- * downloader (string) The downloader the release has been downloaded with. 'download_id' is required with this option.
- *
- * @param array $params
- * @return string
- * @throws InvalidException
- */
- public function getRenamerScan(array $params = [])
- {
- $uri = 'renamer.scan';
- $uriData = [];
- if (array_key_exists('files', $params)) {
- $uriData['files'] = $params['files'];
- }
- if (array_key_exists('base_folder', $params)) {
- $uriData['base_folder'] = $params['base_folder'];
- }
- if (array_key_exists('download_id', $params)) {
- $uriData['download_id'] = $params['download_id'];
- }
- if (array_key_exists('status', $params)) {
- $uriData['status'] = $params['status'];
- }
- if (array_key_exists('to_folder', $params)) {
- $uriData['to_folder'] = $params['to_folder'];
- }
- if (array_key_exists('async', $params)) {
- $uriData['async'] = $params['async'];
- }
- if (array_key_exists('media_folder', $params)) {
- $uriData['media_folder'] = $params['media_folder'];
- }
- if (array_key_exists('downloader', $params)) {
- $uriData['downloader'] = $params['downloader'];
- }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Search the info in providers for a movie
- *
- * @param string $query The (partial) movie name you want to search for
- * @param string|null $type Search for a specific media type. Leave empty to search all.
- * @return string
- * @throws InvalidException
- */
- public function getSearch($query, $type = null)
- {
- $uri = 'search';
- $uriData = [
- 'q' => $query
- ];
- if ( $type ) { $uriData['type'] = $type; }
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Starts a full search for all media
- *
- * @return string
- * @throws InvalidException
- */
- public function getSearcherFull()
- {
- $uri = 'searcher.full_search';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get the progress of all media searches
- *
- * @return string
- * @throws InvalidException
- */
- public function getSearcherProgress()
- {
- $uri = 'searcher.progress';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Return the options and its values of settings.conf.
- * Including the default values and group ordering used on the settings page.
- *
- * @return string
- * @throws InvalidException
- */
- public function getSettings()
- {
- $uri = 'settings';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Save setting to config file (settings.conf)
- *
- * @param string $section The section name in settings.conf
- * @param string $name The option name
- * @param string $value The value you want to save
- * @return string
- * @throws InvalidException
- */
- public function getSettingsSave($section, $name, $value)
- {
- $uri = 'settings.save';
- $uriData = [
- 'section' => $section,
- 'name' => $name,
- 'value' => $value
- ];
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => $uriData
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Check for available update
- *
- * @return string
- * @throws InvalidException
- */
- public function getUpdaterCheck()
- {
- $uri = 'updater.check';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Get updater information
- *
- * @return string
- * @throws InvalidException
- */
- public function getUpdaterInfo()
- {
- $uri = 'updater.info';
- try {
- $response = $this->_request(
- [
- 'uri' => $uri,
- 'type' => 'get',
- 'data' => []
- ]
- );
- } catch (\Exception $e) {
- throw new InvalidException($e->getMessage());
- }
- return $response->getBody()->getContents();
- }
- /**
- * Process requests with Guzzle
- *
- * @param array $params
- * @return \Psr\Http\Message\ResponseInterface
- */
- protected function _request(array $params)
- {
- $client = new Client($this->options);
- if ( $params['type'] == 'get' ) {
- $url = $this->url . '/api/' . $this->apiKey . '/' . $params['uri'] . '?' . http_build_query($params['data']);
- $options = [];
- if ( $this->httpAuthUsername && $this->httpAuthPassword ) {
- $options['auth'] = [
- $this->httpAuthUsername,
- $this->httpAuthPassword
- ];
- }
- return $client->get($url, $options);
- }
- }
- }
|