|
|
|
@@ -52,6 +52,20 @@ _mosaic_sync_woodpecker_env() {
|
|
|
|
printf '%s\n' "$expected" > "$env_file"
|
|
|
|
printf '%s\n' "$expected" > "$env_file"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Load legacy flat Woodpecker credentials (.woodpecker.url / .woodpecker.token).
|
|
|
|
|
|
|
|
# Some environments export WOODPECKER_INSTANCE=mosaic, but the current
|
|
|
|
|
|
|
|
# credentials.json may still use the legacy flat schema. Treat "mosaic" as the
|
|
|
|
|
|
|
|
# default flat instance when a nested .woodpecker.mosaic object is absent.
|
|
|
|
|
|
|
|
_mosaic_load_woodpecker_legacy() {
|
|
|
|
|
|
|
|
export WOODPECKER_URL="$(_mosaic_read_cred '.woodpecker.url')"
|
|
|
|
|
|
|
|
export WOODPECKER_TOKEN="$(_mosaic_read_cred '.woodpecker.token')"
|
|
|
|
|
|
|
|
export WOODPECKER_INSTANCE="${WOODPECKER_INSTANCE:-mosaic}"
|
|
|
|
|
|
|
|
WOODPECKER_URL="${WOODPECKER_URL%/}"
|
|
|
|
|
|
|
|
[[ -n "$WOODPECKER_URL" ]] || { echo "Error: woodpecker.url not found" >&2; return 1; }
|
|
|
|
|
|
|
|
[[ -n "$WOODPECKER_TOKEN" ]] || { echo "Error: woodpecker.token not found" >&2; return 1; }
|
|
|
|
|
|
|
|
_mosaic_sync_woodpecker_env "$WOODPECKER_INSTANCE" "$WOODPECKER_URL" "$WOODPECKER_TOKEN"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
load_credentials() {
|
|
|
|
load_credentials() {
|
|
|
|
local service="$1"
|
|
|
|
local service="$1"
|
|
|
|
|
|
|
|
|
|
|
|
@@ -155,7 +169,14 @@ EOF
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
woodpecker-*)
|
|
|
|
woodpecker-*)
|
|
|
|
local wp_instance="${service#woodpecker-}"
|
|
|
|
local wp_instance="${service#woodpecker-}"
|
|
|
|
# credentials.json is authoritative — always read from it, ignore env
|
|
|
|
# credentials.json is authoritative — always read from it, ignore env.
|
|
|
|
|
|
|
|
# Backward compatibility: the default Mosaic Woodpecker instance may be
|
|
|
|
|
|
|
|
# stored in the legacy flat schema (.woodpecker.url/.token) instead of
|
|
|
|
|
|
|
|
# .woodpecker.mosaic.url/.token.
|
|
|
|
|
|
|
|
if [[ "$wp_instance" == "mosaic" ]] && [[ -z "$(_mosaic_read_cred '.woodpecker.mosaic.url')" ]] && [[ -n "$(_mosaic_read_cred '.woodpecker.url')" ]]; then
|
|
|
|
|
|
|
|
WOODPECKER_INSTANCE="mosaic" _mosaic_load_woodpecker_legacy
|
|
|
|
|
|
|
|
return $?
|
|
|
|
|
|
|
|
fi
|
|
|
|
export WOODPECKER_URL="$(_mosaic_read_cred ".woodpecker.${wp_instance}.url")"
|
|
|
|
export WOODPECKER_URL="$(_mosaic_read_cred ".woodpecker.${wp_instance}.url")"
|
|
|
|
export WOODPECKER_TOKEN="$(_mosaic_read_cred ".woodpecker.${wp_instance}.token")"
|
|
|
|
export WOODPECKER_TOKEN="$(_mosaic_read_cred ".woodpecker.${wp_instance}.token")"
|
|
|
|
export WOODPECKER_INSTANCE="$wp_instance"
|
|
|
|
export WOODPECKER_INSTANCE="$wp_instance"
|
|
|
|
@@ -166,7 +187,10 @@ EOF
|
|
|
|
_mosaic_sync_woodpecker_env "$wp_instance" "$WOODPECKER_URL" "$WOODPECKER_TOKEN"
|
|
|
|
_mosaic_sync_woodpecker_env "$wp_instance" "$WOODPECKER_URL" "$WOODPECKER_TOKEN"
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
woodpecker)
|
|
|
|
woodpecker)
|
|
|
|
# Resolve default instance, then load it
|
|
|
|
# Resolve default instance, then load it. If WOODPECKER_INSTANCE is set to
|
|
|
|
|
|
|
|
# "mosaic" by a shell/profile but credentials.json still uses the legacy
|
|
|
|
|
|
|
|
# flat .woodpecker.url/.token schema, load the flat credentials instead of
|
|
|
|
|
|
|
|
# failing with "woodpecker.mosaic.url not found".
|
|
|
|
local wp_default
|
|
|
|
local wp_default
|
|
|
|
wp_default="${WOODPECKER_INSTANCE:-$(_mosaic_read_cred '.woodpecker.default')}"
|
|
|
|
wp_default="${WOODPECKER_INSTANCE:-$(_mosaic_read_cred '.woodpecker.default')}"
|
|
|
|
if [[ -z "$wp_default" ]]; then
|
|
|
|
if [[ -z "$wp_default" ]]; then
|
|
|
|
@@ -174,18 +198,18 @@ EOF
|
|
|
|
local legacy_url
|
|
|
|
local legacy_url
|
|
|
|
legacy_url="$(_mosaic_read_cred '.woodpecker.url')"
|
|
|
|
legacy_url="$(_mosaic_read_cred '.woodpecker.url')"
|
|
|
|
if [[ -n "$legacy_url" ]]; then
|
|
|
|
if [[ -n "$legacy_url" ]]; then
|
|
|
|
export WOODPECKER_URL="${WOODPECKER_URL:-$legacy_url}"
|
|
|
|
_mosaic_load_woodpecker_legacy
|
|
|
|
export WOODPECKER_TOKEN="${WOODPECKER_TOKEN:-$(_mosaic_read_cred '.woodpecker.token')}"
|
|
|
|
|
|
|
|
WOODPECKER_URL="${WOODPECKER_URL%/}"
|
|
|
|
|
|
|
|
[[ -n "$WOODPECKER_URL" ]] || { echo "Error: woodpecker.url not found" >&2; return 1; }
|
|
|
|
|
|
|
|
[[ -n "$WOODPECKER_TOKEN" ]] || { echo "Error: woodpecker.token not found" >&2; return 1; }
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
echo "Error: woodpecker.default not set and no WOODPECKER_INSTANCE env var" >&2
|
|
|
|
echo "Error: woodpecker.default not set and no WOODPECKER_INSTANCE env var" >&2
|
|
|
|
echo "Available instances: $(jq -r '.woodpecker | keys | join(", ")' "$MOSAIC_CREDENTIALS_FILE" 2>/dev/null)" >&2
|
|
|
|
echo "Available instances: $(jq -r '.woodpecker | keys | join(", ")' "$MOSAIC_CREDENTIALS_FILE" 2>/dev/null)" >&2
|
|
|
|
return 1
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
else
|
|
|
|
load_credentials "woodpecker-${wp_default}"
|
|
|
|
if [[ "$wp_default" == "mosaic" ]] && [[ -z "$(_mosaic_read_cred '.woodpecker.mosaic.url')" ]] && [[ -n "$(_mosaic_read_cred '.woodpecker.url')" ]]; then
|
|
|
|
|
|
|
|
WOODPECKER_INSTANCE="mosaic" _mosaic_load_woodpecker_legacy
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
load_credentials "woodpecker-${wp_default}"
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
cloudflare-*)
|
|
|
|
cloudflare-*)
|
|
|
|
|