|
| 1 | +#!/bin/sh |
| 2 | + |
| 3 | +echo "**** ***** Running Radicle CI Hook ***** ****" |
| 4 | + |
| 5 | +if [ -f "$GIT_PROJECT_ROOT/etc/.ci.env" ]; then |
| 6 | + . "$GIT_PROJECT_ROOT/etc/.ci.env" |
| 7 | +fi |
| 8 | + |
| 9 | +run_pipeline() { |
| 10 | + local tag=$(echo $GIT_NAMESPACE | cut -c 31-) |
| 11 | + local urn="$RADICLE_NAME-$tag" |
| 12 | + # login |
| 13 | + fly -t local login -c $CONCOURSE_URL -u $CONCOURSE_USER -p $CONCOURSE_PASS |
| 14 | + # create pipeline |
| 15 | + if [ -f "$GIT_PROJECT_ROOT/secrets/$GIT_NAMESPACE.yml" ]; then |
| 16 | + fly -t local validate-pipeline -c /tmp/$GIT_NAMESPACE/.rad/concourse.yml |
| 17 | + fly -t local set-pipeline -p $urn -c /tmp/$GIT_NAMESPACE/.rad/concourse.yml --non-interactive -l $GIT_PROJECT_ROOT/secrets/$GIT_NAMESPACE.yml > /dev/null |
| 18 | + else |
| 19 | + fly -t local set-pipeline -p $urn -c /tmp/$GIT_NAMESPACE/.rad/concourse.yml --non-interactive |
| 20 | + fi |
| 21 | + # unpause pipeline |
| 22 | + fly -t local unpause-pipeline -p $urn |
| 23 | + # trigger a job |
| 24 | + # TODO: trigger all jobs |
| 25 | + fly -t local trigger-job --job $urn/job |
| 26 | +} |
| 27 | + |
| 28 | +delete_team() { |
| 29 | + local tag=$(echo $GIT_NAMESPACE | cut -c 31-) |
| 30 | + local urn="$RADICLE_NAME-$tag" |
| 31 | + # login |
| 32 | + fly -t local login -c $CONCOURSE_URL -u $CONCOURSE_USER -p $CONCOURSE_PASS |
| 33 | + # destroy pipeline |
| 34 | + fly -t local destroy-pipeline -p $urn -n |
| 35 | +} |
| 36 | + |
| 37 | +check_ci_deletion() { |
| 38 | + local urn=$1 |
| 39 | + local commit=$2 |
| 40 | + local branch=$3 |
| 41 | + # initial commit has prev_commit as 00..00 |
| 42 | + if [ "$commit" = "0000000000000000000000000000000000000000" ]; then |
| 43 | + return; |
| 44 | + fi |
| 45 | + |
| 46 | + # checkout into that commit |
| 47 | + unset GIT_DIR && cd /tmp/$urn && git checkout $commit -f -q |
| 48 | + |
| 49 | + if [ -f "/tmp/$urn/.rad/concourse.yml" ]; then |
| 50 | + echo "ci yml was deleted in this commit" |
| 51 | + delete_team $urn |
| 52 | + fi |
| 53 | + |
| 54 | + # revert checkout |
| 55 | + unset GIT_DIR && cd /tmp/$urn && git checkout $branch -f |
| 56 | +} |
| 57 | + |
| 58 | +clone_or_pull() { |
| 59 | + local urn=$GIT_NAMESPACE |
| 60 | + if [ -e "/tmp/$urn" ]; then |
| 61 | + echo "pulling..." |
| 62 | + unset GIT_DIR && cd /tmp/$urn && git pull -f --rebase |
| 63 | + else |
| 64 | + echo "cloning..." |
| 65 | + git clone $GIT_DIR /tmp/$urn |
| 66 | + fi |
| 67 | +} |
| 68 | + |
| 69 | +while read line |
| 70 | +do |
| 71 | + echo "stdin: $line" |
| 72 | + urn=$GIT_NAMESPACE |
| 73 | + prev_commit=$(echo $line | cut -d' ' -f2) |
| 74 | + branch=$(echo $line | cut -d' ' -f4) |
| 75 | + echo "urn: $urn, project: $RADICLE_NAME, prev_commit: $prev_commit, branch: $branch" |
| 76 | + |
| 77 | + # clone the project locally in /tmp |
| 78 | + clone_or_pull |
| 79 | + |
| 80 | + default_branch=$(GIT_DIR=/tmp/$urn/.git git symbolic-ref --short refs/remotes/origin/HEAD) |
| 81 | + # remove the `origin` part |
| 82 | + default_branch=$(echo $default_branch | cut -c 8-) |
| 83 | + |
| 84 | + if [ "$branch" != "$default_branch" ]; then |
| 85 | + echo "skpping, only running on pushes to branch $default_branch" |
| 86 | + continue |
| 87 | + fi |
| 88 | + |
| 89 | + # check for .rad/concourse.yml |
| 90 | + if [ -f "/tmp/$urn/.rad/concourse.yml" ]; then |
| 91 | + echo "yml exists." |
| 92 | + run_pipeline |
| 93 | + else |
| 94 | + echo "yml does not exist." |
| 95 | + check_ci_deletion $urn $prev_commit $branch |
| 96 | + exit 0 |
| 97 | + fi |
| 98 | + |
| 99 | +done |
| 100 | + |
| 101 | +echo "Exiting..." |
| 102 | +exit 0 |
0 commit comments