Add Filenuke support

master
Sven Slootweg 12 years ago
parent 6e6489a04b
commit acd96523aa

@ -25,6 +25,9 @@ def resolve(url):
elif re.match("https?:\/\/(www\.)?vidbux\.com\/[a-zA-Z0-9]+", url) is not None: elif re.match("https?:\/\/(www\.)?vidbux\.com\/[a-zA-Z0-9]+", url) is not None:
task = resolvers.VidbuxTask(url) task = resolvers.VidbuxTask(url)
return task.run() return task.run()
elif re.match("https?:\/\/(www\.)?filenuke\.com\/[a-zA-Z0-9]+", url) is not None:
task = resolvers.FilenukeTask(url)
return task.run()
elif re.match("https?:\/\/(www\.)?pastebin\.com\/[a-zA-Z0-9]+", url) is not None: elif re.match("https?:\/\/(www\.)?pastebin\.com\/[a-zA-Z0-9]+", url) is not None:
task = resolvers.PastebinTask(url) task = resolvers.PastebinTask(url)
return task.run() return task.run()

@ -8,3 +8,4 @@ from pastebin import *
from mediafire import * from mediafire import *
from vidxden import * from vidxden import *
from vidbux import * from vidbux import *
from filenuke import *

@ -0,0 +1,93 @@
import re, time, urllib2
from resolv.shared import ResolverError, TechnicalError, Task, unpack_js
# No such file or the file has been removed due to copyright infringement issues.
class FilenukeTask(Task):
result_type = "video"
name = "Filenuke"
author = "Sven Slootweg"
author_url = "http://cryto.net/~joepie91"
def run(self):
matches = re.search("https?:\/\/(www\.)?filenuke\.com\/([a-zA-Z0-9]+)", self.url)
if matches is None:
self.state = "invalid"
raise ResolverError("The provided URL is not a valid Filenuke URL.")
video_id = matches.group(2)
try:
contents = self.fetch_page(self.url)
except urllib2.URLError, e:
self.state = "failed"
raise TechnicalError("Could not retrieve the video page.")
if 'Choose how to download' not in contents:
self.state = "invalid"
raise ResolverError("The provided URL does not exist.")
matches = re.search('<input type="hidden" name="fname" value="([^"]+)">', contents)
if matches is None:
self.state = "failed"
raise TechnicalError("Could not find filename.")
filename = matches.group(1)
matches = re.search('<input type="hidden" name="referer" value="([^"]*)">', contents)
if matches is None:
self.state = "failed"
raise TechnicalError("Could not find referer.")
referer = matches.group(1)
try:
contents = self.post_page(self.url, {
'op': "download1",
'usr_login': "",
'id': video_id,
'filename': filename,
'referer': referer,
'method_free': "Free"
})
except urllib2.URLError, e:
self.state = "failed"
raise TechnicalError("Could not continue to download")
matches = re.search('<div id="player_code">(.*?)</div>', contents, re.DOTALL)
if matches is None:
self.state = "unsupported"
raise ResolverError("No player was found. The Filenuke resolver currently only supports video links.")
player_code = matches.group(1)
script = unpack_js(player_code)
matches = re.search("'file','([^']+)'", script)
if matches is None:
self.state = "failed"
raise TechnicalError("No video was found on the specified URL.")
video_file = matches.group(1)
stream_dict = {
'url' : video_file,
'method' : "GET",
'quality' : "unknown",
'priority' : 1,
'format' : "unknown"
}
self.results = {
'title': "",
'videos': [stream_dict]
}
self.state = "finished"
return self

@ -29,6 +29,9 @@ suites = {
}, },
'vidbux': { 'vidbux': {
"VidBux": "http://www.vidbux.com/5ovunjri3fqq" "VidBux": "http://www.vidbux.com/5ovunjri3fqq"
},
'filenuke': {
"Filenuke": "http://filenuke.com/osk9yi7vbtq0"
} }
} }

Loading…
Cancel
Save