generated from okp4/template-oss
-
Notifications
You must be signed in to change notification settings - Fork 23
112 lines (99 loc) · 4.57 KB
/
update-versioned-docs.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
name: Update versioned docs
concurrency: update-docs-${{ github.ref }}
on:
workflow_dispatch:
inputs:
version:
description: "New docs version (repository tag or repository ref)"
required: true
repository:
description: "Set the repository that docs has been updated (okp4/contracts | okp4/okp4d)"
required: true
section:
description: "Which section will be update (contracts | modules | commands)"
required: true
docs_directory:
description: "On which directory documentation is located (docs/* | docs/proto/* | docs/command/*)"
required: false
default: "docs/*"
draft:
type: boolean
description: "Indicate if the publication of the documentation should be kept in draft and no new version should be released"
required: false
default: false
jobs:
update-versioned-doc:
runs-on: ubuntu-22.04
steps:
- name: Check out repository
uses: actions/checkout@v4
with:
token: ${{ secrets.OKP4_TOKEN }}
fetch-depth: 2
- name: Check out repository
uses: actions/checkout@v4
with:
ref: ${{ github.event.inputs.version }}
repository: ${{ github.event.inputs.repository }}
token: ${{ secrets.OKP4_TOKEN }}
path: tmp
- name: Import GPG key
uses: crazy-max/ghaction-import-gpg@v6
with:
gpg_private_key: ${{ secrets.OKP4_BOT_GPG_PRIVATE_KEY }}
passphrase: ${{ secrets.OKP4_BOT_GPG_PASSPHRASE }}
git_config_global: true
git_user_signingkey: true
git_commit_gpgsign: true
- name: Copy updated docs
run: |
rm -rf ${{ github.event.inputs.section }}/*
rsync -rmv --include='*/' --include='*.md' --include='*.mdx' --include='*.json' --exclude='*' tmp/${{ github.event.inputs.docs_directory }} ${{ github.event.inputs.section }}
git rm --ignore-unmatch --cached tmp
rm -rf .git/modules/tmp
rm -rf tmp
- name: Setup node environment
uses: actions/setup-node@v4
with:
node-version: 18.19
cache: yarn
- name: Bump new version
if: ${{ github.event.inputs.draft == 'false' }}
run: |
yarn
yarn run docusaurus docs:version:${{ github.event.inputs.section }} ${{ github.event.inputs.version }}
- name: Search for all modified files that involve the creation of PR or commit to main
id: changed-files
uses: tj-actions/[email protected]
with:
files: |
*.json
*.md
- name: Commit documentation draft
uses: stefanzweifel/git-auto-commit-action@v5
if: ${{ github.event.inputs.draft == 'true' && steps.changed-files.outputs.any_changed }}
with:
commit_user_name: ${{ secrets.OKP4_BOT_GIT_COMMITTER_NAME }}
commit_user_email: ${{ secrets.OKP4_BOT_GIT_COMMITTER_EMAIL }}
commit_author: ${{ secrets.OKP4_BOT_GIT_AUTHOR_NAME }} <${{ secrets.OKP4_BOT_GIT_AUTHOR_EMAIL }}>
commit_message: "feat(${{ github.event.inputs.section }}): update ${{ github.event.inputs.repository }} ${{ github.event.inputs.section }} documentation"
- name: Create Pull Request
uses: peter-evans/create-pull-request@v6
if: ${{ github.event.inputs.draft == 'false' && steps.changed-files.outputs.any_changed }}
with:
token: ${{ secrets.OKP4_TOKEN }}
commit-message: "feat(${{ github.event.inputs.section }}): add ${{ github.event.inputs.repository }} ${{ github.event.inputs.version }} ${{ github.event.inputs.section }} documentation"
committer: ${{ secrets.OKP4_BOT_GIT_AUTHOR_NAME }} <${{ secrets.OKP4_BOT_GIT_AUTHOR_EMAIL }}>
author: ${{ secrets.OKP4_BOT_GIT_AUTHOR_NAME }} <${{ secrets.OKP4_BOT_GIT_AUTHOR_EMAIL }}>
branch: feat/${{ github.event.inputs.section }}-${{ github.event.inputs.version }}
title: 📜 Add ${{ github.event.inputs.version }} ${{ github.event.inputs.section }} documentation version
body: |
#### 📜 Documentation update
🎉 A new version of [${{ github.event.inputs.repository }}](https://github.com/${{ github.event.inputs.repository }}/releases/tag/${{ github.event.inputs.version }}) is available.
This PR add this new `${{ github.event.inputs.version }}` version into the documentation.
labels: documentation
assignees: ccamel,amimart
reviewers: ccamel,amimart
add-paths: |
*.json
*.md