StreamingCommunity 2.5.2__py3-none-any.whl → 2.5.6__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.
- StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +143 -143
- StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +136 -136
- StreamingCommunity/Api/Player/ddl.py +89 -89
- StreamingCommunity/Api/Player/maxstream.py +151 -151
- StreamingCommunity/Api/Player/supervideo.py +193 -193
- StreamingCommunity/Api/Player/vixcloud.py +272 -272
- StreamingCommunity/Api/Site/1337xx/__init__.py +51 -50
- StreamingCommunity/Api/Site/1337xx/costant.py +14 -14
- StreamingCommunity/Api/Site/1337xx/site.py +87 -89
- StreamingCommunity/Api/Site/1337xx/title.py +63 -64
- StreamingCommunity/Api/Site/altadefinizionegratis/__init__.py +74 -50
- StreamingCommunity/Api/Site/altadefinizionegratis/costant.py +21 -19
- StreamingCommunity/Api/Site/altadefinizionegratis/film.py +81 -72
- StreamingCommunity/Api/Site/altadefinizionegratis/site.py +116 -94
- StreamingCommunity/Api/Site/animeunity/__init__.py +75 -50
- StreamingCommunity/Api/Site/animeunity/costant.py +21 -19
- StreamingCommunity/Api/Site/animeunity/film_serie.py +172 -134
- StreamingCommunity/Api/Site/animeunity/site.py +191 -174
- StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +97 -97
- StreamingCommunity/Api/Site/cb01new/__init__.py +51 -51
- StreamingCommunity/Api/Site/cb01new/costant.py +19 -19
- StreamingCommunity/Api/Site/cb01new/film.py +61 -71
- StreamingCommunity/Api/Site/cb01new/site.py +82 -82
- StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +55 -55
- StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +20 -20
- StreamingCommunity/Api/Site/ddlstreamitaly/series.py +150 -145
- StreamingCommunity/Api/Site/ddlstreamitaly/site.py +98 -98
- StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +84 -84
- StreamingCommunity/Api/Site/guardaserie/__init__.py +50 -50
- StreamingCommunity/Api/Site/guardaserie/costant.py +19 -19
- StreamingCommunity/Api/Site/guardaserie/series.py +200 -198
- StreamingCommunity/Api/Site/guardaserie/site.py +89 -89
- StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +110 -110
- StreamingCommunity/Api/Site/ilcorsaronero/__init__.py +51 -51
- StreamingCommunity/Api/Site/ilcorsaronero/costant.py +18 -18
- StreamingCommunity/Api/Site/ilcorsaronero/site.py +71 -71
- StreamingCommunity/Api/Site/ilcorsaronero/title.py +44 -44
- StreamingCommunity/Api/Site/ilcorsaronero/util/ilCorsarScraper.py +149 -149
- StreamingCommunity/Api/Site/mostraguarda/__init__.py +48 -48
- StreamingCommunity/Api/Site/mostraguarda/costant.py +18 -18
- StreamingCommunity/Api/Site/mostraguarda/film.py +90 -101
- StreamingCommunity/Api/Site/streamingcommunity/__init__.py +79 -55
- StreamingCommunity/Api/Site/streamingcommunity/costant.py +21 -19
- StreamingCommunity/Api/Site/streamingcommunity/film.py +86 -75
- StreamingCommunity/Api/Site/streamingcommunity/series.py +260 -207
- StreamingCommunity/Api/Site/streamingcommunity/site.py +156 -142
- StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +124 -124
- StreamingCommunity/Api/Template/Class/SearchType.py +101 -101
- StreamingCommunity/Api/Template/Util/__init__.py +4 -4
- StreamingCommunity/Api/Template/Util/get_domain.py +201 -201
- StreamingCommunity/Api/Template/Util/manage_ep.py +178 -178
- StreamingCommunity/Api/Template/Util/recall_search.py +37 -37
- StreamingCommunity/Api/Template/__init__.py +2 -2
- StreamingCommunity/Api/Template/site.py +87 -87
- StreamingCommunity/Lib/Downloader/HLS/downloader.py +529 -1008
- StreamingCommunity/Lib/Downloader/HLS/proxyes.py +110 -110
- StreamingCommunity/Lib/Downloader/HLS/segments.py +446 -573
- StreamingCommunity/Lib/Downloader/MP4/downloader.py +181 -155
- StreamingCommunity/Lib/Downloader/TOR/downloader.py +297 -295
- StreamingCommunity/Lib/Downloader/__init__.py +4 -4
- StreamingCommunity/Lib/FFmpeg/__init__.py +4 -4
- StreamingCommunity/Lib/FFmpeg/capture.py +170 -170
- StreamingCommunity/Lib/FFmpeg/command.py +264 -296
- StreamingCommunity/Lib/FFmpeg/util.py +248 -248
- StreamingCommunity/Lib/M3U8/__init__.py +5 -5
- StreamingCommunity/Lib/M3U8/decryptor.py +164 -164
- StreamingCommunity/Lib/M3U8/estimator.py +146 -228
- StreamingCommunity/Lib/M3U8/parser.py +666 -666
- StreamingCommunity/Lib/M3U8/url_fixer.py +57 -57
- StreamingCommunity/Lib/TMBD/__init__.py +1 -1
- StreamingCommunity/Lib/TMBD/obj_tmbd.py +39 -39
- StreamingCommunity/Lib/TMBD/tmdb.py +345 -345
- StreamingCommunity/TelegramHelp/__init__.py +0 -0
- StreamingCommunity/TelegramHelp/request_manager.py +82 -0
- StreamingCommunity/TelegramHelp/session.py +56 -0
- StreamingCommunity/TelegramHelp/telegram_bot.py +561 -0
- StreamingCommunity/Upload/update.py +75 -67
- StreamingCommunity/Upload/version.py +5 -5
- StreamingCommunity/Util/_jsonConfig.py +227 -228
- StreamingCommunity/Util/call_stack.py +42 -42
- StreamingCommunity/Util/color.py +20 -20
- StreamingCommunity/Util/console.py +12 -12
- StreamingCommunity/Util/ffmpeg_installer.py +342 -370
- StreamingCommunity/Util/headers.py +159 -159
- StreamingCommunity/Util/logger.py +61 -61
- StreamingCommunity/Util/message.py +36 -64
- StreamingCommunity/Util/os.py +500 -507
- StreamingCommunity/Util/table.py +271 -228
- StreamingCommunity/run.py +352 -245
- {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.6.dist-info}/LICENSE +674 -674
- {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.6.dist-info}/METADATA +601 -543
- StreamingCommunity-2.5.6.dist-info/RECORD +96 -0
- {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.6.dist-info}/entry_points.txt +0 -1
- StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/js_parser.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/js_parser.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/util.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/Helper/Vixcloud/__pycache__/util.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/ddl.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/ddl.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/maxstream.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/maxstream.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/supervideo.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/supervideo.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/vixcloud.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Player/__pycache__/vixcloud.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/title.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/1337xx/__pycache__/title.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/film.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/film.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/film_serie.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/film_serie.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/animeunity/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/film.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/film.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/cb01new/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/series.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/series.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/series.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/series.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/guardaserie/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/title.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/__pycache__/title.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/util/__pycache__/ilCorsarScraper.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/ilcorsaronero/util/__pycache__/ilCorsarScraper.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/film.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/mostraguarda/__pycache__/film.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/costant.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/costant.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/film.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/film.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/series.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/series.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/util/__pycache__/ScrapeSerie.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Site/streamingcommunity/util/__pycache__/ScrapeSerie.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/Class/__pycache__/SearchType.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/Class/__pycache__/SearchType.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/get_domain.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/get_domain.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/manage_ep.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/manage_ep.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/recall_search.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/Util/__pycache__/recall_search.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Api/Template/__pycache__/site.cpython-313.pyc +0 -0
- StreamingCommunity/Api/Template/__pycache__/site.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/downloader.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/downloader.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/proxyes.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/proxyes.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/segments.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/HLS/__pycache__/segments.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/MP4/__pycache__/downloader.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/MP4/__pycache__/downloader.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/TOR/__pycache__/downloader.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/TOR/__pycache__/downloader.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/capture.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/capture.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/command.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/command.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/util.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__pycache__/util.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/decryptor.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/decryptor.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/estimator.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/estimator.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/parser.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/parser.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/url_fixer.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/M3U8/__pycache__/url_fixer.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/obj_tmbd.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/obj_tmbd.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/tmdb.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/TMBD/__pycache__/tmdb.cpython-39.pyc +0 -0
- StreamingCommunity/Upload/__pycache__/update.cpython-313.pyc +0 -0
- StreamingCommunity/Upload/__pycache__/update.cpython-39.pyc +0 -0
- StreamingCommunity/Upload/__pycache__/version.cpython-313.pyc +0 -0
- StreamingCommunity/Upload/__pycache__/version.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/_jsonConfig.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/_jsonConfig.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/call_stack.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/call_stack.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/color.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/color.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/console.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/console.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/ffmpeg_installer.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/ffmpeg_installer.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/headers.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/headers.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/logger.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/logger.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/message.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/message.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/os.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/os.cpython-39.pyc +0 -0
- StreamingCommunity/Util/__pycache__/table.cpython-313.pyc +0 -0
- StreamingCommunity/Util/__pycache__/table.cpython-39.pyc +0 -0
- StreamingCommunity/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/__pycache__/run.cpython-313.pyc +0 -0
- StreamingCommunity/__pycache__/run.cpython-39.pyc +0 -0
- StreamingCommunity-2.5.2.dist-info/RECORD +0 -264
- {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.6.dist-info}/WHEEL +0 -0
- {StreamingCommunity-2.5.2.dist-info → StreamingCommunity-2.5.6.dist-info}/top_level.txt +0 -0
|
@@ -1,72 +1,72 @@
|
|
|
1
|
-
# 02.07.24
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
# Internal utilities
|
|
5
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
6
|
-
from StreamingCommunity.Util.table import TVShowManager
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
# Logic class
|
|
10
|
-
from StreamingCommunity.Api.Template import get_select_title
|
|
11
|
-
from StreamingCommunity.Api.Template.Util import search_domain
|
|
12
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
13
|
-
from .util.ilCorsarScraper import IlCorsaroNeroScraper
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
# Variable
|
|
17
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
18
|
-
media_search_manager = MediaManager()
|
|
19
|
-
table_show_manager = TVShowManager()
|
|
20
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
21
|
-
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
async def title_search(word_to_search: str) -> int:
|
|
25
|
-
"""
|
|
26
|
-
Search for titles based on a search query.
|
|
27
|
-
|
|
28
|
-
Parameters:
|
|
29
|
-
- title_search (str): The title to search for.
|
|
30
|
-
|
|
31
|
-
Returns:
|
|
32
|
-
- int: The number of titles found.
|
|
33
|
-
"""
|
|
34
|
-
media_search_manager.clear()
|
|
35
|
-
table_show_manager.clear()
|
|
36
|
-
|
|
37
|
-
# Find new domain if prev dont work
|
|
38
|
-
domain_to_use = DOMAIN_NOW
|
|
39
|
-
|
|
40
|
-
if not disable_searchDomain:
|
|
41
|
-
domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}.{DOMAIN_NOW}")
|
|
42
|
-
|
|
43
|
-
# Create scraper and collect result
|
|
44
|
-
print("\n")
|
|
45
|
-
scraper = IlCorsaroNeroScraper(f"https://{SITE_NAME}.{domain_to_use}/", 1)
|
|
46
|
-
results = await scraper.search(word_to_search)
|
|
47
|
-
|
|
48
|
-
for i, torrent in enumerate(results):
|
|
49
|
-
try:
|
|
50
|
-
|
|
51
|
-
media_search_manager.add_media({
|
|
52
|
-
'name': torrent['name'],
|
|
53
|
-
'type': torrent['type'],
|
|
54
|
-
'seed': torrent['seed'],
|
|
55
|
-
'leech': torrent['leech'],
|
|
56
|
-
'size': torrent['size'],
|
|
57
|
-
'date': torrent['date'],
|
|
58
|
-
'url': torrent['url']
|
|
59
|
-
})
|
|
60
|
-
|
|
61
|
-
except Exception as e:
|
|
62
|
-
print(f"Error parsing a film entry: {e}")
|
|
63
|
-
|
|
64
|
-
# Return the number of titles found
|
|
65
|
-
return media_search_manager.get_length()
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
def run_get_select_title():
|
|
69
|
-
"""
|
|
70
|
-
Display a selection of titles and prompt the user to choose one.
|
|
71
|
-
"""
|
|
1
|
+
# 02.07.24
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
# Internal utilities
|
|
5
|
+
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
6
|
+
from StreamingCommunity.Util.table import TVShowManager
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
# Logic class
|
|
10
|
+
from StreamingCommunity.Api.Template import get_select_title
|
|
11
|
+
from StreamingCommunity.Api.Template.Util import search_domain
|
|
12
|
+
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
13
|
+
from .util.ilCorsarScraper import IlCorsaroNeroScraper
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
# Variable
|
|
17
|
+
from .costant import SITE_NAME, DOMAIN_NOW
|
|
18
|
+
media_search_manager = MediaManager()
|
|
19
|
+
table_show_manager = TVShowManager()
|
|
20
|
+
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
21
|
+
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
async def title_search(word_to_search: str) -> int:
|
|
25
|
+
"""
|
|
26
|
+
Search for titles based on a search query.
|
|
27
|
+
|
|
28
|
+
Parameters:
|
|
29
|
+
- title_search (str): The title to search for.
|
|
30
|
+
|
|
31
|
+
Returns:
|
|
32
|
+
- int: The number of titles found.
|
|
33
|
+
"""
|
|
34
|
+
media_search_manager.clear()
|
|
35
|
+
table_show_manager.clear()
|
|
36
|
+
|
|
37
|
+
# Find new domain if prev dont work
|
|
38
|
+
domain_to_use = DOMAIN_NOW
|
|
39
|
+
|
|
40
|
+
if not disable_searchDomain:
|
|
41
|
+
domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}.{DOMAIN_NOW}")
|
|
42
|
+
|
|
43
|
+
# Create scraper and collect result
|
|
44
|
+
print("\n")
|
|
45
|
+
scraper = IlCorsaroNeroScraper(f"https://{SITE_NAME}.{domain_to_use}/", 1)
|
|
46
|
+
results = await scraper.search(word_to_search)
|
|
47
|
+
|
|
48
|
+
for i, torrent in enumerate(results):
|
|
49
|
+
try:
|
|
50
|
+
|
|
51
|
+
media_search_manager.add_media({
|
|
52
|
+
'name': torrent['name'],
|
|
53
|
+
'type': torrent['type'],
|
|
54
|
+
'seed': torrent['seed'],
|
|
55
|
+
'leech': torrent['leech'],
|
|
56
|
+
'size': torrent['size'],
|
|
57
|
+
'date': torrent['date'],
|
|
58
|
+
'url': torrent['url']
|
|
59
|
+
})
|
|
60
|
+
|
|
61
|
+
except Exception as e:
|
|
62
|
+
print(f"Error parsing a film entry: {e}")
|
|
63
|
+
|
|
64
|
+
# Return the number of titles found
|
|
65
|
+
return media_search_manager.get_length()
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
def run_get_select_title():
|
|
69
|
+
"""
|
|
70
|
+
Display a selection of titles and prompt the user to choose one.
|
|
71
|
+
"""
|
|
72
72
|
return get_select_title(table_show_manager, media_search_manager)
|
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
# 02.07.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util.console import console
|
|
8
|
-
from StreamingCommunity.Util.os import os_manager
|
|
9
|
-
from StreamingCommunity.Util.message import start_message
|
|
10
|
-
from StreamingCommunity.Lib.Downloader import TOR_downloader
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
# Logic class
|
|
14
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
# Config
|
|
18
|
-
from .costant import MOVIE_FOLDER
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
def download_title(select_title: MediaItem):
|
|
22
|
-
"""
|
|
23
|
-
Downloads a media item and saves it as an MP4 file.
|
|
24
|
-
|
|
25
|
-
Parameters:
|
|
26
|
-
- select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
|
|
27
|
-
"""
|
|
28
|
-
|
|
29
|
-
start_message()
|
|
30
|
-
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
31
|
-
print()
|
|
32
|
-
|
|
33
|
-
# Define output path
|
|
34
|
-
title_name = os_manager.get_sanitize_file(select_title.name)
|
|
35
|
-
mp4_path = os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
36
|
-
|
|
37
|
-
# Create output folder
|
|
38
|
-
os_manager.create_path(mp4_path)
|
|
39
|
-
|
|
40
|
-
# Tor manager
|
|
41
|
-
manager = TOR_downloader()
|
|
42
|
-
manager.add_magnet_link(select_title.url)
|
|
43
|
-
manager.start_download()
|
|
44
|
-
manager.move_downloaded_files(mp4_path)
|
|
1
|
+
# 02.07.24
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
# Internal utilities
|
|
7
|
+
from StreamingCommunity.Util.console import console
|
|
8
|
+
from StreamingCommunity.Util.os import os_manager
|
|
9
|
+
from StreamingCommunity.Util.message import start_message
|
|
10
|
+
from StreamingCommunity.Lib.Downloader import TOR_downloader
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
# Logic class
|
|
14
|
+
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
# Config
|
|
18
|
+
from .costant import MOVIE_FOLDER
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def download_title(select_title: MediaItem):
|
|
22
|
+
"""
|
|
23
|
+
Downloads a media item and saves it as an MP4 file.
|
|
24
|
+
|
|
25
|
+
Parameters:
|
|
26
|
+
- select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
|
|
27
|
+
"""
|
|
28
|
+
|
|
29
|
+
start_message()
|
|
30
|
+
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
31
|
+
print()
|
|
32
|
+
|
|
33
|
+
# Define output path
|
|
34
|
+
title_name = os_manager.get_sanitize_file(select_title.name)
|
|
35
|
+
mp4_path = os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
36
|
+
|
|
37
|
+
# Create output folder
|
|
38
|
+
os_manager.create_path(mp4_path)
|
|
39
|
+
|
|
40
|
+
# Tor manager
|
|
41
|
+
manager = TOR_downloader()
|
|
42
|
+
manager.add_magnet_link(select_title.url)
|
|
43
|
+
manager.start_download()
|
|
44
|
+
manager.move_downloaded_files(mp4_path)
|
|
@@ -1,149 +1,149 @@
|
|
|
1
|
-
# 12.14.24
|
|
2
|
-
|
|
3
|
-
import logging
|
|
4
|
-
import asyncio
|
|
5
|
-
from typing import List, Dict, Optional
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# External libraries
|
|
9
|
-
import httpx
|
|
10
|
-
from bs4 import BeautifulSoup
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
# Internal utilities
|
|
14
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
15
|
-
from StreamingCommunity.Util.headers import get_headers
|
|
16
|
-
from StreamingCommunity.Util.console import console
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
# Variable
|
|
20
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
class IlCorsaroNeroScraper:
|
|
24
|
-
def __init__(self, base_url: str, max_page: int = 1):
|
|
25
|
-
self.base_url = base_url
|
|
26
|
-
self.max_page = max_page
|
|
27
|
-
self.headers = {
|
|
28
|
-
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
|
29
|
-
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
|
|
30
|
-
'cache-control': 'max-age=0',
|
|
31
|
-
'priority': 'u=0, i',
|
|
32
|
-
'sec-ch-ua': '"Google Chrome";v="131", "Chromium";v="131", "Not_A Brand";v="24"',
|
|
33
|
-
'sec-ch-ua-mobile': '?0',
|
|
34
|
-
'sec-ch-ua-platform': '"Windows"',
|
|
35
|
-
'sec-fetch-dest': 'document',
|
|
36
|
-
'sec-fetch-mode': 'navigate',
|
|
37
|
-
'sec-fetch-site': 'same-origin',
|
|
38
|
-
'sec-fetch-user': '?1',
|
|
39
|
-
'upgrade-insecure-requests': '1',
|
|
40
|
-
'user-agent': get_headers()
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
async def fetch_url(self, url: str) -> Optional[str]:
|
|
44
|
-
"""
|
|
45
|
-
Fetch the HTML content of a given URL.
|
|
46
|
-
"""
|
|
47
|
-
try:
|
|
48
|
-
console.print(f"[cyan]Fetching url[white]: [red]{url}")
|
|
49
|
-
async with httpx.AsyncClient(headers=self.headers, follow_redirects=True, timeout=max_timeout) as client:
|
|
50
|
-
response = await client.get(url)
|
|
51
|
-
|
|
52
|
-
# If the request was successful, return the HTML content
|
|
53
|
-
response.raise_for_status()
|
|
54
|
-
return response.text
|
|
55
|
-
|
|
56
|
-
except Exception as e:
|
|
57
|
-
logging.error(f"Error fetching from {url}: {e}")
|
|
58
|
-
return None
|
|
59
|
-
|
|
60
|
-
def parse_torrents(self, html: str) -> List[Dict[str, str]]:
|
|
61
|
-
"""
|
|
62
|
-
Parse the HTML content and extract torrent details.
|
|
63
|
-
"""
|
|
64
|
-
torrents = []
|
|
65
|
-
soup = BeautifulSoup(html, "html.parser")
|
|
66
|
-
table = soup.find("tbody")
|
|
67
|
-
|
|
68
|
-
for row in table.find_all("tr"):
|
|
69
|
-
try:
|
|
70
|
-
columns = row.find_all("td")
|
|
71
|
-
|
|
72
|
-
torrents.append({
|
|
73
|
-
'type': columns[0].get_text(strip=True),
|
|
74
|
-
'name': row.find("th").find("a").get_text(strip=True),
|
|
75
|
-
'seed': columns[1].get_text(strip=True),
|
|
76
|
-
'leech': columns[2].get_text(strip=True),
|
|
77
|
-
'size': columns[3].get_text(strip=True),
|
|
78
|
-
'date': columns[4].get_text(strip=True),
|
|
79
|
-
'url': "https://ilcorsaronero.link" + row.find("th").find("a").get("href")
|
|
80
|
-
})
|
|
81
|
-
|
|
82
|
-
except Exception as e:
|
|
83
|
-
logging.error(f"Error parsing row: {e}")
|
|
84
|
-
continue
|
|
85
|
-
|
|
86
|
-
return torrents
|
|
87
|
-
|
|
88
|
-
async def fetch_real_url(self, url: str) -> Optional[str]:
|
|
89
|
-
"""
|
|
90
|
-
Fetch the real torrent URL from the detailed page.
|
|
91
|
-
"""
|
|
92
|
-
response_html = await self.fetch_url(url)
|
|
93
|
-
if not response_html:
|
|
94
|
-
return None
|
|
95
|
-
|
|
96
|
-
soup = BeautifulSoup(response_html, "html.parser")
|
|
97
|
-
links = soup.find_all("a")
|
|
98
|
-
|
|
99
|
-
# Find and return the magnet link
|
|
100
|
-
for link in links:
|
|
101
|
-
if "magnet" in str(link):
|
|
102
|
-
return link.get("href")
|
|
103
|
-
|
|
104
|
-
return None
|
|
105
|
-
|
|
106
|
-
async def search(self, query: str) -> List[Dict[str, str]]:
|
|
107
|
-
"""
|
|
108
|
-
Search for torrents based on the query string.
|
|
109
|
-
"""
|
|
110
|
-
all_torrents = []
|
|
111
|
-
|
|
112
|
-
# Loop through each page
|
|
113
|
-
for page in range(self.max_page):
|
|
114
|
-
url = f'{self.base_url}search?q={query}&page={page}'
|
|
115
|
-
|
|
116
|
-
html = await self.fetch_url(url)
|
|
117
|
-
if not html:
|
|
118
|
-
console.print(f"[bold red]No HTML content for page {page}[/bold red]")
|
|
119
|
-
break
|
|
120
|
-
|
|
121
|
-
torrents = self.parse_torrents(html)
|
|
122
|
-
if not torrents:
|
|
123
|
-
console.print(f"[bold red]No torrents found on page {page}[/bold red]")
|
|
124
|
-
break
|
|
125
|
-
|
|
126
|
-
# Use asyncio.gather to fetch all real URLs concurrently
|
|
127
|
-
tasks = [self.fetch_real_url(result['url']) for result in torrents]
|
|
128
|
-
real_urls = await asyncio.gather(*tasks)
|
|
129
|
-
|
|
130
|
-
# Attach real URLs to the torrent data
|
|
131
|
-
for i, result in enumerate(torrents):
|
|
132
|
-
result['url'] = real_urls[i]
|
|
133
|
-
|
|
134
|
-
all_torrents.extend(torrents)
|
|
135
|
-
|
|
136
|
-
return all_torrents
|
|
137
|
-
|
|
138
|
-
async def main():
|
|
139
|
-
scraper = IlCorsaroNeroScraper("https://ilcorsaronero.link/")
|
|
140
|
-
results = await scraper.search("cars")
|
|
141
|
-
|
|
142
|
-
if results:
|
|
143
|
-
for i, torrent in enumerate(results):
|
|
144
|
-
console.print(f"[bold green]{i} = {torrent}[/bold green] \n")
|
|
145
|
-
else:
|
|
146
|
-
console.print("[bold red]No torrents found.[/bold red]")
|
|
147
|
-
|
|
148
|
-
if __name__ == '__main__':
|
|
149
|
-
asyncio.run(main())
|
|
1
|
+
# 12.14.24
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
import asyncio
|
|
5
|
+
from typing import List, Dict, Optional
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
# External libraries
|
|
9
|
+
import httpx
|
|
10
|
+
from bs4 import BeautifulSoup
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
# Internal utilities
|
|
14
|
+
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
15
|
+
from StreamingCommunity.Util.headers import get_headers
|
|
16
|
+
from StreamingCommunity.Util.console import console
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
# Variable
|
|
20
|
+
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class IlCorsaroNeroScraper:
|
|
24
|
+
def __init__(self, base_url: str, max_page: int = 1):
|
|
25
|
+
self.base_url = base_url
|
|
26
|
+
self.max_page = max_page
|
|
27
|
+
self.headers = {
|
|
28
|
+
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
|
29
|
+
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
|
|
30
|
+
'cache-control': 'max-age=0',
|
|
31
|
+
'priority': 'u=0, i',
|
|
32
|
+
'sec-ch-ua': '"Google Chrome";v="131", "Chromium";v="131", "Not_A Brand";v="24"',
|
|
33
|
+
'sec-ch-ua-mobile': '?0',
|
|
34
|
+
'sec-ch-ua-platform': '"Windows"',
|
|
35
|
+
'sec-fetch-dest': 'document',
|
|
36
|
+
'sec-fetch-mode': 'navigate',
|
|
37
|
+
'sec-fetch-site': 'same-origin',
|
|
38
|
+
'sec-fetch-user': '?1',
|
|
39
|
+
'upgrade-insecure-requests': '1',
|
|
40
|
+
'user-agent': get_headers()
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async def fetch_url(self, url: str) -> Optional[str]:
|
|
44
|
+
"""
|
|
45
|
+
Fetch the HTML content of a given URL.
|
|
46
|
+
"""
|
|
47
|
+
try:
|
|
48
|
+
console.print(f"[cyan]Fetching url[white]: [red]{url}")
|
|
49
|
+
async with httpx.AsyncClient(headers=self.headers, follow_redirects=True, timeout=max_timeout) as client:
|
|
50
|
+
response = await client.get(url)
|
|
51
|
+
|
|
52
|
+
# If the request was successful, return the HTML content
|
|
53
|
+
response.raise_for_status()
|
|
54
|
+
return response.text
|
|
55
|
+
|
|
56
|
+
except Exception as e:
|
|
57
|
+
logging.error(f"Error fetching from {url}: {e}")
|
|
58
|
+
return None
|
|
59
|
+
|
|
60
|
+
def parse_torrents(self, html: str) -> List[Dict[str, str]]:
|
|
61
|
+
"""
|
|
62
|
+
Parse the HTML content and extract torrent details.
|
|
63
|
+
"""
|
|
64
|
+
torrents = []
|
|
65
|
+
soup = BeautifulSoup(html, "html.parser")
|
|
66
|
+
table = soup.find("tbody")
|
|
67
|
+
|
|
68
|
+
for row in table.find_all("tr"):
|
|
69
|
+
try:
|
|
70
|
+
columns = row.find_all("td")
|
|
71
|
+
|
|
72
|
+
torrents.append({
|
|
73
|
+
'type': columns[0].get_text(strip=True),
|
|
74
|
+
'name': row.find("th").find("a").get_text(strip=True),
|
|
75
|
+
'seed': columns[1].get_text(strip=True),
|
|
76
|
+
'leech': columns[2].get_text(strip=True),
|
|
77
|
+
'size': columns[3].get_text(strip=True),
|
|
78
|
+
'date': columns[4].get_text(strip=True),
|
|
79
|
+
'url': "https://ilcorsaronero.link" + row.find("th").find("a").get("href")
|
|
80
|
+
})
|
|
81
|
+
|
|
82
|
+
except Exception as e:
|
|
83
|
+
logging.error(f"Error parsing row: {e}")
|
|
84
|
+
continue
|
|
85
|
+
|
|
86
|
+
return torrents
|
|
87
|
+
|
|
88
|
+
async def fetch_real_url(self, url: str) -> Optional[str]:
|
|
89
|
+
"""
|
|
90
|
+
Fetch the real torrent URL from the detailed page.
|
|
91
|
+
"""
|
|
92
|
+
response_html = await self.fetch_url(url)
|
|
93
|
+
if not response_html:
|
|
94
|
+
return None
|
|
95
|
+
|
|
96
|
+
soup = BeautifulSoup(response_html, "html.parser")
|
|
97
|
+
links = soup.find_all("a")
|
|
98
|
+
|
|
99
|
+
# Find and return the magnet link
|
|
100
|
+
for link in links:
|
|
101
|
+
if "magnet" in str(link):
|
|
102
|
+
return link.get("href")
|
|
103
|
+
|
|
104
|
+
return None
|
|
105
|
+
|
|
106
|
+
async def search(self, query: str) -> List[Dict[str, str]]:
|
|
107
|
+
"""
|
|
108
|
+
Search for torrents based on the query string.
|
|
109
|
+
"""
|
|
110
|
+
all_torrents = []
|
|
111
|
+
|
|
112
|
+
# Loop through each page
|
|
113
|
+
for page in range(self.max_page):
|
|
114
|
+
url = f'{self.base_url}search?q={query}&page={page}'
|
|
115
|
+
|
|
116
|
+
html = await self.fetch_url(url)
|
|
117
|
+
if not html:
|
|
118
|
+
console.print(f"[bold red]No HTML content for page {page}[/bold red]")
|
|
119
|
+
break
|
|
120
|
+
|
|
121
|
+
torrents = self.parse_torrents(html)
|
|
122
|
+
if not torrents:
|
|
123
|
+
console.print(f"[bold red]No torrents found on page {page}[/bold red]")
|
|
124
|
+
break
|
|
125
|
+
|
|
126
|
+
# Use asyncio.gather to fetch all real URLs concurrently
|
|
127
|
+
tasks = [self.fetch_real_url(result['url']) for result in torrents]
|
|
128
|
+
real_urls = await asyncio.gather(*tasks)
|
|
129
|
+
|
|
130
|
+
# Attach real URLs to the torrent data
|
|
131
|
+
for i, result in enumerate(torrents):
|
|
132
|
+
result['url'] = real_urls[i]
|
|
133
|
+
|
|
134
|
+
all_torrents.extend(torrents)
|
|
135
|
+
|
|
136
|
+
return all_torrents
|
|
137
|
+
|
|
138
|
+
async def main():
|
|
139
|
+
scraper = IlCorsaroNeroScraper("https://ilcorsaronero.link/")
|
|
140
|
+
results = await scraper.search("cars")
|
|
141
|
+
|
|
142
|
+
if results:
|
|
143
|
+
for i, torrent in enumerate(results):
|
|
144
|
+
console.print(f"[bold green]{i} = {torrent}[/bold green] \n")
|
|
145
|
+
else:
|
|
146
|
+
console.print("[bold red]No torrents found.[/bold red]")
|
|
147
|
+
|
|
148
|
+
if __name__ == '__main__':
|
|
149
|
+
asyncio.run(main())
|
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
# 26.05.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 StreamingCommunity.Lib.TMBD import tmdb, Json_film
|
|
12
|
-
from .film import download_film
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Variable
|
|
16
|
-
indice = 9
|
|
17
|
-
_useFor = "film"
|
|
18
|
-
_deprecate = False
|
|
19
|
-
_priority = 2
|
|
20
|
-
_engineDownload = "hls"
|
|
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
|
-
# Not available for the moment
|
|
33
|
-
if get_onylDatabase:
|
|
34
|
-
return 0
|
|
35
|
-
|
|
36
|
-
# Search on database
|
|
37
|
-
movie_id = tmdb.search_movie(quote_plus(string_to_search))
|
|
38
|
-
|
|
39
|
-
if movie_id is not None:
|
|
40
|
-
movie_details: Json_film = tmdb.get_movie_details(tmdb_id=movie_id)
|
|
41
|
-
|
|
42
|
-
# Download only film
|
|
43
|
-
download_film(movie_details)
|
|
44
|
-
|
|
45
|
-
else:
|
|
46
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
47
|
-
|
|
48
|
-
# Retry
|
|
1
|
+
# 26.05.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 StreamingCommunity.Lib.TMBD import tmdb, Json_film
|
|
12
|
+
from .film import download_film
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
# Variable
|
|
16
|
+
indice = 9
|
|
17
|
+
_useFor = "film"
|
|
18
|
+
_deprecate = False
|
|
19
|
+
_priority = 2
|
|
20
|
+
_engineDownload = "hls"
|
|
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
|
+
# Not available for the moment
|
|
33
|
+
if get_onylDatabase:
|
|
34
|
+
return 0
|
|
35
|
+
|
|
36
|
+
# Search on database
|
|
37
|
+
movie_id = tmdb.search_movie(quote_plus(string_to_search))
|
|
38
|
+
|
|
39
|
+
if movie_id is not None:
|
|
40
|
+
movie_details: Json_film = tmdb.get_movie_details(tmdb_id=movie_id)
|
|
41
|
+
|
|
42
|
+
# Download only film
|
|
43
|
+
download_film(movie_details)
|
|
44
|
+
|
|
45
|
+
else:
|
|
46
|
+
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
47
|
+
|
|
48
|
+
# Retry
|
|
49
49
|
search()
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
# 26.05.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
SITE_NAME = os.path.basename(os.path.dirname(os.path.abspath(__file__)))
|
|
11
|
-
ROOT_PATH = config_manager.get('DEFAULT', 'root_path')
|
|
12
|
-
DOMAIN_NOW = config_manager.get_dict('SITE', SITE_NAME)['domain']
|
|
13
|
-
|
|
14
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
15
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
16
|
-
|
|
17
|
-
if config_manager.get_bool("DEFAULT", "add_siteName"):
|
|
18
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
1
|
+
# 26.05.24
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
# Internal utilities
|
|
7
|
+
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
SITE_NAME = os.path.basename(os.path.dirname(os.path.abspath(__file__)))
|
|
11
|
+
ROOT_PATH = config_manager.get('DEFAULT', 'root_path')
|
|
12
|
+
DOMAIN_NOW = config_manager.get_dict('SITE', SITE_NAME)['domain']
|
|
13
|
+
|
|
14
|
+
SERIES_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
15
|
+
MOVIE_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
16
|
+
|
|
17
|
+
if config_manager.get_bool("DEFAULT", "add_siteName"):
|
|
18
|
+
SERIES_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
19
19
|
MOVIE_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'movie_folder_name'))
|