StreamingCommunity 1.8.0__py3-none-any.whl → 1.9.2__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 (98) hide show
  1. StreamingCommunity/run.py +18 -13
  2. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/METADATA +157 -63
  3. StreamingCommunity-1.9.2.dist-info/RECORD +7 -0
  4. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/WHEEL +1 -1
  5. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/entry_points.txt +1 -0
  6. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
  7. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/util.py +0 -166
  8. StreamingCommunity/Src/Api/Player/ddl.py +0 -89
  9. StreamingCommunity/Src/Api/Player/maxstream.py +0 -151
  10. StreamingCommunity/Src/Api/Player/supervideo.py +0 -194
  11. StreamingCommunity/Src/Api/Player/vixcloud.py +0 -224
  12. StreamingCommunity/Src/Api/Site/1337xx/__init__.py +0 -50
  13. StreamingCommunity/Src/Api/Site/1337xx/costant.py +0 -15
  14. StreamingCommunity/Src/Api/Site/1337xx/site.py +0 -84
  15. StreamingCommunity/Src/Api/Site/1337xx/title.py +0 -66
  16. StreamingCommunity/Src/Api/Site/altadefinizione/__init__.py +0 -50
  17. StreamingCommunity/Src/Api/Site/altadefinizione/costant.py +0 -15
  18. StreamingCommunity/Src/Api/Site/altadefinizione/film.py +0 -69
  19. StreamingCommunity/Src/Api/Site/altadefinizione/site.py +0 -86
  20. StreamingCommunity/Src/Api/Site/animeunity/__init__.py +0 -50
  21. StreamingCommunity/Src/Api/Site/animeunity/anime.py +0 -126
  22. StreamingCommunity/Src/Api/Site/animeunity/costant.py +0 -15
  23. StreamingCommunity/Src/Api/Site/animeunity/film_serie.py +0 -131
  24. StreamingCommunity/Src/Api/Site/animeunity/site.py +0 -165
  25. StreamingCommunity/Src/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
  26. StreamingCommunity/Src/Api/Site/bitsearch/__init__.py +0 -51
  27. StreamingCommunity/Src/Api/Site/bitsearch/costant.py +0 -15
  28. StreamingCommunity/Src/Api/Site/bitsearch/site.py +0 -84
  29. StreamingCommunity/Src/Api/Site/bitsearch/title.py +0 -47
  30. StreamingCommunity/Src/Api/Site/cb01new/__init__.py +0 -51
  31. StreamingCommunity/Src/Api/Site/cb01new/costant.py +0 -15
  32. StreamingCommunity/Src/Api/Site/cb01new/film.py +0 -69
  33. StreamingCommunity/Src/Api/Site/cb01new/site.py +0 -74
  34. StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +0 -83
  35. StreamingCommunity/Src/Api/Site/ddlstreamitaly/__init__.py +0 -57
  36. StreamingCommunity/Src/Api/Site/ddlstreamitaly/costant.py +0 -16
  37. StreamingCommunity/Src/Api/Site/ddlstreamitaly/series.py +0 -142
  38. StreamingCommunity/Src/Api/Site/ddlstreamitaly/site.py +0 -93
  39. StreamingCommunity/Src/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -83
  40. StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +0 -110
  41. StreamingCommunity/Src/Api/Site/guardaserie/__init__.py +0 -52
  42. StreamingCommunity/Src/Api/Site/guardaserie/costant.py +0 -15
  43. StreamingCommunity/Src/Api/Site/guardaserie/series.py +0 -195
  44. StreamingCommunity/Src/Api/Site/guardaserie/site.py +0 -84
  45. StreamingCommunity/Src/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
  46. StreamingCommunity/Src/Api/Site/mostraguarda/__init__.py +0 -48
  47. StreamingCommunity/Src/Api/Site/mostraguarda/costant.py +0 -15
  48. StreamingCommunity/Src/Api/Site/mostraguarda/film.py +0 -94
  49. StreamingCommunity/Src/Api/Site/piratebays/__init__.py +0 -50
  50. StreamingCommunity/Src/Api/Site/piratebays/costant.py +0 -15
  51. StreamingCommunity/Src/Api/Site/piratebays/site.py +0 -89
  52. StreamingCommunity/Src/Api/Site/piratebays/title.py +0 -45
  53. StreamingCommunity/Src/Api/Site/streamingcommunity/__init__.py +0 -55
  54. StreamingCommunity/Src/Api/Site/streamingcommunity/costant.py +0 -15
  55. StreamingCommunity/Src/Api/Site/streamingcommunity/film.py +0 -70
  56. StreamingCommunity/Src/Api/Site/streamingcommunity/series.py +0 -203
  57. StreamingCommunity/Src/Api/Site/streamingcommunity/site.py +0 -126
  58. StreamingCommunity/Src/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -113
  59. StreamingCommunity/Src/Api/Template/Class/SearchType.py +0 -101
  60. StreamingCommunity/Src/Api/Template/Util/__init__.py +0 -5
  61. StreamingCommunity/Src/Api/Template/Util/get_domain.py +0 -137
  62. StreamingCommunity/Src/Api/Template/Util/manage_ep.py +0 -153
  63. StreamingCommunity/Src/Api/Template/Util/recall_search.py +0 -37
  64. StreamingCommunity/Src/Api/Template/__init__.py +0 -3
  65. StreamingCommunity/Src/Api/Template/site.py +0 -87
  66. StreamingCommunity/Src/Lib/Downloader/HLS/downloader.py +0 -968
  67. StreamingCommunity/Src/Lib/Downloader/HLS/proxyes.py +0 -110
  68. StreamingCommunity/Src/Lib/Downloader/HLS/segments.py +0 -540
  69. StreamingCommunity/Src/Lib/Downloader/MP4/downloader.py +0 -156
  70. StreamingCommunity/Src/Lib/Downloader/TOR/downloader.py +0 -222
  71. StreamingCommunity/Src/Lib/Downloader/__init__.py +0 -5
  72. StreamingCommunity/Src/Lib/Driver/driver_1.py +0 -76
  73. StreamingCommunity/Src/Lib/FFmpeg/__init__.py +0 -4
  74. StreamingCommunity/Src/Lib/FFmpeg/capture.py +0 -170
  75. StreamingCommunity/Src/Lib/FFmpeg/command.py +0 -292
  76. StreamingCommunity/Src/Lib/FFmpeg/util.py +0 -242
  77. StreamingCommunity/Src/Lib/M3U8/__init__.py +0 -6
  78. StreamingCommunity/Src/Lib/M3U8/decryptor.py +0 -129
  79. StreamingCommunity/Src/Lib/M3U8/estimator.py +0 -173
  80. StreamingCommunity/Src/Lib/M3U8/parser.py +0 -666
  81. StreamingCommunity/Src/Lib/M3U8/url_fixer.py +0 -52
  82. StreamingCommunity/Src/Lib/TMBD/__init__.py +0 -2
  83. StreamingCommunity/Src/Lib/TMBD/obj_tmbd.py +0 -39
  84. StreamingCommunity/Src/Lib/TMBD/tmdb.py +0 -346
  85. StreamingCommunity/Src/Upload/update.py +0 -64
  86. StreamingCommunity/Src/Upload/version.py +0 -5
  87. StreamingCommunity/Src/Util/_jsonConfig.py +0 -204
  88. StreamingCommunity/Src/Util/call_stack.py +0 -42
  89. StreamingCommunity/Src/Util/color.py +0 -20
  90. StreamingCommunity/Src/Util/console.py +0 -12
  91. StreamingCommunity/Src/Util/headers.py +0 -147
  92. StreamingCommunity/Src/Util/logger.py +0 -53
  93. StreamingCommunity/Src/Util/message.py +0 -46
  94. StreamingCommunity/Src/Util/os.py +0 -417
  95. StreamingCommunity/Src/Util/table.py +0 -163
  96. StreamingCommunity-1.8.0.dist-info/RECORD +0 -97
  97. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/LICENSE +0 -0
  98. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/top_level.txt +0 -0
@@ -1,110 +0,0 @@
1
- # 13.06.24
2
-
3
- import logging
4
- from typing import List, Dict
5
-
6
-
7
- # External libraries
8
- import httpx
9
- from bs4 import BeautifulSoup
10
-
11
-
12
- # Internal utilities
13
- from StreamingCommunity.Src.Util.headers import get_headers
14
-
15
-
16
- # Logic class
17
- from StreamingCommunity.Src.Api.Template .Class.SearchType import MediaItem
18
-
19
-
20
- class GetSerieInfo:
21
- def __init__(self, dict_serie: MediaItem) -> None:
22
- """
23
- Initializes the GetSerieInfo object with default values.
24
-
25
- Parameters:
26
- dict_serie (MediaItem): Dictionary containing series information (optional).
27
- """
28
- self.headers = {'user-agent': get_headers()}
29
- self.url = dict_serie.url
30
- self.tv_name = None
31
- self.list_episodes = None
32
-
33
- def get_seasons_number(self) -> int:
34
- """
35
- Retrieves the number of seasons of a TV series.
36
-
37
- Returns:
38
- int: Number of seasons of the TV series.
39
- """
40
- try:
41
-
42
- # Make an HTTP request to the series URL
43
- response = httpx.get(self.url, headers=self.headers, timeout=15)
44
- response.raise_for_status()
45
-
46
- # Parse HTML content of the page
47
- soup = BeautifulSoup(response.text, "html.parser")
48
-
49
- # Find the container of seasons
50
- table_content = soup.find('div', class_="tt_season")
51
-
52
- # Count the number of seasons
53
- seasons_number = len(table_content.find_all("li"))
54
-
55
- # Extract the name of the series
56
- self.tv_name = soup.find("h1", class_="front_title").get_text(strip=True)
57
-
58
- return seasons_number
59
-
60
- except Exception as e:
61
- logging.error(f"Error parsing HTML page: {e}")
62
-
63
- return -999
64
-
65
- def get_episode_number(self, n_season: int) -> List[Dict[str, str]]:
66
- """
67
- Retrieves the number of episodes for a specific season.
68
-
69
- Parameters:
70
- n_season (int): The season number.
71
-
72
- Returns:
73
- List[Dict[str, str]]: List of dictionaries containing episode information.
74
- """
75
- try:
76
-
77
- # Make an HTTP request to the series URL
78
- response = httpx.get(self.url, headers=self.headers, timeout=15)
79
- response.raise_for_status()
80
-
81
- # Parse HTML content of the page
82
- soup = BeautifulSoup(response.text, "html.parser")
83
-
84
- # Find the container of episodes for the specified season
85
- table_content = soup.find('div', class_="tab-pane", id=f"season-{n_season}")
86
-
87
- # Extract episode information
88
- episode_content = table_content.find_all("li")
89
- list_dict_episode = []
90
-
91
- for episode_div in episode_content:
92
- index = episode_div.find("a").get("data-num")
93
- link = episode_div.find("a").get("data-link")
94
- name = episode_div.find("a").get("data-title")
95
-
96
- obj_episode = {
97
- 'number': index,
98
- 'name': name,
99
- 'url': link
100
- }
101
-
102
- list_dict_episode.append(obj_episode)
103
-
104
- self.list_episodes = list_dict_episode
105
- return list_dict_episode
106
-
107
- except Exception as e:
108
- logging.error(f"Error parsing HTML page: {e}")
109
-
110
- return []
@@ -1,48 +0,0 @@
1
- # 26.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 StreamingCommunity.Src.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
-
22
-
23
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
- """
25
- Main function of the application for film and series.
26
- """
27
-
28
- if string_to_search is None:
29
- string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
30
-
31
- # Not available for the moment
32
- if get_onylDatabase:
33
- return 0
34
-
35
- # Search on database
36
- movie_id = tmdb.search_movie(unidecode(string_to_search))
37
-
38
- if movie_id is not None:
39
- movie_details: Json_film = tmdb.get_movie_details(tmdb_id=movie_id)
40
-
41
- # Download only film
42
- download_film(movie_details)
43
-
44
- else:
45
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
46
-
47
- # Retry
48
- search()
@@ -1,15 +0,0 @@
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
- MOVIE_FOLDER = "Movie"
15
- SERIES_FOLDER= "Serie"
@@ -1,94 +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.Src.Util.console import console, msg
16
- from StreamingCommunity.Src.Util.os import os_manager
17
- from StreamingCommunity.Src.Util.message import start_message
18
- from StreamingCommunity.Src.Util.call_stack import get_call_stack
19
- from StreamingCommunity.Src.Util.headers import get_headers
20
- from StreamingCommunity.Src.Lib.Downloader import HLS_Downloader
21
-
22
-
23
- # Logic class
24
- from StreamingCommunity.Src.Api.Template.Util import execute_search
25
-
26
-
27
- # Player
28
- from StreamingCommunity.Src.Api.Player.supervideo import VideoSource
29
-
30
-
31
- # TMBD
32
- from StreamingCommunity.Src.Lib.TMBD import Json_film
33
-
34
-
35
- # Config
36
- from .costant import ROOT_PATH, SITE_NAME, DOMAIN_NOW, MOVIE_FOLDER
37
-
38
-
39
- def download_film(movie_details: Json_film):
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
-
47
- # Start message and display film information
48
- start_message()
49
- console.print(f"[yellow]Download: [red]{movie_details.title} \n")
50
-
51
- # Make request to main site
52
- try:
53
- url = f"https://{SITE_NAME}.{DOMAIN_NOW}/set-movie-a/{movie_details.imdb_id}"
54
- response = httpx.get(url, headers={'User-Agent': get_headers()})
55
- response.raise_for_status()
56
-
57
- except:
58
- logging.error(f"Not found in the server. Dict: {movie_details}")
59
- raise
60
-
61
- # Extract supervideo url
62
- soup = BeautifulSoup(response.text, "html.parser")
63
- player_links = soup.find("ul", class_ = "_player-mirrors").find_all("li")
64
- supervideo_url = "https:" + player_links[0].get("data-link")
65
-
66
-
67
- # Set domain and media ID for the video source
68
- video_source = VideoSource()
69
- video_source.setup(supervideo_url)
70
-
71
- # Define output path
72
- title_name = os_manager.get_sanitize_file(movie_details.title) + ".mp4"
73
- mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
74
-
75
- # Get m3u8 master playlist
76
- master_playlist = video_source.get_playlist()
77
-
78
- # Download the film using the m3u8 playlist, and output filename
79
- r_proc = HLS_Downloader(
80
- m3u8_playlist=master_playlist,
81
- output_filename=os.path.join(mp4_path, title_name)
82
- ).start()
83
-
84
- if r_proc == 404:
85
- time.sleep(2)
86
-
87
- # Re call search function
88
- 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":
89
- frames = get_call_stack()
90
- execute_search(frames[-4])
91
-
92
- if r_proc != None:
93
- console.print("[green]Result: ")
94
- console.print(r_proc)
@@ -1,50 +0,0 @@
1
- # 02.07.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 .title import download_title
13
-
14
-
15
- # Variable
16
- indice = 8
17
- _useFor = "film_serie"
18
- _deprecate = False
19
- _priority = 2
20
- _engineDownload = "tor"
21
-
22
-
23
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
- """
25
- Main function of the application for film and series.
26
- """
27
-
28
- if string_to_search is None:
29
- string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
30
-
31
- # Search on database
32
- len_database = title_search(unidecode(string_to_search))
33
-
34
- # Return list of elements
35
- if get_onylDatabase:
36
- return media_search_manager
37
-
38
- if len_database > 0:
39
-
40
- # Select title from list
41
- select_title = run_get_select_title()
42
-
43
- # Download title
44
- download_title(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 +0,0 @@
1
- # 09.06.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 = "Film"
@@ -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.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.Class.SearchType import MediaManager
18
-
19
-
20
- # Variable
21
- from .costant import SITE_NAME, DOMAIN_NOW
22
- media_search_manager = MediaManager()
23
- table_show_manager = TVShowManager()
24
-
25
-
26
- def title_search(word_to_search: str) -> int:
27
- """
28
- Search for titles based on a search query.
29
-
30
- Parameters:
31
- - title_search (str): The title to search for.
32
-
33
- Returns:
34
- - int: The number of titles found.
35
- """
36
-
37
- # Find new domain if prev dont work
38
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
39
-
40
- # Construct the full site URL and load the search page
41
- try:
42
- response = httpx.get(
43
- url=f"https://1.{SITE_NAME}.{DOMAIN_NOW}/s/?q={word_to_search}&video=on",
44
- headers={
45
- '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',
46
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
47
- 'referer': 'https://wwv.thepiratebay3.co/',
48
- 'user-agent': get_headers()
49
- },
50
- follow_redirects=True,
51
- timeout=max_timeout
52
- )
53
- response.raise_for_status()
54
-
55
- except Exception as e:
56
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
57
-
58
- # Create soup and find table
59
- soup = BeautifulSoup(response.text, "html.parser")
60
- table = soup.find("tbody")
61
-
62
- # Scrape div film in table on single page
63
- for tr in table.find_all('tr'):
64
- try:
65
-
66
- title_info = {
67
- 'name': tr.find_all("a")[1].get_text(strip=True),
68
- 'url': tr.find_all("td")[3].find("a").get("href"),
69
- 'upload': tr.find_all("td")[2].get_text(strip=True),
70
- 'size': tr.find_all("td")[4].get_text(strip=True),
71
- 'seader': tr.find_all("td")[5].get_text(strip=True),
72
- 'leacher': tr.find_all("td")[6].get_text(strip=True),
73
- 'by': tr.find_all("td")[7].get_text(strip=True),
74
- }
75
-
76
- media_search_manager.add_media(title_info)
77
-
78
- except:
79
- continue
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,45 +0,0 @@
1
- # 02.07.24
2
-
3
- import os
4
- import sys
5
-
6
-
7
- # Internal utilities
8
- from StreamingCommunity.Src.Util.console import console
9
- from StreamingCommunity.Src.Util.message import start_message
10
- from StreamingCommunity.Src.Util.os import os_manager
11
- from StreamingCommunity.Src.Lib.Downloader import TOR_downloader
12
-
13
-
14
- # Logic class
15
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
16
-
17
-
18
- # Config
19
- from .costant import ROOT_PATH, DOMAIN_NOW, SITE_NAME, MOVIE_FOLDER
20
-
21
-
22
- def download_title(select_title: MediaItem):
23
- """
24
- Downloads a media item and saves it as an MP4 file.
25
-
26
- Parameters:
27
- - select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
28
- """
29
-
30
- start_message()
31
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
32
- print()
33
-
34
- # Define output path
35
- title_name = os_manager.get_sanitize_file(select_title.name.replace("-", "_") + ".mp4")
36
- mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
37
-
38
- # Create output folder
39
- os_manager.create_path(mp4_path)
40
-
41
- # Tor manager
42
- manager = TOR_downloader()
43
- manager.add_magnet_link(select_title.url)
44
- manager.start_download()
45
- manager.move_downloaded_files(mp4_path)
@@ -1,55 +0,0 @@
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 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
-
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("\n[purple]Insert word to search in all site").strip()
31
-
32
- # Get site domain and version and get result of the search
33
- site_version, domain = get_version_and_domain()
34
- len_database = title_search(unidecode(string_to_search), domain)
35
-
36
- # Return list of elements
37
- if get_onylDatabase:
38
- return media_search_manager
39
-
40
- if len_database > 0:
41
-
42
- # Select title from list
43
- select_title = run_get_select_title()
44
-
45
- if select_title.type == 'tv':
46
- download_series(select_title, site_version)
47
-
48
- else:
49
- download_film(select_title)
50
-
51
- else:
52
- console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
53
-
54
- # Retry
55
- search()
@@ -1,15 +0,0 @@
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('SITE', SITE_NAME)
13
-
14
- MOVIE_FOLDER = "Movie"
15
- SERIES_FOLDER = "Serie"
@@ -1,70 +0,0 @@
1
- # 3.12.23
2
-
3
- import os
4
- import time
5
-
6
-
7
- # Internal utilities
8
- from StreamingCommunity.Src.Util.console import console, msg
9
- from StreamingCommunity.Src.Util.os import os_manager
10
- from StreamingCommunity.Src.Util.message import start_message
11
- from StreamingCommunity.Src.Util.call_stack import get_call_stack
12
- from StreamingCommunity.Src.Lib.Downloader import HLS_Downloader
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Src.Api.Template.Util import execute_search
17
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
18
-
19
-
20
- # Player
21
- from StreamingCommunity.Src.Api.Player.vixcloud import VideoSource
22
-
23
-
24
- # Variable
25
- from .costant import ROOT_PATH, SITE_NAME, MOVIE_FOLDER
26
- video_source = VideoSource(SITE_NAME, False)
27
-
28
-
29
- def download_film(select_title: MediaItem):
30
- """
31
- Downloads a film using the provided film ID, title name, and domain.
32
-
33
- Parameters:
34
- - domain (str): The domain of the site
35
- - version (str): Version of site.
36
- """
37
-
38
- # Start message and display film information
39
- start_message()
40
- console.print(f"[yellow]Download: [red]{select_title.slug} \n")
41
-
42
- # Set domain and media ID for the video source
43
- video_source.setup(select_title.id)
44
-
45
- # Retrieve scws and if available master playlist
46
- video_source.get_iframe(select_title.id)
47
- video_source.get_content()
48
- master_playlist = video_source.get_playlist()
49
-
50
- # Define the filename and path for the downloaded film
51
- title_name = os_manager.get_sanitize_file(select_title.slug) + ".mp4"
52
- mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, select_title.slug)
53
-
54
- # Download the film using the m3u8 playlist, and output filename
55
- r_proc = HLS_Downloader(
56
- m3u8_playlist=master_playlist,
57
- output_filename=os.path.join(mp4_path, title_name)
58
- ).start()
59
-
60
- if r_proc == 404:
61
- time.sleep(2)
62
-
63
- # Re call search function
64
- 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":
65
- frames = get_call_stack()
66
- execute_search(frames[-4])
67
-
68
- if r_proc != None:
69
- console.print("[green]Result: ")
70
- console.print(r_proc)