StreamingCommunity 2.3.0__py3-none-any.whl → 2.5.0__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 (92) hide show
  1. StreamingCommunity/run.py +61 -7
  2. {StreamingCommunity-2.3.0.dist-info → StreamingCommunity-2.5.0.dist-info}/METADATA +88 -18
  3. StreamingCommunity-2.5.0.dist-info/RECORD +8 -0
  4. StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
  5. StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +0 -136
  6. StreamingCommunity/Api/Player/ddl.py +0 -89
  7. StreamingCommunity/Api/Player/maxstream.py +0 -151
  8. StreamingCommunity/Api/Player/supervideo.py +0 -194
  9. StreamingCommunity/Api/Player/vixcloud.py +0 -273
  10. StreamingCommunity/Api/Site/1337xx/__init__.py +0 -51
  11. StreamingCommunity/Api/Site/1337xx/costant.py +0 -15
  12. StreamingCommunity/Api/Site/1337xx/site.py +0 -89
  13. StreamingCommunity/Api/Site/1337xx/title.py +0 -66
  14. StreamingCommunity/Api/Site/altadefinizione/__init__.py +0 -51
  15. StreamingCommunity/Api/Site/altadefinizione/costant.py +0 -19
  16. StreamingCommunity/Api/Site/altadefinizione/film.py +0 -74
  17. StreamingCommunity/Api/Site/altadefinizione/site.py +0 -95
  18. StreamingCommunity/Api/Site/animeunity/__init__.py +0 -51
  19. StreamingCommunity/Api/Site/animeunity/costant.py +0 -19
  20. StreamingCommunity/Api/Site/animeunity/film_serie.py +0 -135
  21. StreamingCommunity/Api/Site/animeunity/site.py +0 -175
  22. StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
  23. StreamingCommunity/Api/Site/cb01new/__init__.py +0 -52
  24. StreamingCommunity/Api/Site/cb01new/costant.py +0 -19
  25. StreamingCommunity/Api/Site/cb01new/film.py +0 -73
  26. StreamingCommunity/Api/Site/cb01new/site.py +0 -83
  27. StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +0 -56
  28. StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +0 -20
  29. StreamingCommunity/Api/Site/ddlstreamitaly/series.py +0 -146
  30. StreamingCommunity/Api/Site/ddlstreamitaly/site.py +0 -99
  31. StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -85
  32. StreamingCommunity/Api/Site/guardaserie/__init__.py +0 -51
  33. StreamingCommunity/Api/Site/guardaserie/costant.py +0 -19
  34. StreamingCommunity/Api/Site/guardaserie/series.py +0 -198
  35. StreamingCommunity/Api/Site/guardaserie/site.py +0 -90
  36. StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
  37. StreamingCommunity/Api/Site/ilcorsaronero/__init__.py +0 -52
  38. StreamingCommunity/Api/Site/ilcorsaronero/costant.py +0 -19
  39. StreamingCommunity/Api/Site/ilcorsaronero/site.py +0 -72
  40. StreamingCommunity/Api/Site/ilcorsaronero/title.py +0 -46
  41. StreamingCommunity/Api/Site/ilcorsaronero/util/ilCorsarScraper.py +0 -149
  42. StreamingCommunity/Api/Site/mostraguarda/__init__.py +0 -49
  43. StreamingCommunity/Api/Site/mostraguarda/costant.py +0 -19
  44. StreamingCommunity/Api/Site/mostraguarda/film.py +0 -101
  45. StreamingCommunity/Api/Site/streamingcommunity/__init__.py +0 -56
  46. StreamingCommunity/Api/Site/streamingcommunity/costant.py +0 -19
  47. StreamingCommunity/Api/Site/streamingcommunity/film.py +0 -75
  48. StreamingCommunity/Api/Site/streamingcommunity/series.py +0 -206
  49. StreamingCommunity/Api/Site/streamingcommunity/site.py +0 -139
  50. StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -123
  51. StreamingCommunity/Api/Template/Class/SearchType.py +0 -101
  52. StreamingCommunity/Api/Template/Util/__init__.py +0 -5
  53. StreamingCommunity/Api/Template/Util/get_domain.py +0 -137
  54. StreamingCommunity/Api/Template/Util/manage_ep.py +0 -179
  55. StreamingCommunity/Api/Template/Util/recall_search.py +0 -37
  56. StreamingCommunity/Api/Template/__init__.py +0 -3
  57. StreamingCommunity/Api/Template/site.py +0 -87
  58. StreamingCommunity/Lib/Downloader/HLS/downloader.py +0 -955
  59. StreamingCommunity/Lib/Downloader/HLS/proxyes.py +0 -110
  60. StreamingCommunity/Lib/Downloader/HLS/segments.py +0 -564
  61. StreamingCommunity/Lib/Downloader/MP4/downloader.py +0 -155
  62. StreamingCommunity/Lib/Downloader/TOR/downloader.py +0 -296
  63. StreamingCommunity/Lib/Downloader/__init__.py +0 -5
  64. StreamingCommunity/Lib/FFmpeg/__init__.py +0 -4
  65. StreamingCommunity/Lib/FFmpeg/capture.py +0 -170
  66. StreamingCommunity/Lib/FFmpeg/command.py +0 -296
  67. StreamingCommunity/Lib/FFmpeg/util.py +0 -249
  68. StreamingCommunity/Lib/M3U8/__init__.py +0 -6
  69. StreamingCommunity/Lib/M3U8/decryptor.py +0 -164
  70. StreamingCommunity/Lib/M3U8/estimator.py +0 -229
  71. StreamingCommunity/Lib/M3U8/parser.py +0 -666
  72. StreamingCommunity/Lib/M3U8/url_fixer.py +0 -52
  73. StreamingCommunity/Lib/TMBD/__init__.py +0 -2
  74. StreamingCommunity/Lib/TMBD/obj_tmbd.py +0 -39
  75. StreamingCommunity/Lib/TMBD/tmdb.py +0 -346
  76. StreamingCommunity/Upload/update.py +0 -67
  77. StreamingCommunity/Upload/version.py +0 -5
  78. StreamingCommunity/Util/_jsonConfig.py +0 -204
  79. StreamingCommunity/Util/call_stack.py +0 -42
  80. StreamingCommunity/Util/color.py +0 -20
  81. StreamingCommunity/Util/console.py +0 -12
  82. StreamingCommunity/Util/ffmpeg_installer.py +0 -351
  83. StreamingCommunity/Util/headers.py +0 -147
  84. StreamingCommunity/Util/logger.py +0 -53
  85. StreamingCommunity/Util/message.py +0 -64
  86. StreamingCommunity/Util/os.py +0 -545
  87. StreamingCommunity/Util/table.py +0 -229
  88. StreamingCommunity-2.3.0.dist-info/RECORD +0 -92
  89. {StreamingCommunity-2.3.0.dist-info → StreamingCommunity-2.5.0.dist-info}/LICENSE +0 -0
  90. {StreamingCommunity-2.3.0.dist-info → StreamingCommunity-2.5.0.dist-info}/WHEEL +0 -0
  91. {StreamingCommunity-2.3.0.dist-info → StreamingCommunity-2.5.0.dist-info}/entry_points.txt +0 -0
  92. {StreamingCommunity-2.3.0.dist-info → StreamingCommunity-2.5.0.dist-info}/top_level.txt +0 -0
@@ -1,19 +0,0 @@
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
- MOVIE_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'movie_folder_name'))
@@ -1,75 +0,0 @@
1
- # 3.12.23
2
-
3
- import os
4
- import time
5
-
6
-
7
- # Internal utilities
8
- from StreamingCommunity.Util.console import console, msg
9
- from StreamingCommunity.Util.os import os_manager
10
- from StreamingCommunity.Util.message import start_message
11
- from StreamingCommunity.Util.call_stack import get_call_stack
12
- from StreamingCommunity.Lib.Downloader import HLS_Downloader
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Api.Template.Util import execute_search
17
- from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
18
-
19
-
20
- # Player
21
- from StreamingCommunity.Api.Player.vixcloud import VideoSource
22
-
23
-
24
- # Variable
25
- from .costant import SITE_NAME, MOVIE_FOLDER
26
-
27
-
28
- def download_film(select_title: MediaItem) -> str:
29
- """
30
- Downloads a film using the provided film ID, title name, and domain.
31
-
32
- Parameters:
33
- - domain (str): The domain of the site
34
- - version (str): Version of site.
35
-
36
- Return:
37
- - str: output path
38
- """
39
-
40
- # Start message and display film information
41
- start_message()
42
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
43
-
44
- # Init class
45
- video_source = VideoSource(SITE_NAME, False)
46
- video_source.setup(select_title.id)
47
-
48
- # Retrieve scws and if available master playlist
49
- video_source.get_iframe(select_title.id)
50
- video_source.get_content()
51
- master_playlist = video_source.get_playlist()
52
-
53
- # Define the filename and path for the downloaded film
54
- title_name = os_manager.get_sanitize_file(select_title.name) + ".mp4"
55
- mp4_path = os.path.join(MOVIE_FOLDER, select_title.name)
56
-
57
- # Download the film using the m3u8 playlist, and output filename
58
- r_proc = HLS_Downloader(
59
- m3u8_playlist=master_playlist,
60
- output_filename=os.path.join(mp4_path, title_name)
61
- ).start()
62
-
63
- """if r_proc == 404:
64
- time.sleep(2)
65
-
66
- # Re call search function
67
- if msg.ask("[green]Do you want to continue [white]([red]y[white])[green] or return at home[white]([red]n[white]) ", choices=['y', 'n'], default='y', show_choices=True) == "n":
68
- frames = get_call_stack()
69
- execute_search(frames[-4])"""
70
-
71
- if r_proc != None:
72
- console.print("[green]Result: ")
73
- console.print(r_proc)
74
-
75
- return os.path.join(mp4_path, title_name)
@@ -1,206 +0,0 @@
1
- # 3.12.23
2
-
3
- import os
4
- import sys
5
- import time
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Util.console import console, msg
10
- from StreamingCommunity.Util.message import start_message
11
- from StreamingCommunity.Util.call_stack import get_call_stack
12
- from StreamingCommunity.Util.table import TVShowManager
13
- from StreamingCommunity.Lib.Downloader import HLS_Downloader
14
-
15
-
16
- # Logic class
17
- from .util.ScrapeSerie import ScrapeSerie
18
- from StreamingCommunity.Api.Template.Util import manage_selection, map_episode_title, validate_selection, validate_episode_selection, execute_search
19
- from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
20
-
21
-
22
- # Player
23
- from StreamingCommunity.Api.Player.vixcloud import VideoSource
24
-
25
-
26
- # Variable
27
- from .costant import SITE_NAME, SERIES_FOLDER
28
-
29
-
30
-
31
- def download_video(index_season_selected: int, index_episode_selected: int, scrape_serie: ScrapeSerie, video_source: VideoSource) -> str:
32
- """
33
- Download a single episode video.
34
-
35
- Parameters:
36
- - index_season_selected (int): Index of the selected season.
37
- - index_episode_selected (int): Index of the selected episode.
38
-
39
- Return:
40
- - str: output path
41
- """
42
- start_message()
43
-
44
- # Get info about episode
45
- obj_episode = scrape_serie.episode_manager.get(index_episode_selected - 1)
46
- console.print(f"[yellow]Download: [red]{index_season_selected}:{index_episode_selected} {obj_episode.name}")
47
- print()
48
-
49
- # Define filename and path for the downloaded video
50
- mp4_name = f"{map_episode_title(scrape_serie.series_name, index_season_selected, index_episode_selected, obj_episode.name)}.mp4"
51
- mp4_path = os.path.join(SERIES_FOLDER, scrape_serie.series_name, f"S{index_season_selected}")
52
-
53
- # Retrieve scws and if available master playlist
54
- video_source.get_iframe(obj_episode.id)
55
- video_source.get_content()
56
- master_playlist = video_source.get_playlist()
57
-
58
- # Download the episode
59
- r_proc = HLS_Downloader(
60
- m3u8_playlist=master_playlist,
61
- output_filename=os.path.join(mp4_path, mp4_name)
62
- ).start()
63
-
64
- """if r_proc == 404:
65
- time.sleep(2)
66
-
67
- # Re call search function
68
- if msg.ask("[green]Do you want to continue [white]([red]y[white])[green] or return at home[white]([red]n[white]) ", choices=['y', 'n'], default='y', show_choices=True) == "n":
69
- frames = get_call_stack()
70
- execute_search(frames[-4])"""
71
-
72
- if r_proc != None:
73
- console.print("[green]Result: ")
74
- console.print(r_proc)
75
-
76
- return os.path.join(mp4_path, mp4_name)
77
-
78
- def download_episode(index_season_selected: int, scrape_serie: ScrapeSerie, video_source: VideoSource, download_all: bool = False) -> None:
79
- """
80
- Download episodes of a selected season.
81
-
82
- Parameters:
83
- - index_season_selected (int): Index of the selected season.
84
- - download_all (bool): Download all episodes in the season.
85
- """
86
-
87
- # Clean memory of all episodes and get the number of the season
88
- scrape_serie.episode_manager.clear()
89
-
90
- # Start message and collect information about episodes
91
- start_message()
92
- scrape_serie.collect_info_season(index_season_selected)
93
- episodes_count = scrape_serie.episode_manager.length()
94
-
95
- if download_all:
96
-
97
- # Download all episodes without asking
98
- for i_episode in range(1, episodes_count + 1):
99
- download_video(index_season_selected, i_episode, scrape_serie, video_source)
100
- console.print(f"\n[red]End downloaded [yellow]season: [red]{index_season_selected}.")
101
-
102
- else:
103
-
104
- # Display episodes list and manage user selection
105
- last_command = display_episodes_list(scrape_serie)
106
- list_episode_select = manage_selection(last_command, episodes_count)
107
-
108
- try:
109
- list_episode_select = validate_episode_selection(list_episode_select, episodes_count)
110
- except ValueError as e:
111
- console.print(f"[red]{str(e)}")
112
- return
113
-
114
- # Download selected episodes
115
- for i_episode in list_episode_select:
116
- download_video(index_season_selected, i_episode, scrape_serie, video_source)
117
-
118
- def download_series(select_season: MediaItem, version: str) -> None:
119
- """
120
- Download episodes of a TV series based on user selection.
121
-
122
- Parameters:
123
- - select_season (MediaItem): Selected media item (TV series).
124
- - domain (str): Domain from which to download.
125
- - version (str): Version of the site.
126
- """
127
-
128
- # Start message and set up video source
129
- start_message()
130
-
131
- # Init class
132
- scrape_serie = ScrapeSerie(SITE_NAME)
133
- video_source = VideoSource(SITE_NAME, True)
134
-
135
- # Setup video source
136
- scrape_serie.setup(version, select_season.id, select_season.slug)
137
- video_source.setup(select_season.id)
138
-
139
- # Collect information about seasons
140
- scrape_serie.collect_info_title()
141
- seasons_count = scrape_serie.season_manager.seasons_count
142
-
143
- # Prompt user for season selection and download episodes
144
- console.print(f"\n[green]Seasons found: [red]{seasons_count}")
145
- index_season_selected = msg.ask(
146
- "\n[cyan]Insert season number [yellow](e.g., 1), [red]* [cyan]to download all seasons, "
147
- "[yellow](e.g., 1-2) [cyan]for a range of seasons, or [yellow](e.g., 3-*) [cyan]to download from a specific season to the end"
148
- )
149
-
150
- # Manage and validate the selection
151
- list_season_select = manage_selection(index_season_selected, seasons_count)
152
-
153
- try:
154
- list_season_select = validate_selection(list_season_select, seasons_count)
155
- except ValueError as e:
156
- console.print(f"[red]{str(e)}")
157
- return
158
-
159
- # Loop through the selected seasons and download episodes
160
- for i_season in list_season_select:
161
- if len(list_season_select) > 1 or index_season_selected == "*":
162
-
163
- # Download all episodes if multiple seasons are selected or if '*' is used
164
- download_episode(i_season, scrape_serie, video_source, download_all=True)
165
- else:
166
-
167
- # Otherwise, let the user select specific episodes for the single season
168
- download_episode(i_season, scrape_serie, video_source, download_all=False)
169
-
170
-
171
- def display_episodes_list(scrape_serie) -> str:
172
- """
173
- Display episodes list and handle user input.
174
-
175
- Returns:
176
- last_command (str): Last command entered by the user.
177
- """
178
-
179
- # Set up table for displaying episodes
180
- table_show_manager = TVShowManager()
181
- table_show_manager.set_slice_end(10)
182
-
183
- # Add columns to the table
184
- column_info = {
185
- "Index": {'color': 'red'},
186
- "Name": {'color': 'magenta'},
187
- "Duration": {'color': 'green'}
188
- }
189
- table_show_manager.add_column(column_info)
190
-
191
- # Populate the table with episodes information
192
- for i, media in enumerate(scrape_serie.episode_manager.episodes):
193
- table_show_manager.add_tv_show({
194
- 'Index': str(media.number),
195
- 'Name': media.name,
196
- 'Duration': str(media.duration)
197
- })
198
-
199
- # Run the table and handle user input
200
- last_command = table_show_manager.run()
201
-
202
- if last_command == "q":
203
- console.print("\n[red]Quit [white]...")
204
- sys.exit(0)
205
-
206
- return last_command
@@ -1,139 +0,0 @@
1
- # 10.12.23
2
-
3
- import sys
4
- import json
5
- import logging
6
- import secrets
7
-
8
-
9
- # External libraries
10
- import httpx
11
- from bs4 import BeautifulSoup
12
-
13
-
14
- # Internal utilities
15
- from StreamingCommunity.Util.console import console
16
- from StreamingCommunity.Util._jsonConfig import config_manager
17
- from StreamingCommunity.Util.headers import get_headers
18
- from StreamingCommunity.Util.table import TVShowManager
19
-
20
-
21
-
22
- # Logic class
23
- from StreamingCommunity.Api.Template import get_select_title
24
- from StreamingCommunity.Api.Template.Util import search_domain
25
- from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
26
-
27
-
28
- # Config
29
- from .costant import SITE_NAME, DOMAIN_NOW
30
-
31
-
32
- # Variable
33
- media_search_manager = MediaManager()
34
- table_show_manager = TVShowManager()
35
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
36
- disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
37
-
38
-
39
- def get_version(domain: str):
40
- """
41
- Extracts the version from the HTML text of a webpage.
42
-
43
- Parameters:
44
- - domain (str): The domain of the site.
45
-
46
- Returns:
47
- str: The version extracted from the webpage.
48
- """
49
- try:
50
- response = httpx.get(
51
- url=f"https://{SITE_NAME}.{domain}/",
52
- headers={'User-Agent': get_headers()},
53
- timeout=max_timeout
54
- )
55
- response.raise_for_status()
56
-
57
- # Parse request to site
58
- soup = BeautifulSoup(response.text, "html.parser")
59
-
60
- # Extract version
61
- version = json.loads(soup.find("div", {"id": "app"}).get("data-page"))['version']
62
- console.print(f"[cyan]Get version [white]=> [red]{version} \n")
63
-
64
- return version
65
-
66
- except Exception as e:
67
- logging.error(f"Error extracting version: {e}")
68
- raise
69
-
70
-
71
- def get_version_and_domain():
72
- """
73
- Retrieve the current version and domain of the site.
74
-
75
- This function performs the following steps:
76
- - Determines the correct domain to use for the site by searching for a specific meta tag.
77
- - Fetches the content of the site to extract the version information.
78
- """
79
-
80
- # Find new domain if prev dont work
81
- domain_to_use = DOMAIN_NOW
82
-
83
- if not disable_searchDomain:
84
- domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}")
85
-
86
- version = get_version(domain_to_use)
87
-
88
- return version, domain_to_use
89
-
90
-
91
- def title_search(title_search: str, domain: str) -> int:
92
- """
93
- Search for titles based on a search query.
94
-
95
- Parameters:
96
- - title_search (str): The title to search for.
97
- - domain (str): The domain to search on.
98
-
99
- Returns:
100
- int: The number of titles found.
101
- """
102
- media_search_manager.clear()
103
- table_show_manager.clear()
104
-
105
- try:
106
- response = httpx.get(
107
- url=f"https://{SITE_NAME}.{domain}/api/search?q={title_search.replace(' ', '+')}",
108
- headers={'user-agent': get_headers()},
109
- timeout=max_timeout
110
- )
111
- response.raise_for_status()
112
-
113
- except Exception as e:
114
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
115
-
116
- for dict_title in response.json()['data']:
117
- try:
118
-
119
- media_search_manager.add_media({
120
- 'id': dict_title.get('id'),
121
- 'slug': dict_title.get('slug'),
122
- 'name': dict_title.get('name'),
123
- 'type': dict_title.get('type'),
124
- 'date': dict_title.get('last_air_date'),
125
- 'score': dict_title.get('score')
126
- })
127
-
128
- except Exception as e:
129
- print(f"Error parsing a film entry: {e}")
130
-
131
- # Return the number of titles found
132
- return media_search_manager.get_length()
133
-
134
-
135
- def run_get_select_title():
136
- """
137
- Display a selection of titles and prompt the user to choose one.
138
- """
139
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,123 +0,0 @@
1
- # 01.03.24
2
-
3
- import json
4
- import logging
5
-
6
-
7
- # External libraries
8
- import httpx
9
- from bs4 import BeautifulSoup
10
-
11
-
12
- # Internal utilities
13
- from StreamingCommunity.Util.headers import get_headers
14
- from StreamingCommunity.Util._jsonConfig import config_manager
15
- from StreamingCommunity.Api.Player.Helper.Vixcloud.util import Season, EpisodeManager
16
-
17
-
18
- # Variable
19
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
20
-
21
-
22
- class ScrapeSerie:
23
- def __init__(self, site_name: str):
24
- """
25
- Initialize the ScrapeSerie class for scraping TV series information.
26
-
27
- Args:
28
- site_name (str): Name of the streaming site to scrape from
29
- """
30
- self.is_series = False
31
- self.headers = {'user-agent': get_headers()}
32
- self.base_name = site_name
33
- self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
34
-
35
- def setup(self, version: str = None, media_id: int = None, series_name: str = None):
36
- """
37
- Set up the scraper with specific media details.
38
-
39
- Args:
40
- version (str, optional): Site version for request headers
41
- media_id (int, optional): Unique identifier for the media
42
- series_name (str, optional): Name of the TV series
43
- """
44
- self.version = version
45
- self.media_id = media_id
46
-
47
- # If series name is provided, initialize series-specific managers
48
- if series_name is not None:
49
- self.is_series = True
50
- self.series_name = series_name
51
- self.season_manager = None
52
- self.episode_manager: EpisodeManager = EpisodeManager()
53
-
54
- def collect_info_title(self) -> None:
55
- """
56
- Retrieve season information for a TV series from the streaming site.
57
-
58
- Raises:
59
- Exception: If there's an error fetching season information
60
- """
61
- try:
62
- response = httpx.get(
63
- url=f"https://{self.base_name}.{self.domain}/titles/{self.media_id}-{self.series_name}",
64
- headers=self.headers,
65
- timeout=max_timeout
66
- )
67
- response.raise_for_status()
68
-
69
- # Extract seasons from JSON response
70
- soup = BeautifulSoup(response.text, "html.parser")
71
- json_response = json.loads(soup.find("div", {"id": "app"}).get("data-page"))
72
-
73
- """
74
- response = httpx.post(
75
- url=f'https://{self.base_name}.{self.domain}/api/titles/preview/{self.media_id}',
76
- headers={'User-Agent': get_headers()}
77
- )
78
- response.raise_for_status()
79
-
80
-
81
- # Extract seasons from JSON response
82
- json_response = response.json()
83
- """
84
-
85
- # Collect info about season
86
- self.season_manager = Season(json_response.get("props").get("title"))
87
-
88
- except Exception as e:
89
- logging.error(f"Error collecting season info: {e}")
90
- raise
91
-
92
- def collect_info_season(self, number_season: int) -> None:
93
- """
94
- Retrieve episode information for a specific season.
95
-
96
- Args:
97
- number_season (int): Season number to fetch episodes for
98
-
99
- Raises:
100
- Exception: If there's an error fetching episode information
101
- """
102
- try:
103
- response = httpx.get(
104
- url=f'https://{self.base_name}.{self.domain}/titles/{self.media_id}-{self.series_name}/stagione-{number_season}',
105
- headers={
106
- 'User-Agent': get_headers(),
107
- 'x-inertia': 'true',
108
- 'x-inertia-version': self.version,
109
- },
110
- timeout=max_timeout
111
- )
112
- response.raise_for_status()
113
-
114
- # Extract episodes from JSON response
115
- json_response = response.json().get('props').get('loadedSeason').get('episodes')
116
-
117
- # Add each episode to the episode manager
118
- for dict_episode in json_response:
119
- self.episode_manager.add(dict_episode)
120
-
121
- except Exception as e:
122
- logging.error(f"Error collecting title season info: {e}")
123
- raise
@@ -1,101 +0,0 @@
1
- # 07.07.24
2
-
3
- from typing import List, TypedDict
4
-
5
-
6
- class MediaItemData(TypedDict, total=False):
7
- id: int # GENERAL
8
- name: str # GENERAL
9
- type: str # GENERAL
10
- url: str # GENERAL
11
- size: str # GENERAL
12
- score: str # GENERAL
13
- date: str # GENERAL
14
- desc: str # GENERAL
15
-
16
- seeder: int # TOR
17
- leecher: int # TOR
18
-
19
- slug: str # SC
20
-
21
-
22
-
23
- class MediaItemMeta(type):
24
- def __new__(cls, name, bases, dct):
25
- def init(self, **kwargs):
26
- for key, value in kwargs.items():
27
- setattr(self, key, value)
28
-
29
- dct['__init__'] = init
30
-
31
- def get_attr(self, item):
32
- return self.__dict__.get(item, None)
33
-
34
- dct['__getattr__'] = get_attr
35
-
36
- def set_attr(self, key, value):
37
- self.__dict__[key] = value
38
-
39
- dct['__setattr__'] = set_attr
40
-
41
- return super().__new__(cls, name, bases, dct)
42
-
43
-
44
- class MediaItem(metaclass=MediaItemMeta):
45
- id: int # GENERAL
46
- name: str # GENERAL
47
- type: str # GENERAL
48
- url: str # GENERAL
49
- size: str # GENERAL
50
- score: str # GENERAL
51
- date: str # GENERAL
52
- desc: str # GENERAL
53
-
54
- seeder: int # TOR
55
- leecher: int # TOR
56
-
57
- slug: str # SC
58
-
59
-
60
- class MediaManager:
61
- def __init__(self):
62
- self.media_list: List[MediaItem] = []
63
-
64
- def add_media(self, data: dict) -> None:
65
- """
66
- Add media to the list.
67
-
68
- Args:
69
- data (dict): Media data to add.
70
- """
71
- self.media_list.append(MediaItem(**data))
72
-
73
- def get(self, index: int) -> MediaItem:
74
- """
75
- Get a media item from the list by index.
76
-
77
- Args:
78
- index (int): The index of the media item to retrieve.
79
-
80
- Returns:
81
- MediaItem: The media item at the specified index.
82
- """
83
- return self.media_list[index]
84
-
85
- def get_length(self) -> int:
86
- """
87
- Get the number of media items in the list.
88
-
89
- Returns:
90
- int: Number of media items.
91
- """
92
- return len(self.media_list)
93
-
94
- def clear(self) -> None:
95
- """
96
- This method clears the media list.
97
- """
98
- self.media_list.clear()
99
-
100
- def __str__(self):
101
- return f"MediaManager(num_media={len(self.media_list)})"
@@ -1,5 +0,0 @@
1
- # 23.11.24
2
-
3
- from .recall_search import execute_search
4
- from .get_domain import search_domain
5
- from .manage_ep import manage_selection, map_episode_title, validate_episode_selection, validate_selection