diff options
| -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): | 
