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,89 +0,0 @@
1
- # 02.07.24
2
-
3
- # External libraries
4
- import httpx
5
- from bs4 import BeautifulSoup
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Util.console import console
10
- from StreamingCommunity.Util._jsonConfig import config_manager
11
- from StreamingCommunity.Util.headers import get_headers
12
- from StreamingCommunity.Util.table import TVShowManager
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Api.Template import get_select_title
17
- from StreamingCommunity.Api.Template.Util import search_domain
18
- from StreamingCommunity.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
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
26
- disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
27
-
28
-
29
- def title_search(word_to_search: str) -> int:
30
- """
31
- Search for titles based on a search query.
32
-
33
- Parameters:
34
- - title_search (str): The title to search for.
35
-
36
- Returns:
37
- - int: The number of titles found.
38
- """
39
- media_search_manager.clear()
40
- table_show_manager.clear()
41
-
42
- # Find new domain if prev dont work
43
- domain_to_use = DOMAIN_NOW
44
-
45
- if not disable_searchDomain:
46
- domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}")
47
-
48
- # Construct the full site URL and load the search page
49
- try:
50
- response = httpx.get(
51
- url=f"https://{SITE_NAME}.{domain_to_use}/search/{word_to_search}/1/",
52
- headers={'user-agent': get_headers()},
53
- follow_redirects=True,
54
- timeout=max_timeout
55
- )
56
- response.raise_for_status()
57
-
58
- except Exception as e:
59
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
60
-
61
- # Create soup and find table
62
- soup = BeautifulSoup(response.text, "html.parser")
63
-
64
- for tr in soup.find_all('tr'):
65
- try:
66
-
67
- title_info = {
68
- 'name': tr.find_all("a")[1].get_text(strip=True),
69
- 'url': tr.find_all("a")[1].get("href"),
70
- 'seader': tr.find_all("td")[-5].get_text(strip=True),
71
- 'leacher': tr.find_all("td")[-4].get_text(strip=True),
72
- 'date': tr.find_all("td")[-3].get_text(strip=True).replace("'", ""),
73
- 'size': tr.find_all("td")[-2].get_text(strip=True)
74
- }
75
-
76
- media_search_manager.add_media(title_info)
77
-
78
- except Exception as e:
79
- print(f"Error parsing a film entry: {e}")
80
-
81
- # Return the number of titles found
82
- return media_search_manager.get_length()
83
-
84
-
85
- def run_get_select_title():
86
- """
87
- Display a selection of titles and prompt the user to choose one.
88
- """
89
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,66 +0,0 @@
1
- # 02.07.24
2
-
3
- import os
4
-
5
-
6
- # External libraries
7
- import httpx
8
- from bs4 import BeautifulSoup
9
-
10
-
11
- # Internal utilities
12
- from StreamingCommunity.Util.console import console
13
- from StreamingCommunity.Util.os import os_manager
14
- from StreamingCommunity.Util.message import start_message
15
- from StreamingCommunity.Util.headers import get_headers
16
- from StreamingCommunity.Lib.Downloader import TOR_downloader
17
-
18
-
19
- # Logic class
20
- from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
21
-
22
-
23
- # Config
24
- from .costant import DOMAIN_NOW, SITE_NAME, MOVIE_FOLDER
25
-
26
-
27
- def download_title(select_title: MediaItem):
28
- """
29
- Downloads a media item and saves it as an MP4 file.
30
-
31
- Parameters:
32
- - select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
33
- """
34
-
35
- start_message()
36
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
37
- print()
38
-
39
- # Define output path
40
- title_name = os_manager.get_sanitize_file(select_title.name)
41
- mp4_path = os_manager.get_sanitize_path(
42
- os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
43
- )
44
-
45
- # Create output folder
46
- os_manager.create_path(mp4_path)
47
-
48
- # Make request to page with magnet
49
- full_site_name = f"{SITE_NAME}.{DOMAIN_NOW}"
50
- response = httpx.get(
51
- url="https://" + full_site_name + select_title.url,
52
- headers={
53
- 'user-agent': get_headers()
54
- },
55
- follow_redirects=True
56
- )
57
-
58
- # Create soup and find table
59
- soup = BeautifulSoup(response.text, "html.parser")
60
- final_url = soup.find("a", class_="torrentdown1").get("href")
61
-
62
- # Tor manager
63
- manager = TOR_downloader()
64
- manager.add_magnet_link(final_url)
65
- manager.start_download()
66
- manager.move_downloaded_files(mp4_path)
@@ -1,51 +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 .site import title_search, run_get_select_title, media_search_manager
12
- from .film import download_film
13
-
14
-
15
- # Variable
16
- indice = 2
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
- # Search on database
33
- len_database = title_search(quote_plus(string_to_search))
34
-
35
- # Return list of elements
36
- if get_onylDatabase:
37
- return media_search_manager
38
-
39
- if len_database > 0:
40
-
41
- # Select title from list
42
- select_title = run_get_select_title()
43
-
44
- # Download only film
45
- download_film(select_title)
46
-
47
- else:
48
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
49
-
50
- # Retry
51
- 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,74 +0,0 @@
1
- # 26.05.24
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.supervideo import VideoSource
22
-
23
-
24
- # Config
25
- from .costant import 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
- - title_name (str): The name of the film title.
34
- - url (str): The url of the video
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
- # Set domain and media ID for the video source
45
- video_source = VideoSource(select_title.url)
46
-
47
- # Define output path
48
- title_name = os_manager.get_sanitize_file(select_title.name) + ".mp4"
49
- mp4_path = os_manager.get_sanitize_path(
50
- os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
51
- )
52
-
53
- # Get m3u8 master playlist
54
- master_playlist = video_source.get_playlist()
55
-
56
- # Download the film using the m3u8 playlist, and output filename
57
- r_proc = HLS_Downloader(
58
- m3u8_playlist=master_playlist,
59
- output_filename=os.path.join(mp4_path, title_name)
60
- ).start()
61
-
62
- """if r_proc == 404:
63
- time.sleep(2)
64
-
65
- # Re call search function
66
- 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":
67
- frames = get_call_stack()
68
- execute_search(frames[-4])"""
69
-
70
- if r_proc != None:
71
- console.print("[green]Result: ")
72
- console.print(r_proc)
73
-
74
- return os.path.join(mp4_path, title_name)
@@ -1,95 +0,0 @@
1
- # 26.05.24
2
-
3
- # External libraries
4
- import httpx
5
- from bs4 import BeautifulSoup
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Util.console import console
10
- from StreamingCommunity.Util._jsonConfig import config_manager
11
- from StreamingCommunity.Util.headers import get_headers
12
- from StreamingCommunity.Util.table import TVShowManager
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Api.Template import get_select_title
17
- from StreamingCommunity.Api.Template.Util import search_domain
18
- from StreamingCommunity.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
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
26
- disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
27
-
28
-
29
- def title_search(title_search: str) -> int:
30
- """
31
- Search for titles based on a search query.
32
-
33
- Parameters:
34
- - title_search (str): The title to search for.
35
-
36
- Returns:
37
- int: The number of titles found.
38
- """
39
- media_search_manager.clear()
40
- table_show_manager.clear()
41
-
42
- # Find new domain if prev dont work
43
- domain_to_use = DOMAIN_NOW
44
-
45
- if not disable_searchDomain:
46
- domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}")
47
-
48
- # Send request to search for title
49
- client = httpx.Client()
50
-
51
- try:
52
- response = client.get(
53
- url=f"https://{SITE_NAME}.{domain_to_use}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
54
- headers={'User-Agent': get_headers()},
55
- timeout=max_timeout
56
- )
57
- response.raise_for_status()
58
-
59
- except Exception as e:
60
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
61
- raise
62
-
63
- # Create soup and find table
64
- soup = BeautifulSoup(response.text, "html.parser")
65
-
66
- for row in soup.find_all('div', class_='col-lg-3 col-md-3 col-xs-4'):
67
- try:
68
-
69
- title_element = row.find('h2', class_='titleFilm').find('a')
70
- title = title_element.get_text(strip=True)
71
- link = title_element['href']
72
-
73
- imdb_element = row.find('div', class_='imdb-rate')
74
- imdb_rating = imdb_element.get_text(strip=True).split(":")[-1]
75
-
76
- film_info = {
77
- 'name': title,
78
- 'url': link,
79
- 'score': imdb_rating
80
- }
81
-
82
- media_search_manager.add_media(film_info)
83
-
84
- except AttributeError as e:
85
- print(f"Error parsing a film entry: {e}")
86
-
87
- # Return the number of titles found
88
- return media_search_manager.get_length()
89
-
90
-
91
- def run_get_select_title():
92
- """
93
- Display a selection of titles and prompt the user to choose one.
94
- """
95
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,51 +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 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
- from .costant import SITE_NAME
22
-
23
-
24
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
25
-
26
- if string_to_search is None:
27
- string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
28
-
29
- # Search on database
30
- len_database = title_search(quote_plus(string_to_search))
31
-
32
- # Return list of elements
33
- if get_onylDatabase:
34
- return media_search_manager
35
-
36
- if len_database > 0:
37
-
38
- # Select title from list (type: TV \ Movie \ OVA)
39
- select_title = run_get_select_title()
40
-
41
- if select_title.type == 'Movie' or select_title.type == 'OVA':
42
- download_film(select_title)
43
-
44
- else:
45
- download_series(select_title)
46
-
47
- else:
48
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
49
-
50
- # Retry
51
- 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,135 +0,0 @@
1
- # 11.03.24
2
-
3
- import os
4
- import sys
5
- import logging
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Util.console import console, msg
10
- from StreamingCommunity.Util.os import os_manager
11
- from StreamingCommunity.Util.message import start_message
12
- from StreamingCommunity.Lib.Downloader import MP4_downloader
13
-
14
-
15
- # Logic class
16
- from .util.ScrapeSerie import ScrapeSerieAnime
17
- from StreamingCommunity.Api.Template.Util import manage_selection
18
- from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
19
-
20
-
21
- # Player
22
- from StreamingCommunity.Api.Player.vixcloud import VideoSourceAnime
23
-
24
-
25
- # Variable
26
- from .costant import SITE_NAME, SERIES_FOLDER, MOVIE_FOLDER
27
-
28
-
29
-
30
- def download_episode(index_select: int, scrape_serie: ScrapeSerieAnime, video_source: VideoSourceAnime) -> str:
31
- """
32
- Downloads the selected episode.
33
-
34
- Parameters:
35
- - index_select (int): Index of the episode to download.
36
-
37
- Return:
38
- - str: output path
39
- """
40
-
41
- # Get information about the selected episode
42
- obj_episode = scrape_serie.get_info_episode(index_select)
43
-
44
- if obj_episode is not None:
45
-
46
- start_message()
47
- console.print(f"[yellow]Download: [red]EP_{obj_episode.number} \n")
48
-
49
- # Collect mp4 url
50
- video_source.get_embed(obj_episode.id)
51
-
52
- # Create output path
53
- title_name = f"{obj_episode.number}.mp4"
54
-
55
- if scrape_serie.is_series:
56
- mp4_path = os_manager.get_sanitize_path(
57
- os.path.join(SERIES_FOLDER, scrape_serie.series_name)
58
- )
59
- else:
60
- mp4_path = os_manager.get_sanitize_path(
61
- os.path.join(MOVIE_FOLDER, scrape_serie.series_name)
62
- )
63
-
64
- # Create output folder
65
- os_manager.create_path(mp4_path)
66
-
67
- # Start downloading
68
- r_proc = MP4_downloader(
69
- url=str(video_source.src_mp4).strip(),
70
- path=os.path.join(mp4_path, title_name)
71
- )
72
-
73
- if r_proc != None:
74
- console.print("[green]Result: ")
75
- console.print(r_proc)
76
-
77
- return os.path.join(mp4_path, title_name)
78
-
79
- else:
80
- logging.error(f"Skip index: {index_select} cant find info with api.")
81
-
82
-
83
- def download_series(select_title: MediaItem):
84
- """
85
- Function to download episodes of a TV series.
86
-
87
- Parameters:
88
- - tv_id (int): The ID of the TV series.
89
- - tv_name (str): The name of the TV series.
90
- """
91
- scrape_serie = ScrapeSerieAnime(SITE_NAME)
92
- video_source = VideoSourceAnime(SITE_NAME)
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, scrape_serie, video_source)
110
-
111
- # Download all other episodes selecter
112
- else:
113
- for i_episode in list_episode_select:
114
- download_episode(i_episode-1, scrape_serie, video_source)
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
- # Init class
127
- scrape_serie = ScrapeSerieAnime(SITE_NAME)
128
- video_source = VideoSourceAnime(SITE_NAME)
129
-
130
- # Set up video source
131
- scrape_serie.setup(None, select_title.id, select_title.slug)
132
- scrape_serie.is_series = False
133
-
134
- # Start download
135
- download_episode(0, scrape_serie, video_source)