quasarr 2.4.2__py3-none-any.whl → 2.4.5__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 quasarr might be problematic. Click here for more details.
- quasarr/__init__.py +2 -2
- quasarr/api/captcha/__init__.py +6 -6
- quasarr/downloads/packages/__init__.py +2 -1
- quasarr/providers/html_images.py +1 -1
- quasarr/providers/imdb_metadata.py +1 -1
- quasarr/providers/sessions/dd.py +1 -1
- quasarr/providers/statistics.py +8 -8
- quasarr/providers/version.py +12 -4
- quasarr/search/sources/he.py +2 -2
- {quasarr-2.4.2.dist-info → quasarr-2.4.5.dist-info}/METADATA +11 -20
- {quasarr-2.4.2.dist-info → quasarr-2.4.5.dist-info}/RECORD +14 -15
- {quasarr-2.4.2.dist-info → quasarr-2.4.5.dist-info}/WHEEL +1 -2
- quasarr-2.4.2.dist-info/top_level.txt +0 -1
- {quasarr-2.4.2.dist-info → quasarr-2.4.5.dist-info}/entry_points.txt +0 -0
- {quasarr-2.4.2.dist-info → quasarr-2.4.5.dist-info}/licenses/LICENSE +0 -0
quasarr/__init__.py
CHANGED
|
@@ -263,7 +263,7 @@ def flaresolverr_checker(shared_state_dict, shared_state_lock):
|
|
|
263
263
|
flaresolverr_skipped = skip_flaresolverr_db.retrieve("skipped")
|
|
264
264
|
|
|
265
265
|
flaresolverr_url = Config('FlareSolverr').get('url')
|
|
266
|
-
|
|
266
|
+
|
|
267
267
|
# If FlareSolverr is not configured and not skipped, it means it's the first run
|
|
268
268
|
# and the user needs to be prompted via the WebUI.
|
|
269
269
|
# This background process should NOT block or prompt the user.
|
|
@@ -271,7 +271,7 @@ def flaresolverr_checker(shared_state_dict, shared_state_lock):
|
|
|
271
271
|
if not flaresolverr_url and not flaresolverr_skipped:
|
|
272
272
|
info('FlareSolverr URL not configured. Please configure it via the WebUI.')
|
|
273
273
|
info('Some sites (AL) will not work without FlareSolverr.')
|
|
274
|
-
return
|
|
274
|
+
return # Exit the checker, it will be re-checked if user configures it later
|
|
275
275
|
|
|
276
276
|
if flaresolverr_skipped:
|
|
277
277
|
info('FlareSolverr setup skipped by user preference')
|
quasarr/api/captcha/__init__.py
CHANGED
|
@@ -324,7 +324,7 @@ def setup_captcha_routes(app):
|
|
|
324
324
|
|
|
325
325
|
source_button = ""
|
|
326
326
|
if original_url:
|
|
327
|
-
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
327
|
+
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
328
328
|
|
|
329
329
|
return render_centered_html(f"""
|
|
330
330
|
<!DOCTYPE html>
|
|
@@ -370,7 +370,7 @@ def setup_captcha_routes(app):
|
|
|
370
370
|
|
|
371
371
|
source_button = ""
|
|
372
372
|
if original_url:
|
|
373
|
-
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
373
|
+
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
374
374
|
|
|
375
375
|
return render_centered_html(f"""
|
|
376
376
|
<!DOCTYPE html>
|
|
@@ -417,7 +417,7 @@ def setup_captcha_routes(app):
|
|
|
417
417
|
|
|
418
418
|
source_button = ""
|
|
419
419
|
if original_url:
|
|
420
|
-
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
420
|
+
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
421
421
|
|
|
422
422
|
return render_centered_html(f"""
|
|
423
423
|
<!DOCTYPE html>
|
|
@@ -464,7 +464,7 @@ def setup_captcha_routes(app):
|
|
|
464
464
|
|
|
465
465
|
source_button = ""
|
|
466
466
|
if original_url:
|
|
467
|
-
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
467
|
+
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
468
468
|
|
|
469
469
|
return render_centered_html(f"""
|
|
470
470
|
<!DOCTYPE html>
|
|
@@ -852,7 +852,7 @@ def setup_captcha_routes(app):
|
|
|
852
852
|
|
|
853
853
|
source_button = ""
|
|
854
854
|
if original_url:
|
|
855
|
-
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
855
|
+
source_button = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
856
856
|
|
|
857
857
|
return render_centered_html(f"""
|
|
858
858
|
<!DOCTYPE html>
|
|
@@ -1219,7 +1219,7 @@ def setup_captcha_routes(app):
|
|
|
1219
1219
|
|
|
1220
1220
|
source_button_html = ""
|
|
1221
1221
|
if original_url:
|
|
1222
|
-
source_button_html = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"
|
|
1222
|
+
source_button_html = f'<p>{render_button("Source", "secondary", {"onclick": f"window.open(\'{js_single_quoted_string_safe(original_url)}\', \'_blank\')"})}</p>'
|
|
1223
1223
|
|
|
1224
1224
|
content = render_centered_html(r'''
|
|
1225
1225
|
<style>
|
|
@@ -582,7 +582,8 @@ def get_packages(shared_state, _cache=None):
|
|
|
582
582
|
"uuid": package.get("uuid"),
|
|
583
583
|
"is_archive": package.get("is_archive", False),
|
|
584
584
|
"extraction_ok": package.get("extraction_ok", False),
|
|
585
|
-
"extraction_status": "SUCCESSFUL" if package.get("extraction_ok", False) else "RUNNING" if package.get(
|
|
585
|
+
"extraction_status": "SUCCESSFUL" if package.get("extraction_ok", False) else "RUNNING" if package.get(
|
|
586
|
+
"is_archive", False) else ""
|
|
586
587
|
})
|
|
587
588
|
history_index += 1
|
|
588
589
|
else:
|
quasarr/providers/html_images.py
CHANGED
|
@@ -3,4 +3,4 @@
|
|
|
3
3
|
# Project by https://github.com/rix1337
|
|
4
4
|
|
|
5
5
|
favicon = ''
|
|
6
|
-
logo = ''
|
|
6
|
+
logo = ''
|
|
@@ -456,7 +456,7 @@ def get_imdb_metadata(imdb_id):
|
|
|
456
456
|
if response_json:
|
|
457
457
|
imdb_metadata["title"] = TitleCleaner.sanitize(response_json.get("primaryTitle", ""))
|
|
458
458
|
imdb_metadata["year"] = response_json.get("startYear")
|
|
459
|
-
|
|
459
|
+
|
|
460
460
|
days = 7 if imdb_metadata.get("title") and imdb_metadata.get("year") else 1
|
|
461
461
|
imdb_metadata["ttl"] = now + timedelta(days=days).total_seconds()
|
|
462
462
|
|
quasarr/providers/sessions/dd.py
CHANGED
|
@@ -32,7 +32,7 @@ def create_and_persist_session(shared_state):
|
|
|
32
32
|
}
|
|
33
33
|
|
|
34
34
|
r = dd_session.post(f'https://{dd}/index/index',
|
|
35
|
-
|
|
35
|
+
cookies=cookies, headers=headers, data=data, timeout=10)
|
|
36
36
|
r.raise_for_status()
|
|
37
37
|
|
|
38
38
|
error = False
|
quasarr/providers/statistics.py
CHANGED
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
# Quasarr
|
|
3
3
|
# Project by https://github.com/rix1337
|
|
4
4
|
|
|
5
|
-
from typing import Dict, Any
|
|
6
5
|
from json import loads
|
|
6
|
+
from typing import Dict, Any
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
class StatsHelper:
|
|
@@ -110,29 +110,29 @@ class StatsHelper:
|
|
|
110
110
|
try:
|
|
111
111
|
db = self.shared_state.values["database"]("imdb_metadata")
|
|
112
112
|
all_entries = db.retrieve_all_titles()
|
|
113
|
-
|
|
113
|
+
|
|
114
114
|
total_cached = 0
|
|
115
115
|
with_title = 0
|
|
116
116
|
with_poster = 0
|
|
117
117
|
with_localized = 0
|
|
118
|
-
|
|
118
|
+
|
|
119
119
|
for _, data_str in all_entries:
|
|
120
120
|
try:
|
|
121
121
|
data = loads(data_str)
|
|
122
122
|
total_cached += 1
|
|
123
|
-
|
|
123
|
+
|
|
124
124
|
if data.get("title"):
|
|
125
125
|
with_title += 1
|
|
126
|
-
|
|
126
|
+
|
|
127
127
|
if data.get("poster_link"):
|
|
128
128
|
with_poster += 1
|
|
129
|
-
|
|
129
|
+
|
|
130
130
|
if data.get("localized") and isinstance(data["localized"], dict) and len(data["localized"]) > 0:
|
|
131
131
|
with_localized += 1
|
|
132
|
-
|
|
132
|
+
|
|
133
133
|
except (ValueError, TypeError):
|
|
134
134
|
continue
|
|
135
|
-
|
|
135
|
+
|
|
136
136
|
return {
|
|
137
137
|
"imdb_total_cached": total_cached,
|
|
138
138
|
"imdb_with_title": with_title,
|
quasarr/providers/version.py
CHANGED
|
@@ -3,12 +3,13 @@
|
|
|
3
3
|
# Project by https://github.com/rix1337
|
|
4
4
|
|
|
5
5
|
import re
|
|
6
|
+
import sys
|
|
6
7
|
|
|
7
|
-
|
|
8
|
+
__version__ = "2.4.5"
|
|
8
9
|
|
|
9
10
|
|
|
10
11
|
def get_version():
|
|
11
|
-
return
|
|
12
|
+
return __version__
|
|
12
13
|
|
|
13
14
|
|
|
14
15
|
def get_latest_version():
|
|
@@ -17,6 +18,11 @@ def get_latest_version():
|
|
|
17
18
|
Returns the tag name string (e.g. "1.5.0" or "1.4.2a1").
|
|
18
19
|
Raises RuntimeError on HTTP errors.
|
|
19
20
|
"""
|
|
21
|
+
try:
|
|
22
|
+
import requests
|
|
23
|
+
except ImportError:
|
|
24
|
+
return __version__
|
|
25
|
+
|
|
20
26
|
api_url = "https://api.github.com/repos/rix1337/Quasarr/releases/latest"
|
|
21
27
|
resp = requests.get(api_url, headers={"Accept": "application/vnd.github.v3+json"})
|
|
22
28
|
if resp.status_code != 200:
|
|
@@ -114,5 +120,7 @@ def create_version_file():
|
|
|
114
120
|
|
|
115
121
|
|
|
116
122
|
if __name__ == '__main__':
|
|
117
|
-
|
|
118
|
-
|
|
123
|
+
if len(sys.argv) > 1 and sys.argv[1] == '--create-version-file':
|
|
124
|
+
create_version_file()
|
|
125
|
+
else:
|
|
126
|
+
print(get_version())
|
quasarr/search/sources/he.py
CHANGED
|
@@ -84,7 +84,7 @@ def he_search(shared_state, start_time, request_from, search_string="", mirror=N
|
|
|
84
84
|
if not local_title:
|
|
85
85
|
info(f"{hostname}: no title for IMDb {imdb_id}")
|
|
86
86
|
return releases
|
|
87
|
-
if not season:
|
|
87
|
+
if not season:
|
|
88
88
|
year = get_year(imdb_id)
|
|
89
89
|
if year:
|
|
90
90
|
local_title += f" {year}"
|
|
@@ -97,7 +97,7 @@ def he_search(shared_state, start_time, request_from, search_string="", mirror=N
|
|
|
97
97
|
|
|
98
98
|
if not source_search:
|
|
99
99
|
search_type = "feed"
|
|
100
|
-
timeout=30
|
|
100
|
+
timeout = 30
|
|
101
101
|
else:
|
|
102
102
|
search_type = "search"
|
|
103
103
|
timeout = 10
|
|
@@ -1,29 +1,20 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: quasarr
|
|
3
|
-
Version: 2.4.
|
|
3
|
+
Version: 2.4.5
|
|
4
4
|
Summary: Quasarr connects JDownloader with Radarr, Sonarr and LazyLibrarian. It also decrypts links protected by CAPTCHAs.
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
Author-email:
|
|
8
|
-
Classifier: Programming Language :: Python :: 3
|
|
5
|
+
Author-email: rix1337 <rix1337@users.noreply.github.com>
|
|
6
|
+
License-File: LICENSE
|
|
9
7
|
Classifier: License :: OSI Approved :: MIT License
|
|
10
8
|
Classifier: Operating System :: OS Independent
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
Classifier: Programming Language :: Python :: 3
|
|
10
|
+
Requires-Python: >=3.12
|
|
13
11
|
Requires-Dist: beautifulsoup4>=4.14.3
|
|
14
12
|
Requires-Dist: bottle>=0.13.4
|
|
15
13
|
Requires-Dist: dukpy>=0.5.0
|
|
16
14
|
Requires-Dist: pillow>=12.0.0
|
|
17
15
|
Requires-Dist: pycryptodomex>=3.23.0
|
|
18
16
|
Requires-Dist: requests>=2.32.5
|
|
19
|
-
|
|
20
|
-
Dynamic: classifier
|
|
21
|
-
Dynamic: description
|
|
22
|
-
Dynamic: description-content-type
|
|
23
|
-
Dynamic: home-page
|
|
24
|
-
Dynamic: license-file
|
|
25
|
-
Dynamic: requires-dist
|
|
26
|
-
Dynamic: summary
|
|
17
|
+
Description-Content-Type: text/markdown
|
|
27
18
|
|
|
28
19
|
#
|
|
29
20
|
|
|
@@ -206,8 +197,7 @@ docker run -d \
|
|
|
206
197
|
| `EXTERNAL_ADDRESS` | Optional. External URL (e.g. reverse proxy). Always protect external access with authentication. |
|
|
207
198
|
| `DISCORD` | Optional. Discord webhook URL for notifications. |
|
|
208
199
|
| `HOSTNAMES` | Optional. URL to a hostname list to skip manual setup. Must be a publicly accessible `HTTP`/`HTTPS` link, point to a raw `.ini` or plain text file (not HTML or JSON), and contain at least one hostname per line in the format `ab = xyz`. |
|
|
209
|
-
| `USER`
|
|
210
|
-
| `PASS` | Password to protect the web UI. |
|
|
200
|
+
| `USER` / `PASS` | Optional, but recommended! Username / Password to protect the web UI. |
|
|
211
201
|
| `AUTH` | Authentication mode. Supported values: `form` or `basic`. |
|
|
212
202
|
| `SILENT` | Optional. If `True`, silences all Discord notifications except SponsorHelper error messages. |
|
|
213
203
|
| `DEBUG` | Optional. If `True`, enables debug logging. |
|
|
@@ -215,13 +205,14 @@ docker run -d \
|
|
|
215
205
|
|
|
216
206
|
# Manual setup
|
|
217
207
|
|
|
218
|
-
Use this only in case you can't run the docker image.
|
|
208
|
+
> Use this only in case you can't run the docker image.
|
|
219
209
|
|
|
220
|
-
|
|
210
|
+
> ⚠️ Requires Python 3.12 (or later) and [uv](https://docs.astral.sh/uv/#installation)!
|
|
221
211
|
|
|
222
|
-
|
|
212
|
+
`uv tool install quasarr`
|
|
223
213
|
|
|
224
214
|
```
|
|
215
|
+
quasarr
|
|
225
216
|
--port=8080
|
|
226
217
|
--discord=https://discord.com/api/webhooks/1234567890/ABCDEFGHIJKLMN
|
|
227
218
|
--external_address=https://foo.bar/
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
quasarr/__init__.py,sha256=
|
|
1
|
+
quasarr/__init__.py,sha256=CU4S8Kb1RpzePtFoS2tpOj1S6wDaTZeg7TmkmwejA24,16108
|
|
2
2
|
quasarr/api/__init__.py,sha256=kFePULH7xR--gAD73DS1J9V4q5s3On5da4NzupHgkaY,19743
|
|
3
3
|
quasarr/api/arr/__init__.py,sha256=eEop8A5t936uT5azn4qz0bq1DMX84_Ja16wyleGFhyM,18495
|
|
4
|
-
quasarr/api/captcha/__init__.py,sha256=
|
|
4
|
+
quasarr/api/captcha/__init__.py,sha256=GDuhmoAkwEqZdlpnf7LP_TdsBtPaV4MKnvJueo5ARaQ,73705
|
|
5
5
|
quasarr/api/config/__init__.py,sha256=q-7vK5YULrSDgTicho--bNK8aAhcbzCdhhNwEwUEwWg,14173
|
|
6
6
|
quasarr/api/packages/__init__.py,sha256=PrJbXxw0bqW_8u-MLFL4Uje_lvwZClgBWI2iqumZLy8,30719
|
|
7
7
|
quasarr/api/sponsors_helper/__init__.py,sha256=PAXjlNWRf8Cf2s7CFLPOyHUjLPkLvI7LC-m97Q8tGh0,6215
|
|
@@ -11,7 +11,7 @@ quasarr/downloads/linkcrypters/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5
|
|
|
11
11
|
quasarr/downloads/linkcrypters/al.py,sha256=mfUG5VclC_-FcGoZL9zHYD7dz7X_YpaNmoKkgiyl9-0,8812
|
|
12
12
|
quasarr/downloads/linkcrypters/filecrypt.py,sha256=nUZCTmvKylaNk1KAXcYUV1FgQCVAKNE3roXCNaqHLYA,17057
|
|
13
13
|
quasarr/downloads/linkcrypters/hide.py,sha256=H4hJWhENkszV1u_ULC3aOW2fu9infC-Nv-7wx2DYqrA,6266
|
|
14
|
-
quasarr/downloads/packages/__init__.py,sha256=
|
|
14
|
+
quasarr/downloads/packages/__init__.py,sha256=MvMqlpmo6ruFNfnfp8dlS-Mzf1AKTai1qP65SlY-YDw,33086
|
|
15
15
|
quasarr/downloads/sources/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
16
16
|
quasarr/downloads/sources/al.py,sha256=cV0rOpda4YHmv5X07855wzoaczd3yFGdPyFdm07srFM,27842
|
|
17
17
|
quasarr/downloads/sources/by.py,sha256=ThyEVblYxaxKS_iROpxLhpqp2gOpcHjI1TCKX7CtrNw,4310
|
|
@@ -33,22 +33,22 @@ quasarr/providers/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU
|
|
|
33
33
|
quasarr/providers/auth.py,sha256=ve89PgDGmDCRvzE8XS29gcuGO2KgTdK0aX5627prnYI,10536
|
|
34
34
|
quasarr/providers/cloudflare.py,sha256=oUDR7OQ8E-8vCtagZLnIS2ZZV3ERffhxmW0njKKbtf0,7867
|
|
35
35
|
quasarr/providers/hostname_issues.py,sha256=9PJFIosLB-bMTmgWlR5-sYAmcyps7TDoSYjoL9cw9TE,1460
|
|
36
|
-
quasarr/providers/html_images.py,sha256=
|
|
36
|
+
quasarr/providers/html_images.py,sha256=G3tttyGbsV-IR8qIS9NUMX2J0-onxNUplcon70-YDWQ,19755
|
|
37
37
|
quasarr/providers/html_templates.py,sha256=H0Zd_hxmL49pXcEgkERqnxb1fO2Zd6boEsCsoypEZoM,15818
|
|
38
|
-
quasarr/providers/imdb_metadata.py,sha256=
|
|
38
|
+
quasarr/providers/imdb_metadata.py,sha256=nF2UBiCR7zdGEnnQFrR1yw6q0w5iM5JawJCzCKEOmZw,20763
|
|
39
39
|
quasarr/providers/jd_cache.py,sha256=mSvMrs3UwTn3sd9yGSJKGT-qwYeyYKC_l8whpXTVn7s,13530
|
|
40
40
|
quasarr/providers/log.py,sha256=_g5RwtfuksARXnvryhsngzoJyFcNzj6suqd3ndqZM0Y,313
|
|
41
41
|
quasarr/providers/myjd_api.py,sha256=Z3PEiO3c3UfDSr4Up5rgwTAnjloWHb-H1RkJ6BLKZv8,34140
|
|
42
42
|
quasarr/providers/notifications.py,sha256=hMMAKKXTi_MCEJKaTWdTq7cGkY4z-wIFx_x1sH5P6hA,4811
|
|
43
43
|
quasarr/providers/obfuscated.py,sha256=EYm_7SfdJd9ae_m4HZgY9ruDXC5J9hb4KEV_WAnk-ms,2275588
|
|
44
44
|
quasarr/providers/shared_state.py,sha256=5a_ZbGqTvt4-OqBt2a1WtR9I5J_Ky7IlkEY8EGtKVu8,30646
|
|
45
|
-
quasarr/providers/statistics.py,sha256=
|
|
45
|
+
quasarr/providers/statistics.py,sha256=ne8O3hLmIAsLvoOTczijqSV0uirUTS2KgcfYIsOXshQ,8021
|
|
46
46
|
quasarr/providers/utils.py,sha256=mcUPbcXMsLmrYv0CTZO5a9aOt2-JLyL3SZxu6N8OyjU,12075
|
|
47
|
-
quasarr/providers/version.py,sha256=
|
|
47
|
+
quasarr/providers/version.py,sha256=kYwfXee03t6k0PenLlLzUS0iTFcYdOlbDO2c_n6dJbg,4196
|
|
48
48
|
quasarr/providers/web_server.py,sha256=M1dGcEg_VuYpjcpGIrJS4WryCLiPQrCdtTUOlc9zlAI,1728
|
|
49
49
|
quasarr/providers/sessions/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
50
50
|
quasarr/providers/sessions/al.py,sha256=AQ59vVU7uQSuwZLNppNsZAFvpow3zcxQ29dirPbyYc4,13432
|
|
51
|
-
quasarr/providers/sessions/dd.py,sha256=
|
|
51
|
+
quasarr/providers/sessions/dd.py,sha256=d6tYYtEgXWD5AeIBjcdzQnlay24Q5lT2kt_1fSV1KdE,3314
|
|
52
52
|
quasarr/providers/sessions/dl.py,sha256=yTJlD84ItotViA1d-m0RwrbEJlL-VK-0nGw_4kfNLe0,5923
|
|
53
53
|
quasarr/providers/sessions/nx.py,sha256=ZuWuqfb_rPJVom0c1dsXefXPXdzAIYqnQZapOPaUYUI,3421
|
|
54
54
|
quasarr/search/__init__.py,sha256=1Z4dEfbbTiUSs139S5_5VivnXszQjQrLn9AQPX87OyU,5920
|
|
@@ -61,7 +61,7 @@ quasarr/search/sources/dl.py,sha256=L4GK58Mp46dAZzmwtMB4ia1w0SSpp3z3eFvrmT-5278,
|
|
|
61
61
|
quasarr/search/sources/dt.py,sha256=hvOqPKQRw5joSaTb9mpdPZXL4xpU167SFmLg8yhsPwM,10227
|
|
62
62
|
quasarr/search/sources/dw.py,sha256=hna1ueKjdi9uqRQJ7UPenT0ym7igQgWGrv_--yGChVs,8215
|
|
63
63
|
quasarr/search/sources/fx.py,sha256=xZUrv7dJSSmeLR2xnRQsRZAk9Q0-fDfQLNjz4wdBTqo,9452
|
|
64
|
-
quasarr/search/sources/he.py,sha256=
|
|
64
|
+
quasarr/search/sources/he.py,sha256=BQhDlaIrPR6GMoQpOZNNOAOOA_ZAMIYa6GQsvuxd_M8,7379
|
|
65
65
|
quasarr/search/sources/mb.py,sha256=Hq1zupo27FzYSQUio03HPG0wP4jYwOXl6cqgdOpjlzQ,8178
|
|
66
66
|
quasarr/search/sources/nk.py,sha256=Y-FgWmKyiPqcTdDsAGviClL_wyip7zPDNwrSPCcx4Ew,7146
|
|
67
67
|
quasarr/search/sources/nx.py,sha256=UXUSYEL4zwYVwCri359I26GYN8CDuCKokpOOR21YEns,7602
|
|
@@ -74,9 +74,8 @@ quasarr/storage/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
|
74
74
|
quasarr/storage/config.py,sha256=SSTgIce2FVYoVTK_6OCU3msknhxuLA3EC4Kcrrf_dxQ,6378
|
|
75
75
|
quasarr/storage/setup.py,sha256=Vy8YEL85KrNZdrXIuXKUj2hLBNn_JQ9onC6oP06Xq1g,48613
|
|
76
76
|
quasarr/storage/sqlite_database.py,sha256=yMqFQfKf0k7YS-6Z3_7pj4z1GwWSXJ8uvF4IydXsuTE,3554
|
|
77
|
-
quasarr-2.4.
|
|
78
|
-
quasarr-2.4.
|
|
79
|
-
quasarr-2.4.
|
|
80
|
-
quasarr-2.4.
|
|
81
|
-
quasarr-2.4.
|
|
82
|
-
quasarr-2.4.2.dist-info/RECORD,,
|
|
77
|
+
quasarr-2.4.5.dist-info/METADATA,sha256=_asH0B1lSZlhbsicu8zCH8vskDa2kFOz4RDFYHaknxU,14669
|
|
78
|
+
quasarr-2.4.5.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
|
|
79
|
+
quasarr-2.4.5.dist-info/entry_points.txt,sha256=gXi8mUKsIqKVvn-bOc8E5f04sK_KoMCC-ty6b2Hf-jc,40
|
|
80
|
+
quasarr-2.4.5.dist-info/licenses/LICENSE,sha256=QQFCAfDgt7lSA8oSWDHIZ9aTjFbZaBJdjnGOHkuhK7k,1060
|
|
81
|
+
quasarr-2.4.5.dist-info/RECORD,,
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
quasarr
|
|
File without changes
|
|
File without changes
|