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'))
)
|