diff options
| author | Andrew Dolgov <fox@fakecake.org> | 2025-05-27 13:36:06 +0300 |
|---|---|---|
| committer | Andrew Dolgov <fox@fakecake.org> | 2025-05-27 13:36:06 +0300 |
| commit | 5372338873e19309a32f8553de6347aece8c051f (patch) | |
| tree | a0e6871022a878c33f7a6ffae2f8d8a0bbb7f2a0 /utils | |
| parent | 9b39aa00412433014a2cb6f1fbfbe96cf577df97 (diff) | |
auto create MR on push into weblate-integration
Diffstat (limited to 'utils')
| -rwxr-xr-x | utils/autoMergeRequest.sh | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/utils/autoMergeRequest.sh b/utils/autoMergeRequest.sh new file mode 100755 index 00000000..bd33db0c --- /dev/null +++ b/utils/autoMergeRequest.sh @@ -0,0 +1,35 @@ +#!/usr/bin/env bash +# Extract the host where the server is running, and add the URL to the APIs +[[ $HOST =~ ^https?://[^/]+ ]] && HOST="${BASH_REMATCH[0]}/api/v4/projects/" + +# Look which is the default branch +TARGET_BRANCH=`curl --silent "${HOST}${CI_PROJECT_ID}" --header "PRIVATE-TOKEN:${PRIVATE_TOKEN}" | python3 -c "import sys, json; print(json.load(sys.stdin)['default_branch'])"`; + +# The description of our new MR, we want to remove the branch after the MR has +# been closed +BODY="{ + \"id\": ${CI_PROJECT_ID}, + \"source_branch\": \"${CI_COMMIT_REF_NAME}\", + \"target_branch\": \"${TARGET_BRANCH}\", + \"remove_source_branch\": true, + \"title\": \"WIP: ${CI_COMMIT_REF_NAME}\", + \"assignee_id\":\"${GITLAB_USER_ID}\" +}"; + +# Require a list of all the merge request and take a look if there is already +# one with the same source branch +LISTMR=`curl --silent "${HOST}${CI_PROJECT_ID}/merge_requests?state=opened" --header "PRIVATE-TOKEN:${PRIVATE_TOKEN}"`; +COUNTBRANCHES=`echo ${LISTMR} | grep -o "\"source_branch\":\"${CI_COMMIT_REF_NAME}\"" | wc -l`; + +# No MR found, let's create a new one +if [ ${COUNTBRANCHES} -eq "0" ]; then + curl -X POST "${HOST}${CI_PROJECT_ID}/merge_requests" \ + --header "PRIVATE-TOKEN:${PRIVATE_TOKEN}" \ + --header "Content-Type: application/json" \ + --data "${BODY}"; + + echo "Opened a new merge request: WIP: ${CI_COMMIT_REF_NAME} and assigned to you"; + exit; +fi + +echo "No new merge request opened"; |