mirror of
https://github.com/vikstrous/pirate-get
synced 2025-01-24 12:14:20 +01:00
Cosmesis
Use more idioms and switch to single quotes
This commit is contained in:
parent
10ba834ab0
commit
23211e5a91
343
pirate-get.py
343
pirate-get.py
@ -36,71 +36,71 @@ from urllib.error import URLError
|
|||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
|
||||||
categories = {
|
categories = {
|
||||||
"All":"0",
|
'All': 0,
|
||||||
"Audio":"100",
|
'Applications': 300,
|
||||||
"Audio/Music":"101",
|
'Applications/Android': 306,
|
||||||
"Audio/Audio books":"102",
|
'Applications/Handheld': 304,
|
||||||
"Audio/Sound clips":"103",
|
'Applications/IOS (iPad/iPhone)': 305,
|
||||||
"Audio/FLAC":"104",
|
'Applications/Mac': 302,
|
||||||
"Audio/Other":"199",
|
'Applications/Other OS': 399,
|
||||||
"Video":"200",
|
'Applications/UNIX': 303,
|
||||||
"Video/Movies":"201",
|
'Applications/Windows': 301,
|
||||||
"Video/Movies DVDR":"202",
|
'Audio': 100,
|
||||||
"Video/Music videos":"203",
|
'Audio/Audio books': 102,
|
||||||
"Video/Movie clips":"204",
|
'Audio/FLAC': 104,
|
||||||
"Video/TV shows":"205",
|
'Audio/Music': 101,
|
||||||
"Video/Handheld":"206",
|
'Audio/Other': 199,
|
||||||
"Video/HD - Movies":"207",
|
'Audio/Sound clips': 103,
|
||||||
"Video/HD - TV shows":"208",
|
'Games': 400,
|
||||||
"Video/3D":"209",
|
'Games/Android': 408,
|
||||||
"Video/Other":"299",
|
'Games/Handheld': 406,
|
||||||
"Applications":"300",
|
'Games/IOS (iPad/iPhone)': 407,
|
||||||
"Applications/Windows":"301",
|
'Games/Mac': 402,
|
||||||
"Applications/Mac":"302",
|
'Games/Other': 499,
|
||||||
"Applications/UNIX":"303",
|
'Games/PC': 401,
|
||||||
"Applications/Handheld":"304",
|
'Games/PSx': 403,
|
||||||
"Applications/IOS (iPad/iPhone)":"305",
|
'Games/Wii': 405,
|
||||||
"Applications/Android":"306",
|
'Games/XBOX360': 404,
|
||||||
"Applications/Other OS":"399",
|
'Other': 600,
|
||||||
"Games":"400",
|
'Other/Comics': 602,
|
||||||
"Games/PC":"401",
|
'Other/Covers': 604,
|
||||||
"Games/Mac":"402",
|
'Other/E-books': 601,
|
||||||
"Games/PSx":"403",
|
'Other/Other': 699,
|
||||||
"Games/XBOX360":"404",
|
'Other/Physibles': 605,
|
||||||
"Games/Wii":"405",
|
'Other/Pictures': 603,
|
||||||
"Games/Handheld":"406",
|
'Porn': 500,
|
||||||
"Games/IOS (iPad/iPhone)":"407",
|
'Porn/Games': 504,
|
||||||
"Games/Android":"408",
|
'Porn/HD - Movies': 505,
|
||||||
"Games/Other":"499",
|
'Porn/Movie clips': 506,
|
||||||
"Porn":"500",
|
'Porn/Movies': 501,
|
||||||
"Porn/Movies":"501",
|
'Porn/Movies DVDR': 502,
|
||||||
"Porn/Movies DVDR":"502",
|
'Porn/Other': 599,
|
||||||
"Porn/Pictures":"503",
|
'Porn/Pictures': 503,
|
||||||
"Porn/Games":"504",
|
'Video': 200,
|
||||||
"Porn/HD - Movies":"505",
|
'Video/3D': 209,
|
||||||
"Porn/Movie clips":"506",
|
'Video/HD - Movies': 207,
|
||||||
"Porn/Other":"599",
|
'Video/HD - TV shows': 208,
|
||||||
"Other":"600",
|
'Video/Handheld': 206,
|
||||||
"Other/E-books":"601",
|
'Video/Movie clips': 204,
|
||||||
"Other/Comics":"602",
|
'Video/Movies': 201,
|
||||||
"Other/Pictures":"603",
|
'Video/Movies DVDR': 202,
|
||||||
"Other/Covers":"604",
|
'Video/Music videos': 203,
|
||||||
"Other/Physibles":"605",
|
'Video/Other': 299,
|
||||||
"Other/Other":"699"}
|
'Video/TV shows': 205}
|
||||||
|
|
||||||
sorts = {
|
sorts = {
|
||||||
"TitleDsc": "1", "TitleAsc": "2",
|
'TitleDsc': 1, 'TitleAsc': 2,
|
||||||
"DateDsc": "3", "DateAsc": "4",
|
'DateDsc': 3, 'DateAsc': 4,
|
||||||
"SizeDsc": "5", "SizeAsc": "6",
|
'SizeDsc': 5, 'SizeAsc': 6,
|
||||||
"SeedersDsc": "7", "SeedersAsc": "8",
|
'SeedersDsc': 7, 'SeedersAsc': 8,
|
||||||
"LeechersDsc": "9", "LeechersAsc": "10",
|
'LeechersDsc': 9, 'LeechersAsc': 10,
|
||||||
"CategoryDsc": "13", "CategoryAsc": "14",
|
'CategoryDsc': 13, 'CategoryAsc': 14,
|
||||||
"Default": "99"}
|
'Default': 99}
|
||||||
|
|
||||||
|
|
||||||
class NoRedirection(request.HTTPErrorProcessor):
|
class NoRedirection(request.HTTPErrorProcessor):
|
||||||
def http_response(self, request, response):
|
def http_response(self, _, res):
|
||||||
return response
|
return res
|
||||||
|
|
||||||
https_response = http_response
|
https_response = http_response
|
||||||
|
|
||||||
@ -143,16 +143,16 @@ def print(*args, **kwargs):
|
|||||||
import colorama
|
import colorama
|
||||||
colorama.init()
|
colorama.init()
|
||||||
color_dict = {
|
color_dict = {
|
||||||
"default": "",
|
'default': '',
|
||||||
"header": colorama.Back.BLACK + colorama.Fore.WHITE,
|
'header': colorama.Back.BLACK + colorama.Fore.WHITE,
|
||||||
"alt": colorama.Fore.YELLOW,
|
'alt': colorama.Fore.YELLOW,
|
||||||
"zebra_0": "",
|
'zebra_0': '',
|
||||||
"zebra_1": colorama.Fore.BLUE,
|
'zebra_1': colorama.Fore.BLUE,
|
||||||
"WARN": colorama.Fore.MAGENTA,
|
'WARN': colorama.Fore.MAGENTA,
|
||||||
"ERROR": colorama.Fore.RED}
|
'ERROR': colorama.Fore.RED}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
c = color_dict[kwargs.pop("color")]
|
c = color_dict[kwargs.pop('color')]
|
||||||
args = (c + args[0],) + args[1:] + (colorama.Style.RESET_ALL,)
|
args = (c + args[0],) + args[1:] + (colorama.Style.RESET_ALL,)
|
||||||
except (KeyError, IndexError):
|
except (KeyError, IndexError):
|
||||||
pass
|
pass
|
||||||
@ -167,24 +167,24 @@ def remote(args, mirror):
|
|||||||
res_l = []
|
res_l = []
|
||||||
pages = int(args.pages)
|
pages = int(args.pages)
|
||||||
if pages < 1:
|
if pages < 1:
|
||||||
raise ValueError("Please provide an integer greater than 0 "
|
raise ValueError('Please provide an integer greater than 0 '
|
||||||
"for the number of pages to fetch.")
|
'for the number of pages to fetch.')
|
||||||
|
|
||||||
if str(args.category) in categories.values():
|
if str(args.category) in categories.values():
|
||||||
category = args.category
|
category = args.category
|
||||||
elif args.category in categories.keys():
|
elif args.category in categories.keys():
|
||||||
category = categories[args.category]
|
category = categories[args.category]
|
||||||
else:
|
else:
|
||||||
category = "0"
|
category = '0'
|
||||||
print("Invalid category ignored", color="WARN")
|
print('Invalid category ignored', color='WARN')
|
||||||
|
|
||||||
if str(args.sort) in sorts.values():
|
if str(args.sort) in sorts.values():
|
||||||
sort = args.sort
|
sort = args.sort
|
||||||
elif args.sort in sorts.keys():
|
elif args.sort in sorts.keys():
|
||||||
sort = sorts[args.sort]
|
sort = sorts[args.sort]
|
||||||
else:
|
else:
|
||||||
sort = "99"
|
sort = '99'
|
||||||
print("Invalid sort ignored", color="WARN")
|
print('Invalid sort ignored', color='WARN')
|
||||||
|
|
||||||
# Catch the Ctrl-C exception and exit cleanly
|
# Catch the Ctrl-C exception and exit cleanly
|
||||||
try:
|
try:
|
||||||
@ -193,20 +193,20 @@ def remote(args, mirror):
|
|||||||
identifiers = []
|
identifiers = []
|
||||||
for page in range(pages):
|
for page in range(pages):
|
||||||
if args.browse:
|
if args.browse:
|
||||||
path = "/browse/"
|
path = '/browse/'
|
||||||
if(category == "0"):
|
if(category == '0'):
|
||||||
category = '100'
|
category = '100'
|
||||||
path = '/browse/' + '/'.join(str(i) for i in (
|
path = '/browse/' + '/'.join(str(i) for i in (
|
||||||
category, page, sort))
|
category, page, sort))
|
||||||
elif len(args.search) == 0:
|
elif len(args.search) == 0:
|
||||||
path = "/top/48h" if args.recent else "/top/"
|
path = '/top/48h' if args.recent else '/top/'
|
||||||
if(category == "0"):
|
if(category == '0'):
|
||||||
path += 'all'
|
path += 'all'
|
||||||
else:
|
else:
|
||||||
path += category
|
path += str(category)
|
||||||
else:
|
else:
|
||||||
path = '/search/' + '/'.join(str(i) for i in (
|
path = '/search/' + '/'.join(str(i) for i in (
|
||||||
"+".join(args.search),
|
'+'.join(args.search),
|
||||||
page, sort,
|
page, sort,
|
||||||
category))
|
category))
|
||||||
|
|
||||||
@ -220,28 +220,28 @@ def remote(args, mirror):
|
|||||||
r'([^<]+)</td>', res)
|
r'([^<]+)</td>', res)
|
||||||
|
|
||||||
# check for a blocked mirror
|
# check for a blocked mirror
|
||||||
no_results = re.search(r"\"No hits\.", res)
|
no_results = re.search(r'"No hits\.', res)
|
||||||
if found == [] and not no_results is None:
|
if found == [] and not no_results is None:
|
||||||
# Contradiction - we found no results,
|
# Contradiction - we found no results,
|
||||||
# but the page didn't say there were no results.
|
# but the page didn't say there were no results.
|
||||||
# The page is probably not actually the pirate bay,
|
# The page is probably not actually the pirate bay,
|
||||||
# so let's try another mirror
|
# so let's try another mirror
|
||||||
raise IOError("Blocked mirror detected.")
|
raise IOError('Blocked mirror detected.')
|
||||||
|
|
||||||
# get sizes as well and substitute the character
|
# get sizes as well and substitute the character
|
||||||
sizes.extend([match.replace(" ", " ")
|
sizes.extend([match.replace(' ', ' ').split()
|
||||||
for match in re.findall(r"(?<=Size )[0-9.]"
|
for match in re.findall(r'(?<=Size )[0-9.]'
|
||||||
r"+\ \;[KMGT]*[i ]*B", res)])
|
r'+\ \;[KMGT]*[i ]*B', res)])
|
||||||
|
|
||||||
uploaded.extend([match.replace(" ", " ")
|
uploaded.extend([match.replace(' ', ' ')
|
||||||
for match in re.findall(r"(?<=Uploaded )"
|
for match in re.findall(r'(?<=Uploaded )'
|
||||||
r".+(?=\, Size)",res)])
|
r'.+(?=\, Size)',res)])
|
||||||
|
|
||||||
identifiers.extend([match.replace(" ", " ")
|
identifiers.extend([match.replace(' ', ' ')
|
||||||
for match in re.findall("(?<=/torrent/)"
|
for match in re.findall('(?<=/torrent/)'
|
||||||
"[0-9]+(?=/)",res)])
|
'[0-9]+(?=/)',res)])
|
||||||
|
|
||||||
state = "seeds"
|
state = 'seeds'
|
||||||
curr = ['', 0, 0] #magnet, seeds, leeches
|
curr = ['', 0, 0] #magnet, seeds, leeches
|
||||||
for f in found:
|
for f in found:
|
||||||
if f[1] == '':
|
if f[1] == '':
|
||||||
@ -256,7 +256,7 @@ def remote(args, mirror):
|
|||||||
res_l.append(curr)
|
res_l.append(curr)
|
||||||
curr = ['', 0, 0]
|
curr = ['', 0, 0]
|
||||||
except KeyboardInterrupt :
|
except KeyboardInterrupt :
|
||||||
print("\nCancelled.")
|
print('\nCancelled.')
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
# return the sizes in a spearate list
|
# return the sizes in a spearate list
|
||||||
@ -282,29 +282,28 @@ def config_to_load():
|
|||||||
|
|
||||||
# enhanced print output with column titles
|
# enhanced print output with column titles
|
||||||
def print_search_results(mags, sizes, uploaded):
|
def print_search_results(mags, sizes, uploaded):
|
||||||
columns = int(os.popen('stty size', 'r').read().split()[1]) - 52
|
columns = int(os.popen('stty size', 'r').read().split()[1]) - 55
|
||||||
cur_color = "zebra_0"
|
cur_color = 'zebra_0'
|
||||||
|
|
||||||
print("%5s %6s %6s %-5s %-11s %-11s %-*s" \
|
print("%5s %6s %6s %-5s %-11s %-11s %-*s" \
|
||||||
% ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", columns, "NAME"),
|
% ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", columns, "NAME"),
|
||||||
color="header")
|
color="header")
|
||||||
|
|
||||||
for m in range(len(mags)):
|
for m, magnet in enumerate(mags):
|
||||||
magnet = mags[m]
|
|
||||||
no_seeders = int(magnet[1])
|
no_seeders = int(magnet[1])
|
||||||
no_leechers = int(magnet[2])
|
no_leechers = int(magnet[2])
|
||||||
name = re.search(r"dn=([^\&]*)", magnet[0])
|
name = re.search(r'dn=([^\&]*)', magnet[0])
|
||||||
|
|
||||||
# compute the S/L ratio (Higher is better)
|
# compute the S/L ratio (Higher is better)
|
||||||
try:
|
try:
|
||||||
ratio = no_seeders/no_leechers
|
ratio = no_seeders / no_leechers
|
||||||
except ZeroDivisionError:
|
except ZeroDivisionError:
|
||||||
ratio = 0
|
ratio = 0
|
||||||
|
|
||||||
# Alternate between colors
|
# Alternate between colors
|
||||||
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
|
cur_color = 'zebra_0' if (cur_color == 'zebra_1') else 'zebra_1'
|
||||||
|
|
||||||
torrent_name = parse.unquote(name.group(1)).replace("+", " ")
|
torrent_name = parse.unquote(name.group(1)).replace('+', ' ')
|
||||||
# enhanced print output with justified columns
|
# enhanced print output with justified columns
|
||||||
print("%5d %6d %6d %5.1f %-11s %-11s %-*s" % (
|
print("%5d %6d %6d %5.1f %-11s %-11s %-*s" % (
|
||||||
m, no_seeders, no_leechers, ratio ,sizes[m],
|
m, no_seeders, no_leechers, ratio ,sizes[m],
|
||||||
@ -323,17 +322,17 @@ def print_descriptions(chosen_links, mags, site, identifiers):
|
|||||||
f = gzip.GzipFile(fileobj=BytesIO(f.read()))
|
f = gzip.GzipFile(fileobj=BytesIO(f.read()))
|
||||||
|
|
||||||
res = f.read().decode('utf-8')
|
res = f.read().decode('utf-8')
|
||||||
name = re.search(r"dn=([^\&]*)", mags[link][0])
|
name = re.search(r'dn=([^\&]*)', mags[link][0])
|
||||||
torrent_name = parse.unquote(name.group(1)).replace("+", " ")
|
torrent_name = parse.unquote(name.group(1)).replace('+', ' ')
|
||||||
desc = re.search(r"<div class=\"nfo\">\s*<pre>(.+?)(?=</pre>)",
|
desc = re.search(r'<div class="nfo">\s*<pre>(.+?)(?=</pre>)',
|
||||||
res, re.DOTALL).group(1)
|
res, re.DOTALL).group(1)
|
||||||
|
|
||||||
# Replace HTML links with markdown style versions
|
# Replace HTML links with markdown style versions
|
||||||
desc = re.sub(r"<a href=\"\s*([^\"]+?)\s*\"[^>]*>(\s*)([^<]+?)(\s*"
|
desc = re.sub(r'<a href="\s*([^"]+?)\s*"[^>]*>(\s*)([^<]+?)(\s*'
|
||||||
r")</a>", r"\2[\3](\1)\4", desc)
|
r')</a>', r'\2[\3](\1)\4', desc)
|
||||||
|
|
||||||
print('Description for "' + torrent_name + '":', color="zebra_1")
|
print('Description for "' + torrent_name + '":', color='zebra_1')
|
||||||
print(desc, color="zebra_0")
|
print(desc, color='zebra_0')
|
||||||
|
|
||||||
def print_fileLists(chosen_links, mags, site, identifiers):
|
def print_fileLists(chosen_links, mags, site, identifiers):
|
||||||
for link in chosen_links:
|
for link in chosen_links:
|
||||||
@ -346,18 +345,18 @@ def print_fileLists(chosen_links, mags, site, identifiers):
|
|||||||
if f.info().get('Content-Encoding') == 'gzip':
|
if f.info().get('Content-Encoding') == 'gzip':
|
||||||
f = gzip.GzipFile(fileobj=BytesIO(f.read()))
|
f = gzip.GzipFile(fileobj=BytesIO(f.read()))
|
||||||
|
|
||||||
res = f.read().decode('utf-8').replace(" ", " ")
|
res = f.read().decode('utf-8').replace(' ', ' ')
|
||||||
files = re.findall(r"<td align=\"left\">\s*([^<]+?)\s*</td><td ali"
|
files = re.findall(r'<td align="left">\s*([^<]+?)\s*</td><td ali'
|
||||||
r"gn=\"right\">\s*([^<]+?)\s*</tr>", res)
|
r'gn="right">\s*([^<]+?)\s*</tr>', res)
|
||||||
name = re.search(r"dn=([^\&]*)", mags[int(link)][0])
|
name = re.search(r'dn=([^\&]*)', mags[int(link)][0])
|
||||||
torrent_name = parse.unquote(name.group(1)).replace("+", " ")
|
torrent_name = parse.unquote(name.group(1)).replace('+', ' ')
|
||||||
|
|
||||||
print('Files in "' + torrent_name + '":', color="zebra_1")
|
print('Files in "' + torrent_name + '":', color='zebra_1')
|
||||||
cur_color = "zebra_0"
|
cur_color = 'zebra_0'
|
||||||
|
|
||||||
for f in files:
|
for f in files:
|
||||||
print("%-11s %s" % (f[1], f[0]), color=cur_color)
|
print('{0[0]:>11} {0[1]}'.format(f), color=cur_color)
|
||||||
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
|
cur_color = 'zebra_0' if (cur_color == 'zebra_1') else 'zebra_1'
|
||||||
|
|
||||||
|
|
||||||
def id_generator(size=6, chars=string.ascii_uppercase + string.digits):
|
def id_generator(size=6, chars=string.ascii_uppercase + string.digits):
|
||||||
@ -379,103 +378,103 @@ def main():
|
|||||||
description='finds and downloads torrents from the Pirate Bay')
|
description='finds and downloads torrents from the Pirate Bay')
|
||||||
parser.add_argument('-b', dest='browse',
|
parser.add_argument('-b', dest='browse',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="display in Browse mode")
|
help='display in Browse mode')
|
||||||
parser.add_argument('search', metavar='search',
|
parser.add_argument('search', metavar='search',
|
||||||
nargs="*", help="term to search for")
|
nargs='*', help='term to search for')
|
||||||
parser.add_argument('-c', dest='category', metavar='category',
|
parser.add_argument('-c', dest='category', metavar='category',
|
||||||
help="specify a category to search", default="All")
|
help='specify a category to search', default='All')
|
||||||
parser.add_argument('-s', dest='sort', metavar='sort',
|
parser.add_argument('-s', dest='sort', metavar='sort',
|
||||||
help="specify a sort option", default="SeedersDsc")
|
help='specify a sort option', default='SeedersDsc')
|
||||||
parser.add_argument('-R', dest='recent', action='store_true',
|
parser.add_argument('-R', dest='recent', action='store_true',
|
||||||
help="torrents uploaded in the last 48hours."
|
help='torrents uploaded in the last 48hours.'
|
||||||
"*ignored in searches*")
|
'*ignored in searches*')
|
||||||
parser.add_argument('-l', dest='list_categories',
|
parser.add_argument('-l', dest='list_categories',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="list categories")
|
help='list categories')
|
||||||
parser.add_argument('--list_sorts', dest='list_sorts',
|
parser.add_argument('--list_sorts', dest='list_sorts',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="list Sortable Types")
|
help='list Sortable Types')
|
||||||
parser.add_argument('-t', dest='transmission',
|
parser.add_argument('-t', dest='transmission',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="call transmission-remote to start the download")
|
help='call transmission-remote to start the download')
|
||||||
parser.add_argument('--custom', dest='command',
|
parser.add_argument('--custom', dest='command',
|
||||||
help="call custom command, %%s will be replaced with"
|
help='call custom command, %%s will be replaced with'
|
||||||
"the url")
|
'the url')
|
||||||
parser.add_argument('--local', dest='database',
|
parser.add_argument('--local', dest='database',
|
||||||
help="an xml file containing the Pirate Bay database")
|
help='an xml file containing the Pirate Bay database')
|
||||||
parser.add_argument('-p', dest='pages', default=1,
|
parser.add_argument('-p', dest='pages', default=1,
|
||||||
help="the number of pages to fetch (doesn't work with"
|
help="the number of pages to fetch (doesn't work with"
|
||||||
"--local)")
|
'--local)')
|
||||||
parser.add_argument('-0', dest='first',
|
parser.add_argument('-0', dest='first',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="choose the top result")
|
help='choose the top result')
|
||||||
parser.add_argument('-a', dest='download_all',
|
parser.add_argument('-a', dest='download_all',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help="download all results")
|
help='download all results')
|
||||||
parser.add_argument('--color', dest='color',
|
parser.add_argument('--color', dest='color',
|
||||||
action='store_false', default=True,
|
action='store_false', default=True,
|
||||||
help="disable colored output")
|
help='disable colored output')
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
if args.list_categories:
|
if args.list_categories:
|
||||||
cur_color = "zebra_0"
|
cur_color = 'zebra_0'
|
||||||
for key, value in sorted(categories.iteritems()) :
|
for key, value in sorted(categories.items()) :
|
||||||
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
|
cur_color = 'zebra_0' if (cur_color == 'zebra_1') else 'zebra_1'
|
||||||
print(str(value) +"\t" + key, color=cur_color)
|
print(str(value), '\t', key, sep='', color=cur_color)
|
||||||
return
|
return
|
||||||
|
|
||||||
if args.list_sorts:
|
if args.list_sorts:
|
||||||
cur_color = "zebra_0"
|
cur_color = 'zebra_0'
|
||||||
for key, value in sorted(sorts.iteritems()):
|
for key, value in sorted(sorts.items()):
|
||||||
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
|
cur_color = 'zebra_0' if (cur_color == 'zebra_1') else 'zebra_1'
|
||||||
print(str(value) +"\t" + key, color=cur_color)
|
print(str(value), '\t', key, sep='', color=cur_color)
|
||||||
return
|
return
|
||||||
|
|
||||||
if args.database:
|
if args.database:
|
||||||
mags = local(args)
|
mags = local(args)
|
||||||
else:
|
else:
|
||||||
mirrors = ["http://thepiratebay.se"]
|
mirrors = ['http://thepiratebay.se']
|
||||||
try:
|
try:
|
||||||
opener = request.build_opener(NoRedirection)
|
opener = request.build_opener(NoRedirection)
|
||||||
f = opener.open("https://proxybay.info/list.txt", timeout=5)
|
f = opener.open('https://proxybay.info/list.txt', timeout=5)
|
||||||
if f.getcode() != 200:
|
if f.getcode() != 200:
|
||||||
raise IOError("The pirate bay responded with an error.")
|
raise IOError('The pirate bay responded with an error.')
|
||||||
res = f.read().decode('utf-8')
|
res = f.read().decode('utf-8')
|
||||||
mirrors.extend(res.split("\n")[3:])
|
mirrors.extend(res.split('\n')[3:])
|
||||||
except IOError:
|
except IOError:
|
||||||
print("Could not fetch additional mirrors", color="WARN")
|
print('Could not fetch additional mirrors', color='WARN')
|
||||||
for mirror in mirrors:
|
for mirror in mirrors:
|
||||||
try:
|
try:
|
||||||
print("Trying", mirror, end="... ")
|
print('Trying', mirror, end='... ')
|
||||||
mags, sizes, uploaded, identifiers = remote(args, mirror)
|
mags, sizes, uploaded, identifiers = remote(args, mirror)
|
||||||
site = mirror
|
site = mirror
|
||||||
print("Ok", color="alt")
|
print('Ok', color='alt')
|
||||||
break
|
break
|
||||||
except URLError:
|
except URLError:
|
||||||
print("Failed", color="WARN")
|
print('Failed', color='WARN')
|
||||||
|
|
||||||
if not mags or len(mags) == 0:
|
if not mags or len(mags) == 0:
|
||||||
print("No results")
|
print('No results')
|
||||||
return
|
return
|
||||||
|
|
||||||
print_search_results(mags, sizes, uploaded)
|
print_search_results(mags, sizes, uploaded)
|
||||||
|
|
||||||
if args.first:
|
if args.first:
|
||||||
print("Choosing first result")
|
print('Choosing first result')
|
||||||
choices = [0]
|
choices = [0]
|
||||||
elif args.download_all:
|
elif args.download_all:
|
||||||
print("Downloading all results")
|
print('Downloading all results')
|
||||||
choices = range(len(mags))
|
choices = range(len(mags))
|
||||||
else:
|
else:
|
||||||
# New input loop to support different link options
|
# New input loop to support different link options
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
print("\nSelect links (Type 'h' for more options" +
|
print("\nSelect links (Type 'h' for more options"
|
||||||
", 'q' to quit)", end="\b", color="alt")
|
", 'q' to quit)", end='\b', color='alt')
|
||||||
l=input(": ")
|
l=input(': ')
|
||||||
except KeyboardInterrupt :
|
except KeyboardInterrupt :
|
||||||
print("\nCancelled.")
|
print('\nCancelled.')
|
||||||
sys.exit(0)
|
return
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# Very permissive handling
|
# Very permissive handling
|
||||||
@ -490,23 +489,23 @@ def main():
|
|||||||
# Substitute multiple consecutive spaces/commas for single comma
|
# Substitute multiple consecutive spaces/commas for single comma
|
||||||
# Remove anything that isn't an integer or comma.
|
# Remove anything that isn't an integer or comma.
|
||||||
# Turn into list
|
# Turn into list
|
||||||
l = re.sub(r"^[hdfp, ]*|[hdfp, ]*$", "", l)
|
l = re.sub(r'^[hdfp, ]*|[hdfp, ]*$', '', l)
|
||||||
l = re.sub("[ ,]+", ",", l)
|
l = re.sub('[ ,]+', ',', l)
|
||||||
l = re.sub("[^0-9,]", "", l)
|
l = re.sub('[^0-9,]', '', l)
|
||||||
choices = l.split(",")
|
choices = l.split(',')
|
||||||
|
|
||||||
# Act on option, if supplied
|
# Act on option, if supplied
|
||||||
print("")
|
print('')
|
||||||
if code == 'h':
|
if code == 'h':
|
||||||
print("Options:",
|
print('Options:',
|
||||||
"<links>: Download selected torrents",
|
'<links>: Download selected torrents',
|
||||||
"[d<links>]: Get descriptions",
|
'[d<links>]: Get descriptions',
|
||||||
"[f<links>]: Get files",
|
'[f<links>]: Get files',
|
||||||
"[p] Print search results",
|
'[p] Print search results',
|
||||||
"[q] Quit", sep="\n")
|
'[q] Quit', sep='\n')
|
||||||
elif code == 'q':
|
elif code == 'q':
|
||||||
print("Bye.", color="alt")
|
print('Bye.', color='alt')
|
||||||
sys.exit(0)
|
return
|
||||||
elif code == 'd':
|
elif code == 'd':
|
||||||
print_descriptions(choices, mags, site, identifiers)
|
print_descriptions(choices, mags, site, identifiers)
|
||||||
elif code == 'f':
|
elif code == 'f':
|
||||||
@ -529,7 +528,7 @@ def main():
|
|||||||
config.get('SaveToFile','directory')
|
config.get('SaveToFile','directory')
|
||||||
) + id_generator() + '.magnet'
|
) + id_generator() + '.magnet'
|
||||||
|
|
||||||
print("Saving to File: " + fileName)
|
print('Saving to File:', fileName)
|
||||||
|
|
||||||
f = open(fileName, 'w')
|
f = open(fileName, 'w')
|
||||||
for choice in choices:
|
for choice in choices:
|
||||||
@ -553,5 +552,5 @@ def main():
|
|||||||
webbrowser.open(url)
|
webbrowser.open(url)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
Loading…
Reference in New Issue
Block a user