Plugin docgen for 8.18 #17
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | name: "Plugin docgen for specified 8.x and earlier" | |
| run-name: "Plugin docgen for ${{ github.event.inputs.branch }}" | |
| on: | |
| workflow_dispatch: | |
| inputs: | |
| branch: | |
| description: 'Branch to update plugin docs' | |
| required: true | |
| default: '8.1' | |
| type: string | |
| permissions: | |
| contents: write | |
| pull-requests: write | |
| jobs: | |
| build: | |
| name: "Update docs for ${{ github.event.inputs.branch }}" | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: ruby/setup-ruby@v1 | |
| with: | |
| ruby-version: jruby | |
| - uses: actions/setup-java@dded0888837ed1f317902acf8a20df0ad188d165 # v5 | |
| with: | |
| distribution: 'temurin' | |
| java-version: '21' | |
| - name: Clone elastic/docs-tools | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5 | |
| with: | |
| repository: elastic/docs-tools | |
| path: docs-tools | |
| fetch-depth: 1 | |
| - name: Clone elastic/logstash-docs | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5 | |
| with: | |
| repository: elastic/logstash-docs | |
| path: logstash-docs | |
| fetch-depth: 1 | |
| ref: ${{ github.event.inputs.branch }} | |
| - name: Clone elastic/logstash | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5 | |
| with: | |
| repository: elastic/logstash | |
| path: logstash | |
| fetch-depth: 1 | |
| ref: ${{ github.event.inputs.branch }} | |
| - name: Clone elastic/docs | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5 | |
| with: | |
| repository: elastic/docs | |
| path: docs | |
| fetch-depth: 1 | |
| - name: Generate plugin versions | |
| working-directory: ./logstash | |
| env: | |
| GRADLE_OPTS: "-Dorg.gradle.jvmargs=\"-Xmx4g\"" | |
| run: ./gradlew generatePluginsVersion | |
| - name: Generate plugin docs | |
| working-directory: ./docs-tools | |
| run: | | |
| bundle install --path=vendor/bundle | |
| bundle exec ruby plugindocs.rb --skip-existing --output-path ../logstash-docs ../logstash/plugins_version_docs.json | |
| - name: Build docs | |
| working-directory: ./logstash | |
| run: ../docs/build_docs --asciidoctor --respect_edit_url_overrides --doc docs/index.asciidoc --resource=../logstash-docs/docs/ --chunk 1 | |
| - run: echo "T=$(date +%s)" >> $GITHUB_ENV | |
| - run: echo "BRANCH=update_docs_${T}" >> $GITHUB_ENV | |
| - name: Commit and Push | |
| working-directory: ./logstash-docs | |
| run: | | |
| git config user.email [email protected] | |
| git config user.name logstashmachine | |
| git checkout -b $BRANCH | |
| git add . | |
| git status | |
| if [[ -z $(git status --porcelain) ]]; then echo "No changes. We're done."; exit 0; fi | |
| git commit -m "updated docs for ${{ github.event.inputs.branch }}" -a | |
| git push origin $BRANCH | |
| - name: Create Pull Request | |
| run: | | |
| curl -H "Authorization: token ${{ secrets.GITHUB_TOKEN }}" -X POST -d "{\"title\": \"updated docs for ${{ github.event.inputs.branch }}\",\"head\": \"${BRANCH}\",\"base\": \"${{ github.event.inputs.branch }}\"}" https://api.github.com/repos/elastic/logstash-docs/pulls | |
| - run: echo "### Updated docs for ${{ github.event.inputs.branch }} :rocket:" >> $GITHUB_STEP_SUMMARY |