6 changed files with 33 additions and 102 deletions
@ -1,5 +0,0 @@
@@ -1,5 +0,0 @@
|
||||
REPOSITORY_REF="$1" |
||||
TOKEN="$2" |
||||
|
||||
curl -H "Accept: application/vnd.github.everest-preview+json" -H "Authorization: token ${TOKEN}" --request POST --data '{"event_type": "request-build-reference"}' https://api.github.com/repos/${REPOSITORY_REF}/dispatches |
||||
echo "Requested Build for $REPOSITORY_REF" |
||||
@ -1,41 +0,0 @@
@@ -1,41 +0,0 @@
|
||||
name: Generate Antora Files and Request Build |
||||
|
||||
on: |
||||
workflow_dispatch: |
||||
push: |
||||
branches-ignore: |
||||
- 'gh-pages' |
||||
tags: '**' |
||||
|
||||
env: |
||||
GH_ACTIONS_REPO_TOKEN: ${{ secrets.GH_ACTIONS_REPO_TOKEN }} |
||||
|
||||
permissions: |
||||
contents: read |
||||
|
||||
jobs: |
||||
build: |
||||
runs-on: ubuntu-latest |
||||
if: ${{ github.repository == 'spring-projects/spring-security' }} |
||||
steps: |
||||
- name: Checkout Source |
||||
uses: actions/checkout@v2 |
||||
- name: Set up gradle |
||||
uses: spring-io/spring-gradle-build-action@v1 |
||||
with: |
||||
java-version: '11' |
||||
distribution: 'adopt' |
||||
- name: Generate antora.yml |
||||
run: ./gradlew :spring-security-docs:generateAntora |
||||
- name: Extract Branch Name |
||||
id: extract_branch_name |
||||
run: echo "##[set-output name=generated_branch_name;]$(echo ${GITHUB_REPOSITORY}/${GITHUB_REF##*/})" |
||||
- name: Push generated antora files to the spring-generated-docs |
||||
uses: JamesIves/github-pages-deploy-action@4.1.4 |
||||
with: |
||||
branch: ${{ steps.extract_branch_name.outputs.generated_branch_name }} # The branch the action should deploy to. |
||||
folder: "docs/build/generateAntora" # The folder the action should deploy. |
||||
repository-name: "spring-io/spring-generated-docs" |
||||
token: ${{ secrets.GH_ACTIONS_REPO_TOKEN }} |
||||
- name: Dispatch Build Request |
||||
run: ${GITHUB_WORKSPACE}/.github/actions/dispatch.sh 'spring-projects/spring-security' "$GH_ACTIONS_REPO_TOKEN" |
||||
@ -0,0 +1,31 @@
@@ -0,0 +1,31 @@
|
||||
name: Deploy Docs |
||||
on: |
||||
push: |
||||
branches-ignore: [ gh-pages ] |
||||
tags: '**' |
||||
repository_dispatch: |
||||
types: request-build-reference # legacy |
||||
schedule: |
||||
- cron: '0 10 * * *' # Once per day at 10am UTC |
||||
workflow_dispatch: |
||||
permissions: read-all |
||||
jobs: |
||||
build: |
||||
runs-on: ubuntu-latest |
||||
if: github.repository_owner == 'spring-projects' |
||||
steps: |
||||
- name: Checkout |
||||
uses: actions/checkout@v3 |
||||
with: |
||||
ref: docs-build |
||||
fetch-depth: 1 |
||||
- name: Dispatch (partial build) |
||||
if: github.ref_type == 'branch' |
||||
env: |
||||
GH_TOKEN: ${{ secrets.GH_ACTIONS_REPO_TOKEN }} |
||||
run: gh workflow run deploy-docs.yml -r $(git rev-parse --abbrev-ref HEAD) -f build-refname=${{ github.ref_name }} |
||||
- name: Dispatch (full build) |
||||
if: github.ref_type == 'tag' |
||||
env: |
||||
GH_TOKEN: ${{ secrets.GH_ACTIONS_REPO_TOKEN }} |
||||
run: gh workflow run deploy-docs.yml -r $(git rev-parse --abbrev-ref HEAD) |
||||
@ -1,53 +0,0 @@
@@ -1,53 +0,0 @@
|
||||
'use strict' |
||||
|
||||
/* Copyright (c) 2002-2022 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
*
|
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
const { promises: fsp } = require('fs') |
||||
const ospath = require('path') |
||||
|
||||
/** |
||||
* Rewrites local content sources to support the use of linked worktrees. |
||||
* |
||||
* @author Dan Allen <dan@opendevise.com> |
||||
*/ |
||||
module.exports.register = function () { |
||||
this.once('playbookBuilt', async ({ playbook }) => { |
||||
const expandPath = this.require('@antora/expand-path-helper') |
||||
for (const contentSource of playbook.content.sources) { |
||||
const { url, branches } = contentSource |
||||
if (url.charAt() !== '.') continue |
||||
const absdir = expandPath(url, { dot: playbook.dir }) |
||||
const gitfile = ospath.join(absdir, '.git') |
||||
if (await fsp.stat(gitfile).then((stat) => !stat.isDirectory(), () => false)) { |
||||
const worktreeGitdir = await fsp.readFile(gitfile, 'utf8') |
||||
.then((contents) => contents.trimRight().substr(8)) |
||||
const worktreeBranch = await fsp.readFile(ospath.join(worktreeGitdir, 'HEAD'), 'utf8') |
||||
.then((contents) => contents.trimRight().replace(/^ref: (?:refs\/heads\/)?/, '')) |
||||
const reldir = ospath.relative( |
||||
playbook.dir, |
||||
await fsp.readFile(ospath.join(worktreeGitdir, 'commondir'), 'utf8') |
||||
.then((contents) => { |
||||
const gitdir = ospath.join(worktreeGitdir, contents.trimRight()) |
||||
return ospath.basename(gitdir) === '.git' ? ospath.dirname(gitdir) : gitdir |
||||
}) |
||||
) |
||||
contentSource.url = reldir ? `.${ospath.sep}${reldir}` : '.' |
||||
if (!branches) continue |
||||
contentSource.branches = (branches.constructor === Array ? branches : [branches]) |
||||
.map((pattern) => pattern.replaceAll('HEAD', worktreeBranch)) |
||||
} |
||||
} |
||||
}) |
||||
} |
||||
Loading…
Reference in new issue