Add syncthing systemd dependencies
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
@@ -1,7 +1,17 @@
|
|||||||
{
|
{
|
||||||
username ? throw "username argument is required",
|
username ? throw "username argument is required",
|
||||||
}:
|
}:
|
||||||
{ config, ... }:
|
{
|
||||||
|
config,
|
||||||
|
inputs,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
userConfig = config.users.users.${username};
|
||||||
|
hmConfig = config.home-manager.users.${username};
|
||||||
|
in
|
||||||
{
|
{
|
||||||
networking.firewall = {
|
networking.firewall = {
|
||||||
allowedTCPPorts = [ 22000 ];
|
allowedTCPPorts = [ 22000 ];
|
||||||
@@ -24,18 +34,41 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
home-manager.users.${username}.services.syncthing = {
|
home-manager.users.${username} = {
|
||||||
enable = true;
|
services.syncthing = {
|
||||||
key = config.sops.secrets."syncthing/key".path;
|
enable = true;
|
||||||
cert = config.sops.secrets."syncthing/cert".path;
|
key = config.sops.secrets."syncthing/key".path;
|
||||||
extraOptions = [ "-no-default-folder" ];
|
cert = config.sops.secrets."syncthing/cert".path;
|
||||||
|
extraOptions = [ "-no-default-folder" ];
|
||||||
|
|
||||||
settings = {
|
settings = {
|
||||||
options.urAccepted = -1;
|
options.urAccepted = -1;
|
||||||
devices = {
|
devices = {
|
||||||
amalthea.id = "2W7YT6Q-TO7CYMW-JH6QZXE-7Q6MDQQ-HPHKP4A-VI5HP7G-KLMGMST-MNRYHQG"; # Google Pixel 8 Pro
|
amalthea.id = "2W7YT6Q-TO7CYMW-JH6QZXE-7Q6MDQQ-HPHKP4A-VI5HP7G-KLMGMST-MNRYHQG"; # Google Pixel 8 Pro
|
||||||
ganymede.id = "DXJPEJA-JNGF6I4-VIZYTX7-U345C5V-HIUTSFC-D36N2EM-Y3FAKJM-PRKYQAI"; # Samsung Galaxy Tab S7+
|
ganymede.id = "DXJPEJA-JNGF6I4-VIZYTX7-U345C5V-HIUTSFC-D36N2EM-Y3FAKJM-PRKYQAI"; # Samsung Galaxy Tab S7+
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
systemd.user.services.syncthing.Unit.After =
|
||||||
|
let
|
||||||
|
inherit (pkgs.callPackage "${inputs.impermanence}/lib.nix" { }) mkServiceName parentsOf;
|
||||||
|
removeHomePrefix =
|
||||||
|
path: lib.strings.removePrefix "~/" (lib.strings.removePrefix "${userConfig.home}/" path);
|
||||||
|
syncthingFolders = builtins.map (folder: removeHomePrefix folder.path) (
|
||||||
|
builtins.attrValues hmConfig.services.syncthing.settings.folders
|
||||||
|
);
|
||||||
|
in
|
||||||
|
lib.lists.flatten (
|
||||||
|
builtins.map (
|
||||||
|
persistence:
|
||||||
|
builtins.map (folder: "${mkServiceName persistence.persistentStoragePath folder}.service") (
|
||||||
|
builtins.filter (folder: builtins.elem folder persistence.directories) (
|
||||||
|
lib.lists.unique (lib.lists.flatten (builtins.map parentsOf syncthingFolders))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
) (builtins.attrValues hmConfig.home.persistence)
|
||||||
|
)
|
||||||
|
++ [ "sops-nix.service" ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user