{ lib, config, proxyReverse, setup, ... }: let cfg = config.my.servers.maloja; in { options.my.servers.maloja = setup.mkOptions "maloja" "maloja" 42010; config = lib.mkIf cfg.enable { sops.secrets.maloja.sopsFile = ../../secrets/env.yaml; virtualisation.oci-containers.containers.maloja = { image = "krateng/maloja"; ports = [ "${toString cfg.port}:${toString cfg.port}" ]; environmentFiles = [ config.sops.secrets.maloja.path ]; environment = { TZ = "America/Mexico_City"; MALOJA_TIMEZONE = "-6"; PUID = "1000"; PGID = "100"; MALOJA_DATA_DIRECTORY = "/mljdata"; MALOJA_SKIP_SETUP = "true"; }; volumes = [ "${config.my.containerData}/maloja:/mljdata" ]; labels = { "flame.type" = "application"; "flame.name" = "Maloja"; "flame.url" = cfg.url; "flame.icon" = "bookmark-music"; }; }; services.nginx.virtualHosts."${cfg.host}" = proxyReverse cfg.port // { }; }; }