diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-13 13:33:21 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-13 13:33:21 +0200 |
commit | 1ffd7d167dfc9b40eab7067d81a25720d04c9387 (patch) | |
tree | 749e04f092b8471e9fe144845159296a98d5d33d | |
parent | merge (diff) | |
download | pyload-1ffd7d167dfc9b40eab7067d81a25720d04c9387.tar.xz |
some fixes, working irc interface
-rw-r--r-- | module/FileDatabase.py | 8 | ||||
-rw-r--r-- | module/plugins/hooks/IRCInterface.py | 203 | ||||
-rwxr-xr-x | pyLoadCore.py | 2 |
3 files changed, 105 insertions, 108 deletions
diff --git a/module/FileDatabase.py b/module/FileDatabase.py index 1c2667732..a59632bb8 100644 --- a/module/FileDatabase.py +++ b/module/FileDatabase.py @@ -189,6 +189,10 @@ class FileHandler: """deletes links""" f = self.getFile(id) + + if not f: + return None + e = RemoveEvent("file", id, "collector" if not f.package().queue else "queue") @@ -243,6 +247,10 @@ class FileHandler: def getPackageData(self, id): """returns dict with package information""" pack = self.getPackage(id) + + if not pack: + return None + pack = pack.toDict()[id] data = self.db.getPackageData(id) diff --git a/module/plugins/hooks/IRCInterface.py b/module/plugins/hooks/IRCInterface.py index 8d50647e3..e7e1e6797 100644 --- a/module/plugins/hooks/IRCInterface.py +++ b/module/plugins/hooks/IRCInterface.py @@ -57,6 +57,7 @@ class IRCInterface(Thread, Hook): self.abort = False self.links_added = 0 + self.more = [] self.start() @@ -190,7 +191,7 @@ class IRCInterface(Thread, Hook): def event_status(self, args): downloads = self.sm.status_downloads() - if len(downloads) < 1: + if not downloads: return ["INFO: There are no active downloads currently."] lines = [] @@ -200,142 +201,129 @@ class IRCInterface(Thread, Hook): ( data['id'], data['name'], - data['status'], - "%d kb/s" % int(data['speed']), - "%d min" % int(data['eta'] / 60), - "%d/%d MB (%d%%)" % ((data['size']-data['kbleft']) / 1024, data['size'] / 1024, data['percent']) + data['statusmsg'], + "%.2f kb/s" % data['speed'], + "%s" % data['format_eta'], + "%d%% (%s)" % (data['percent'], data['format_size']) ) ) return lines def event_queue(self, args): - # just forward for now - return self.event_status(args) + ps = self.sm.get_queue() - def event_collector(self, args): - ps = self.sm.get_collector() - if len(ps) == 0: - return ["INFO: No packages in collector!"] + if not ps: + return ["INFO: There are no packages in queue."] lines = [] - for packdata in ps: - lines.append('PACKAGE: Package "%s" with id #%d' % (packdata['package_name'], packdata['id'])) - for fileid in self.sm.get_package_files(packdata['id']): - fileinfo = self.sm.get_file_info(fileid) - lines.append('#%d FILE: %s (#%d)' % (packdata['id'], fileinfo["filename"], fileinfo["id"])) + for id, pack in ps.iteritems(): + lines.append('PACKAGE #%s: "%s" with %d links.' % (id, pack['name'], len(pack['links']) )) return lines - def event_links(self, args): - fids = self.sm.get_files() - if len(fids) == 0: - return ["INFO: No links."] - - lines = [] - for fid in fids: - info = self.sm.get_file_info(fid) - lines.append('LINK #%d: %s [%s]' % (fid, info["filename"], info["status_type"])) - - return lines + def event_collector(self, args): + ps = self.sm.get_collector() + if not ps: + return ["INFO: No packages in collector!"] - def event_packages(self, args): - pids = self.sm.get_packages() - if len(pids) == 0: - return ["INFO: No packages."] - lines = [] - for pid in pids: - data = self.sm.get_package_data(pid) - lines.append('PACKAGE #%d: %s (%d links)' % (pid, data["package_name"], len(self.sm.get_package_files(pid)))) - + for id, pack in ps.iteritems(): + lines.append('PACKAGE #%s: "%s" with %d links.' % (id, pack['name'], len(pack['links']) )) + return lines - + def event_info(self, args): if not args: return ['ERROR: Use info like this: info <id>'] - info = self.sm.get_file_info(int(args[0])) - return ['LINK #%d: %s (%d) [%s bytes]' % (info['id'], info['filename'], info['size'], info['status_type'])] + info = self.sm.get_file_data(int(args[0])) + + if not info: + return ["ERROR: Link doesn't exists."] + + id = info.keys()[0] + data = info[id] + + return ['LINK #%s: %s (%s) [%s][%s]' % (id, data['name'], data['format_size'], data['statusmsg'], data['plugin'])] def event_packinfo(self, args): if not args: return ['ERROR: Use packinfo like this: packinfo <id>'] lines = [] - packdata = self.sm.get_package_data(int(args[0])) - lines.append('PACKAGE: Package "%s" with id #%d' % (packdata['package_name'], packdata['id'])) - for fileid in self.sm.get_package_files(packdata['id']): - fileinfo = self.sm.get_file_info(fileid) - lines.append('#%d LINK: %s (#%d)' % (packdata['id'], fileinfo["filename"], fileinfo["id"])) + pack = self.sm.get_package_data(int(args[0])) + + if not pack: + return ["ERROR: Package doesn't exists."] + + id = args[0] + + self.more = [] + + lines.append('PACKAGE #%s: "%s" with %d links' % (id, pack['name'], len(pack["links"])) ) + for id, pyfile in pack["links"].iteritems(): + self.more.append('LINK #%s: %s (%s) [%s][%s]' % (id, pyfile["name"], pyfile["format_size"], pyfile["statusmsg"], pyfile["plugin"])) + + if len(self.more) < 6: + lines.extend(self.more) + self.more = [] + else: + lines.extend(self.more[:6]) + self.more = self.more[6:] + lines.append("%d more links do display." % len(self.more)) + return lines - def event_start(self, args): - if not args: - count = 0 - for packdata in self.sm.get_collector_packages(): - self.sm.push_package_2_queue(packdata['id']) - count += 1 - - return ["INFO: %d downloads started." % count] - - lines = [] - for val in args: - id = int(val.strip()) - self.sm.push_package_2_queue(id) - lines.append("INFO: Starting download #%d" % id) + def event_more(self, args): + if not self.more: + return ["No more information to display."] - return lines + lines = self.more[:6] + self.more = self.more[6:] + lines.append("%d more links do display." % len(self.more)) - def event_stop(self, args): - if not args: - self.sm.stop_downloads() - return ["INFO: All downloads stopped."] - - lines = [] - for val in args: - id = int(val.strip()) - self.sm.stop_download("", id) - lines.append("INFO: Download #%d stopped." % id) - return lines + + def event_start(self, args): + self.sm.unpause_server() + return ["INFO: Starting downloads."] + + def event_stop(self, args): + + self.sm.pause_server() + return ["INFO: No new downloads will be started."] + + def event_add(self, args): - if len(args) != 2: - return ['ERROR: Add links like this: "add <package|id> <link>". '\ + if len(args) < 2: + return ['ERROR: Add links like this: "add <packagename|id> links". '\ 'This will add the link <link> to to the package <package> / the package with id <id>!'] - def get_pack_id(pack): - if pack.isdigit(): - pack = int(pack) - for packdata in self.sm.get_collector_packages(): - if packdata['id'] == pack: - return pack - return -1 - - for packdata in self.sm.get_collector_packages(): - if packdata['package_name'] == pack: - return packdata['id'] - return -1 - + pack = args[0].strip() - link = args[1].strip() + links = [x.strip() for x in args[1:]] + count_added = 0 count_failed = 0 - - # verify that we have a valid link - #if not self.sm.is_valid_link(link): - #return ["ERROR: Your specified link is not supported by pyLoad."] - - # get a valid package id (create new package if it doesn't exist) - pack_id = get_pack_id(pack) - if pack_id == -1: - pack_id = self.sm.new_package(pack) - - # move link into package - fid = self.sm.add_links_to_package(pack_id, [link]) - return ["INFO: Added %s to Package %s [#%d]" % (link, pack, pack_id)] + try: + id = int(pack) + pack = self.sm.get_package_data(id) + if not pack: + return ["ERROR: Package doesn't exists."] + + #add links + + + return ["INFO: Added %d links to Package %s [#%d]" % (len(links), pack["name"], id)] + + except: + # create new package + id = self.sm.add_package(pack, links, 1) + return ["INFO: Created new Package %s [#%d] with %d links." % (pack, id, len(links))] + def event_del(self, args): if len(args) < 2: @@ -343,11 +331,11 @@ class IRCInterface(Thread, Hook): if args[0] == "-p": ret = self.sm.del_packages(map(int, args[1:])) - return ["INFO: Deleted %d packages!" % ret] + return ["INFO: Deleted %d packages!" % len(args[1:])] elif args[0] == "-l": ret = self.sm.del_links(map(int, args[1:])) - return ["INFO: Deleted %d links!" % ret] + return ["INFO: Deleted %d links!" % len(args[1:])] else: return ["ERROR: Use del command like this: del <-p|-l> <id> [...] (-p indicates that the ids are from packages, -l indicates that the ids are from links)"] @@ -355,18 +343,17 @@ class IRCInterface(Thread, Hook): def event_help(self, args): lines = [] lines.append("The following commands are available:") - lines.append("add <package|packid> <link> Adds link to package. (creates new package if it does not exist)") + lines.append("add <package|packid> <links> [...] Adds link to package. (creates new package if it does not exist)") + lines.append("queue Shows all packages in the queue") lines.append("collector Shows all packages in collector") lines.append("del -p|-l <id> [...] Deletes all packages|links with the ids specified") lines.append("info <id> Shows info of the link with id <id>") - lines.append("help Shows this help file") - lines.append("links Shows all links in pyload") - lines.append("packages Shows all packages in pyload") lines.append("packinfo <id> Shows info of the package with id <id>") - lines.append("queue Shows info about the queue") - lines.append("start [<id>...] Starts the package with id <id> or all packages if no id is given") + lines.append("more Shows more info when the result was truncated") + lines.append("start Starts all downloads") + lines.append("stop Stops the download (but not abort active downloads)") lines.append("status Show general download status") - lines.append("stop [<id>...] Stops the package with id <id> or all packages if no id is given") + lines.append("help Shows this help message") return lines diff --git a/pyLoadCore.py b/pyLoadCore.py index cc9480dee..f3d6de7e0 100755 --- a/pyLoadCore.py +++ b/pyLoadCore.py @@ -482,6 +482,8 @@ class ServerMethods(): self.core.log.info(_("Added package %s containing %s links") % (name, len(links))) self.core.files.save() + + return pid def get_package_data(self, id): |