mirror of
https://gitlab.com/psuapp/psu.git
synced 2024-08-30 18:12:34 +00:00
Merge pull request #33 from openmindlab/1-0-next
improve and simplifying quotes excape
This commit is contained in:
commit
2d14c6d1a5
25
psu
25
psu
@ -281,16 +281,9 @@ echo_debug() {
|
|||||||
deploy() {
|
deploy() {
|
||||||
# Read docker-compose file content
|
# Read docker-compose file content
|
||||||
local docker_compose_file_content
|
local docker_compose_file_content
|
||||||
docker_compose_file_content=$(cat "$DOCKER_COMPOSE_FILE")
|
docker_compose_file_content="$( jq -Rscjr '{StackFileContent: . }' $DOCKER_COMPOSE_FILE | tail -c +2 | head -c -1 )"
|
||||||
|
echo_debug "DOCKER_COMPOSE_FILE -> $DOCKER_COMPOSE_FILE"
|
||||||
# Remove carriage returns
|
echo_debug "docker_compose_file_content -> $docker_compose_file_content"
|
||||||
docker_compose_file_content="${docker_compose_file_content//$'\r'/''}"
|
|
||||||
|
|
||||||
# Escape double quotes
|
|
||||||
docker_compose_file_content="${docker_compose_file_content//$'"'/'\"'}"
|
|
||||||
|
|
||||||
# Escape newlines
|
|
||||||
docker_compose_file_content="${docker_compose_file_content//$'\n'/'\n'}"
|
|
||||||
|
|
||||||
# If the stack does not exist
|
# If the stack does not exist
|
||||||
if [ -z "$STACK" ]; then
|
if [ -z "$STACK" ]; then
|
||||||
@ -324,8 +317,8 @@ deploy() {
|
|||||||
if [ -n "$ENVIRONMENT_VARIABLES_FILE" ]; then
|
if [ -n "$ENVIRONMENT_VARIABLES_FILE" ]; then
|
||||||
stack_envvars=$(env_file_to_json)
|
stack_envvars=$(env_file_to_json)
|
||||||
fi
|
fi
|
||||||
local data_prefix="{\"Name\":\"$PORTAINER_STACK_NAME\",\"StackFileContent\":\""
|
local data_prefix="{\"Name\":\"$PORTAINER_STACK_NAME\","
|
||||||
local data_suffix="\",\"Env\":"$stack_envvars"}"
|
local data_suffix=",\"Env\":"$stack_envvars"}"
|
||||||
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
||||||
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
||||||
|
|
||||||
@ -354,8 +347,8 @@ deploy() {
|
|||||||
if [ -n "$ENVIRONMENT_VARIABLES_FILE" ]; then
|
if [ -n "$ENVIRONMENT_VARIABLES_FILE" ]; then
|
||||||
stack_envvars=$(env_file_to_json)
|
stack_envvars=$(env_file_to_json)
|
||||||
fi
|
fi
|
||||||
local data_prefix="{\"Name\":\"$PORTAINER_STACK_NAME\",\"SwarmID\":\"$swarm_id\",\"StackFileContent\":\""
|
local data_prefix="{\"Name\":\"$PORTAINER_STACK_NAME\",\"SwarmID\":\"$swarm_id\","
|
||||||
local data_suffix="\",\"Env\":"$stack_envvars"}"
|
local data_suffix=",\"Env\":"$stack_envvars"}"
|
||||||
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
||||||
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
||||||
|
|
||||||
@ -395,8 +388,8 @@ deploy() {
|
|||||||
new_stack_envvars=$(env_file_to_json)
|
new_stack_envvars=$(env_file_to_json)
|
||||||
stack_envvars="$(echo "${new_stack_envvars}${stack_envvars}" | jq -sjc 'add | unique_by(.name)')"
|
stack_envvars="$(echo "${new_stack_envvars}${stack_envvars}" | jq -sjc 'add | unique_by(.name)')"
|
||||||
fi
|
fi
|
||||||
local data_prefix="{\"Id\":\"$stack_id\",\"StackFileContent\":\""
|
local data_prefix="{\"Id\":\"$stack_id\","
|
||||||
local data_suffix="\",\"Env\":"$stack_envvars",\"Prune\":$PORTAINER_PRUNE}"
|
local data_suffix=",\"Env\":"$stack_envvars",\"Prune\":$PORTAINER_PRUNE}"
|
||||||
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
echo "$data_prefix$docker_compose_file_content$data_suffix" > json.tmp
|
||||||
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
echo_debug "Stack JSON -> $(echo $data_prefix$docker_compose_file_content$data_suffix | jq -C .)"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user