aboutsummaryrefslogtreecommitdiffstats
path: root/moon_manager/moon_manager/orchestration_driver.py
blob: 5e03c2509d6a08145f7e01ddf00109554371f2ad (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
77
78
79
80
81
# Software Name: MOON

# Version: 5.4

# SPDX-FileCopyrightText: Copyright (c) 2018-2020 Orange and its contributors
# SPDX-License-Identifier: Apache-2.0

# This software is distributed under the 'Apache License 2.0',
# the text of which is available at 'http://www.apache.org/licenses/LICENSE-2.0.txt'
# or see the "LICENSE" file for more details.


import logging
from moon_manager.api import configuration
from moon_manager.api.orchestration import slave, pipeline

logger = logging.getLogger("moon.manager.orchestration_driver")


SlaveManager = None
PipelineManager = None


class Driver:

    def __init__(self, driver_name, engine_name):
        self.name = driver_name
        self.plug = configuration.get_orchestration_driver()
        self.driver = self.plug.Connector(driver_name, engine_name)


class SlaveDriver(Driver):

    def __init__(self, driver_name, engine_name):
        super(SlaveDriver, self).__init__(driver_name, engine_name)
        self.engine = engine_name

    def update_slave(self, slave_id, data):
        raise NotImplementedError()  # pragma: no cover

    def delete_slave(self, slave_id):
        raise NotImplementedError()  # pragma: no cover

    def add_slave(self, slave_id=None, data=None):
        raise NotImplementedError()  # pragma: no cover

    def get_slaves(self, slave_id=None):
        raise NotImplementedError()  # pragma: no cover


class PipelineDriver(Driver):

    def __init__(self, driver_name, engine_name):
        super(PipelineDriver, self).__init__(driver_name, engine_name)
        self.engine = engine_name

    def update_pipeline(self, pipeline_id, data):
        raise NotImplementedError()  # pragma: no cover

    def delete_pipeline(self, pipeline_id):
        raise NotImplementedError()  # pragma: no cover

    def add_pipeline(self, pipeline_id=None, data=None):
        raise NotImplementedError()  # pragma: no cover

    def get_pipelines(self, slave_id=None, pipeline_id=None):
        raise NotImplementedError()  # pragma: no cover


def init():
    global SlaveManager, PipelineManager

    logger.info("Initializing driver")
    conf = configuration.get_configuration("orchestration")

    SlaveManager = slave.SlaveManager(
        SlaveDriver(conf['driver'], conf.get('url'))
    )
    PipelineManager = pipeline.PipelineManager(
        PipelineDriver(conf['driver'], conf.get('url'))
    )