Skip to content

Update bytebase-sql-review.yml #7

Update bytebase-sql-review.yml

Update bytebase-sql-review.yml #7

on: [pull_request]
jobs:
bytebase-sql-review:
runs-on: ubuntu-latest
name: SQL Review
steps:
- name: SQL advise
run: |
API="https://demo.bytebase.com/hook/sql-review/6c86d081-379d-4366-be6f-481425e6f397-1699027458"
TOKEN="${{ secrets.SQL_REVIEW_API_SECRET }}"
echo "Start request $API"
pull_number=$(jq --raw-output .pull_request.number "$GITHUB_EVENT_PATH")
repository=`echo $GITHUB_REPOSITORY`
request_body=$(jq -n \
--arg repositoryId "$repository" \
--arg pullRequestId $pull_number \
--arg webURL "$GITHUB_SERVER_URL" \
'$ARGS.named')
response=$(curl -s -w "%{http_code}" -X POST $API \
-H "X-SQL-Review-Token: $TOKEN" \
-H "Content-Type: application/json" \
-d "$request_body")
echo "::debug::response $response"
http_code=$(tail -n1 <<< "$response")
body=$(sed '$ d' <<< "$response")
if [ $http_code != 200 ]; then
echo ":error::Failed to check SQL with response code $http_code and body $body"
exit 1
fi
status=$(echo $body | jq -r '.status')
content=$(echo $body | jq -r '.content')
while read message; do
echo $message
done <<< "$(echo $content | jq -r '.[]')"
if [ "$status" == "ERROR" ]; then exit 1; fi