name: License Report Workflow on: push: branches: - main paths: - "build.gradle" permissions: contents: read jobs: generate-license-report: runs-on: ubuntu-latest permissions: contents: write pull-requests: write steps: - name: Harden Runner uses: step-security/harden-runner@c6295a65d1254861815972266d5933fd6e532bdf # v2.11.1 with: egress-policy: audit - name: Generate GitHub App Token id: generate-token uses: actions/create-github-app-token@3ff1caaa28b64c9cc276ce0a02e2ff584f3900c5 # v2.0.2 with: app-id: ${{ secrets.GH_APP_ID }} private-key: ${{ secrets.GH_APP_PRIVATE_KEY }} - name: Check out code uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Set up JDK 17 uses: actions/setup-java@c5195efecf7bdfc987ee8bae7a71cb8b11521c00 # v4.7.1 with: java-version: "17" distribution: "adopt" - uses: gradle/actions/setup-gradle@06832c7b30a0129d7fb559bcc6e43d26f6374244 # v4.3.1 - name: check the licenses for compatibility run: ./gradlew clean checkLicense - name: FAILED - check the licenses for compatibility if: failure() uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 with: name: dependencies-without-allowed-license.json path: | build/reports/dependency-license/dependencies-without-allowed-license.json retention-days: 3 - name: Move and Rename License File run: | mv build/reports/dependency-license/index.json src/main/resources/static/3rdPartyLicenses.json - name: Set up git config run: | git config --global user.name "stirlingbot[bot]" git config --global user.email "1113334+stirlingbot[bot]@users.noreply.github.com" - name: Run git add run: | git add src/main/resources/static/3rdPartyLicenses.json git diff --staged --quiet || echo "CHANGES_DETECTED=true" >> $GITHUB_ENV - name: Create Pull Request id: cpr if: env.CHANGES_DETECTED == 'true' uses: peter-evans/create-pull-request@271a8d0340265f705b14b6d32b9829c1cb33d45e # v7.0.8 with: token: ${{ steps.generate-token.outputs.token }} commit-message: "Update 3rd Party Licenses" committer: "stirlingbot[bot] <1113334+stirlingbot[bot]@users.noreply.github.com>" author: "stirlingbot[bot] <1113334+stirlingbot[bot]@users.noreply.github.com>" signoff: true branch: update-3rd-party-licenses title: "Update 3rd Party Licenses" body: | Auto-generated by StirlingBot labels: licenses,github-actions draft: false delete-branch: true sign-commits: true - name: Enable Pull Request Automerge if: steps.cpr.outputs.pull-request-operation == 'created' run: gh pr merge --squash --auto "${{ steps.cpr.outputs.pull-request-number }}" env: GH_TOKEN: ${{ steps.generate-token.outputs.token }}