@@ -16,93 +16,76 @@ jobs:
1616      contents : write 
1717      pull-requests : write 
1818    steps :
19-       - id : download-patch 
20-         name : Download patch 
21- 19+       - name : Download patch 
20+ 2221        with :
23-           #  this script copied from
24-           #  https://docs.github.com/en/actions/writing-workflows/choosing-when-your-workflow-runs/events-that-trigger-workflows#using-data-from-the-triggering-workflow
25-           script : | 
26-             let allArtifacts = await github.rest.actions.listWorkflowRunArtifacts({ 
27-                owner: context.repo.owner, 
28-                repo: context.repo.repo, 
29-                run_id: context.payload.workflow_run.id 
30-             }); 
31-             let patchArtifact = allArtifacts.data.artifacts.filter((artifact) => { 
32-               return artifact.name == "patch" 
33-             })[0]; 
34-             if (!patchArtifact) { 
35-               core.info('No patch to apply.'); 
36-               return; 
37-             } 
38-             let download = await github.rest.actions.downloadArtifact({ 
39-                owner: context.repo.owner, 
40-                repo: context.repo.repo, 
41-                artifact_id: patchArtifact.id, 
42-                archive_format: 'zip' 
43-             }); 
44-             const fs = require('fs'); 
45-             const path = require('path'); 
46-             const temp = '${{ runner.temp }}/artifacts'; 
47-             if (!fs.existsSync(temp)){ 
48-               fs.mkdirSync(temp); 
49-             } 
50-             fs.writeFileSync(path.join(temp, 'patch.zip'), Buffer.from(download.data)); 
51-             core.setOutput("exists", "true"); 
22+           run-id : ${{ github.event.workflow_run.id }} 
23+           name : patch 
24+           path : ${{ runner.temp }} 
25+ 
26+       - id : unzip-patch 
27+         name : Unzip patch 
28+         working-directory : ${{ runner.temp }} 
29+         run : | 
30+           if [ -f patch.zip ]; then 
31+             unzip patch.zip 
32+             echo "exists=true" >> $GITHUB_OUTPUT 
33+           fi 
5234
5335id : get-pr-number 
36+         if : steps.unzip-patch.outputs.exists == 'true' 
5437        name : Get PR number 
55- 56-         with : 
57-           script :  | 
58-             const response = await  github.request(context.payload. workflow_run.url);  
59-             core.setOutput('pr-number ', response.data.pull_requests[0].number);  
60- 
61- -  name :  Unzip patch 
62-         if :  steps.download-patch.outputs.exists == 'true' 
63-         working-directory :  ${{ runner.temp }}/artifacts 
64-         run :  unzip patch.zip 
38+         env : 
39+            PR_BRANCH :  |- 
40+             ${{  
41+               (github.event.workflow_run.head_repository.owner.login !=  github.event. workflow_run.repository.owner.login)  
42+                 && format('{0}:{1} ', github.event.workflow_run.head_repository.owner.login, github.event.workflow_run.head_branch)  
43+                 || github.event.workflow_run.head_branch 
44+             }}  
45+    GH_TOKEN :  ${{ github.token }} 
46+         run :  | 
47+           gh pr view "${PR_BRANCH}" --json 'number' --jq '"pr-number=\(.number)' >> $GITHUB_OUTPUT  
6548
6649uses : actions/create-github-app-token@df432ceedc7162793a195dd1713ff69aefc7379e  #  v2.0.6
67-         if : steps.download -patch.outputs.exists == 'true' 
50+         if : steps.unzip -patch.outputs.exists == 'true' 
6851        id : otelbot-token 
6952        with :
7053          app-id : 1295839 
71-           private-key : ${{ secrets.OTELBOT_JAVA_CONTRIB_PRIVATE_KEY  }} 
54+           private-key : ${{ secrets.OTELBOT_JAVA_INSTRUMENTATION_PRIVATE_KEY  }} 
7255
7356      - uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683  #  v4.2.2
74-         if : steps.download -patch.outputs.exists == 'true' 
57+         if : steps.unzip -patch.outputs.exists == 'true' 
7558        with :
7659          token : ${{ steps.otelbot-token.outputs.token }} 
7760
7861      - name : Check out PR branch 
79-         if : steps.download -patch.outputs.exists == 'true' 
62+         if : steps.unzip -patch.outputs.exists == 'true' 
8063        env :
8164          GH_TOKEN : ${{ github.token }} 
8265        run : gh pr checkout ${{ steps.get-pr-number.outputs.pr-number }} 
8366
8467      - name : Use CLA approved github bot 
85-         if : steps.download -patch.outputs.exists == 'true' 
68+         if : steps.unzip -patch.outputs.exists == 'true' 
8669        #  IMPORTANT do not call the .github/scripts/use-cla-approved-bot.sh
8770        #  since that script could have been compromised in the PR branch
8871        run : | 
8972          git config user.name otelbot 
9073          git config user.email [email protected]  9174
9275name : Apply patch and push 
93-         if : steps.download -patch.outputs.exists == 'true' 
76+         if : steps.unzip -patch.outputs.exists == 'true' 
9477        run : | 
95-           git apply "${{ runner.temp }}/artifacts/ patch" 
78+           git apply "${{ runner.temp }}/patch" 
9679          git commit -a -m "./gradlew spotlessApply" 
9780          git push 
9881
99- if : steps.download -patch.outputs.exists == 'true' && success() 
82+ if : steps.unzip -patch.outputs.exists == 'true' && success() 
10083        env :
10184          GH_TOKEN : ${{ steps.otelbot-token.outputs.token }} 
10285        run : | 
10386          gh pr comment ${{ steps.get-pr-number.outputs.pr-number }} --body "🔧 The result from spotlessApply was committed to the PR branch." 
10487
105- if : steps.download -patch.outputs.exists == 'true' && failure() 
88+ if : steps.unzip -patch.outputs.exists == 'true' && failure() 
10689        env :
10790          GH_TOKEN : ${{ steps.otelbot-token.outputs.token }} 
10891        run : | 
0 commit comments