1
0
mirror of https://github.com/1C-Company/docker_fresh.git synced 2025-03-03 14:42:21 +02:00
docker_fresh/modules/helper.py

136 lines
4.3 KiB
Python
Raw Normal View History

2020-04-05 16:06:36 +03:00
import pathlib
import os
sep = str(os.path.sep)
this_path = str(pathlib.Path().absolute()) + sep
distr_path = this_path + 'distr' + sep
def replace_sep(path):
return path.replace('/', sep)
def new_docker_command(extra_path=None):
command = []
command.append('docker')
command.append('run')
command.append('--rm')
command.append('-v')
if extra_path != None:
current_distr_path = this_path + extra_path
current_distr_path = current_distr_path.replace('/', sep)
else:
current_distr_path = distr_path
command.append(current_distr_path + ':/out_files')
2020-04-06 00:09:47 +03:00
return command
def web_publish_command(host_name, conf_name, internal, descriptor, base_name=''):
if internal:
prefix = 'int'
2020-04-06 18:43:54 +03:00
else:
prefix = 'a'
2020-04-06 00:09:47 +03:00
command = []
command.append('docker')
command.append('exec')
command.append('web.' + host_name)
command.append('/opt/1C/v8.3/x86_64/webinst')
command.append('-apache24')
command.append('-wsdir')
command.append(prefix + '/' + conf_name)
command.append('-dir')
2020-04-06 18:43:54 +03:00
command.append('/var/www/' + prefix + '/' + conf_name)
2020-04-06 00:09:47 +03:00
command.append('-connstr')
if base_name != '':
command.append('\'Srvr=srv;Ref=' + base_name + ';\'')
else:
command.append('\'Srvr=srv;Ref=' + conf_name + ';\'')
command.append('-confpath')
command.append('\'/etc/httpd/conf/httpd.conf\'')
command.append('-descriptor')
command.append('\'/mnt/other-files/vrd/' + descriptor + '.vrd\'')
return command
def create_ib_command(host_name, ib_name, conf_ver=''):
command = []
command.append('docker')
command.append('exec')
command.append('-t')
command.append('srv.' + host_name)
command.append('/opt/1C/v8.3/x86_64/1cv8')
command.append('CREATEINFOBASE')
command.append('\'Srvr="srv";Ref="' + ib_name + '";DBMS=PostgreSQL;DBSrvr="db";DB="' + ib_name + '";DBUID="postgres";LicDstr="Y";Locale="ru_RU";CrSQLDB="Y";SchJobDn="N";\'')
command.append('/UseTemplate')
command.append('/mnt/' + ib_name + '_' + conf_ver.replace('.', '_') + '.cf')
command.append('/Out "/mnt/create_ib_' + ib_name + '.out"')
command.append('/DumpResult "/mnt/create_ib_' + ib_name + '.result"')
2020-04-06 18:43:54 +03:00
return command
def install_control_ext_command(host_name, ib_name):
command = []
command.append('docker')
command.append('exec')
command.append('-t')
command.append('srv.' + host_name)
command.append('/opt/1C/v8.3/x86_64/1cv8')
command.append('DESIGNER')
command.append('/S')
command.append('"srv\\{}"'.format(ib_name))
command.append('/LoadCfg')
command.append('"/mnt/other-file/cfe/api_1cfresh.cfe"')
command.append('-Extension')
command.append('"api_1cfresh"')
command.append('/UpdateDBCfg')
command.append('/Out "/mnt/install_control_ext_' + ib_name + '.out"')
command.append('/DumpResult "/mnt/install_control_ext_' + ib_name + '.result"')
return command
def install_ext_command(host_name, ib_name):
command = []
command.append('docker')
command.append('exec')
command.append('-t')
command.append('srv.' + host_name)
command.append('/opt/1C/v8.3/x86_64/1cv8')
command.append('DESIGNER')
command.append('/S')
command.append('"srv\\{}"'.format(ib_name))
command.append('/LoadCfg')
command.append('"/mnt/{}"'.format(ib_name))
command.append('-Extension')
command.append('"fresh"')
command.append('/UpdateDBCfg')
command.append('/Out "/mnt/install_ext_' + ib_name + '.out"')
command.append('/DumpResult "/mnt/install_ext_' + ib_name + '.result"')
return command
def disable_safe_mode(host_name, ib_name):
command = []
command.append('docker')
command.append('exec')
command.append('-t')
command.append('srv.' + host_name)
command.append('/opt/1C/v8.3/x86_64/1cv8')
command.append('ENTERPRICE')
command.append('/S')
command.append('"srv\\{}"'.format(ib_name))
command.append('/Execute')
command.append('"/mnt/other-files/cfe/disable.epf"')
command.append('/Out "/mnt/disable_safe_mode_' + ib_name + '.out"')
command.append('/DumpResult "/mnt/disable_safe_mode_' + ib_name + '.result"')
return command
def get_host_name(argv):
if '-h' not in argv:
print('parameter -р not specified')
exit(1)
host_index = argv.index('-h')
return argv[host_index + 1]