# Copyright 2015 Red Hat, Inc. # # 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 configparser import os import sys from osc_lib.i18n import _ from tripleo_common.image import kolla_builder TRIPLEO_ARCHIVE_DIR = "/var/lib/tripleo/archive" TRIPLEO_HEAT_TEMPLATES = "/usr/share/openstack-tripleo-heat-templates/" OVERCLOUD_YAML_NAME = "overcloud.yaml" OVERCLOUD_ROLES_FILE = "roles_data.yaml" MINION_ROLES_FILE = "roles/UndercloudMinion.yaml" MINION_OUTPUT_DIR = os.path.join(os.environ.get('HOME', '~/')) MINION_CONF_PATH = os.path.join(MINION_OUTPUT_DIR, "minion.conf") MINION_LOG_FILE = "install-minion.log" UNDERCLOUD_ROLES_FILE = "roles_data_undercloud.yaml" STANDALONE_EPHEMERAL_STACK_VSTATE = '/var/lib/tripleo-heat-installer' UNDERCLOUD_LOG_FILE = "install-undercloud.log" OVERCLOUD_NETWORKS_FILE = "network_data_default.yaml" OVERCLOUD_VIP_FILE = "vip_data_default.yaml" STANDALONE_NETWORKS_FILE = "/dev/null" UNDERCLOUD_NETWORKS_FILE = "network_data_undercloud.yaml" ANSIBLE_HOSTS_FILENAME = "hosts.yaml" EPHEMERAL_HEAT_POD_NAME = "ephemeral-heat" ANSIBLE_CWL = "tripleo_dense,tripleo_profile_tasks,tripleo_states" CONTAINER_IMAGE_PREPARE_LOG_FILE = "container_image_prepare.log" DEFAULT_CONTAINER_REGISTRY = "quay.io" DEFAULT_CONTAINER_NAMESPACE = "tripleomaster" DEFAULT_CONTAINER_TAG = "current-tripleo" DEFAULT_RESOURCE_REGISTRY = 'overcloud-resource-registry-puppet.yaml' if os.path.isfile(kolla_builder.DEFAULT_PREPARE_FILE): kolla_builder.init_prepare_defaults(kolla_builder.DEFAULT_PREPARE_FILE) DEFAULT_CONTAINER_IMAGE_PARAMS = kolla_builder.CONTAINER_IMAGES_DEFAULTS else: DEFAULT_CONTAINER_IMAGE_PARAMS = { 'namespace': 'quay.io/tripleomaster', 'name_prefix': 'openstack-', 'tag': 'current-tripleo' } DEFAULT_HEAT_CONTAINER = ('{}/{}heat-all:{}'.format( DEFAULT_CONTAINER_IMAGE_PARAMS['namespace'], DEFAULT_CONTAINER_IMAGE_PARAMS['name_prefix'], DEFAULT_CONTAINER_IMAGE_PARAMS['tag'])) DEFAULT_HEAT_API_CONTAINER = ('{}/{}heat-api:{}'.format( DEFAULT_CONTAINER_IMAGE_PARAMS['namespace'], DEFAULT_CONTAINER_IMAGE_PARAMS['name_prefix'], DEFAULT_CONTAINER_IMAGE_PARAMS['tag'])) DEFAULT_HEAT_ENGINE_CONTAINER = ('{}/{}heat-engine:{}'.format( DEFAULT_CONTAINER_IMAGE_PARAMS['namespace'], DEFAULT_CONTAINER_IMAGE_PARAMS['name_prefix'], DEFAULT_CONTAINER_IMAGE_PARAMS['tag'])) DEFAULT_EPHEMERAL_HEAT_CONTAINER = \ 'localhost/tripleo/openstack-heat-all:ephemeral' DEFAULT_EPHEMERAL_HEAT_API_CONTAINER = \ 'localhost/tripleo/openstack-heat-api:ephemeral' DEFAULT_EPHEMERAL_HEAT_ENGINE_CONTAINER = \ 'localhost/tripleo/openstack-heat-engine:ephemeral' USER_PARAMETERS = 'user-environments/tripleoclient-parameters.yaml' PASSWORDS_ENV_FORMAT = '{}-passwords.yaml' # This directory may contain additional environments to use during deploy DEFAULT_ENV_DIRECTORY = os.path.join(os.environ.get('HOME', '~/'), '.tripleo', 'environments') DEPLOYED_SERVER_ENVIRONMENT = 'environments/deployed-server-environment.yaml' TRIPLEO_PUPPET_MODULES = "/usr/share/openstack-puppet/modules/" PUPPET_MODULES = "/etc/puppet/modules/" PUPPET_BASE = "/etc/puppet/" STACK_TIMEOUT = 240 IRONIC_HTTP_BOOT_BIND_MOUNT = '/var/lib/ironic/httpboot' IRONIC_LOCAL_IMAGE_PATH = '/var/lib/ironic/images' # The default minor update ansible playbooks generated from heat stack output MINOR_UPDATE_PLAYBOOKS = ['update_steps_playbook.yaml'] # The default major upgrade ansible playbooks generated from heat stack output MAJOR_UPGRADE_PLAYBOOKS = ["upgrade_steps_playbook.yaml", "deploy_steps_playbook.yaml", "post_upgrade_steps_playbook.yaml"] MAJOR_UPGRADE_SKIP_TAGS = ['validation', 'pre-upgrade'] EXTERNAL_UPDATE_PLAYBOOKS = ['external_update_steps_playbook.yaml'] EXTERNAL_UPGRADE_PLAYBOOKS = ['external_upgrade_steps_playbook.yaml'] # upgrade environment files expected by the client in the --templates # tripleo-heat-templates default above $TRIPLEO_HEAT_TEMPLATES UPDATE_PREPARE_ENV = "environments/lifecycle/update-prepare.yaml" UPGRADE_PREPARE_ENV = "environments/lifecycle/upgrade-prepare.yaml" UPGRADE_CONVERGE_ENV = "environments/lifecycle/upgrade-converge.yaml" UPGRADE_CONVERGE_FORBIDDEN_PARAMS = ["ceph3_namespace", "ceph3_tag", "ceph3_image", "name_prefix_stein", "name_suffix_stein", "namespace_stein", "tag_stein", ] ENABLE_SSH_ADMIN_TIMEOUT = 600 ENABLE_SSH_ADMIN_STATUS_INTERVAL = 5 ENABLE_SSH_ADMIN_SSH_PORT_TIMEOUT = 600 ADDITIONAL_ARCHITECTURES = ['ppc64le'] DEFAULT_VALIDATIONS_BASEDIR = "/usr/share/ansible" VALIDATIONS_LOG_BASEDIR = '/var/log/validations' DEFAULT_WORK_DIR = os.path.join(os.environ.get('HOME', '~/'), 'config-download') DEFAULT_TEMPLATES_DIR = "/usr/share/python-tripleoclient/templates" TRIPLEO_STATIC_INVENTORY = 'tripleo-ansible-inventory.yaml' ANSIBLE_INVENTORY = os.path.join(DEFAULT_WORK_DIR, '{}/', TRIPLEO_STATIC_INVENTORY) ANSIBLE_VALIDATION_DIR = "/usr/share/ansible/validation-playbooks" # NOTE(mwhahaha): So if we pip install tripleoclient, we need to also # honor pulling some other files from a venv (e.g. cli playbooks, # and container image yaml for building). This logic will create a # constant for a venv share path which we can use to check to see if things # like tripleo-common or tripleo-ansible have also been pip installed. SHARE_BASE_PATH = os.path.join(sys.prefix, 'share') if sys.prefix != '/usr' and not os.path.isdir(SHARE_BASE_PATH): SHARE_BASE_PATH = os.path.join('/usr', 'share') ANSIBLE_TRIPLEO_PLAYBOOKS = os.path.join( SHARE_BASE_PATH, 'ansible', 'tripleo-playbooks' ) if sys.prefix != '/usr' and not os.path.isdir(ANSIBLE_TRIPLEO_PLAYBOOKS): ANSIBLE_TRIPLEO_PLAYBOOKS = os.path.join( '/usr', 'share', 'ansible', 'tripleo-playbooks' ) CONTAINER_IMAGES_BASE_PATH = os.path.join( SHARE_BASE_PATH, "tripleo-common", "container-images" ) if sys.prefix != "/usr" and not os.path.isdir(CONTAINER_IMAGES_BASE_PATH): CONTAINER_IMAGES_BASE_PATH = os.path.join( "/usr", "share", "tripleo-common", "container-images" ) VALIDATION_GROUPS_INFO = "{}/groups.yaml".format(DEFAULT_VALIDATIONS_BASEDIR) # ctlplane network defaults CTLPLANE_NET_NAME = 'ctlplane' CTLPLANE_CIDR_DEFAULT = '192.168.24.0/24' CTLPLANE_DHCP_START_DEFAULT = ['192.168.24.5'] CTLPLANE_DHCP_END_DEFAULT = ['192.168.24.24'] CTLPLANE_INSPECTION_IPRANGE_DEFAULT = '192.168.24.100,192.168.24.120' CTLPLANE_GATEWAY_DEFAULT = '192.168.24.1' CTLPLANE_DNS_NAMESERVERS_DEFAULT = [] # Ansible parameters used for the actions being executed during tripleo # deploy/upgrade. Used as kwargs in the `utils.run_ansible_playbook` # function. A playbook entry is either a string representing the name of # one the playbook or a list of playbooks to execute. The lookup # will search for the playbook in the work directory path. DEPLOY_ANSIBLE_ACTIONS = { 'deploy': { 'playbook': 'deploy_steps_playbook.yaml' }, 'upgrade': { 'playbook': 'upgrade_steps_playbook.yaml', 'skip_tags': 'validation' }, 'post-upgrade': { 'playbook': 'post_upgrade_steps_playbook.yaml', 'skip_tags': 'validation' }, 'online-upgrade': { 'playbook': 'external_upgrade_steps_playbook.yaml', 'tags': 'online_upgrade' }, 'preflight-deploy': { 'playbook': 'undercloud-disk-space.yaml' }, 'preflight-upgrade': { 'playbook': 'undercloud-disk-space-pre-upgrade.yaml' }, } # Key-value pair of deprecated service and its warning message DEPRECATED_SERVICES = {} # clouds_yaml related constants CLOUD_HOME_DIR = os.path.expanduser('~' + os.environ.get('SUDO_USER', '')) CLOUDS_YAML_DIR = os.path.join('.config', 'openstack') # Undercloud config and output UNDERCLOUD_CONF_PATH = os.path.join(CLOUD_HOME_DIR, "undercloud.conf") try: if os.path.exists(UNDERCLOUD_CONF_PATH): config = configparser.ConfigParser() config.read(UNDERCLOUD_CONF_PATH) UNDERCLOUD_OUTPUT_DIR = config.get('DEFAULT', 'output_dir') else: raise FileNotFoundError except (configparser.NoOptionError, FileNotFoundError): UNDERCLOUD_OUTPUT_DIR = CLOUD_HOME_DIR # regex patterns to exclude when looking for unused params # - exclude *Image params as they may be unused because the service is not # enabled # - exclude SwiftFetchDir*Tempurl because it's used by ceph and generated by us # - exclude PythonInterpreter because it's generated by us and only used # in some custom scripts UNUSED_PARAMETER_EXCLUDES_RE = ['^(Docker|Container).*Image$', '^SwiftFetchDir(Get|Put)Tempurl$', '^PythonInterpreter$'] EXPORT_PASSWORD_EXCLUDE_PATTERNS = [ 'ceph.*' ] EXPORT_DATA = { "EndpointMap": { "parameter": "EndpointMapOverride", }, "HostsEntry": { "parameter": "ExtraHostFileEntries", }, "GlobalConfig": { "parameter": "GlobalConfigExtraMapData", }, "AllNodesConfig": { "file": "group_vars/overcloud.json", "parameter": "AllNodesExtraMapData", "filter": ["oslo_messaging_notify_short_bootstrap_node_name", "oslo_messaging_notify_node_names", "oslo_messaging_rpc_node_names", "memcached_node_ips", "ovn_dbs_vip", "redis_vip"]}, } # Package that need to be to the latest before undercloud # update/update UNDERCLOUD_EXTRA_PACKAGES = [ "openstack-tripleo-common", "openstack-tripleo-heat-templates", "openstack-tripleo-validations", "tripleo-ansible" ] UPGRADE_PROMPT = _('You are about to run a UPGRADE command. ' 'It is strongly recommended to perform a backup ' 'before the upgrade. Are you sure you want to ' 'upgrade [y/N]?') UPGRADE_NO = _('User did not confirm upgrade, so exiting. ' 'Consider using the --yes/-y parameter if you ' 'prefer to skip this warning in the future') UPDATE_PROMPT = _('You are about to run a UPDATE command. ' 'It is strongly recommended to perform a backup ' 'before the update. Are you sure you want to ' 'update [y/N]?') UPDATE_NO = _('User did not confirm update, so exiting. ' 'Consider using the --yes/-y parameter if you ' 'prefer to skip this warning in the future') DEFAULT_PARTITION_IMAGE = 'overcloud-full.qcow2' DEFAULT_WHOLE_DISK_IMAGE = 'overcloud-hardened-uefi-full.qcow2' FIPS_COMPLIANT_HASHES = {'sha1', 'sha224', 'sha256', 'sha384', 'sha512'} # Work-Dir default file names WD_DEFAULT_ROLES_FILE_NAME = 'tripleo-{}-roles-data.yaml' WD_DEFAULT_NETWORKS_FILE_NAME = 'tripleo-{}-network-data.yaml' WD_DEFAULT_VIP_FILE_NAME = 'tripleo-{}-virtual-ips.yaml' WD_DEFAULT_BAREMETAL_FILE_NAME = 'tripleo-{}-baremetal-deployment.yaml' KIND_TEMPLATES = {'roles': WD_DEFAULT_ROLES_FILE_NAME, 'networks': WD_DEFAULT_NETWORKS_FILE_NAME, 'baremetal': WD_DEFAULT_BAREMETAL_FILE_NAME, 'vips': WD_DEFAULT_VIP_FILE_NAME}