determinate-nix-action/tools/README.template.md

118 lines
5.4 KiB
Markdown
Raw Permalink Normal View History

2025-05-15 13:38:56 +01:00
<p align="center">
<a href="https://determinate.systems" target="_blank"><img src="https://raw.githubusercontent.com/determinatesystems/.github/main/.github/banner.jpg"></a>
</p>
<p align="center">
&nbsp;<a href="https://determinate.systems/discord" target="_blank"><img alt="Discord" src="https://img.shields.io/discord/1116012109709463613?style=for-the-badge&logo=discord&logoColor=%23ffffff&label=Discord&labelColor=%234253e8&color=%23e4e2e2"></a>&nbsp;
&nbsp;<a href="https://bsky.app/profile/determinate.systems" target="_blank"><img alt="Bluesky" src="https://img.shields.io/badge/Bluesky-0772D8?style=for-the-badge&logo=bluesky&logoColor=%23ffffff"></a>&nbsp;
&nbsp;<a href="https://hachyderm.io/@determinatesystems" target="_blank"><img alt="Mastodon" src="https://img.shields.io/badge/Mastodon-6468fa?style=for-the-badge&logo=mastodon&logoColor=%23ffffff"></a>&nbsp;
&nbsp;<a href="https://twitter.com/DeterminateSys" target="_blank"><img alt="Twitter" src="https://img.shields.io/badge/Twitter-303030?style=for-the-badge&logo=x&logoColor=%23ffffff"></a>&nbsp;
&nbsp;<a href="https://www.linkedin.com/company/determinate-systems" target="_blank"><img alt="LinkedIn" src="https://img.shields.io/badge/LinkedIn-1667be?style=for-the-badge&logo=linkedin&logoColor=%23ffffff"></a>&nbsp;
</p>
# ️❄️ Determinate Nix Action
2025-05-14 17:20:48 -04:00
2025-05-16 12:39:52 -04:00
[Determinate] is the best way to use Nix on macOS, WSL, and Linux.
2025-05-14 17:20:48 -04:00
It is an end-to-end toolchain for using Nix, from installation to collaboration to deployment.
2025-05-16 12:39:52 -04:00
Based on the [Determinate Nix Installer][nix-installer] and its corresponding [Nix Installer Action][nix-installer-action], responsible for over tens of thousands of Nix installs daily.
2025-05-14 17:20:48 -04:00
> [!NOTE]
>
2025-05-16 12:39:52 -04:00
> **Why a different Action?**
>
2025-05-16 12:39:52 -04:00
> We created a new Action to synchronize version tags to [Determinate Nix][det-nix] releases.
> GitHub Actions are tagged with the specific version, like `v3.5.2`, with a moving `v3` tag for the major version.
2025-05-16 12:39:52 -04:00
> We needed a fresh tag namespace since `nix-installer-action` already has a `v3` tag.
2025-05-15 13:38:56 +01:00
## 🫶 Platform support
2025-05-14 17:20:48 -04:00
2025-05-15 13:38:56 +01:00
-**Accelerated KVM** on open source projects and larger runners. See [GitHub's announcement](https://github.blog/changelog/2023-02-23-hardware-accelerated-android-virtualization-on-actions-windows-and-linux-larger-hosted-runners/) for more info.
- 🐧 Linux, x86_64, aarch64, and i686
- 🍏 macOS, x86_64 and aarch64
- 🪟 WSL2, x86_64 and aarch64
- 🐋 Containers, ARC, and Act
- 🐙 GitHub Enterprise Server
- 💁 GitHub Hosted, self-hosted, and long running Actions Runners
2025-05-14 17:20:48 -04:00
2025-05-15 13:38:56 +01:00
## ️🔧 Usage
2025-05-14 17:20:48 -04:00
2025-05-15 15:09:41 -04:00
Here's an example Actions workflow configuration that uses `determinate-nix-action`:
2025-05-14 17:20:48 -04:00
```yaml
on:
pull_request:
push:
branches: [main]
jobs:
2025-05-15 15:09:41 -04:00
build-pkg:
name: Build Nix package
2025-05-14 17:20:48 -04:00
runs-on: ubuntu-latest
permissions:
2025-05-15 15:09:41 -04:00
id-token: write
contents: read
2025-05-14 17:20:48 -04:00
steps:
- uses: actions/checkout@<!-- checkout_action_tag -->
- uses: DeterminateSystems/determinate-nix-action@main # or <!-- version --> to pin to a release
- run: nix build .
```
2025-05-15 15:09:41 -04:00
> [!IMPORTANT]
2025-05-15 16:03:22 -04:00
> If you use [FlakeHub], you need to add a `permissions` block like the one in the example above or else Determinate Nix can't authenticate with FlakeHub or [FlakeHub Cache][cache].
2025-05-15 15:09:41 -04:00
2025-05-16 12:39:52 -04:00
## 📌 Version pinning: lock it down!
2025-05-14 17:20:48 -04:00
2025-05-16 12:39:52 -04:00
### Why pin your Action?
2025-05-14 17:20:48 -04:00
Unlike `DeterminateSystems/nix-installer-action`, we fully support explicit version pinning for maximum consistency.
2025-05-16 12:39:52 -04:00
This Action is **automatically tagged** for every Determinate Nix release, giving you complete control over your CI environment:
2025-05-14 17:20:48 -04:00
2025-05-15 13:38:56 +01:00
📍 Pinning to `DeterminateSystems/determinate-nix-action@<!-- version -->` guarantees:
- Same `nix-installer-action` revision every time
- Consistent Determinate Nix <!-- version --> installation
- Reproducible CI workflows, even years later
2025-05-15 13:38:56 +01:00
✨ Using `@main` instead? You'll:
2025-05-14 17:20:48 -04:00
- Always get the latest Determinate Nix release
- Occasionally participate in phased rollouts (helping us test new releases!)
> [!IMPORTANT]
2025-05-16 12:39:52 -04:00
> Set up [Dependabot] to stay current with Determinate Nix releases without sacrificing stability.
2025-05-14 17:20:48 -04:00
2025-05-16 12:39:52 -04:00
### 🤖 Automate updates with Dependabot
2025-05-14 17:20:48 -04:00
2025-05-16 12:39:52 -04:00
Keep your GitHub Actions fresh without manual work! Create `.github/dependabot.yml` with:
2025-05-14 17:20:48 -04:00
```yaml
version: 2
updates:
2025-05-16 12:39:52 -04:00
- package-ecosystem: github-actions
directory: /
2025-05-14 17:20:48 -04:00
schedule:
2025-05-16 12:39:52 -04:00
interval: weekly
2025-05-14 17:20:48 -04:00
```
2025-05-15 13:38:56 +01:00
## ️⚙️ Configuration
2025-05-14 17:20:48 -04:00
<!-- table -->
2025-05-16 12:39:52 -04:00
## 🛟 Need help? We're here for you!
2025-05-15 13:38:56 +01:00
We're committed to making your experience with Determinate Nix as smooth as possible. If you encounter any issues or have questions, here's how to reach us:
2025-05-14 17:20:48 -04:00
2025-05-15 13:38:56 +01:00
- 🐛 **Found a bug?** [Open an issue](https://github.com/DeterminateSystems/determinate-nix-action/issues/new) on GitHub
- 💬 **Want to chat?** Join our [Discord community](https://determinate.systems/discord) for quick help and discussions
- 📧 **Need direct support?** Email us at [support@determinate.systems](mailto:support@determinate.systems)
2025-05-14 17:20:48 -04:00
🤝 **Looking for enterprise support?** We offer dedicated support contracts and shared Slack channels for organizations requiring priority assistance. [Contact us](mailto:support@determinate.systems) to learn more.
2025-05-15 15:09:41 -04:00
2025-05-15 16:03:22 -04:00
[cache]: https://flakehub.com/cache
2025-05-16 12:39:52 -04:00
[dependabot]: https://github.com/dependabot
[det-nix]: https://docs.determinate.systems/determinate-nix
[determinate]: https://docs.determinate.systems
2025-05-15 15:09:41 -04:00
[flakehub]: https//flakehub.com
2025-05-16 12:39:52 -04:00
[nix-installer]: https://github.com/DeterminateSystems/nix-installer
[nix-installer-action]: https://github.com/DeterminateSystems/nix-installer-action