solidity/scripts/ci/notification/matrix_notification.sh
Rodrigo Q. Saramago 58555db423
Fix text formatting of CI matrix notifications
Co-authored-by: Kamil Śliwak <kamil.sliwak@codepoets.it>
2023-04-19 01:09:08 +02:00

83 lines
3.2 KiB
Bash
Executable File

#!/bin/bash
set -euo pipefail
shopt -s inherit_errexit
SCRIPT_DIR="$(dirname "$0")"
function fail() {
printf '%s\n' "$1" >&2
exit 1
}
function notify() {
[[ -z "$1" ]] && fail "Event type not provided."
[[ "$1" != "failure" && "$1" != "success" && "$1" != "release" ]] && fail "Wrong event type."
local event="$1"
local formatted_message
# FIXME: Checking $CIRCLE_PULL_REQUEST would be better than hard-coding branch names
# but it's broken. CircleCI associates runs on develop/breaking with random old PRs.
[[ "$BRANCH" == "develop" || "$BRANCH" == "breaking" ]] || { echo "Running on a PR or a feature branch - notification skipped."; exit 0; }
# The release notification only makes sense on tagged commits. If the commit is untagged, just bail out.
[[ "$event" == "release" ]] && { [[ $TAG != "" ]] || { echo "Not a tagged commit - notification skipped."; exit 0; } }
formatted_message="$(format_predefined_message "$event")"
curl "https://${MATRIX_SERVER}/_matrix/client/v3/rooms/${MATRIX_NOTIFY_ROOM_ID}/send/m.room.message" \
--request POST \
--include \
--header "Content-Type: application/json" \
--header "Accept: application/json" \
--header "Authorization: Bearer ${MATRIX_ACCESS_TOKEN}" \
--data "$formatted_message"
}
function circleci_workflow_name() {
# Workflow name is not exposed as an env variable. Has to be queried from the API.
# The name is not critical so if anything fails, use the raw workflow ID as a fallback.
local workflow_info
workflow_info=$(curl --silent "https://circleci.com/api/v2/workflow/${CIRCLE_WORKFLOW_ID}") || true
echo "$workflow_info" | grep -E '"\s*name"\s*:\s*".*"' | cut -d \" -f 4 || echo "$CIRCLE_WORKFLOW_ID"
}
function circleci_job_name() {
(( CIRCLE_NODE_TOTAL == 1 )) && echo "${CIRCLE_JOB}" && return
(( CIRCLE_NODE_TOTAL != 1 )) && echo "${CIRCLE_JOB} (run $((CIRCLE_NODE_INDEX + 1))/${CIRCLE_NODE_TOTAL})"
}
# Currently matrix only supports html formatted body,
# see: https://spec.matrix.org/v1.6/client-server-api/#mtext
#
# Eventually, the matrix api will have support for better format options and `formatted_body` may not be necessary anymore:
# https://github.com/matrix-org/matrix-spec-proposals/pull/1767
function format_predefined_message() {
[[ -z "$1" ]] && fail "Event type not provided."
local event="$1"
local template
[[ "$event" == "failure" ]] && template="${SCRIPT_DIR}/templates/build_fail.json"
[[ "$event" == "success" ]] && template="${SCRIPT_DIR}/templates/build_success.json"
[[ "$event" == "release" ]] && template="${SCRIPT_DIR}/templates/build_release.json"
[[ -z "$template" ]] && fail "Message template for event [$event] not defined."
# Export variables that must be substituted
export WORKFLOW_NAME JOB BRANCH TAG BUILD_URL BUILD_NUM
envsubst < "$template"
unset WORKFLOW_NAME JOB BRANCH TAG BUILD_URL BUILD_NUM
}
# Set message environment variables based on CI backend
if [[ "$CIRCLECI" = true ]] ; then
BRANCH="$CIRCLE_BRANCH"
TAG="$CIRCLE_TAG"
BUILD_URL="$CIRCLE_BUILD_URL"
BUILD_NUM="$CIRCLE_BUILD_NUM"
WORKFLOW_NAME="$(circleci_workflow_name)"
JOB="$(circleci_job_name)"
fi
notify "$@"