diff options
| author | 2014-07-02 14:29:44 +0200 | |
|---|---|---|
| committer | 2014-07-02 14:29:44 +0200 | |
| commit | 1340c543e296f41a9a4ab7377f016c50e716535c (patch) | |
| tree | 3105f843b2acb0ae0ca6b2bbd3bf37dde8db6707 /module/plugins | |
| parent | [Uploaded] Fixes (diff) | |
| download | pyload-1340c543e296f41a9a4ab7377f016c50e716535c.tar.xz | |
[UpdateManager] Fix interval changing procedure
Diffstat (limited to 'module/plugins')
| -rw-r--r-- | module/plugins/hooks/UpdateManager.py | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/module/plugins/hooks/UpdateManager.py b/module/plugins/hooks/UpdateManager.py index 9f8ccdb80..8e8449a51 100644 --- a/module/plugins/hooks/UpdateManager.py +++ b/module/plugins/hooks/UpdateManager.py @@ -14,7 +14,7 @@ from module.plugins.Hook import threaded, Expose, Hook  class UpdateManager(Hook):      __name__ = "UpdateManager" -    __version__ = "0.24" +    __version__ = "0.25"      __description__ = """Check for updates"""      __config__ = [("activated", "bool", "Activated", True),                    ("mode", "pyLoad + plugins;plugins only", "Check updates for", "pyLoad + plugins"), @@ -25,15 +25,21 @@ class UpdateManager(Hook):      __author_mail__ = ("ranan@pyload.org", "l.stickell@yahoo.it", "vuolter@gmail.com")      SERVER_URL = "http://updatemanager.pyload.org" -    MIN_TIME = 3 * 60 * 60  #: 3h minimum check interval +    MIN_TIME = 3 * 60 * 60  #: 3h minimum check interval (seconds)      event_list = ["pluginConfigChanged"]      def pluginConfigChanged(self, plugin, name, value): -        if name == "interval" and 0 < value != self.interval: -            self.interval = max(value * 60 * 60, self.MIN_TIME) -            self.initPeriodical() +        if name == "interval": +            interval = value * 60 * 60 +            if self.MIN_TIME <= interval != self.interval: +                if self.cb: +                    self.core.scheduler.removeJob(self.cb) +                self.interval = interval +                self.initPeriodical() +            else: +                self.logWarning("Invalid interval value, kept current")          elif name == "reloadplugins":              if self.cb2:                  self.core.scheduler.removeJob(self.cb2) | 
