commit
195521350a
@ -17,23 +17,23 @@ let
|
|||||||
resolved = canLoadExternalModules && config.services.resolved.enable;
|
resolved = canLoadExternalModules && config.services.resolved.enable;
|
||||||
|
|
||||||
hostArray = [ "files" ]
|
hostArray = [ "files" ]
|
||||||
++ optionals mymachines [ "mymachines" ]
|
++ optional mymachines "mymachines"
|
||||||
++ optionals nssmdns [ "mdns_minimal [NOTFOUND=return]" ]
|
++ optional nssmdns "mdns_minimal [NOTFOUND=return]"
|
||||||
++ optionals nsswins [ "wins" ]
|
++ optional nsswins "wins"
|
||||||
++ optionals resolved ["resolve [!UNAVAIL=return]"]
|
++ optional resolved "resolve [!UNAVAIL=return]"
|
||||||
++ [ "dns" ]
|
++ [ "dns" ]
|
||||||
++ optionals nssmdns [ "mdns" ]
|
++ optional nssmdns "mdns"
|
||||||
++ optionals myhostname ["myhostname" ];
|
++ optional myhostname "myhostname";
|
||||||
|
|
||||||
passwdArray = [ "files" ]
|
passwdArray = [ "files" ]
|
||||||
++ optional sssd "sss"
|
++ optional sssd "sss"
|
||||||
++ optionals ldap [ "ldap" ]
|
++ optional ldap "ldap"
|
||||||
++ optionals mymachines [ "mymachines" ]
|
++ optional mymachines "mymachines"
|
||||||
++ [ "systemd" ];
|
++ [ "systemd" ];
|
||||||
|
|
||||||
shadowArray = [ "files" ]
|
shadowArray = [ "files" ]
|
||||||
++ optional sssd "sss"
|
++ optional sssd "sss"
|
||||||
++ optionals ldap [ "ldap" ];
|
++ optional ldap "ldap";
|
||||||
|
|
||||||
servicesArray = [ "files" ]
|
servicesArray = [ "files" ]
|
||||||
++ optional sssd "sss";
|
++ optional sssd "sss";
|
||||||
|
@ -504,9 +504,6 @@ in {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Install all the user shells
|
|
||||||
environment.systemPackages = systemShells;
|
|
||||||
|
|
||||||
users.groups = {
|
users.groups = {
|
||||||
root.gid = ids.gids.root;
|
root.gid = ids.gids.root;
|
||||||
wheel.gid = ids.gids.wheel;
|
wheel.gid = ids.gids.wheel;
|
||||||
@ -543,14 +540,29 @@ in {
|
|||||||
# for backwards compatibility
|
# for backwards compatibility
|
||||||
system.activationScripts.groups = stringAfter [ "users" ] "";
|
system.activationScripts.groups = stringAfter [ "users" ] "";
|
||||||
|
|
||||||
environment.etc."subuid" = {
|
# Install all the user shells
|
||||||
|
environment.systemPackages = systemShells;
|
||||||
|
|
||||||
|
environment.etc = {
|
||||||
|
"subuid" = {
|
||||||
text = subuidFile;
|
text = subuidFile;
|
||||||
mode = "0644";
|
mode = "0644";
|
||||||
};
|
};
|
||||||
environment.etc."subgid" = {
|
"subgid" = {
|
||||||
text = subgidFile;
|
text = subgidFile;
|
||||||
mode = "0644";
|
mode = "0644";
|
||||||
};
|
};
|
||||||
|
} // (mapAttrs' (name: { packages, ... }: {
|
||||||
|
name = "profiles/per-user/${name}";
|
||||||
|
value.source = pkgs.buildEnv {
|
||||||
|
name = "user-environment";
|
||||||
|
paths = packages;
|
||||||
|
inherit (config.environment) pathsToLink extraOutputsToInstall;
|
||||||
|
inherit (config.system.path) ignoreCollisions postBuild;
|
||||||
|
};
|
||||||
|
}) (filterAttrs (_: u: u.packages != []) cfg.users));
|
||||||
|
|
||||||
|
environment.profiles = [ "/etc/profiles/per-user/$USER" ];
|
||||||
|
|
||||||
assertions = [
|
assertions = [
|
||||||
{ assertion = !cfg.enforceIdUniqueness || (uidsAreUnique && gidsAreUnique);
|
{ assertion = !cfg.enforceIdUniqueness || (uidsAreUnique && gidsAreUnique);
|
||||||
@ -581,22 +593,4 @@ in {
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
imports =
|
|
||||||
[ (mkAliasOptionModule [ "users" "extraUsers" ] [ "users" "users" ])
|
|
||||||
(mkAliasOptionModule [ "users" "extraGroups" ] [ "users" "groups" ])
|
|
||||||
{
|
|
||||||
environment = {
|
|
||||||
etc = mapAttrs' (name: { packages, ... }: {
|
|
||||||
name = "profiles/per-user/${name}";
|
|
||||||
value.source = pkgs.buildEnv {
|
|
||||||
name = "user-environment";
|
|
||||||
paths = packages;
|
|
||||||
inherit (config.environment) pathsToLink extraOutputsToInstall;
|
|
||||||
inherit (config.system.path) ignoreCollisions postBuild;
|
|
||||||
};
|
|
||||||
}) (filterAttrs (_: { packages, ... }: packages != []) cfg.users);
|
|
||||||
profiles = ["/etc/profiles/per-user/$USER"];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ with lib;
|
|||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
(mkRenamedOptionModule [ "dysnomia" ] [ "services" "dysnomia" ])
|
||||||
(mkRenamedOptionModule [ "environment" "x11Packages" ] [ "environment" "systemPackages" ])
|
(mkRenamedOptionModule [ "environment" "x11Packages" ] [ "environment" "systemPackages" ])
|
||||||
(mkRenamedOptionModule [ "environment" "enableBashCompletion" ] [ "programs" "bash" "enableCompletion" ])
|
(mkRenamedOptionModule [ "environment" "enableBashCompletion" ] [ "programs" "bash" "enableCompletion" ])
|
||||||
(mkRenamedOptionModule [ "environment" "nix" ] [ "nix" "package" ])
|
(mkRenamedOptionModule [ "environment" "nix" ] [ "nix" "package" ])
|
||||||
@ -203,6 +204,10 @@ with lib;
|
|||||||
(mkRenamedOptionModule [ "config" "system" "nixosCodeName" ] [ "config" "system" "nixos" "codeName" ])
|
(mkRenamedOptionModule [ "config" "system" "nixosCodeName" ] [ "config" "system" "nixos" "codeName" ])
|
||||||
(mkRenamedOptionModule [ "config" "system" "nixosLabel" ] [ "config" "system" "nixos" "label" ])
|
(mkRenamedOptionModule [ "config" "system" "nixosLabel" ] [ "config" "system" "nixos" "label" ])
|
||||||
|
|
||||||
|
# Users
|
||||||
|
(mkAliasOptionModule [ "users" "extraUsers" ] [ "users" "users" ])
|
||||||
|
(mkAliasOptionModule [ "users" "extraGroups" ] [ "users" "groups" ])
|
||||||
|
|
||||||
# Options that are obsolete and have no replacement.
|
# Options that are obsolete and have no replacement.
|
||||||
(mkRemovedOptionModule [ "boot" "initrd" "luks" "enable" ] "")
|
(mkRemovedOptionModule [ "boot" "initrd" "luks" "enable" ] "")
|
||||||
(mkRemovedOptionModule [ "programs" "bash" "enable" ] "")
|
(mkRemovedOptionModule [ "programs" "bash" "enable" ] "")
|
||||||
|
@ -57,7 +57,7 @@ in
|
|||||||
###### implementation
|
###### implementation
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
dysnomia.enable = true;
|
services.dysnomia.enable = true;
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.disnix ] ++ optional cfg.useWebServiceInterface pkgs.DisnixWebService;
|
environment.systemPackages = [ pkgs.disnix ] ++ optional cfg.useWebServiceInterface pkgs.DisnixWebService;
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
cfg = config.dysnomia;
|
cfg = config.services.dysnomia;
|
||||||
|
|
||||||
printProperties = properties:
|
printProperties = properties:
|
||||||
concatMapStrings (propertyName:
|
concatMapStrings (propertyName:
|
||||||
@ -72,7 +72,7 @@ let
|
|||||||
in
|
in
|
||||||
{
|
{
|
||||||
options = {
|
options = {
|
||||||
dysnomia = {
|
services.dysnomia = {
|
||||||
|
|
||||||
enable = mkOption {
|
enable = mkOption {
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
@ -145,7 +145,7 @@ in
|
|||||||
|
|
||||||
environment.systemPackages = [ cfg.package ];
|
environment.systemPackages = [ cfg.package ];
|
||||||
|
|
||||||
dysnomia.package = pkgs.dysnomia.override (origArgs: {
|
services.dysnomia.package = pkgs.dysnomia.override (origArgs: {
|
||||||
enableApacheWebApplication = config.services.httpd.enable;
|
enableApacheWebApplication = config.services.httpd.enable;
|
||||||
enableAxis2WebService = config.services.tomcat.axis2.enable;
|
enableAxis2WebService = config.services.tomcat.axis2.enable;
|
||||||
enableEjabberdDump = config.services.ejabberd.enable;
|
enableEjabberdDump = config.services.ejabberd.enable;
|
||||||
@ -156,7 +156,7 @@ in
|
|||||||
enableMongoDatabase = config.services.mongodb.enable;
|
enableMongoDatabase = config.services.mongodb.enable;
|
||||||
});
|
});
|
||||||
|
|
||||||
dysnomia.properties = {
|
services.dysnomia.properties = {
|
||||||
hostname = config.networking.hostName;
|
hostname = config.networking.hostName;
|
||||||
system = if config.nixpkgs.system == "" then builtins.currentSystem else config.nixpkgs.system;
|
system = if config.nixpkgs.system == "" then builtins.currentSystem else config.nixpkgs.system;
|
||||||
|
|
||||||
@ -174,7 +174,7 @@ in
|
|||||||
}}");
|
}}");
|
||||||
};
|
};
|
||||||
|
|
||||||
dysnomia.containers = lib.recursiveUpdate ({
|
services.dysnomia.containers = lib.recursiveUpdate ({
|
||||||
process = {};
|
process = {};
|
||||||
wrapper = {};
|
wrapper = {};
|
||||||
}
|
}
|
||||||
|
@ -44,9 +44,9 @@ in
|
|||||||
path = [ pkgs.iptables pkgs.tcpcrypt pkgs.procps ];
|
path = [ pkgs.iptables pkgs.tcpcrypt pkgs.procps ];
|
||||||
|
|
||||||
preStart = ''
|
preStart = ''
|
||||||
mkdir -p /var/run/tcpcryptd
|
mkdir -p /run/tcpcryptd
|
||||||
chown tcpcryptd /var/run/tcpcryptd
|
chown tcpcryptd /run/tcpcryptd
|
||||||
sysctl -n net.ipv4.tcp_ecn >/run/pre-tcpcrypt-ecn-state
|
sysctl -n net.ipv4.tcp_ecn > /run/tcpcryptd/pre-tcpcrypt-ecn-state
|
||||||
sysctl -w net.ipv4.tcp_ecn=0
|
sysctl -w net.ipv4.tcp_ecn=0
|
||||||
|
|
||||||
iptables -t raw -N nixos-tcpcrypt
|
iptables -t raw -N nixos-tcpcrypt
|
||||||
@ -61,8 +61,8 @@ in
|
|||||||
script = "tcpcryptd -x 0x10";
|
script = "tcpcryptd -x 0x10";
|
||||||
|
|
||||||
postStop = ''
|
postStop = ''
|
||||||
if [ -f /run/pre-tcpcrypt-ecn-state ]; then
|
if [ -f /run/tcpcryptd/pre-tcpcrypt-ecn-state ]; then
|
||||||
sysctl -w net.ipv4.tcp_ecn=$(cat /run/pre-tcpcrypt-ecn-state)
|
sysctl -w net.ipv4.tcp_ecn=$(cat /run/tcpcryptd/pre-tcpcrypt-ecn-state)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
iptables -t mangle -D POSTROUTING -j nixos-tcpcrypt || true
|
iptables -t mangle -D POSTROUTING -j nixos-tcpcrypt || true
|
||||||
|
@ -30,7 +30,7 @@ let
|
|||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
cfg = stdenv.lib.attrByPath [ browserName ] {} config;
|
cfg = config.${browserName} or {};
|
||||||
enableAdobeFlash = cfg.enableAdobeFlash or false;
|
enableAdobeFlash = cfg.enableAdobeFlash or false;
|
||||||
ffmpegSupport = browser.ffmpegSupport or false;
|
ffmpegSupport = browser.ffmpegSupport or false;
|
||||||
gssSupport = browser.gssSupport or false;
|
gssSupport = browser.gssSupport or false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user