init
This commit is contained in:
commit
643f58adcf
4 changed files with 190 additions and 0 deletions
13
flake.nix
Normal file
13
flake.nix
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
{
|
||||||
|
description = "ГОЙДА_OS - переделка NixOS на runit";
|
||||||
|
|
||||||
|
inputs = {
|
||||||
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
|
};
|
||||||
|
|
||||||
|
outputs = { self, nixpkgs }: {
|
||||||
|
lib = {
|
||||||
|
makeSystem = import ./make-system.nix { inherit nixpkgs; };
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
66
make-system.nix
Normal file
66
make-system.nix
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
{ nixpkgs }:
|
||||||
|
{
|
||||||
|
modules,
|
||||||
|
system ? builtins.currentSystem,
|
||||||
|
platform ? null,
|
||||||
|
crossSystem ? null,
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
pkgs = import nixpkgs {
|
||||||
|
inherit system;
|
||||||
|
platform = platform;
|
||||||
|
config = { };
|
||||||
|
};
|
||||||
|
pkgsModule =
|
||||||
|
{ config, ... }:
|
||||||
|
{
|
||||||
|
_file = ./default.nix;
|
||||||
|
key = ./default.nix;
|
||||||
|
config = {
|
||||||
|
nixpkgs.pkgs = (
|
||||||
|
import nixpkgs {
|
||||||
|
inherit system crossSystem;
|
||||||
|
config = config.nixpkgs.config;
|
||||||
|
overlays = config.nixpkgs.overlays;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
nixpkgs.localSystem =
|
||||||
|
{
|
||||||
|
inherit system;
|
||||||
|
}
|
||||||
|
// pkgs.lib.optionalAttrs (crossSystem != null) {
|
||||||
|
inherit crossSystem;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
baseModules = [
|
||||||
|
./base.nix
|
||||||
|
./system-path.nix
|
||||||
|
./stage-1.nix
|
||||||
|
./stage-2.nix
|
||||||
|
./runit.nix
|
||||||
|
(nixpkgs + "/nixos/modules/system/etc/etc.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/system/activation/activation-script.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/misc/nixpkgs.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/system/boot/kernel.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/misc/assertions.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/misc/lib.nix")
|
||||||
|
(nixpkgs + "/nixos/modules/config/sysctl.nix")
|
||||||
|
pkgsModule
|
||||||
|
];
|
||||||
|
other = {
|
||||||
|
_module.check = true;
|
||||||
|
_module.args = { };
|
||||||
|
};
|
||||||
|
in
|
||||||
|
pkgs.lib.evalModules {
|
||||||
|
prefix = [ ];
|
||||||
|
modules =
|
||||||
|
modules
|
||||||
|
++ baseModules
|
||||||
|
++ [
|
||||||
|
pkgsModule
|
||||||
|
other
|
||||||
|
];
|
||||||
|
}
|
62
runit.nix
Normal file
62
runit.nix
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
compat = pkgs.runCommand "runit-compat" { } ''
|
||||||
|
mkdir -p $out/bin/
|
||||||
|
cat << EOF > $out/bin/poweroff
|
||||||
|
#!/bin/sh
|
||||||
|
exec runit-init 0
|
||||||
|
EOF
|
||||||
|
cat << EOF > $out/bin/reboot
|
||||||
|
#!/bin/sh
|
||||||
|
exec runit-init 6
|
||||||
|
EOF
|
||||||
|
chmod +x $out/bin/{poweroff,reboot}
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
{
|
||||||
|
environment.systemPackages = [ compat ];
|
||||||
|
environment.etc = lib.mkMerge [
|
||||||
|
{
|
||||||
|
"runit/1".source = pkgs.writeScript "1" ''
|
||||||
|
#!${pkgs.runtimeShell}
|
||||||
|
mkdir /bin/
|
||||||
|
ln -s ${pkgs.runtimeShell} /bin/sh
|
||||||
|
|
||||||
|
${lib.optionalString (config.networking.timeServers != [ ]) ''
|
||||||
|
${pkgs.ntp}/bin/ntpdate ${toString config.networking.timeServers}
|
||||||
|
''}
|
||||||
|
|
||||||
|
# disable DPMS on tty's
|
||||||
|
echo -ne "\033[9;0]" > /dev/tty0
|
||||||
|
|
||||||
|
touch /etc/runit/stopit
|
||||||
|
chmod 0 /etc/runit/stopit
|
||||||
|
'';
|
||||||
|
"runit/2".source = pkgs.writeScript "2" ''
|
||||||
|
#!${pkgs.runtimeShell}
|
||||||
|
exec runsvdir -P /etc/service
|
||||||
|
'';
|
||||||
|
"runit/3".source = pkgs.writeScript "3" ''
|
||||||
|
#!${pkgs.runtimeShell}
|
||||||
|
echo and down we go
|
||||||
|
'';
|
||||||
|
"service/nix-daemon/run".source = pkgs.writeScript "nix-daemon" ''
|
||||||
|
#!${pkgs.runtimeShell}
|
||||||
|
nix-daemon
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
(lib.mkIf config.not-os.rngd {
|
||||||
|
"service/rngd/run".source = pkgs.writeScript "rngd" ''
|
||||||
|
#!${pkgs.runtimeShell}
|
||||||
|
export PATH=$PATH:${pkgs.rng-tools}/bin
|
||||||
|
exec rngd -r /dev/hwrng
|
||||||
|
'';
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}
|
49
services/default.nix
Normal file
49
services/default.nix
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
{ lib, config, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.runit;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
runit.services = lib.mkOption {
|
||||||
|
type = lib.types.attrsOf (
|
||||||
|
lib.types.submodule {
|
||||||
|
run = lib.mkOption {
|
||||||
|
type = lib.types.string;
|
||||||
|
description = "The command to run. Equivalent to ExecStart in systemd";
|
||||||
|
};
|
||||||
|
check = lib.mkOption {
|
||||||
|
type = lib.types.optional lib.types.string;
|
||||||
|
description = "The command to run to check if the service is running.";
|
||||||
|
};
|
||||||
|
finish = lib.mkOption {
|
||||||
|
type = lib.types.optional lib.types.string;
|
||||||
|
description = "The command to run when the service is stopped.";
|
||||||
|
};
|
||||||
|
conf = lib.mkOption {
|
||||||
|
type = lib.types.optional lib.types.string;
|
||||||
|
description = "The command to run to configure the service.";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
default = { };
|
||||||
|
};
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
environment.etc = lib.mkMerge lib.mapAttrsToList (
|
||||||
|
name: value:
|
||||||
|
{
|
||||||
|
"service/${name}/run".source = value.run;
|
||||||
|
|
||||||
|
}
|
||||||
|
// lib.optionalAttrs (value.check != null) {
|
||||||
|
"service/${name}/check".source = value.check;
|
||||||
|
}
|
||||||
|
// lib.optionalAttrs (value.finish != null) {
|
||||||
|
"service/${name}/finish".source = value.finish;
|
||||||
|
}
|
||||||
|
// lib.optionalAttrs (value.conf != null) {
|
||||||
|
"service/${name}/conf".source = value.conf;
|
||||||
|
}
|
||||||
|
) cfg.services;
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue