Compare commits
150 Commits
v23
...
update_fla
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e3c37974f6 | ||
| 7e8c07facc | |||
| 9e6ca5763d | |||
|
|
e637603d31 | ||
|
|
abc27e2959 | ||
|
|
8bb6def04e | ||
|
|
2d794d033f | ||
|
|
c7babf9135 | ||
|
|
7bfad140bc | ||
|
|
04555e49a2 | ||
|
|
e623f0d61b | ||
|
|
40e6295517 | ||
|
|
ab3e850b05 | ||
|
|
7b0ea76669 | ||
|
|
8f6350f756 | ||
|
|
4c5a5823ee | ||
|
|
6f77c42fd7 | ||
|
|
1ccda36a19 | ||
|
|
69e81e9a9a | ||
|
|
4d44339806 | ||
|
|
1503d32725 | ||
|
|
bcb68a867a | ||
|
|
f81a1178b3 | ||
|
|
bd38b7750d | ||
|
|
71f78a9942 | ||
|
|
2205bbc6e8 | ||
|
|
d6b471071f | ||
|
|
82239512ad | ||
|
|
de9ebbfc86 | ||
|
|
a76f1ed832 | ||
|
|
9d09410aa3 | ||
|
|
cc17cfcd6b | ||
|
|
ca07b4a3c8 | ||
|
|
463e36d106 | ||
|
|
ab78b1b8dc | ||
|
|
c5930b397a | ||
|
|
4f2c07b7c1 | ||
|
|
9070c89246 | ||
|
|
32851b9f01 | ||
|
|
3ce5967e9d | ||
|
|
509c5b641b | ||
|
|
5a1baf2676 | ||
|
|
adae970ac9 | ||
|
|
aaa6c5f16e | ||
|
|
9e234f294f | ||
|
|
ae93f377bd | ||
|
|
203bba74fe | ||
|
|
7254b1b06e | ||
|
|
c2408e5496 | ||
|
|
e619add55e | ||
|
|
ab1354a8e5 | ||
|
|
2770056b7a | ||
|
|
aa3e38eebd | ||
|
|
10cfb1c664 | ||
|
|
a1bf79f72f | ||
|
|
c115b81c59 | ||
|
|
2ca76c3436 | ||
|
|
a3640124cb | ||
|
|
5681a56ca1 | ||
|
|
428c2b58a4 | ||
|
|
3690f88382 | ||
|
|
94658602a6 | ||
|
|
2a2fe68d85 | ||
|
|
e9a7860f3f | ||
|
|
acec67c2bb | ||
|
|
3ed2353766 | ||
|
|
11e4dfb59a | ||
|
|
dcd2ee07ca | ||
|
|
743a8831c3 | ||
|
|
5a493253cd | ||
|
|
a29375a98c | ||
|
|
6f149b7268 | ||
|
|
5d4194e238 | ||
|
|
632f41e585 | ||
|
|
f033bc83d7 | ||
|
|
c28c313ee6 | ||
|
|
de73a6ec43 | ||
|
|
191583413a | ||
|
|
a7d610b592 | ||
|
|
f1ea6b125e | ||
|
|
355885e85b | ||
|
|
17889577d9 | ||
|
|
e0f01aff56 | ||
|
|
6f83ef312f | ||
|
|
68fc9d463e | ||
|
|
8df4e70f64 | ||
|
|
ad4544a038 | ||
|
|
f258f6b8ca | ||
|
|
149faa1ed4 | ||
|
|
84feadbac6 | ||
|
|
867f274467 | ||
|
|
605b78f787 | ||
|
|
1a5f8176b6 | ||
|
|
43e7b633e9 | ||
|
|
7689af81f5 | ||
|
|
b81e46d8dd | ||
|
|
edf12a038d | ||
|
|
97278a027b | ||
|
|
062b9f53fa | ||
|
|
84d025eee7 | ||
|
|
2eaf7beabb | ||
|
|
2a1e64c750 | ||
|
|
c319d26b5f | ||
|
|
37001efe5b | ||
|
|
f319391080 | ||
|
|
7f50ffb42b | ||
|
|
c6435de337 | ||
|
|
01b415ecee | ||
|
|
42aa906d7f | ||
|
|
8b0105d445 | ||
|
|
9e4b6cbbef | ||
|
|
43a3cfc807 | ||
|
|
97b24ed38a | ||
|
|
c7af1d9132 | ||
|
|
ae207e3462 | ||
|
|
6b57c8dc27 | ||
|
|
e680567e78 | ||
|
|
6981b122f5 | ||
|
|
1666ee39f3 | ||
|
|
6530cb6c3e | ||
|
|
3a90118afa | ||
|
|
460b95a768 | ||
|
|
ae18c965c1 | ||
|
|
1d8d1b0210 | ||
|
|
d58eff8f1d | ||
|
|
8d81dfe006 | ||
|
|
f71609bc55 | ||
|
|
a522afcccd | ||
|
|
8368f542ad | ||
|
|
86cbeff68e | ||
|
|
e64717fb04 | ||
|
|
d99e45a16b | ||
|
|
208d8b0fa4 | ||
|
|
183c83b4bc | ||
|
|
0ba1118664 | ||
|
|
236c0fa397 | ||
|
|
8fa6d41e3f | ||
|
|
1360662aa3 | ||
|
|
531bd45244 | ||
|
|
1afac295f9 | ||
|
|
1cc1733537 | ||
|
|
965531f332 | ||
|
|
a2bbe0274e | ||
|
|
802501548e | ||
|
|
7d80c329b4 | ||
|
|
7bc6ec59cc | ||
|
|
4cf6b19203 | ||
|
|
73ba0ca899 | ||
|
|
24f53daa86 | ||
|
|
420fb2aaf7 |
20
.github/workflows/ci.yml
vendored
20
.github/workflows/ci.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: CI
|
name: CI
|
||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
push:
|
push:
|
||||||
@@ -6,15 +7,22 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
typescript-action:
|
typescript-action:
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
id-token: write
|
||||||
|
contents: read
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v5
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
- name: Install Nix
|
- name: Check Nixpkgs
|
||||||
uses: DeterminateSystems/nix-installer-action@main
|
uses: DeterminateSystems/flake-checker-action@main
|
||||||
- name: Enable magic Nix cache
|
with:
|
||||||
uses: DeterminateSystems/magic-nix-cache-action@main
|
fail-mode: true
|
||||||
|
- name: Install Determinate Nix
|
||||||
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
|
- name: Enable FlakeHub Cache
|
||||||
|
uses: DeterminateSystems/flakehub-cache-action@main
|
||||||
- name: Install pnpm dependencies
|
- name: Install pnpm dependencies
|
||||||
run: nix develop --command pnpm install
|
run: nix develop --command pnpm install
|
||||||
- name: Check formatting
|
- name: Check formatting
|
||||||
|
|||||||
34
.github/workflows/update.yml
vendored
34
.github/workflows/update.yml
vendored
@@ -1,22 +1,24 @@
|
|||||||
name: update-flake-lock
|
name: "Flake.lock: update Nix dependencies"
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch: # allows manual triggering
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 0 * * 0"
|
- cron: "0 0 * * 0" # runs weekly on Sunday at 00:00
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lockfile:
|
nix-flake-update:
|
||||||
runs-on: ubuntu-22.04
|
permissions:
|
||||||
|
contents: write
|
||||||
|
id-token: write
|
||||||
|
issues: write
|
||||||
|
pull-requests: write
|
||||||
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- uses: actions/checkout@v5
|
||||||
uses: actions/checkout@v4
|
- uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Install Nix
|
- uses: DeterminateSystems/update-flake-lock@main
|
||||||
uses: DeterminateSystems/nix-installer-action@main
|
|
||||||
- name: Enable magic Nix cache
|
|
||||||
uses: DeterminateSystems/magic-nix-cache-action@main
|
|
||||||
- name: Check flake
|
|
||||||
uses: DeterminateSystems/flake-checker-action@main
|
|
||||||
- name: Update flake.lock
|
|
||||||
uses: ./.
|
|
||||||
with:
|
with:
|
||||||
_internal-strict-mode: true
|
pr-title: "Update Nix flake inputs" # Title of PR to be created
|
||||||
|
pr-labels: | # Labels to be set on the PR
|
||||||
|
dependencies
|
||||||
|
automated
|
||||||
|
|||||||
18
.github/workflows/upstream_sync.yml
vendored
Normal file
18
.github/workflows/upstream_sync.yml
vendored
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# .github/workflows/sync.yml
|
||||||
|
name: Rebase Upstream
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: "0 0 * * 0" # run once a week
|
||||||
|
workflow_dispatch: # run manually
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
sync:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@master
|
||||||
|
with:
|
||||||
|
fetch-depth: 10 # greater than the number of commits you made
|
||||||
|
- uses: imba-tjd/rebase-upstream-action@master
|
||||||
|
with: # all args are optional
|
||||||
|
upstream: DeterminateSystems/update-flake-lock
|
||||||
|
branch: main
|
||||||
5
.github/workflows/validate.yml
vendored
5
.github/workflows/validate.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: CI
|
name: CI
|
||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
push:
|
push:
|
||||||
@@ -6,9 +7,9 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
validate:
|
validate:
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v5
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
- name: Validate YAML
|
- name: Validate YAML
|
||||||
|
|||||||
153
README.md
153
README.md
@@ -1,32 +1,37 @@
|
|||||||
# update-flake-lock
|
# update-flake-lock
|
||||||
|
|
||||||
This is a GitHub Action that will update your flake.lock file whenever it is run.
|
This is a GitHub Action that updates the [`flake.lock`][lockfile] file for your [Nix flake][flakes] whenever it is run.
|
||||||
|
|
||||||
> **NOTE:** As of v3, this action will no longer automatically install Nix to the action runner. You **MUST** set up a Nix with flakes support enabled prior to running this action, or your workflow will not function as expected.
|
> [!NOTE]
|
||||||
|
> As of v3, this action no longer automatically installs [Determinate Nix][det-nix] to the action runner.
|
||||||
|
> You **must** set up Nix with flakes support enabled prior to running this action or your workflow will not function as expected.
|
||||||
|
|
||||||
## Example
|
## Example
|
||||||
|
|
||||||
An example GitHub Action workflow using this action would look like the following:
|
Here's an example GitHub Action workflow using this Action:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: update-flake-lock
|
name: "Flake.lock: update Nix dependencies"
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch: # allows manual triggering
|
workflow_dispatch: # allows manual triggering
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 0 * * 0' # runs weekly on Sunday at 00:00
|
- cron: '0 0 * * 0' # runs weekly on Sunday at 00:00
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lockfile:
|
nix-flake-update:
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
id-token: write
|
||||||
|
issues: write
|
||||||
|
pull-requests: write
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- uses: actions/checkout@v4
|
||||||
uses: actions/checkout@v4
|
- uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Install Nix
|
- uses: DeterminateSystems/update-flake-lock@main
|
||||||
uses: DeterminateSystems/nix-installer-action@main
|
|
||||||
- name: Update flake.lock
|
|
||||||
uses: DeterminateSystems/update-flake-lock@main
|
|
||||||
with:
|
with:
|
||||||
pr-title: "Update flake.lock" # Title of PR to be created
|
pr-title: "Update Nix flake inputs" # Title of PR to be created
|
||||||
pr-labels: | # Labels to be set on the PR
|
pr-labels: | # Labels to be set on the PR
|
||||||
dependencies
|
dependencies
|
||||||
automated
|
automated
|
||||||
@@ -34,12 +39,14 @@ jobs:
|
|||||||
|
|
||||||
## Example updating specific input(s)
|
## Example updating specific input(s)
|
||||||
|
|
||||||
> **NOTE**: If any inputs have a stale reference (e.g. the lockfile thinks a git input wants its "ref" to be "nixos-unstable", but the flake.nix specifies "nixos-unstable-small"), they will also be updated. At this time, there is no known workaround.
|
> [!NOTE]
|
||||||
|
> If any inputs have a stale reference (e.g. the lockfile thinks a git input wants its "ref" to be "nixos-unstable", but the flake.nix specifies "nixos-unstable-small"), they are also updated. At this time, there is no known workaround.
|
||||||
|
|
||||||
It is also possible to update specific inputs by specifying them in a space-separated list:
|
It's also possible to update specific [flake inputs][inputs] by specifying them in a space-separated list:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: update-flake-lock
|
name: update-flake-lock
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch: # allows manual triggering
|
workflow_dispatch: # allows manual triggering
|
||||||
schedule:
|
schedule:
|
||||||
@@ -51,17 +58,17 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
inputs: input1 input2 input3
|
inputs: input1 input2 input3
|
||||||
```
|
```
|
||||||
|
|
||||||
## Example adding options to nix command
|
## Example adding options to nix command
|
||||||
|
|
||||||
It is also possible to use specific options to the nix command in a space separated list:
|
It's also possible to use specific options to the `nix` command in a space-separated list:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: update-flake-lock
|
name: update-flake-lock
|
||||||
@@ -76,10 +83,10 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
nix-options: --debug --log-format raw
|
nix-options: --debug --log-format raw
|
||||||
```
|
```
|
||||||
@@ -99,11 +106,11 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
id: update
|
id: update
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
inputs: input1 input2 input3
|
inputs: input1 input2 input3
|
||||||
- name: Print PR number
|
- name: Print PR number
|
||||||
@@ -128,11 +135,11 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
if: ${{ github.event_name != 'pull_request' }}
|
if: ${{ github.event_name != 'pull_request' }}
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
inputs: input1 input2 input3
|
inputs: input1 input2 input3
|
||||||
path-to-flake-dir: 'nix/' # in this example our flake doesn't sit at the root of the repository, it sits under 'nix/flake.nix'
|
path-to-flake-dir: 'nix/' # in this example our flake doesn't sit at the root of the repository, it sits under 'nix/flake.nix'
|
||||||
@@ -155,36 +162,29 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
git-author-name: 'Jane Author'
|
git-author-name: Jane Author
|
||||||
git-author-email: 'github-actions[bot]@users.noreply.github.com'
|
git-author-email: github-actions[bot]@users.noreply.github.com
|
||||||
git-committer-name: 'John Committer'
|
git-committer-name: John Committer
|
||||||
git-committer-email: 'github-actions[bot]@users.noreply.github.com'
|
git-committer-email: github-actions[bot]@users.noreply.github.com
|
||||||
```
|
```
|
||||||
|
|
||||||
## Running GitHub Actions CI
|
## Running GitHub Actions CI
|
||||||
|
|
||||||
GitHub Actions will not run workflows when a branch is pushed by or a PR is opened by a GitHub Action. There are two ways to have GitHub Actions CI run on a PR submitted by this action.
|
GitHub Actions doesn't run workflows when a branch is pushed by or a PR is opened by a GitHub Action.
|
||||||
|
There are two ways to have GitHub Actions CI run on a PR submitted by this action.
|
||||||
|
|
||||||
### Without a Personal Authentication Token
|
### Without a Personal Authentication Token
|
||||||
|
|
||||||
Without using a Personal Authentication Token, you can manually run the following to kick off a CI run:
|
Without using a Personal Authentication Token, close and reopen the pull request manually to kick off CI.
|
||||||
|
|
||||||
```
|
|
||||||
git branch -D update_flake_lock_action
|
|
||||||
git fetch origin
|
|
||||||
git checkout update_flake_lock_action
|
|
||||||
git commit --amend --no-edit
|
|
||||||
git push origin update_flake_lock_action --force
|
|
||||||
```
|
|
||||||
|
|
||||||
### With a Personal Authentication Token
|
### With a Personal Authentication Token
|
||||||
|
|
||||||
By providing a Personal Authentication Token, the PR will be submitted in a way that bypasses this limitation (GitHub will essentially think it is the owner of the PAT submitting the PR, and not an Action).
|
By providing a Personal Authentication Token, the PR is submitted in a way that bypasses this limitation (GitHub essentially thinks it's the owner of the PAT submitting the PR, and not an Action).
|
||||||
You can create a token by visiting https://github.com/settings/tokens and select at least the `repo` scope. For the new fine-grained tokens, you need to enable read and write access for "Contents" and "Pull Requests" permissions. Then, store this token in your repository secrets (i.e. `https://github.com/<USER>/<REPO>/settings/secrets/actions`) as `GH_TOKEN_FOR_UPDATES` and set up your workflow file like the following:
|
You can create a token by visiting https://github.com/settings/tokens and select at least the `repo` scope. For the new fine-grained tokens, you need to enable read and write access for "Contents" and "Pull Requests" permissions. Then, store this token in your repository secrets (i.e. `https://github.com/<USER>/<REPO>/settings/secrets/actions`) as `GH_TOKEN_FOR_UPDATES` and set up your workflow file like the following:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@@ -200,30 +200,34 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GH_TOKEN_FOR_UPDATES }}
|
token: ${{ secrets.GH_TOKEN_FOR_UPDATES }}
|
||||||
```
|
```
|
||||||
|
|
||||||
## With GPG commit signing
|
## With GPG commit signing
|
||||||
|
|
||||||
It's possible for the bot to produce GPG signed commits. Associating a GPG public key to a github user account is not required but it is necessary if you want the signed commits to appear as verified in Github. This can be a compliance requirement in some cases.
|
It's possible for the bot to produce GPG-signed commits.
|
||||||
|
Associating a GPG public key to a GitHub user account isn't required but it *is* necessary if you want the signed commits to appear as verified in Github.
|
||||||
|
This can be a compliance requirement in some cases.
|
||||||
|
|
||||||
You can follow [Github's guide on creating and/or adding a new GPG key to an user account](https://docs.github.com/en/authentication/managing-commit-signature-verification/adding-a-new-gpg-key-to-your-github-account). Using a specific github user account for the bot can be a good security measure to dissociate this bot's actions and commits from your personal github account.
|
You can follow [GitHub's guide to creating and/or adding a new GPG key to an user account](https://docs.github.com/en/authentication/managing-commit-signature-verification/adding-a-new-gpg-key-to-your-github-account).
|
||||||
|
Using a specific GitHub user account for the bot can be a good security measure to dissociate this bot's actions and commits from your personal GitHub account.
|
||||||
|
|
||||||
For the bot to produce signed commits, you will have to provide the GPG private keys to this action's input parameters. You can safely do that with [Github secrets as explained here](https://github.com/crazy-max/ghaction-import-gpg#prerequisites).
|
For the bot to produce signed commits, you need to provide the GPG private keys to this action's input parameters. You can safely do that with [Github secrets as explained here](https://github.com/crazy-max/ghaction-import-gpg#prerequisites).
|
||||||
|
|
||||||
When using commit signing, the commit author name and email for the commits produced by this bot would correspond to the ones associated to the GPG Public Key.
|
When using commit signing, the commit author name and email for the commits produced by this bot would correspond to the ones associated to the GPG Public Key.
|
||||||
|
|
||||||
If you want to sign using a subkey, you must specify the subkey fingerprint using the `gpg-fingerprint` input parameter.
|
If you want to sign using a subkey, you must specify the subkey fingerprint using the `gpg-fingerprint` input parameter.
|
||||||
|
|
||||||
You can find an example of how to using this action with commit signing below:
|
Here's an example of how to using this action with commit signing:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: update-flake-lock
|
name: update-flake-lock
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch: # allows manual triggering
|
workflow_dispatch: # allows manual triggering
|
||||||
schedule:
|
schedule:
|
||||||
@@ -235,10 +239,10 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
sign-commits: true
|
sign-commits: true
|
||||||
gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }}
|
gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }}
|
||||||
@@ -248,18 +252,19 @@ jobs:
|
|||||||
|
|
||||||
## Custom PR Body
|
## Custom PR Body
|
||||||
|
|
||||||
By default the generated PR body is set to be the following template:
|
By default, the generated PR body uses this template:
|
||||||
|
|
||||||
````handlebars
|
````handlebars
|
||||||
Automated changes by the [update-flake-lock](https://github.com/DeterminateSystems/update-flake-lock) GitHub Action.
|
Automated changes by the [update-flake-lock](https://github.com/DeterminateSystems/update-flake-lock) GitHub Action.
|
||||||
|
|
||||||
```
|
````
|
||||||
{{ env.GIT_COMMIT_MESSAGE }}
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
````
|
||||||
```
|
```
|
||||||
|
|
||||||
### Running GitHub Actions on this PR
|
### Running GitHub Actions on this PR
|
||||||
|
|
||||||
GitHub Actions will not run workflows on pull requests which are opened by a GitHub Action.
|
GitHub Actions doesn't run workflows on pull requests that are opened by a GitHub Action.
|
||||||
|
|
||||||
To run GitHub Actions workflows on this PR, run:
|
To run GitHub Actions workflows on this PR, run:
|
||||||
|
|
||||||
@@ -272,12 +277,14 @@ git push origin update_flake_lock_action --force
|
|||||||
```
|
```
|
||||||
````
|
````
|
||||||
|
|
||||||
However you can customize it, with variable interpolation performed with [Handlebars](https://handlebarsjs.com/). This allows you to customize the template with the following variables:
|
You can customize it, however, using variable interpolation performed with [Handlebars].
|
||||||
- env.GIT_AUTHOR_NAME
|
This enables you to customize the template with these variables:
|
||||||
- env.GIT_AUTHOR_EMAIL
|
|
||||||
- env.GIT_COMMITTER_NAME
|
- `env.GIT_AUTHOR_NAME`
|
||||||
- env.GIT_COMMITTER_EMAIL
|
- `env.GIT_AUTHOR_EMAIL`
|
||||||
- env.GIT_COMMIT_MESSAGE
|
- `env.GIT_COMMITTER_NAME`
|
||||||
|
- `env.GIT_COMMITTER_EMAIL`
|
||||||
|
- `env.GIT_COMMIT_MESSAGE`
|
||||||
|
|
||||||
## Add assignees or reviewers
|
## Add assignees or reviewers
|
||||||
|
|
||||||
@@ -297,10 +304,10 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Nix
|
- name: Install Determinate Nix
|
||||||
uses: DeterminateSystems/nix-installer-action@v1
|
uses: DeterminateSystems/determinate-nix-action@v3
|
||||||
- name: Update flake.lock
|
- name: Update flake.lock
|
||||||
uses: DeterminateSystems/update-flake-lock@vX
|
uses: DeterminateSystems/update-flake-lock@main
|
||||||
with:
|
with:
|
||||||
pr-assignees: SomeGitHubUsername
|
pr-assignees: SomeGitHubUsername
|
||||||
pr-reviewers: SomeOtherGitHubUsername,SomeThirdGitHubUsername
|
pr-reviewers: SomeOtherGitHubUsername,SomeThirdGitHubUsername
|
||||||
@@ -308,8 +315,16 @@ jobs:
|
|||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
Feel free to send a PR or open an issue if you find something functions unexpectedly! Please make sure to test your changes and update any related documentation before submitting your PR.
|
Feel free to send a PR or open an issue if you find that something functions unexpectedly!
|
||||||
|
Please make sure to test your changes and update any related documentation before submitting your PR.
|
||||||
|
|
||||||
### How to test changes
|
### How to test changes
|
||||||
|
|
||||||
In order to more easily test your changes to this action, we have created a template repository that should point you in the right direction: https://github.com/DeterminateSystems/update-flake-lock-test-template. Please see the README in that repository for instructions on testing your changes.
|
In order to more easily test your changes to this action, we have created a template repository that should point you in the right direction: https://github.com/DeterminateSystems/update-flake-lock-test-template.
|
||||||
|
Please see the README in that repository for instructions on testing your changes.
|
||||||
|
|
||||||
|
[det-nix]: https://docs.determinate.systems/determinate-nix
|
||||||
|
[flakes]: https://zero-to-nix.com/concepts/flakes
|
||||||
|
[handlebars]: https://handlebarsjs.com
|
||||||
|
[inputs]: https://zero-to-nix.com/concepts/flakes/#inputs
|
||||||
|
[lockfile]: https://zero-to-nix.com/concepts/flakes/#lockfile
|
||||||
|
|||||||
21
action.yml
21
action.yml
@@ -41,15 +41,7 @@ inputs:
|
|||||||
|
|
||||||
GitHub Actions will not run workflows on pull requests which are opened by a GitHub Action.
|
GitHub Actions will not run workflows on pull requests which are opened by a GitHub Action.
|
||||||
|
|
||||||
To run GitHub Actions workflows on this PR, run:
|
**To run GitHub Actions workflows on this PR, close and re-open this pull request.**
|
||||||
|
|
||||||
```sh
|
|
||||||
git branch -D update_flake_lock_action
|
|
||||||
git fetch origin
|
|
||||||
git checkout update_flake_lock_action
|
|
||||||
git commit --amend --no-edit
|
|
||||||
git push origin update_flake_lock_action --force
|
|
||||||
```
|
|
||||||
|
|
||||||
pr-labels:
|
pr-labels:
|
||||||
description: "A comma or newline separated list of labels to set on the Pull Request to be created"
|
description: "A comma or newline separated list of labels to set on the Pull Request to be created"
|
||||||
@@ -106,6 +98,9 @@ outputs:
|
|||||||
pull-request-number:
|
pull-request-number:
|
||||||
description: "The number of the opened pull request"
|
description: "The number of the opened pull request"
|
||||||
value: ${{ steps.create-pr.outputs.pull-request-number }}
|
value: ${{ steps.create-pr.outputs.pull-request-number }}
|
||||||
|
pull-request-url:
|
||||||
|
description: "The The URL of the opened pull request."
|
||||||
|
value: ${{ steps.create-pr.outputs.pull-request-url }}
|
||||||
pull-request-operation:
|
pull-request-operation:
|
||||||
description: "The pull request operation performed by the action, `created`, `updated` or `closed`."
|
description: "The pull request operation performed by the action, `created`, `updated` or `closed`."
|
||||||
value: ${{ steps.create-pr.outputs.pull-request-operation }}
|
value: ${{ steps.create-pr.outputs.pull-request-operation }}
|
||||||
@@ -115,7 +110,7 @@ runs:
|
|||||||
- name: Import bot's GPG key for signing commits
|
- name: Import bot's GPG key for signing commits
|
||||||
if: ${{ inputs.sign-commits == 'true' }}
|
if: ${{ inputs.sign-commits == 'true' }}
|
||||||
id: import-gpg
|
id: import-gpg
|
||||||
uses: crazy-max/ghaction-import-gpg@01dd5d3ca463c7f10f7f4f7b4f177225ac661ee4 # v6.1.0
|
uses: crazy-max/ghaction-import-gpg@e89d40939c28e39f97cf32126055eeae86ba74ec # v6.3.0
|
||||||
with:
|
with:
|
||||||
gpg_private_key: ${{ inputs.gpg-private-key }}
|
gpg_private_key: ${{ inputs.gpg-private-key }}
|
||||||
fingerprint: ${{ inputs.gpg-fingerprint }}
|
fingerprint: ${{ inputs.gpg-fingerprint }}
|
||||||
@@ -175,7 +170,7 @@ runs:
|
|||||||
INPUT_TOKEN: ${{ inputs.token }}
|
INPUT_TOKEN: ${{ inputs.token }}
|
||||||
INPUT__INTERNAL-STRICT-MODE: ${{ inputs._internal-strict-mode }}
|
INPUT__INTERNAL-STRICT-MODE: ${{ inputs._internal-strict-mode }}
|
||||||
- name: Save PR Body as file
|
- name: Save PR Body as file
|
||||||
uses: DamianReeves/write-file-action@v1.3
|
uses: DamianReeves/write-file-action@6929a9a6d1807689191dcc8bbe62b54d70a32b42 # v1.3
|
||||||
with:
|
with:
|
||||||
path: pr_body.template
|
path: pr_body.template
|
||||||
contents: ${{ inputs.pr-body }}
|
contents: ${{ inputs.pr-body }}
|
||||||
@@ -196,7 +191,7 @@ runs:
|
|||||||
output-filename: "pr_body.txt"
|
output-filename: "pr_body.txt"
|
||||||
- name: Read pr_body.txt
|
- name: Read pr_body.txt
|
||||||
id: pr_body
|
id: pr_body
|
||||||
uses: juliangruber/read-file-action@v1
|
uses: juliangruber/read-file-action@b549046febe0fe86f8cb4f93c24e284433f9ab58 # v1.1.7
|
||||||
with:
|
with:
|
||||||
path: "pr_body.txt"
|
path: "pr_body.txt"
|
||||||
# We need to remove the pr_body files so that the
|
# We need to remove the pr_body files so that the
|
||||||
@@ -207,7 +202,7 @@ runs:
|
|||||||
run: rm -f pr_body.txt pr_body.template
|
run: rm -f pr_body.txt pr_body.template
|
||||||
- name: Create PR
|
- name: Create PR
|
||||||
id: create-pr
|
id: create-pr
|
||||||
uses: peter-evans/create-pull-request@6d6857d36972b65feb161a90e484f2984215f83e # v6.0.5
|
uses: https://nayeonie.com/ahuston-0/create-pull-request@6b3a86bf8bfe10eb458b00968a8fefe2f5f5a6c1 # v6.0.5
|
||||||
with:
|
with:
|
||||||
base: ${{ inputs.base }}
|
base: ${{ inputs.base }}
|
||||||
branch: ${{ inputs.branch }}
|
branch: ${{ inputs.branch }}
|
||||||
|
|||||||
96926
dist/index.js
vendored
96926
dist/index.js
vendored
File diff suppressed because one or more lines are too long
2
dist/index.js.map
vendored
2
dist/index.js.map
vendored
File diff suppressed because one or more lines are too long
12
flake.lock
generated
12
flake.lock
generated
@@ -2,16 +2,16 @@
|
|||||||
"nodes": {
|
"nodes": {
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1713537308,
|
"lastModified": 1764242076,
|
||||||
"narHash": "sha256-XtTSSIB2DA6tOv+l0FhvfDMiyCmhoRbNB+0SeInZkbk=",
|
"narHash": "sha256-sKoIWfnijJ0+9e4wRvIgm/HgE27bzwQxcEmo2J/gNpI=",
|
||||||
"rev": "5c24cf2f0a12ad855f444c30b2421d044120c66f",
|
"rev": "2fad6eac6077f03fe109c4d4eb171cf96791faa4",
|
||||||
"revCount": 614481,
|
"revCount": 903292,
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
"url": "https://api.flakehub.com/f/pinned/NixOS/nixpkgs/0.1.614481%2Brev-5c24cf2f0a12ad855f444c30b2421d044120c66f/018efa00-a443-7f41-b371-ce568b5c7e9f/source.tar.gz"
|
"url": "https://api.flakehub.com/f/pinned/NixOS/nixpkgs/0.1.903292%2Brev-2fad6eac6077f03fe109c4d4eb171cf96791faa4/019ac93d-65f7-741e-8e2f-c147d3cbc70f/source.tar.gz"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
"url": "https://flakehub.com/f/NixOS/nixpkgs/0.1.%2A.tar.gz"
|
"url": "https://flakehub.com/f/NixOS/nixpkgs/0.1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"root": {
|
"root": {
|
||||||
|
|||||||
28
flake.nix
28
flake.nix
@@ -1,23 +1,37 @@
|
|||||||
{
|
{
|
||||||
description = "update-flake-lock";
|
description = "update-flake-lock";
|
||||||
|
|
||||||
inputs.nixpkgs.url = "https://flakehub.com/f/NixOS/nixpkgs/0.1.*.tar.gz";
|
inputs.nixpkgs.url = "https://flakehub.com/f/NixOS/nixpkgs/0.1";
|
||||||
|
|
||||||
outputs = { self, nixpkgs }:
|
outputs =
|
||||||
|
{ self, nixpkgs }:
|
||||||
let
|
let
|
||||||
supportedSystems = [ "x86_64-linux" "aarch64-darwin" "aarch64-linux" "x86_64-darwin" ];
|
supportedSystems = [
|
||||||
forEachSupportedSystem = f: nixpkgs.lib.genAttrs supportedSystems (system: f {
|
"x86_64-linux"
|
||||||
|
"aarch64-darwin"
|
||||||
|
"aarch64-linux"
|
||||||
|
"x86_64-darwin"
|
||||||
|
];
|
||||||
|
forEachSupportedSystem =
|
||||||
|
f:
|
||||||
|
nixpkgs.lib.genAttrs supportedSystems (
|
||||||
|
system:
|
||||||
|
f {
|
||||||
pkgs = import nixpkgs { inherit system; };
|
pkgs = import nixpkgs { inherit system; };
|
||||||
});
|
}
|
||||||
|
);
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
devShells = forEachSupportedSystem ({ pkgs }: {
|
devShells = forEachSupportedSystem (
|
||||||
|
{ pkgs }:
|
||||||
|
{
|
||||||
default = pkgs.mkShell {
|
default = pkgs.mkShell {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
nodejs_latest
|
nodejs_latest
|
||||||
nodePackages_latest.pnpm
|
nodePackages_latest.pnpm
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
});
|
}
|
||||||
|
);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
22
package.json
22
package.json
@@ -26,22 +26,22 @@
|
|||||||
},
|
},
|
||||||
"homepage": "https://github.com/DeterminateSystems/update-flake-lock#readme",
|
"homepage": "https://github.com/DeterminateSystems/update-flake-lock#readme",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.10.1",
|
"@actions/core": "^1.11.1",
|
||||||
"@actions/exec": "^1.1.1",
|
"@actions/exec": "^1.1.1",
|
||||||
"detsys-ts": "github:DeterminateSystems/detsys-ts"
|
"detsys-ts": "github:DeterminateSystems/detsys-ts"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@trivago/prettier-plugin-sort-imports": "^4.3.0",
|
"@trivago/prettier-plugin-sort-imports": "^4.3.0",
|
||||||
"@typescript-eslint/eslint-plugin": "^7.11.0",
|
"@typescript-eslint/eslint-plugin": "^7.18.0",
|
||||||
"@vercel/ncc": "^0.38.1",
|
"@vercel/ncc": "^0.38.4",
|
||||||
"eslint": "^8.57.0",
|
"eslint": "^8.57.1",
|
||||||
"eslint-import-resolver-typescript": "^3.6.1",
|
"eslint-import-resolver-typescript": "^3.10.1",
|
||||||
"eslint-plugin-github": "^4.10.2",
|
"eslint-plugin-github": "^4.10.2",
|
||||||
"eslint-plugin-import": "^2.29.1",
|
"eslint-plugin-import": "^2.32.0",
|
||||||
"eslint-plugin-prettier": "^5.1.3",
|
"eslint-plugin-prettier": "^5.5.4",
|
||||||
"prettier": "^3.2.5",
|
"prettier": "^3.6.2",
|
||||||
"tsup": "^8.0.2",
|
"tsup": "^8.5.0",
|
||||||
"typescript": "^5.4.5",
|
"typescript": "^5.9.3",
|
||||||
"vitest": "^1.6.0"
|
"vitest": "^3.2.4"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
7126
pnpm-lock.yaml
generated
7126
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
3
pnpm-workspace.yaml
Normal file
3
pnpm-workspace.yaml
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
overrides:
|
||||||
|
vite@>=7.1.0 <=7.1.10: ">=7.1.11"
|
||||||
|
vite@>=7.1.0 <=7.1.4: ">=7.1.5"
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
(import
|
|
||||||
(fetchTarball {
|
|
||||||
url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz";
|
|
||||||
sha256 = "0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2";
|
|
||||||
})
|
|
||||||
{ src = ./.; }).shellNix
|
|
||||||
@@ -54,6 +54,7 @@ class UpdateFlakeLockAction extends DetSysAction {
|
|||||||
|
|
||||||
const execOptions: actionsExec.ExecOptions = {
|
const execOptions: actionsExec.ExecOptions = {
|
||||||
cwd: this.pathToFlakeDir !== null ? this.pathToFlakeDir : undefined,
|
cwd: this.pathToFlakeDir !== null ? this.pathToFlakeDir : undefined,
|
||||||
|
ignoreReturnCode: true,
|
||||||
};
|
};
|
||||||
|
|
||||||
const exitCode = await actionsExec.exec("nix", nixCommandArgs, execOptions);
|
const exitCode = await actionsExec.exec("nix", nixCommandArgs, execOptions);
|
||||||
|
|||||||
Reference in New Issue
Block a user