2022-05-21 00:07:49 +00:00
|
|
|
# docs:
|
|
|
|
# https://nixos.wiki/wiki/Flakes
|
|
|
|
# https://serokell.io/blog/practical-nix-flakes
|
|
|
|
|
|
|
|
{
|
|
|
|
inputs = {
|
2022-05-28 19:35:43 +00:00
|
|
|
nixpkgs.url = "nixpkgs/nixos-22.05";
|
2022-05-24 03:45:33 +00:00
|
|
|
pkgs-unstable.url = "nixpkgs/nixos-unstable";
|
2022-05-25 03:57:43 +00:00
|
|
|
# pkgs-telegram.url = "nixpkgs/33775ec9a2173a08e46edf9f46c9febadbf743e8";# 2022/04/18; telegram 3.7.3. fails: nix log /nix/store/y5kv47hnv55qknb6cnmpcyraicay79fx-telegram-desktop-3.7.3.drv: g++: fatal error: cannot execute '/nix/store/njk5sbd21305bhr7gwibxbbvgbx5lxvn-gcc-9.3.0/libexec/gcc/aarch64-unknown-linux-gnu/9.3.0/cc1plus': execv: No such file or directory
|
|
|
|
pkgs-mobile.url = "nixpkgs/dfd82985c273aac6eced03625f454b334daae2e8"; # WORKS: 2022/05/20; mobile-nixos follows this same commit.
|
2022-05-23 02:45:54 +00:00
|
|
|
mobile-nixos = {
|
2022-05-24 05:47:32 +00:00
|
|
|
url = "github:nixos/mobile-nixos";
|
|
|
|
flake = false;
|
2022-05-24 09:47:04 +00:00
|
|
|
# TODO colin: is this necessary (or wanted)?
|
|
|
|
# inputs.nixpkgs.follows = "pkgs-mobile";
|
2022-05-23 02:45:54 +00:00
|
|
|
};
|
2022-05-22 01:05:32 +00:00
|
|
|
home-manager = {
|
|
|
|
url = "github:nix-community/home-manager/release-21.11";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2022-05-22 11:03:30 +00:00
|
|
|
nurpkgs.url = "github:nix-community/NUR";
|
2022-05-21 00:07:49 +00:00
|
|
|
};
|
2022-05-21 07:30:29 +00:00
|
|
|
|
2022-06-01 00:47:28 +00:00
|
|
|
outputs = { self, nixpkgs, pkgs-unstable, pkgs-mobile, mobile-nixos, home-manager, nurpkgs }: {
|
2022-05-22 21:39:52 +00:00
|
|
|
machines.uninsane = self.decl-bootable-machine { name = "uninsane"; system = "aarch64-linux"; };
|
|
|
|
machines.desko = self.decl-bootable-machine { name = "desko"; system = "x86_64-linux"; };
|
|
|
|
machines.lappy = self.decl-bootable-machine { name = "lappy"; system = "x86_64-linux"; };
|
2022-05-22 08:27:02 +00:00
|
|
|
|
2022-05-24 07:53:13 +00:00
|
|
|
machines.moby =
|
|
|
|
let machine = self.decl-machine {
|
|
|
|
name = "moby";
|
2022-05-22 21:39:52 +00:00
|
|
|
system = "aarch64-linux";
|
2022-05-24 07:53:13 +00:00
|
|
|
extraModules = [
|
2022-05-24 05:47:32 +00:00
|
|
|
(import "${mobile-nixos}/lib/configuration.nix" {
|
|
|
|
device = "pine64-pinephone";
|
2022-05-22 21:39:52 +00:00
|
|
|
})
|
|
|
|
];
|
2022-05-24 09:47:04 +00:00
|
|
|
basePkgs = pkgs-mobile;
|
2022-05-22 21:39:52 +00:00
|
|
|
};
|
2022-05-24 07:53:13 +00:00
|
|
|
in {
|
|
|
|
nixosConfiguration = machine;
|
|
|
|
img = machine.config.mobile.outputs.u-boot.disk-image;
|
|
|
|
};
|
2022-05-22 01:05:32 +00:00
|
|
|
|
2022-05-22 22:11:08 +00:00
|
|
|
nixosConfigurations = builtins.mapAttrs (name: value: value.nixosConfiguration) self.machines;
|
|
|
|
imgs = builtins.mapAttrs (name: value: value.img) self.machines;
|
2022-05-21 07:30:29 +00:00
|
|
|
|
2022-05-24 09:47:04 +00:00
|
|
|
decl-machine = { name, system, extraModules ? [], basePkgs ? nixpkgs }: (basePkgs.lib.nixosSystem {
|
2022-05-22 21:39:52 +00:00
|
|
|
inherit system;
|
2022-05-27 06:52:08 +00:00
|
|
|
specialArgs = { inherit home-manager; inherit nurpkgs; secrets = import ./secrets/default.nix; };
|
2022-05-21 07:40:56 +00:00
|
|
|
modules = [
|
|
|
|
./configuration.nix
|
|
|
|
./modules
|
2022-05-24 00:15:38 +00:00
|
|
|
./machines/${name}
|
2022-05-24 03:20:05 +00:00
|
|
|
(import ./helpers/set-hostname.nix name)
|
2022-05-24 07:45:55 +00:00
|
|
|
(self.overlaysModule system)
|
2022-05-21 07:40:56 +00:00
|
|
|
] ++ extraModules;
|
|
|
|
});
|
|
|
|
|
2022-05-22 08:38:19 +00:00
|
|
|
# this produces a EFI-bootable .img file (GPT with / and /boot).
|
|
|
|
# after building this, steps are:
|
|
|
|
# run `btrfs-convert --uuid copy <device>`
|
|
|
|
# boot, checkout this flake into /etc/nixos AND UPDATE THE UUIDS IT REFERENCES.
|
|
|
|
# then `nixos-rebuild ...`
|
2022-05-24 00:15:38 +00:00
|
|
|
decl-img = { name, system, extraModules ? [] }: (
|
|
|
|
(self.decl-machine { inherit name; inherit system; extraModules = extraModules ++ [./image.nix]; })
|
2022-05-22 20:35:04 +00:00
|
|
|
.config.system.build.raw
|
2022-05-22 08:38:19 +00:00
|
|
|
);
|
|
|
|
|
2022-05-24 00:15:38 +00:00
|
|
|
decl-bootable-machine = { name, system }: {
|
|
|
|
nixosConfiguration = self.decl-machine { inherit name; inherit system; };
|
|
|
|
img = self.decl-img { inherit name; inherit system; };
|
|
|
|
};
|
2022-05-22 21:39:52 +00:00
|
|
|
|
2022-05-24 07:45:55 +00:00
|
|
|
overlaysModule = system: { config, pkgs, ...}: {
|
|
|
|
nixpkgs.config.allowUnfree = true;
|
|
|
|
|
|
|
|
nixpkgs.overlays = [
|
|
|
|
#mobile-nixos.overlay
|
|
|
|
nurpkgs.overlay
|
|
|
|
(next: prev: {
|
|
|
|
#### customized packages
|
|
|
|
# nixos-unstable pleroma is too far out-of-date for our db
|
|
|
|
pleroma = prev.callPackage ./pkgs/pleroma { };
|
|
|
|
# jackett doesn't allow customization of the bind address: this will probably always be here.
|
|
|
|
jackett = next.callPackage ./pkgs/jackett { pkgs = prev; };
|
|
|
|
# fix abrupt HDD poweroffs as during reboot. patching systemd requires rebuilding nearly every package.
|
|
|
|
# systemd = import ./pkgs/systemd { pkgs = prev; };
|
|
|
|
|
|
|
|
# patch rpi uboot with something that fixes USB HDD boot
|
|
|
|
ubootRaspberryPi4_64bit = next.callPackage ./pkgs/ubootRaspberryPi4_64bit { pkgs = prev; };
|
|
|
|
|
2022-05-25 03:57:43 +00:00
|
|
|
# we care about keeping these packages up-to-date
|
|
|
|
electrum = pkgs-unstable.legacyPackages.${system}.electrum;
|
|
|
|
|
|
|
|
#### TEMPORARY NIXOS-UNSTABLE PACKAGES
|
2022-05-24 07:45:55 +00:00
|
|
|
|
|
|
|
# nixos-21.11 whalebird uses an insecure electron version.
|
|
|
|
# TODO: remove this on next nixos release.
|
|
|
|
whalebird = pkgs-unstable.legacyPackages.${system}.whalebird;
|
|
|
|
|
2022-05-25 03:57:43 +00:00
|
|
|
# pkgs-mobile' telegram doesn't build, so explicitly use the stable one.
|
|
|
|
# TODO: apply this specifically to the moby build?
|
|
|
|
# tdesktop = pkgs-telegram.legacyPackages.${system}.tdesktop;
|
|
|
|
tdesktop = nixpkgs.legacyPackages.${system}.tdesktop;
|
2022-05-24 07:45:55 +00:00
|
|
|
})
|
|
|
|
];
|
|
|
|
};
|
2022-05-21 00:07:49 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|