aboutsummaryrefslogtreecommitdiffstats
path: root/moonv4/moon_orchestrator/moon_orchestrator/api/slaves.py
blob: 66ddf256a2cfad4adb353949d62182207b6ab180 (plain)
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors
# This software is distributed under the terms and conditions of the 'Apache-2.0'
# license which can be found in the file 'LICENSE' in this package distribution
# or at 'http://www.apache.org/licenses/LICENSE-2.0'.

from oslo_config import cfg
from oslo_log import log as logging
from uuid import uuid4

LOG = logging.getLogger(__name__)
CONF = cfg.CONF


class Slaves(object):
    """
    Manage containers.
    """

    __version__ = "0.1.0"

    def __init__(self, slaves):
        self.slaves = slaves

    def add_slave(self, ctx, args=None):
        """Add a new slave in the global list

        :param ctx: {
            "name": "name of the slave",
            "description": "description"
        }
        :param args: {}
        :return: {
            "uuid_of_the_slave": {
                "name": "name of the slave",
                "description": "description"
            }
        }
        """
        if "name" in ctx:
            for _id, _dict in self.slaves.items():
                if _dict['name'] == ctx['name']:
                    LOG.warning("A slave named {} already exists!".format(ctx['name']))
                    return {"slaves": {_id: _dict}}
            uuid = uuid4().hex
            ctx.pop("method")
            ctx.pop("call_master")
            self.slaves[uuid] = ctx
            return {"slaves": {uuid: ctx}}

    def get_slaves(self, ctx, args=None):
        """Get all the known slaves

        :param ctx: {}
        :param args: {}
        :return: {
            "uuid_of_the_slave": {
                "name": "name of the slave",
                "description": "description"
            }
        }
        """
        return {"slaves": self.slaves}

    def delete_slave(self, ctx, args=None):
        """Delete a previous slave in the global list

        :param ctx: {
            "id": "ID of the slave"
        }
        :param args: {}
        :return: None
        """
        if "id" in ctx:
            if ctx['id'] in self.slaves:
                self.slaves.pop(ctx['id'])
        return {"slaves": self.slaves}