Add immich to the set of programs we have configured
This commit is contained in:
parent
d6cb176357
commit
f54b895602
2 changed files with 63 additions and 0 deletions
62
nix/home/programs/immich/default.nix
Normal file
62
nix/home/programs/immich/default.nix
Normal file
|
|
@ -0,0 +1,62 @@
|
|||
{ lib, config, ... }:
|
||||
|
||||
let
|
||||
immichDomain = lib.strings.fileContents ../../../../secrets/letsencrypt/mediaserver/immichdomain;
|
||||
in
|
||||
{
|
||||
services.immich = {
|
||||
enable = true;
|
||||
port = 2283;
|
||||
mediaLocation = "/storage/organized/photos";
|
||||
|
||||
## Enable hardware acceleration for video
|
||||
# `null` will give access to all devices.
|
||||
# You may want to restrict this by using something like `[ "/dev/dri/renderD128" ]`
|
||||
accelerationDevices = null;
|
||||
|
||||
settings.server.externalDomain = "https://${immichDomain}";
|
||||
};
|
||||
|
||||
hardware.graphics = {
|
||||
enable = true;
|
||||
# Maybe we need more here, hard to say...
|
||||
};
|
||||
|
||||
users.users.immich.extraGroups = [ "video" "render" "multimedia"
|
||||
# something strange here about remote file-system groups...
|
||||
"jellyfin" ];
|
||||
|
||||
## Expose immich to "the world"
|
||||
networking.firewall = {
|
||||
allowedTCPPorts = [
|
||||
#nginx
|
||||
80
|
||||
443
|
||||
];
|
||||
};
|
||||
|
||||
services.nginx = {
|
||||
|
||||
recommendedProxySettings = true;
|
||||
recommendedGzipSettings = true;
|
||||
recommendedOptimisation = true;
|
||||
recommendedTlsSettings = true;
|
||||
|
||||
virtualHosts."${immichDomain}" = {
|
||||
forceSSL = true;
|
||||
enableACME = true;
|
||||
extraConfig = ''
|
||||
client_max_body_size 50000M;
|
||||
proxy_read_timeout 600s;
|
||||
proxy_send_timeout 600s;
|
||||
send_timeout 600s;
|
||||
'';
|
||||
|
||||
locations."/" = {
|
||||
proxyPass = "http://[::1]:${toString config.services.immich.port}";
|
||||
proxyWebsockets = true;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue