nixos-config/machines/orbi/service-photoprism.nix

71 lines
1.9 KiB
Nix
Raw Normal View History

2024-05-10 20:53:21 +02:00
{ config, pkgs, lib, ... }:
let
mySQLPackage = pkgs.mysql;
photoprismPort = 2342;
mysqlPort = 3336;
in
{
2024-05-10 23:17:45 +02:00
networking.firewall.interfaces.wg0.allowedTCPPorts = [ photoprismPort ];
# networking.firewall.interfaces.wg0.allowedUDPPorts = [ photoprismPort ];
2024-05-10 20:53:21 +02:00
containers.photoprism = {
privateNetwork = false;
autoStart = true;
2024-05-18 12:02:21 +02:00
config = { config, lib, ... }: {
nixpkgs.pkgs = pkgs;
2024-05-18 23:57:31 +02:00
imports = [ ../../components/monitor/container.nix ];
2024-05-10 20:53:21 +02:00
system.stateVersion = "23.11";
services.logrotate.checkConfig = false; # because uid 3000 does not exist in here
2024-05-10 20:53:21 +02:00
# Photoprism
# ----------
services.photoprism = {
enable = true;
port = photoprismPort;
2024-06-20 16:04:05 +02:00
package = pkgs.photoprism;
2024-05-10 20:53:21 +02:00
originalsPath = "/var/lib/private/photoprism/originals";
address = "0.0.0.0";
settings = {
PHOTOPRISM_ADMIN_USER = "admin";
PHOTOPRISM_ADMIN_PASSWORD = "...";
PHOTOPRISM_DEFAULT_LOCALE = "en";
PHOTOPRISM_DATABASE_DRIVER = "mysql";
PHOTOPRISM_DATABASE_NAME = "photoprism";
PHOTOPRISM_DATABASE_SERVER = "/run/mysqld/mysqld.sock";
PHOTOPRISM_DATABASE_USER = "photoprism";
PHOTOPRISM_SITE_URL = "http://photoprism.orbi.private:${toString photoprismPort}";
PHOTOPRISM_SITE_TITLE = "PhotoPrism";
};
};
# MySQL Database
# --------------
services.mysql = {
enable = true;
package = mySQLPackage;
settings.mysqld.port = mysqlPort;
ensureDatabases = [ "photoprism" ];
ensureUsers = [{
name = "photoprism";
ensurePermissions = {
"photoprism.*" = "ALL PRIVILEGES";
};
}];
};
# Backup Database
# ---------------
services.mysqlBackup = {
enable = true;
databases = config.services.mysql.ensureDatabases;
singleTransaction = true;
};
};
};
}