File: PluginObject.py

package info (click to toggle)
uranium 5.0.0-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 5,304 kB
  • sloc: python: 31,765; sh: 132; makefile: 12
file content (51 lines) | stat: -rw-r--r-- 1,812 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# Copyright (c) 2018 Ultimaker B.V.
# Uranium is released under the terms of the LGPLv3 or higher.
from typing import Optional, Dict, Any


class PluginObject:
    """Base class for objects that can be provided by a plugin.

    This class should be inherited by any class that can be provided
    by a plugin. Its only function is to serve as a mapping between
    the plugin and the object.
    """

    def __init__(self, *args, **kwags) -> None:
        self._plugin_id = None  # type: Optional[str]
        self._version = None  # type: Optional[str]
        self._metadata = {}  # type: Dict[str, Any]
        self._name = None  # type: Optional[str]

    #   This returns a globally unique id for this plugin object.
    #   It prepends it's set name (which should be locally (eg; within the plugin) unique) with the plugin_id, making it
    #   globally unique.
    def getId(self) -> str:
        result = self.getPluginId()
        if self._name:
            result += "_%s" % self._name
        return result

    def setPluginId(self, plugin_id: str) -> None:
        self._plugin_id = plugin_id

    #   The metadata of the plugin is set at the moment it is loaded.
    def setMetaData(self, metadata: Dict[str, Any]) -> None:
        self._metadata = metadata

    def getMetaData(self) -> Dict[str, Any]:
        return self._metadata

    def getPluginId(self) -> str:
        if not self._plugin_id:
            raise ValueError("The plugin ID needs to be set before the plugin can be used")
        return self._plugin_id

    def setVersion(self, version: str) -> None:
        self._version = version

    def getVersion(self) -> str:
        if not self._version:
            raise ValueError("The plugin version needs to be set before the plugin can be used")
        return self._version