|
|
@ -1,4 +1,4 @@ |
|
|
|
#VERSION: 1.25 |
|
|
|
#VERSION: 1.30 |
|
|
|
#AUTHORS: BTDigg team (research@btdigg.org) |
|
|
|
#AUTHORS: BTDigg team (research@btdigg.org) |
|
|
|
|
|
|
|
|
|
|
|
# GNU GENERAL PUBLIC LICENSE |
|
|
|
# GNU GENERAL PUBLIC LICENSE |
|
|
@ -33,30 +33,39 @@ class btdigg(object): |
|
|
|
|
|
|
|
|
|
|
|
def search(self, what, cat='all'): |
|
|
|
def search(self, what, cat='all'): |
|
|
|
req = urllib.parse.unquote(what) |
|
|
|
req = urllib.parse.unquote(what) |
|
|
|
u = urllib.request.urlopen('https://api.btdigg.org/api/public-8e9a50f8335b964f/s01?%s' % (urllib.parse.urlencode(dict(q = req)),)) |
|
|
|
what_list = req.split() |
|
|
|
|
|
|
|
i = 0 |
|
|
|
try: |
|
|
|
results = 0 |
|
|
|
|
|
|
|
while i < 3: |
|
|
|
|
|
|
|
u = urllib.request.urlopen('https://api.btdigg.org/api/public-8e9a50f8335b964f/s01?%s' % urllib.parse.urlencode(dict(q = req, p = i))) |
|
|
|
for line in u: |
|
|
|
for line in u: |
|
|
|
line = line.decode('utf-8') |
|
|
|
try: |
|
|
|
if line.startswith('#'): |
|
|
|
line = line.decode('utf8') |
|
|
|
continue |
|
|
|
if line.startswith('#'): |
|
|
|
|
|
|
|
continue |
|
|
|
info_hash, name, files, size, dl, seen = line.strip().split('\t')[:6] |
|
|
|
|
|
|
|
name = name.replace('|', '') |
|
|
|
info_hash, name, files, size, dl, seen = line.strip().split('\t')[:6] |
|
|
|
res = dict(link = 'magnet:?xt=urn:btih:%s&dn=%s' % (info_hash, urllib.parse.quote(name)), |
|
|
|
name = name.replace('|', '') |
|
|
|
name = name, |
|
|
|
# BTDigg returns unrelated results, we need to filter |
|
|
|
size = size, |
|
|
|
if not all(word in name.lower() for word in what_list): |
|
|
|
seeds = int(dl), |
|
|
|
continue |
|
|
|
leech = int(dl), |
|
|
|
|
|
|
|
engine_url = self.url, |
|
|
|
res = dict(link = 'magnet:?xt=urn:btih:%s&dn=%s' % (info_hash, urllib.parse.quote(name)), |
|
|
|
desc_link = '%s/search?%s' % (self.url, urllib.parse.urlencode(dict(info_hash = info_hash, q = req)),)) |
|
|
|
name = name, |
|
|
|
|
|
|
|
size = size, |
|
|
|
prettyPrinter(res) |
|
|
|
seeds = int(dl), |
|
|
|
finally: |
|
|
|
leech = int(dl), |
|
|
|
u.close() |
|
|
|
engine_url = self.url, |
|
|
|
|
|
|
|
desc_link = '%s/search?%s' % (self.url, urllib.parse.urlencode(dict(info_hash = info_hash, q = req)))) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
prettyPrinter(res) |
|
|
|
|
|
|
|
results += 1 |
|
|
|
|
|
|
|
except: |
|
|
|
|
|
|
|
pass |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if results == 0: |
|
|
|
|
|
|
|
break |
|
|
|
|
|
|
|
i += 1 |
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
|
|
if __name__ == "__main__": |
|
|
|
s = btdigg() |
|
|
|
s = btdigg() |
|
|
|