diff options
| author | 2015-02-16 10:46:28 +0100 | |
|---|---|---|
| committer | 2015-02-16 10:46:28 +0100 | |
| commit | ce1c2b6b05c08b669357947e61ae40efce7fc50f (patch) | |
| tree | 0b5f7996960cf35c4eface53a89eba18a37519b7 /module/plugins/addon/MultiHome.py | |
| parent | Fix filename case (diff) | |
| download | pyload-ce1c2b6b05c08b669357947e61ae40efce7fc50f.tar.xz | |
module temp
Diffstat (limited to 'module/plugins/addon/MultiHome.py')
| -rw-r--r-- | module/plugins/addon/MultiHome.py | 81 | 
1 files changed, 81 insertions, 0 deletions
| diff --git a/module/plugins/addon/MultiHome.py b/module/plugins/addon/MultiHome.py new file mode 100644 index 000000000..84b1e6ab7 --- /dev/null +++ b/module/plugins/addon/MultiHome.py @@ -0,0 +1,81 @@ +# -*- coding: utf-8 -*- + +from time import time + +from pyload.plugin.Addon import Addon + + +class MultiHome(Addon): +    __name__    = "MultiHome" +    __type__    = "addon" +    __version__ = "0.12" + +    __config__ = [("interfaces", "str", "Interfaces", "None")] + +    __description__ = """Ip address changer""" +    __license__     = "GPLv3" +    __authors__     = [("mkaay", "mkaay@mkaay.de")] + + +    def setup(self): +        self.register = {} +        self.interfaces = [] +        self.parseInterfaces(self.getConfig("interfaces").split(";")) +        if not self.interfaces: +            self.parseInterfaces([self.config['download']['interface']]) +            self.setConfig("interfaces", self.toConfig()) + + +    def toConfig(self): +        return ";".join([i.adress for i in self.interfaces]) + + +    def parseInterfaces(self, interfaces): +        for interface in interfaces: +            if not interface or str(interface).lower() == "none": +                continue +            self.interfaces.append(Interface(interface)) + + +    def activate(self): +        requestFactory = self.core.requestFactory +        oldGetRequest = requestFactory.getRequest + +        def getRequest(pluginName, account=None): +            iface = self.bestInterface(pluginName, account) +            if iface: +                iface.useFor(pluginName, account) +                requestFactory.iface = lambda: iface.adress +                self.logDebug("Using address", iface.adress) +            return oldGetRequest(pluginName, account) + +        requestFactory.getRequest = getRequest + + +    def bestInterface(self, pluginName, account): +        best = None +        for interface in self.interfaces: +            if not best or interface.lastPluginAccess(pluginName, account) < best.lastPluginAccess(pluginName, account): +                best = interface +        return best + + +class Interface(object): + +    def __init__(self, adress): +        self.adress = adress +        self.history = {} + + +    def lastPluginAccess(self, pluginName, account): +        if (pluginName, account) in self.history: +            return self.history[(pluginName, account)] +        return 0 + + +    def useFor(self, pluginName, account): +        self.history[(pluginName, account)] = time() + + +    def __repr__(self): +        return "<Interface - %s>" % self.adress | 
