Add a module for nextcloud-cli-client

This commit is contained in:
Andreas Zweili 2024-02-11 18:06:10 +01:00
parent a20ec71063
commit d7370e206a
5 changed files with 110 additions and 0 deletions

View File

@ -33,6 +33,7 @@
./services/mariadb-for-containers
./services/media-share
./services/nextcloud
./services/nextcloud-cli-client
./services/nginx-acme-base
./services/nginx-fpm
./services/nginx-proxy

View File

@ -0,0 +1,74 @@
{
config,
inputs,
lib,
pkgs,
...
}:
let
cfg = config.services.az-nextcloud-cli-client;
pathToMonitor = "/home/${config.az-username}/nextcloud/10_documents/";
monitor-notes = pkgs.writeShellScriptBin "monitor-notes" ''
${pkgs.nextcloud-client}/bin/nextcloudcmd \
--user andreas \
--password $(cat ${config.age.secrets.nextcloudCliSecrets.path}) \
--non-interactive \
--path /10_documents \
${pathToMonitor} \
https://nextcloud.2li.ch
'';
in
{
options = {
services.az-nextcloud-cli-client.enable = lib.mkEnableOption "Enable my implementation of a Nextcloud headless client";
};
config = lib.mkIf cfg.enable {
environment.systemPackages = [ pkgs.nextcloud-client ];
services.az-telegram-notifications.enable = true;
age.secrets.nextcloudCliSecrets = {
file = "${inputs.self}/scrts/nextcloud_cli.age";
path = "/home/${config.az-username}/.config/nextcloud_cli/nextcloud_cli.key";
mode = "600";
owner = "${config.az-username}";
group = "users";
};
systemd.timers."nextcloud-sync" = {
wantedBy = [ "timers.target" ];
partOf = [ "nextcloud-sync.service" ];
timerConfig = {
OnStartupSec = "5min";
OnUnitActiveSec = "5min";
};
};
systemd.services."nextcloud-sync" = {
after = [ "network-online.target" ];
serviceConfig = {
User = config.az-username;
Type = "oneshot";
};
onFailure = [ "unit-status-telegram@%n.service" ];
script = "${monitor-notes}/bin/monitor-notes";
};
systemd.services."nextcloud-monitor" = {
requires = [ "network-online.target" ];
after = [ "network-online.target" ];
serviceConfig = {
User = config.az-username;
};
onFailure = [ "unit-status-telegram@%n.service" ];
wantedBy = [ "multi-user.target" ];
script = ''
${pkgs.inotify-tools}/bin/inotifywait -m -r -e create,modify,delete,move "${pathToMonitor}" |
while read -r directory event file; do
sleep 10
${monitor-notes}/bin/monitor-notes
done
'';
};
};
}

33
scrts/nextcloud_cli.age Normal file
View File

@ -0,0 +1,33 @@
age-encryption.org/v1
-> ssh-rsa 7S8lxw
KFe28MS4Ow4aayFS18ywfn6bUnUoP9nQT+xc6n3QDrHJqw3qj34TtQ0n2RQc3Bhj
/qsn03s1KgCid0Nb80xzMUWBxiIRCG5LT72wflZatUe3HiTxPD+/TdzTDfNOfhnx
WxpA6yV1cfOrjgLPgp5tRwX2FxhxUkpTTeBCDgrJDeumnRuNjOGY+HcGmtNYVHSh
o9t0j8ZrvRI2wbwakY42sEREXA0WfgSoQq6PL3SvvWUISqbihkKQEkyQaGKiA3E9
fT8EyR5lNvOh+z4HLtNni9IUVAim8SZAuSqrh8vEl/gEanbqRpO/f4GvP9MmU//E
IqCWoQwMsjhpZd/tz7HxkmFP4tiXvJcvW1lOkTR2w4XJpw/Al8n8xlOm/iMKSPW6
kiGurRkzgYqn7H371IC4/YTTTTgoKr6K68Z04ImG7ydy9dG4xW/9uQMwWXzu6rB4
FmQwXf9J1EpJijOh6wu3APQyLa8vv9kqHVs4mTdh6xnsZn5AvdBlC+pqB78uSxkm
-> ssh-ed25519 Xj0rlw DiXhwtInAOcOsmcoM0xAnroR1+jjyWQvDgyxFo+JtEk
+ZJZWEBl4mBWHI2OVs1F3rRSFyzZW+efnXTRkady3Eg
-> ssh-rsa Ws+JZA
jZJNM68C/hHmZf2B/DkeRPCNLOkZMCDtYEzzyikJdV273WuhsAtw2qohM+mPwH2c
i8MJck/vCdfMXtGOQlUyA032EZCMicJewcmUiokZpf64FF9vw90tDaitDKX/M8BB
ISfXDOoysSlSwXOdT2+NAgopT4etM4npeSuE/ZZI5ZsSnP0lED2CxVcCSMX3uNVZ
3HxroysgUt9zJln5z+OvZqqzrOdrg8ucYybwnigQgxypVGDhkvqGm1k9rPXQKar1
/+lFe+go5l6nMIwEQtBoBfAOu/uP22pQAGFNzuzM/H2iIDa8QqA3NI4esjvwfe96
mWBuI9rsKcFSBeRa4vqMv2S6ypnttJzZGfDye9JkIn5HneGDN6cabuBX+xnx7DAB
MlY/gkMcZ/kNozh6db81eOQQtvZBkps7jx3UdRdCtkFWlM7R+XCOSCW5TZRTitcg
+g3WclHIMd47F68gVn8rHwASuUPrbquMpWL+j25nxVabmIx4dML0LXg/e/LnoHHv
-> ssh-ed25519 skmU/w +tmWBmy+j5T7S93a2PyyoIWmCtEnhZUEpgqNDXqPMDA
kmJyRBOMLQE4JbUDADwFS5Q8qzgnQls6Gs6Qt8Hdvj8
-> ssh-ed25519 YoupUg xe5vwT1FdxXK0Z7tdPuKADE6r2jWjChPpIQCcGBKqDQ
jlRtPl1cwyr+bA5g6iEu4PZVkofmcQa7sX34Xu7Ns2E
-> ssh-ed25519 KXqA9w CW8exLU6olSUluG5d2eGRcAFvYsqwpJboRpW5OqdVXA
MNmrx6+yFfHD2QMTWgCylsdBVjGn1QAhoxMfv116g8k
-> ssh-ed25519 O6+Deg wOAQ/0j4nuEE+CKTVwNK6peVQSO40sxucsKg1Kw67Ew
Aw+RDGCdgBftnjHBVz4crij0A2DkEvKKSB/FGh6lwks
--- xMBpypDreUVc9bBijQ8BnRxdhyOTKscTw8RBNx4qpwA
¨Ñh)»½qiFO6F*¥b˜L¨™…*\r<>ï&¥Ý¥xf2nÅô³ô¿D>çvÁµ‡zâêžH0ê[

View File

@ -53,6 +53,7 @@ in
"gitea_env.age".publicKeys = defaultKeys ++ [ git ];
"infomaniak_env.age".publicKeys = all;
"nextcloud_env.age".publicKeys = defaultKeys ++ [ nextcloud ];
"nextcloud_cli.age".publicKeys = defaultKeys;
"personal_email.key.age".publicKeys = defaultKeys;
"plex_claim.age".publicKeys = defaultKeys ++ [ plex ];
"restic.key.age".publicKeys = all;

View File

@ -13,6 +13,7 @@
az-data-share.enable = true;
az-docker.enable = true;
az-logs-share.enable = true;
az-nextcloud-cli-client.enable = true;
az-restic-client-server = {
enable = true;
path = "/home/andreas";