You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nixos/modules/hosting/rmfakecloud.nix

62 lines
1.4 KiB
Nix

{ pkgs, config, lib, ... }:
with lib;
let
cfg = config.hosting.rmfakecloud;
domain = config.networking.domain;
in
{
options.hosting.rmfakecloud = {
enable = mkEnableOption "rmfakecloud";
port = mkOption {
type = types.port;
default = 8082;
};
domain = mkOption {
type = types.str;
default = "rmfakecloud.${domain}";
};
};
config = lib.mkIf cfg.enable {
services.rmfakecloud = {
enable = true;
storageUrl = "https://${cfg.domain}";
port = cfg.port;
environmentFile = "${config.custom.secretsDir}/rmfakecloud.env";
extraSettings = {
RM_SMTP_SERVER = "mail.freumh.org:465";
RM_SMTP_USERNAME = "misc@${domain}";
RM_SMTP_FROM="remarkable@${domain}";
};
};
mailserver.loginAccounts."misc@${domain}".aliases = [ "remarkable@${domain}" ];
# nginx handles letsencrypt
services.nginx = {
enable = true;
recommendedProxySettings = true;
# to allow syncing
# another option would just be opening a separate port for this
clientMaxBodySize = "100M";
virtualHosts."${cfg.domain}" = {
forceSSL = true;
enableACME = true;
locations."/".proxyPass = ''
http://localhost:${builtins.toString cfg.port}
'';
};
};
dns.records = [
{
name = "rmfakecloud";
type = "CNAME";
data = "vps";
}
];
};
}