StreamingCommunity 2.4.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 (91) hide show
  1. {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/METADATA +9 -6
  2. StreamingCommunity-2.5.0.dist-info/RECORD +8 -0
  3. StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
  4. StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +0 -136
  5. StreamingCommunity/Api/Player/ddl.py +0 -89
  6. StreamingCommunity/Api/Player/maxstream.py +0 -151
  7. StreamingCommunity/Api/Player/supervideo.py +0 -194
  8. StreamingCommunity/Api/Player/vixcloud.py +0 -273
  9. StreamingCommunity/Api/Site/1337xx/__init__.py +0 -51
  10. StreamingCommunity/Api/Site/1337xx/costant.py +0 -15
  11. StreamingCommunity/Api/Site/1337xx/site.py +0 -89
  12. StreamingCommunity/Api/Site/1337xx/title.py +0 -66
  13. StreamingCommunity/Api/Site/altadefinizionegratis/__init__.py +0 -51
  14. StreamingCommunity/Api/Site/altadefinizionegratis/costant.py +0 -19
  15. StreamingCommunity/Api/Site/altadefinizionegratis/film.py +0 -74
  16. StreamingCommunity/Api/Site/altadefinizionegratis/site.py +0 -95
  17. StreamingCommunity/Api/Site/animeunity/__init__.py +0 -51
  18. StreamingCommunity/Api/Site/animeunity/costant.py +0 -19
  19. StreamingCommunity/Api/Site/animeunity/film_serie.py +0 -135
  20. StreamingCommunity/Api/Site/animeunity/site.py +0 -175
  21. StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
  22. StreamingCommunity/Api/Site/cb01new/__init__.py +0 -52
  23. StreamingCommunity/Api/Site/cb01new/costant.py +0 -19
  24. StreamingCommunity/Api/Site/cb01new/film.py +0 -73
  25. StreamingCommunity/Api/Site/cb01new/site.py +0 -83
  26. StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +0 -56
  27. StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +0 -20
  28. StreamingCommunity/Api/Site/ddlstreamitaly/series.py +0 -146
  29. StreamingCommunity/Api/Site/ddlstreamitaly/site.py +0 -99
  30. StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -85
  31. StreamingCommunity/Api/Site/guardaserie/__init__.py +0 -51
  32. StreamingCommunity/Api/Site/guardaserie/costant.py +0 -19
  33. StreamingCommunity/Api/Site/guardaserie/series.py +0 -198
  34. StreamingCommunity/Api/Site/guardaserie/site.py +0 -90
  35. StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
  36. StreamingCommunity/Api/Site/ilcorsaronero/__init__.py +0 -52
  37. StreamingCommunity/Api/Site/ilcorsaronero/costant.py +0 -19
  38. StreamingCommunity/Api/Site/ilcorsaronero/site.py +0 -72
  39. StreamingCommunity/Api/Site/ilcorsaronero/title.py +0 -46
  40. StreamingCommunity/Api/Site/ilcorsaronero/util/ilCorsarScraper.py +0 -149
  41. StreamingCommunity/Api/Site/mostraguarda/__init__.py +0 -49
  42. StreamingCommunity/Api/Site/mostraguarda/costant.py +0 -19
  43. StreamingCommunity/Api/Site/mostraguarda/film.py +0 -101
  44. StreamingCommunity/Api/Site/streamingcommunity/__init__.py +0 -56
  45. StreamingCommunity/Api/Site/streamingcommunity/costant.py +0 -19
  46. StreamingCommunity/Api/Site/streamingcommunity/film.py +0 -75
  47. StreamingCommunity/Api/Site/streamingcommunity/series.py +0 -206
  48. StreamingCommunity/Api/Site/streamingcommunity/site.py +0 -142
  49. StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -123
  50. StreamingCommunity/Api/Template/Class/SearchType.py +0 -101
  51. StreamingCommunity/Api/Template/Util/__init__.py +0 -5
  52. StreamingCommunity/Api/Template/Util/get_domain.py +0 -203
  53. StreamingCommunity/Api/Template/Util/manage_ep.py +0 -179
  54. StreamingCommunity/Api/Template/Util/recall_search.py +0 -37
  55. StreamingCommunity/Api/Template/__init__.py +0 -3
  56. StreamingCommunity/Api/Template/site.py +0 -87
  57. StreamingCommunity/Lib/Downloader/HLS/downloader.py +0 -965
  58. StreamingCommunity/Lib/Downloader/HLS/proxyes.py +0 -110
  59. StreamingCommunity/Lib/Downloader/HLS/segments.py +0 -573
  60. StreamingCommunity/Lib/Downloader/MP4/downloader.py +0 -155
  61. StreamingCommunity/Lib/Downloader/TOR/downloader.py +0 -296
  62. StreamingCommunity/Lib/Downloader/__init__.py +0 -5
  63. StreamingCommunity/Lib/FFmpeg/__init__.py +0 -4
  64. StreamingCommunity/Lib/FFmpeg/capture.py +0 -170
  65. StreamingCommunity/Lib/FFmpeg/command.py +0 -296
  66. StreamingCommunity/Lib/FFmpeg/util.py +0 -249
  67. StreamingCommunity/Lib/M3U8/__init__.py +0 -6
  68. StreamingCommunity/Lib/M3U8/decryptor.py +0 -165
  69. StreamingCommunity/Lib/M3U8/estimator.py +0 -229
  70. StreamingCommunity/Lib/M3U8/parser.py +0 -666
  71. StreamingCommunity/Lib/M3U8/url_fixer.py +0 -58
  72. StreamingCommunity/Lib/TMBD/__init__.py +0 -2
  73. StreamingCommunity/Lib/TMBD/obj_tmbd.py +0 -39
  74. StreamingCommunity/Lib/TMBD/tmdb.py +0 -346
  75. StreamingCommunity/Upload/update.py +0 -67
  76. StreamingCommunity/Upload/version.py +0 -5
  77. StreamingCommunity/Util/_jsonConfig.py +0 -228
  78. StreamingCommunity/Util/call_stack.py +0 -42
  79. StreamingCommunity/Util/color.py +0 -20
  80. StreamingCommunity/Util/console.py +0 -12
  81. StreamingCommunity/Util/ffmpeg_installer.py +0 -368
  82. StreamingCommunity/Util/headers.py +0 -160
  83. StreamingCommunity/Util/logger.py +0 -62
  84. StreamingCommunity/Util/message.py +0 -64
  85. StreamingCommunity/Util/os.py +0 -507
  86. StreamingCommunity/Util/table.py +0 -229
  87. StreamingCommunity-2.4.0.dist-info/RECORD +0 -92
  88. {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/LICENSE +0 -0
  89. {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/WHEEL +0 -0
  90. {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/entry_points.txt +0 -0
  91. {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/top_level.txt +0 -0
@@ -1,46 +0,0 @@
1
- # 02.07.24
2
-
3
- import os
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Util.console import console
8
- from StreamingCommunity.Util.os import os_manager
9
- from StreamingCommunity.Util.message import start_message
10
- from StreamingCommunity.Lib.Downloader import TOR_downloader
11
-
12
-
13
- # Logic class
14
- from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
15
-
16
-
17
- # Config
18
- from .costant import MOVIE_FOLDER
19
-
20
-
21
- def download_title(select_title: MediaItem):
22
- """
23
- Downloads a media item and saves it as an MP4 file.
24
-
25
- Parameters:
26
- - select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
27
- """
28
-
29
- start_message()
30
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
31
- print()
32
-
33
- # Define output path
34
- title_name = os_manager.get_sanitize_file(select_title.name)
35
- mp4_path = os_manager.get_sanitize_path(
36
- os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
37
- )
38
-
39
- # Create output folder
40
- os_manager.create_path(mp4_path)
41
-
42
- # Tor manager
43
- manager = TOR_downloader()
44
- manager.add_magnet_link(select_title.url)
45
- manager.start_download()
46
- manager.move_downloaded_files(mp4_path)
@@ -1,149 +0,0 @@
1
- # 12.14.24
2
-
3
- import logging
4
- import asyncio
5
- from typing import List, Dict, Optional
6
-
7
-
8
- # External libraries
9
- import httpx
10
- from bs4 import BeautifulSoup
11
-
12
-
13
- # Internal utilities
14
- from StreamingCommunity.Util._jsonConfig import config_manager
15
- from StreamingCommunity.Util.headers import get_headers
16
- from StreamingCommunity.Util.console import console
17
-
18
-
19
- # Variable
20
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
21
-
22
-
23
- class IlCorsaroNeroScraper:
24
- def __init__(self, base_url: str, max_page: int = 1):
25
- self.base_url = base_url
26
- self.max_page = max_page
27
- self.headers = {
28
- 'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
29
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
30
- 'cache-control': 'max-age=0',
31
- 'priority': 'u=0, i',
32
- 'sec-ch-ua': '"Google Chrome";v="131", "Chromium";v="131", "Not_A Brand";v="24"',
33
- 'sec-ch-ua-mobile': '?0',
34
- 'sec-ch-ua-platform': '"Windows"',
35
- 'sec-fetch-dest': 'document',
36
- 'sec-fetch-mode': 'navigate',
37
- 'sec-fetch-site': 'same-origin',
38
- 'sec-fetch-user': '?1',
39
- 'upgrade-insecure-requests': '1',
40
- 'user-agent': get_headers()
41
- }
42
-
43
- async def fetch_url(self, url: str) -> Optional[str]:
44
- """
45
- Fetch the HTML content of a given URL.
46
- """
47
- try:
48
- console.print(f"[cyan]Fetching url[white]: [red]{url}")
49
- async with httpx.AsyncClient(headers=self.headers, follow_redirects=True, timeout=max_timeout) as client:
50
- response = await client.get(url)
51
-
52
- # If the request was successful, return the HTML content
53
- response.raise_for_status()
54
- return response.text
55
-
56
- except Exception as e:
57
- logging.error(f"Error fetching from {url}: {e}")
58
- return None
59
-
60
- def parse_torrents(self, html: str) -> List[Dict[str, str]]:
61
- """
62
- Parse the HTML content and extract torrent details.
63
- """
64
- torrents = []
65
- soup = BeautifulSoup(html, "html.parser")
66
- table = soup.find("tbody")
67
-
68
- for row in table.find_all("tr"):
69
- try:
70
- columns = row.find_all("td")
71
-
72
- torrents.append({
73
- 'type': columns[0].get_text(strip=True),
74
- 'name': row.find("th").find("a").get_text(strip=True),
75
- 'seed': columns[1].get_text(strip=True),
76
- 'leech': columns[2].get_text(strip=True),
77
- 'size': columns[3].get_text(strip=True),
78
- 'date': columns[4].get_text(strip=True),
79
- 'url': "https://ilcorsaronero.link" + row.find("th").find("a").get("href")
80
- })
81
-
82
- except Exception as e:
83
- logging.error(f"Error parsing row: {e}")
84
- continue
85
-
86
- return torrents
87
-
88
- async def fetch_real_url(self, url: str) -> Optional[str]:
89
- """
90
- Fetch the real torrent URL from the detailed page.
91
- """
92
- response_html = await self.fetch_url(url)
93
- if not response_html:
94
- return None
95
-
96
- soup = BeautifulSoup(response_html, "html.parser")
97
- links = soup.find_all("a")
98
-
99
- # Find and return the magnet link
100
- for link in links:
101
- if "magnet" in str(link):
102
- return link.get("href")
103
-
104
- return None
105
-
106
- async def search(self, query: str) -> List[Dict[str, str]]:
107
- """
108
- Search for torrents based on the query string.
109
- """
110
- all_torrents = []
111
-
112
- # Loop through each page
113
- for page in range(self.max_page):
114
- url = f'{self.base_url}search?q={query}&page={page}'
115
-
116
- html = await self.fetch_url(url)
117
- if not html:
118
- console.print(f"[bold red]No HTML content for page {page}[/bold red]")
119
- break
120
-
121
- torrents = self.parse_torrents(html)
122
- if not torrents:
123
- console.print(f"[bold red]No torrents found on page {page}[/bold red]")
124
- break
125
-
126
- # Use asyncio.gather to fetch all real URLs concurrently
127
- tasks = [self.fetch_real_url(result['url']) for result in torrents]
128
- real_urls = await asyncio.gather(*tasks)
129
-
130
- # Attach real URLs to the torrent data
131
- for i, result in enumerate(torrents):
132
- result['url'] = real_urls[i]
133
-
134
- all_torrents.extend(torrents)
135
-
136
- return all_torrents
137
-
138
- async def main():
139
- scraper = IlCorsaroNeroScraper("https://ilcorsaronero.link/")
140
- results = await scraper.search("cars")
141
-
142
- if results:
143
- for i, torrent in enumerate(results):
144
- console.print(f"[bold green]{i} = {torrent}[/bold green] \n")
145
- else:
146
- console.print("[bold red]No torrents found.[/bold red]")
147
-
148
- if __name__ == '__main__':
149
- asyncio.run(main())
@@ -1,49 +0,0 @@
1
- # 26.05.24
2
-
3
- from urllib.parse import quote_plus
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Util.console import console, msg
8
-
9
-
10
- # Logic class
11
- from StreamingCommunity.Lib.TMBD import tmdb, Json_film
12
- from .film import download_film
13
-
14
-
15
- # Variable
16
- indice = 9
17
- _useFor = "film"
18
- _deprecate = False
19
- _priority = 2
20
- _engineDownload = "hls"
21
- from .costant import SITE_NAME
22
-
23
-
24
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
25
- """
26
- Main function of the application for film and series.
27
- """
28
-
29
- if string_to_search is None:
30
- string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
31
-
32
- # Not available for the moment
33
- if get_onylDatabase:
34
- return 0
35
-
36
- # Search on database
37
- movie_id = tmdb.search_movie(quote_plus(string_to_search))
38
-
39
- if movie_id is not None:
40
- movie_details: Json_film = tmdb.get_movie_details(tmdb_id=movie_id)
41
-
42
- # Download only film
43
- download_film(movie_details)
44
-
45
- else:
46
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
47
-
48
- # Retry
49
- search()
@@ -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,101 +0,0 @@
1
- # 17.09.24
2
-
3
- import os
4
- import sys
5
- import time
6
- import logging
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, msg
16
- from StreamingCommunity.Util.os import os_manager
17
- from StreamingCommunity.Util.message import start_message
18
- from StreamingCommunity.Util.call_stack import get_call_stack
19
- from StreamingCommunity.Util.headers import get_headers
20
- from StreamingCommunity.Lib.Downloader import HLS_Downloader
21
-
22
-
23
- # Logic class
24
- from StreamingCommunity.Api.Template.Util import execute_search
25
-
26
-
27
- # Player
28
- from StreamingCommunity.Api.Player.supervideo import VideoSource
29
-
30
-
31
- # TMBD
32
- from StreamingCommunity.Lib.TMBD import Json_film
33
-
34
-
35
- # Config
36
- from .costant import SITE_NAME, DOMAIN_NOW, MOVIE_FOLDER
37
-
38
-
39
- def download_film(movie_details: Json_film) -> str:
40
- """
41
- Downloads a film using the provided tmbd id.
42
-
43
- Parameters:
44
- - movie_details (Json_film): Class with info about film title.
45
-
46
- Return:
47
- - str: output path
48
- """
49
-
50
- # Start message and display film information
51
- start_message()
52
- console.print(f"[yellow]Download: [red]{movie_details.title} \n")
53
-
54
- # Make request to main site
55
- try:
56
- url = f"https://{SITE_NAME}.{DOMAIN_NOW}/set-movie-a/{movie_details.imdb_id}"
57
- response = httpx.get(url, headers={'User-Agent': get_headers()})
58
- response.raise_for_status()
59
-
60
- except:
61
- logging.error(f"Not found in the server. Dict: {movie_details}")
62
- raise
63
-
64
- if "not found" in str(response.text):
65
- logging.error(f"Cant find in the server, Element: {movie_details}")
66
- raise
67
-
68
- # Extract supervideo url
69
- soup = BeautifulSoup(response.text, "html.parser")
70
- player_links = soup.find("ul", class_ = "_player-mirrors").find_all("li")
71
- supervideo_url = "https:" + player_links[0].get("data-link")
72
-
73
- # Set domain and media ID for the video source
74
- video_source = VideoSource(url=supervideo_url)
75
-
76
- # Define output path
77
- title_name = os_manager.get_sanitize_file(movie_details.title) + ".mp4"
78
- mp4_path = os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
79
-
80
- # Get m3u8 master playlist
81
- master_playlist = video_source.get_playlist()
82
-
83
- # Download the film using the m3u8 playlist, and output filename
84
- r_proc = HLS_Downloader(
85
- m3u8_playlist=master_playlist,
86
- output_filename=os.path.join(mp4_path, title_name)
87
- ).start()
88
-
89
- """if r_proc == 404:
90
- time.sleep(2)
91
-
92
- # Re call search function
93
- 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":
94
- frames = get_call_stack()
95
- execute_search(frames[-4])"""
96
-
97
- if r_proc != None:
98
- console.print("[green]Result: ")
99
- console.print(r_proc)
100
-
101
- return os.path.join(mp4_path, title_name)
@@ -1,56 +0,0 @@
1
- # 21.05.24
2
-
3
- from urllib.parse import quote_plus
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Util.console import console, msg
8
-
9
-
10
- # Logic class
11
- from .site import get_version_and_domain, title_search, run_get_select_title, media_search_manager
12
- from .film import download_film
13
- from .series import download_series
14
-
15
-
16
- # Variable
17
- indice = 0
18
- _useFor = "film_serie"
19
- _deprecate = False
20
- _priority = 1
21
- _engineDownload = "hls"
22
- from .costant import SITE_NAME
23
-
24
-
25
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
26
- """
27
- Main function of the application for film and series.
28
- """
29
-
30
- if string_to_search is None:
31
- string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
32
-
33
- # Get site domain and version and get result of the search
34
- site_version, domain = get_version_and_domain()
35
- len_database = title_search(quote_plus(string_to_search), domain)
36
-
37
- # Return list of elements
38
- if get_onylDatabase:
39
- return media_search_manager
40
-
41
- if len_database > 0:
42
-
43
- # Select title from list
44
- select_title = run_get_select_title()
45
-
46
- if select_title.type == 'tv':
47
- download_series(select_title, site_version)
48
-
49
- else:
50
- download_film(select_title)
51
-
52
- else:
53
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
54
-
55
- # Retry
56
- search()
@@ -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)