Monorepo for sharing my most commonly used Nix expressions between hostsç
Find a file
2024-02-07 01:11:15 +00:00
.github build(deps): bump cachix/cachix-action from 13 to 14 2024-01-15 01:38:44 +00:00
npins [CI]: update npins 2024-02-07 01:11:15 +00:00
patches pkgs: add rofi-calc-wayland and rofi-emoji-wayland 2023-11-03 19:01:08 +03:00
pkgs mov-cli: use my own fork until upsteam is fixed 2024-01-21 14:04:21 +03:00
.envrc flake: direnv 2023-11-07 16:02:21 +03:00
.gitignore initial commit 2023-11-03 10:25:58 +03:00
default.nix flake: add flake-compat 2023-11-03 12:40:30 +03:00
flake.lock [CI]: update flake inputs 2024-02-04 00:41:35 +00:00
flake.nix flake: provide npins in default devShell 2023-11-07 16:02:08 +03:00
LICENSE add license 2023-11-03 10:54:40 +03:00
README.md pkgs/mastodon-bird-ui: init at 1.8.2 2023-11-12 17:43:11 +03:00

🌙 nyxpkgs

My personal package overlay for sharing my most commonly used derivations.

📦 Packages

There are several packages exposed by this flake. Each directory in pkgs contains a description of the package inside its README.

Package Description
ani-cli An up-to-date, auto updated version of ani-cli
cloneit A CLI tool to download specific GitHub directories or files
foot-transparent A patched version of the foot terminal emulator that brings back fullscreen transparency1
headscale-ui A web frontend for the headscale Tailscale-compatible coordination server
mastodon-bird-ui Mastodon web UI, but strongly inspired by Twitter.
mov-cli A cli tool to browse and watch Movies/Shows/TV/Sports
rat Linux shell port of the horizontally spinning rat meme, complete with soundtrack and spin counter.
reposilite-bin A derivation for the reposilite maven repository.
rofi-calc-wayland A wayland patched version of rofi-calc
rofi-emoji-wayland A wayland patched version of rofi-emoji

Usage

Binary Cache

Regardless of your setup,you may want to add the binary cache to your substituters to avoid building the provided packages on each pull. You may follow the example below to add the binary cache to your system.

nix.settings = {
    builders-use-substitutes = true;
    substituters = [
        # other substituters
        "https://nyx.cachix.org"
    ];

    trusted-public-keys = [
        # other trusted keys
        "nyx.cachix.org-1:xH6G0MO9PrpeGe7mHBtj1WbNzmnXr7jId2mCiq6hipE="
    ];
};

NixOS/Home-manager (flakes)

It is as simple as adding a new entry to your inputs with the correct url.

# flake.nix
inputs = {
    # ...
    nyxpkgs.url = "github:notashelf/nyxpkgs";
    # ...
};

After adding the input, you can consume the exposed packages in your system configuration. An example flake.nix would be as follows:

# flake.nix
{
  inputs = {
    nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
    home-manager.url = "github:nix-community/home-manager";

    # ↓ add nyxpkgs as a flake input
    nyxpkgs.url = "github:notashelf/nyxpkgs";
  };

  outputs = inputs @ {self, nixpkgs, ...}: {
    # set up for NixOS
    nixosConfigurations.<yourHostName> = nixpkgs.lib.nixosSystem {
      specialArgs = {inherit inputs;};
      modules = [
        ./configuration.nix
        # ...
      ];
    };

    # or for Home Manager
    homeConfigurations.<yourHostName> = inputs.home-manager.lib.homeManagerConfiguration {
      extraSpecialArgs = {inherit inputs;};

      pkgs = import nixpkgs {
        system = "x86_64-linux";
        config.allowUnfree = true;
      };

      modules = [
        ./home.nix
        # ...
      ];
    }
  };
}

Where you can then add the relevant package to your environment.systemPackages or home.packages

{pkgs, inputs, ...}: {
  # in case of home-manager, this will be home.packages
  environment.systemPackages = [
    inputs.nyxpkgs.packages.${pkgs.system}.<packageName> # installs a package
  ];
}

Nix

If you are using Nix on a non-NixOS distro, you may nix run to try out packages, or nix profile install to install them on your system profile. If using home-manager on non-NixOS, I recommend using home.packages instead.

nix profile install github:notashelf/nyxpkgs#<package>

NixOS/Home-manager (no flakes)

If you are not using flakes, the above instructions will not apply. You may obtain the source as a tarball to consume in your system configuration as follows:

{pkgs, ...}: let
  nyxpkgs = import (builtins.fetchTarball "https://github.com/notashelf/nyxpkgs/archive/main.tar.gz");
in {
  # install packages
  # this can also be home.packages if you are using home-manager
  environment.systemPackages = [
    nyxpkgs.packages.${pkgs.hostPlatform.system}.<packageName>
  ];
}

🔧 Contributing

PRs are always welcome.

🫂 Credits

The repository structure is mostly borrowed from @fufexan's nix-gaming.


  1. Foot has broken fullscreen transparency on 1.15, which looks really ugly with padding. The author is dead set on not fixing it, because it's broken on one wayland compositor that a total of 7 people use. ↩︎