added teamcity_upload_ssh_key.sh
parent
a3e9e15fa0
commit
32648877a3
@ -0,0 +1,98 @@
|
||||
#!/usr/bin/env bash
|
||||
# vim:ts=4:sts=4:sw=4:et
|
||||
#
|
||||
# Author: Hari Sekhon
|
||||
# Date: 2021-01-11 13:14:37 +0000 (Mon, 11 Jan 2021)
|
||||
#
|
||||
# https://github.com/HariSekhon/bash-tools
|
||||
#
|
||||
# License: see accompanying Hari Sekhon LICENSE file
|
||||
#
|
||||
# If you're using my code you're welcome to connect with me on LinkedIn and optionally send me feedback to help steer this or other code I publish
|
||||
#
|
||||
# https://www.linkedin.com/in/HariSekhon
|
||||
#
|
||||
|
||||
set -euo pipefail
|
||||
[ -n "${DEBUG:-}" ] && set -x
|
||||
srcdir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
|
||||
# shellcheck disable=SC1090
|
||||
. "$srcdir/lib/utils.sh"
|
||||
|
||||
# shellcheck disable=SC2034,SC2154
|
||||
usage_description="
|
||||
Uploads SSH private key to TeamCity via the Web UI
|
||||
|
||||
There's no TeamCity Rest API support for SSH key management at the time of writing so this script posts to the Web UI :'-(
|
||||
|
||||
If no project is specified as the 3rd arg, uploads to the Root project:
|
||||
|
||||
\$TEAMCITY_URL/admin/editProject.html?projectId=_Root&tab=ssh-manager#
|
||||
|
||||
|
||||
This is useful for (re)connecting VCS configurations using SSH auth which can be used to load entire teamcity projects
|
||||
|
||||
|
||||
Idempotent - if the named SSH key already exists, will replace it and exit with success code zero
|
||||
"
|
||||
|
||||
# used by usage() in lib/utils.sh
|
||||
# shellcheck disable=SC2034
|
||||
usage_args="<key_file> [<key_name> <teamcity_project_id>]"
|
||||
|
||||
help_usage "$@"
|
||||
|
||||
min_args 1 "$@"
|
||||
|
||||
ssh_private_key="$1"
|
||||
|
||||
name="${2:-${ssh_private_key##*/}}"
|
||||
|
||||
# defaults to the Root project because this is the best place to use external VCS connections and auth from, to prevent them being reset and broken by import from VCS which by default excludes secrets
|
||||
project_id="${3:-_Root}"
|
||||
|
||||
url_path=""
|
||||
|
||||
if [ -n "${TEAMCITY_URL:-}" ]; then
|
||||
url_base="${TEAMCITY_URL%%/}"
|
||||
else
|
||||
protocol="http"
|
||||
if [ -n "${TEAMCITY_SSL:-}" ]; then
|
||||
protocol="https"
|
||||
fi
|
||||
[ -n "${TEAMCITY_HOST:-}" ] || usage "neither \$TEAMCITY_URL nor \$TEAMCITY_HOST defined in environment"
|
||||
host="$TEAMCITY_HOST"
|
||||
port="${TEAMCITY_PORT:-8111}"
|
||||
url_base="$protocol://$host:$port"
|
||||
fi
|
||||
|
||||
teamcity_curl_auth(){
|
||||
local url_path="$1"
|
||||
shift || :
|
||||
local curl_opts=(-sS --fail --connect-timeout 5)
|
||||
# use superuser token override to support teamcity.sh when token has already been created but we cannot get it's key value out of the API, so need to continue using superuser token
|
||||
if [ -n "${TEAMCITY_SUPERUSER_TOKEN:-}" ]; then
|
||||
# XXX: superuser token can only be used with blank user which cannot be used with curl_auth.sh
|
||||
curl -u ":$TEAMCITY_SUPERUSER_TOKEN" "$url_base/$url_path" "${curl_opts[@]}" "$@"
|
||||
else
|
||||
"$srcdir/curl_auth.sh" "$url_base/$url_path" "${curl_opts[@]}" "$@"
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
timestamp "Uploading TeamCity SSH key '$ssh_private_key' to project '$project_id' to TeamCity server at '$url_base'"
|
||||
output="$(teamcity_curl_auth /admin/sshKeys.html -X POST \
|
||||
-F "action=createSshKey" \
|
||||
-F "projectId=$project_id" \
|
||||
-F "fileName=$name" \
|
||||
-F "file:fileToUpload=@$ssh_private_key"
|
||||
)"
|
||||
echo
|
||||
if grep -i error <<< "$output"; then
|
||||
echo
|
||||
timestamp "ERROR: TeamCity SSH key upload FAILED"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
timestamp "TeamCity SSH key '$name' created in '$project_id' project"
|
Loading…
Reference in New Issue