forked from snowdreamtech/base
-
Notifications
You must be signed in to change notification settings - Fork 0
194 lines (184 loc) · 6.58 KB
/
Copy pathdependabot-sync.yml
File metadata and controls
194 lines (184 loc) · 6.58 KB
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
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
# Copyright (c) 2026 SnowdreamTech. All rights reserved.
# Licensed under the MIT License. See LICENSE file in the project root for full license information.
---
# Dependabot Smart Sync
# Purpose: Automatically regenerates .github/dependabot.yml based on detected ecosystems.
# Trigger: Push to dev (manifest file changes), monthly schedule, or manual dispatch.
# Design:
# - Uses .unirtm.toml to scan for manifest files via git ls-files.
# - Only commits if the generated config differs from the current one.
# - Uses native git commands — no third-party commit Actions.
name: "🤖 Dependabot Smart Sync"
"on":
push:
branches: ["dev"]
paths:
# Trigger when manifest files or the generator script change
- "package.json"
- "**/package.json"
- "go.mod"
- "**/go.mod"
- "Cargo.toml"
- "**/Cargo.toml"
- "requirements.txt"
- "**/requirements.txt"
- "Dockerfile"
- "**/Dockerfile"
- "composer.json"
- "**/composer.json"
- "Gemfile"
- "**/Gemfile"
- "mix.exs"
- "pubspec.yaml"
- "Package.swift"
- "**/*.tf"
- "**/devcontainer.json"
- ".pre-commit-config.yaml"
- "Chart.yaml"
- ".unirtm.toml"
# UniRTM toolchain configuration
- ".unirtm.toml"
- ".github/workflows/dependabot-sync.yml"
schedule:
# Weekly safety net: every Monday at 06:00 UTC
- cron: "0 6 * * 1"
workflow_dispatch:
permissions: {}
env:
UNIRTM_LOCKED: 1
# Opt into Node.js 24 now ahead of GitHub's June 16, 2026 forced migration.
# See: https://github.blog/changelog/2025-09-19-deprecation-of-node-20-on-github-actions-runners/
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: "1"
jobs:
sync:
name: "🔄 Sync Dependabot Config"
runs-on: ubuntu-latest
permissions:
contents: write
environment: maintenance
timeout-minutes: 30
steps:
- name: "🔒 Harden Runner"
uses: step-security/harden-runner@9af89fc71515a100421586dfdb3dc9c984fbf411 # v2.19.4
with:
disable-sudo: true
egress-policy: block
allowed-endpoints: >
api.github.com:443
raw.githubusercontent.com:443
objects.githubusercontent.com:443
pkg-containers.githubusercontent.com:443
avatars.githubusercontent.com:443
github.com:443
packages.microsoft.com:443
archive.ubuntu.com:80
archive.ubuntu.com:443
security.ubuntu.com:80
security.ubuntu.com:443
ports.ubuntu.com:80
ports.ubuntu.com:443
keyserver.ubuntu.com:80
keyserver.ubuntu.com:443
changelogs.ubuntu.com:80
changelogs.ubuntu.com:443
deb.debian.org:80
deb.debian.org:443
security.debian.org:80
security.debian.org:443
snapshot.debian.org:80
snapshot.debian.org:443
dl.rockylinux.org:443
mirrors.rockylinux.org:443
mirror.centos.org:443
vault.centos.org:443
isv-data.centos.org:443
mirrorlist.centos.org:80
mirrorlist.centos.org:443
cdn.redhat.com:443
cdn-ubi.redhat.com:443
access.redhat.com:443
sso.redhat.com:443
dl-cdn.alpinelinux.org:443
registry.npmjs.org:443
registry.yarnpkg.com:443
pypi.org:443
files.pythonhosted.org:443
proxy.golang.org:443
sum.golang.org:443
index.crates.io:443
static.rust-lang.org:443
packagist.org:443
repo.maven.apache.org:443
golang.org:443
pkg.go.dev:443
dl.google.com:443
rubygems.org:443
registry.terraform.io:443
formulae.brew.sh:443
repo.yarnpkg.com:443
ghcr.io:443
production.cloudflare.docker.com:80
production.cloudflare.docker.com:443
registry-1.docker.io:443
auth.docker.io:443
docker.io:443
quay.io:443
cdn.quay.io:443
docker-images-prod.s3.us-west-2.amazonaws.com:443
docker-images-prod.s3.us-east-1.amazonaws.com:443
docker-images-prod.s3.amazonaws.com:443
s3.amazonaws.com:443
s3.us-west-2.amazonaws.com:443
s3.us-east-1.amazonaws.com:443
osv-vulnerabilities.storage.googleapis.com:443
api.osv.dev:443
get.trivy.dev:443
aquasecurity.github.io:443
tuf-repo-cdn.sigstore.dev:443
oauth2.sigstore.dev:443
rekor.sigstore.dev:443
fulcio.sigstore.dev:443
api.sigstore.dev:443
- name: "📂 Checkout Repository Code"
uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6.0.3
with:
persist-credentials: true
ref: ${{ github.ref }}
- name: "⚡ Setup UniRTM"
uses: snowdreamtech/setup-unirtm@cacfb4d739ee46d4a4b2528b02b508df2f560706 # v0.4.0
with:
unirtm-version: "0.25.0"
install: true
trust: true
env:
GITHUB_TOKEN: ${{ secrets.WORKFLOW_SECRET || secrets.GITHUB_TOKEN }}
- name: "🤖 Generate Dependabot Config"
shell: sh
run: |
unirtm generate dependabot --output .github/dependabot.yml
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
UNIRTM_YES: 1
- name: "🔧 Update UniRTM Toolchain & Lockfile"
shell: sh
run: |
unirtm lock --all-platforms
env:
GITHUB_TOKEN: ${{ secrets.WORKFLOW_SECRET || secrets.GITHUB_TOKEN }}
UNIRTM_YES: 1
- name: "📝 Commit Changes (if any)"
shell: sh
env:
GITHUB_TOKEN: ${{ secrets.WORKFLOW_SECRET || secrets.GITHUB_TOKEN }}
GITHUB_REF: ${{ github.ref }}
run: |
if git diff --quiet .github/dependabot.yml unirtm.lock .unirtm.toml 2>/dev/null; then
echo "✅ No changes detected. Dependabot config and UniRTM toolchain are up-to-date."
else
git config user.name "github-actions[bot]"
git config user.email "github-actions[bot]@users.noreply.github.com"
git add .github/dependabot.yml unirtm.lock .unirtm.toml
git commit --signoff -m "chore(deps): sync dependabot config and unirtm toolchain [skip ci]"
git push origin HEAD:"$GITHUB_REF"
echo "✅ Dependabot config and UniRTM toolchain updated and pushed."
fi