StreamingCommunity 1.7.6__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 (97) hide show
  1. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/js_parser.py +140 -0
  2. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/util.py +166 -0
  3. StreamingCommunity/Src/Api/Player/ddl.py +89 -0
  4. StreamingCommunity/Src/Api/Player/maxstream.py +151 -0
  5. StreamingCommunity/Src/Api/Player/supervideo.py +194 -0
  6. StreamingCommunity/Src/Api/Player/vixcloud.py +212 -0
  7. StreamingCommunity/Src/Api/Site/1337xx/__init__.py +50 -0
  8. StreamingCommunity/Src/Api/Site/1337xx/costant.py +15 -0
  9. StreamingCommunity/Src/Api/Site/1337xx/site.py +84 -0
  10. StreamingCommunity/Src/Api/Site/1337xx/title.py +66 -0
  11. StreamingCommunity/Src/Api/Site/altadefinizione/__init__.py +50 -0
  12. StreamingCommunity/Src/Api/Site/altadefinizione/costant.py +15 -0
  13. StreamingCommunity/Src/Api/Site/altadefinizione/film.py +69 -0
  14. StreamingCommunity/Src/Api/Site/altadefinizione/site.py +86 -0
  15. StreamingCommunity/Src/Api/Site/animeunity/__init__.py +50 -0
  16. StreamingCommunity/Src/Api/Site/animeunity/anime.py +126 -0
  17. StreamingCommunity/Src/Api/Site/animeunity/costant.py +15 -0
  18. StreamingCommunity/Src/Api/Site/animeunity/film_serie.py +131 -0
  19. StreamingCommunity/Src/Api/Site/animeunity/site.py +165 -0
  20. StreamingCommunity/Src/Api/Site/animeunity/util/ScrapeSerie.py +97 -0
  21. StreamingCommunity/Src/Api/Site/bitsearch/__init__.py +51 -0
  22. StreamingCommunity/Src/Api/Site/bitsearch/costant.py +15 -0
  23. StreamingCommunity/Src/Api/Site/bitsearch/site.py +84 -0
  24. StreamingCommunity/Src/Api/Site/bitsearch/title.py +47 -0
  25. StreamingCommunity/Src/Api/Site/cb01new/__init__.py +51 -0
  26. StreamingCommunity/Src/Api/Site/cb01new/costant.py +15 -0
  27. StreamingCommunity/Src/Api/Site/cb01new/film.py +69 -0
  28. StreamingCommunity/Src/Api/Site/cb01new/site.py +74 -0
  29. StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +83 -0
  30. StreamingCommunity/Src/Api/Site/ddlstreamitaly/__init__.py +57 -0
  31. StreamingCommunity/Src/Api/Site/ddlstreamitaly/costant.py +16 -0
  32. StreamingCommunity/Src/Api/Site/ddlstreamitaly/series.py +142 -0
  33. StreamingCommunity/Src/Api/Site/ddlstreamitaly/site.py +93 -0
  34. StreamingCommunity/Src/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +83 -0
  35. StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +110 -0
  36. StreamingCommunity/Src/Api/Site/guardaserie/__init__.py +52 -0
  37. StreamingCommunity/Src/Api/Site/guardaserie/costant.py +15 -0
  38. StreamingCommunity/Src/Api/Site/guardaserie/series.py +195 -0
  39. StreamingCommunity/Src/Api/Site/guardaserie/site.py +84 -0
  40. StreamingCommunity/Src/Api/Site/guardaserie/util/ScrapeSerie.py +110 -0
  41. StreamingCommunity/Src/Api/Site/mostraguarda/__init__.py +48 -0
  42. StreamingCommunity/Src/Api/Site/mostraguarda/costant.py +15 -0
  43. StreamingCommunity/Src/Api/Site/mostraguarda/film.py +94 -0
  44. StreamingCommunity/Src/Api/Site/piratebays/__init__.py +50 -0
  45. StreamingCommunity/Src/Api/Site/piratebays/costant.py +15 -0
  46. StreamingCommunity/Src/Api/Site/piratebays/site.py +89 -0
  47. StreamingCommunity/Src/Api/Site/piratebays/title.py +45 -0
  48. StreamingCommunity/Src/Api/Site/streamingcommunity/__init__.py +55 -0
  49. StreamingCommunity/Src/Api/Site/streamingcommunity/costant.py +15 -0
  50. StreamingCommunity/Src/Api/Site/streamingcommunity/film.py +70 -0
  51. StreamingCommunity/Src/Api/Site/streamingcommunity/series.py +203 -0
  52. StreamingCommunity/Src/Api/Site/streamingcommunity/site.py +126 -0
  53. StreamingCommunity/Src/Api/Site/streamingcommunity/util/ScrapeSerie.py +113 -0
  54. StreamingCommunity/Src/Api/Template/Class/SearchType.py +101 -0
  55. StreamingCommunity/Src/Api/Template/Util/__init__.py +5 -0
  56. StreamingCommunity/Src/Api/Template/Util/get_domain.py +137 -0
  57. StreamingCommunity/Src/Api/Template/Util/manage_ep.py +153 -0
  58. StreamingCommunity/Src/Api/Template/Util/recall_search.py +37 -0
  59. StreamingCommunity/Src/Api/Template/__init__.py +3 -0
  60. StreamingCommunity/Src/Api/Template/site.py +87 -0
  61. StreamingCommunity/Src/Lib/Downloader/HLS/downloader.py +968 -0
  62. StreamingCommunity/Src/Lib/Downloader/HLS/proxyes.py +110 -0
  63. StreamingCommunity/Src/Lib/Downloader/HLS/segments.py +540 -0
  64. StreamingCommunity/Src/Lib/Downloader/MP4/downloader.py +156 -0
  65. StreamingCommunity/Src/Lib/Downloader/TOR/downloader.py +222 -0
  66. StreamingCommunity/Src/Lib/Downloader/__init__.py +5 -0
  67. StreamingCommunity/Src/Lib/Driver/driver_1.py +76 -0
  68. StreamingCommunity/Src/Lib/FFmpeg/__init__.py +4 -0
  69. StreamingCommunity/Src/Lib/FFmpeg/capture.py +170 -0
  70. StreamingCommunity/Src/Lib/FFmpeg/command.py +292 -0
  71. StreamingCommunity/Src/Lib/FFmpeg/util.py +242 -0
  72. StreamingCommunity/Src/Lib/M3U8/__init__.py +6 -0
  73. StreamingCommunity/Src/Lib/M3U8/decryptor.py +129 -0
  74. StreamingCommunity/Src/Lib/M3U8/estimator.py +173 -0
  75. StreamingCommunity/Src/Lib/M3U8/parser.py +666 -0
  76. StreamingCommunity/Src/Lib/M3U8/url_fixer.py +52 -0
  77. StreamingCommunity/Src/Lib/TMBD/__init__.py +2 -0
  78. StreamingCommunity/Src/Lib/TMBD/obj_tmbd.py +39 -0
  79. StreamingCommunity/Src/Lib/TMBD/tmdb.py +346 -0
  80. StreamingCommunity/Src/Upload/update.py +64 -0
  81. StreamingCommunity/Src/Upload/version.py +5 -0
  82. StreamingCommunity/Src/Util/_jsonConfig.py +204 -0
  83. StreamingCommunity/Src/Util/call_stack.py +42 -0
  84. StreamingCommunity/Src/Util/color.py +20 -0
  85. StreamingCommunity/Src/Util/console.py +12 -0
  86. StreamingCommunity/Src/Util/headers.py +147 -0
  87. StreamingCommunity/Src/Util/logger.py +53 -0
  88. StreamingCommunity/Src/Util/message.py +46 -0
  89. StreamingCommunity/Src/Util/os.py +417 -0
  90. StreamingCommunity/Src/Util/table.py +163 -0
  91. StreamingCommunity/run.py +196 -0
  92. StreamingCommunity-1.7.6.dist-info/LICENSE +674 -0
  93. StreamingCommunity-1.7.6.dist-info/METADATA +348 -0
  94. StreamingCommunity-1.7.6.dist-info/RECORD +97 -0
  95. StreamingCommunity-1.7.6.dist-info/WHEEL +5 -0
  96. StreamingCommunity-1.7.6.dist-info/entry_points.txt +2 -0
  97. StreamingCommunity-1.7.6.dist-info/top_level.txt +1 -0
@@ -0,0 +1,97 @@
1
+ # 01.03.24
2
+
3
+ import logging
4
+
5
+
6
+ # External libraries
7
+ import httpx
8
+
9
+
10
+ # Internal utilities
11
+ from StreamingCommunity.Src.Util.headers import get_headers
12
+ from StreamingCommunity.Src.Util._jsonConfig import config_manager
13
+ from StreamingCommunity.Src.Api.Player.Helper.Vixcloud.util import EpisodeManager, Episode
14
+
15
+
16
+ # Variable
17
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
18
+
19
+
20
+
21
+ class ScrapeSerieAnime():
22
+ def __init__(self, site_name: str):
23
+ """
24
+ Initialize the media scraper for a specific website.
25
+
26
+ Args:
27
+ site_name (str): Name of the streaming site to scrape
28
+ """
29
+ self.is_series = False
30
+ self.headers = {'user-agent': get_headers()}
31
+ self.base_name = site_name
32
+ self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
33
+
34
+ def setup(self, version: str = None, media_id: int = None, series_name: str = None):
35
+ self.version = version
36
+ self.media_id = media_id
37
+
38
+ if series_name is not None:
39
+ self.is_series = True
40
+ self.series_name = series_name
41
+ self.obj_episode_manager: EpisodeManager = EpisodeManager()
42
+
43
+ def get_count_episodes(self):
44
+ """
45
+ Retrieve total number of episodes for the selected media.
46
+
47
+ Returns:
48
+ int: Total episode count
49
+ """
50
+ try:
51
+
52
+ response = httpx.get(
53
+ url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/",
54
+ headers=self.headers,
55
+ timeout=max_timeout
56
+ )
57
+ response.raise_for_status()
58
+
59
+ # Parse JSON response and return episode count
60
+ return response.json()["episodes_count"]
61
+
62
+ except Exception as e:
63
+ logging.error(f"Error fetching episode count: {e}")
64
+ return None
65
+
66
+ def get_info_episode(self, index_ep: int) -> Episode:
67
+ """
68
+ Fetch detailed information for a specific episode.
69
+
70
+ Args:
71
+ index_ep (int): Zero-based index of the target episode
72
+
73
+ Returns:
74
+ Episode: Detailed episode information
75
+ """
76
+ try:
77
+
78
+ params = {
79
+ "start_range": index_ep,
80
+ "end_range": index_ep + 1
81
+ }
82
+
83
+ response = httpx.get(
84
+ url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/{index_ep}",
85
+ headers=self.headers,
86
+ params=params,
87
+ timeout=max_timeout
88
+ )
89
+ response.raise_for_status()
90
+
91
+ # Return information about the episode
92
+ json_data = response.json()["episodes"][-1]
93
+ return Episode(json_data)
94
+
95
+ except Exception as e:
96
+ logging.error(f"Error fetching episode information: {e}")
97
+ return None
@@ -0,0 +1,51 @@
1
+ # 01.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 = 7
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
+
47
+ else:
48
+ console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
49
+
50
+ # Retry
51
+ search()
@@ -0,0 +1,15 @@
1
+ # 01.07.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"
@@ -0,0 +1,84 @@
1
+ # 01.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.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
+ # Construct the full site URL and load the search page
43
+ try:
44
+ response = httpx.get(
45
+ url=f"https://{SITE_NAME}.{domain_to_use}/search?q={word_to_search}&category=1&subcat=2&page=1",
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
+
57
+ for title_div in soup.find_all("li", class_ = "card"):
58
+ try:
59
+ div_stats = title_div.find("div", class_ = "stats")
60
+
61
+ title_info = {
62
+ 'name': title_div.find("a").get_text(strip=True),
63
+ 'url': title_div.find_all("a")[-1].get("href"),
64
+ #'nDownload': div_stats.find_all("div")[0].get_text(strip=True),
65
+ 'size': div_stats.find_all("div")[1].get_text(strip=True),
66
+ 'seader': div_stats.find_all("div")[2].get_text(strip=True),
67
+ 'leacher': div_stats.find_all("div")[3].get_text(strip=True),
68
+ 'date': div_stats.find_all("div")[4].get_text(strip=True)
69
+ }
70
+
71
+ media_search_manager.add_media(title_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)
@@ -0,0 +1,47 @@
1
+ # 01.07.24
2
+
3
+ import os
4
+
5
+
6
+ # Internal utilities
7
+ from StreamingCommunity.Src.Util.console import console
8
+ from StreamingCommunity.Src.Util.message import start_message
9
+ from StreamingCommunity.Src.Util.os import os_manager
10
+ from StreamingCommunity.Src.Lib.Downloader import TOR_downloader
11
+
12
+
13
+ # Logic class
14
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
15
+
16
+
17
+ # Config
18
+ from .costant import ROOT_PATH, SITE_NAME, 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
+
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_manager.get_sanitize_path(
37
+ os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
38
+ )
39
+
40
+ # Create output folder
41
+ os_manager.create_path(mp4_path)
42
+
43
+ # Tor manager
44
+ manager = TOR_downloader()
45
+ manager.add_magnet_link(select_title.url)
46
+ manager.start_download()
47
+ manager.move_downloaded_files(mp4_path)
@@ -0,0 +1,51 @@
1
+ # 09.06.24
2
+
3
+ from unidecode import unidecode
4
+
5
+
6
+ # Internal utilities
7
+ from StreamingCommunity.Src.Util.console import console, msg
8
+
9
+
10
+ # Logic class
11
+ from .site import title_search, run_get_select_title, media_search_manager
12
+ from .film import download_film
13
+
14
+
15
+ # Variable
16
+ indice = 9
17
+ _useFor = "film"
18
+ _deprecate = False
19
+ _priority = 2
20
+ _engineDownload = "mp4"
21
+
22
+
23
+ def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
+ """
25
+ 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
+ # !!! ADD TYPE DONT WORK FOR SERIE
44
+ download_film(select_title)
45
+
46
+
47
+ else:
48
+ console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
49
+
50
+ # Retry
51
+ search()
@@ -0,0 +1,15 @@
1
+ # 03.07.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"
@@ -0,0 +1,69 @@
1
+ # 03.07.24
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.maxstream import VideoSource
22
+
23
+
24
+ # Config
25
+ from .costant import ROOT_PATH, SITE_NAME, MOVIE_FOLDER
26
+
27
+
28
+ def download_film(select_title: MediaItem):
29
+ """
30
+ Downloads a film using the provided obj.
31
+
32
+ Parameters:
33
+ - select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
34
+ """
35
+
36
+ # Start message and display film information
37
+ start_message()
38
+ console.print(f"[yellow]Download: [red]{select_title.name} \n")
39
+
40
+ # Setup api manger
41
+ print(select_title.url)
42
+ video_source = VideoSource(select_title.url)
43
+
44
+ # Define output path
45
+ title_name = os_manager.get_sanitize_file(select_title.name) +".mp4"
46
+ mp4_path = os_manager.get_sanitize_path(
47
+ os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
48
+ )
49
+
50
+ # Get m3u8 master playlist
51
+ master_playlist = video_source.get_playlist()
52
+
53
+ # Download the film using the m3u8 playlist, and output filename
54
+ r_proc = HLS_Downloader(
55
+ m3u8_playlist=master_playlist,
56
+ output_filename=os.path.join(mp4_path, title_name)
57
+ ).start()
58
+
59
+ if r_proc == 404:
60
+ time.sleep(2)
61
+
62
+ # Re call search function
63
+ 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":
64
+ frames = get_call_stack()
65
+ execute_search(frames[-4])
66
+
67
+ if r_proc != None:
68
+ console.print("[green]Result: ")
69
+ console.print(r_proc)
@@ -0,0 +1,74 @@
1
+ # 03.07.24
2
+
3
+ # External libraries
4
+ import httpx
5
+ from bs4 import BeautifulSoup
6
+
7
+
8
+ # Internal utilities
9
+ from StreamingCommunity.Src.Util._jsonConfig import config_manager
10
+ from StreamingCommunity.Src.Util.headers import get_headers
11
+ from StreamingCommunity.Src.Util.table import TVShowManager
12
+
13
+
14
+ # Logic class
15
+ from StreamingCommunity.Src.Api.Template import get_select_title
16
+ from StreamingCommunity.Src.Api.Template.Util import search_domain
17
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
18
+
19
+
20
+ # Variable
21
+ from .costant import SITE_NAME
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
+ domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
40
+
41
+ response = httpx.get(
42
+ url=f"https://{SITE_NAME}.{domain_to_use}/?s={word_to_search}",
43
+ headers={'user-agent': get_headers()},
44
+ timeout=max_timeout
45
+ )
46
+ response.raise_for_status()
47
+
48
+ # Create soup and find table
49
+ soup = BeautifulSoup(response.text, "html.parser")
50
+
51
+ # For all element in table
52
+ for div in soup.find_all("div", class_ = "card-content"):
53
+
54
+ url = div.find("h3").find("a").get("href")
55
+ title = div.find("h3").find("a").get_text(strip=True)
56
+ desc = div.find("p").find("strong").text
57
+
58
+ title_info = {
59
+ 'name': title,
60
+ 'desc': desc,
61
+ 'url': url
62
+ }
63
+
64
+ media_search_manager.add_media(title_info)
65
+
66
+ # Return the number of titles found
67
+ return media_search_manager.get_length()
68
+
69
+
70
+ def run_get_select_title():
71
+ """
72
+ Display a selection of titles and prompt the user to choose one.
73
+ """
74
+ return get_select_title(table_show_manager, media_search_manager)
@@ -0,0 +1,83 @@
1
+ # 13.06.24
2
+
3
+ import sys
4
+ import logging
5
+ from typing import List, Dict
6
+
7
+
8
+ # External libraries
9
+ import httpx
10
+ from bs4 import BeautifulSoup
11
+
12
+
13
+ # Internal utilities
14
+ from StreamingCommunity.Src.Util.headers import get_headers
15
+
16
+
17
+ # Logic class
18
+ from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
19
+
20
+
21
+ # Variable
22
+ from ..costant import COOKIE
23
+
24
+
25
+ class GetSerieInfo:
26
+ def __init__(self, dict_serie: MediaItem) -> None:
27
+ """
28
+ Initializes the GetSerieInfo object with default values.
29
+
30
+ Parameters:
31
+ - dict_serie (MediaItem): Dictionary containing series information (optional).
32
+ """
33
+ self.headers = {'user-agent': get_headers()}
34
+ self.cookies = COOKIE
35
+ self.url = dict_serie.url
36
+ self.tv_name = None
37
+ self.list_episodes = None
38
+
39
+ def get_episode_number(self) -> List[Dict[str, str]]:
40
+ """
41
+ Retrieves the number of episodes for a specific season.
42
+
43
+ Parameters:
44
+ n_season (int): The season number.
45
+
46
+ Returns:
47
+ List[Dict[str, str]]: List of dictionaries containing episode information.
48
+ """
49
+
50
+ try:
51
+ response = httpx.get(self.url + "?area=online", cookies=self.cookies, headers=self.headers, timeout=10)
52
+ response.raise_for_status()
53
+
54
+ except:
55
+ logging.error(f"Insert value for [ips4_device_key, ips4_member_id, ips4_login_key] in config.json file SITE \\ ddlstreamitaly \\ cookie. Use browser debug and cookie request with a valid account, filter by DOC.")
56
+ sys.exit(0)
57
+
58
+ # Parse HTML content of the page
59
+ soup = BeautifulSoup(response.text, "html.parser")
60
+
61
+ # Get tv name
62
+ self.tv_name = soup.find("span", class_= "ipsType_break").get_text(strip=True)
63
+
64
+ # Find the container of episodes for the specified season
65
+ table_content = soup.find('div', class_='ipsMargin_bottom:half')
66
+ list_dict_episode = []
67
+
68
+ for episode_div in table_content.find_all('a', href=True):
69
+
70
+ # Get text of episode
71
+ part_name = episode_div.get_text(strip=True)
72
+
73
+ if part_name:
74
+ obj_episode = {
75
+ 'name': part_name,
76
+ 'url': episode_div['href']
77
+ }
78
+
79
+ list_dict_episode.append(obj_episode)
80
+
81
+ self.list_episodes = list_dict_episode
82
+ return list_dict_episode
83
+
@@ -0,0 +1,57 @@
1
+ # 09.06.24
2
+
3
+ import logging
4
+ from unidecode import unidecode
5
+
6
+
7
+ # Internal utilities
8
+ from StreamingCommunity.Src.Util.console import console, msg
9
+
10
+
11
+ # Logic class
12
+ from .site import title_search, run_get_select_title, media_search_manager
13
+ from .series import download_thread
14
+
15
+
16
+ # Variable
17
+ indice = 3
18
+ _useFor = "serie"
19
+ _deprecate = False
20
+ _priority = 2
21
+ _engineDownload = "mp4"
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
+
31
+ # Make request to site to get content that corrsisponde to that string
32
+ string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
33
+
34
+ # Search on database
35
+ len_database = title_search(unidecode(string_to_search))
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
+ # Download only film
47
+ if "Serie TV" in str(select_title.type):
48
+ download_thread(select_title)
49
+
50
+ else:
51
+ logging.error(f"Not supported: {select_title.type}")
52
+
53
+ else:
54
+ console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
55
+
56
+ # Retry
57
+ search()
@@ -0,0 +1,16 @@
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
+ COOKIE = config_manager.get_dict('SITE', SITE_NAME)['cookie']
14
+
15
+ MOVIE_FOLDER = "Movie"
16
+ SERIES_FOLDER = "Serie"