diff options
| author | 2013-01-03 17:14:02 +0100 | |
|---|---|---|
| committer | 2013-01-03 17:14:02 +0100 | |
| commit | a6b5a69612f4dd744be20c326152a9d892150f98 (patch) | |
| tree | f3a221e2c8e1b805b5b83c0136978b9fb36eae59 /module/api | |
| parent | little cleanup, improved handling of custom exceptions via api (diff) | |
| download | pyload-a6b5a69612f4dd744be20c326152a9d892150f98.tar.xz | |
seperate api into several components
Diffstat (limited to 'module/api')
| -rw-r--r-- | module/api/ApiComponent.py | 12 | ||||
| -rw-r--r-- | module/api/ConfigApi.py | 104 | ||||
| -rw-r--r-- | module/api/CoreApi.py | 121 | ||||
| -rw-r--r-- | module/api/__init__.py | 1 | 
4 files changed, 238 insertions, 0 deletions
| diff --git a/module/api/ApiComponent.py b/module/api/ApiComponent.py new file mode 100644 index 000000000..2b09d05a3 --- /dev/null +++ b/module/api/ApiComponent.py @@ -0,0 +1,12 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +class ApiComponent: + +    def __init__(self, core): +        # Only for auto completion, this class can not be instantiated +        from pyload import Core +        assert isinstance(core, Core) +        self.core = core +        # No instantiating! +        raise Exception()
\ No newline at end of file diff --git a/module/api/ConfigApi.py b/module/api/ConfigApi.py new file mode 100644 index 000000000..f3f2e6950 --- /dev/null +++ b/module/api/ConfigApi.py @@ -0,0 +1,104 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +from module.Api import Api, UserContext, RequirePerm, Permission, ConfigHolder, ConfigItem +from module.utils import to_string + +from ApiComponent import ApiComponent + +class ConfigApi(ApiComponent): +    """ Everything related to configuration """ + +    def getConfigValue(self, section, option): +        """Retrieve config value. + +        :param section: name of category, or plugin +        :param option: config option +        :rtype: str +        :return: config value as string +        """ +        value = self.core.config.get(section, option) +        return to_string(value) + +    def setConfigValue(self, section, option, value): +        """Set new config value. + +        :param section: +        :param option: +        :param value: new config value +        """ +        if option in ("limit_speed", "max_speed"): #not so nice to update the limit +            self.core.requestFactory.updateBucket() + +        self.core.config.set(section, option, value) + +    def getConfig(self): +        """Retrieves complete config of core. + +        :rtype: ConfigHolder +        :return: dict with section mapped to config +        """ +        # TODO +        return dict([(section, ConfigHolder(section, data.name, data.description, data.long_desc, [ +        ConfigItem(option, d.name, d.description, d.type, to_string(d.default), +            to_string(self.core.config.get(section, option))) for +        option, d in data.config.iteritems()])) for +                     section, data in self.core.config.getBaseSections()]) + + +    def getConfigRef(self): +        """Config instance, not for RPC""" +        return self.core.config + +    def getGlobalPlugins(self): +        """All global plugins/addons, only admin can use this + +        :return: list of `ConfigInfo` +        """ +        pass + +    @UserContext +    @RequirePerm(Permission.Plugins) +    def getUserPlugins(self): +        """List of plugins every user can configure for himself + +        :return: list of `ConfigInfo` +        """ +        pass + +    @UserContext +    @RequirePerm(Permission.Plugins) +    def configurePlugin(self, plugin): +        """Get complete config options for an plugin + +        :param plugin: Name of the plugin to configure +        :return: :class:`ConfigHolder` +        """ + +        pass + +    @UserContext +    @RequirePerm(Permission.Plugins) +    def saveConfig(self, config): +        """Used to save a configuration, core config can only be saved by admins + +        :param config: :class:`ConfigHolder +        """ +        pass + +    @UserContext +    @RequirePerm(Permission.Plugins) +    def deleteConfig(self, plugin): +        """Deletes modified config + +        :param plugin: plugin name +        :return: +        """ +        pass + +    @RequirePerm(Permission.Plugins) +    def setConfigHandler(self, plugin, iid, value): +        pass + +if Api.extend(ConfigApi): +    del ConfigApi
\ No newline at end of file diff --git a/module/api/CoreApi.py b/module/api/CoreApi.py new file mode 100644 index 000000000..4de8c1f96 --- /dev/null +++ b/module/api/CoreApi.py @@ -0,0 +1,121 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +from module.Api import Api, RequirePerm, Permission, ServerStatus +from module.utils.fs import join, free_space +from module.utils import compare_time + +from ApiComponent import ApiComponent + +class CoreApi(ApiComponent): +    """ This module provides methods for general interaction with the core, like status or progress retrieval  """ + +    @RequirePerm(Permission.All) +    def getServerVersion(self): +        """pyLoad Core version """ +        return self.core.version + +    @RequirePerm(Permission.All) +    def getWSAddress(self): +        """Gets and address for the websocket based on configuration""" +        # TODO + +    @RequirePerm(Permission.All) +    def getServerStatus(self): +        """Some general information about the current status of pyLoad. + +        :return: `ServerStatus` +        """ +        serverStatus = ServerStatus(self.core.files.getQueueCount(), self.core.files.getFileCount(), 0, +            not self.core.threadManager.pause and self.isTimeDownload(), self.core.threadManager.pause, +            self.core.config['reconnect']['activated'] and self.isTimeReconnect()) + +        for pyfile in self.core.threadManager.getActiveDownloads(): +            serverStatus.speed += pyfile.getSpeed() #bytes/s + +        return serverStatus + +    @RequirePerm(Permission.All) +    def getProgressInfo(self): +        """ Status of all currently running tasks + +        :rtype: list of :class:`ProgressInfo` +        """ +        pass + +    def pauseServer(self): +        """Pause server: It won't start any new downloads, but nothing gets aborted.""" +        self.core.threadManager.pause = True + +    def unpauseServer(self): +        """Unpause server: New Downloads will be started.""" +        self.core.threadManager.pause = False + +    def togglePause(self): +        """Toggle pause state. + +        :return: new pause state +        """ +        self.core.threadManager.pause ^= True +        return self.core.threadManager.pause + +    def toggleReconnect(self): +        """Toggle reconnect activation. + +        :return: new reconnect state +        """ +        self.core.config["reconnect"]["activated"] ^= True +        return self.core.config["reconnect"]["activated"] + +    def freeSpace(self): +        """Available free space at download directory in bytes""" +        return free_space(self.core.config["general"]["download_folder"]) + + +    def quit(self): +        """Clean way to quit pyLoad""" +        self.core.do_kill = True + +    def restart(self): +        """Restart pyload core""" +        self.core.do_restart = True + +    def getLog(self, offset=0): +        """Returns most recent log entries. + +        :param offset: line offset +        :return: List of log entries +        """ +        filename = join(self.core.config['log']['log_folder'], 'log.txt') +        try: +            fh = open(filename, "r") +            lines = fh.readlines() +            fh.close() +            if offset >= len(lines): +                return [] +            return lines[offset:] +        except: +            return ['No log available'] + +    @RequirePerm(Permission.All) +    def isTimeDownload(self): +        """Checks if pyload will start new downloads according to time in config. + +        :return: bool +        """ +        start = self.core.config['downloadTime']['start'].split(":") +        end = self.core.config['downloadTime']['end'].split(":") +        return compare_time(start, end) + +    @RequirePerm(Permission.All) +    def isTimeReconnect(self): +        """Checks if pyload will try to make a reconnect + +        :return: bool +        """ +        start = self.core.config['reconnect']['startTime'].split(":") +        end = self.core.config['reconnect']['endTime'].split(":") +        return compare_time(start, end) and self.core.config["reconnect"]["activated"] + +if Api.extend(CoreApi): +    del CoreApi
\ No newline at end of file diff --git a/module/api/__init__.py b/module/api/__init__.py new file mode 100644 index 000000000..f7ceb6183 --- /dev/null +++ b/module/api/__init__.py @@ -0,0 +1 @@ +__all__ = ["CoreApi", "ConfigApi"]
\ No newline at end of file | 
