add forgejo module
This commit is contained in:
parent
0473f830f6
commit
1c2b67ba0c
|
@ -6,5 +6,6 @@
|
|||
}: {
|
||||
imports = [
|
||||
./trash
|
||||
./services
|
||||
];
|
||||
}
|
||||
|
|
10
nixos/services/default.nix
Normal file
10
nixos/services/default.nix
Normal file
|
@ -0,0 +1,10 @@
|
|||
{
|
||||
config,
|
||||
lib,
|
||||
pkgs,
|
||||
...
|
||||
}: {
|
||||
imports = [
|
||||
./forgejo
|
||||
];
|
||||
}
|
66
nixos/services/forgejo/default.nix
Normal file
66
nixos/services/forgejo/default.nix
Normal file
|
@ -0,0 +1,66 @@
|
|||
{
|
||||
config,
|
||||
lib,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
with lib; let
|
||||
cfg = config.options.trivium.services.forgejo;
|
||||
in {
|
||||
options.trivium.services.forgejo = {
|
||||
enable = mkEnableOption "forgejo settings";
|
||||
|
||||
virtualHost = mkOption {
|
||||
type = types.string;
|
||||
description = "Virtualhost to use for nginx's reverse proxy. Usually something like git.<your server>.com";
|
||||
};
|
||||
|
||||
appName = mkOption {
|
||||
type = types.string;
|
||||
description = "You guess what this does";
|
||||
};
|
||||
|
||||
disableRegistration = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = "Turn this off just to create the first admin account";
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
services = {
|
||||
nginx = {
|
||||
virtualHosts."${cfg.virtualHost}" = {
|
||||
enableACME = true;
|
||||
forceSSL = true;
|
||||
locations."/".proxyPass = "http://localhost:9170";
|
||||
};
|
||||
};
|
||||
|
||||
forgejo = {
|
||||
enable = true;
|
||||
lfs.enable = true;
|
||||
useWizard = false;
|
||||
settings = {
|
||||
general.APP_NAME = "${cfg.appName}";
|
||||
ui.DEFAULT_THEME = "forgejo-dark";
|
||||
server = {
|
||||
DOMAIN = "${cfg.virtualHost}";
|
||||
ROOT_URL = "https://${cfg.virtualHost}";
|
||||
HTTP_PORT = 9170;
|
||||
LANDING_PAGE = "explore";
|
||||
};
|
||||
|
||||
service.DISABLE_REGISTRATION = ${cfg.disableRegistration};
|
||||
|
||||
actions = {
|
||||
ENABLED = true;
|
||||
};
|
||||
mailer = {
|
||||
ENABLED = false;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
Loading…
Reference in a new issue