StreamingCommunity 1.7.6__py3-none-any.whl → 1.9.1__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 (101) hide show
  1. StreamingCommunity/{Src/Api → Api}/Player/Helper/Vixcloud/js_parser.py +4 -1
  2. StreamingCommunity/{Src/Api → Api}/Player/Helper/Vixcloud/util.py +166 -166
  3. StreamingCommunity/{Src/Api → Api}/Player/ddl.py +89 -89
  4. StreamingCommunity/{Src/Api → Api}/Player/maxstream.py +151 -151
  5. StreamingCommunity/{Src/Api → Api}/Player/supervideo.py +193 -193
  6. StreamingCommunity/{Src/Api → Api}/Player/vixcloud.py +224 -212
  7. StreamingCommunity/{Src/Api → Api}/Site/1337xx/__init__.py +50 -50
  8. StreamingCommunity/{Src/Api → Api}/Site/1337xx/costant.py +15 -15
  9. StreamingCommunity/{Src/Api → Api}/Site/1337xx/site.py +83 -83
  10. StreamingCommunity/{Src/Api → Api}/Site/1337xx/title.py +66 -66
  11. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/__init__.py +50 -50
  12. StreamingCommunity/{Src/Api/Site/mostraguarda → Api/Site/altadefinizione}/costant.py +15 -15
  13. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/film.py +69 -69
  14. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/site.py +86 -86
  15. StreamingCommunity/{Src/Api → Api}/Site/animeunity/__init__.py +50 -50
  16. StreamingCommunity/{Src/Api/Site/altadefinizione → Api/Site/animeunity}/costant.py +15 -15
  17. StreamingCommunity/{Src/Api → Api}/Site/animeunity/film_serie.py +130 -131
  18. StreamingCommunity/{Src/Api → Api}/Site/animeunity/site.py +164 -164
  19. StreamingCommunity/{Src/Api → Api}/Site/animeunity/util/ScrapeSerie.py +3 -3
  20. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/__init__.py +51 -51
  21. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/costant.py +15 -15
  22. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/site.py +84 -84
  23. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/title.py +47 -47
  24. StreamingCommunity/{Src/Api → Api}/Site/cb01new/__init__.py +51 -51
  25. StreamingCommunity/{Src/Api → Api}/Site/cb01new/costant.py +15 -15
  26. StreamingCommunity/{Src/Api → Api}/Site/cb01new/film.py +69 -69
  27. StreamingCommunity/{Src/Api → Api}/Site/cb01new/site.py +74 -74
  28. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/__init__.py +57 -57
  29. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/costant.py +16 -16
  30. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/series.py +141 -142
  31. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/site.py +92 -92
  32. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/util/ScrapeSerie.py +84 -82
  33. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/__init__.py +52 -52
  34. StreamingCommunity/{Src/Api/Site/piratebays → Api/Site/guardaserie}/costant.py +15 -15
  35. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/series.py +195 -195
  36. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/site.py +84 -84
  37. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/util/ScrapeSerie.py +110 -110
  38. StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/__init__.py +48 -48
  39. StreamingCommunity/{Src/Api/Site/animeunity → Api/Site/mostraguarda}/costant.py +15 -15
  40. StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/film.py +94 -94
  41. StreamingCommunity/{Src/Api → Api}/Site/piratebays/__init__.py +50 -50
  42. StreamingCommunity/{Src/Api/Site/guardaserie → Api/Site/piratebays}/costant.py +15 -15
  43. StreamingCommunity/{Src/Api → Api}/Site/piratebays/site.py +88 -88
  44. StreamingCommunity/{Src/Api → Api}/Site/piratebays/title.py +45 -45
  45. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/__init__.py +55 -55
  46. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/costant.py +15 -15
  47. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/film.py +70 -70
  48. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/series.py +205 -203
  49. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/site.py +125 -125
  50. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/util/ScrapeSerie.py +3 -3
  51. StreamingCommunity/{Src/Api → Api}/Template/Class/SearchType.py +101 -101
  52. StreamingCommunity/{Src/Api → Api}/Template/Util/__init__.py +4 -4
  53. StreamingCommunity/{Src/Api → Api}/Template/Util/get_domain.py +137 -137
  54. StreamingCommunity/{Src/Api → Api}/Template/Util/manage_ep.py +153 -153
  55. StreamingCommunity/{Src/Api → Api}/Template/Util/recall_search.py +37 -37
  56. StreamingCommunity/Api/Template/__init__.py +3 -0
  57. StreamingCommunity/{Src/Api → Api}/Template/site.py +87 -87
  58. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/downloader.py +968 -968
  59. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/proxyes.py +110 -110
  60. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/segments.py +538 -540
  61. StreamingCommunity/{Src/Lib → Lib}/Downloader/MP4/downloader.py +156 -156
  62. StreamingCommunity/{Src/Lib → Lib}/Downloader/TOR/downloader.py +222 -222
  63. StreamingCommunity/{Src/Lib → Lib}/Downloader/__init__.py +4 -4
  64. StreamingCommunity/{Src/Lib → Lib}/Driver/driver_1.py +76 -76
  65. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/__init__.py +4 -4
  66. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/capture.py +170 -170
  67. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/command.py +292 -292
  68. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/util.py +241 -241
  69. StreamingCommunity/{Src/Lib → Lib}/M3U8/__init__.py +5 -5
  70. StreamingCommunity/{Src/Lib → Lib}/M3U8/decryptor.py +164 -129
  71. StreamingCommunity/{Src/Lib → Lib}/M3U8/estimator.py +175 -172
  72. StreamingCommunity/{Src/Lib → Lib}/M3U8/parser.py +666 -666
  73. StreamingCommunity/{Src/Lib → Lib}/M3U8/url_fixer.py +51 -51
  74. StreamingCommunity/Lib/TMBD/__init__.py +2 -0
  75. StreamingCommunity/{Src/Lib → Lib}/TMBD/obj_tmbd.py +39 -39
  76. StreamingCommunity/{Src/Lib → Lib}/TMBD/tmdb.py +345 -345
  77. StreamingCommunity/{Src/Upload → Upload}/update.py +68 -64
  78. StreamingCommunity/{Src/Upload → Upload}/version.py +5 -5
  79. StreamingCommunity/{Src/Util → Util}/_jsonConfig.py +204 -204
  80. StreamingCommunity/{Src/Util → Util}/call_stack.py +42 -42
  81. StreamingCommunity/{Src/Util → Util}/color.py +20 -20
  82. StreamingCommunity/{Src/Util → Util}/console.py +12 -12
  83. StreamingCommunity/Util/ffmpeg_installer.py +275 -0
  84. StreamingCommunity/{Src/Util → Util}/headers.py +147 -147
  85. StreamingCommunity/{Src/Util → Util}/logger.py +53 -53
  86. StreamingCommunity/{Src/Util → Util}/message.py +46 -46
  87. StreamingCommunity/{Src/Util → Util}/os.py +514 -417
  88. StreamingCommunity/{Src/Util → Util}/table.py +163 -163
  89. StreamingCommunity/run.py +202 -196
  90. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/METADATA +126 -60
  91. StreamingCommunity-1.9.1.dist-info/RECORD +95 -0
  92. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/WHEEL +1 -1
  93. StreamingCommunity/Src/Api/Site/animeunity/anime.py +0 -126
  94. StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +0 -83
  95. StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +0 -110
  96. StreamingCommunity/Src/Api/Template/__init__.py +0 -3
  97. StreamingCommunity/Src/Lib/TMBD/__init__.py +0 -2
  98. StreamingCommunity-1.7.6.dist-info/RECORD +0 -97
  99. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/LICENSE +0 -0
  100. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/entry_points.txt +0 -0
  101. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/top_level.txt +0 -0
@@ -1,84 +1,84 @@
1
- # 09.06.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
23
- media_search_manager = MediaManager()
24
- table_show_manager = TVShowManager()
25
-
26
-
27
- def title_search(word_to_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
-
38
- # Find new domain if prev dont work
39
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
40
- domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
41
-
42
- # Send request to search for titles
43
- try:
44
- response = httpx.get(
45
- url=f"https://guardaserie.{domain_to_use}/?story={word_to_search}&do=search&subaction=search",
46
- headers={'user-agent': get_headers()},
47
- timeout=max_timeout
48
- )
49
- response.raise_for_status()
50
-
51
- except Exception as e:
52
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
53
-
54
- # Create soup and find table
55
- soup = BeautifulSoup(response.text, "html.parser")
56
- table_content = soup.find('div', class_="mlnew-list")
57
-
58
- for serie_div in table_content.find_all('div', class_='mlnew'):
59
-
60
- try:
61
- title = serie_div.find('div', class_='mlnh-2').find("h2").get_text(strip=True)
62
- link = serie_div.find('div', class_='mlnh-2').find('a')['href']
63
- imdb_rating = serie_div.find('span', class_='mlnh-imdb').get_text(strip=True)
64
-
65
- serie_info = {
66
- 'name': title,
67
- 'url': link,
68
- 'score': imdb_rating
69
- }
70
-
71
- media_search_manager.add_media(serie_info)
72
-
73
- except:
74
- pass
75
-
76
- # Return the number of titles found
77
- return media_search_manager.get_length()
78
-
79
-
80
- def run_get_select_title():
81
- """
82
- Display a selection of titles and prompt the user to choose one.
83
- """
84
- return get_select_title(table_show_manager, media_search_manager)
1
+ # 09.06.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
23
+ media_search_manager = MediaManager()
24
+ table_show_manager = TVShowManager()
25
+
26
+
27
+ def title_search(word_to_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
+
38
+ # Find new domain if prev dont work
39
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
40
+ domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
41
+
42
+ # Send request to search for titles
43
+ try:
44
+ response = httpx.get(
45
+ url=f"https://guardaserie.{domain_to_use}/?story={word_to_search}&do=search&subaction=search",
46
+ headers={'user-agent': get_headers()},
47
+ timeout=max_timeout
48
+ )
49
+ response.raise_for_status()
50
+
51
+ except Exception as e:
52
+ console.print(f"Site: {SITE_NAME}, request search error: {e}")
53
+
54
+ # Create soup and find table
55
+ soup = BeautifulSoup(response.text, "html.parser")
56
+ table_content = soup.find('div', class_="mlnew-list")
57
+
58
+ for serie_div in table_content.find_all('div', class_='mlnew'):
59
+
60
+ try:
61
+ title = serie_div.find('div', class_='mlnh-2').find("h2").get_text(strip=True)
62
+ link = serie_div.find('div', class_='mlnh-2').find('a')['href']
63
+ imdb_rating = serie_div.find('span', class_='mlnh-imdb').get_text(strip=True)
64
+
65
+ serie_info = {
66
+ 'name': title,
67
+ 'url': link,
68
+ 'score': imdb_rating
69
+ }
70
+
71
+ media_search_manager.add_media(serie_info)
72
+
73
+ except:
74
+ pass
75
+
76
+ # Return the number of titles found
77
+ return media_search_manager.get_length()
78
+
79
+
80
+ def run_get_select_title():
81
+ """
82
+ Display a selection of titles and prompt the user to choose one.
83
+ """
84
+ return get_select_title(table_show_manager, media_search_manager)
@@ -1,110 +1,110 @@
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
+ # 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.Util.headers import get_headers
14
+
15
+
16
+ # Logic class
17
+ from StreamingCommunity.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 +1,48 @@
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
+ # 26.05.24
2
+
3
+ from unidecode import unidecode
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
+
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 +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.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 = config_manager.get('DEFAULT', 'serie_folder_name')
15
+ MOVIE_FOLDER = config_manager.get('DEFAULT', 'movie_folder_name')