forked from epam/ai-dial-ci
-
Notifications
You must be signed in to change notification settings - Fork 1
96 lines (92 loc) · 4.43 KB
/
deploy-review-command.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
name: deploy-review-command
on:
repository_dispatch:
types: [deploy-review-command]
jobs:
deploy-review:
runs-on: ubuntu-latest
steps:
- name: Check repository owner
id: owner
run: |
DISPATCHED_REPO_NAME=${{ github.event.client_payload.github.payload.repository.name }}
DISPATCHED_REPO_OWNER=${{ github.event.client_payload.github.payload.repository.owner.login }}
ERROR_MESSAGE=""
if [[ "$DISPATCHED_REPO_OWNER" != "$GITHUB_REPOSITORY_OWNER" ]]; then
ERROR_MESSAGE="The event was not dispatched by a repository within the same owner."
fi
if [[ "$DISPATCHED_REPO_NAME" != ai-dial* ]]; then
ERROR_MESSAGE+=" The repository name does not start with 'ai-dial'."
fi
if [[ -n "$ERROR_MESSAGE" ]]; then
echo "status=$ERROR_MESSAGE" >> $GITHUB_OUTPUT
exit 1
fi
echo "All checks passed."
- name: Checks and transformations
id: vars
run: |
ERROR_MESSAGE=""
if [[ -z "${{ github.event.client_payload.slash_command.args.named.application }}" ]]; then
ERROR_MESSAGE="The 'application' argument is missing."
fi
if [[ -z "${{ github.event.client_payload.pull_request.number }}" ]]; then
ERROR_MESSAGE+=" Pull request number is missing."
fi
if [[ -z "${{ github.event.client_payload.pull_request.head.repo.full_name }}" ]]; then
ERROR_MESSAGE+=" Pull request head repo full name is missing."
fi
if [[ -z "${{ github.event.client_payload.pull_request.head.ref }}" ]]; then
ERROR_MESSAGE+=" Pull request head ref is missing."
fi
if [[ -n "$ERROR_MESSAGE" ]]; then
echo "status=$ERROR_MESSAGE" >> $GITHUB_OUTPUT
exit 1
fi
echo "All required values are present."
- name: Deploy environment
id: deploy
uses: digital-blueprint/gitlab-pipeline-trigger-action@7fef6b4967aef68a1671ccf42a6e45f7a27487d8 # v1.2.0
with:
host: ${{ secrets.DEPLOY_HOST }}
trigger_token: ${{ secrets.DEPLOY_TRIGGER_TOKEN }}
access_token: ${{ secrets.DEPLOY_ACCESS_TOKEN }}
id: ${{ secrets.DEPLOY_PROJECT_ID }}
ref: ${{ secrets.DEPLOY_REF }}
variables: >
{
"GITHUB_APP":"${{ github.event.client_payload.slash_command.args.named.application }}",
"GITHUB_PR":"pr-${{ github.event.client_payload.pull_request.number }}",
"GITHUB_REPO":"${{ github.event.client_payload.pull_request.head.repo.full_name }}",
"GITHUB_REF":"${{ github.event.client_payload.pull_request.head.ref }}",
"GITHUB_TRIGGER": "${{ github.event.client_payload.github.payload.comment.html_url }}"
}
- name: Check status
id: status
if: success() || failure()
run: |
GITHUB_WORKFLOW_URL=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID
GITLAB_PIPELINE_URL=${{ steps.deploy.outputs.web_url }}
MESSAGE=""
if [[ -n "${{ steps.owner.outputs.status }}" ]]; then
MESSAGE+=">- **Owner check failed**: ${{ steps.owner.outputs.status }}\n"
fi
if [[ -n "${{ steps.vars.outputs.status }}" ]]; then
MESSAGE+=">- **Vars check failed**: ${{ steps.vars.outputs.status }}\n"
fi
if [[ -n "${{ steps.deploy.outputs.status }}" && "${{ steps.deploy.outputs.status }}" != "success" ]]; then
MESSAGE+=">- **Deployment failed**: [${{ steps.deploy.outputs.status }}](${GITLAB_PIPELINE_URL})\n"
fi
if [[ -z "${{ steps.owner.outputs.status }}" && -z "${{ steps.vars.outputs.status }}" && -z "${{ steps.deploy.outputs.status }}" ]]; then
MESSAGE+=">Something went wrong, check [GitHub Workflow run output](${GITHUB_WORKFLOW_URL})\n"
fi
echo -e "message=$MESSAGE" >> $GITHUB_OUTPUT
- name: Return status
if: success() || failure()
uses: peter-evans/create-or-update-comment@71345be0265236311c031f5c7866368bd1eff043 # v4.0.0
with:
token: ${{ secrets.ACTIONS_BOT_TOKEN }}
repository: ${{ github.event.client_payload.github.payload.repository.full_name }}
comment-id: ${{ github.event.client_payload.github.payload.comment.id }}
body: |
${{ steps.status.outputs.message }}