switch to session
This commit is contained in:
parent
2c27425b02
commit
a9404fdc57
1 changed files with 24 additions and 6 deletions
30
.github/workflows/update.yml
vendored
30
.github/workflows/update.yml
vendored
|
|
@ -72,12 +72,28 @@ jobs:
|
||||||
--base main \
|
--base main \
|
||||||
--head ${{ env.BRANCH_NAME }}
|
--head ${{ env.BRANCH_NAME }}
|
||||||
|
|
||||||
|
- name: Get Hydra session token
|
||||||
|
id: hydra-session
|
||||||
|
run: |
|
||||||
|
response=$(curl -X POST -i \
|
||||||
|
'${{ env.HYDRA_INSTANCE }}/login' \
|
||||||
|
-H 'accept: application/json' \
|
||||||
|
-H 'Content-Type: application/json' \
|
||||||
|
-H 'Origin: ${{ env.HYDRA_INSTANCE }}' \
|
||||||
|
-d '{
|
||||||
|
"username": "${{ secrets.HYDRA_USERNAME }}",
|
||||||
|
"password": "${{ secrets.HYDRA_PASSWORD }}"
|
||||||
|
}')
|
||||||
|
session_cookie=$(echo "$response" | grep -i 'set-cookie' | sed -n 's/.*hydra_session=\([^;]*\).*/\1/p')
|
||||||
|
echo "SESSION_COOKIE=$session_cookie" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Create Hydra jobset
|
- name: Create Hydra jobset
|
||||||
if: steps.update-flake.outputs.CHANGED == 'true'
|
if: steps.update-flake.outputs.CHANGED == 'true'
|
||||||
|
env:
|
||||||
|
SESSION_COOKIE: ${{ steps.hydra-session.outputs.SESSION_COOKIE }}
|
||||||
run: |
|
run: |
|
||||||
AUTH_HEADER="Authorization: Basic $(echo -n '${{ secrets.HYDRA_USERNAME }}:${{ secrets.HYDRA_PASSWORD }}' | base64)"
|
|
||||||
curl -X PUT -H "Content-Type: application/json" \
|
curl -X PUT -H "Content-Type: application/json" \
|
||||||
-H "$AUTH_HEADER" \
|
-H "Cookie: hydra_session=$SESSION_COOKIE" \
|
||||||
-d '{
|
-d '{
|
||||||
"enabled": 1,
|
"enabled": 1,
|
||||||
"visible": true,
|
"visible": true,
|
||||||
|
|
@ -92,10 +108,11 @@ jobs:
|
||||||
|
|
||||||
- name: Trigger Hydra build
|
- name: Trigger Hydra build
|
||||||
if: steps.update-flake.outputs.CHANGED == 'true'
|
if: steps.update-flake.outputs.CHANGED == 'true'
|
||||||
|
env:
|
||||||
|
SESSION_COOKIE: ${{ steps.hydra-session.outputs.SESSION_COOKIE }}
|
||||||
run: |
|
run: |
|
||||||
AUTH_HEADER="Authorization: Basic $(echo -n '${{ secrets.HYDRA_USERNAME }}:${{ secrets.HYDRA_PASSWORD }}' | base64)"
|
|
||||||
curl -X POST -H "Content-Type: application/json" \
|
curl -X POST -H "Content-Type: application/json" \
|
||||||
-H "$AUTH_HEADER" \
|
-H "Cookie: hydra_session=$SESSION_COOKIE" \
|
||||||
-H "Origin: ${{ env.HYDRA_INSTANCE }}" \
|
-H "Origin: ${{ env.HYDRA_INSTANCE }}" \
|
||||||
-d '{"jobsets": ["${{ env.HYDRA_PROJECT }}:${{ env.HYDRA_JOBSET }}"]}' \
|
-d '{"jobsets": ["${{ env.HYDRA_PROJECT }}:${{ env.HYDRA_JOBSET }}"]}' \
|
||||||
"${{ env.HYDRA_INSTANCE }}/api/push"
|
"${{ env.HYDRA_INSTANCE }}/api/push"
|
||||||
|
|
@ -103,12 +120,13 @@ jobs:
|
||||||
- name: Wait for Hydra build
|
- name: Wait for Hydra build
|
||||||
if: steps.update-flake.outputs.CHANGED == 'true'
|
if: steps.update-flake.outputs.CHANGED == 'true'
|
||||||
id: wait-for-build
|
id: wait-for-build
|
||||||
|
env:
|
||||||
|
SESSION_COOKIE: ${{ steps.hydra-session.outputs.SESSION_COOKIE }}
|
||||||
run: |
|
run: |
|
||||||
AUTH_HEADER="Authorization: Basic $(echo -n '${{ secrets.HYDRA_USERNAME }}:${{ secrets.HYDRA_PASSWORD }}' | base64)"
|
|
||||||
max_attempts=60 # 30 minutes (30 * 2 minutes)
|
max_attempts=60 # 30 minutes (30 * 2 minutes)
|
||||||
attempt=0
|
attempt=0
|
||||||
while [ $attempt -lt $max_attempts ]; do
|
while [ $attempt -lt $max_attempts ]; do
|
||||||
response=$(curl -s -H "$AUTH_HEADER" \
|
response=$(curl -s -H "Cookie: hydra_session=$SESSION_COOKIE" \
|
||||||
"${{ env.HYDRA_INSTANCE }}/api/jobsets?project=${{ env.HYDRA_PROJECT }}")
|
"${{ env.HYDRA_INSTANCE }}/api/jobsets?project=${{ env.HYDRA_PROJECT }}")
|
||||||
status=$(echo "$response" | jq -r '.[] | select(.name == "${{ env.HYDRA_JOBSET }}") | .nrfailed')
|
status=$(echo "$response" | jq -r '.[] | select(.name == "${{ env.HYDRA_JOBSET }}") | .nrfailed')
|
||||||
if [ "$status" = "0" ]; then
|
if [ "$status" = "0" ]; then
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue