StreamingCommunity 2.5.2__py3-none-any.whl → 2.5.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of StreamingCommunity might be problematic. Click here for more details.

Files changed (268) hide show
  1. StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +143 -143
  2. StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +136 -136
  3. StreamingCommunity/Api/Player/ddl.py +89 -89
  4. StreamingCommunity/Api/Player/maxstream.py +151 -151
  5. StreamingCommunity/Api/Player/supervideo.py +193 -193
  6. StreamingCommunity/Api/Player/vixcloud.py +272 -272
  7. StreamingCommunity/Api/Site/1337xx/__init__.py +51 -50
  8. StreamingCommunity/Api/Site/1337xx/costant.py +14 -14
  9. StreamingCommunity/Api/Site/1337xx/site.py +87 -89
  10. StreamingCommunity/Api/Site/1337xx/title.py +63 -64
  11. StreamingCommunity/Api/Site/altadefinizionegratis/__init__.py +74 -50
  12. StreamingCommunity/Api/Site/altadefinizionegratis/costant.py +21 -19
  13. StreamingCommunity/Api/Site/altadefinizionegratis/film.py +81 -72
  14. StreamingCommunity/Api/Site/altadefinizionegratis/site.py +116 -94
  15. StreamingCommunity/Api/Site/animeunity/__init__.py +75 -50
  16. StreamingCommunity/Api/Site/animeunity/costant.py +21 -19
  17. StreamingCommunity/Api/Site/animeunity/film_serie.py +171 -134
  18. StreamingCommunity/Api/Site/animeunity/site.py +191 -174
  19. StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +97 -97
  20. StreamingCommunity/Api/Site/cb01new/__init__.py +51 -51
  21. StreamingCommunity/Api/Site/cb01new/costant.py +19 -19
  22. StreamingCommunity/Api/Site/cb01new/film.py +61 -71
  23. StreamingCommunity/Api/Site/cb01new/site.py +82 -82
  24. StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +55 -55
  25. StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +20 -20
  26. StreamingCommunity/Api/Site/ddlstreamitaly/series.py +149 -145
  27. StreamingCommunity/Api/Site/ddlstreamitaly/site.py +98 -98
  28. StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +84 -84
  29. StreamingCommunity/Api/Site/guardaserie/__init__.py +50 -50
  30. StreamingCommunity/Api/Site/guardaserie/costant.py +19 -19
  31. StreamingCommunity/Api/Site/guardaserie/series.py +199 -198
  32. StreamingCommunity/Api/Site/guardaserie/site.py +89 -89
  33. StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +110 -110
  34. StreamingCommunity/Api/Site/ilcorsaronero/__init__.py +51 -51
  35. StreamingCommunity/Api/Site/ilcorsaronero/costant.py +18 -18
  36. StreamingCommunity/Api/Site/ilcorsaronero/site.py +71 -71
  37. StreamingCommunity/Api/Site/ilcorsaronero/title.py +44 -44
  38. StreamingCommunity/Api/Site/ilcorsaronero/util/ilCorsarScraper.py +149 -149
  39. StreamingCommunity/Api/Site/mostraguarda/__init__.py +48 -48
  40. StreamingCommunity/Api/Site/mostraguarda/costant.py +18 -18
  41. StreamingCommunity/Api/Site/mostraguarda/film.py +90 -101
  42. StreamingCommunity/Api/Site/streamingcommunity/__init__.py +79 -55
  43. StreamingCommunity/Api/Site/streamingcommunity/costant.py +21 -19
  44. StreamingCommunity/Api/Site/streamingcommunity/film.py +86 -75
  45. StreamingCommunity/Api/Site/streamingcommunity/series.py +259 -207
  46. StreamingCommunity/Api/Site/streamingcommunity/site.py +156 -142
  47. StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +124 -124
  48. StreamingCommunity/Api/Template/Class/SearchType.py +101 -101
  49. StreamingCommunity/Api/Template/Util/__init__.py +4 -4
  50. StreamingCommunity/Api/Template/Util/get_domain.py +201 -201
  51. StreamingCommunity/Api/Template/Util/manage_ep.py +178 -178
  52. StreamingCommunity/Api/Template/Util/recall_search.py +37 -37
  53. StreamingCommunity/Api/Template/__init__.py +2 -2
  54. StreamingCommunity/Api/Template/site.py +87 -87
  55. StreamingCommunity/Lib/Downloader/HLS/downloader.py +529 -1008
  56. StreamingCommunity/Lib/Downloader/HLS/proxyes.py +110 -110
  57. StreamingCommunity/Lib/Downloader/HLS/segments.py +446 -573
  58. StreamingCommunity/Lib/Downloader/MP4/downloader.py +181 -155
  59. StreamingCommunity/Lib/Downloader/TOR/downloader.py +297 -295
  60. StreamingCommunity/Lib/Downloader/__init__.py +4 -4
  61. StreamingCommunity/Lib/FFmpeg/__init__.py +4 -4
  62. StreamingCommunity/Lib/FFmpeg/capture.py +170 -170
  63. StreamingCommunity/Lib/FFmpeg/command.py +264 -296
  64. StreamingCommunity/Lib/FFmpeg/util.py +248 -248
  65. StreamingCommunity/Lib/M3U8/__init__.py +5 -5
  66. StreamingCommunity/Lib/M3U8/decryptor.py +164 -164
  67. StreamingCommunity/Lib/M3U8/estimator.py +146 -228
  68. StreamingCommunity/Lib/M3U8/parser.py +666 -666
  69. StreamingCommunity/Lib/M3U8/url_fixer.py +57 -57
  70. StreamingCommunity/Lib/TMBD/__init__.py +1 -1
  71. StreamingCommunity/Lib/TMBD/obj_tmbd.py +39 -39
  72. StreamingCommunity/Lib/TMBD/tmdb.py +345 -345
  73. StreamingCommunity/TelegramHelp/__init__.py +0 -0
  74. StreamingCommunity/TelegramHelp/request_manager.py +82 -0
  75. StreamingCommunity/TelegramHelp/session.py +56 -0
  76. StreamingCommunity/TelegramHelp/telegram_bot.py +561 -0
  77. StreamingCommunity/Upload/update.py +75 -67
  78. StreamingCommunity/Upload/version.py +5 -5
  79. StreamingCommunity/Util/_jsonConfig.py +227 -228
  80. StreamingCommunity/Util/call_stack.py +42 -42
  81. StreamingCommunity/Util/color.py +20 -20
  82. StreamingCommunity/Util/console.py +12 -12
  83. StreamingCommunity/Util/ffmpeg_installer.py +342 -370
  84. StreamingCommunity/Util/headers.py +159 -159
  85. StreamingCommunity/Util/logger.py +61 -61
  86. StreamingCommunity/Util/message.py +36 -64
  87. StreamingCommunity/Util/os.py +500 -507
  88. StreamingCommunity/Util/table.py +271 -228
  89. StreamingCommunity/run.py +352 -245
  90. {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.5.dist-info}/LICENSE +674 -674
  91. {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.5.dist-info}/METADATA +601 -543
  92. StreamingCommunity-2.5.5.dist-info/RECORD +96 -0
  93. {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.5.dist-info}/entry_points.txt +0 -1
  94. StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/js_parser.cpython-313.pyc +0 -0
  95. StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/js_parser.cpython-39.pyc +0 -0
  96. StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/util.cpython-313.pyc +0 -0
  97. StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/util.cpython-39.pyc +0 -0
  98. StreamingCommunity/Api/Player/__pycache__/ddl.cpython-313.pyc +0 -0
  99. StreamingCommunity/Api/Player/__pycache__/ddl.cpython-39.pyc +0 -0
  100. StreamingCommunity/Api/Player/__pycache__/maxstream.cpython-313.pyc +0 -0
  101. StreamingCommunity/Api/Player/__pycache__/maxstream.cpython-39.pyc +0 -0
  102. StreamingCommunity/Api/Player/__pycache__/supervideo.cpython-313.pyc +0 -0
  103. StreamingCommunity/Api/Player/__pycache__/supervideo.cpython-39.pyc +0 -0
  104. StreamingCommunity/Api/Player/__pycache__/vixcloud.cpython-313.pyc +0 -0
  105. StreamingCommunity/Api/Player/__pycache__/vixcloud.cpython-39.pyc +0 -0
  106. StreamingCommunity/Api/Site/1337xx/__pycache__/__init__.cpython-313.pyc +0 -0
  107. StreamingCommunity/Api/Site/1337xx/__pycache__/__init__.cpython-39.pyc +0 -0
  108. StreamingCommunity/Api/Site/1337xx/__pycache__/costant.cpython-313.pyc +0 -0
  109. StreamingCommunity/Api/Site/1337xx/__pycache__/costant.cpython-39.pyc +0 -0
  110. StreamingCommunity/Api/Site/1337xx/__pycache__/site.cpython-313.pyc +0 -0
  111. StreamingCommunity/Api/Site/1337xx/__pycache__/site.cpython-39.pyc +0 -0
  112. StreamingCommunity/Api/Site/1337xx/__pycache__/title.cpython-313.pyc +0 -0
  113. StreamingCommunity/Api/Site/1337xx/__pycache__/title.cpython-39.pyc +0 -0
  114. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/__init__.cpython-313.pyc +0 -0
  115. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/__init__.cpython-39.pyc +0 -0
  116. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/costant.cpython-313.pyc +0 -0
  117. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/costant.cpython-39.pyc +0 -0
  118. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/film.cpython-313.pyc +0 -0
  119. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/film.cpython-39.pyc +0 -0
  120. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/site.cpython-313.pyc +0 -0
  121. StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/site.cpython-39.pyc +0 -0
  122. StreamingCommunity/Api/Site/animeunity/__pycache__/__init__.cpython-313.pyc +0 -0
  123. StreamingCommunity/Api/Site/animeunity/__pycache__/__init__.cpython-39.pyc +0 -0
  124. StreamingCommunity/Api/Site/animeunity/__pycache__/costant.cpython-313.pyc +0 -0
  125. StreamingCommunity/Api/Site/animeunity/__pycache__/costant.cpython-39.pyc +0 -0
  126. StreamingCommunity/Api/Site/animeunity/__pycache__/film_serie.cpython-313.pyc +0 -0
  127. StreamingCommunity/Api/Site/animeunity/__pycache__/film_serie.cpython-39.pyc +0 -0
  128. StreamingCommunity/Api/Site/animeunity/__pycache__/site.cpython-313.pyc +0 -0
  129. StreamingCommunity/Api/Site/animeunity/__pycache__/site.cpython-39.pyc +0 -0
  130. StreamingCommunity/Api/Site/animeunity/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
  131. StreamingCommunity/Api/Site/animeunity/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
  132. StreamingCommunity/Api/Site/cb01new/__pycache__/__init__.cpython-313.pyc +0 -0
  133. StreamingCommunity/Api/Site/cb01new/__pycache__/__init__.cpython-39.pyc +0 -0
  134. StreamingCommunity/Api/Site/cb01new/__pycache__/costant.cpython-313.pyc +0 -0
  135. StreamingCommunity/Api/Site/cb01new/__pycache__/costant.cpython-39.pyc +0 -0
  136. StreamingCommunity/Api/Site/cb01new/__pycache__/film.cpython-313.pyc +0 -0
  137. StreamingCommunity/Api/Site/cb01new/__pycache__/film.cpython-39.pyc +0 -0
  138. StreamingCommunity/Api/Site/cb01new/__pycache__/site.cpython-313.pyc +0 -0
  139. StreamingCommunity/Api/Site/cb01new/__pycache__/site.cpython-39.pyc +0 -0
  140. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/__init__.cpython-313.pyc +0 -0
  141. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/__init__.cpython-39.pyc +0 -0
  142. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/costant.cpython-313.pyc +0 -0
  143. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/costant.cpython-39.pyc +0 -0
  144. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/series.cpython-313.pyc +0 -0
  145. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/series.cpython-39.pyc +0 -0
  146. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/site.cpython-313.pyc +0 -0
  147. StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/site.cpython-39.pyc +0 -0
  148. StreamingCommunity/Api/Site/ddlstreamitaly/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
  149. StreamingCommunity/Api/Site/ddlstreamitaly/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
  150. StreamingCommunity/Api/Site/guardaserie/__pycache__/__init__.cpython-313.pyc +0 -0
  151. StreamingCommunity/Api/Site/guardaserie/__pycache__/__init__.cpython-39.pyc +0 -0
  152. StreamingCommunity/Api/Site/guardaserie/__pycache__/costant.cpython-313.pyc +0 -0
  153. StreamingCommunity/Api/Site/guardaserie/__pycache__/costant.cpython-39.pyc +0 -0
  154. StreamingCommunity/Api/Site/guardaserie/__pycache__/series.cpython-313.pyc +0 -0
  155. StreamingCommunity/Api/Site/guardaserie/__pycache__/series.cpython-39.pyc +0 -0
  156. StreamingCommunity/Api/Site/guardaserie/__pycache__/site.cpython-313.pyc +0 -0
  157. StreamingCommunity/Api/Site/guardaserie/__pycache__/site.cpython-39.pyc +0 -0
  158. StreamingCommunity/Api/Site/guardaserie/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
  159. StreamingCommunity/Api/Site/guardaserie/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
  160. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/__init__.cpython-313.pyc +0 -0
  161. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/__init__.cpython-39.pyc +0 -0
  162. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/costant.cpython-313.pyc +0 -0
  163. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/costant.cpython-39.pyc +0 -0
  164. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/site.cpython-313.pyc +0 -0
  165. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/site.cpython-39.pyc +0 -0
  166. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/title.cpython-313.pyc +0 -0
  167. StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/title.cpython-39.pyc +0 -0
  168. StreamingCommunity/Api/Site/ilcorsaronero/util/__pycache__/ilCorsarScraper.cpython-313.pyc +0 -0
  169. StreamingCommunity/Api/Site/ilcorsaronero/util/__pycache__/ilCorsarScraper.cpython-39.pyc +0 -0
  170. StreamingCommunity/Api/Site/mostraguarda/__pycache__/__init__.cpython-313.pyc +0 -0
  171. StreamingCommunity/Api/Site/mostraguarda/__pycache__/__init__.cpython-39.pyc +0 -0
  172. StreamingCommunity/Api/Site/mostraguarda/__pycache__/costant.cpython-313.pyc +0 -0
  173. StreamingCommunity/Api/Site/mostraguarda/__pycache__/costant.cpython-39.pyc +0 -0
  174. StreamingCommunity/Api/Site/mostraguarda/__pycache__/film.cpython-313.pyc +0 -0
  175. StreamingCommunity/Api/Site/mostraguarda/__pycache__/film.cpython-39.pyc +0 -0
  176. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/__init__.cpython-313.pyc +0 -0
  177. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/__init__.cpython-39.pyc +0 -0
  178. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/costant.cpython-313.pyc +0 -0
  179. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/costant.cpython-39.pyc +0 -0
  180. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/film.cpython-313.pyc +0 -0
  181. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/film.cpython-39.pyc +0 -0
  182. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/series.cpython-313.pyc +0 -0
  183. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/series.cpython-39.pyc +0 -0
  184. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/site.cpython-313.pyc +0 -0
  185. StreamingCommunity/Api/Site/streamingcommunity/__pycache__/site.cpython-39.pyc +0 -0
  186. StreamingCommunity/Api/Site/streamingcommunity/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
  187. StreamingCommunity/Api/Site/streamingcommunity/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
  188. StreamingCommunity/Api/Template/Class/__pycache__/SearchType.cpython-313.pyc +0 -0
  189. StreamingCommunity/Api/Template/Class/__pycache__/SearchType.cpython-39.pyc +0 -0
  190. StreamingCommunity/Api/Template/Util/__pycache__/__init__.cpython-313.pyc +0 -0
  191. StreamingCommunity/Api/Template/Util/__pycache__/__init__.cpython-39.pyc +0 -0
  192. StreamingCommunity/Api/Template/Util/__pycache__/get_domain.cpython-313.pyc +0 -0
  193. StreamingCommunity/Api/Template/Util/__pycache__/get_domain.cpython-39.pyc +0 -0
  194. StreamingCommunity/Api/Template/Util/__pycache__/manage_ep.cpython-313.pyc +0 -0
  195. StreamingCommunity/Api/Template/Util/__pycache__/manage_ep.cpython-39.pyc +0 -0
  196. StreamingCommunity/Api/Template/Util/__pycache__/recall_search.cpython-313.pyc +0 -0
  197. StreamingCommunity/Api/Template/Util/__pycache__/recall_search.cpython-39.pyc +0 -0
  198. StreamingCommunity/Api/Template/__pycache__/__init__.cpython-313.pyc +0 -0
  199. StreamingCommunity/Api/Template/__pycache__/__init__.cpython-39.pyc +0 -0
  200. StreamingCommunity/Api/Template/__pycache__/site.cpython-313.pyc +0 -0
  201. StreamingCommunity/Api/Template/__pycache__/site.cpython-39.pyc +0 -0
  202. StreamingCommunity/Lib/Downloader/HLS/__pycache__/downloader.cpython-313.pyc +0 -0
  203. StreamingCommunity/Lib/Downloader/HLS/__pycache__/downloader.cpython-39.pyc +0 -0
  204. StreamingCommunity/Lib/Downloader/HLS/__pycache__/proxyes.cpython-313.pyc +0 -0
  205. StreamingCommunity/Lib/Downloader/HLS/__pycache__/proxyes.cpython-39.pyc +0 -0
  206. StreamingCommunity/Lib/Downloader/HLS/__pycache__/segments.cpython-313.pyc +0 -0
  207. StreamingCommunity/Lib/Downloader/HLS/__pycache__/segments.cpython-39.pyc +0 -0
  208. StreamingCommunity/Lib/Downloader/MP4/__pycache__/downloader.cpython-313.pyc +0 -0
  209. StreamingCommunity/Lib/Downloader/MP4/__pycache__/downloader.cpython-39.pyc +0 -0
  210. StreamingCommunity/Lib/Downloader/TOR/__pycache__/downloader.cpython-313.pyc +0 -0
  211. StreamingCommunity/Lib/Downloader/TOR/__pycache__/downloader.cpython-39.pyc +0 -0
  212. StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-313.pyc +0 -0
  213. StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-39.pyc +0 -0
  214. StreamingCommunity/Lib/FFmpeg/__pycache__/__init__.cpython-313.pyc +0 -0
  215. StreamingCommunity/Lib/FFmpeg/__pycache__/__init__.cpython-39.pyc +0 -0
  216. StreamingCommunity/Lib/FFmpeg/__pycache__/capture.cpython-313.pyc +0 -0
  217. StreamingCommunity/Lib/FFmpeg/__pycache__/capture.cpython-39.pyc +0 -0
  218. StreamingCommunity/Lib/FFmpeg/__pycache__/command.cpython-313.pyc +0 -0
  219. StreamingCommunity/Lib/FFmpeg/__pycache__/command.cpython-39.pyc +0 -0
  220. StreamingCommunity/Lib/FFmpeg/__pycache__/util.cpython-313.pyc +0 -0
  221. StreamingCommunity/Lib/FFmpeg/__pycache__/util.cpython-39.pyc +0 -0
  222. StreamingCommunity/Lib/M3U8/__pycache__/__init__.cpython-313.pyc +0 -0
  223. StreamingCommunity/Lib/M3U8/__pycache__/__init__.cpython-39.pyc +0 -0
  224. StreamingCommunity/Lib/M3U8/__pycache__/decryptor.cpython-313.pyc +0 -0
  225. StreamingCommunity/Lib/M3U8/__pycache__/decryptor.cpython-39.pyc +0 -0
  226. StreamingCommunity/Lib/M3U8/__pycache__/estimator.cpython-313.pyc +0 -0
  227. StreamingCommunity/Lib/M3U8/__pycache__/estimator.cpython-39.pyc +0 -0
  228. StreamingCommunity/Lib/M3U8/__pycache__/parser.cpython-313.pyc +0 -0
  229. StreamingCommunity/Lib/M3U8/__pycache__/parser.cpython-39.pyc +0 -0
  230. StreamingCommunity/Lib/M3U8/__pycache__/url_fixer.cpython-313.pyc +0 -0
  231. StreamingCommunity/Lib/M3U8/__pycache__/url_fixer.cpython-39.pyc +0 -0
  232. StreamingCommunity/Lib/TMBD/__pycache__/__init__.cpython-313.pyc +0 -0
  233. StreamingCommunity/Lib/TMBD/__pycache__/__init__.cpython-39.pyc +0 -0
  234. StreamingCommunity/Lib/TMBD/__pycache__/obj_tmbd.cpython-313.pyc +0 -0
  235. StreamingCommunity/Lib/TMBD/__pycache__/obj_tmbd.cpython-39.pyc +0 -0
  236. StreamingCommunity/Lib/TMBD/__pycache__/tmdb.cpython-313.pyc +0 -0
  237. StreamingCommunity/Lib/TMBD/__pycache__/tmdb.cpython-39.pyc +0 -0
  238. StreamingCommunity/Upload/__pycache__/update.cpython-313.pyc +0 -0
  239. StreamingCommunity/Upload/__pycache__/update.cpython-39.pyc +0 -0
  240. StreamingCommunity/Upload/__pycache__/version.cpython-313.pyc +0 -0
  241. StreamingCommunity/Upload/__pycache__/version.cpython-39.pyc +0 -0
  242. StreamingCommunity/Util/__pycache__/_jsonConfig.cpython-313.pyc +0 -0
  243. StreamingCommunity/Util/__pycache__/_jsonConfig.cpython-39.pyc +0 -0
  244. StreamingCommunity/Util/__pycache__/call_stack.cpython-313.pyc +0 -0
  245. StreamingCommunity/Util/__pycache__/call_stack.cpython-39.pyc +0 -0
  246. StreamingCommunity/Util/__pycache__/color.cpython-313.pyc +0 -0
  247. StreamingCommunity/Util/__pycache__/color.cpython-39.pyc +0 -0
  248. StreamingCommunity/Util/__pycache__/console.cpython-313.pyc +0 -0
  249. StreamingCommunity/Util/__pycache__/console.cpython-39.pyc +0 -0
  250. StreamingCommunity/Util/__pycache__/ffmpeg_installer.cpython-313.pyc +0 -0
  251. StreamingCommunity/Util/__pycache__/ffmpeg_installer.cpython-39.pyc +0 -0
  252. StreamingCommunity/Util/__pycache__/headers.cpython-313.pyc +0 -0
  253. StreamingCommunity/Util/__pycache__/headers.cpython-39.pyc +0 -0
  254. StreamingCommunity/Util/__pycache__/logger.cpython-313.pyc +0 -0
  255. StreamingCommunity/Util/__pycache__/logger.cpython-39.pyc +0 -0
  256. StreamingCommunity/Util/__pycache__/message.cpython-313.pyc +0 -0
  257. StreamingCommunity/Util/__pycache__/message.cpython-39.pyc +0 -0
  258. StreamingCommunity/Util/__pycache__/os.cpython-313.pyc +0 -0
  259. StreamingCommunity/Util/__pycache__/os.cpython-39.pyc +0 -0
  260. StreamingCommunity/Util/__pycache__/table.cpython-313.pyc +0 -0
  261. StreamingCommunity/Util/__pycache__/table.cpython-39.pyc +0 -0
  262. StreamingCommunity/__pycache__/__init__.cpython-313.pyc +0 -0
  263. StreamingCommunity/__pycache__/__init__.cpython-39.pyc +0 -0
  264. StreamingCommunity/__pycache__/run.cpython-313.pyc +0 -0
  265. StreamingCommunity/__pycache__/run.cpython-39.pyc +0 -0
  266. StreamingCommunity-2.5.2.dist-info/RECORD +0 -264
  267. {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.5.dist-info}/WHEEL +0 -0
  268. {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.5.dist-info}/top_level.txt +0 -0
@@ -1,175 +1,192 @@
1
- # 10.12.23
2
-
3
- import logging
4
-
5
-
6
- # External libraries
7
- import httpx
8
- from bs4 import BeautifulSoup
9
-
10
-
11
- # Internal utilities
12
- from StreamingCommunity.Util.console import console
13
- from StreamingCommunity.Util._jsonConfig import config_manager
14
- from StreamingCommunity.Util.table import TVShowManager
15
-
16
-
17
- # Logic class
18
- from StreamingCommunity.Api.Template import get_select_title
19
- from StreamingCommunity.Api.Template.Util import search_domain
20
- from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
21
-
22
-
23
- # Variable
24
- from .costant import SITE_NAME, DOMAIN_NOW
25
- media_search_manager = MediaManager()
26
- table_show_manager = TVShowManager()
27
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
28
- disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
29
-
30
-
31
- def get_token(site_name: str, domain: str) -> dict:
32
- """
33
- Function to retrieve session tokens from a specified website.
34
-
35
- Parameters:
36
- - site_name (str): The name of the site.
37
- - domain (str): The domain of the site.
38
-
39
- Returns:
40
- - dict: A dictionary containing session tokens. The keys are 'XSRF_TOKEN', 'animeunity_session', and 'csrf_token'.
41
- """
42
-
43
- # Send a GET request to the specified URL composed of the site name and domain
44
- response = httpx.get(
45
- url=f"https://www.{site_name}.{domain}",
46
- timeout=max_timeout
47
- )
48
- response.raise_for_status()
49
-
50
- # Initialize variables to store CSRF token
51
- find_csrf_token = None
52
-
53
- # Parse the HTML response using BeautifulSoup
54
- soup = BeautifulSoup(response.text, "html.parser")
55
-
56
- # Loop through all meta tags in the HTML response
57
- for html_meta in soup.find_all("meta"):
58
-
59
- # Check if the meta tag has a 'name' attribute equal to "csrf-token"
60
- if html_meta.get('name') == "csrf-token":
61
-
62
- # If found, retrieve the content of the meta tag, which is the CSRF token
63
- find_csrf_token = html_meta.get('content')
64
-
65
- logging.info(f"Extract: ('animeunity_session': {response.cookies['animeunity_session']}, 'csrf_token': {find_csrf_token})")
66
- return {
67
- 'animeunity_session': response.cookies['animeunity_session'],
68
- 'csrf_token': find_csrf_token
69
- }
70
-
71
-
72
- def get_real_title(record):
73
- """
74
- Get the real title from a record.
75
-
76
- This function takes a record, which is assumed to be a dictionary representing a row of JSON data.
77
- It looks for a title in the record, prioritizing English over Italian titles if available.
78
-
79
- Parameters:
80
- - record (dict): A dictionary representing a row of JSON data.
81
-
82
- Returns:
83
- - str: The title found in the record. If no title is found, returns None.
84
- """
85
-
86
- if record['title'] is not None:
87
- return record['title']
88
-
89
- elif record['title_eng'] is not None:
90
- return record['title_eng']
91
-
92
- else:
93
- return record['title_it']
94
-
95
-
96
- def title_search(title: str) -> int:
97
- """
98
- Function to perform an anime search using a provided title.
99
-
100
- Parameters:
101
- - title_search (str): The title to search for.
102
-
103
- Returns:
104
- - int: A number containing the length of media search manager.
105
- """
106
- media_search_manager.clear()
107
- table_show_manager.clear()
108
-
109
- # Get token and session value from configuration
110
- domain_to_use = DOMAIN_NOW
111
-
112
- if not disable_searchDomain:
113
- domain_to_use, base_url = search_domain(SITE_NAME, f"https://www.{SITE_NAME}.{DOMAIN_NOW}")
114
-
115
- data = get_token(SITE_NAME, domain_to_use)
116
-
117
- # Prepare cookies to be used in the request
118
- cookies = {
119
- 'animeunity_session': data.get('animeunity_session')
120
- }
121
-
122
- # Prepare headers for the request
123
- headers = {
124
- 'accept': 'application/json, text/plain, */*',
125
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
126
- 'content-type': 'application/json;charset=UTF-8',
127
- 'x-csrf-token': data.get('csrf_token')
128
- }
129
-
130
- # Prepare JSON data to be sent in the request
131
- json_data = {
132
- 'title': title
133
- }
134
-
135
- # Send a POST request to the API endpoint for live search
136
- try:
137
- response = httpx.post(
138
- url=f'https://www.{SITE_NAME}.{domain_to_use}/livesearch',
139
- cookies=cookies,
140
- headers=headers,
141
- json=json_data,
142
- timeout=max_timeout
143
- )
144
- response.raise_for_status()
145
-
146
- except Exception as e:
147
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
148
-
149
- for dict_title in response.json()['records']:
150
- try:
151
-
152
- # Rename keys for consistency
153
- dict_title['name'] = get_real_title(dict_title)
154
-
155
- media_search_manager.add_media({
156
- 'id': dict_title.get('id'),
157
- 'slug': dict_title.get('slug'),
158
- 'name': dict_title.get('name'),
159
- 'type': dict_title.get('type'),
160
- 'score': dict_title.get('score'),
161
- 'episodes_count': dict_title.get('episodes_count')
162
- })
163
-
164
- except Exception as e:
165
- print(f"Error parsing a film entry: {e}")
166
-
167
- # Return the length of media search manager
168
- return media_search_manager.get_length()
169
-
170
-
171
- def run_get_select_title():
172
- """
173
- Display a selection of titles and prompt the user to choose one.
174
- """
1
+ # 10.12.23
2
+
3
+ import logging
4
+
5
+
6
+ # External libraries
7
+ import httpx
8
+ from bs4 import BeautifulSoup
9
+
10
+
11
+ # Internal utilities
12
+ from StreamingCommunity.Util.console import console
13
+ from StreamingCommunity.Util._jsonConfig import config_manager
14
+ from StreamingCommunity.Util.table import TVShowManager
15
+ from StreamingCommunity.TelegramHelp.telegram_bot import get_bot_instance
16
+
17
+
18
+ # Logic class
19
+ from StreamingCommunity.Api.Template import get_select_title
20
+ from StreamingCommunity.Api.Template.Util import search_domain
21
+ from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
22
+
23
+
24
+ # Variable
25
+ from .costant import SITE_NAME, DOMAIN_NOW, TELEGRAM_BOT
26
+ media_search_manager = MediaManager()
27
+ table_show_manager = TVShowManager()
28
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
29
+ disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
30
+
31
+
32
+ def get_token(site_name: str, domain: str) -> dict:
33
+ """
34
+ Function to retrieve session tokens from a specified website.
35
+
36
+ Parameters:
37
+ - site_name (str): The name of the site.
38
+ - domain (str): The domain of the site.
39
+
40
+ Returns:
41
+ - dict: A dictionary containing session tokens. The keys are 'XSRF_TOKEN', 'animeunity_session', and 'csrf_token'.
42
+ """
43
+
44
+ # Send a GET request to the specified URL composed of the site name and domain
45
+ response = httpx.get(
46
+ url=f"https://www.{site_name}.{domain}",
47
+ timeout=max_timeout
48
+ )
49
+ response.raise_for_status()
50
+
51
+ # Initialize variables to store CSRF token
52
+ find_csrf_token = None
53
+
54
+ # Parse the HTML response using BeautifulSoup
55
+ soup = BeautifulSoup(response.text, "html.parser")
56
+
57
+ # Loop through all meta tags in the HTML response
58
+ for html_meta in soup.find_all("meta"):
59
+
60
+ # Check if the meta tag has a 'name' attribute equal to "csrf-token"
61
+ if html_meta.get('name') == "csrf-token":
62
+
63
+ # If found, retrieve the content of the meta tag, which is the CSRF token
64
+ find_csrf_token = html_meta.get('content')
65
+
66
+ logging.info(f"Extract: ('animeunity_session': {response.cookies['animeunity_session']}, 'csrf_token': {find_csrf_token})")
67
+ return {
68
+ 'animeunity_session': response.cookies['animeunity_session'],
69
+ 'csrf_token': find_csrf_token
70
+ }
71
+
72
+
73
+ def get_real_title(record):
74
+ """
75
+ Get the real title from a record.
76
+
77
+ This function takes a record, which is assumed to be a dictionary representing a row of JSON data.
78
+ It looks for a title in the record, prioritizing English over Italian titles if available.
79
+
80
+ Parameters:
81
+ - record (dict): A dictionary representing a row of JSON data.
82
+
83
+ Returns:
84
+ - str: The title found in the record. If no title is found, returns None.
85
+ """
86
+
87
+ if record['title'] is not None:
88
+ return record['title']
89
+
90
+ elif record['title_eng'] is not None:
91
+ return record['title_eng']
92
+
93
+ else:
94
+ return record['title_it']
95
+
96
+
97
+ def title_search(title: str) -> int:
98
+ """
99
+ Function to perform an anime search using a provided title.
100
+
101
+ Parameters:
102
+ - title_search (str): The title to search for.
103
+
104
+ Returns:
105
+ - int: A number containing the length of media search manager.
106
+ """
107
+ if TELEGRAM_BOT:
108
+ bot = get_bot_instance()
109
+
110
+ media_search_manager.clear()
111
+ table_show_manager.clear()
112
+
113
+ # Get token and session value from configuration
114
+ domain_to_use = DOMAIN_NOW
115
+
116
+ if not disable_searchDomain:
117
+ domain_to_use, base_url = search_domain(SITE_NAME, f"https://www.{SITE_NAME}.{DOMAIN_NOW}")
118
+
119
+ data = get_token(SITE_NAME, domain_to_use)
120
+
121
+ # Prepare cookies to be used in the request
122
+ cookies = {
123
+ 'animeunity_session': data.get('animeunity_session')
124
+ }
125
+
126
+ # Prepare headers for the request
127
+ headers = {
128
+ 'accept': 'application/json, text/plain, */*',
129
+ 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
130
+ 'content-type': 'application/json;charset=UTF-8',
131
+ 'x-csrf-token': data.get('csrf_token')
132
+ }
133
+
134
+ # Prepare JSON data to be sent in the request
135
+ json_data = {
136
+ 'title': title
137
+ }
138
+
139
+ # Send a POST request to the API endpoint for live search
140
+ try:
141
+ response = httpx.post(
142
+ url=f'https://www.{SITE_NAME}.{domain_to_use}/livesearch',
143
+ cookies=cookies,
144
+ headers=headers,
145
+ json=json_data,
146
+ timeout=max_timeout
147
+ )
148
+ response.raise_for_status()
149
+
150
+ except Exception as e:
151
+ console.print(f"Site: {SITE_NAME}, request search error: {e}")
152
+
153
+ # Inizializza la lista delle scelte
154
+ if TELEGRAM_BOT:
155
+ choices = []
156
+
157
+ for dict_title in response.json()['records']:
158
+ try:
159
+
160
+ # Rename keys for consistency
161
+ dict_title['name'] = get_real_title(dict_title)
162
+
163
+ media_search_manager.add_media({
164
+ 'id': dict_title.get('id'),
165
+ 'slug': dict_title.get('slug'),
166
+ 'name': dict_title.get('name'),
167
+ 'type': dict_title.get('type'),
168
+ 'score': dict_title.get('score'),
169
+ 'episodes_count': dict_title.get('episodes_count')
170
+ })
171
+
172
+ if TELEGRAM_BOT:
173
+ # Crea una stringa formattata per ogni scelta con numero
174
+ choice_text = f"{len(choices)} - {dict_title.get('name')} ({dict_title.get('type')}) - Episodi: {dict_title.get('episodes_count')}"
175
+ choices.append(choice_text)
176
+
177
+ except Exception as e:
178
+ print(f"Error parsing a film entry: {e}")
179
+
180
+ if TELEGRAM_BOT:
181
+ if choices:
182
+ bot.send_message(f"Lista dei risultati:", choices)
183
+
184
+ # Return the length of media search manager
185
+ return media_search_manager.get_length()
186
+
187
+
188
+ def run_get_select_title():
189
+ """
190
+ Display a selection of titles and prompt the user to choose one.
191
+ """
175
192
  return get_select_title(table_show_manager, media_search_manager)
@@ -1,97 +1,97 @@
1
- # 01.03.24
2
-
3
- import logging
4
-
5
-
6
- # External libraries
7
- import httpx
8
-
9
-
10
- # Internal utilities
11
- from StreamingCommunity.Util.headers import get_headers
12
- from StreamingCommunity.Util._jsonConfig import config_manager
13
- from StreamingCommunity.Api.Player.Helper.Vixcloud.util import EpisodeManager, Episode
14
-
15
-
16
- # Variable
17
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
18
-
19
-
20
-
21
- class ScrapeSerieAnime():
22
- def __init__(self, site_name: str):
23
- """
24
- Initialize the media scraper for a specific website.
25
-
26
- Args:
27
- site_name (str): Name of the streaming site to scrape
28
- """
29
- self.is_series = False
30
- self.headers = {'user-agent': get_headers()}
31
- self.base_name = site_name
32
- self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
33
-
34
- def setup(self, version: str = None, media_id: int = None, series_name: str = None):
35
- self.version = version
36
- self.media_id = media_id
37
-
38
- if series_name is not None:
39
- self.is_series = True
40
- self.series_name = series_name
41
- self.obj_episode_manager: EpisodeManager = EpisodeManager()
42
-
43
- def get_count_episodes(self):
44
- """
45
- Retrieve total number of episodes for the selected media.
46
-
47
- Returns:
48
- int: Total episode count
49
- """
50
- try:
51
-
52
- response = httpx.get(
53
- url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/",
54
- headers=self.headers,
55
- timeout=max_timeout
56
- )
57
- response.raise_for_status()
58
-
59
- # Parse JSON response and return episode count
60
- return response.json()["episodes_count"]
61
-
62
- except Exception as e:
63
- logging.error(f"Error fetching episode count: {e}")
64
- return None
65
-
66
- def get_info_episode(self, index_ep: int) -> Episode:
67
- """
68
- Fetch detailed information for a specific episode.
69
-
70
- Args:
71
- index_ep (int): Zero-based index of the target episode
72
-
73
- Returns:
74
- Episode: Detailed episode information
75
- """
76
- try:
77
-
78
- params = {
79
- "start_range": index_ep,
80
- "end_range": index_ep + 1
81
- }
82
-
83
- response = httpx.get(
84
- url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/{index_ep}",
85
- headers=self.headers,
86
- params=params,
87
- timeout=max_timeout
88
- )
89
- response.raise_for_status()
90
-
91
- # Return information about the episode
92
- json_data = response.json()["episodes"][-1]
93
- return Episode(json_data)
94
-
95
- except Exception as e:
96
- logging.error(f"Error fetching episode information: {e}")
97
- return None
1
+ # 01.03.24
2
+
3
+ import logging
4
+
5
+
6
+ # External libraries
7
+ import httpx
8
+
9
+
10
+ # Internal utilities
11
+ from StreamingCommunity.Util.headers import get_headers
12
+ from StreamingCommunity.Util._jsonConfig import config_manager
13
+ from StreamingCommunity.Api.Player.Helper.Vixcloud.util import EpisodeManager, Episode
14
+
15
+
16
+ # Variable
17
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
18
+
19
+
20
+
21
+ class ScrapeSerieAnime():
22
+ def __init__(self, site_name: str):
23
+ """
24
+ Initialize the media scraper for a specific website.
25
+
26
+ Args:
27
+ site_name (str): Name of the streaming site to scrape
28
+ """
29
+ self.is_series = False
30
+ self.headers = {'user-agent': get_headers()}
31
+ self.base_name = site_name
32
+ self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
33
+
34
+ def setup(self, version: str = None, media_id: int = None, series_name: str = None):
35
+ self.version = version
36
+ self.media_id = media_id
37
+
38
+ if series_name is not None:
39
+ self.is_series = True
40
+ self.series_name = series_name
41
+ self.obj_episode_manager: EpisodeManager = EpisodeManager()
42
+
43
+ def get_count_episodes(self):
44
+ """
45
+ Retrieve total number of episodes for the selected media.
46
+
47
+ Returns:
48
+ int: Total episode count
49
+ """
50
+ try:
51
+
52
+ response = httpx.get(
53
+ url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/",
54
+ headers=self.headers,
55
+ timeout=max_timeout
56
+ )
57
+ response.raise_for_status()
58
+
59
+ # Parse JSON response and return episode count
60
+ return response.json()["episodes_count"]
61
+
62
+ except Exception as e:
63
+ logging.error(f"Error fetching episode count: {e}")
64
+ return None
65
+
66
+ def get_info_episode(self, index_ep: int) -> Episode:
67
+ """
68
+ Fetch detailed information for a specific episode.
69
+
70
+ Args:
71
+ index_ep (int): Zero-based index of the target episode
72
+
73
+ Returns:
74
+ Episode: Detailed episode information
75
+ """
76
+ try:
77
+
78
+ params = {
79
+ "start_range": index_ep,
80
+ "end_range": index_ep + 1
81
+ }
82
+
83
+ response = httpx.get(
84
+ url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/{index_ep}",
85
+ headers=self.headers,
86
+ params=params,
87
+ timeout=max_timeout
88
+ )
89
+ response.raise_for_status()
90
+
91
+ # Return information about the episode
92
+ json_data = response.json()["episodes"][-1]
93
+ return Episode(json_data)
94
+
95
+ except Exception as e:
96
+ logging.error(f"Error fetching episode information: {e}")
97
+ return None
@@ -1,52 +1,52 @@
1
- # 09.06.24
2
-
3
- from urllib.parse import quote_plus
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Util.console import console, msg
8
-
9
-
10
- # Logic class
11
- from .site import title_search, run_get_select_title, media_search_manager
12
- from .film import download_film
13
-
14
-
15
- # Variable
16
- indice = 9
17
- _useFor = "film"
18
- _deprecate = False
19
- _priority = 2
20
- _engineDownload = "mp4"
21
- from .costant import SITE_NAME
22
-
23
-
24
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
25
- """
26
- Main function of the application for film and series.
27
- """
28
-
29
- if string_to_search is None:
30
- string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
31
-
32
- # Search on database
33
- len_database = title_search(quote_plus(string_to_search))
34
-
35
- # Return list of elements
36
- if get_onylDatabase:
37
- return media_search_manager
38
-
39
- if len_database > 0:
40
-
41
- # Select title from list
42
- select_title = run_get_select_title()
43
-
44
- # !!! ADD TYPE DONT WORK FOR SERIE
45
- download_film(select_title)
46
-
47
-
48
- else:
49
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
50
-
51
- # Retry
1
+ # 09.06.24
2
+
3
+ from urllib.parse import quote_plus
4
+
5
+
6
+ # Internal utilities
7
+ from StreamingCommunity.Util.console import console, msg
8
+
9
+
10
+ # Logic class
11
+ from .site import title_search, run_get_select_title, media_search_manager
12
+ from .film import download_film
13
+
14
+
15
+ # Variable
16
+ indice = 9
17
+ _useFor = "film"
18
+ _deprecate = False
19
+ _priority = 2
20
+ _engineDownload = "mp4"
21
+ from .costant import SITE_NAME
22
+
23
+
24
+ def search(string_to_search: str = None, get_onylDatabase: bool = False):
25
+ """
26
+ Main function of the application for film and series.
27
+ """
28
+
29
+ if string_to_search is None:
30
+ string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
31
+
32
+ # Search on database
33
+ len_database = title_search(quote_plus(string_to_search))
34
+
35
+ # Return list of elements
36
+ if get_onylDatabase:
37
+ return media_search_manager
38
+
39
+ if len_database > 0:
40
+
41
+ # Select title from list
42
+ select_title = run_get_select_title()
43
+
44
+ # !!! ADD TYPE DONT WORK FOR SERIE
45
+ download_film(select_title)
46
+
47
+
48
+ else:
49
+ console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
50
+
51
+ # Retry
52
52
  search()