129 lines
2.9 KiB
Bash
Executable File
129 lines
2.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# mkdir -p collect certs bundle
|
|
# tools/airship pegleg site -r /target collect airsloop -s collect
|
|
# tools/airship promenade generate-certs -o /target/certs /target/collect/*.yaml
|
|
# tools/airship promenade build-all -o /target/bundle /target/collect/*.yaml /target/certs/*.yaml
|
|
# tools/shipyard get actions
|
|
|
|
: ${TERM_OPTS:='-it'}
|
|
|
|
|
|
ENV_FILE=$(mktemp)
|
|
trap "{ rm -f $ENV_FILE; }" EXIT
|
|
|
|
# prepare docker environment file
|
|
cat > $ENV_FILE << EOF
|
|
PEGLEG_PASSPHRASE=${PEGLEG_PASSPHRASE:-'password123'}
|
|
PEGLEG_SALT=${PEGLEG_SALT:=-'password123'}
|
|
|
|
OS_AUTH_URL=${OS_AUTH_URL:-'http://keystone-api.ucp.svc.cluster.local:5000/v3'}
|
|
OS_PASSWORD=${OS_PASSWORD:-'password123'}
|
|
OS_PROJECT_DOMAIN_NAME=${OS_PROJECT_DOMAIN_NAME:-'default'}
|
|
OS_PROJECT_NAME=${OS_PROJECT_NAME:-'service'}
|
|
OS_USERNAME=${OS_USERNAME:-'shipyard'}
|
|
OS_USER_DOMAIN_NAME=${OS_USER_DOMAIN_NAME:-'default'}
|
|
OS_IDENTITY_API_VERSION=${OS_IDENTITY_API_VERSION:-'3'}
|
|
EOF
|
|
|
|
|
|
# Key/value lookups from manifests
|
|
manifests_lookup(){
|
|
|
|
local file="$1"
|
|
local schema="$2"
|
|
local mdata_name="$3"
|
|
local key_path="$4"
|
|
local oper="$5"
|
|
local allow_fail="$6"
|
|
|
|
FAIL=false
|
|
RESULT=`python3 -c "
|
|
|
|
import yaml,sys
|
|
y = yaml.load_all(open('$file'))
|
|
for x in y:
|
|
if x.get('schema') == '$schema':
|
|
if x['metadata']['name'] == '$mdata_name':
|
|
if isinstance(x$key_path,list):
|
|
if '$oper' == 'get_size':
|
|
print(len(x$key_path))
|
|
break
|
|
else:
|
|
for i in x$key_path:
|
|
print(i)
|
|
break
|
|
else:
|
|
if '$oper' == 'dict_keys':
|
|
print(' '.join(x$key_path.keys()))
|
|
break
|
|
else:
|
|
print(x$key_path)
|
|
break
|
|
else:
|
|
sys.exit(1)" 2>&1` || FAIL=true
|
|
|
|
if [[ $FAIL = true ]] && [[ $allow_fail != true ]]; then
|
|
die "Lookup failed for schema '$schema', metadata.name '$mdata_name', key path '$key_path'"
|
|
fi
|
|
}
|
|
|
|
versions_lookup() {
|
|
manifests_lookup 'global/software/config/versions.yaml' \
|
|
'pegleg/SoftwareVersions/v1' \
|
|
'software-versions' "$1"
|
|
IMAGE_URL=$RESULT
|
|
}
|
|
|
|
|
|
pegleg() {
|
|
|
|
versions_lookup "['data']['images']['ucp']['pegleg']['pegleg']"
|
|
|
|
docker run --rm --net=host $TERM_OPTS \
|
|
-w /target \
|
|
-v $(pwd):/target \
|
|
-v ${HOME}/.ssh:/target/.ssh \
|
|
--env-file $ENV_FILE \
|
|
$IMAGE_URL $@
|
|
}
|
|
|
|
promenade() {
|
|
|
|
versions_lookup "['data']['images']['ucp']['promenade']['promenade']"
|
|
|
|
docker run --rm --net=host $TERM_OPTS \
|
|
-w /target \
|
|
-v $(pwd):/target \
|
|
--env-file $ENV_FILE \
|
|
$IMAGE_URL $@
|
|
}
|
|
|
|
shipyard() {
|
|
|
|
versions_lookup "['data']['images']['ucp']['shipyard']['shipyard']"
|
|
|
|
SHIPYARD_IMAGE=$RESULT
|
|
docker run --rm --net=host $TERM_OPTS \
|
|
-w /target \
|
|
-v $(pwd):/target \
|
|
--env-file $ENV_FILE \
|
|
$IMAGE_URL $@
|
|
}
|
|
|
|
|
|
case "$1" in
|
|
'pegleg')
|
|
pegleg $@
|
|
;;
|
|
'promenade')
|
|
promenade $@
|
|
;;
|
|
'shipyard')
|
|
shipyard $@
|
|
;;
|
|
*) echo "Invalid option"
|
|
exit 1
|
|
;;
|
|
esac
|