adddda-simple-mixin

This commit is contained in:
jem 2020-05-01 17:38:17 +02:00
parent 50f8e0d3eb
commit 8fe52fa1e3
4 changed files with 75 additions and 2 deletions

View file

@ -1,7 +1,6 @@
language: python
python:
- "2.7"
- "3.7"
before_script: sudo apt-get install pychecker
install: pip install pybuilder

View file

@ -11,6 +11,7 @@ from .devops_docker_build import DevopsDockerBuild, create_devops_docker_build_c
from .hetzner_mixin import HetznerMixin, add_hetzner_mixin_config
from .aws_backend_properties_mixin import AwsBackendPropertiesMixin, add_aws_backend_properties_mixin_config
from .aws_mfa_mixin import AwsMfaMixin, add_aws_mfa_mixin_config
from .dda_pallet_mixin import DdaPalletMixin, add_dda_pallet_mixin_config
from .dda_tenant_mixin import DdaTenantMixin, add_dda_tenant_mixin_config
from .dda_simple_mixin import DdaSimpleMixin, add_dda_simple_mixin_config
__version__ = "${version}"

View file

@ -0,0 +1,72 @@
from string import Template
from subprocess import run
from .python_util import *
from .devops_build import DevopsBuild
def add_dda_simple_mixin_config(config, domain_file_name,
jar_file=None,
target_edn_name='target.edn'):
config.update({'DdaSimpleMixin':
{'domain_file_name': domain_file_name,
'target_edn_name': target_edn_name,
'jar_file': jar_file,
'target_template':
"""
{:existing [{:node-name "$node_name"
:node-ip "$ipv4"}]
:provisioning-user {:login "root"}}
""", }})
return config
class DdaSimpleMixin(DevopsBuild):
def __init__(self, project, config):
super().__init__(project, config)
dda_pallet_mixin_config = config['DdaSimpleMixin']
self.domain_file_name = dda_pallet_mixin_config['domain_file_name']
self.target_edn_name = dda_pallet_mixin_config['target_edn_name']
self.jar_file = dda_pallet_mixin_config['jar_file']
if not self.jar_file:
self.jar_file = 'target/uberjar/' + self.module + '-standalone.jar'
self.target_template = Template(
dda_pallet_mixin_config['target_template'])
def initialize_build_dir(self):
super().initialize_build_dir()
run('cp *.edn ' + self.build_path(), shell=True)
def dda_write_target(self, node_name, ipv4):
with open(self.build_path() + '/' + self.target_edn_name, "w") as output_file:
output_file.write(
self.target_template.substitute({'ipv4': ipv4, 'node_name': node_name}))
def dda_write_domain(self, substitues):
with open(self.build_path() + '/' + self.domain_file_name, "r") as input_file:
domain_input = input_file.read()
domain_template = Template(domain_input)
with open(self.build_path() + '/out_' + self.domain_file_name, "w") as output_file:
output_file.write(domain_template.substitute(substitues))
def dda_uberjar(self, configure_switch=None):
if configure_switch:
cmd = ['java', '-jar', self.project_root_path + '/' + self.jar_file,
'--targets', self.build_path() + '/' + self.target_edn_name,
'--configure',
self.build_path() + '/out_' + self.domain_file_name]
else:
cmd = ['java', '-jar', self.project_root_path + '/' + self.jar_file,
'--targets', self.build_path() + '/' + self.target_edn_name,
self.build_path() + '/out_' + self.domain_file_name]
prn_cmd = list(cmd)
print(" ".join(prn_cmd))
output = execute(cmd)
print(output)
return output
def dda_install(self):
return self.dda_uberjar()
def dda_configure(self):
return self.dda_uberjar(True)

View file

@ -15,6 +15,7 @@ def get_devops_build(project):
class DevopsBuild:
def __init__(self, project, config):
#deprecate stage
self.stage = config['stage']
self.project_root_path = config['project_root_path']
self.module = config['module']