Merge branch 'master' of github.com:aciceri/fleet

This commit is contained in:
Andrea Ciceri 2021-10-06 10:50:25 +02:00
commit 8e4f077b23
No known key found for this signature in database
GPG key ID: A1FC89532D1C5654
5 changed files with 170 additions and 103 deletions

215
flake.nix
View file

@ -52,6 +52,7 @@
, nixos , nixos
, home , home
, nixos-hardware , nixos-hardware
, darwin
, pinebook-pro , pinebook-pro
, pinebook-pro-kernel-latest , pinebook-pro-kernel-latest
, nixpkgs-wayland , nixpkgs-wayland
@ -62,122 +63,132 @@
, ... , ...
} @ inputs: } @ inputs:
digga.lib.mkFlake digga.lib.mkFlake
{ {
inherit self inputs; inherit self inputs;
channelsConfig = { allowUnfree = true; }; channelsConfig = { allowUnfree = true; };
channels = channels =
let let
commonOverlays = [ commonOverlays = [
digga.overlays.patchedNix digga.overlays.patchedNix
nur.overlay nur.overlay
emacs-overlay.overlay emacs-overlay.overlay
nvfetcher.overlay nvfetcher.overlay
deploy.overlay deploy.overlay
nixpkgs-wayland.overlay nixpkgs-wayland.overlay
./pkgs/default.nix ./pkgs/default.nix
]; ];
in in
{ {
stable = { stable = {
imports = [ (digga.lib.importOverlays ./overlays) ]; imports = [ (digga.lib.importOverlays ./overlays) ];
overlays = commonOverlays; overlays = commonOverlays;
};
unstable = {
imports = [ (digga.lib.importOverlays ./overlays) ];
overlays = commonOverlays;
};
};
lib = import ./lib { lib = digga.lib // nixos.lib; };
sharedOverlays = [
(
final: prev: {
__dontExport = true;
lib = prev.lib.extend (
lfinal: lprev: {
our = self.lib;
}
);
}
)
];
nixos = {
hostDefaults = {
channelName = "unstable";
imports = [ (digga.lib.importModules ./modules) ];
externalModules = [
{ lib.our = self.lib; }
digga.nixosModules.bootstrapIso
digga.nixosModules.nixConfig
home.nixosModules.home-manager
bud.nixosModules.bud
];
}; };
hosts = { unstable = {
pc = { imports = [ (digga.lib.importOverlays ./overlays) ];
system = "x86_64-linux"; overlays = commonOverlays;
};
pbp = {
system = "aarch64-linux";
modules = [
"${pinebook-pro}/pinebook_pro.nix"
];
};
}; };
imports = [ (digga.lib.importHosts ./hosts) ]; };
importables = rec {
profiles = digga.lib.rakeLeaves ./profiles // { lib = import ./lib { lib = digga.lib // nixos.lib; };
users = digga.lib.rakeLeaves ./users;
}; sharedOverlays = [
suites = with profiles; rec { (
base = [ core users.ccr users.root ]; final: prev: {
}; __dontExport = true;
pbpKernelLatest = ( lib = prev.lib.extend (
import pinebook-pro-kernel-latest { lfinal: lprev: {
system = "aarch64-linux"; our = self.lib;
overlays = [
(import "${pinebook-pro}/overlay.nix")
];
config.allowUnfree = true;
} }
).pkgs.linuxPackages_pinebookpro_latest; );
}
)
];
nixos = {
hostDefaults = {
channelName = "unstable";
imports = [ (digga.lib.importModules ./modules) ];
externalModules = [
{ lib.our = self.lib; }
digga.nixosModules.bootstrapIso
digga.nixosModules.nixConfig
home.nixosModules.home-manager
bud.nixosModules.bud
];
};
hosts = {
# mbp is added bypassing Digga's mkFlake and adding a specific output to this flake
pc = {
system = "x86_64-linux";
imports = [{ modules = ./hosts/pc; }];
};
pbp = {
system = "aarch64-linux";
imports = [{ modules = ./hosts/pbp; }];
modules = [
"${pinebook-pro}/pinebook_pro.nix"
];
}; };
}; };
# imports = [ (digga.lib.importHosts ./hosts) ]; # same reason as above
importables = rec {
profiles = digga.lib.rakeLeaves ./profiles // {
users = digga.lib.rakeLeaves ./users;
};
suites = with profiles; rec {
base = [ core users.ccr users.root ];
};
pbpKernelLatest = (
import pinebook-pro-kernel-latest {
system = "aarch64-linux";
overlays = [
(import "${pinebook-pro}/overlay.nix")
];
config.allowUnfree = true;
}
).pkgs.linuxPackages_pinebookpro_latest;
};
};
home = { home = {
imports = [ (digga.lib.importModules ./users/modules) ]; imports = [ (digga.lib.importModules ./users/modules) ];
externalModules = []; externalModules = [ ];
importables = rec { importables = rec {
profiles = digga.lib.rakeLeaves ./users/profiles; profiles = digga.lib.rakeLeaves ./users/profiles;
suites = with profiles; rec { suites = with profiles; rec {
base = [ direnv git zsh gpg password-store ]; base = [ direnv git zsh gpg password-store ];
shell = [ zsh exa fzf ]; shell = [ zsh exa fzf ];
gui = [ sway xdg gtk foot bat ]; gui = [ sway xdg gtk foot bat ];
browser = [ firefox chromium qutebrowser ]; browser = [ firefox chromium qutebrowser ];
multimedia = [ mpv zathura ]; multimedia = [ mpv zathura ];
dev = [ vim emacs vscode lorri direnv ]; dev = [ vim emacs vscode lorri direnv ];
};
}; };
}; };
};
devshell = ./shell; devshell = ./shell;
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations; homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations {}; deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations { };
defaultTemplate = self.templates.bud; defaultTemplate = self.templates.bud;
templates.bud.path = ./.; templates.bud.path = ./.;
templates.bud.description = "bud template"; templates.bud.description = "bud template";
} }
// { // {
budModules = { devos = import ./bud; }; budModules = { devos = import ./bud; };
# checks.aarch64-linux = { }; # this line will be uncommented by Github Action in order since it can't build aarch64 derivations # checks.aarch64-linux = { }; # this line will be uncommented by Github Action in order since it can't build aarch64 derivations
}
// {
darwinConfigurations."mbp" = darwin.lib.darwinSystem {
system = "x86_64-darwin";
modules = [ home.darwinModules.home-manager ./hosts/mbp ];
inputs = { inherit darwin; };
}; };
};
} }

View file

@ -0,0 +1,30 @@
{pkgs, home-manager, ...}:
{
imports = [
../../users/andreaciceri
];
home-manager = {
useGlobalPkgs = true;
useUserPackages = true;
};
programs.gnupg.agent = {
enable = true;
enableSSHSupport = true;
};
nix = {
package = pkgs.nixUnstable;
extraOptions = ''
experimental-features = nix-command flakes flakes ca-references
keep-derivations = true
keep-outputs = true
'';
gc = {
automatic = false;
user = "andreaciceri";
options = "--delete-older-than 3d";
};
};
}

8
hosts/mbp/default.nix Normal file
View file

@ -0,0 +1,8 @@
{ pkgs, ...}:
{
imports = [
./configuration.nix
];
}

View file

@ -0,0 +1,15 @@
{ config, lib, pkgs, ... }: {
home-manager.users."andreaciceri" = {...}: {
imports = [
../profiles/bat
../profiles/fzf
../profiles/zsh
../profiles/direnv
../profiles/exa
];
home.packages = with pkgs; [
yarn
];
};
}

View file

@ -1,4 +1,4 @@
{ pkgs, ... }: { pkgs, config, ... }:
{ {
programs.zsh = { programs.zsh = {
enable = true; enable = true;
@ -55,5 +55,8 @@
PROMPT = "\\\${IN_NIX_SHELL:+[nix-shell] }$PROMPT"; PROMPT = "\\\${IN_NIX_SHELL:+[nix-shell] }$PROMPT";
}; };
loginExtra = "[[ -z $DISPLAY && $TTY = /dev/tty1 ]] && exec sway"; loginExtra = "[[ -z $DISPLAY && $TTY = /dev/tty1 ]] && exec sway";
initExtra = if pkgs.system == "x86_64-darwin"
then "if test -e /etc/static/bashrc; then source /etc/static/bashrc > /dev/null 2>&1; fi"
else "";
}; };
} }