jackett.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <?php
  2. trait JackettHomepageItem
  3. {
  4. public function jackettSettingsArray($infoOnly = false)
  5. {
  6. $homepageInformation = [
  7. 'name' => 'Jackett',
  8. 'enabled' => true,
  9. 'image' => 'plugins/images/tabs/jackett.png',
  10. 'category' => 'Utility',
  11. 'settingsArray' => __FUNCTION__
  12. ];
  13. if ($infoOnly) {
  14. return $homepageInformation;
  15. }
  16. $homepageSettings = [
  17. 'debug' => true,
  18. 'settings' => [
  19. 'Enable' => [
  20. $this->settingsOption('enable', 'homepageJackettEnabled'),
  21. $this->settingsOption('auth', 'homepageJackettAuth'),
  22. ],
  23. 'Connection' => [
  24. $this->settingsOption('url', 'jackettURL'),
  25. $this->settingsOption('token', 'jackettToken'),
  26. $this->settingsOption('disable-cert-check', 'jackettDisableCertCheck'),
  27. $this->settingsOption('use-custom-certificate', 'jackettUseCustomCertificate'),
  28. ],
  29. 'Options' => [
  30. $this->settingsOption('switch', 'homepageJackettBackholeDownload', ['label' => 'Prefer black hole download', 'help' => 'Prefer black hole download link instead of direct/magnet download']),
  31. ],
  32. 'Test Connection' => [
  33. $this->settingsOption('blank', null, ['label' => 'Please Save before Testing']),
  34. $this->settingsOption('test', 'jackett'),
  35. ]
  36. ]
  37. ];
  38. return array_merge($homepageInformation, $homepageSettings);
  39. }
  40. public function jackettHomepagePermissions($key = null)
  41. {
  42. $permissions = [
  43. 'main' => [
  44. 'enabled' => [
  45. 'homepageJackettEnabled'
  46. ],
  47. 'auth' => [
  48. 'homepageJackettAuth'
  49. ],
  50. 'not_empty' => [
  51. 'jackettURL',
  52. 'jackettToken'
  53. ]
  54. ],
  55. 'test' => [
  56. 'auth' => [
  57. 'homepageJackettAuth'
  58. ],
  59. 'not_empty' => [
  60. 'jackettURL',
  61. 'jackettToken'
  62. ]
  63. ]
  64. ];
  65. return $this->homepageCheckKeyPermissions($key, $permissions);
  66. }
  67. public function homepageOrderJackett()
  68. {
  69. if ($this->homepageItemPermissions($this->jackettHomepagePermissions('main'))) {
  70. return '
  71. <div id="' . __FUNCTION__ . '">
  72. <div class="white-box homepage-loading-box"><h2 class="text-center" lang="en">Loading Jackett...</h2></div>
  73. <script>
  74. // Jackett
  75. homepageJackett();
  76. // End Jackett
  77. </script>
  78. </div>
  79. ';
  80. }
  81. }
  82. public function testConnectionJackett()
  83. {
  84. if (!$this->homepageItemPermissions($this->jackettHomepagePermissions('test'), true)) {
  85. return false;
  86. }
  87. $apiURL = $this->qualifyURL($this->config['jackettURL']);
  88. $endpoint = $apiURL . '/api/v2.0/indexers/all/results?apikey=' . $this->config['jackettToken'] . '&Query=this-is-just-a-test-for-organizr';
  89. try {
  90. $headers = [];
  91. $options = $this->requestOptions($apiURL, 120, $this->config['jackettDisableCertCheck'], $this->config['jackettUseCustomCertificate']);
  92. $response = Requests::get($endpoint, $headers, $options);
  93. if ($response->success) {
  94. $apiData = json_decode($response->body, true);
  95. $api['content'] = $apiData;
  96. unset($apiData);
  97. } else {
  98. $this->setResponse(403, 'Error connecting to Jackett');
  99. return false;
  100. }
  101. } catch (Requests_Exception $e) {
  102. $this->setResponse(500, $e->getMessage());
  103. return false;
  104. };
  105. $api['content'] = $api['content'] ?? false;
  106. $this->setResponse(200, null, $api);
  107. return $api;
  108. }
  109. public function searchJackettIndexers($query = null)
  110. {
  111. if (!$this->homepageItemPermissions($this->jackettHomepagePermissions('main'), true)) {
  112. return false;
  113. }
  114. if (!$query) {
  115. $this->setAPIResponse('error', 'Query was not supplied', 422);
  116. return false;
  117. }
  118. $apiURL = $this->qualifyURL($this->config['jackettURL']);
  119. $endpoint = $apiURL . '/api/v2.0/indexers/all/results?apikey=' . $this->config['jackettToken'] . '&Query=' . urlencode($query);
  120. try {
  121. $headers = [];
  122. $options = $this->requestOptions($apiURL, 120, $this->config['jackettDisableCertCheck'], $this->config['jackettUseCustomCertificate']);
  123. $response = Requests::get($endpoint, $headers, $options);
  124. if ($response->success) {
  125. $apiData = json_decode($response->body, true);
  126. $api['content'] = $apiData;
  127. unset($apiData);
  128. }
  129. } catch (Requests_Exception $e) {
  130. $this->setResponse(500, $e->getMessage());
  131. return false;
  132. };
  133. $api['content'] = isset($api['content']) ? $api['content'] : false;
  134. $this->setAPIResponse('success', null, 200, $api);
  135. return $api;
  136. }
  137. public function performJackettBackHoleDownload($url = null)
  138. {
  139. if (!$this->homepageItemPermissions($this->jackettHomepagePermissions('main'), true)) {
  140. return false;
  141. }
  142. if (!$url) {
  143. $this->setAPIResponse('error', 'URL was not supplied', 422);
  144. return false;
  145. }
  146. $apiURL = $this->qualifyURL($this->config['jackettURL']);
  147. $endpoint = $apiURL . $url;
  148. error_log($endpoint);
  149. try {
  150. $headers = [];
  151. $options = $this->requestOptions($apiURL, 120, $this->config['jackettDisableCertCheck'], $this->config['jackettUseCustomCertificate']);
  152. $response = Requests::get($endpoint, $headers, $options);
  153. if ($response->success) {
  154. $apiData = json_decode($response->body, true);
  155. $api['content'] = $apiData;
  156. unset($apiData);
  157. }
  158. } catch (Requests_Exception $e) {
  159. $this->setLoggerChannel('Jackett')->error($e);
  160. $this->setResponse(500, $e->getMessage());
  161. return false;
  162. };
  163. $api['content'] = isset($api['content']) ? $api['content'] : false;
  164. if ($api['content'] && $api['content']['result'] == 'success') {
  165. $this->setAPIResponse('success', null, 200, $api);
  166. } else if ($api['content']) {
  167. $this->setAPIResponse('error', $api['content']['error'], 400, $api);
  168. } else {
  169. $this->setAPIResponse('error', 'Unknown error', 400, $api);
  170. }
  171. return $api;
  172. }
  173. }