-
Notifications
You must be signed in to change notification settings - Fork 123
158 lines (145 loc) · 6.78 KB
/
main.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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
name: DataMiner Sync Starter Workflows
# Controls when the workflow will run
on:
schedule:
# Run every day, feel free to adjust this to your specific needs.
- cron: "0 0 * * *"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
createDotGithubIfNotExist:
runs-on: ubuntu-latest
name: Verify '.github' repository.
steps:
- name: Check If .github Exists
id: check_github_repo
run: |
if curl -s https://api.github.com/repos/${{ github.repository_owner }}/.github | grep -q 'Not Found'; then
echo not_found='true'>> $GITHUB_OUTPUT
else
echo not_found='false'>> $GITHUB_OUTPUT
fi
- name: Use Node.js
if: steps.check_github_repo.outputs.not_found == 'true'
uses: actions/setup-node@v4
- name: Create GitHub Repo
if: steps.check_github_repo.outputs.not_found == 'true'
uses: howlowck/[email protected]
with:
# Organization name of the repo
repoOrg: ${{ github.repository_owner }}
# Repository name
repoName: .github
# Repository description
repoDescription: Default Organisation Repository
# Repository visibility
repoVisibility: public
# Security token
securityToken: ${{ secrets.PAT }}
- name: Create main branch
if: steps.check_github_repo.outputs.not_found == 'true'
id: create_main_branch
run: |
mkdir -p newRepo
cd newRepo
git config --global user.email "[email protected]"
git config --global user.name "SkylineStarterWorkflows"
echo "# ${{ github.repository_owner }}" >> README.md
git init --initial-branch=main
git init -b main
git add README.md
git commit -m "first commit"
git push --set-upstream https://${{ secrets.PAT }}@github.com/${{ github.repository_owner }}/.github.git main
autoSyncFork:
name: Sync Fork with Upstream.
# dont sync when this is the original
# git merge -s ours upstream/main --allow-unrelated-histories
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
token: '${{ secrets.PAT }}'
- name: Sync Fork With Remote
if: github.repository_owner!='SkylineCommunications'
id: check_github_repo
run: |
git config --global user.email "[email protected]"
git config --global user.name "SyncBot"
git remote add upstream https://github.com/SkylineCommunications/Skyline-Starter-Workflows.git
git fetch upstream
git checkout main
git merge -s recursive -X ours upstream/main --allow-unrelated-histories
git push origin main --force
collectWorkflowFiles:
name: Find Workflow Files
runs-on: ubuntu-latest
needs: [autoSyncFork,createDotGithubIfNotExist]
steps:
- uses: actions/checkout@v4
with:
ref: 'main'
- name: Archive Workflow Files
uses: actions/upload-artifact@v4
with:
name: WorkflowFiles
path: "${{ github.workspace }}/workflow-templates"
createPullRequest:
name: Pull Request
runs-on: ubuntu-latest
needs: collectWorkflowFiles
steps:
- uses: actions/checkout@v4
with:
token: ${{ secrets.PAT }}
repository: ${{ github.repository_owner }}/.github
- name: Download WorkflowFiles
id: downloadWorkflowFiles
uses: actions/download-artifact@v4
with:
name: WorkflowFiles
path: "${{ github.workspace }}/workflow-templates"
- name: Create Pull Request
# You may pin to the exact commit or the version.
# uses: peter-evans/create-pull-request@2b011faafdcbc9ceb11414d64d0573f37c774b04
uses: peter-evans/[email protected]
with:
# GITHUB_TOKEN or a `repo` scoped Personal Access Token (PAT)
token: ${{ secrets.PAT }}
# Relative path under $GITHUB_WORKSPACE to the repository. Defaults to $GITHUB_WORKSPACE.
# path: # optional
# A comma or newline-separated list of file paths to commit. Paths should follow git's pathspec syntax. Defaults to adding all new and modified files.
# add-paths: # optional
# The message to use when committing changes.
# commit-message: # optional, default is [create-pull-request] automated change
# The committer name and email address in the format `Display Name <[email protected]>`. Defaults to the GitHub Actions bot user.
#committer: # optional, default is GitHub <[email protected]>
# The author name and email address in the format `Display Name <[email protected]>`. Defaults to the user who triggered the workflow run.
# author: # optional, default is ${{ github.actor }} <${{ github.actor }}@users.noreply.github.com>
# Add `Signed-off-by` line by the committer at the end of the commit log message.
# signoff: # optional
# The pull request branch name.
# branch: # optional, default is create-pull-request/patch
# Delete the `branch` when closing pull requests, and when undeleted after merging. Recommend `true`.
# delete-branch: # optional
# The branch suffix type when using the alternative branching strategy.
# branch-suffix: # optional
# The pull request base branch. Defaults to the branch checked out in the workflow.
# base: # optional
# A fork of the checked out parent repository to which the pull request branch will be pushed. e.g. `owner/repo-fork`. The pull request will be created to merge the fork's branch into the parent's base.
#push-to-fork:
# The title of the pull request.
#title: # optional, default is Changes by create-pull-request action
# The body of the pull request.
#body: # optional, default is Automated changes by [create-pull-request](https://github.com/peter-evans/create-pull-request) GitHub action
# A comma or newline separated list of labels.
#labels: # optional
# A comma or newline separated list of assignees (GitHub usernames).
#assignees: # optional
# A comma or newline separated list of reviewers (GitHub usernames) to request a review from.
#reviewers: # optional
# A comma or newline separated list of GitHub teams to request a review from. Note that a `repo` scoped Personal Access Token (PAT) may be required.
#team-reviewers: # optional
# The number of the milestone to associate the pull request with.
#milestone: # optional
# Create a draft pull request. It is not possible to change draft status after creation except through the web interface
#draft: # optional