1
0
mirror of https://github.com/vikstrous/pirate-get synced 2025-01-25 12:24:20 +01:00

Add options to print torrent descriptions & files

The user can type 'd' or 'f' before their selected links to get either
the piratebay description or file list printed.  This data is requested
from the site using the torrent id number parsed from the search
results.
This commit is contained in:
Alex Peak 2014-07-26 23:06:59 -07:00
parent 73e1779b64
commit f6d1b5f806

View File

@ -101,6 +101,7 @@ def main():
try: try:
sizes = [] sizes = []
uploaded = [] uploaded = []
identifiers = []
for page in xrange(pages): for page in xrange(pages):
# #
@ -133,6 +134,7 @@ def main():
# print res # print res
sizes.extend([match.replace("&nbsp;", " ") for match in re.findall("(?<=Size )[0-9.]+\&nbsp\;[KMGT]*[i ]*B",res)]) sizes.extend([match.replace("&nbsp;", " ") for match in re.findall("(?<=Size )[0-9.]+\&nbsp\;[KMGT]*[i ]*B",res)])
uploaded.extend([match.replace("&nbsp;", " ") for match in re.findall("(?<=Uploaded ).+(?=\, Size)",res)]) uploaded.extend([match.replace("&nbsp;", " ") for match in re.findall("(?<=Uploaded ).+(?=\, Size)",res)])
identifiers.extend([match.replace("&nbsp;", " ") for match in re.findall("(?<=/torrent/)[0-9]+(?=/)",res)])
# pprint(sizes); print len(sizes) # pprint(sizes); print len(sizes)
# pprint(uploaded); print len(uploaded) # pprint(uploaded); print len(uploaded)
state = "seeds" state = "seeds"
@ -154,7 +156,7 @@ def main():
exit() exit()
# return the sizes in a spearate list # return the sizes in a spearate list
return res_l, sizes, uploaded return res_l, sizes, uploaded, identifiers
args = parser.parse_args() args = parser.parse_args()
@ -221,7 +223,7 @@ def main():
for mirror in mirrors: for mirror in mirrors:
try: try:
print("Trying " + mirror) print("Trying " + mirror)
mags, sizes, uploaded = remote(args, mirror) mags, sizes, uploaded, identifiers = remote(args, mirror)
break break
except Exception, e: except Exception, e:
print(format(e)) print(format(e))
@ -231,6 +233,7 @@ def main():
print("no results") print("no results")
return return
# enhanced print output with column titles # enhanced print output with column titles
def print_search_results():
print("%5s %6s %6s %-5s %-11s %-11s %s" \ print("%5s %6s %6s %-5s %-11s %-11s %s" \
% ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", "NAME"), % ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", "NAME"),
color="header") color="header")
@ -256,6 +259,47 @@ def main():
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],
uploaded[m], torrent_name), color=cur_color) uploaded[m], torrent_name), color=cur_color)
def print_descriptions(chosen_links):
for link in chosen_links:
path = '/torrent/' + identifiers[int(link)] + '/'
request = urllib2.Request(mirror + path)
request.add_header('Accept-encoding', 'gzip')
f = urllib2.urlopen(request)
if f.info().get('Content-Encoding') == 'gzip':
buf = StringIO(f.read())
f = gzip.GzipFile(fileobj=buf)
res = f.read()
name = re.search("dn=([^\&]*)", mags[int(link)][0])
torrent_name = urllib.unquote(name.group(1).encode('ascii')) \
.decode('utf-8').replace("+", " ")
desc = re.search(r"<div class=\"nfo\">\s*<pre>(.+?)(?=</pre>)", res, re.DOTALL).group(1)
# Replace HTML links with markdown style versions
desc = re.sub(r"<a href=\"\s*([^\"]+?)\s*\"[^>]*>(\s*)([^<]+?)(\s*)</a>", r"\2[\3](\1)\4", desc)
print ('Description for "' + torrent_name + '":', color="zebra_1")
print (desc, color="zebra_0")
def print_fileLists(chosen_links):
for link in chosen_links:
path = '/ajax_details_filelist.php'
query = '?id=' + identifiers[int(link)]
request = urllib2.Request(mirror + path + query)
request.add_header('Accept-encoding', 'gzip')
f = urllib2.urlopen(request)
if f.info().get('Content-Encoding') == 'gzip':
buf = StringIO(f.read())
f = gzip.GzipFile(fileobj=buf)
res = f.read().replace("&nbsp;", " ")
files = re.findall(r"<td align=\"left\">\s*([^<]+?)\s*</td><td align=\"right\">\s*([^<]+?)\s*</tr>", res)
name = re.search("dn=([^\&]*)", mags[int(link)][0])
torrent_name = urllib.unquote(name.group(1).encode('ascii')) \
.decode('utf-8').replace("+", " ")
print ('Files in "' + torrent_name + '":', color="zebra_1")
cur_color = "zebra_0"
for f in files:
print ("%-11s %s" % (f[1], f[0]), color=cur_color)
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
print_search_results()
if args.first: if args.first:
print("Choosing first result"); print("Choosing first result");
@ -264,22 +308,57 @@ def main():
print("Downloading all results"); print("Downloading all results");
choices = range(0, len(mags)) choices = range(0, len(mags))
else: else:
# New input loop to support different link options
while True:
try: try:
l = raw_input("Select link(s): ") l = raw_input("Select link(s) (Type 'h' for more options): ")
except KeyboardInterrupt : except KeyboardInterrupt :
print("\nCancelled.") print("\nCancelled.")
exit() exit()
try: try:
# Very permissive handling # Very permissive handling
# Check for any occurances or d, f, or p
cmd_code_match = re.search(r'([hdfp])', l, flags=re.IGNORECASE)
if cmd_code_match:
code = cmd_code_match.group(0).lower()
else:
code = None
# Clean up command codes
l = re.sub(r"^[hdfp, ]*|[hdfp, ]*$", "", l)
# Substitute multiple consecutive spaces or commas for single comma # Substitute multiple consecutive spaces or commas for single comma
l = re.sub("[ ,]+", ",", l) l = re.sub("[ ,]+", ",", l)
# Remove anything that isn't an integer or comma. # Remove anything that isn't an integer or comma.
l = re.sub("[^0-9,]", "", l) l = re.sub("[^0-9,]", "", l)
# Turn into list # Turn into list
choices = l.split(",") choices = l.split(",")
except Exception: # Act on option, if supplied
if code == 'h':
print("Options:")
print("<links>: Download selected torrents")
print("[d<links>]: Get descriptions")
print("[f<links>]: Get files")
print("[p] Print search results")
continue
elif code == 'd':
print_descriptions(choices)
continue
elif code == 'f':
print_fileLists(choices)
continue
elif code == 'p':
print_search_results()
continue
elif not l:
print('No links entered!')
continue
else:
break
except Exception, e:
print('Exception:')
print(str(e))
choices = () choices = ()
break;
if config.get('SaveToFile', 'enabled'): if config.get('SaveToFile', 'enabled'):
# Save to file is enabled # Save to file is enabled