heat-agents/heat-config-hiera/install.d/hook-hiera.py

119 lines
3.8 KiB
Python
Executable File

#!/usr/bin/env python
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import json
import logging
import os
import subprocess
import sys
HIERA_DATADIR = os.environ.get('HEAT_PUPPET_HIERA_DATADIR',
'/etc/puppet/hieradata')
HIERA_CONFIG = os.environ.get('HEAT_HIERA_CONFIG', '/etc/puppet/hiera.yaml')
HIERA_ELEMENT_CHECK_CMD = os.environ.get('HEAT_HIERA_ELEMENT_CHECK_CMD',
'os-apply-config '
'--key hiera.datafiles '
'--type raw --key-default empty')
HIERA_CONFIG_BASE = """
---
:backends:
- json
:json:
:datadir: %(datadir)s
:hierarchy:
""" % {'datadir': HIERA_DATADIR}
def prepare_dir(path):
if not os.path.isdir(path):
os.makedirs(path, 0o700)
def exit_legacy_hiera_detected():
try:
subproc = subprocess.Popen(HIERA_ELEMENT_CHECK_CMD.split(" "),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
stdout, stderr = subproc.communicate()
rs_stdout = stdout.rstrip().decode('utf-8', 'replace')
if rs_stdout != 'empty':
err_msg = ('Legacy hieradata from os-apply-config has been '
'detected - %s. Please update all of your interfaces '
'to use the new heat-agents hiera hook before '
'proceeding' % rs_stdout)
response = {
'deploy_stdout': stdout,
'deploy_stderr': err_msg,
'deploy_status_code': 1,
}
json.dump(response, sys.stdout)
sys.exit(0)
except OSError:
# os-apply-config is not installed? Assume there is no legacy data.
pass
def main(argv=sys.argv):
log = logging.getLogger('heat-config')
handler = logging.StreamHandler(sys.stderr)
handler.setFormatter(
logging.Formatter(
'[%(asctime)s] (%(name)s) [%(levelname)s] %(message)s'))
log.addHandler(handler)
log.setLevel('DEBUG')
c = json.load(sys.stdin)['config']
exit_legacy_hiera_detected()
prepare_dir(HIERA_DATADIR)
hiera_config_file = os.path.join(HIERA_CONFIG)
# allow the end user to order the hiera config as they wish
if 'hierarchy' in c:
with os.fdopen(os.open(hiera_config_file,
os.O_CREAT | os.O_TRUNC | os.O_WRONLY, 0o600),
'w') as config_file:
config_file.write(HIERA_CONFIG_BASE)
for item in c['hierarchy']:
config_file.write(' - %s\n' % item)
# write out the datafiles as YAML
if 'datafiles' in c:
for name, data in c['datafiles'].items():
hiera_data = os.path.join(HIERA_DATADIR, '%s.json' % name)
with os.fdopen(os.open(hiera_data,
os.O_CREAT | os.O_TRUNC | os.O_WRONLY,
0o600),
'w') as hiera_data_file:
json.dump(data, hiera_data_file, indent=4, sort_keys=True,
separators=(',', ': '))
response = {
'deploy_stdout': '',
'deploy_stderr': '',
'deploy_status_code': 0,
}
json.dump(response, sys.stdout)
if __name__ == '__main__':
sys.exit(main(sys.argv))