···
+
{ config, pkgs, lib, ... }:
+
with import ./lib.nix { inherit lib; };
+
inherit (lib) concatStringsSep intersperse mapAttrsToList mkForce mkIf mkMerge mkOption optionalString types;
+
bosConfig = pkgs.writeText "BosConfig" (''
+
'' + (optionalString cfg.roles.database.enable ''
+
bnode simple vlserver 1
+
parm ${openafsBin}/libexec/openafs/vlserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.vlserverArgs}
+
bnode simple ptserver 1
+
parm ${openafsBin}/libexec/openafs/ptserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.ptserverArgs}
+
'') + (optionalString cfg.roles.fileserver.enable ''
+
parm ${openafsBin}/libexec/openafs/dafileserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.fileserverArgs}
+
parm ${openafsBin}/libexec/openafs/davolserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.volserverArgs}
+
parm ${openafsBin}/libexec/openafs/salvageserver ${cfg.roles.fileserver.salvageserverArgs}
+
parm ${openafsBin}/libexec/openafs/dasalvager ${cfg.roles.fileserver.salvagerArgs}
+
'') + (optionalString (cfg.roles.database.enable && cfg.roles.backup.enable) ''
+
bnode simple buserver 1
+
parm ${openafsBin}/libexec/openafs/buserver ${cfg.roles.backup.buserverArgs} ${optionalString (cfg.roles.backup.cellServDB != []) "-cellservdb /etc/openafs/backup/"}
+
netInfo = if (cfg.advertisedAddresses != []) then
+
pkgs.writeText "NetInfo" ((concatStringsSep "\nf " cfg.advertisedAddresses) + "\n")
+
buCellServDB = pkgs.writeText "backup-cellServDB-${cfg.cellName}" (mkCellServDB cfg.cellName cfg.roles.backup.cellServDB);
+
cfg = config.services.openafsServer;
+
udpSizeStr = toString cfg.udpPacketSize;
+
openafsBin = lib.getBin pkgs.openafs;
+
services.openafsServer = {
+
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
+
advertisedAddresses = mkOption {
+
description = "List of IP addresses this server is advertised under. See NetInfo(5)";
+
description = "Cell name, this server will serve.";
+
example = "grand.central.org";
+
cellServDB = mkOption {
+
type = with types; listOf (submodule [ { options = cellServDBConfig;} ]);
+
description = "Definition of all cell-local database server machines.";
+
description = "Fileserver role, serves files and volumes from its local storage.";
+
fileserverArgs = mkOption {
+
default = "-vattachpar 128 -vhashsize 11 -L -rxpck 400 -cb 1000000";
+
description = "Arguments to the dafileserver process. See its man page.";
+
volserverArgs = mkOption {
+
description = "Arguments to the davolserver process. See its man page.";
+
example = "-sync never";
+
salvageserverArgs = mkOption {
+
description = "Arguments to the salvageserver process. See its man page.";
+
salvagerArgs = mkOption {
+
description = "Arguments to the dasalvager process. See its man page.";
+
example = "-showlog -showmounts";
+
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
+
vlserverArgs = mkOption {
+
description = "Arguments to the vlserver process. See its man page.";
+
ptserverArgs = mkOption {
+
description = "Arguments to the ptserver process. See its man page.";
+
example = "-restricted -default_access S---- S-M---";
+
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 {
+
description = "Arguments to the buserver process. See its man page.";
+
cellServDB = mkOption {
+
type = with types; listOf (submodule [ { options = cellServDBConfig;} ]);
+
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 {
+
If enabled, allow principal names containing (.) dots. Enabling
+
this has security implications!
+
udpPacketSize = mkOption {
+
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>
+
config = mkIf cfg.enable {
+
{ 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.";
+
environment.systemPackages = [ pkgs.openafs ];
+
target = "openafs/BosConfig";
+
text = mkCellServDB cfg.cellName cfg.cellServDB;
+
target = "openafs/server/CellServDB";
+
target = "openafs/server/ThisCell";
+
enable = (cfg.roles.backup.cellServDB != []);
+
text = mkCellServDB cfg.cellName cfg.roles.backup.cellServDB;
+
target = "openafs/backup/CellServDB";
+
description = "OpenAFS server";
+
after = [ "syslog.target" "network.target" ];
+
wantedBy = [ "multi-user.target" ];
+
restartIfChanged = false;
+
unitConfig.ConditionPathExists = [ "/etc/openafs/server/rxkad.keytab" ];
+
mkdir -m 0755 -p /var/openafs
+
${optionalString (netInfo != null) "cp ${netInfo} /var/openafs/netInfo"}
+
${optionalString (cfg.roles.backup.cellServDB != []) "cp ${buCellServDB}"}
+
ExecStart = "${openafsBin}/bin/bosserver -nofork";
+
ExecStop = "${openafsBin}/bin/bos shutdown localhost -wait -localauth";