standalone run a post config to generate a clouds.yaml
Implement a post script for the standalone to generate a basic clouds.yaml for use with various tools. This one does not reuse the undercloud post because the undercloud script performs a bunch of undercloud specific functions. Change-Id: I0496f4dd2026ab6c705683126c8f50302a0861b9
This commit is contained in:
parent
526f39517b
commit
2a9fc8db79
@ -2,7 +2,7 @@ resource_registry:
|
||||
OS::TripleO::Network::Ports::RedisVipPort: ../network/ports/noop.yaml
|
||||
OS::TripleO::Network::Ports::ControlPlaneVipPort: ../deployed-server/deployed-neutron-port.yaml
|
||||
OS::TripleO::Standalone::Net::SoftwareConfig: ../net-config-standalone.yaml
|
||||
OS::TripleO::NodeExtraConfigPost: OS::Heat::None
|
||||
OS::TripleO::NodeExtraConfigPost: ../extraconfig/post_deploy/standalone_post.yaml
|
||||
|
||||
# Disable non-openstack services that are enabled by default
|
||||
OS::TripleO::Services::HAproxy: OS::Heat::None
|
||||
|
26
extraconfig/post_deploy/standalone_post.sh
Executable file
26
extraconfig/post_deploy/standalone_post.sh
Executable file
@ -0,0 +1,26 @@
|
||||
#!/bin/bash
|
||||
set -eux
|
||||
|
||||
ln -sf /etc/puppet/hiera.yaml /etc/hiera.yaml
|
||||
|
||||
HOMEDIR="$homedir"
|
||||
|
||||
# write out clouds.yaml
|
||||
|
||||
mkdir -p $HOMEDIR/.config/openstack
|
||||
touch $HOMEDIR/.config/openstack/clouds.yaml
|
||||
chown 600 $HOMEDIR/.config/openstack/clouds.yaml
|
||||
cat <<EOF >$HOMEDIR/.config/openstack/clouds.yaml
|
||||
clouds:
|
||||
$cloud_name:
|
||||
auth:
|
||||
auth_url: $auth_url
|
||||
project_name: admin
|
||||
username: admin
|
||||
password: $admin_password
|
||||
region_name: $region_name
|
||||
identity_api_version: 3
|
||||
cloud: standalone
|
||||
EOF
|
||||
|
||||
|
90
extraconfig/post_deploy/standalone_post.yaml
Normal file
90
extraconfig/post_deploy/standalone_post.yaml
Normal file
@ -0,0 +1,90 @@
|
||||
heat_template_version: rocky
|
||||
|
||||
description: >
|
||||
Post-deployment for the TripleO standalone deployment
|
||||
|
||||
parameters:
|
||||
servers:
|
||||
type: json
|
||||
DeployedServerPortMap:
|
||||
default: {}
|
||||
type: json
|
||||
UndercloudHomeDir:
|
||||
description: The HOME directory where the stackrc and ssh credentials for the Undercloud will be installed. Set to /home/<user> to customize the location.
|
||||
type: string
|
||||
default: '/root'
|
||||
AdminPassword: #supplied by tripleo-undercloud-passwords.yaml
|
||||
type: string
|
||||
description: The password for the keystone admin account, used for monitoring, querying neutron etc.
|
||||
hidden: True
|
||||
SSLCertificate:
|
||||
description: >
|
||||
The content of the SSL certificate (without Key) in PEM format.
|
||||
type: string
|
||||
default: ""
|
||||
hidden: True
|
||||
PublicSSLCertificateAutogenerated:
|
||||
default: false
|
||||
description: >
|
||||
Whether the public SSL certificate was autogenerated or not.
|
||||
type: boolean
|
||||
KeystoneRegion:
|
||||
type: string
|
||||
default: 'regionOne'
|
||||
description: Keystone region for endpoint
|
||||
StandaloneCloudName:
|
||||
type: string
|
||||
default: 'standalone'
|
||||
description: Cloud name for the clouds.yaml
|
||||
|
||||
conditions:
|
||||
|
||||
tls_enabled:
|
||||
or:
|
||||
- not:
|
||||
equals:
|
||||
- {get_param: SSLCertificate}
|
||||
- ""
|
||||
- equals:
|
||||
- {get_param: PublicSSLCertificateAutogenerated}
|
||||
- true
|
||||
|
||||
resources:
|
||||
|
||||
StandalonePostConfig:
|
||||
type: OS::Heat::SoftwareConfig
|
||||
properties:
|
||||
group: script
|
||||
inputs:
|
||||
- name: admin_password
|
||||
- name: auth_url
|
||||
- name: cloud_name
|
||||
- name: homedir
|
||||
- name: region_name
|
||||
config: {get_file: ./standalone_post.sh}
|
||||
|
||||
StandalonePostDeployment:
|
||||
type: OS::Heat::SoftwareDeployments
|
||||
properties:
|
||||
name: StandalonePostDeployment
|
||||
servers: {get_param: servers}
|
||||
config: {get_resource: StandalonePostConfig}
|
||||
input_values:
|
||||
admin_password: {get_param: AdminPassword}
|
||||
# if SSL is enabled we use the public virtual ip as the stackrc endpoint
|
||||
auth_url:
|
||||
if:
|
||||
- tls_enabled
|
||||
- make_url:
|
||||
scheme: https
|
||||
host: {get_param: [DeployedServerPortMap, 'public_virtual_ip', fixed_ips, 0, ip_address]}
|
||||
port: 13000
|
||||
path: /
|
||||
- make_url:
|
||||
scheme: http
|
||||
host: {get_param: [DeployedServerPortMap, 'control_virtual_ip', fixed_ips, 0, ip_address]}
|
||||
port: 5000
|
||||
path: /
|
||||
cloud_name: {get_param: StandaloneCloudName}
|
||||
homedir: {get_param: UndercloudHomeDir}
|
||||
region_name: {get_param: KeystoneRegion}
|
Loading…
Reference in New Issue
Block a user