70 lines
2.2 KiB
Nix
70 lines
2.2 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
let
|
|
cfg = config.ragon.services.hedgedoc;
|
|
in
|
|
{
|
|
options.ragon.services.hedgedoc.enable = lib.mkEnableOption "Enables the hedgedoc BitWarden Server";
|
|
options.ragon.services.hedgedoc.domain =
|
|
lib.mkOption {
|
|
type = lib.types.str;
|
|
default = "md.xyno.systems";
|
|
};
|
|
config = lib.mkIf cfg.enable {
|
|
ragon.agenix.secrets.autheliaHedgedoc = { owner = "authelia-main"; };
|
|
services.authelia.instances.main.settingsFiles = [
|
|
config.age.secrets.autheliaHedgedoc.path
|
|
];
|
|
services.hedgedoc = {
|
|
enable = true;
|
|
environmentFile = "${config.age.secrets.hedgedocSecret.path}";
|
|
settings = {
|
|
protocolUseSSL = true;
|
|
sessionSecret = "$SESSION_SECRET";
|
|
allowAnonymous = false;
|
|
allowAnonymousEdits = false;
|
|
allowFreeURL = true;
|
|
email = false;
|
|
oauth2 = {
|
|
clientID = "$CLIENT_ID";
|
|
clientSecret = "$CLIENT_SECRET";
|
|
providerName = "xyno.systems SSO";
|
|
authorizationURL = "https://sso.xyno.systems/api/oidc/authorize";
|
|
tokenURL = "https://sso.xyno.systems/api/oidc/token";
|
|
userProfileURL = "https://sso.xyno.systems/api/oidc/userinfo";
|
|
scope = "openid profile email";
|
|
userProfileUsernameAttr = "sub";
|
|
userProfileEmailAttr = "email";
|
|
userProfileDisplayNameAttr = "name";
|
|
};
|
|
domain = "${cfg.domain}";
|
|
db = {
|
|
dialect = "postgres";
|
|
host = "/run/postgresql";
|
|
database = "hedgedoc";
|
|
};
|
|
};
|
|
|
|
};
|
|
ragon.agenix.secrets.hedgedocSecret.owner = "hedgedoc";
|
|
services.nginx.virtualHosts."${cfg.domain}" = {
|
|
locations."/".proxyWebsockets = true;
|
|
locations."/".proxyPass = "http://[::1]:${toString config.services.hedgedoc.settings.port}";
|
|
} // (lib.my.findOutTlsConfig cfg.domain config);
|
|
services.postgresql = {
|
|
|
|
enable = true;
|
|
|
|
# Ensure the database, user, and permissions always exist
|
|
ensureDatabases = [ "hedgedoc" ];
|
|
ensureUsers = [
|
|
{
|
|
name = "hedgedoc";
|
|
ensurePermissions."DATABASE hedgedoc" = "ALL PRIVILEGES";
|
|
}
|
|
];
|
|
};
|
|
ragon.persist.extraDirectories = [
|
|
"/var/lib/hedgedoc"
|
|
];
|
|
};
|
|
}
|