mirror of
https://github.com/nix-community/awesome-nix
synced 2024-11-13 00:47:06 +00:00
194 lines
12 KiB
Markdown
194 lines
12 KiB
Markdown
# Awesome Nix [![Awesome](https://awesome.re/badge.svg)](https://awesome.re) [<img src="https://nixos.org/logo/nixos-logo-only-hires.png" width="200" align="right" alt="NixOS">](https://nixos.org)
|
|
|
|
> A curated list of the best resources in the Nix community.
|
|
|
|
[Nix](https://github.com/nixos/nix) is a powerful package manager for Linux and other Unix systems that makes package management reliable and reproducible.
|
|
|
|
*Please read the [contribution guidelines](CONTRIBUTING.md) before contributing.*
|
|
|
|
## Contents
|
|
|
|
* [Resources](#resources)
|
|
* [Learning](#learning)
|
|
* [Discovery](#discovery)
|
|
* [Newsletters](#newsletters)
|
|
* [Installation Media](#installation-media)
|
|
* [Channel History](#channel-history)
|
|
* [Deployment Tools](#deployment-tools)
|
|
* [Command-Line Tools](#command-line-tools)
|
|
* [Development](#development)
|
|
* [Programming Languages](#programming-languages)
|
|
* [Arduino](#arduino)
|
|
* [Crystal](#crystal)
|
|
* [Elm](#elm)
|
|
* [Haskell](#haskell)
|
|
* [Node.js](#nodejs)
|
|
* [PHP](#php)
|
|
* [PureScript](#purescript)
|
|
* [Python](#python)
|
|
* [Ruby](#ruby)
|
|
* [Rust](#rust)
|
|
* [Scala](#scala)
|
|
* [NixOS Modules](#nixos-modules)
|
|
* [Overlays](#overlays)
|
|
* [Community](#community)
|
|
|
|
## Resources
|
|
|
|
### Learning
|
|
|
|
* [How to Learn Nix](https://ianthehenry.com/posts/how-to-learn-nix/) - It's like a Let's Play, but for obscure software documentation.
|
|
* [Nix Notes](https://github.com/noteed/nix-notes) - A collection of short notes about Nix, each contributing to the same virtual machine image.
|
|
* [Nix Pills](https://nixos.org/nixos/nix-pills/) - The best way to learn, with examples.
|
|
* [Nix Shorts](https://github.com/justinwoo/nix-shorts/) - A collection of short notes about Nix.
|
|
* [nix.dev](https://nix.dev/) - An opinionated guide for developers about getting things done using the Nix ecosystem.
|
|
* [Tour of Nix](https://nixcloud.io/tour) - An online interactive tutorial on Nix language constructs.
|
|
|
|
### Discovery
|
|
|
|
* [Hound](https://search.nix.gsc.io) - Handily search across all or selected Nix-related repositories.
|
|
* [Nix Package Versions](https://lazamar.co.uk/nix-versions/) - Find all versions of a package that were available in a channel and the revision you can download it from.
|
|
* [Pkgs on Nix](https://pkgs.on-nix.com/) - A database with Nix packages at all versions, from all channels.
|
|
|
|
### Newsletters
|
|
|
|
* [NixOS Weekly](https://weekly.nixos.org/) - *The* newsletter to stay informed about community updates.
|
|
|
|
## Installation Media
|
|
|
|
* [nixos-generators](https://github.com/nix-community/nixos-generators) - Take a NixOS config and build multiple different images types including VirtualBox VMs, Azure images, and installation ISOs.
|
|
* [nixos-up](https://github.com/samuela/nixos-up) - Super easy NixOS installer that can be used from the installation ISO.
|
|
|
|
## Channel History
|
|
|
|
* [Channel History](https://channels.nix.gsc.io) - Get historical git commits for Nix channels.
|
|
* [Nix Infra Status](https://status.nixos.org) - Get the age and current git commit of each Nix channel.
|
|
* [nixpkgs PR tracker](https://nixpk.gs/pr-tracker.html) - A tracker for whether a PR has made it into a channel yet.
|
|
|
|
## Deployment Tools
|
|
|
|
* [Colmena](https://github.com/zhaofengli/colmena) - A simple, stateless NixOS deployment tool modeled after NixOps and morph.
|
|
* [deploy-rs](https://github.com/serokell/deploy-rs) - A simple multi-profile Nix-flake deploy tool.
|
|
* [krops](https://cgit.krebsco.de/krops/about/) - A lightweight toolkit to deploy NixOS systems, remotely or locally.
|
|
* [KubeNix](https://github.com/xtruder/kubenix) - A Kubernetes resource builder using Nix.
|
|
* [KuberNix](https://github.com/saschagrunert/kubernix) - Single-dependency Kubernetes clusters via Nix packages.
|
|
* [morph](https://github.com/DBCDK/morph) - A tool for managing existing NixOS hosts.
|
|
* [Nixery](https://github.com/google/nixery) - A Docker-compatible container registry which builds images ad-hoc via Nix.
|
|
* [NixOps](https://github.com/NixOS/nixops) - The official Nix deployment tool, compatible with AWS, Hetzner, and more.
|
|
* [nixos-shell](https://github.com/Mic92/nixos-shell) - Simple headless VM configuration using Nix (similar to Vagrant).
|
|
* [pushnix](https://github.com/arnarg/pushnix) - Simple cli utility that pushes NixOS configuration and triggers a rebuild using ssh.
|
|
* [terraform-nixos](https://github.com/tweag/terraform-nixos) - A set of Terraform modules designed to deploy NixOS.
|
|
* [terranix](https://terranix.org) - Use Nix and the NixOS module system to write your Terraform code.
|
|
|
|
## Command-Line Tools
|
|
|
|
* [comma](https://github.com/Shopify/comma) - Quickly run any binary; wraps together `nix run` and `nix-index`.
|
|
* [nixfmt](https://github.com/serokell/nixfmt) - A formatter for Nix code, intended to easily apply a uniform style.
|
|
* [nixpkgs-fmt](https://github.com/nix-community/nixpkgs-fmt) - Nix code formatter for nixpkgs.
|
|
* [nixpkgs-hammering](https://github.com/jtojnar/nixpkgs-hammering) - Beat your package expressions into a shape.
|
|
* [nix-alien](https://github.com/thiagokokada/nix-alien) - Run unpatched binaries on Nix/NixOS easily.
|
|
* [nix-diff](https://github.com/Gabriel439/nix-diff) - A tool to explain why two Nix derivations differ.
|
|
* [nix-index](https://github.com/bennofs/nix-index) - Quickly locate Nix packages with specific files.
|
|
* [nix-prefetch](https://github.com/msteen/nix-prefetch) - A universal tool for updating source checksums.
|
|
* [nix-tree](https://github.com/utdemir/nix-tree) - Interactively browse the dependency graph of Nix derivations.
|
|
|
|
## Development
|
|
|
|
* [Arion](https://github.com/hercules-ci/arion) - Run `docker-compose` with help from Nix/NixOS.
|
|
* [cached-nix-shell](https://github.com/xzfc/cached-nix-shell) - A `nix-shell` replacement that uses caching to open subsequent shells quickly.
|
|
* [Cachix](https://cachix.org/) - Hosted binary cache service; free for open-source projects.
|
|
* [devshell](https://github.com/numtide/devshell) - `mkShell` with extra bits and a toml config option to be able to onboard non-nix users.
|
|
* [flake-utils](https://github.com/numtide/flake-utils) - Pure Nix flake utility functions to help with writing flakes.
|
|
* [gitignore.nix](https://github.com/hercules-ci/gitignore.nix) - The most feature-complete and easy-to-use `.gitignore` integration.
|
|
* [lorri](https://github.com/target/lorri/) - A much better `nix-shell` for development that augments direnv.
|
|
* [niv](https://github.com/nmattia/niv/) - Easy dependency management for Nix projects with package pinning.
|
|
* [nix-direnv](https://github.com/nix-community/nix-direnv) - A fast loader and flake-compliant configuration for the direnv environment auto-loader.
|
|
* [nixpkgs-review](https://github.com/Mic92/nixpkgs-review) - The best tool to verify that a pull-request in Nixpkgs is building properly.
|
|
* [pre-commit-hooks.nix](https://github.com/cachix/pre-commit-hooks.nix) - Run linters/formatters at commit time and on your CI.
|
|
|
|
## Programming Languages
|
|
|
|
### Arduino
|
|
|
|
* [nixduino](https://github.com/boredom101/nixduino) - Nix-based tool to help build Arduino sketches.
|
|
|
|
### Crystal
|
|
|
|
* [crystal2nix](https://github.com/nix-community/crystal2nix) - Convert `shard.lock` into Nix expressions.
|
|
|
|
### Elm
|
|
|
|
* [elm2nix](https://github.com/hercules-ci/elm2nix) - Convert `elm.json` into Nix expressions.
|
|
|
|
### Haskell
|
|
|
|
* [cabal2nix](https://github.com/NixOS/cabal2nix) - Converts a Cabal file into a Nix build expression.
|
|
* [haskell.nix](https://github.com/input-output-hk/haskell.nix) - Alternative Haskell Infrastructure for Nixpkgs.
|
|
* [nix-haskell-mode](https://github.com/matthewbauer/nix-haskell-mode) - Automatic Haskell setup in Emacs.
|
|
* [nixkell](https://github.com/pwm/nixkell) - A Haskell project template using Nix and direnv.
|
|
* [stack2nix](https://github.com/input-output-hk/stack2nix) - Generate nix expressions for Haskell projects.
|
|
|
|
### Node.js
|
|
|
|
* [Napalm](https://github.com/nmattia/napalm) - Support for building npm packages in Nix with a lightweight npm registry.
|
|
* [node2nix](https://github.com/svanderburg/node2nix) - Generate Nix expression from a `package.json` (or `package-lock.json`) (to be stored as files).
|
|
* [npmlock2nix](https://github.com/tweag/npmlock2nix) - Generate Nix expressions from a `package-lock.json` (in-memory), primarily for web projects.
|
|
* [yarn2nix](https://github.com/nix-community/yarn2nix) - Generate Nix expressions from a `yarn.lock` file.
|
|
|
|
### PHP
|
|
|
|
* [composer2nix](https://github.com/svanderburg/composer2nix) - Generate Nix expressions to build composer packages.
|
|
* [composition-c4](https://github.com/fossar/composition-c4) - Support for building composer packages from a `composer.lock` (using IFD).
|
|
* [nix-phps](https://github.com/fossar/nix-phps) - Flake containing old and unmaintained PHP versions (intended for CI use).
|
|
|
|
### PureScript
|
|
|
|
* [Easy PureScript Nix](https://github.com/justinwoo/easy-purescript-nix) - A project to easily use PureScript and other tools with Nix.
|
|
|
|
### Python
|
|
|
|
* [mach-nix](https://github.com/DavHau/mach-nix) - Tool to create highly reproducible python environments.
|
|
* [poetry2nix](https://github.com/nix-community/poetry2nix) - Build Python packages directly from [Poetry's](https://python-poetry.org/) `poetry.lock`. No conversion step needed.
|
|
* [pypi2nix](https://github.com/nix-community/pypi2nix) - Generate Nix expressions for Python packages.
|
|
|
|
### Ruby
|
|
|
|
* [Bundix](https://github.com/nix-community/bundix) - Generates a Nix expression for your Bundler-managed application.
|
|
|
|
### Rust
|
|
|
|
* [fenix](https://github.com/nix-community/fenix) - Rust toolchains and Rust analyzer nightly for nix.
|
|
* [naersk](https://github.com/nmattia/naersk) - Build Rust packages directly from `Cargo.lock`. No conversion step needed.
|
|
* [nix-cargo-integration](https://github.com/yusdacra/nix-cargo-integration) - A library that allows easy and effortless integration for Cargo projects.
|
|
* [nixpkgs-mozilla](https://github.com/mozilla/nixpkgs-mozilla) - Mozilla's overlay with Rust toolchains and Firefox.
|
|
* [rust-nix-templater](https://github.com/yusdacra/rust-nix-templater) - Generates Nix build and development files for Rust projects.
|
|
* [rust-overlay](https://github.com/oxalica/rust-overlay) - Pure and reproducible nix overlay of binary distributed Rust toolchains.
|
|
|
|
### Scala
|
|
|
|
* [sbt-derivation](https://github.com/zaninime/sbt-derivation) - mkDerivation for sbt, similar to buildGoModule.
|
|
* [sbt-nix.g8](https://github.com/gvolpe/sbt-nix.g8) - giter8 template for new Scala projects with Nix support.
|
|
|
|
## NixOS Modules
|
|
|
|
* [musnix](https://github.com/musnix/musnix) - Do real-time audio work in NixOS.
|
|
* [nixcloud-webservices](https://github.com/nixcloud/nixcloud-webservices) - A Nixpkgs extension with a focus on ease of deployment of web-related technologies.
|
|
* [Simple Nixos Mailserver](https://gitlab.com/simple-nixos-mailserver/nixos-mailserver) - A complete mailserver, managed with NixOS modules.
|
|
|
|
## Overlays
|
|
|
|
* [awesome-nix-hpc](https://github.com/freuk/awesome-nix-hpc) - High Performance Computing package sets.
|
|
* [Home Manager](https://github.com/nix-community/home-manager) - Manage your user configuration just like NixOS.
|
|
* [nix-bitcoin](https://github.com/fort-nix/nix-bitcoin) - Nix packages and NixOS modules for Bitcoin nodes with higher-layer protocols with an emphasis on security.
|
|
* [nix-darwin](https://github.com/LnL7/nix-darwin) - Manage macOS configuration just like on NixOS.
|
|
* [nixpkgs-wayland](https://github.com/nix-community/nixpkgs-wayland) - Bleeding-edge Wayland packages.
|
|
* [NUR](https://github.com/nix-community/NUR/) - Nix User Repositories. The mother of all overlays, allowing access to user repositories and installing packages via attributes.
|
|
|
|
## Community
|
|
|
|
* [#nix:nixos.org](https://matrix.to/#/#nix:nixos.org)
|
|
* [#nixos on Libera.Chat](https://web.libera.chat/?nick=Guest?#nixos)
|
|
* [Discord - Nix/Nixos (Unofficial)](https://discord.gg/BMUCQx6)
|
|
* [Discourse](https://discourse.nixos.org/) - The best place to get help and discuss Nix-related topics.
|
|
* [NixCon](https://nixcon.org/) - The annual community conference for contributors and users of Nix and NixOS.
|
|
* [Wiki (Unofficial)](https://nixos.wiki)
|