diff options
-rw-r--r-- | Plugins/RapidshareCom.py | 2 | ||||
-rw-r--r-- | module/file_list.py | 30 | ||||
-rw-r--r-- | module/remote/RequestHandler.py | 6 | ||||
-rw-r--r-- | module/remote/RequestObject.py | 1 | ||||
-rw-r--r-- | pyLoadCli.py | 41 | ||||
-rw-r--r-- | pyLoadCore.py | 8 |
6 files changed, 72 insertions, 16 deletions
diff --git a/Plugins/RapidshareCom.py b/Plugins/RapidshareCom.py index 20423197b..4eb7bf93d 100644 --- a/Plugins/RapidshareCom.py +++ b/Plugins/RapidshareCom.py @@ -130,7 +130,7 @@ class RapidshareCom(Plugin): file_url_pattern = r".*name=\"dlf\" action=\"(.*)\" method=.*" return re.search(file_url_pattern, self.html[1]).group(1) else: - return False + raise Exception, "Error when retrieving download url" def get_file_name(self): if self.html[0] == None: diff --git a/module/file_list.py b/module/file_list.py index d2a634645..8f32ef474 100644 --- a/module/file_list.py +++ b/module/file_list.py @@ -18,7 +18,7 @@ # ### -LIST_VERSION = 1 +LIST_VERSION = 2 import cPickle from Py_Load_File import PyLoadFile @@ -28,7 +28,7 @@ class File_List(object): def __init__(self, core): self.core = core self.files = [] - self.data = {'version': LIST_VERSION} + self.data = {'version': LIST_VERSION, 'order': []} self.load() def new_pyfile(self, url): @@ -46,6 +46,7 @@ class File_List(object): new_file = self.new_pyfile(url) self.files.append(new_file) self.data[new_file.id] = Data(url) + self.data['order'].append(new_file.id) def extend(self, urls): for url in urls: @@ -56,8 +57,24 @@ class File_List(object): if pyfile in self.files: self.files.remove(pyfile) + self.data['order'].remove(pyfile.id) del self.data[pyfile.id] + def remove_id(self, pyid): + pyid = int(pyid) + found = False + for pyfile in self.files: + if pyfile.id == pyid: + self.files.remove(pyfile) + found = True + break + + if not found: + return False + + self.data['order'].remove(pyid) + del self.data[pyid] + def get_id(self): """return a free id""" id = 1 @@ -77,14 +94,13 @@ class File_List(object): pkl_file = open('links.pkl', 'rb') obj = cPickle.load(pkl_file) except: - obj = {'version': LIST_VERSION} + obj = {'version': LIST_VERSION, 'order': []} if obj['version'] < LIST_VERSION: - obj = {'version': LIST_VERSION} + obj = {'version': LIST_VERSION, 'order': []} - for key, value in obj.iteritems(): - if key != 'version': - self.append(value.url) + for i in obj['order']: + self.append(obj[i].url) self.core.logger.info("Links loaded: "+ str(int(len(obj) - 1))) diff --git a/module/remote/RequestHandler.py b/module/remote/RequestHandler.py index 5d39623c3..7fa85abe1 100644 --- a/module/remote/RequestHandler.py +++ b/module/remote/RequestHandler.py @@ -29,9 +29,9 @@ class RequestHandler: if obj.command == "exec": func = getattr(self.core, obj.function) - obj.response = func( * obj.args) + obj.data = func( * obj.args) else: - obj.response = "error happend" + obj.data = "error happend" return self.encrypt(obj) @@ -61,4 +61,4 @@ class RequestHandler: enc_str = self.bf.encrypt(enc_str) enc_str = base64.standard_b64encode(enc_str) - return enc_str + "\n"
\ No newline at end of file + return enc_str + "\n" diff --git a/module/remote/RequestObject.py b/module/remote/RequestObject.py index 0141b5e1d..54ea837a6 100644 --- a/module/remote/RequestObject.py +++ b/module/remote/RequestObject.py @@ -15,5 +15,4 @@ class RequestObject(object): self.command = None self.function = "" self.args = [] - self.response = None self.data = None diff --git a/pyLoadCli.py b/pyLoadCli.py index 759298409..f77fa19f0 100644 --- a/pyLoadCli.py +++ b/pyLoadCli.py @@ -28,7 +28,7 @@ class pyLoadCli: self.thread = SocketThread(adress, int(port), pw, self) self.getch = _Getch() self.input = "" - self.pos = [0] + self.pos = [0,0] self.inputline = 0 self.menuline = 0 @@ -38,6 +38,9 @@ class pyLoadCli: self.println(1, blue("py") + yellow("Load") + white(" Command Line Interface")) self.println(2, "") + self.file_list = {} + self.thread.push_exec("get_links") + self.start() def start(self): @@ -73,6 +76,9 @@ class pyLoadCli: def print_input(self): self.println(self.inputline, white(" Input: ") + self.input) self.println(self.inputline+1, "") + self.println(self.inputline+2, "") + self.println(self.inputline+3, "") + self.println(self.inputline+4, "") def data_arrived(self, obj): """Handle incoming data""" @@ -106,6 +112,8 @@ class pyLoadCli: self.menuline = line self.build_menu() + elif obj.command == "file_list" or obj.function == "get_links": + self.file_list = obj.data def build_menu(self): line = self.menuline @@ -126,6 +134,7 @@ class pyLoadCli: line += 1 self.println(line, "") line += 1 + self.println(line, "") elif self.pos[0] == 1:#add links self.println(line, "Parse the links you want to add.") line += 1 @@ -141,17 +150,33 @@ class pyLoadCli: line += 1 self.println(line, mag("0.") + " back to main menu") line += 1 + self.println(line, "") elif self.pos[0] == 2:#remove links - pass + self.println(line, "Type the number of the link you want to delete.") + line += 1 + i = 0 + for id in range(self.pos[1],self.pos[1]+5): + if id < 0 or id >= len(self.file_list['order']): + continue + item = self.file_list['order'][id] + self.println(line, mag(str(item)) + ": " + self.file_list[item].url) + line += 1 + i += 1 + for x in range(5-i): + self.println(line,"") + line += 1 - self.println(line, "") + self.println(line, mag("p") +" - previous" + " | " + mag("n") + " - next") + line += 1 + self.println(line, mag("0.") + " back to main menu") + self.inputline = line + 1 self.print_input() def handle_input(self): inp = self.input if inp == "0": - self.pos = [0] + self.pos = [0,0] self.build_menu() return True @@ -161,6 +186,7 @@ class pyLoadCli: self.pos[0] = 1 elif inp == "2": self.pos[0] = 2 + self.pos[1] = 0 elif inp == "3": self.pos[0] = 3 elif inp == "4": @@ -172,6 +198,13 @@ class pyLoadCli: if inp[:7] == "http://": self.thread.push_exec("add_links", [(inp, None)]) self.links_added += 1 + elif self.pos[0] == 2: + if inp == "p": + self.pos[1] -= 5 + elif inp == "n": + self.pos[1] += 5 + else: + self.thread.push_exec("remove_links", [[inp]]) self.build_menu() diff --git a/pyLoadCore.py b/pyLoadCore.py index 3a46aea21..a9364d98a 100644 --- a/pyLoadCore.py +++ b/pyLoadCore.py @@ -250,6 +250,14 @@ class Core(object): self.file_list.extend(links) self.file_list.save() + def remove_links(self, ids): + for id in ids: + self.file_list.remove_id(id) + self.file_list.save() + + def get_links(self): + return self.file_list.data + if __name__ == "__main__": testLoader = Core() testLoader.start() |