Compare commits
2 commits
a3d1233ad1
...
61fecf3bdb
Author | SHA1 | Date | |
---|---|---|---|
61fecf3bdb | |||
9590b879ed |
6 changed files with 92 additions and 27 deletions
|
@ -116,7 +116,7 @@
|
||||||
owner = "grafana";
|
owner = "grafana";
|
||||||
group = "forgejo";
|
group = "forgejo";
|
||||||
};
|
};
|
||||||
|
"firefly-app-key".owner = "firefly-iii";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
"syncthing"
|
"syncthing"
|
||||||
"atticd"
|
"atticd"
|
||||||
"jellyfin"
|
"jellyfin"
|
||||||
|
"firefly"
|
||||||
]
|
]
|
||||||
++ [
|
++ [
|
||||||
./disko.nix
|
./disko.nix
|
||||||
|
|
|
@ -15,6 +15,8 @@
|
||||||
"photos.aciceri.dev"
|
"photos.aciceri.dev"
|
||||||
"status.aciceri.dev"
|
"status.aciceri.dev"
|
||||||
"jelly.aciceri.dev"
|
"jelly.aciceri.dev"
|
||||||
|
"firefly.aciceri.dev"
|
||||||
|
"import.firefly.aciceri.dev"
|
||||||
];
|
];
|
||||||
apiTokenFile = config.age.secrets.cloudflare-dyndns-api-token.path;
|
apiTokenFile = config.age.secrets.cloudflare-dyndns-api-token.path;
|
||||||
};
|
};
|
||||||
|
|
67
modules/firefly/default.nix
Normal file
67
modules/firefly/default.nix
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
{ pkgs, config, ... }:
|
||||||
|
let
|
||||||
|
domain = "firefly.aciceri.dev";
|
||||||
|
domainImporter = "import.firefly.aciceri.dev";
|
||||||
|
dbUser = config.services.firefly-iii.user;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
services.firefly-iii = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.firefly-iii;
|
||||||
|
virtualHost = domain;
|
||||||
|
enableNginx = true;
|
||||||
|
settings = {
|
||||||
|
APP_ENV = "production";
|
||||||
|
APP_KEY_FILE = config.age.secrets.firefly-app-key.path;
|
||||||
|
SITE_OWNER = "andrea.ciceri@autistici.org";
|
||||||
|
DB_CONNECTION = "pgsql";
|
||||||
|
DEFAULT_LANGUAGE = "en_US";
|
||||||
|
TZ = "Europe/Rome";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.firefly-iii-data-importer = {
|
||||||
|
enable = true;
|
||||||
|
enableNginx = true;
|
||||||
|
virtualHost = domainImporter;
|
||||||
|
settings = {
|
||||||
|
IGNORE_DUPLICATE_ERRORS = "false";
|
||||||
|
APP_ENV = "production";
|
||||||
|
APP_DEBUG = "false";
|
||||||
|
LOG_CHANNEL = "stack";
|
||||||
|
TRUSTED_PROXIES = "**";
|
||||||
|
TZ = "Europe/Rome";
|
||||||
|
FIREFLY_III_URL = "https://${domain}";
|
||||||
|
VANITY_URL = "https://${domain}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
imports = [ ../nginx-base ];
|
||||||
|
|
||||||
|
services.nginx.virtualHosts = {
|
||||||
|
${domain} = {
|
||||||
|
enableACME = true;
|
||||||
|
forceSSL = true;
|
||||||
|
};
|
||||||
|
${domainImporter} = {
|
||||||
|
enableACME = true;
|
||||||
|
forceSSL = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.postgresql = {
|
||||||
|
ensureUsers = [
|
||||||
|
{
|
||||||
|
name = dbUser;
|
||||||
|
ensureDBOwnership = true;
|
||||||
|
ensureClauses.login = true;
|
||||||
|
}
|
||||||
|
];
|
||||||
|
ensureDatabases = [ dbUser ];
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.persistence."/persist".directories = [
|
||||||
|
config.services.firefly-iii.dataDir
|
||||||
|
config.services.firefly-iii-data-importer.dataDir
|
||||||
|
];
|
||||||
|
}
|
17
secrets/firefly-app-key.age
Normal file
17
secrets/firefly-app-key.age
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
age-encryption.org/v1
|
||||||
|
-> ssh-rsa /AagBw
|
||||||
|
MmxPeP4hU2l5lrGOzfZk9opd2NoVG8Y2fdSLCZH7bJwHEWexmsSFJN8n6XrmbMwo
|
||||||
|
LthbkBhkdANoyeVlCOvz35k5lzTsLcYjizfEYaqliCEIRFvcUxhcyk4HzV1D11jD
|
||||||
|
mMEzk1WsqGdd9ejLebqskUkCFRKp4d+W0tODeOo+qoXhDJ/rq/zitXqLQbajK2a1
|
||||||
|
11S/UhOElizE65Onv2PgLKMiRkpjdVwAzf2CMnGKJ0E9CSwBLgHeqdDHooxzXPMb
|
||||||
|
OGWdg3xTxLALfbeEBgfxmTGafe44cFjq/T80qte9Q2eWzboO8GqvxTgF/Cx4nVgF
|
||||||
|
InJhD7cdubO31CfdZGb6pIHgRs2De9MRjQ7oO4F8N1q79Wh/3NSAaeItyHM7AnK6
|
||||||
|
Yc0lO2HQF8NhDfeu+dca5G6TF8Zi7ehLe1tv6WNOC3OVo/11X12M3Nqu6oKhRiGz
|
||||||
|
VXiJ8EHwGm4MHcBP8j8ulBkHJUR9MERZuVengROYl4TkT/bWKYu+4ISjl8sLJorh
|
||||||
|
jHmfjViGtAD1sqrYpCzylm7ufZeZ4sv38EwEpMneG/1SIpIwP47wkzKUjb8RdXrc
|
||||||
|
xWqFzLP0Lj4PAwT1lB0awTc2+niko+3P+ABpxnJ3QLNJLOtXJuuVAcsLl5EsEFKc
|
||||||
|
VDmwA/tzgfXkNI3eGXukrM/GiwpRYMfkWzz6/ijvLug
|
||||||
|
-> ssh-ed25519 +vdRnA m9PlgKXpW2mKUt+S1mgWrbVvv3LDzVUKg0u22QMmXis
|
||||||
|
3rdA1dsQ26+vacNk+5j/+uMfG/zE2pE21zMKZy6MxsI
|
||||||
|
--- CDzukG+NpxaQvo7SFGfBbS8MV5yCl/tmla59lpSaT5s
|
||||||
|
:}ôàn<C3A0>4q‹}Ó'”ð6EßEc°+’!ñïi_™Ä´$Í|ùà¥È<C2A5>¥efƒ™´úEâðâÕŒ!(I/D놢Áb»<62>›tYS íÔ:Tbø<07>“
|
|
@ -37,62 +37,52 @@ with keys.users;
|
||||||
];
|
];
|
||||||
"autistici-password.age".publicKeys = [
|
"autistici-password.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
kirk
|
kirk
|
||||||
picard
|
picard
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"hercules-ci-join-token.age".publicKeys = [
|
"hercules-ci-join-token.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
mothership
|
mothership
|
||||||
sisko
|
sisko
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"hercules-ci-binary-caches.age".publicKeys = [
|
"hercules-ci-binary-caches.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
mothership
|
mothership
|
||||||
sisko
|
sisko
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"hercules-ci-secrets-json.age".publicKeys = [
|
"hercules-ci-secrets-json.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
mothership
|
mothership
|
||||||
sisko
|
sisko
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"minio-credentials.age".publicKeys = [
|
"minio-credentials.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"aws-credentials.age".publicKeys = [
|
"aws-credentials.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"nextcloud-admin-pass.age".publicKeys = [
|
"nextcloud-admin-pass.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"home-planimetry.age".publicKeys = [
|
"home-planimetry.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"home-assistant-token.age".publicKeys = [
|
"home-assistant-token.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"chatgpt-token.age".publicKeys = [
|
"chatgpt-token.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
kirk
|
kirk
|
||||||
mothership
|
mothership
|
||||||
picard
|
picard
|
||||||
|
@ -100,86 +90,74 @@ with keys.users;
|
||||||
];
|
];
|
||||||
"cloudflare-dyndns-api-token.age".publicKeys = [
|
"cloudflare-dyndns-api-token.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"restic-hetzner-password.age".publicKeys = [
|
"restic-hetzner-password.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
sisko
|
sisko
|
||||||
kirk
|
kirk
|
||||||
];
|
];
|
||||||
"hass-ssh-key.age".publicKeys = [
|
"hass-ssh-key.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"grafana-password.age".publicKeys = [
|
"grafana-password.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"matrix-registration-shared-secret.age".publicKeys = [
|
"matrix-registration-shared-secret.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"matrix-sliding-sync-secret.age".publicKeys = [
|
"matrix-sliding-sync-secret.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"forgejo-runners-token.age".publicKeys = [
|
"forgejo-runners-token.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"forgejo-nix-access-tokens.age".publicKeys = [
|
"forgejo-nix-access-tokens.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"garmin-collector-environment.age".publicKeys = [
|
"garmin-collector-environment.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"hetzner-storage-box-sisko-ssh-password.age".publicKeys = [
|
"hetzner-storage-box-sisko-ssh-password.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"sisko-restic-password.age".publicKeys = [
|
"sisko-restic-password.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"sisko-attic-environment-file.age".publicKeys = [
|
"sisko-attic-environment-file.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
sisko
|
||||||
|
];
|
||||||
|
"firefly-app-key.age".publicKeys = [
|
||||||
|
ccr-ssh
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
|
|
||||||
# WireGuard
|
# WireGuard
|
||||||
"picard-wireguard-private-key.age".publicKeys = [
|
"picard-wireguard-private-key.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
picard
|
picard
|
||||||
];
|
];
|
||||||
"sisko-wireguard-private-key.age".publicKeys = [
|
"sisko-wireguard-private-key.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
sisko
|
sisko
|
||||||
];
|
];
|
||||||
"kirk-wireguard-private-key.age".publicKeys = [
|
"kirk-wireguard-private-key.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
kirk
|
kirk
|
||||||
];
|
];
|
||||||
"deltaflyer-wireguard-private-key.age".publicKeys = [
|
"deltaflyer-wireguard-private-key.age".publicKeys = [
|
||||||
ccr-ssh
|
ccr-ssh
|
||||||
|
|
||||||
deltaflyer
|
deltaflyer
|
||||||
];
|
];
|
||||||
"tpol-wireguard-private-key.age".publicKeys = [
|
"tpol-wireguard-private-key.age".publicKeys = [
|
||||||
|
|
Loading…
Add table
Reference in a new issue