stdlib: cue fmt
Signed-off-by: Sam Alba <sam.alba@gmail.com>
This commit is contained in:
parent
669a47a159
commit
1fb4f4e314
@ -37,36 +37,36 @@ import (
|
|||||||
"-eo",
|
"-eo",
|
||||||
"pipefail",
|
"pipefail",
|
||||||
#"""
|
#"""
|
||||||
if [ -s "$VHOST" ]; then
|
if [ -s "$VHOST" ]; then
|
||||||
# We passed a vhost as input, try to recycle priority from previously allocated vhost
|
# We passed a vhost as input, try to recycle priority from previously allocated vhost
|
||||||
priority=$(aws elbv2 describe-rules \
|
priority=$(aws elbv2 describe-rules \
|
||||||
--listener-arn "$LISTENER_ARN" | \
|
--listener-arn "$LISTENER_ARN" | \
|
||||||
jq -r --arg vhost "$VHOST" '.Rules[] | select(.Conditions[].HostHeaderConfig.Values[] == $VHOST) | .Priority')
|
jq -r --arg vhost "$VHOST" '.Rules[] | select(.Conditions[].HostHeaderConfig.Values[] == $VHOST) | .Priority')
|
||||||
|
|
||||||
if [ -n "${priority}" ]; then
|
if [ -n "${priority}" ]; then
|
||||||
echo -n "${priority}" > /priority
|
echo -n "${priority}" > /priority
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Grab a priority random from 1-50k and check if available, retry 10 times if none available
|
# Grab a priority random from 1-50k and check if available, retry 10 times if none available
|
||||||
priority=0
|
priority=0
|
||||||
for i in {1..10}
|
for i in {1..10}
|
||||||
do
|
do
|
||||||
p=$(shuf -i 1-50000 -n 1)
|
p=$(shuf -i 1-50000 -n 1)
|
||||||
# Find the next priority available that we can allocate
|
# Find the next priority available that we can allocate
|
||||||
aws elbv2 describe-rules \
|
aws elbv2 describe-rules \
|
||||||
--listener-arn "$LISTENER_ARN" \
|
--listener-arn "$LISTENER_ARN" \
|
||||||
| jq -e "select(.Rules[].Priority == \"${p}\") | true" && continue
|
| jq -e "select(.Rules[].Priority == \"${p}\") | true" && continue
|
||||||
priority="${p}"
|
priority="${p}"
|
||||||
break
|
break
|
||||||
done
|
done
|
||||||
if [ "${priority}" -lt 1 ]; then
|
if [ "${priority}" -lt 1 ]; then
|
||||||
echo "Error: cannot determine a Rule priority"
|
echo "Error: cannot determine a Rule priority"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo -n "${priority}" > /priority
|
echo -n "${priority}" > /priority
|
||||||
"""#,
|
"""#,
|
||||||
]
|
]
|
||||||
env: {
|
env: {
|
||||||
LISTENER_ARN: listenerArn
|
LISTENER_ARN: listenerArn
|
||||||
|
@ -41,27 +41,27 @@ import (
|
|||||||
"-eo",
|
"-eo",
|
||||||
"pipefail",
|
"pipefail",
|
||||||
#"""
|
#"""
|
||||||
echo "dbType: $DB_TYPE"
|
echo "dbType: $DB_TYPE"
|
||||||
|
|
||||||
sql="CREATE DATABASE \`"$NAME" \`"
|
sql="CREATE DATABASE \`"$NAME" \`"
|
||||||
if [ "$DB_TYPE" = postgres ]; then
|
if [ "$DB_TYPE" = postgres ]; then
|
||||||
sql="CREATE DATABASE \""$NAME"\""
|
sql="CREATE DATABASE \""$NAME"\""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "$NAME" >> /db_created
|
echo "$NAME" >> /db_created
|
||||||
|
|
||||||
aws rds-data execute-statement \
|
aws rds-data execute-statement \
|
||||||
--resource-arn "$DB_ARN" \
|
--resource-arn "$DB_ARN" \
|
||||||
--secret-arn "$SECRET_ARN" \
|
--secret-arn "$SECRET_ARN" \
|
||||||
--sql "$sql" \
|
--sql "$sql" \
|
||||||
--database "$DB_TYPE" \
|
--database "$DB_TYPE" \
|
||||||
--no-include-result-metadata \
|
--no-include-result-metadata \
|
||||||
|& tee /tmp/out
|
|& tee /tmp/out
|
||||||
exit_code=${PIPESTATUS[0]}
|
exit_code=${PIPESTATUS[0]}
|
||||||
if [ $exit_code -ne 0 ]; then
|
if [ $exit_code -ne 0 ]; then
|
||||||
grep -q "database exists\|already exists" /tmp/out || exit $exit_code
|
grep -q "database exists\|already exists" /tmp/out || exit $exit_code
|
||||||
fi
|
fi
|
||||||
"""#,
|
"""#,
|
||||||
]
|
]
|
||||||
env: {
|
env: {
|
||||||
NAME: name
|
NAME: name
|
||||||
@ -119,53 +119,53 @@ import (
|
|||||||
"-eo",
|
"-eo",
|
||||||
"pipefail",
|
"pipefail",
|
||||||
#"""
|
#"""
|
||||||
echo "dbType: $DB_TYPE"
|
echo "dbType: $DB_TYPE"
|
||||||
|
|
||||||
sql="CREATE USER '"$USERNAME"'@'%' IDENTIFIED BY '"$PASSWORD"'"
|
sql="CREATE USER '"$USERNAME"'@'%' IDENTIFIED BY '"$PASSWORD"'"
|
||||||
if [ "$DB_TYPE" = postgres ]; then
|
if [ "$DB_TYPE" = postgres ]; then
|
||||||
sql="CREATE USER \""$USERNAME"\" WITH PASSWORD '"$PASSWORD"'"
|
sql="CREATE USER \""$USERNAME"\" WITH PASSWORD '"$PASSWORD"'"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "$USERNAME" >> /username
|
echo "$USERNAME" >> /username
|
||||||
|
|
||||||
aws rds-data execute-statement \
|
aws rds-data execute-statement \
|
||||||
--resource-arn "$DB_ARN" \
|
--resource-arn "$DB_ARN" \
|
||||||
--secret-arn "$SECRET_ARN" \
|
--secret-arn "$SECRET_ARN" \
|
||||||
--sql "$sql" \
|
--sql "$sql" \
|
||||||
--database "$DB_TYPE" \
|
--database "$DB_TYPE" \
|
||||||
--no-include-result-metadata \
|
--no-include-result-metadata \
|
||||||
|& tee tmp/out
|
|& tee tmp/out
|
||||||
exit_code=${PIPESTATUS[0]}
|
exit_code=${PIPESTATUS[0]}
|
||||||
if [ $exit_code -ne 0 ]; then
|
if [ $exit_code -ne 0 ]; then
|
||||||
grep -q "Operation CREATE USER failed for\|ERROR" tmp/out || exit $exit_code
|
grep -q "Operation CREATE USER failed for\|ERROR" tmp/out || exit $exit_code
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sql="SET PASSWORD FOR '"$USERNAME"'@'%' = PASSWORD('"$PASSWORD"')"
|
sql="SET PASSWORD FOR '"$USERNAME"'@'%' = PASSWORD('"$PASSWORD"')"
|
||||||
if [ "$DB_TYPE" = postgres ]; then
|
if [ "$DB_TYPE" = postgres ]; then
|
||||||
sql="ALTER ROLE \""$USERNAME"\" WITH PASSWORD '"$PASSWORD"'"
|
sql="ALTER ROLE \""$USERNAME"\" WITH PASSWORD '"$PASSWORD"'"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
aws rds-data execute-statement \
|
aws rds-data execute-statement \
|
||||||
--resource-arn "$DB_ARN" \
|
--resource-arn "$DB_ARN" \
|
||||||
--secret-arn "$SECRET_ARN" \
|
--secret-arn "$SECRET_ARN" \
|
||||||
--sql "$sql" \
|
--sql "$sql" \
|
||||||
--database "$DB_TYPE" \
|
--database "$DB_TYPE" \
|
||||||
--no-include-result-metadata
|
--no-include-result-metadata
|
||||||
|
|
||||||
sql="GRANT ALL ON \`"$GRAND_DATABASE"\`.* to '"$USERNAME"'@'%'"
|
sql="GRANT ALL ON \`"$GRAND_DATABASE"\`.* to '"$USERNAME"'@'%'"
|
||||||
if [ "$DB_TYPE" = postgres ]; then
|
if [ "$DB_TYPE" = postgres ]; then
|
||||||
sql="GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO \""$USERNAME"\"; GRANT ALL PRIVILEGES ON DATABASE \""$GRAND_DATABASE"\" to \""$USERNAME"\"; GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO \""$USERNAME"\"; ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON TABLES TO \""$USERNAME"\"; ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON SEQUENCES TO \""$USERNAME"\"; GRANT USAGE ON SCHEMA public TO \""$USERNAME"\";"
|
sql="GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO \""$USERNAME"\"; GRANT ALL PRIVILEGES ON DATABASE \""$GRAND_DATABASE"\" to \""$USERNAME"\"; GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO \""$USERNAME"\"; ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON TABLES TO \""$USERNAME"\"; ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL PRIVILEGES ON SEQUENCES TO \""$USERNAME"\"; GRANT USAGE ON SCHEMA public TO \""$USERNAME"\";"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -s "$GRAND_DATABASE ]; then
|
if [ -s "$GRAND_DATABASE ]; then
|
||||||
aws rds-data execute-statement \
|
aws rds-data execute-statement \
|
||||||
--resource-arn "$DB_ARN" \
|
--resource-arn "$DB_ARN" \
|
||||||
--secret-arn "$SECRET_ARN" \
|
--secret-arn "$SECRET_ARN" \
|
||||||
--sql "$sql" \
|
--sql "$sql" \
|
||||||
--database "$DB_TYPE" \
|
--database "$DB_TYPE" \
|
||||||
--no-include-result-metadata
|
--no-include-result-metadata
|
||||||
fi
|
fi
|
||||||
"""#,
|
"""#,
|
||||||
]
|
]
|
||||||
env: {
|
env: {
|
||||||
USERNAME: username
|
USERNAME: username
|
||||||
@ -222,11 +222,11 @@ import (
|
|||||||
"-eo",
|
"-eo",
|
||||||
"pipefail",
|
"pipefail",
|
||||||
#"""
|
#"""
|
||||||
data=$(aws rds describe-db-clusters --filters "Name=db-cluster-id,Values=$DB_URN" )
|
data=$(aws rds describe-db-clusters --filters "Name=db-cluster-id,Values=$DB_URN" )
|
||||||
echo "$data" | jq -r '.DBClusters[].Endpoint' > /tmp/out
|
echo "$data" | jq -r '.DBClusters[].Endpoint' > /tmp/out
|
||||||
echo "$data" | jq -r '.DBClusters[].Port' >> /tmp/out
|
echo "$data" | jq -r '.DBClusters[].Port' >> /tmp/out
|
||||||
cat /tmp/out | jq -sR 'split("\n") | {hostname: .[0], port: (.[1] | tonumber)}' > /out
|
cat /tmp/out | jq -sR 'split("\n") | {hostname: .[0], port: (.[1] | tonumber)}' > /out
|
||||||
"""#,
|
"""#,
|
||||||
]
|
]
|
||||||
env: DB_ARN: dbArn
|
env: DB_ARN: dbArn
|
||||||
},
|
},
|
||||||
|
Reference in New Issue
Block a user