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,242 +1,242 @@
1
- # 16.04.24
2
-
3
- import os
4
- import sys
5
- import json
6
- import subprocess
7
- import logging
8
- from typing import Tuple
9
-
10
-
11
- # Internal utilities
12
- from StreamingCommunity.Src.Util.console import console
13
-
14
-
15
- def has_audio_stream(video_path: str) -> bool:
16
- """
17
- Check if the input video has an audio stream.
18
-
19
- Parameters:
20
- - video_path (str): Path to the input video file.
21
-
22
- Returns:
23
- has_audio (bool): True if the input video has an audio stream, False otherwise.
24
- """
25
- try:
26
- ffprobe_cmd = ['ffprobe', '-v', 'error', '-print_format', 'json', '-select_streams', 'a', '-show_streams', video_path]
27
- logging.info(f"FFmpeg command: {ffprobe_cmd}")
28
-
29
- with subprocess.Popen(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) as proc:
30
- stdout, stderr = proc.communicate()
31
- if stderr:
32
- logging.error(f"Error: {stderr}")
33
- else:
34
- probe_result = json.loads(stdout)
35
- return bool(probe_result.get('streams', []))
36
-
37
- except Exception as e:
38
- logging.error(f"Error: {e}")
39
- return False
40
-
41
-
42
- def get_video_duration(file_path: str) -> float:
43
- """
44
- Get the duration of a video file.
45
-
46
- Parameters:
47
- - file_path (str): The path to the video file.
48
-
49
- Returns:
50
- (float): The duration of the video in seconds if successful,
51
- None if there's an error.
52
- """
53
-
54
- try:
55
- ffprobe_cmd = ['ffprobe', '-v', 'error', '-show_format', '-print_format', 'json', file_path]
56
- logging.info(f"FFmpeg command: {ffprobe_cmd}")
57
-
58
- # Use a with statement to ensure the subprocess is cleaned up properly
59
- with subprocess.Popen(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) as proc:
60
- stdout, stderr = proc.communicate()
61
-
62
- if proc.returncode != 0:
63
- logging.error(f"Error: {stderr}")
64
- return None
65
-
66
- # Parse JSON output
67
- probe_result = json.loads(stdout)
68
-
69
- # Extract duration from the video information
70
- try:
71
- return float(probe_result['format']['duration'])
72
- except:
73
- logging.error("Cant get duration.")
74
- return 1
75
-
76
- except Exception as e:
77
- logging.error(f"Error get video duration: {e}")
78
- sys.exit(0)
79
-
80
- def get_video_duration_s(filename):
81
- """
82
- Get the duration of a video file using ffprobe.
83
-
84
- Parameters:
85
- - filename (str): Path to the video file (e.g., 'sim.mp4')
86
-
87
- Returns:
88
- - duration (float): Duration of the video in seconds, or None if an error occurs.
89
- """
90
- ffprobe_cmd = ['ffprobe', '-v', 'error', '-show_entries', 'format=duration', '-of', 'default=noprint_wrappers=1:nokey=1', filename]
91
-
92
- try:
93
-
94
- # Run ffprobe command and capture output
95
- result = subprocess.run(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, check=True, text=True)
96
-
97
- # Extract duration from the output
98
- duration_str = result.stdout.strip()
99
- duration = float(duration_str) # Convert duration to float
100
-
101
- return int(duration)
102
-
103
- except subprocess.CalledProcessError as e:
104
- print(f"Error running ffprobe: {e}")
105
- return None
106
- except ValueError as e:
107
- print(f"Error converting duration to float: {e}")
108
- return None
109
-
110
-
111
- def format_duration(seconds: float) -> Tuple[int, int, int]:
112
- """
113
- Format duration in seconds into hours, minutes, and seconds.
114
-
115
- Parameters:
116
- - seconds (float): Duration in seconds.
117
-
118
- Returns:
119
- list[int, int, int]: List containing hours, minutes, and seconds.
120
- """
121
-
122
- hours, remainder = divmod(seconds, 3600)
123
- minutes, seconds = divmod(remainder, 60)
124
-
125
- return int(hours), int(minutes), int(seconds)
126
-
127
-
128
- def print_duration_table(file_path: str, description: str = "Duration", return_string: bool = False):
129
- """
130
- Print the duration of a video file in hours, minutes, and seconds, or return it as a formatted string.
131
-
132
- Parameters:
133
- - file_path (str): The path to the video file.
134
- - description (str): Optional description to be included in the output. Defaults to "Duration". If not provided, the duration will not be printed.
135
- - return_string (bool): If True, returns the formatted duration string. If False, returns a dictionary with hours, minutes, and seconds.
136
-
137
- Returns:
138
- - str: The formatted duration string if return_string is True.
139
- - dict: A dictionary with keys 'h', 'm', 's' representing hours, minutes, and seconds if return_string is False.
140
- """
141
-
142
- video_duration = get_video_duration(file_path)
143
-
144
- if video_duration is not None:
145
- hours, minutes, seconds = format_duration(video_duration)
146
- formatted_duration = f"[yellow]{int(hours)}[red]h [yellow]{int(minutes)}[red]m [yellow]{int(seconds)}[red]s"
147
- duration_dict = {'h': hours, 'm': minutes, 's': seconds}
148
-
149
- if description:
150
- console.print(f"[cyan]{description} for [white]([green]{os.path.basename(file_path)}[white]): {formatted_duration}")
151
- else:
152
- if return_string:
153
- return formatted_duration
154
- else:
155
- return duration_dict
156
-
157
-
158
- def get_ffprobe_info(file_path):
159
- """
160
- Get format and codec information for a media file using ffprobe.
161
-
162
- Parameters:
163
- file_path (str): Path to the media file.
164
-
165
- Returns:
166
- dict: A dictionary containing the format name and a list of codec names.
167
- """
168
- try:
169
- result = subprocess.run(
170
- ['ffprobe', '-v', 'error', '-show_format', '-show_streams', '-print_format', 'json', file_path],
171
- stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True, check=True
172
- )
173
- output = result.stdout
174
- info = json.loads(output)
175
-
176
- format_name = info['format']['format_name'] if 'format' in info else None
177
- codec_names = [stream['codec_name'] for stream in info['streams']] if 'streams' in info else []
178
-
179
- return {
180
- 'format_name': format_name,
181
- 'codec_names': codec_names
182
- }
183
-
184
- except subprocess.CalledProcessError as e:
185
- logging.error(f"ffprobe failed for file {file_path}: {e}")
186
- return None
187
-
188
- except json.JSONDecodeError as e:
189
- logging.error(f"Failed to parse JSON output from ffprobe for file {file_path}: {e}")
190
- return None
191
-
192
-
193
- def is_png_format_or_codec(file_info):
194
- """
195
- Check if the format is 'png_pipe' or if any codec is 'png'.
196
-
197
- Parameters:
198
- file_info (dict): The dictionary containing file information.
199
-
200
- Returns:
201
- bool: True if the format is 'png_pipe' or any codec is 'png', otherwise False.
202
- """
203
- if not file_info:
204
- return False
205
- return file_info['format_name'] == 'png_pipe' or 'png' in file_info['codec_names']
206
-
207
-
208
- def need_to_force_to_ts(file_path):
209
- """
210
- Get if a file to TS format if it is in PNG format or contains a PNG codec.
211
-
212
- Parameters:
213
- file_path (str): Path to the input media file.
214
- """
215
- logging.info(f"Processing file: {file_path}")
216
- file_info = get_ffprobe_info(file_path)
217
-
218
- if is_png_format_or_codec(file_info):
219
- return True
220
- return False
221
-
222
-
223
- def check_duration_v_a(video_path, audio_path):
224
- """
225
- Check if the duration of the video and audio matches.
226
-
227
- Parameters:
228
- - video_path (str): Path to the video file.
229
- - audio_path (str): Path to the audio file.
230
-
231
- Returns:
232
- - bool: True if the duration of the video and audio matches, False otherwise.
233
- """
234
-
235
- # Ottieni la durata del video
236
- video_duration = get_video_duration(video_path)
237
-
238
- # Ottieni la durata dell'audio
239
- audio_duration = get_video_duration(audio_path)
240
-
241
- # Verifica se le durate corrispondono
1
+ # 16.04.24
2
+
3
+ import os
4
+ import sys
5
+ import json
6
+ import subprocess
7
+ import logging
8
+ from typing import Tuple
9
+
10
+
11
+ # Internal utilities
12
+ from StreamingCommunity.Util.console import console
13
+
14
+
15
+ def has_audio_stream(video_path: str) -> bool:
16
+ """
17
+ Check if the input video has an audio stream.
18
+
19
+ Parameters:
20
+ - video_path (str): Path to the input video file.
21
+
22
+ Returns:
23
+ has_audio (bool): True if the input video has an audio stream, False otherwise.
24
+ """
25
+ try:
26
+ ffprobe_cmd = ['ffprobe', '-v', 'error', '-print_format', 'json', '-select_streams', 'a', '-show_streams', video_path]
27
+ logging.info(f"FFmpeg command: {ffprobe_cmd}")
28
+
29
+ with subprocess.Popen(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) as proc:
30
+ stdout, stderr = proc.communicate()
31
+ if stderr:
32
+ logging.error(f"Error: {stderr}")
33
+ else:
34
+ probe_result = json.loads(stdout)
35
+ return bool(probe_result.get('streams', []))
36
+
37
+ except Exception as e:
38
+ logging.error(f"Error: {e}")
39
+ return False
40
+
41
+
42
+ def get_video_duration(file_path: str) -> float:
43
+ """
44
+ Get the duration of a video file.
45
+
46
+ Parameters:
47
+ - file_path (str): The path to the video file.
48
+
49
+ Returns:
50
+ (float): The duration of the video in seconds if successful,
51
+ None if there's an error.
52
+ """
53
+
54
+ try:
55
+ ffprobe_cmd = ['ffprobe', '-v', 'error', '-show_format', '-print_format', 'json', file_path]
56
+ logging.info(f"FFmpeg command: {ffprobe_cmd}")
57
+
58
+ # Use a with statement to ensure the subprocess is cleaned up properly
59
+ with subprocess.Popen(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) as proc:
60
+ stdout, stderr = proc.communicate()
61
+
62
+ if proc.returncode != 0:
63
+ logging.error(f"Error: {stderr}")
64
+ return None
65
+
66
+ # Parse JSON output
67
+ probe_result = json.loads(stdout)
68
+
69
+ # Extract duration from the video information
70
+ try:
71
+ return float(probe_result['format']['duration'])
72
+ except:
73
+ logging.error("Cant get duration.")
74
+ return 1
75
+
76
+ except Exception as e:
77
+ logging.error(f"Error get video duration: {e}")
78
+ sys.exit(0)
79
+
80
+ def get_video_duration_s(filename):
81
+ """
82
+ Get the duration of a video file using ffprobe.
83
+
84
+ Parameters:
85
+ - filename (str): Path to the video file (e.g., 'sim.mp4')
86
+
87
+ Returns:
88
+ - duration (float): Duration of the video in seconds, or None if an error occurs.
89
+ """
90
+ ffprobe_cmd = ['ffprobe', '-v', 'error', '-show_entries', 'format=duration', '-of', 'default=noprint_wrappers=1:nokey=1', filename]
91
+
92
+ try:
93
+
94
+ # Run ffprobe command and capture output
95
+ result = subprocess.run(ffprobe_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, check=True, text=True)
96
+
97
+ # Extract duration from the output
98
+ duration_str = result.stdout.strip()
99
+ duration = float(duration_str) # Convert duration to float
100
+
101
+ return int(duration)
102
+
103
+ except subprocess.CalledProcessError as e:
104
+ print(f"Error running ffprobe: {e}")
105
+ return None
106
+ except ValueError as e:
107
+ print(f"Error converting duration to float: {e}")
108
+ return None
109
+
110
+
111
+ def format_duration(seconds: float) -> Tuple[int, int, int]:
112
+ """
113
+ Format duration in seconds into hours, minutes, and seconds.
114
+
115
+ Parameters:
116
+ - seconds (float): Duration in seconds.
117
+
118
+ Returns:
119
+ list[int, int, int]: List containing hours, minutes, and seconds.
120
+ """
121
+
122
+ hours, remainder = divmod(seconds, 3600)
123
+ minutes, seconds = divmod(remainder, 60)
124
+
125
+ return int(hours), int(minutes), int(seconds)
126
+
127
+
128
+ def print_duration_table(file_path: str, description: str = "Duration", return_string: bool = False):
129
+ """
130
+ Print the duration of a video file in hours, minutes, and seconds, or return it as a formatted string.
131
+
132
+ Parameters:
133
+ - file_path (str): The path to the video file.
134
+ - description (str): Optional description to be included in the output. Defaults to "Duration". If not provided, the duration will not be printed.
135
+ - return_string (bool): If True, returns the formatted duration string. If False, returns a dictionary with hours, minutes, and seconds.
136
+
137
+ Returns:
138
+ - str: The formatted duration string if return_string is True.
139
+ - dict: A dictionary with keys 'h', 'm', 's' representing hours, minutes, and seconds if return_string is False.
140
+ """
141
+
142
+ video_duration = get_video_duration(file_path)
143
+
144
+ if video_duration is not None:
145
+ hours, minutes, seconds = format_duration(video_duration)
146
+ formatted_duration = f"[yellow]{int(hours)}[red]h [yellow]{int(minutes)}[red]m [yellow]{int(seconds)}[red]s"
147
+ duration_dict = {'h': hours, 'm': minutes, 's': seconds}
148
+
149
+ if description:
150
+ console.print(f"[cyan]{description} for [white]([green]{os.path.basename(file_path)}[white]): {formatted_duration}")
151
+ else:
152
+ if return_string:
153
+ return formatted_duration
154
+ else:
155
+ return duration_dict
156
+
157
+
158
+ def get_ffprobe_info(file_path):
159
+ """
160
+ Get format and codec information for a media file using ffprobe.
161
+
162
+ Parameters:
163
+ file_path (str): Path to the media file.
164
+
165
+ Returns:
166
+ dict: A dictionary containing the format name and a list of codec names.
167
+ """
168
+ try:
169
+ result = subprocess.run(
170
+ ['ffprobe', '-v', 'error', '-show_format', '-show_streams', '-print_format', 'json', file_path],
171
+ stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True, check=True
172
+ )
173
+ output = result.stdout
174
+ info = json.loads(output)
175
+
176
+ format_name = info['format']['format_name'] if 'format' in info else None
177
+ codec_names = [stream['codec_name'] for stream in info['streams']] if 'streams' in info else []
178
+
179
+ return {
180
+ 'format_name': format_name,
181
+ 'codec_names': codec_names
182
+ }
183
+
184
+ except subprocess.CalledProcessError as e:
185
+ logging.error(f"ffprobe failed for file {file_path}: {e}")
186
+ return None
187
+
188
+ except json.JSONDecodeError as e:
189
+ logging.error(f"Failed to parse JSON output from ffprobe for file {file_path}: {e}")
190
+ return None
191
+
192
+
193
+ def is_png_format_or_codec(file_info):
194
+ """
195
+ Check if the format is 'png_pipe' or if any codec is 'png'.
196
+
197
+ Parameters:
198
+ file_info (dict): The dictionary containing file information.
199
+
200
+ Returns:
201
+ bool: True if the format is 'png_pipe' or any codec is 'png', otherwise False.
202
+ """
203
+ if not file_info:
204
+ return False
205
+ return file_info['format_name'] == 'png_pipe' or 'png' in file_info['codec_names']
206
+
207
+
208
+ def need_to_force_to_ts(file_path):
209
+ """
210
+ Get if a file to TS format if it is in PNG format or contains a PNG codec.
211
+
212
+ Parameters:
213
+ file_path (str): Path to the input media file.
214
+ """
215
+ logging.info(f"Processing file: {file_path}")
216
+ file_info = get_ffprobe_info(file_path)
217
+
218
+ if is_png_format_or_codec(file_info):
219
+ return True
220
+ return False
221
+
222
+
223
+ def check_duration_v_a(video_path, audio_path):
224
+ """
225
+ Check if the duration of the video and audio matches.
226
+
227
+ Parameters:
228
+ - video_path (str): Path to the video file.
229
+ - audio_path (str): Path to the audio file.
230
+
231
+ Returns:
232
+ - bool: True if the duration of the video and audio matches, False otherwise.
233
+ """
234
+
235
+ # Ottieni la durata del video
236
+ video_duration = get_video_duration(video_path)
237
+
238
+ # Ottieni la durata dell'audio
239
+ audio_duration = get_video_duration(audio_path)
240
+
241
+ # Verifica se le durate corrispondono
242
242
  return video_duration == audio_duration
@@ -1,6 +1,6 @@
1
- # 02.04.24
2
-
3
- from .decryptor import M3U8_Decryption
4
- from .estimator import M3U8_Ts_Estimator
5
- from .parser import M3U8_Parser, M3U8_Codec
1
+ # 02.04.24
2
+
3
+ from .decryptor import M3U8_Decryption
4
+ from .estimator import M3U8_Ts_Estimator
5
+ from .parser import M3U8_Parser, M3U8_Codec
6
6
  from .url_fixer import M3U8_UrlFix