2019-08-12 04:39:19 +00:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import shutil
|
|
|
|
import logging
|
|
|
|
import jinja2 as j2
|
|
|
|
|
|
|
|
|
2019-08-12 05:29:30 +00:00
|
|
|
######################################################################
|
|
|
|
# Utils
|
|
|
|
|
2019-08-13 01:33:49 +00:00
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
|
2019-08-12 04:39:19 +00:00
|
|
|
def set_perms(path, user, group, mode):
|
|
|
|
shutil.chown(path, user=user, group=group)
|
|
|
|
os.chmod(path, mode)
|
|
|
|
|
2019-08-13 01:23:20 +00:00
|
|
|
# Setup Jinja2 for templating
|
|
|
|
jenv = j2.Environment(
|
|
|
|
loader=j2.FileSystemLoader('/opt/atlassian/etc/'),
|
|
|
|
autoescape=j2.select_autoescape(['xml']))
|
|
|
|
|
2019-08-12 05:29:30 +00:00
|
|
|
def gen_cfg(tmpl, target, env, user='root', group='root', mode=0o644):
|
|
|
|
logging.info("Generating {} from template {}".format(target, tmpl))
|
|
|
|
cfg = jenv.get_template(tmpl).render(env)
|
|
|
|
with open(target, 'w') as fd:
|
|
|
|
fd.write(cfg)
|
|
|
|
set_perms(target, user, group, mode)
|
2019-08-12 04:39:19 +00:00
|
|
|
|
2019-08-12 05:29:30 +00:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Setup inputs and outputs
|
2019-08-12 04:39:19 +00:00
|
|
|
|
2019-08-13 01:23:20 +00:00
|
|
|
# Import all ATL_* and Dockerfile environment variables. We lower-case
|
|
|
|
# these for compatability with Ansible template convention. We also
|
|
|
|
# support CATALINA variables from older versions of the Docker images
|
|
|
|
# for backwards compatability, if the new version is not set.
|
2019-08-12 05:29:30 +00:00
|
|
|
env = {k.lower(): v
|
|
|
|
for k, v in os.environ.items()
|
2019-08-13 01:23:20 +00:00
|
|
|
if k.startswith(('ATL_', 'CONFLUENCE_', 'RUN_', 'CATALINA_'))}
|
2019-08-12 23:52:18 +00:00
|
|
|
|
|
|
|
# For compatability with the Ansible templates.
|
|
|
|
env['atl_product_home'] = env['confluence_home']
|
|
|
|
env['atl_product_home_shared'] = env.get('confluence_shared_home')
|
2019-08-12 05:29:30 +00:00
|
|
|
|
2019-08-12 04:39:19 +00:00
|
|
|
|
|
|
|
######################################################################
|
2019-08-13 01:33:49 +00:00
|
|
|
# Generate all configuration files for Confluence
|
2019-08-12 06:07:48 +00:00
|
|
|
|
2019-08-13 01:33:49 +00:00
|
|
|
gen_cfg('server.xml.j2',
|
|
|
|
env['confluence_install_dir']+'/conf/server.xml', env)
|
2019-08-12 06:18:01 +00:00
|
|
|
|
2019-08-13 01:33:49 +00:00
|
|
|
gen_cfg('seraph-config.xml.j2',
|
|
|
|
env['confluence_install_dir']+'/confluence/WEB-INF/classes/seraph-config.xml', env)
|
2019-08-12 06:18:01 +00:00
|
|
|
|
2019-08-13 01:33:49 +00:00
|
|
|
gen_cfg('confluence-init.properties.j2',
|
|
|
|
env['confluence_install_dir']+'/confluence/WEB-INF/classes/confluence-init.properties', env)
|
2019-08-12 23:03:57 +00:00
|
|
|
|
2019-08-13 01:33:49 +00:00
|
|
|
gen_cfg('confluence.cfg.xml.j2',
|
|
|
|
env['confluence_home']+'/confluence.cfg.xml', env,
|
2019-08-12 23:52:18 +00:00
|
|
|
user=env['run_user'], group=env['run_group'], mode=0o640)
|
2019-08-12 23:03:57 +00:00
|
|
|
|
2019-08-12 05:54:29 +00:00
|
|
|
|
2019-08-12 04:39:19 +00:00
|
|
|
######################################################################
|
|
|
|
# Start Confluence as the correct user
|
|
|
|
|
2019-08-12 23:52:18 +00:00
|
|
|
start_cmd = "{}/bin/start-confluence.sh".format(env['confluence_install_dir'])
|
2019-08-12 04:39:19 +00:00
|
|
|
if os.getuid() == 0:
|
2019-08-12 23:52:18 +00:00
|
|
|
logging.info("User is currently root. Will change directory ownership to {} then downgrade permissions".format(env['run_user']))
|
|
|
|
set_perms(env['confluence_home'], env['run_user'], env['run_group'], 0o700)
|
2019-08-12 04:39:19 +00:00
|
|
|
|
|
|
|
cmd = '/bin/su'
|
|
|
|
start_cmd = ' '.join([start_cmd] + sys.argv[1:])
|
2019-08-12 23:52:18 +00:00
|
|
|
args = [cmd, env['run_user'], '-c', start_cmd]
|
2019-08-12 04:39:19 +00:00
|
|
|
else:
|
|
|
|
cmd = start_cmd
|
2019-08-12 05:54:29 +00:00
|
|
|
args = [start_cmd] + sys.argv[1:]
|
2019-08-12 04:39:19 +00:00
|
|
|
|
|
|
|
logging.info("Running Confluence with command '{}', arguments {}".format(cmd, args))
|
2019-08-12 05:54:29 +00:00
|
|
|
os.execv(cmd, args)
|