StreamingCommunity 1.9.1__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 (96) hide show
  1. StreamingCommunity/run.py +2 -3
  2. {StreamingCommunity-1.9.1.dist-info → StreamingCommunity-1.9.2.dist-info}/METADATA +32 -4
  3. StreamingCommunity-1.9.2.dist-info/RECORD +7 -0
  4. {StreamingCommunity-1.9.1.dist-info → StreamingCommunity-1.9.2.dist-info}/WHEEL +1 -1
  5. {StreamingCommunity-1.9.1.dist-info → StreamingCommunity-1.9.2.dist-info}/entry_points.txt +1 -0
  6. StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
  7. StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +0 -166
  8. StreamingCommunity/Api/Player/ddl.py +0 -89
  9. StreamingCommunity/Api/Player/maxstream.py +0 -151
  10. StreamingCommunity/Api/Player/supervideo.py +0 -194
  11. StreamingCommunity/Api/Player/vixcloud.py +0 -224
  12. StreamingCommunity/Api/Site/1337xx/__init__.py +0 -50
  13. StreamingCommunity/Api/Site/1337xx/costant.py +0 -15
  14. StreamingCommunity/Api/Site/1337xx/site.py +0 -84
  15. StreamingCommunity/Api/Site/1337xx/title.py +0 -66
  16. StreamingCommunity/Api/Site/altadefinizione/__init__.py +0 -50
  17. StreamingCommunity/Api/Site/altadefinizione/costant.py +0 -15
  18. StreamingCommunity/Api/Site/altadefinizione/film.py +0 -69
  19. StreamingCommunity/Api/Site/altadefinizione/site.py +0 -86
  20. StreamingCommunity/Api/Site/animeunity/__init__.py +0 -50
  21. StreamingCommunity/Api/Site/animeunity/costant.py +0 -15
  22. StreamingCommunity/Api/Site/animeunity/film_serie.py +0 -130
  23. StreamingCommunity/Api/Site/animeunity/site.py +0 -165
  24. StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
  25. StreamingCommunity/Api/Site/bitsearch/__init__.py +0 -51
  26. StreamingCommunity/Api/Site/bitsearch/costant.py +0 -15
  27. StreamingCommunity/Api/Site/bitsearch/site.py +0 -84
  28. StreamingCommunity/Api/Site/bitsearch/title.py +0 -47
  29. StreamingCommunity/Api/Site/cb01new/__init__.py +0 -51
  30. StreamingCommunity/Api/Site/cb01new/costant.py +0 -15
  31. StreamingCommunity/Api/Site/cb01new/film.py +0 -69
  32. StreamingCommunity/Api/Site/cb01new/site.py +0 -74
  33. StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +0 -57
  34. StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +0 -16
  35. StreamingCommunity/Api/Site/ddlstreamitaly/series.py +0 -141
  36. StreamingCommunity/Api/Site/ddlstreamitaly/site.py +0 -93
  37. StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -85
  38. StreamingCommunity/Api/Site/guardaserie/__init__.py +0 -52
  39. StreamingCommunity/Api/Site/guardaserie/costant.py +0 -15
  40. StreamingCommunity/Api/Site/guardaserie/series.py +0 -195
  41. StreamingCommunity/Api/Site/guardaserie/site.py +0 -84
  42. StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
  43. StreamingCommunity/Api/Site/mostraguarda/__init__.py +0 -48
  44. StreamingCommunity/Api/Site/mostraguarda/costant.py +0 -15
  45. StreamingCommunity/Api/Site/mostraguarda/film.py +0 -94
  46. StreamingCommunity/Api/Site/piratebays/__init__.py +0 -50
  47. StreamingCommunity/Api/Site/piratebays/costant.py +0 -15
  48. StreamingCommunity/Api/Site/piratebays/site.py +0 -89
  49. StreamingCommunity/Api/Site/piratebays/title.py +0 -45
  50. StreamingCommunity/Api/Site/streamingcommunity/__init__.py +0 -55
  51. StreamingCommunity/Api/Site/streamingcommunity/costant.py +0 -15
  52. StreamingCommunity/Api/Site/streamingcommunity/film.py +0 -70
  53. StreamingCommunity/Api/Site/streamingcommunity/series.py +0 -205
  54. StreamingCommunity/Api/Site/streamingcommunity/site.py +0 -126
  55. StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -113
  56. StreamingCommunity/Api/Template/Class/SearchType.py +0 -101
  57. StreamingCommunity/Api/Template/Util/__init__.py +0 -5
  58. StreamingCommunity/Api/Template/Util/get_domain.py +0 -137
  59. StreamingCommunity/Api/Template/Util/manage_ep.py +0 -153
  60. StreamingCommunity/Api/Template/Util/recall_search.py +0 -37
  61. StreamingCommunity/Api/Template/__init__.py +0 -3
  62. StreamingCommunity/Api/Template/site.py +0 -87
  63. StreamingCommunity/Lib/Downloader/HLS/downloader.py +0 -968
  64. StreamingCommunity/Lib/Downloader/HLS/proxyes.py +0 -110
  65. StreamingCommunity/Lib/Downloader/HLS/segments.py +0 -538
  66. StreamingCommunity/Lib/Downloader/MP4/downloader.py +0 -156
  67. StreamingCommunity/Lib/Downloader/TOR/downloader.py +0 -222
  68. StreamingCommunity/Lib/Downloader/__init__.py +0 -5
  69. StreamingCommunity/Lib/Driver/driver_1.py +0 -76
  70. StreamingCommunity/Lib/FFmpeg/__init__.py +0 -4
  71. StreamingCommunity/Lib/FFmpeg/capture.py +0 -170
  72. StreamingCommunity/Lib/FFmpeg/command.py +0 -292
  73. StreamingCommunity/Lib/FFmpeg/util.py +0 -242
  74. StreamingCommunity/Lib/M3U8/__init__.py +0 -6
  75. StreamingCommunity/Lib/M3U8/decryptor.py +0 -164
  76. StreamingCommunity/Lib/M3U8/estimator.py +0 -176
  77. StreamingCommunity/Lib/M3U8/parser.py +0 -666
  78. StreamingCommunity/Lib/M3U8/url_fixer.py +0 -52
  79. StreamingCommunity/Lib/TMBD/__init__.py +0 -2
  80. StreamingCommunity/Lib/TMBD/obj_tmbd.py +0 -39
  81. StreamingCommunity/Lib/TMBD/tmdb.py +0 -346
  82. StreamingCommunity/Upload/update.py +0 -68
  83. StreamingCommunity/Upload/version.py +0 -5
  84. StreamingCommunity/Util/_jsonConfig.py +0 -204
  85. StreamingCommunity/Util/call_stack.py +0 -42
  86. StreamingCommunity/Util/color.py +0 -20
  87. StreamingCommunity/Util/console.py +0 -12
  88. StreamingCommunity/Util/ffmpeg_installer.py +0 -275
  89. StreamingCommunity/Util/headers.py +0 -147
  90. StreamingCommunity/Util/logger.py +0 -53
  91. StreamingCommunity/Util/message.py +0 -46
  92. StreamingCommunity/Util/os.py +0 -514
  93. StreamingCommunity/Util/table.py +0 -163
  94. StreamingCommunity-1.9.1.dist-info/RECORD +0 -95
  95. {StreamingCommunity-1.9.1.dist-info → StreamingCommunity-1.9.2.dist-info}/LICENSE +0 -0
  96. {StreamingCommunity-1.9.1.dist-info → StreamingCommunity-1.9.2.dist-info}/top_level.txt +0 -0
@@ -1,69 +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 ROOT_PATH, SITE_NAME, MOVIE_FOLDER
26
-
27
-
28
- def download_film(select_title: MediaItem):
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
-
37
- # Start message and display film information
38
- start_message()
39
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
40
-
41
- # Set domain and media ID for the video source
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)
@@ -1,86 +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
-
26
-
27
- def title_search(title_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
- client = httpx.Client()
38
-
39
- # Find new domain if prev dont work
40
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
41
- #domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
42
-
43
- # Send request to search for title
44
- try:
45
- response = client.get(
46
- url=f"https://{SITE_NAME}.{DOMAIN_NOW}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
47
- headers={
48
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
49
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
50
- 'User-Agent': get_headers()
51
- },
52
- timeout=max_timeout
53
- )
54
- response.raise_for_status()
55
-
56
- except Exception as e:
57
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
58
- raise
59
-
60
- # Create soup and find table
61
- soup = BeautifulSoup(response.text, "html.parser")
62
- table_content = soup.find('div', id="dle-content")
63
-
64
- # Scrape div film in table on single page
65
- for film_div in table_content.find_all('div', class_='col-lg-3'):
66
- title = film_div.find('h2', class_='titleFilm').get_text(strip=True)
67
- link = film_div.find('h2', class_='titleFilm').find('a')['href']
68
- imdb_rating = film_div.find('div', class_='imdb-rate').get_text(strip=True).split(":")[-1]
69
-
70
- film_info = {
71
- 'name': title,
72
- 'url': link,
73
- 'score': imdb_rating
74
- }
75
-
76
- media_search_manager.add_media(film_info)
77
-
78
- # Return the number of titles found
79
- return media_search_manager.get_length()
80
-
81
-
82
- def run_get_select_title():
83
- """
84
- Display a selection of titles and prompt the user to choose one.
85
- """
86
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,50 +0,0 @@
1
- # 21.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 .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
-
22
-
23
- def search(string_to_search: str = None, get_onylDatabase: bool = False):
24
-
25
- if string_to_search is None:
26
- string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
27
-
28
- # Search on database
29
- len_database = title_search(unidecode(string_to_search))
30
-
31
- # Return list of elements
32
- if get_onylDatabase:
33
- return media_search_manager
34
-
35
- if len_database > 0:
36
-
37
- # Select title from list (type: TV \ Movie \ OVA)
38
- select_title = run_get_select_title()
39
-
40
- if select_title.type == 'Movie' or select_title.type == 'OVA':
41
- download_film(select_title)
42
-
43
- else:
44
- download_series(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
- # 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')
@@ -1,130 +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 ROOT_PATH, SITE_NAME, SERIES_FOLDER, MOVIE_FOLDER
27
-
28
-
29
-
30
- def download_episode(index_select: int, scrape_serie: ScrapeSerieAnime, video_source: VideoSourceAnime):
31
- """
32
- Downloads the selected episode.
33
-
34
- Parameters:
35
- - index_select (int): Index of the episode to download.
36
- """
37
-
38
- # Get information about the selected episode
39
- obj_episode = scrape_serie.get_info_episode(index_select)
40
-
41
- if obj_episode is not None:
42
-
43
- start_message()
44
- console.print(f"[yellow]Download: [red]EP_{obj_episode.number} \n")
45
-
46
- # Collect mp4 url
47
- video_source.get_embed(obj_episode.id)
48
-
49
- # Create output path
50
- title_name = f"{obj_episode.number}.mp4"
51
-
52
- if scrape_serie.is_series:
53
- mp4_path = os_manager.get_sanitize_path(
54
- os.path.join(ROOT_PATH, SITE_NAME, SERIES_FOLDER, scrape_serie.series_name)
55
- )
56
- else:
57
- mp4_path = os_manager.get_sanitize_path(
58
- os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, scrape_serie.series_name)
59
- )
60
-
61
- # Create output folder
62
- os_manager.create_path(mp4_path)
63
-
64
- # Start downloading
65
- r_proc = MP4_downloader(
66
- url = str(video_source.src_mp4).strip(),
67
- path = os.path.join(mp4_path, title_name)
68
- )
69
-
70
- if r_proc != None:
71
- console.print("[green]Result: ")
72
- console.print(r_proc)
73
-
74
- else:
75
- logging.error(f"Skip index: {index_select} cant find info with api.")
76
-
77
-
78
- def download_series(select_title: MediaItem):
79
- """
80
- Function to download episodes of a TV series.
81
-
82
- Parameters:
83
- - tv_id (int): The ID of the TV series.
84
- - tv_name (str): The name of the TV series.
85
- """
86
- scrape_serie = ScrapeSerieAnime(SITE_NAME)
87
- video_source = VideoSourceAnime(SITE_NAME)
88
-
89
- # Set up video source
90
- scrape_serie.setup(None, select_title.id, select_title.slug)
91
-
92
- # Get the count of episodes for the TV series
93
- episoded_count = scrape_serie.get_count_episodes()
94
- console.print(f"[cyan]Episodes find: [red]{episoded_count}")
95
-
96
- # Prompt user to select an episode index
97
- 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")
98
-
99
- # Manage user selection
100
- list_episode_select = manage_selection(last_command, episoded_count)
101
-
102
- # Download selected episodes
103
- if len(list_episode_select) == 1 and last_command != "*":
104
- download_episode(list_episode_select[0]-1, scrape_serie, video_source)
105
-
106
- # Download all other episodes selecter
107
- else:
108
- for i_episode in list_episode_select:
109
- download_episode(i_episode-1, scrape_serie, video_source)
110
-
111
-
112
- def download_film(select_title: MediaItem):
113
- """
114
- Function to download a film.
115
-
116
- Parameters:
117
- - id_film (int): The ID of the film.
118
- - title_name (str): The title of the film.
119
- """
120
-
121
- # Init class
122
- scrape_serie = ScrapeSerieAnime(SITE_NAME)
123
- video_source = VideoSourceAnime(SITE_NAME)
124
-
125
- # Set up video source
126
- scrape_serie.setup(None, select_title.id, select_title.slug)
127
- scrape_serie.is_series = False
128
-
129
- # Start download
130
- download_episode(0, scrape_serie, video_source)
@@ -1,165 +0,0 @@
1
- # 10.12.23
2
-
3
- import logging
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._jsonConfig import config_manager
14
- from StreamingCommunity.Util.table import TVShowManager
15
-
16
-
17
- # Logic class
18
- from StreamingCommunity.Api.Template import get_select_title
19
- from StreamingCommunity.Api.Template.Util import search_domain
20
- from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
21
-
22
-
23
- # Variable
24
- from .costant import SITE_NAME
25
- media_search_manager = MediaManager()
26
- table_show_manager = TVShowManager()
27
-
28
-
29
-
30
- def get_token(site_name: str, domain: str) -> dict:
31
- """
32
- Function to retrieve session tokens from a specified website.
33
-
34
- Parameters:
35
- - site_name (str): The name of the site.
36
- - domain (str): The domain of the site.
37
-
38
- Returns:
39
- - dict: A dictionary containing session tokens. The keys are 'XSRF_TOKEN', 'animeunity_session', and 'csrf_token'.
40
- """
41
-
42
- # Send a GET request to the specified URL composed of the site name and domain
43
- response = httpx.get(f"https://www.{site_name}.{domain}")
44
- response.raise_for_status()
45
-
46
- # Initialize variables to store CSRF token
47
- find_csrf_token = None
48
-
49
- # Parse the HTML response using BeautifulSoup
50
- soup = BeautifulSoup(response.text, "html.parser")
51
-
52
- # Loop through all meta tags in the HTML response
53
- for html_meta in soup.find_all("meta"):
54
-
55
- # Check if the meta tag has a 'name' attribute equal to "csrf-token"
56
- if html_meta.get('name') == "csrf-token":
57
-
58
- # If found, retrieve the content of the meta tag, which is the CSRF token
59
- find_csrf_token = html_meta.get('content')
60
-
61
- logging.info(f"Extract: ('animeunity_session': {response.cookies['animeunity_session']}, 'csrf_token': {find_csrf_token})")
62
- return {
63
- 'animeunity_session': response.cookies['animeunity_session'],
64
- 'csrf_token': find_csrf_token
65
- }
66
-
67
-
68
- def get_real_title(record):
69
- """
70
- Get the real title from a record.
71
-
72
- This function takes a record, which is assumed to be a dictionary representing a row of JSON data.
73
- It looks for a title in the record, prioritizing English over Italian titles if available.
74
-
75
- Parameters:
76
- - record (dict): A dictionary representing a row of JSON data.
77
-
78
- Returns:
79
- - str: The title found in the record. If no title is found, returns None.
80
- """
81
-
82
- if record['title'] is not None:
83
- return record['title']
84
-
85
- elif record['title_eng'] is not None:
86
- return record['title_eng']
87
-
88
- else:
89
- return record['title_it']
90
-
91
-
92
- def title_search(title: str) -> int:
93
- """
94
- Function to perform an anime search using a provided title.
95
-
96
- Parameters:
97
- - title_search (str): The title to search for.
98
-
99
- Returns:
100
- - int: A number containing the length of media search manager.
101
- """
102
-
103
- # Get token and session value from configuration
104
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
105
- domain_to_use, _ = search_domain(SITE_NAME, f"https://www.{SITE_NAME}")
106
-
107
- data = get_token(SITE_NAME, domain_to_use)
108
-
109
- # Prepare cookies to be used in the request
110
- cookies = {
111
- 'animeunity_session': data.get('animeunity_session')
112
- }
113
-
114
- # Prepare headers for the request
115
- headers = {
116
- 'accept': 'application/json, text/plain, */*',
117
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
118
- 'content-type': 'application/json;charset=UTF-8',
119
- 'x-csrf-token': data.get('csrf_token')
120
- }
121
-
122
- # Prepare JSON data to be sent in the request
123
- json_data = {
124
- 'title': title # Use the provided title for the search
125
- }
126
-
127
- # Send a POST request to the API endpoint for live search
128
- try:
129
- response = httpx.post(
130
- url=f'https://www.{SITE_NAME}.{domain_to_use}/livesearch',
131
- cookies=cookies,
132
- headers=headers,
133
- json=json_data,
134
- timeout=max_timeout
135
- )
136
- response.raise_for_status()
137
-
138
- except Exception as e:
139
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
140
-
141
- # Process each record returned in the response
142
- for dict_title in response.json()['records']:
143
-
144
- # Rename keys for consistency
145
- dict_title['name'] = get_real_title(dict_title)
146
-
147
- # Add the record to media search manager if the name is not None
148
- media_search_manager.add_media({
149
- 'id': dict_title.get('id'),
150
- 'slug': dict_title.get('slug'),
151
- 'name': dict_title.get('name'),
152
- 'type': dict_title.get('type'),
153
- 'score': dict_title.get('score'),
154
- 'episodes_count': dict_title.get('episodes_count')
155
- })
156
-
157
- # Return the length of media search manager
158
- return media_search_manager.get_length()
159
-
160
-
161
- def run_get_select_title():
162
- """
163
- Display a selection of titles and prompt the user to choose one.
164
- """
165
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,97 +0,0 @@
1
- # 01.03.24
2
-
3
- import logging
4
-
5
-
6
- # External libraries
7
- import httpx
8
-
9
-
10
- # Internal utilities
11
- from StreamingCommunity.Util.headers import get_headers
12
- from StreamingCommunity.Util._jsonConfig import config_manager
13
- from StreamingCommunity.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
@@ -1,51 +0,0 @@
1
- # 01.07.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 .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()
@@ -1,15 +0,0 @@
1
- # 01.07.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')