|
| 1 | +name: 'Continuous Auth Publish Action' |
| 2 | +description: 'Publish a semantic release npm package via CFA' |
| 3 | +inputs: |
| 4 | + project-id: |
| 5 | + description: 'CFA_PROJECT_ID secret value' |
| 6 | + required: true |
| 7 | + secret: |
| 8 | + description: 'CFA_SECRET secret value' |
| 9 | + required: true |
| 10 | + npm-token: |
| 11 | + description: 'NPM_TOKEN secret value' |
| 12 | + required: true |
| 13 | +runs: |
| 14 | + using: "composite" |
| 15 | + steps: |
| 16 | + - name: Set up publishing environment |
| 17 | + run: | |
| 18 | + SHA=1775eb1aacafd0266ea1897255758d985d0bf291 |
| 19 | + DIR=/tmp/semantic-release-packages |
| 20 | + mkdir $DIR |
| 21 | + cp ${{ github.action_path }}/package.json $DIR/package.json |
| 22 | + cp ${{ github.action_path }}/package-lock.json $DIR/package-lock.json |
| 23 | + cd $DIR |
| 24 | + npm ci |
| 25 | + echo "$DIR/node_modules/.bin" >> "$GITHUB_PATH" |
| 26 | + shell: bash |
| 27 | + |
| 28 | + - name: Obtain OIDC token |
| 29 | + id: oidc |
| 30 | + run: | |
| 31 | + token=$(curl --fail -H "Authorization: bearer $ACTIONS_ID_TOKEN_REQUEST_TOKEN" \ |
| 32 | + "$ACTIONS_ID_TOKEN_REQUEST_URL&audience=continuousauth.dev" | jq -r '.value') |
| 33 | + echo "::add-mask::${token}" |
| 34 | + echo "token=${token}" >> $GITHUB_OUTPUT |
| 35 | + shell: bash |
| 36 | + |
| 37 | + - name: Obtain GitHub credentials |
| 38 | + id: github_creds |
| 39 | + run: | |
| 40 | + token=$(curl --fail "https://continuousauth.dev/api/request/${{ inputs.project-id }}/github/credentials" \ |
| 41 | + -X POST \ |
| 42 | + -H "Content-Type: application/json" \ |
| 43 | + -H "Authorization: bearer ${{ inputs.secret }}" \ |
| 44 | + --data "{\"token\":\"${{ steps.oidc.outputs.token }}\"}" | jq -r '.GITHUB_TOKEN') |
| 45 | + echo "::add-mask::${token}" |
| 46 | + echo "token=${token}" >> $GITHUB_OUTPUT |
| 47 | + shell: bash |
| 48 | + |
| 49 | + - name: Run semantic release |
| 50 | + run: semantic-release |
| 51 | + shell: bash |
| 52 | + env: |
| 53 | + GITHUB_ACTION: 1 |
| 54 | + GITHUB_TOKEN: ${{ steps.github_creds.outputs.token }} |
| 55 | + CFA_PROJECT_ID: ${{ inputs.project-id }} |
| 56 | + CFA_SECRET: ${{ inputs.secret }} |
| 57 | + NPM_TOKEN: ${{ inputs.npm-token }} |
0 commit comments