openstack-helm/nova/templates/bin/_ssh-start.sh.tpl
Gerry Kopec 52f8415deb Start nova sshd container only if enabled
Only start the sshd container of nova-compute pod if the capability is
enabled.  Defaults to off to allow cases where nova docker image does
not have ssh packages to run cleanly.

Story: 2003463
Task: 30441
Change-Id: I3acf5b654ecda23a93f6c28e865e1bbee14370aa
Signed-off-by: Gerry Kopec <Gerry.Kopec@windriver.com>
2019-04-10 00:36:07 -04:00

52 lines
1.4 KiB
Smarty

#!/bin/bash
{{/*
Copyright 2017 The Openstack-Helm Authors.
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.
*/}}
set -ex
IFS=','
for KEY_TYPE in $KEY_TYPES; do
KEY_PATH=/etc/ssh/ssh_host_${KEY_TYPE}_key
if [[ ! -f "${KEY_PATH}" ]]; then
ssh-keygen -q -t ${KEY_TYPE} -f ${KEY_PATH} -N ""
fi
done
IFS=''
mkdir -p ~nova/.ssh
if [[ $(stat -c %U:%G ~nova/.ssh) != "nova:nova" ]]; then
chown nova: ~nova/.ssh
fi
subnet_address="{{- .Values.network.sshd.from_subnet -}}"
cat > /tmp/sshd_config_extend <<EOF
# This Match block prevents Password Authentication for root user
Match User root
PasswordAuthentication no
# This Match Block is used to allow Root Login exceptions over the
# internal subnet used by Nova Migrations
Match Address $subnet_address
PermitRootLogin without-password
EOF
cat /tmp/sshd_config_extend >> /etc/ssh/sshd_config
rm /tmp/sshd_config_extend
exec /usr/sbin/sshd -D -e -o Port=$SSH_PORT