You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DevOps-Bash-tools/bitbucket_api.sh

132 lines
3.5 KiB
Bash

#!/usr/bin/env bash
# vim:ts=4:sts=4:sw=4:et
#
# Author: Hari Sekhon
# Date: 2020-08-16 19:45:46 +0100 (Sun, 16 Aug 2020)
#
# 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
#
# args: /user | jq .
# args: /workspaces | jq .
# args: /repositories/harisekhon | jq .
# args: /repositories/harisekhon/devops-bash-tools/pipelines/ | jq .
# args: /repositories/harisekhon/devops-bash-tools -X PUT -H 'Content-Type: application/json' -d '{"description": "some words"}'
set -euo pipefail
[ -n "${DEBUG:-}" ] && set -x
srcdir="$(dirname "$0")"
# shellcheck disable=SC1090
. "$srcdir/lib/utils.sh"
# shellcheck disable=SC1090
. "$srcdir/lib/git.sh"
# shellcheck disable=SC2034,SC2154
usage_description="
Queries the BitBucket.org API
Can specify \$CURL_OPTS for options to pass to curl, or pass them as arguments to the script
Automatically handles authentication via environment variables \$BITBUCKER_USER and \$BITBUCKET_TOKEN
If either of these are not found, tries to infer from local git repo's bitbucket remotes
You must set up a personal access token here:
https://bitbucket.org/account/settings/app-passwords/
API Reference:
https://developer.atlassian.com/bitbucket/api/2/reference/
https://developer.atlassian.com/bitbucket/api/2/reference/resource/
Examples:
# Get currently authenticated user:
${0##*/} /user
# Get currently authenticated user's workspaces:
${0##*/} /workspaces
# Get repos in given workspace:
${0##*/} /repositories/harisekhon
# Get a repo's BitBucket Pipelines [oldest first] (must have a slash on the end otherwise gets 404 error):
${0##*/} /repositories/harisekhon/devops-bash-tools/pipelines/
# Update a repo's description:
${0##*/} /repositories/harisekhon/devops-bash-tools -X PUT -H 'Content-Type: application/json' -d '{\"description\": \"some words\"}'
"
# used by usage() in lib/utils.sh
# shellcheck disable=SC2034
usage_args="/path [<curl_options>]"
url_base="https://api.bitbucket.org/2.0"
CURL_OPTS="-sS --fail --connect-timeout 3 ${CURL_OPTS:-}"
help_usage "$@"
min_args 1 "$@"
user="${BITBUCKET_USER:-}"
PASSWORD="${BITBUCKET_PASSWORD:-${BITBUCKET_TOKEN:-}}"
if [ -z "${BITBUCKET_USER:-}" ]; then
user="$(git remote -v 2>/dev/null | awk '/https:\/\/.+@bitbucket\.org/{print $2; exit}' | sed 's|https://||;s/@.*//;s/:.*//' || :)"
# curl_auth.sh does this automatically
#if [ -z "$user" ]; then
# user="${USERNAME:${USER:-}}"
#fi
fi
if [ -z "${PASSWORD:-}" ]; then
# if this is still blank then curl_auth.sh will detect and prompt for a password (non echo'd)
PASSWORD="$(git remote -v 2>/dev/null | awk '/https:\/\/.+@bitbucket\.org/{print $2; exit}' | sed 's|https://||;s/@.*//;s/.*://' || :)"
fi
if [ -n "$user" ]; then
export USER="$user"
fi
export PASSWORD
url_path="${1:-}"
url_path="${url_path##*:\/\/bitbucket.org\/api\/v4}"
url_path="${url_path##/}"
shift
repo=$(git_repo 2>/dev/null | sed 's/.*\///' || :)
#url_path="${url_path/:owner/$USER}"
#url_path="${url_path/:user/$USER}"
#url_path="${url_path/:username/$USER}"
#url_path="${url_path/<user>/$USER}"
#url_path="${url_path/<username>/$USER}"
#url_path="${url_path/:repo/$repo}"
#url_path="${url_path/<repo>/$repo}"
# need CURL_OPTS splitting, safer than eval
# shellcheck disable=SC2086
"$srcdir/curl_auth.sh" ${CURL_OPTS:-} "$url_base/$url_path" "$@"