2018-06-29 22:34:35 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
2018-01-24 17:32:33 +00:00
|
|
|
|
2018-06-29 22:34:35 +00:00
|
|
|
# openafsBin, openafsSrv, mkCellServDB
|
|
|
|
with import ./lib.nix { inherit config lib pkgs; };
|
2018-01-24 17:32:33 +00:00
|
|
|
|
|
|
|
let
|
2018-07-20 19:36:12 +00:00
|
|
|
inherit (lib) concatStringsSep mkIf mkOption optionalString types;
|
2018-01-24 17:32:33 +00:00
|
|
|
|
|
|
|
bosConfig = pkgs.writeText "BosConfig" (''
|
|
|
|
restrictmode 1
|
|
|
|
restarttime 16 0 0 0 0
|
|
|
|
checkbintime 3 0 5 0 0
|
|
|
|
'' + (optionalString cfg.roles.database.enable ''
|
|
|
|
bnode simple vlserver 1
|
2018-06-29 22:34:35 +00:00
|
|
|
parm ${openafsSrv}/libexec/openafs/vlserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.vlserverArgs}
|
2018-01-24 17:32:33 +00:00
|
|
|
end
|
|
|
|
bnode simple ptserver 1
|
2018-06-29 22:34:35 +00:00
|
|
|
parm ${openafsSrv}/libexec/openafs/ptserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.ptserverArgs}
|
2018-01-24 17:32:33 +00:00
|
|
|
end
|
|
|
|
'') + (optionalString cfg.roles.fileserver.enable ''
|
|
|
|
bnode dafs dafs 1
|
2018-06-29 22:34:35 +00:00
|
|
|
parm ${openafsSrv}/libexec/openafs/dafileserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.fileserverArgs}
|
|
|
|
parm ${openafsSrv}/libexec/openafs/davolserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.volserverArgs}
|
|
|
|
parm ${openafsSrv}/libexec/openafs/salvageserver ${cfg.roles.fileserver.salvageserverArgs}
|
|
|
|
parm ${openafsSrv}/libexec/openafs/dasalvager ${cfg.roles.fileserver.salvagerArgs}
|
2018-01-24 17:32:33 +00:00
|
|
|
end
|
|
|
|
'') + (optionalString (cfg.roles.database.enable && cfg.roles.backup.enable) ''
|
|
|
|
bnode simple buserver 1
|
2018-06-29 22:34:35 +00:00
|
|
|
parm ${openafsSrv}/libexec/openafs/buserver ${cfg.roles.backup.buserverArgs} ${optionalString (cfg.roles.backup.cellServDB != []) "-cellservdb /etc/openafs/backup/"}
|
2018-01-24 17:32:33 +00:00
|
|
|
end
|
|
|
|
''));
|
|
|
|
|
|
|
|
netInfo = if (cfg.advertisedAddresses != []) then
|
|
|
|
pkgs.writeText "NetInfo" ((concatStringsSep "\nf " cfg.advertisedAddresses) + "\n")
|
|
|
|
else null;
|
|
|
|
|
|
|
|
buCellServDB = pkgs.writeText "backup-cellServDB-${cfg.cellName}" (mkCellServDB cfg.cellName cfg.roles.backup.cellServDB);
|
|
|
|
|
|
|
|
cfg = config.services.openafsServer;
|
|
|
|
|
|
|
|
udpSizeStr = toString cfg.udpPacketSize;
|
|
|
|
|
|
|
|
in {
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
services.openafsServer = {
|
|
|
|
|
|
|
|
enable = mkOption {
|
|
|
|
default = false;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable the OpenAFS server. An OpenAFS server needs a
|
|
|
|
complex setup. So, be aware that enabling this service and setting
|
|
|
|
some options does not give you a turn-key-ready solution. You need
|
|
|
|
at least a running Kerberos 5 setup, as OpenAFS relies on it for
|
|
|
|
authentication. See the Guide "QuickStartUnix" coming with
|
|
|
|
<literal>pkgs.openafs.doc</literal> for complete setup
|
|
|
|
instructions.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
advertisedAddresses = mkOption {
|
|
|
|
default = [];
|
|
|
|
description = "List of IP addresses this server is advertised under. See NetInfo(5)";
|
|
|
|
};
|
|
|
|
|
|
|
|
cellName = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Cell name, this server will serve.";
|
|
|
|
example = "grand.central.org";
|
|
|
|
};
|
|
|
|
|
|
|
|
cellServDB = mkOption {
|
|
|
|
default = [];
|
|
|
|
type = with types; listOf (submodule [ { options = cellServDBConfig;} ]);
|
|
|
|
description = "Definition of all cell-local database server machines.";
|
|
|
|
};
|
|
|
|
|
2018-06-29 22:34:35 +00:00
|
|
|
package = mkOption {
|
|
|
|
default = pkgs.openafs.server or pkgs.openafs;
|
2018-10-18 11:11:52 +00:00
|
|
|
defaultText = "pkgs.openafs.server or pkgs.openafs";
|
2018-06-29 22:34:35 +00:00
|
|
|
type = types.package;
|
|
|
|
description = "OpenAFS package for the server binaries";
|
|
|
|
};
|
|
|
|
|
2018-01-24 17:32:33 +00:00
|
|
|
roles = {
|
|
|
|
fileserver = {
|
|
|
|
enable = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = "Fileserver role, serves files and volumes from its local storage.";
|
|
|
|
};
|
|
|
|
|
|
|
|
fileserverArgs = mkOption {
|
|
|
|
default = "-vattachpar 128 -vhashsize 11 -L -rxpck 400 -cb 1000000";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the dafileserver process. See its man page.";
|
|
|
|
};
|
|
|
|
|
|
|
|
volserverArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the davolserver process. See its man page.";
|
|
|
|
example = "-sync never";
|
|
|
|
};
|
|
|
|
|
|
|
|
salvageserverArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the salvageserver process. See its man page.";
|
|
|
|
example = "-showlog";
|
|
|
|
};
|
|
|
|
|
|
|
|
salvagerArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the dasalvager process. See its man page.";
|
|
|
|
example = "-showlog -showmounts";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
database = {
|
|
|
|
enable = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Database server role, maintains the Volume Location Database,
|
|
|
|
Protection Database (and Backup Database, see
|
|
|
|
<literal>backup</literal> role). There can be multiple
|
|
|
|
servers in the database role for replication, which then need
|
|
|
|
reliable network connection to each other.
|
|
|
|
|
|
|
|
Servers in this role appear in AFSDB DNS records or the
|
|
|
|
CellServDB.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
vlserverArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the vlserver process. See its man page.";
|
|
|
|
example = "-rxbind";
|
|
|
|
};
|
|
|
|
|
|
|
|
ptserverArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the ptserver process. See its man page.";
|
|
|
|
example = "-restricted -default_access S---- S-M---";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
backup = {
|
|
|
|
enable = mkOption {
|
|
|
|
default = false;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Backup server role. Use in conjunction with the
|
|
|
|
<literal>database</literal> role to maintain the Backup
|
|
|
|
Database. Normally only used in conjunction with tape storage
|
|
|
|
or IBM's Tivoli Storage Manager.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
buserverArgs = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.str;
|
|
|
|
description = "Arguments to the buserver process. See its man page.";
|
|
|
|
example = "-p 8";
|
|
|
|
};
|
|
|
|
|
|
|
|
cellServDB = mkOption {
|
|
|
|
default = [];
|
|
|
|
type = with types; listOf (submodule [ { options = cellServDBConfig;} ]);
|
|
|
|
description = ''
|
|
|
|
Definition of all cell-local backup database server machines.
|
|
|
|
Use this when your cell uses less backup database servers than
|
|
|
|
other database server machines.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
dottedPrincipals= mkOption {
|
|
|
|
default = false;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
If enabled, allow principal names containing (.) dots. Enabling
|
|
|
|
this has security implications!
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
udpPacketSize = mkOption {
|
|
|
|
default = 1310720;
|
|
|
|
type = types.int;
|
|
|
|
description = ''
|
|
|
|
UDP packet size to use in Bytes. Higher values can speed up
|
|
|
|
communications. The default of 1 MB is a sufficient in most
|
|
|
|
cases. Make sure to increase the kernel's UDP buffer size
|
|
|
|
accordingly via <literal>net.core(w|r|opt)mem_max</literal>
|
|
|
|
sysctl.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
|
|
|
|
assertions = [
|
|
|
|
{ assertion = cfg.cellServDB != [];
|
|
|
|
message = "You must specify all cell-local database servers in config.services.openafsServer.cellServDB.";
|
|
|
|
}
|
|
|
|
{ assertion = cfg.cellName != "";
|
|
|
|
message = "You must specify the local cell name in config.services.openafsServer.cellName.";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
2018-06-29 22:34:35 +00:00
|
|
|
environment.systemPackages = [ openafsBin ];
|
2018-01-24 17:32:33 +00:00
|
|
|
|
|
|
|
environment.etc = {
|
|
|
|
bosConfig = {
|
|
|
|
source = bosConfig;
|
|
|
|
target = "openafs/BosConfig";
|
|
|
|
mode = "0644";
|
|
|
|
};
|
|
|
|
cellServDB = {
|
|
|
|
text = mkCellServDB cfg.cellName cfg.cellServDB;
|
|
|
|
target = "openafs/server/CellServDB";
|
|
|
|
mode = "0644";
|
|
|
|
};
|
|
|
|
thisCell = {
|
|
|
|
text = cfg.cellName;
|
|
|
|
target = "openafs/server/ThisCell";
|
|
|
|
mode = "0644";
|
|
|
|
};
|
|
|
|
buCellServDB = {
|
|
|
|
enable = (cfg.roles.backup.cellServDB != []);
|
|
|
|
text = mkCellServDB cfg.cellName cfg.roles.backup.cellServDB;
|
|
|
|
target = "openafs/backup/CellServDB";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services = {
|
|
|
|
openafs-server = {
|
|
|
|
description = "OpenAFS server";
|
|
|
|
after = [ "syslog.target" "network.target" ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
restartIfChanged = false;
|
2018-06-29 22:34:35 +00:00
|
|
|
unitConfig.ConditionPathExists = [
|
|
|
|
"|/etc/openafs/server/rxkad.keytab"
|
|
|
|
"|/etc/openafs/server/KeyFileExt"
|
|
|
|
];
|
2018-01-24 17:32:33 +00:00
|
|
|
preStart = ''
|
|
|
|
mkdir -m 0755 -p /var/openafs
|
|
|
|
${optionalString (netInfo != null) "cp ${netInfo} /var/openafs/netInfo"}
|
|
|
|
${optionalString (cfg.roles.backup.cellServDB != []) "cp ${buCellServDB}"}
|
|
|
|
'';
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = "${openafsBin}/bin/bosserver -nofork";
|
|
|
|
ExecStop = "${openafsBin}/bin/bos shutdown localhost -wait -localauth";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|