StreamingCommunity 1.7.6__py3-none-any.whl → 1.8.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 (93) hide show
  1. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/js_parser.py +4 -1
  2. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/util.py +166 -166
  3. StreamingCommunity/Src/Api/Player/ddl.py +89 -89
  4. StreamingCommunity/Src/Api/Player/maxstream.py +151 -151
  5. StreamingCommunity/Src/Api/Player/supervideo.py +193 -193
  6. StreamingCommunity/Src/Api/Player/vixcloud.py +224 -212
  7. StreamingCommunity/Src/Api/Site/1337xx/__init__.py +50 -50
  8. StreamingCommunity/Src/Api/Site/1337xx/costant.py +14 -14
  9. StreamingCommunity/Src/Api/Site/1337xx/site.py +83 -83
  10. StreamingCommunity/Src/Api/Site/1337xx/title.py +66 -66
  11. StreamingCommunity/Src/Api/Site/altadefinizione/__init__.py +50 -50
  12. StreamingCommunity/Src/Api/Site/altadefinizione/costant.py +14 -14
  13. StreamingCommunity/Src/Api/Site/altadefinizione/film.py +69 -69
  14. StreamingCommunity/Src/Api/Site/altadefinizione/site.py +86 -86
  15. StreamingCommunity/Src/Api/Site/animeunity/__init__.py +50 -50
  16. StreamingCommunity/Src/Api/Site/animeunity/costant.py +15 -15
  17. StreamingCommunity/Src/Api/Site/animeunity/film_serie.py +131 -131
  18. StreamingCommunity/Src/Api/Site/animeunity/site.py +164 -164
  19. StreamingCommunity/Src/Api/Site/bitsearch/__init__.py +51 -51
  20. StreamingCommunity/Src/Api/Site/bitsearch/costant.py +15 -15
  21. StreamingCommunity/Src/Api/Site/bitsearch/site.py +84 -84
  22. StreamingCommunity/Src/Api/Site/bitsearch/title.py +47 -47
  23. StreamingCommunity/Src/Api/Site/cb01new/__init__.py +51 -51
  24. StreamingCommunity/Src/Api/Site/cb01new/costant.py +15 -15
  25. StreamingCommunity/Src/Api/Site/cb01new/film.py +69 -69
  26. StreamingCommunity/Src/Api/Site/cb01new/site.py +74 -74
  27. StreamingCommunity/Src/Api/Site/ddlstreamitaly/__init__.py +57 -57
  28. StreamingCommunity/Src/Api/Site/ddlstreamitaly/costant.py +16 -16
  29. StreamingCommunity/Src/Api/Site/ddlstreamitaly/series.py +142 -142
  30. StreamingCommunity/Src/Api/Site/ddlstreamitaly/site.py +92 -92
  31. StreamingCommunity/Src/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +82 -82
  32. StreamingCommunity/Src/Api/Site/guardaserie/__init__.py +52 -52
  33. StreamingCommunity/Src/Api/Site/guardaserie/costant.py +15 -15
  34. StreamingCommunity/Src/Api/Site/guardaserie/series.py +195 -195
  35. StreamingCommunity/Src/Api/Site/guardaserie/site.py +84 -84
  36. StreamingCommunity/Src/Api/Site/guardaserie/util/ScrapeSerie.py +110 -110
  37. StreamingCommunity/Src/Api/Site/mostraguarda/__init__.py +48 -48
  38. StreamingCommunity/Src/Api/Site/mostraguarda/costant.py +14 -14
  39. StreamingCommunity/Src/Api/Site/mostraguarda/film.py +94 -94
  40. StreamingCommunity/Src/Api/Site/piratebays/__init__.py +50 -50
  41. StreamingCommunity/Src/Api/Site/piratebays/costant.py +14 -14
  42. StreamingCommunity/Src/Api/Site/piratebays/site.py +88 -88
  43. StreamingCommunity/Src/Api/Site/piratebays/title.py +45 -45
  44. StreamingCommunity/Src/Api/Site/streamingcommunity/__init__.py +55 -55
  45. StreamingCommunity/Src/Api/Site/streamingcommunity/costant.py +14 -14
  46. StreamingCommunity/Src/Api/Site/streamingcommunity/film.py +70 -70
  47. StreamingCommunity/Src/Api/Site/streamingcommunity/series.py +203 -203
  48. StreamingCommunity/Src/Api/Site/streamingcommunity/site.py +125 -125
  49. StreamingCommunity/Src/Api/Template/Class/SearchType.py +101 -101
  50. StreamingCommunity/Src/Api/Template/Util/__init__.py +4 -4
  51. StreamingCommunity/Src/Api/Template/Util/get_domain.py +137 -137
  52. StreamingCommunity/Src/Api/Template/Util/manage_ep.py +153 -153
  53. StreamingCommunity/Src/Api/Template/Util/recall_search.py +37 -37
  54. StreamingCommunity/Src/Api/Template/__init__.py +2 -2
  55. StreamingCommunity/Src/Api/Template/site.py +87 -87
  56. StreamingCommunity/Src/Lib/Downloader/HLS/downloader.py +968 -968
  57. StreamingCommunity/Src/Lib/Downloader/HLS/proxyes.py +110 -110
  58. StreamingCommunity/Src/Lib/Downloader/HLS/segments.py +540 -540
  59. StreamingCommunity/Src/Lib/Downloader/MP4/downloader.py +156 -156
  60. StreamingCommunity/Src/Lib/Downloader/TOR/downloader.py +222 -222
  61. StreamingCommunity/Src/Lib/Downloader/__init__.py +4 -4
  62. StreamingCommunity/Src/Lib/Driver/driver_1.py +76 -76
  63. StreamingCommunity/Src/Lib/FFmpeg/__init__.py +4 -4
  64. StreamingCommunity/Src/Lib/FFmpeg/capture.py +170 -170
  65. StreamingCommunity/Src/Lib/FFmpeg/command.py +292 -292
  66. StreamingCommunity/Src/Lib/FFmpeg/util.py +241 -241
  67. StreamingCommunity/Src/Lib/M3U8/__init__.py +5 -5
  68. StreamingCommunity/Src/Lib/M3U8/decryptor.py +128 -128
  69. StreamingCommunity/Src/Lib/M3U8/estimator.py +172 -172
  70. StreamingCommunity/Src/Lib/M3U8/parser.py +666 -666
  71. StreamingCommunity/Src/Lib/M3U8/url_fixer.py +51 -51
  72. StreamingCommunity/Src/Lib/TMBD/__init__.py +1 -1
  73. StreamingCommunity/Src/Lib/TMBD/obj_tmbd.py +39 -39
  74. StreamingCommunity/Src/Lib/TMBD/tmdb.py +345 -345
  75. StreamingCommunity/Src/Upload/update.py +64 -64
  76. StreamingCommunity/Src/Upload/version.py +5 -5
  77. StreamingCommunity/Src/Util/_jsonConfig.py +204 -204
  78. StreamingCommunity/Src/Util/call_stack.py +42 -42
  79. StreamingCommunity/Src/Util/color.py +20 -20
  80. StreamingCommunity/Src/Util/console.py +12 -12
  81. StreamingCommunity/Src/Util/headers.py +147 -147
  82. StreamingCommunity/Src/Util/logger.py +53 -53
  83. StreamingCommunity/Src/Util/message.py +46 -46
  84. StreamingCommunity/Src/Util/os.py +417 -417
  85. StreamingCommunity/Src/Util/table.py +163 -163
  86. StreamingCommunity/run.py +196 -196
  87. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.8.0.dist-info}/METADATA +1 -1
  88. StreamingCommunity-1.8.0.dist-info/RECORD +97 -0
  89. StreamingCommunity-1.7.6.dist-info/RECORD +0 -97
  90. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.8.0.dist-info}/LICENSE +0 -0
  91. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.8.0.dist-info}/WHEEL +0 -0
  92. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.8.0.dist-info}/entry_points.txt +0 -0
  93. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.8.0.dist-info}/top_level.txt +0 -0
@@ -1,142 +1,142 @@
1
- # 13.06.24
2
-
3
- import os
4
- import sys
5
- from urllib.parse import urlparse
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Src.Util.console import console
10
- from StreamingCommunity.Src.Util.message import start_message
11
- from StreamingCommunity.Src.Util.os import os_manager
12
- from StreamingCommunity.Src.Util.table import TVShowManager
13
- from StreamingCommunity.Src.Lib.Downloader import MP4_downloader
14
-
15
-
16
- # Logic class
17
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
18
- from StreamingCommunity.Src.Api.Template.Util import manage_selection, map_episode_title, validate_episode_selection
19
-
20
-
21
- # Player
22
- from .util.ScrapeSerie import GetSerieInfo
23
- from StreamingCommunity.Src.Api.Player.ddl import VideoSource
24
-
25
-
26
- # Variable
27
- from .costant import ROOT_PATH, SITE_NAME, SERIES_FOLDER
28
- table_show_manager = TVShowManager()
29
- video_source = VideoSource()
30
-
31
-
32
-
33
- def download_video(scape_info_serie: GetSerieInfo, index_episode_selected: int) -> None:
34
- """
35
- Download a single episode video.
36
-
37
- Parameters:
38
- - tv_name (str): Name of the TV series.
39
- - index_episode_selected (int): Index of the selected episode.
40
- """
41
-
42
- start_message()
43
-
44
- # Get info about episode
45
- obj_episode = scape_info_serie.list_episodes[index_episode_selected - 1]
46
- console.print(f"[yellow]Download: [red]{obj_episode.get('name')}")
47
- print()
48
-
49
- # Define filename and path for the downloaded video
50
- title_name = os_manager.get_sanitize_file(
51
- f"{map_episode_title(scape_info_serie.tv_name, None, index_episode_selected, obj_episode.get('name'))}.mp4"
52
- )
53
- mp4_path = os.path.join(ROOT_PATH, SITE_NAME, SERIES_FOLDER, scape_info_serie.tv_name)
54
-
55
- # Create output folder
56
- os_manager.create_path(mp4_path)
57
-
58
- # Setup video source
59
- video_source.setup(obj_episode.get('url'))
60
-
61
- # Get m3u8 master playlist
62
- master_playlist = video_source.get_playlist()
63
-
64
- # Parse start page url
65
- parsed_url = urlparse(obj_episode.get('url'))
66
-
67
- # Start download
68
- r_proc = MP4_downloader(
69
- url = master_playlist,
70
- path = os.path.join(mp4_path, title_name),
71
- referer = f"{parsed_url.scheme}://{parsed_url.netloc}/",
72
- )
73
-
74
- if r_proc != None:
75
- console.print("[green]Result: ")
76
- console.print(r_proc)
77
-
78
-
79
- def download_thread(dict_serie: MediaItem):
80
- """
81
- Download all episode of a thread
82
- """
83
-
84
- # Start message and set up video source
85
- start_message()
86
-
87
- # Init class
88
- scape_info_serie = GetSerieInfo(dict_serie)
89
-
90
- # Collect information about thread
91
- list_dict_episode = scape_info_serie.get_episode_number()
92
- episodes_count = len(list_dict_episode)
93
-
94
- # Display episodes list and manage user selection
95
- last_command = display_episodes_list(scape_info_serie.list_episodes)
96
- list_episode_select = manage_selection(last_command, episodes_count)
97
-
98
- try:
99
- list_episode_select = validate_episode_selection(list_episode_select, episodes_count)
100
- except ValueError as e:
101
- console.print(f"[red]{str(e)}")
102
- return
103
-
104
- # Download selected episodes
105
- for i_episode in list_episode_select:
106
- download_video(scape_info_serie, i_episode)
107
-
108
-
109
-
110
- def display_episodes_list(obj_episode_manager) -> str:
111
- """
112
- Display episodes list and handle user input.
113
-
114
- Returns:
115
- last_command (str): Last command entered by the user.
116
- """
117
-
118
- # Set up table for displaying episodes
119
- table_show_manager.set_slice_end(10)
120
-
121
- # Add columns to the table
122
- column_info = {
123
- "Index": {'color': 'red'},
124
- "Name": {'color': 'magenta'},
125
- }
126
- table_show_manager.add_column(column_info)
127
-
128
- # Populate the table with episodes information
129
- for i, media in enumerate(obj_episode_manager):
130
- table_show_manager.add_tv_show({
131
- 'Index': str(i+1),
132
- 'Name': media.get('name'),
133
- })
134
-
135
- # Run the table and handle user input
136
- last_command = table_show_manager.run()
137
-
138
- if last_command == "q":
139
- console.print("\n[red]Quit [white]...")
140
- sys.exit(0)
141
-
142
- return last_command
1
+ # 13.06.24
2
+
3
+ import os
4
+ import sys
5
+ from urllib.parse import urlparse
6
+
7
+
8
+ # Internal utilities
9
+ from StreamingCommunity.Src.Util.console import console
10
+ from StreamingCommunity.Src.Util.message import start_message
11
+ from StreamingCommunity.Src.Util.os import os_manager
12
+ from StreamingCommunity.Src.Util.table import TVShowManager
13
+ from StreamingCommunity.Src.Lib.Downloader import MP4_downloader
14
+
15
+
16
+ # Logic class
17
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
18
+ from StreamingCommunity.Src.Api.Template.Util import manage_selection, map_episode_title, validate_episode_selection
19
+
20
+
21
+ # Player
22
+ from .util.ScrapeSerie import GetSerieInfo
23
+ from StreamingCommunity.Src.Api.Player.ddl import VideoSource
24
+
25
+
26
+ # Variable
27
+ from .costant import ROOT_PATH, SITE_NAME, SERIES_FOLDER
28
+ table_show_manager = TVShowManager()
29
+ video_source = VideoSource()
30
+
31
+
32
+
33
+ def download_video(scape_info_serie: GetSerieInfo, index_episode_selected: int) -> None:
34
+ """
35
+ Download a single episode video.
36
+
37
+ Parameters:
38
+ - tv_name (str): Name of the TV series.
39
+ - index_episode_selected (int): Index of the selected episode.
40
+ """
41
+
42
+ start_message()
43
+
44
+ # Get info about episode
45
+ obj_episode = scape_info_serie.list_episodes[index_episode_selected - 1]
46
+ console.print(f"[yellow]Download: [red]{obj_episode.get('name')}")
47
+ print()
48
+
49
+ # Define filename and path for the downloaded video
50
+ title_name = os_manager.get_sanitize_file(
51
+ f"{map_episode_title(scape_info_serie.tv_name, None, index_episode_selected, obj_episode.get('name'))}.mp4"
52
+ )
53
+ mp4_path = os.path.join(ROOT_PATH, SITE_NAME, SERIES_FOLDER, scape_info_serie.tv_name)
54
+
55
+ # Create output folder
56
+ os_manager.create_path(mp4_path)
57
+
58
+ # Setup video source
59
+ video_source.setup(obj_episode.get('url'))
60
+
61
+ # Get m3u8 master playlist
62
+ master_playlist = video_source.get_playlist()
63
+
64
+ # Parse start page url
65
+ parsed_url = urlparse(obj_episode.get('url'))
66
+
67
+ # Start download
68
+ r_proc = MP4_downloader(
69
+ url = master_playlist,
70
+ path = os.path.join(mp4_path, title_name),
71
+ referer = f"{parsed_url.scheme}://{parsed_url.netloc}/",
72
+ )
73
+
74
+ if r_proc != None:
75
+ console.print("[green]Result: ")
76
+ console.print(r_proc)
77
+
78
+
79
+ def download_thread(dict_serie: MediaItem):
80
+ """
81
+ Download all episode of a thread
82
+ """
83
+
84
+ # Start message and set up video source
85
+ start_message()
86
+
87
+ # Init class
88
+ scape_info_serie = GetSerieInfo(dict_serie)
89
+
90
+ # Collect information about thread
91
+ list_dict_episode = scape_info_serie.get_episode_number()
92
+ episodes_count = len(list_dict_episode)
93
+
94
+ # Display episodes list and manage user selection
95
+ last_command = display_episodes_list(scape_info_serie.list_episodes)
96
+ list_episode_select = manage_selection(last_command, episodes_count)
97
+
98
+ try:
99
+ list_episode_select = validate_episode_selection(list_episode_select, episodes_count)
100
+ except ValueError as e:
101
+ console.print(f"[red]{str(e)}")
102
+ return
103
+
104
+ # Download selected episodes
105
+ for i_episode in list_episode_select:
106
+ download_video(scape_info_serie, i_episode)
107
+
108
+
109
+
110
+ def display_episodes_list(obj_episode_manager) -> str:
111
+ """
112
+ Display episodes list and handle user input.
113
+
114
+ Returns:
115
+ last_command (str): Last command entered by the user.
116
+ """
117
+
118
+ # Set up table for displaying episodes
119
+ table_show_manager.set_slice_end(10)
120
+
121
+ # Add columns to the table
122
+ column_info = {
123
+ "Index": {'color': 'red'},
124
+ "Name": {'color': 'magenta'},
125
+ }
126
+ table_show_manager.add_column(column_info)
127
+
128
+ # Populate the table with episodes information
129
+ for i, media in enumerate(obj_episode_manager):
130
+ table_show_manager.add_tv_show({
131
+ 'Index': str(i+1),
132
+ 'Name': media.get('name'),
133
+ })
134
+
135
+ # Run the table and handle user input
136
+ last_command = table_show_manager.run()
137
+
138
+ if last_command == "q":
139
+ console.print("\n[red]Quit [white]...")
140
+ sys.exit(0)
141
+
142
+ return last_command
@@ -1,93 +1,93 @@
1
- # 09.06.24
2
-
3
- import logging
4
-
5
-
6
- # External libraries
7
- import httpx
8
- from bs4 import BeautifulSoup
9
-
10
-
11
- # Internal utilities
12
- from StreamingCommunity.Src.Util.console import console
13
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
14
- from StreamingCommunity.Src.Util.headers import get_headers
15
- from StreamingCommunity.Src.Util.table import TVShowManager
16
-
17
-
18
- # Logic class
19
- from StreamingCommunity.Src.Api.Template import get_select_title
20
- from StreamingCommunity.Src.Api.Template.Util import search_domain
21
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
22
-
23
-
24
- # Variable
25
- from .costant import SITE_NAME
26
- media_search_manager = MediaManager()
27
- table_show_manager = TVShowManager()
28
-
29
-
30
- def title_search(word_to_search: str) -> int:
31
- """
32
- Search for titles based on a search query.
33
-
34
- Parameters:
35
- - title_search (str): The title to search for.
36
-
37
- Returns:
38
- - int: The number of titles found.
39
- """
40
-
41
- # Find new domain if prev dont work
42
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
43
- domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
44
-
45
- # Send request to search for titles
46
- try:
47
- response = httpx.get(
48
- url=f"https://{SITE_NAME}.{domain_to_use}/search/?&q={word_to_search}&quick=1&type=videobox_video&nodes=11",
49
- headers={'user-agent': get_headers()},
50
- timeout=max_timeout
51
- )
52
- response.raise_for_status()
53
-
54
- except Exception as e:
55
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
56
-
57
- # Create soup and find table
58
- soup = BeautifulSoup(response.text, "html.parser")
59
- table_content = soup.find('ol', class_="ipsStream")
60
-
61
- if table_content:
62
- for title_div in table_content.find_all('li', class_='ipsStreamItem'):
63
- try:
64
-
65
- title_type = title_div.find("p", class_="ipsType_reset").find_all("a")[-1].get_text(strip=True)
66
- name = title_div.find("span", class_="ipsContained").find("a").get_text(strip=True)
67
- link = title_div.find("span", class_="ipsContained").find("a").get("href")
68
-
69
- title_info = {
70
- 'name': name,
71
- 'url': link,
72
- 'type': title_type
73
- }
74
-
75
- media_search_manager.add_media(title_info)
76
-
77
- except Exception as e:
78
- logging.error(f"Error processing title div: {e}")
79
-
80
- return media_search_manager.get_length()
81
-
82
- else:
83
- logging.error("No table content found.")
84
- return -999
85
-
86
- return -9999
87
-
88
-
89
- def run_get_select_title():
90
- """
91
- Display a selection of titles and prompt the user to choose one.
92
- """
1
+ # 09.06.24
2
+
3
+ import logging
4
+
5
+
6
+ # External libraries
7
+ import httpx
8
+ from bs4 import BeautifulSoup
9
+
10
+
11
+ # Internal utilities
12
+ from StreamingCommunity.Src.Util.console import console
13
+ from StreamingCommunity.Src.Util._jsonConfig import config_manager
14
+ from StreamingCommunity.Src.Util.headers import get_headers
15
+ from StreamingCommunity.Src.Util.table import TVShowManager
16
+
17
+
18
+ # Logic class
19
+ from StreamingCommunity.Src.Api.Template import get_select_title
20
+ from StreamingCommunity.Src.Api.Template.Util import search_domain
21
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
22
+
23
+
24
+ # Variable
25
+ from .costant import SITE_NAME
26
+ media_search_manager = MediaManager()
27
+ table_show_manager = TVShowManager()
28
+
29
+
30
+ def title_search(word_to_search: str) -> int:
31
+ """
32
+ Search for titles based on a search query.
33
+
34
+ Parameters:
35
+ - title_search (str): The title to search for.
36
+
37
+ Returns:
38
+ - int: The number of titles found.
39
+ """
40
+
41
+ # Find new domain if prev dont work
42
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
43
+ domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
44
+
45
+ # Send request to search for titles
46
+ try:
47
+ response = httpx.get(
48
+ url=f"https://{SITE_NAME}.{domain_to_use}/search/?&q={word_to_search}&quick=1&type=videobox_video&nodes=11",
49
+ headers={'user-agent': get_headers()},
50
+ timeout=max_timeout
51
+ )
52
+ response.raise_for_status()
53
+
54
+ except Exception as e:
55
+ console.print(f"Site: {SITE_NAME}, request search error: {e}")
56
+
57
+ # Create soup and find table
58
+ soup = BeautifulSoup(response.text, "html.parser")
59
+ table_content = soup.find('ol', class_="ipsStream")
60
+
61
+ if table_content:
62
+ for title_div in table_content.find_all('li', class_='ipsStreamItem'):
63
+ try:
64
+
65
+ title_type = title_div.find("p", class_="ipsType_reset").find_all("a")[-1].get_text(strip=True)
66
+ name = title_div.find("span", class_="ipsContained").find("a").get_text(strip=True)
67
+ link = title_div.find("span", class_="ipsContained").find("a").get("href")
68
+
69
+ title_info = {
70
+ 'name': name,
71
+ 'url': link,
72
+ 'type': title_type
73
+ }
74
+
75
+ media_search_manager.add_media(title_info)
76
+
77
+ except Exception as e:
78
+ logging.error(f"Error processing title div: {e}")
79
+
80
+ return media_search_manager.get_length()
81
+
82
+ else:
83
+ logging.error("No table content found.")
84
+ return -999
85
+
86
+ return -9999
87
+
88
+
89
+ def run_get_select_title():
90
+ """
91
+ Display a selection of titles and prompt the user to choose one.
92
+ """
93
93
  return get_select_title(table_show_manager, media_search_manager)
@@ -1,83 +1,83 @@
1
- # 13.06.24
2
-
3
- import sys
4
- import logging
5
- from typing import List, Dict
6
-
7
-
8
- # External libraries
9
- import httpx
10
- from bs4 import BeautifulSoup
11
-
12
-
13
- # Internal utilities
14
- from StreamingCommunity.Src.Util.headers import get_headers
15
-
16
-
17
- # Logic class
18
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
19
-
20
-
21
- # Variable
22
- from ..costant import COOKIE
23
-
24
-
25
- class GetSerieInfo:
26
- def __init__(self, dict_serie: MediaItem) -> None:
27
- """
28
- Initializes the GetSerieInfo object with default values.
29
-
30
- Parameters:
31
- - dict_serie (MediaItem): Dictionary containing series information (optional).
32
- """
33
- self.headers = {'user-agent': get_headers()}
34
- self.cookies = COOKIE
35
- self.url = dict_serie.url
36
- self.tv_name = None
37
- self.list_episodes = None
38
-
39
- def get_episode_number(self) -> List[Dict[str, str]]:
40
- """
41
- Retrieves the number of episodes for a specific season.
42
-
43
- Parameters:
44
- n_season (int): The season number.
45
-
46
- Returns:
47
- List[Dict[str, str]]: List of dictionaries containing episode information.
48
- """
49
-
50
- try:
51
- response = httpx.get(f"{self.url}?area=online", cookies=self.cookies, headers=self.headers, timeout=10)
52
- response.raise_for_status()
53
-
54
- except Exception as e:
55
- logging.error(f"Insert value for [ips4_device_key, ips4_member_id, ips4_login_key] in config.json file SITE \\ ddlstreamitaly \\ cookie. Use browser debug and cookie request with a valid account, filter by DOC. Error: {e}")
56
- sys.exit(0)
57
-
58
- # Parse HTML content of the page
59
- soup = BeautifulSoup(response.text, "html.parser")
60
-
61
- # Get tv name
62
- self.tv_name = soup.find("span", class_= "ipsType_break").get_text(strip=True)
63
-
64
- # Find the container of episodes for the specified season
65
- table_content = soup.find('div', class_='ipsMargin_bottom:half')
66
- list_dict_episode = []
67
-
68
- for episode_div in table_content.find_all('a', href=True):
69
-
70
- # Get text of episode
71
- part_name = episode_div.get_text(strip=True)
72
-
73
- if part_name:
74
- obj_episode = {
75
- 'name': part_name,
76
- 'url': episode_div['href']
77
- }
78
-
79
- list_dict_episode.append(obj_episode)
80
-
81
- self.list_episodes = list_dict_episode
82
- return list_dict_episode
1
+ # 13.06.24
2
+
3
+ import sys
4
+ import logging
5
+ from typing import List, Dict
6
+
7
+
8
+ # External libraries
9
+ import httpx
10
+ from bs4 import BeautifulSoup
11
+
12
+
13
+ # Internal utilities
14
+ from StreamingCommunity.Src.Util.headers import get_headers
15
+
16
+
17
+ # Logic class
18
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
19
+
20
+
21
+ # Variable
22
+ from ..costant import COOKIE
23
+
24
+
25
+ class GetSerieInfo:
26
+ def __init__(self, dict_serie: MediaItem) -> None:
27
+ """
28
+ Initializes the GetSerieInfo object with default values.
29
+
30
+ Parameters:
31
+ - dict_serie (MediaItem): Dictionary containing series information (optional).
32
+ """
33
+ self.headers = {'user-agent': get_headers()}
34
+ self.cookies = COOKIE
35
+ self.url = dict_serie.url
36
+ self.tv_name = None
37
+ self.list_episodes = None
38
+
39
+ def get_episode_number(self) -> List[Dict[str, str]]:
40
+ """
41
+ Retrieves the number of episodes for a specific season.
42
+
43
+ Parameters:
44
+ n_season (int): The season number.
45
+
46
+ Returns:
47
+ List[Dict[str, str]]: List of dictionaries containing episode information.
48
+ """
49
+
50
+ try:
51
+ response = httpx.get(f"{self.url}?area=online", cookies=self.cookies, headers=self.headers, timeout=10)
52
+ response.raise_for_status()
53
+
54
+ except Exception as e:
55
+ logging.error(f"Insert value for [ips4_device_key, ips4_member_id, ips4_login_key] in config.json file SITE \\ ddlstreamitaly \\ cookie. Use browser debug and cookie request with a valid account, filter by DOC. Error: {e}")
56
+ sys.exit(0)
57
+
58
+ # Parse HTML content of the page
59
+ soup = BeautifulSoup(response.text, "html.parser")
60
+
61
+ # Get tv name
62
+ self.tv_name = soup.find("span", class_= "ipsType_break").get_text(strip=True)
63
+
64
+ # Find the container of episodes for the specified season
65
+ table_content = soup.find('div', class_='ipsMargin_bottom:half')
66
+ list_dict_episode = []
67
+
68
+ for episode_div in table_content.find_all('a', href=True):
69
+
70
+ # Get text of episode
71
+ part_name = episode_div.get_text(strip=True)
72
+
73
+ if part_name:
74
+ obj_episode = {
75
+ 'name': part_name,
76
+ 'url': episode_div['href']
77
+ }
78
+
79
+ list_dict_episode.append(obj_episode)
80
+
81
+ self.list_episodes = list_dict_episode
82
+ return list_dict_episode
83
83