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,86 +1,86 @@
1
- # 26.05.24
2
-
3
- # External libraries
4
- import httpx
5
- from bs4 import BeautifulSoup
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Src.Util.console import console
10
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
11
- from StreamingCommunity.Src.Util.headers import get_headers
12
- from StreamingCommunity.Src.Util.table import TVShowManager
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Src.Api.Template import get_select_title
17
- from StreamingCommunity.Src.Api.Template.Util import search_domain
18
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
19
-
20
-
21
- # Variable
22
- from .costant import SITE_NAME, DOMAIN_NOW
23
- media_search_manager = MediaManager()
24
- table_show_manager = TVShowManager()
25
-
26
-
27
- def title_search(title_search: str) -> int:
28
- """
29
- Search for titles based on a search query.
30
-
31
- Parameters:
32
- - title_search (str): The title to search for.
33
-
34
- Returns:
35
- int: The number of titles found.
36
- """
37
- client = httpx.Client()
38
-
39
- # Find new domain if prev dont work
40
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
41
- #domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
42
-
43
- # Send request to search for title
44
- try:
45
- response = client.get(
46
- url=f"https://{SITE_NAME}.{DOMAIN_NOW}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
47
- headers={
48
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
49
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
50
- 'User-Agent': get_headers()
51
- },
52
- timeout=max_timeout
53
- )
54
- response.raise_for_status()
55
-
56
- except Exception as e:
57
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
58
- raise
59
-
60
- # Create soup and find table
61
- soup = BeautifulSoup(response.text, "html.parser")
62
- table_content = soup.find('div', id="dle-content")
63
-
64
- # Scrape div film in table on single page
65
- for film_div in table_content.find_all('div', class_='col-lg-3'):
66
- title = film_div.find('h2', class_='titleFilm').get_text(strip=True)
67
- link = film_div.find('h2', class_='titleFilm').find('a')['href']
68
- imdb_rating = film_div.find('div', class_='imdb-rate').get_text(strip=True).split(":")[-1]
69
-
70
- film_info = {
71
- 'name': title,
72
- 'url': link,
73
- 'score': imdb_rating
74
- }
75
-
76
- media_search_manager.add_media(film_info)
77
-
78
- # Return the number of titles found
79
- return media_search_manager.get_length()
80
-
81
-
82
- def run_get_select_title():
83
- """
84
- Display a selection of titles and prompt the user to choose one.
85
- """
86
- return get_select_title(table_show_manager, media_search_manager)
1
+ # 26.05.24
2
+
3
+ # External libraries
4
+ import httpx
5
+ from bs4 import BeautifulSoup
6
+
7
+
8
+ # Internal utilities
9
+ from StreamingCommunity.Src.Util.console import console
10
+ from StreamingCommunity.Src.Util._jsonConfig import config_manager
11
+ from StreamingCommunity.Src.Util.headers import get_headers
12
+ from StreamingCommunity.Src.Util.table import TVShowManager
13
+
14
+
15
+ # Logic class
16
+ from StreamingCommunity.Src.Api.Template import get_select_title
17
+ from StreamingCommunity.Src.Api.Template.Util import search_domain
18
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
19
+
20
+
21
+ # Variable
22
+ from .costant import SITE_NAME, DOMAIN_NOW
23
+ media_search_manager = MediaManager()
24
+ table_show_manager = TVShowManager()
25
+
26
+
27
+ def title_search(title_search: str) -> int:
28
+ """
29
+ Search for titles based on a search query.
30
+
31
+ Parameters:
32
+ - title_search (str): The title to search for.
33
+
34
+ Returns:
35
+ int: The number of titles found.
36
+ """
37
+ client = httpx.Client()
38
+
39
+ # Find new domain if prev dont work
40
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
41
+ #domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
42
+
43
+ # Send request to search for title
44
+ try:
45
+ response = client.get(
46
+ url=f"https://{SITE_NAME}.{DOMAIN_NOW}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
47
+ headers={
48
+ 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
49
+ 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
50
+ 'User-Agent': get_headers()
51
+ },
52
+ timeout=max_timeout
53
+ )
54
+ response.raise_for_status()
55
+
56
+ except Exception as e:
57
+ console.print(f"Site: {SITE_NAME}, request search error: {e}")
58
+ raise
59
+
60
+ # Create soup and find table
61
+ soup = BeautifulSoup(response.text, "html.parser")
62
+ table_content = soup.find('div', id="dle-content")
63
+
64
+ # Scrape div film in table on single page
65
+ for film_div in table_content.find_all('div', class_='col-lg-3'):
66
+ title = film_div.find('h2', class_='titleFilm').get_text(strip=True)
67
+ link = film_div.find('h2', class_='titleFilm').find('a')['href']
68
+ imdb_rating = film_div.find('div', class_='imdb-rate').get_text(strip=True).split(":")[-1]
69
+
70
+ film_info = {
71
+ 'name': title,
72
+ 'url': link,
73
+ 'score': imdb_rating
74
+ }
75
+
76
+ media_search_manager.add_media(film_info)
77
+
78
+ # Return the number of titles found
79
+ return media_search_manager.get_length()
80
+
81
+
82
+ def run_get_select_title():
83
+ """
84
+ Display a selection of titles and prompt the user to choose one.
85
+ """
86
+ return get_select_title(table_show_manager, media_search_manager)
@@ -1,50 +1,50 @@
1
- # 21.05.24
2
-
3
- from unidecode import unidecode
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.Util.console import console, msg
8
-
9
-
10
- # Logic class
11
- from .site import title_search, run_get_select_title, media_search_manager
12
- from .film_serie import download_film, download_series
13
-
14
-
15
- # Variable
16
- indice = 1
17
- _useFor = "anime"
18
- _deprecate = False
19
- _priority = 2
20
- _engineDownload = "mp4"
21
-
22
-
23
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
-
25
- if string_to_search is None:
26
- string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
27
-
28
- # Search on database
29
- len_database = title_search(unidecode(string_to_search))
30
-
31
- # Return list of elements
32
- if get_onylDatabase:
33
- return media_search_manager
34
-
35
- if len_database > 0:
36
-
37
- # Select title from list (type: TV \ Movie \ OVA)
38
- select_title = run_get_select_title()
39
-
40
- if select_title.type == 'Movie' or select_title.type == 'OVA':
41
- download_film(select_title)
42
-
43
- else:
44
- download_series(select_title)
45
-
46
- else:
47
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
48
-
49
- # Retry
50
- search()
1
+ # 21.05.24
2
+
3
+ from unidecode import unidecode
4
+
5
+
6
+ # Internal utilities
7
+ from StreamingCommunity.Src.Util.console import console, msg
8
+
9
+
10
+ # Logic class
11
+ from .site import title_search, run_get_select_title, media_search_manager
12
+ from .film_serie import download_film, download_series
13
+
14
+
15
+ # Variable
16
+ indice = 1
17
+ _useFor = "anime"
18
+ _deprecate = False
19
+ _priority = 2
20
+ _engineDownload = "mp4"
21
+
22
+
23
+ def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
+
25
+ if string_to_search is None:
26
+ string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
27
+
28
+ # Search on database
29
+ len_database = title_search(unidecode(string_to_search))
30
+
31
+ # Return list of elements
32
+ if get_onylDatabase:
33
+ return media_search_manager
34
+
35
+ if len_database > 0:
36
+
37
+ # Select title from list (type: TV \ Movie \ OVA)
38
+ select_title = run_get_select_title()
39
+
40
+ if select_title.type == 'Movie' or select_title.type == 'OVA':
41
+ download_film(select_title)
42
+
43
+ else:
44
+ download_series(select_title)
45
+
46
+ else:
47
+ console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
48
+
49
+ # Retry
50
+ search()
@@ -1,15 +1,15 @@
1
- # 26.05.24
2
-
3
- import os
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.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= "Serie"
15
- MOVIE_FOLDER = "Movie"
1
+ # 26.05.24
2
+
3
+ import os
4
+
5
+
6
+ # Internal utilities
7
+ from StreamingCommunity.Src.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= "Serie"
15
+ MOVIE_FOLDER = "Movie"
@@ -1,131 +1,131 @@
1
- # 11.03.24
2
-
3
- import os
4
- import sys
5
- import logging
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Src.Util.console import console, msg
10
- from StreamingCommunity.Src.Util.os import os_manager
11
- from StreamingCommunity.Src.Util.message import start_message
12
- from StreamingCommunity.Src.Lib.Downloader import MP4_downloader
13
-
14
-
15
- # Logic class
16
- from .util.ScrapeSerie import ScrapeSerieAnime
17
- from StreamingCommunity.Src.Api.Template.Util import manage_selection
18
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
19
-
20
-
21
- # Player
22
- from StreamingCommunity.Src.Api.Player.vixcloud import VideoSourceAnime
23
-
24
-
25
- # Variable
26
- from .costant import ROOT_PATH, SITE_NAME, SERIES_FOLDER, MOVIE_FOLDER
27
- scrape_serie = ScrapeSerieAnime(SITE_NAME)
28
- video_source = VideoSourceAnime(SITE_NAME)
29
-
30
-
31
- def download_episode(index_select: int):
32
- """
33
- Downloads the selected episode.
34
-
35
- Parameters:
36
- - index_select (int): Index of the episode to download.
37
- """
38
-
39
- # Get information about the selected episode
40
- obj_episode = scrape_serie.get_info_episode(index_select)
41
-
42
- if obj_episode is not None:
43
-
44
- start_message()
45
- console.print(f"[yellow]Download: [red]EP_{obj_episode.number} \n")
46
-
47
- # Collect mp4 url
48
- video_source.get_embed(obj_episode.id)
49
-
50
- # Get the js script from the episode
51
- #js_script = video_source.get_embed(obj_episode.id)
52
-
53
- # Parse parameter in embed text
54
- #video_source.parse_script(js_script)
55
-
56
- # Create output path
57
- title_name = f"{obj_episode.number}.mp4"
58
-
59
- if scrape_serie.is_series:
60
- mp4_path = os_manager.get_sanitize_path(
61
- os.path.join(ROOT_PATH, SITE_NAME, SERIES_FOLDER, scrape_serie.series_name)
62
- )
63
- else:
64
- mp4_path = os_manager.get_sanitize_path(
65
- os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, scrape_serie.series_name)
66
- )
67
-
68
- # Create output folder
69
- os_manager.create_path(mp4_path)
70
-
71
- # Start downloading
72
- r_proc = MP4_downloader(
73
- url = str(video_source.src_mp4).strip(),
74
- path = os.path.join(mp4_path, title_name)
75
- )
76
-
77
- if r_proc != None:
78
- console.print("[green]Result: ")
79
- console.print(r_proc)
80
-
81
- else:
82
- logging.error(f"Skip index: {index_select} cant find info with api.")
83
-
84
-
85
- def download_series(select_title: MediaItem):
86
- """
87
- Function to download episodes of a TV series.
88
-
89
- Parameters:
90
- - tv_id (int): The ID of the TV series.
91
- - tv_name (str): The name of the TV series.
92
- """
93
-
94
- # Set up video source
95
- scrape_serie.setup(None, select_title.id, select_title.slug)
96
-
97
- # Get the count of episodes for the TV series
98
- episoded_count = scrape_serie.get_count_episodes()
99
- console.print(f"[cyan]Episodes find: [red]{episoded_count}")
100
-
101
- # Prompt user to select an episode index
102
- last_command = msg.ask("\n[cyan]Insert media [red]index [yellow]or [red](*) [cyan]to download all media [yellow]or [red][1-2] [cyan]or [red][3-*] [cyan]for a range of media")
103
-
104
- # Manage user selection
105
- list_episode_select = manage_selection(last_command, episoded_count)
106
-
107
- # Download selected episodes
108
- if len(list_episode_select) == 1 and last_command != "*":
109
- download_episode(list_episode_select[0]-1)
110
-
111
- # Download all other episodes selecter
112
- else:
113
- for i_episode in list_episode_select:
114
- download_episode(i_episode-1)
115
-
116
-
117
- def download_film(select_title: MediaItem):
118
- """
119
- Function to download a film.
120
-
121
- Parameters:
122
- - id_film (int): The ID of the film.
123
- - title_name (str): The title of the film.
124
- """
125
-
126
- # Set up video source
127
- scrape_serie.setup(None, select_title.id, select_title.slug)
128
- scrape_serie.is_series = False
129
-
130
- # Start download
131
- download_episode(0)
1
+ # 11.03.24
2
+
3
+ import os
4
+ import sys
5
+ import logging
6
+
7
+
8
+ # Internal utilities
9
+ from StreamingCommunity.Src.Util.console import console, msg
10
+ from StreamingCommunity.Src.Util.os import os_manager
11
+ from StreamingCommunity.Src.Util.message import start_message
12
+ from StreamingCommunity.Src.Lib.Downloader import MP4_downloader
13
+
14
+
15
+ # Logic class
16
+ from .util.ScrapeSerie import ScrapeSerieAnime
17
+ from StreamingCommunity.Src.Api.Template.Util import manage_selection
18
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
19
+
20
+
21
+ # Player
22
+ from StreamingCommunity.Src.Api.Player.vixcloud import VideoSourceAnime
23
+
24
+
25
+ # Variable
26
+ from .costant import ROOT_PATH, SITE_NAME, SERIES_FOLDER, MOVIE_FOLDER
27
+ scrape_serie = ScrapeSerieAnime(SITE_NAME)
28
+ video_source = VideoSourceAnime(SITE_NAME)
29
+
30
+
31
+ def download_episode(index_select: int):
32
+ """
33
+ Downloads the selected episode.
34
+
35
+ Parameters:
36
+ - index_select (int): Index of the episode to download.
37
+ """
38
+
39
+ # Get information about the selected episode
40
+ obj_episode = scrape_serie.get_info_episode(index_select)
41
+
42
+ if obj_episode is not None:
43
+
44
+ start_message()
45
+ console.print(f"[yellow]Download: [red]EP_{obj_episode.number} \n")
46
+
47
+ # Collect mp4 url
48
+ video_source.get_embed(obj_episode.id)
49
+
50
+ # Get the js script from the episode
51
+ #js_script = video_source.get_embed(obj_episode.id)
52
+
53
+ # Parse parameter in embed text
54
+ #video_source.parse_script(js_script)
55
+
56
+ # Create output path
57
+ title_name = f"{obj_episode.number}.mp4"
58
+
59
+ if scrape_serie.is_series:
60
+ mp4_path = os_manager.get_sanitize_path(
61
+ os.path.join(ROOT_PATH, SITE_NAME, SERIES_FOLDER, scrape_serie.series_name)
62
+ )
63
+ else:
64
+ mp4_path = os_manager.get_sanitize_path(
65
+ os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, scrape_serie.series_name)
66
+ )
67
+
68
+ # Create output folder
69
+ os_manager.create_path(mp4_path)
70
+
71
+ # Start downloading
72
+ r_proc = MP4_downloader(
73
+ url = str(video_source.src_mp4).strip(),
74
+ path = os.path.join(mp4_path, title_name)
75
+ )
76
+
77
+ if r_proc != None:
78
+ console.print("[green]Result: ")
79
+ console.print(r_proc)
80
+
81
+ else:
82
+ logging.error(f"Skip index: {index_select} cant find info with api.")
83
+
84
+
85
+ def download_series(select_title: MediaItem):
86
+ """
87
+ Function to download episodes of a TV series.
88
+
89
+ Parameters:
90
+ - tv_id (int): The ID of the TV series.
91
+ - tv_name (str): The name of the TV series.
92
+ """
93
+
94
+ # Set up video source
95
+ scrape_serie.setup(None, select_title.id, select_title.slug)
96
+
97
+ # Get the count of episodes for the TV series
98
+ episoded_count = scrape_serie.get_count_episodes()
99
+ console.print(f"[cyan]Episodes find: [red]{episoded_count}")
100
+
101
+ # Prompt user to select an episode index
102
+ last_command = msg.ask("\n[cyan]Insert media [red]index [yellow]or [red](*) [cyan]to download all media [yellow]or [red][1-2] [cyan]or [red][3-*] [cyan]for a range of media")
103
+
104
+ # Manage user selection
105
+ list_episode_select = manage_selection(last_command, episoded_count)
106
+
107
+ # Download selected episodes
108
+ if len(list_episode_select) == 1 and last_command != "*":
109
+ download_episode(list_episode_select[0]-1)
110
+
111
+ # Download all other episodes selecter
112
+ else:
113
+ for i_episode in list_episode_select:
114
+ download_episode(i_episode-1)
115
+
116
+
117
+ def download_film(select_title: MediaItem):
118
+ """
119
+ Function to download a film.
120
+
121
+ Parameters:
122
+ - id_film (int): The ID of the film.
123
+ - title_name (str): The title of the film.
124
+ """
125
+
126
+ # Set up video source
127
+ scrape_serie.setup(None, select_title.id, select_title.slug)
128
+ scrape_serie.is_series = False
129
+
130
+ # Start download
131
+ download_episode(0)