StreamingCommunity 2.5.0__py3-none-any.whl → 2.5.2__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/__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/Helper/Vixcloud/js_parser.py +143 -0
- StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +136 -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/Player/ddl.py +89 -0
- StreamingCommunity/Api/Player/maxstream.py +151 -0
- StreamingCommunity/Api/Player/supervideo.py +194 -0
- StreamingCommunity/Api/Player/vixcloud.py +273 -0
- StreamingCommunity/Api/Site/1337xx/__init__.py +51 -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/1337xx/costant.py +15 -0
- StreamingCommunity/Api/Site/1337xx/site.py +89 -0
- StreamingCommunity/Api/Site/1337xx/title.py +64 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/__init__.py +51 -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/altadefinizionegratis/costant.py +19 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/film.py +72 -0
- StreamingCommunity/Api/Site/altadefinizionegratis/site.py +95 -0
- StreamingCommunity/Api/Site/animeunity/__init__.py +51 -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/costant.py +19 -0
- StreamingCommunity/Api/Site/animeunity/film_serie.py +135 -0
- StreamingCommunity/Api/Site/animeunity/site.py +175 -0
- StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +97 -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/__init__.py +52 -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/cb01new/costant.py +19 -0
- StreamingCommunity/Api/Site/cb01new/film.py +71 -0
- StreamingCommunity/Api/Site/cb01new/site.py +83 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +56 -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/costant.py +20 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/series.py +145 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/site.py +99 -0
- StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +85 -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/__init__.py +51 -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/costant.py +19 -0
- StreamingCommunity/Api/Site/guardaserie/series.py +198 -0
- StreamingCommunity/Api/Site/guardaserie/site.py +90 -0
- StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +110 -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/__init__.py +52 -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/costant.py +19 -0
- StreamingCommunity/Api/Site/ilcorsaronero/site.py +72 -0
- StreamingCommunity/Api/Site/ilcorsaronero/title.py +44 -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/ilcorsaronero/util/ilCorsarScraper.py +149 -0
- StreamingCommunity/Api/Site/mostraguarda/__init__.py +49 -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/mostraguarda/costant.py +19 -0
- StreamingCommunity/Api/Site/mostraguarda/film.py +101 -0
- StreamingCommunity/Api/Site/streamingcommunity/__init__.py +56 -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/costant.py +19 -0
- StreamingCommunity/Api/Site/streamingcommunity/film.py +75 -0
- StreamingCommunity/Api/Site/streamingcommunity/series.py +207 -0
- StreamingCommunity/Api/Site/streamingcommunity/site.py +143 -0
- StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +124 -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/SearchType.py +101 -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/__init__.py +5 -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/Util/get_domain.py +202 -0
- StreamingCommunity/Api/Template/Util/manage_ep.py +179 -0
- StreamingCommunity/Api/Template/Util/recall_search.py +37 -0
- StreamingCommunity/Api/Template/__init__.py +3 -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/Api/Template/site.py +87 -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/HLS/downloader.py +1008 -0
- StreamingCommunity/Lib/Downloader/HLS/proxyes.py +110 -0
- StreamingCommunity/Lib/Downloader/HLS/segments.py +573 -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/MP4/downloader.py +155 -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/TOR/downloader.py +296 -0
- StreamingCommunity/Lib/Downloader/__init__.py +5 -0
- StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-313.pyc +0 -0
- StreamingCommunity/Lib/Downloader/__pycache__/__init__.cpython-39.pyc +0 -0
- StreamingCommunity/Lib/FFmpeg/__init__.py +4 -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/FFmpeg/capture.py +170 -0
- StreamingCommunity/Lib/FFmpeg/command.py +296 -0
- StreamingCommunity/Lib/FFmpeg/util.py +249 -0
- StreamingCommunity/Lib/M3U8/__init__.py +6 -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/M3U8/decryptor.py +165 -0
- StreamingCommunity/Lib/M3U8/estimator.py +229 -0
- StreamingCommunity/Lib/M3U8/parser.py +666 -0
- StreamingCommunity/Lib/M3U8/url_fixer.py +58 -0
- StreamingCommunity/Lib/TMBD/__init__.py +2 -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/Lib/TMBD/obj_tmbd.py +39 -0
- StreamingCommunity/Lib/TMBD/tmdb.py +346 -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/Upload/update.py +67 -0
- StreamingCommunity/Upload/version.py +5 -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/Util/_jsonConfig.py +228 -0
- StreamingCommunity/Util/call_stack.py +42 -0
- StreamingCommunity/Util/color.py +20 -0
- StreamingCommunity/Util/console.py +12 -0
- StreamingCommunity/Util/ffmpeg_installer.py +371 -0
- StreamingCommunity/Util/headers.py +160 -0
- StreamingCommunity/Util/logger.py +62 -0
- StreamingCommunity/Util/message.py +64 -0
- StreamingCommunity/Util/os.py +507 -0
- StreamingCommunity/Util/table.py +229 -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.0.dist-info → StreamingCommunity-2.5.2.dist-info}/METADATA +1 -1
- StreamingCommunity-2.5.2.dist-info/RECORD +264 -0
- StreamingCommunity-2.5.0.dist-info/RECORD +0 -8
- {StreamingCommunity-2.5.0.dist-info → StreamingCommunity-2.5.2.dist-info}/LICENSE +0 -0
- {StreamingCommunity-2.5.0.dist-info → StreamingCommunity-2.5.2.dist-info}/WHEEL +0 -0
- {StreamingCommunity-2.5.0.dist-info → StreamingCommunity-2.5.2.dist-info}/entry_points.txt +0 -0
- {StreamingCommunity-2.5.0.dist-info → StreamingCommunity-2.5.2.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
# 03.04.24
|
|
2
|
+
|
|
3
|
+
import sys
|
|
4
|
+
import time
|
|
5
|
+
import logging
|
|
6
|
+
import subprocess
|
|
7
|
+
import importlib.util
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
# Internal utilities
|
|
11
|
+
from StreamingCommunity.Util.console import console
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# Check if Crypto module is installed
|
|
15
|
+
crypto_spec = importlib.util.find_spec("Cryptodome")
|
|
16
|
+
crypto_installed = crypto_spec is not None
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
if crypto_installed:
|
|
20
|
+
logging.info("[cyan]Decrypy use: Cryptodomex")
|
|
21
|
+
from Cryptodome.Cipher import AES
|
|
22
|
+
from Cryptodome.Util.Padding import unpad
|
|
23
|
+
|
|
24
|
+
class M3U8_Decryption:
|
|
25
|
+
"""
|
|
26
|
+
Class for decrypting M3U8 playlist content using AES encryption when the Crypto module is available.
|
|
27
|
+
"""
|
|
28
|
+
def __init__(self, key: bytes, iv: bytes, method: str) -> None:
|
|
29
|
+
"""
|
|
30
|
+
Initialize the M3U8_Decryption object.
|
|
31
|
+
|
|
32
|
+
Parameters:
|
|
33
|
+
- key (bytes): The encryption key.
|
|
34
|
+
- iv (bytes): The initialization vector (IV).
|
|
35
|
+
- method (str): The encryption method.
|
|
36
|
+
"""
|
|
37
|
+
self.key = key
|
|
38
|
+
self.iv = iv
|
|
39
|
+
if "0x" in str(iv):
|
|
40
|
+
self.iv = bytes.fromhex(iv.replace("0x", ""))
|
|
41
|
+
self.method = method
|
|
42
|
+
|
|
43
|
+
# Precreate cipher based on encryption method
|
|
44
|
+
if self.method == "AES":
|
|
45
|
+
self.cipher = AES.new(self.key, AES.MODE_ECB)
|
|
46
|
+
elif self.method == "AES-128":
|
|
47
|
+
self.cipher = AES.new(self.key[:16], AES.MODE_CBC, iv=self.iv)
|
|
48
|
+
elif self.method == "AES-128-CTR":
|
|
49
|
+
self.cipher = AES.new(self.key[:16], AES.MODE_CTR, nonce=self.iv)
|
|
50
|
+
else:
|
|
51
|
+
raise ValueError("Invalid or unsupported method")
|
|
52
|
+
|
|
53
|
+
def decrypt(self, ciphertext: bytes) -> bytes:
|
|
54
|
+
"""
|
|
55
|
+
Decrypt the ciphertext using the specified encryption method.
|
|
56
|
+
|
|
57
|
+
Parameters:
|
|
58
|
+
- ciphertext (bytes): The encrypted content to decrypt.
|
|
59
|
+
|
|
60
|
+
Returns:
|
|
61
|
+
bytes: The decrypted content.
|
|
62
|
+
"""
|
|
63
|
+
start = time.perf_counter_ns()
|
|
64
|
+
#logging.info(f"Ciphertext: {ciphertext}")
|
|
65
|
+
|
|
66
|
+
# Decrypt based on encryption method
|
|
67
|
+
if self.method in {"AES", "AES-128"}:
|
|
68
|
+
decrypted_data = self.cipher.decrypt(ciphertext)
|
|
69
|
+
decrypted_content = unpad(decrypted_data, AES.block_size)
|
|
70
|
+
|
|
71
|
+
elif self.method == "AES-128-CTR":
|
|
72
|
+
decrypted_content = self.cipher.decrypt(ciphertext)
|
|
73
|
+
else:
|
|
74
|
+
raise ValueError("Invalid or unsupported method")
|
|
75
|
+
|
|
76
|
+
end = time.perf_counter_ns()
|
|
77
|
+
|
|
78
|
+
# Calculate elapsed time with high precision
|
|
79
|
+
elapsed_nanoseconds = end - start
|
|
80
|
+
elapsed_milliseconds = elapsed_nanoseconds / 1_000_000
|
|
81
|
+
elapsed_seconds = elapsed_nanoseconds / 1_000_000_000
|
|
82
|
+
|
|
83
|
+
# Print performance metrics
|
|
84
|
+
logging.info(f"[Crypto Decryption Performance]")
|
|
85
|
+
logging.info(f"Method: {self.method}")
|
|
86
|
+
logging.info(f"Decryption Time: {elapsed_milliseconds:.4f} ms ({elapsed_seconds:.6f} s)")
|
|
87
|
+
logging.info(f"Decrypted Content Length: {len(decrypted_content)} bytes")
|
|
88
|
+
|
|
89
|
+
return decrypted_content
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
else:
|
|
93
|
+
|
|
94
|
+
# Check if openssl command is available
|
|
95
|
+
try:
|
|
96
|
+
openssl_available = subprocess.run(["openssl", "version"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL).returncode == 0
|
|
97
|
+
logging.info("[cyan]Decrypy use: OPENSSL")
|
|
98
|
+
except:
|
|
99
|
+
openssl_available = False
|
|
100
|
+
|
|
101
|
+
if not openssl_available:
|
|
102
|
+
console.log("[red]Neither python library: pycryptodomex nor openssl software is installed. Please install either one of them. Read readme.md [Requirement].")
|
|
103
|
+
sys.exit(0)
|
|
104
|
+
|
|
105
|
+
class M3U8_Decryption:
|
|
106
|
+
"""
|
|
107
|
+
Class for decrypting M3U8 playlist content using OpenSSL when the Crypto module is not available.
|
|
108
|
+
"""
|
|
109
|
+
def __init__(self, key: bytes, iv: bytes, method: str) -> None:
|
|
110
|
+
"""
|
|
111
|
+
Initialize the M3U8_Decryption object.
|
|
112
|
+
|
|
113
|
+
Parameters:
|
|
114
|
+
- key (bytes): The encryption key.
|
|
115
|
+
- iv (bytes): The initialization vector (IV).
|
|
116
|
+
- method (str): The encryption method.
|
|
117
|
+
"""
|
|
118
|
+
self.key = key
|
|
119
|
+
self.iv = iv
|
|
120
|
+
if "0x" in str(iv):
|
|
121
|
+
self.iv = bytes.fromhex(iv.replace("0x", ""))
|
|
122
|
+
self.method = method
|
|
123
|
+
logging.info(f"Decrypt add: ('key': {self.key}, 'iv': {self.iv}, 'method': {self.method})")
|
|
124
|
+
|
|
125
|
+
def decrypt(self, ciphertext: bytes) -> bytes:
|
|
126
|
+
"""
|
|
127
|
+
Decrypt the ciphertext using the specified encryption method.
|
|
128
|
+
|
|
129
|
+
Parameters:
|
|
130
|
+
- ciphertext (bytes): The encrypted content to decrypt.
|
|
131
|
+
|
|
132
|
+
Returns:
|
|
133
|
+
bytes: The decrypted content.
|
|
134
|
+
"""
|
|
135
|
+
start = time.perf_counter_ns()
|
|
136
|
+
|
|
137
|
+
# Construct OpenSSL command based on encryption method
|
|
138
|
+
if self.method == "AES":
|
|
139
|
+
openssl_cmd = f'openssl enc -d -aes-256-ecb -K {self.key.hex()} -nosalt'
|
|
140
|
+
elif self.method == "AES-128":
|
|
141
|
+
openssl_cmd = f'openssl enc -d -aes-128-cbc -K {self.key[:16].hex()} -iv {self.iv.hex()}'
|
|
142
|
+
elif self.method == "AES-128-CTR":
|
|
143
|
+
openssl_cmd = f'openssl enc -d -aes-128-ctr -K {self.key[:16].hex()} -iv {self.iv.hex()}'
|
|
144
|
+
else:
|
|
145
|
+
raise ValueError("Invalid or unsupported method")
|
|
146
|
+
|
|
147
|
+
try:
|
|
148
|
+
decrypted_content = subprocess.check_output(openssl_cmd.split(), input=ciphertext, stderr=subprocess.STDOUT)
|
|
149
|
+
except subprocess.CalledProcessError as e:
|
|
150
|
+
raise ValueError(f"Decryption failed: {e.output.decode()}")
|
|
151
|
+
|
|
152
|
+
end = time.perf_counter_ns()
|
|
153
|
+
|
|
154
|
+
# Calculate elapsed time with high precision
|
|
155
|
+
elapsed_nanoseconds = end - start
|
|
156
|
+
elapsed_milliseconds = elapsed_nanoseconds / 1_000_000
|
|
157
|
+
elapsed_seconds = elapsed_nanoseconds / 1_000_000_000
|
|
158
|
+
|
|
159
|
+
# Print performance metrics
|
|
160
|
+
logging.info(f"[OpenSSL Decryption Performance]")
|
|
161
|
+
logging.info(f"Method: {self.method}")
|
|
162
|
+
logging.info(f"Decryption Time: {elapsed_milliseconds:.4f} ms ({elapsed_seconds:.6f} s)")
|
|
163
|
+
logging.info(f"Decrypted Content Length: {len(decrypted_content)} bytes")
|
|
164
|
+
|
|
165
|
+
return decrypted_content
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
# 21.04.25
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
import time
|
|
5
|
+
import logging
|
|
6
|
+
import threading
|
|
7
|
+
from collections import deque
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
# External libraries
|
|
11
|
+
import psutil
|
|
12
|
+
from tqdm import tqdm
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
# Internal utilities
|
|
16
|
+
from StreamingCommunity.Util.color import Colors
|
|
17
|
+
from StreamingCommunity.Util.os import internet_manager
|
|
18
|
+
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
# Variable
|
|
22
|
+
TQDM_USE_LARGE_BAR = config_manager.get_int('M3U8_DOWNLOAD', 'tqdm_use_large_bar')
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
class M3U8_Ts_Estimator:
|
|
26
|
+
def __init__(self, total_segments: int):
|
|
27
|
+
"""
|
|
28
|
+
Initialize the M3U8_Ts_Estimator object.
|
|
29
|
+
|
|
30
|
+
Parameters:
|
|
31
|
+
- total_segments (int): Length of total segments to download.
|
|
32
|
+
"""
|
|
33
|
+
self.ts_file_sizes = []
|
|
34
|
+
self.now_downloaded_size = 0
|
|
35
|
+
self.total_segments = total_segments
|
|
36
|
+
self.lock = threading.Lock()
|
|
37
|
+
self.speed = {"upload": "N/A", "download": "N/A"}
|
|
38
|
+
self.process_pid = os.getpid() # Get current process PID
|
|
39
|
+
logging.debug(f"Initializing M3U8_Ts_Estimator with PID: {self.process_pid}")
|
|
40
|
+
|
|
41
|
+
# Start the speed capture thread if TQDM_USE_LARGE_BAR is True
|
|
42
|
+
if TQDM_USE_LARGE_BAR:
|
|
43
|
+
logging.debug("TQDM_USE_LARGE_BAR is True, starting speed capture thread")
|
|
44
|
+
self.speed_thread = threading.Thread(target=self.capture_speed, args=(1, self.process_pid))
|
|
45
|
+
self.speed_thread.daemon = True
|
|
46
|
+
self.speed_thread.start()
|
|
47
|
+
|
|
48
|
+
else:
|
|
49
|
+
logging.debug("TQDM_USE_LARGE_BAR is False, speed capture thread not started")
|
|
50
|
+
|
|
51
|
+
def add_ts_file(self, size: int, size_download: int, duration: float):
|
|
52
|
+
"""Add a file size to the list of file sizes."""
|
|
53
|
+
logging.debug(f"Adding ts file - size: {size}, download size: {size_download}, duration: {duration}")
|
|
54
|
+
|
|
55
|
+
if size <= 0 or size_download <= 0 or duration <= 0:
|
|
56
|
+
logging.error(f"Invalid input values: size={size}, size_download={size_download}, duration={duration}")
|
|
57
|
+
return
|
|
58
|
+
|
|
59
|
+
self.ts_file_sizes.append(size)
|
|
60
|
+
self.now_downloaded_size += size_download
|
|
61
|
+
logging.debug(f"Current total downloaded size: {self.now_downloaded_size}")
|
|
62
|
+
|
|
63
|
+
def capture_speed(self, interval: float = 1, pid: int = None):
|
|
64
|
+
"""Capture the internet speed periodically."""
|
|
65
|
+
logging.debug(f"Starting speed capture with interval {interval}s for PID: {pid}")
|
|
66
|
+
|
|
67
|
+
def get_network_io(process=None):
|
|
68
|
+
try:
|
|
69
|
+
if process:
|
|
70
|
+
|
|
71
|
+
# For process-specific monitoring
|
|
72
|
+
connections = process.connections(kind='inet')
|
|
73
|
+
if connections:
|
|
74
|
+
io_counters = process.io_counters()
|
|
75
|
+
logging.debug(f"Process IO counters: {io_counters}")
|
|
76
|
+
return io_counters
|
|
77
|
+
|
|
78
|
+
else:
|
|
79
|
+
logging.debug("No active internet connections found for process")
|
|
80
|
+
return None
|
|
81
|
+
else:
|
|
82
|
+
|
|
83
|
+
# For system-wide monitoring
|
|
84
|
+
io_counters = psutil.net_io_counters()
|
|
85
|
+
logging.debug(f"System IO counters: {io_counters}")
|
|
86
|
+
return io_counters
|
|
87
|
+
|
|
88
|
+
except Exception as e:
|
|
89
|
+
logging.error(f"Error getting network IO: {str(e)}")
|
|
90
|
+
return None
|
|
91
|
+
|
|
92
|
+
try:
|
|
93
|
+
process = psutil.Process(pid) if pid else None
|
|
94
|
+
logging.debug(f"Monitoring process: {process}")
|
|
95
|
+
|
|
96
|
+
except Exception as e:
|
|
97
|
+
logging.error(f"Failed to get process with PID {pid}: {str(e)}")
|
|
98
|
+
process = None
|
|
99
|
+
|
|
100
|
+
last_upload = None
|
|
101
|
+
last_download = None
|
|
102
|
+
first_run = True
|
|
103
|
+
|
|
104
|
+
# Buffer circolare per le ultime N misurazioni
|
|
105
|
+
speed_buffer_size = 3
|
|
106
|
+
speed_buffer = deque(maxlen=speed_buffer_size)
|
|
107
|
+
|
|
108
|
+
while True:
|
|
109
|
+
try:
|
|
110
|
+
io_counters = get_network_io()
|
|
111
|
+
|
|
112
|
+
if io_counters:
|
|
113
|
+
current_upload = io_counters.bytes_sent
|
|
114
|
+
current_download = io_counters.bytes_recv
|
|
115
|
+
|
|
116
|
+
if not first_run and last_upload is not None and last_download is not None:
|
|
117
|
+
|
|
118
|
+
# Calcola la velocità istantanea
|
|
119
|
+
upload_speed = max(0, (current_upload - last_upload) / interval)
|
|
120
|
+
download_speed = max(0, (current_download - last_download) / interval)
|
|
121
|
+
|
|
122
|
+
# Aggiungi al buffer
|
|
123
|
+
speed_buffer.append(download_speed)
|
|
124
|
+
|
|
125
|
+
# Calcola la media mobile delle velocità
|
|
126
|
+
if len(speed_buffer) > 0:
|
|
127
|
+
avg_download_speed = sum(speed_buffer) / len(speed_buffer)
|
|
128
|
+
|
|
129
|
+
if avg_download_speed > 0:
|
|
130
|
+
with self.lock:
|
|
131
|
+
self.speed = {
|
|
132
|
+
"upload": internet_manager.format_transfer_speed(upload_speed),
|
|
133
|
+
"download": internet_manager.format_transfer_speed(avg_download_speed)
|
|
134
|
+
}
|
|
135
|
+
logging.debug(f"Updated speeds - Upload: {self.speed['upload']}, Download: {self.speed['download']}")
|
|
136
|
+
|
|
137
|
+
last_upload = current_upload
|
|
138
|
+
last_download = current_download
|
|
139
|
+
first_run = False
|
|
140
|
+
|
|
141
|
+
time.sleep(interval)
|
|
142
|
+
except Exception as e:
|
|
143
|
+
logging.error(f"Error in speed capture loop: {str(e)}")
|
|
144
|
+
logging.exception("Full traceback:")
|
|
145
|
+
logging.sleep(interval)
|
|
146
|
+
|
|
147
|
+
def get_average_speed(self) -> list:
|
|
148
|
+
"""Calculate the average internet speed."""
|
|
149
|
+
with self.lock:
|
|
150
|
+
logging.debug(f"Current speed data: {self.speed}")
|
|
151
|
+
return self.speed['download'].split(" ")
|
|
152
|
+
|
|
153
|
+
def calculate_total_size(self) -> str:
|
|
154
|
+
"""
|
|
155
|
+
Calculate the total size of the files.
|
|
156
|
+
|
|
157
|
+
Returns:
|
|
158
|
+
str: The mean size of the files in a human-readable format.
|
|
159
|
+
"""
|
|
160
|
+
try:
|
|
161
|
+
if len(self.ts_file_sizes) == 0:
|
|
162
|
+
raise ValueError("No file sizes available to calculate total size.")
|
|
163
|
+
|
|
164
|
+
total_size = sum(self.ts_file_sizes)
|
|
165
|
+
mean_size = total_size / len(self.ts_file_sizes)
|
|
166
|
+
|
|
167
|
+
# Return formatted mean size
|
|
168
|
+
return internet_manager.format_file_size(mean_size)
|
|
169
|
+
|
|
170
|
+
except ZeroDivisionError as e:
|
|
171
|
+
logging.error("Division by zero error occurred: %s", e)
|
|
172
|
+
return "0B"
|
|
173
|
+
|
|
174
|
+
except Exception as e:
|
|
175
|
+
logging.error("An unexpected error occurred: %s", e)
|
|
176
|
+
return "Error"
|
|
177
|
+
|
|
178
|
+
def get_downloaded_size(self) -> str:
|
|
179
|
+
"""
|
|
180
|
+
Get the total downloaded size formatted as a human-readable string.
|
|
181
|
+
|
|
182
|
+
Returns:
|
|
183
|
+
str: The total downloaded size as a human-readable string.
|
|
184
|
+
"""
|
|
185
|
+
return internet_manager.format_file_size(self.now_downloaded_size)
|
|
186
|
+
|
|
187
|
+
def update_progress_bar(self, total_downloaded: int, duration: float, progress_counter: tqdm) -> None:
|
|
188
|
+
"""Updates the progress bar with download information."""
|
|
189
|
+
try:
|
|
190
|
+
self.add_ts_file(total_downloaded * self.total_segments, total_downloaded, duration)
|
|
191
|
+
|
|
192
|
+
downloaded_file_size_str = self.get_downloaded_size()
|
|
193
|
+
file_total_size = self.calculate_total_size()
|
|
194
|
+
|
|
195
|
+
number_file_downloaded = downloaded_file_size_str.split(' ')[0]
|
|
196
|
+
number_file_total_size = file_total_size.split(' ')[0]
|
|
197
|
+
units_file_downloaded = downloaded_file_size_str.split(' ')[1]
|
|
198
|
+
units_file_total_size = file_total_size.split(' ')[1]
|
|
199
|
+
|
|
200
|
+
if TQDM_USE_LARGE_BAR:
|
|
201
|
+
speed_data = self.get_average_speed()
|
|
202
|
+
#logging.debug(f"Speed data for progress bar: {speed_data}")
|
|
203
|
+
|
|
204
|
+
if len(speed_data) >= 2:
|
|
205
|
+
average_internet_speed = speed_data[0]
|
|
206
|
+
average_internet_unit = speed_data[1]
|
|
207
|
+
|
|
208
|
+
else:
|
|
209
|
+
logging.warning(f"Invalid speed data format: {speed_data}")
|
|
210
|
+
average_internet_speed = "N/A"
|
|
211
|
+
average_internet_unit = ""
|
|
212
|
+
|
|
213
|
+
progress_str = (
|
|
214
|
+
f"{Colors.WHITE}[ {Colors.GREEN}{number_file_downloaded} {Colors.WHITE}< "
|
|
215
|
+
f"{Colors.GREEN}{number_file_total_size} {Colors.RED}{units_file_total_size} "
|
|
216
|
+
f"{Colors.WHITE}| {Colors.CYAN}{average_internet_speed} {Colors.RED}{average_internet_unit}"
|
|
217
|
+
)
|
|
218
|
+
|
|
219
|
+
else:
|
|
220
|
+
progress_str = (
|
|
221
|
+
f"{Colors.WHITE}[ {Colors.GREEN}{number_file_downloaded} {Colors.WHITE}< "
|
|
222
|
+
f"{Colors.GREEN}{number_file_total_size} {Colors.RED}{units_file_total_size}"
|
|
223
|
+
)
|
|
224
|
+
|
|
225
|
+
progress_counter.set_postfix_str(progress_str)
|
|
226
|
+
#logging.debug(f"Updated progress bar: {progress_str}")
|
|
227
|
+
|
|
228
|
+
except Exception as e:
|
|
229
|
+
logging.error(f"Error updating progress bar: {str(e)}")
|