mirror of
https://github.com/itme-brain/nixos.git
synced 2026-03-24 00:29:43 -04:00
added server configs
This commit is contained in:
parent
34ce975a09
commit
10e8a34586
4 changed files with 152 additions and 2 deletions
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
modules = {
|
modules = {
|
||||||
system = {
|
system = {
|
||||||
|
nginx.enable = true;
|
||||||
|
forgejo.enable = true;
|
||||||
bitcoin = {
|
bitcoin = {
|
||||||
enable = true;
|
enable = true;
|
||||||
electrum.enable = true;
|
electrum.enable = true;
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
with lib;
|
with lib;
|
||||||
let
|
let
|
||||||
cfg = config.modules.system.bitcoin;
|
cfg = config.modules.system.bitcoin;
|
||||||
|
nginx = config.modules.system.nginx;
|
||||||
|
|
||||||
home = "/var/lib/bitcoind";
|
home = "/var/lib/bitcoind";
|
||||||
|
|
||||||
|
|
@ -35,6 +36,11 @@ in
|
||||||
group = "bitcoin";
|
group = "bitcoin";
|
||||||
createHome = true;
|
createHome = true;
|
||||||
};
|
};
|
||||||
|
"nginx" = {
|
||||||
|
extraGroups = mkIf nginx.enable [
|
||||||
|
"bitcoin"
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
groups = {
|
groups = {
|
||||||
"bitcoin" = {
|
"bitcoin" = {
|
||||||
|
|
@ -49,8 +55,6 @@ in
|
||||||
btc = "bitcoind";
|
btc = "bitcoind";
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.firewall.allowedTCPPorts = [ 8333 ];
|
|
||||||
|
|
||||||
services.bitcoind = {
|
services.bitcoind = {
|
||||||
"btc" = {
|
"btc" = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
|
||||||
58
src/system/modules/forgejo/default.nix
Normal file
58
src/system/modules/forgejo/default.nix
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
{ pkgs, lib, config, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
let
|
||||||
|
cfg = config.modules.system.forgejo;
|
||||||
|
nginx = config.modules.system.nginx;
|
||||||
|
|
||||||
|
in
|
||||||
|
{ options.modules.system.forgejo = { enable = mkEnableOption "Forgejo Server"; };
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
users = {
|
||||||
|
users = {
|
||||||
|
"git" = {
|
||||||
|
description = "Git server system user";
|
||||||
|
isSystemUser = true;
|
||||||
|
group = "git";
|
||||||
|
extraGroups = mkIf nginx.enable [
|
||||||
|
"web"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
"nginx" = {
|
||||||
|
extraGroups = mkIf nginx.enable [
|
||||||
|
"git"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
groups = {
|
||||||
|
"git" = {
|
||||||
|
members = [
|
||||||
|
"git"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.forgejo = rec {
|
||||||
|
enable = true;
|
||||||
|
user = "git";
|
||||||
|
group = "git";
|
||||||
|
stateDir = "/var/lib/forgejo";
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
server = {
|
||||||
|
PROTOCOL = "http+unix";
|
||||||
|
DOMAIN = "127.0.0.1";
|
||||||
|
HTTP_ADDR = "/run/forgejo/forgejo.sock";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
database = {
|
||||||
|
inherit user;
|
||||||
|
type = "sqlite3";
|
||||||
|
path = "${stateDir}/data/forgejo.db";
|
||||||
|
createDatabase = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
86
src/system/modules/nginx/default.nix
Normal file
86
src/system/modules/nginx/default.nix
Normal file
|
|
@ -0,0 +1,86 @@
|
||||||
|
{ pkgs, lib, config, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
let
|
||||||
|
cfg = config.modules.system.nginx;
|
||||||
|
module = config.modules.system;
|
||||||
|
|
||||||
|
in
|
||||||
|
{ options.modules.system.nginx = { enable = mkEnableOption "Nginx Reverse Proxy"; };
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
users = {
|
||||||
|
users = {
|
||||||
|
"nginx" = {
|
||||||
|
description = "Web server system user";
|
||||||
|
isSystemUser = true;
|
||||||
|
group = mkForce "web";
|
||||||
|
};
|
||||||
|
"btc" = {
|
||||||
|
extraGroups = mkIf module.bitcoin.enable [
|
||||||
|
"web"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
"git" = {
|
||||||
|
extraGroups = mkIf module.forgejo.enable [
|
||||||
|
"web"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
groups = {
|
||||||
|
"web" = {
|
||||||
|
members = [
|
||||||
|
"nginx"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
security.acme =
|
||||||
|
let
|
||||||
|
acmeDir = "/var/lib/acme";
|
||||||
|
in
|
||||||
|
{
|
||||||
|
acceptTerms = true;
|
||||||
|
certs = {
|
||||||
|
"ramos.codes" = {
|
||||||
|
#webroot = "${acmeDir}/acme-challenge";
|
||||||
|
directory = "${acmeDir}/ramos.codes";
|
||||||
|
email = config.user.email;
|
||||||
|
group = "web";
|
||||||
|
validMinDays = 90;
|
||||||
|
extraDomainNames = attrNames config.services.nginx.virtualHosts;
|
||||||
|
listenHTTP = ":80";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.nginx = {
|
||||||
|
enable = true;
|
||||||
|
virtualHosts =
|
||||||
|
let
|
||||||
|
certPath = config.security.acme.certs."ramos.codes".directory;
|
||||||
|
sslCertificate = "${certPath}/fullchain.pem";
|
||||||
|
sslCertificateKey = "${certPath}/key.pem";
|
||||||
|
|
||||||
|
withSSL = hosts: mapAttrs (name: hostConfig: hostConfig // {
|
||||||
|
inherit sslCertificate sslCertificateKey;
|
||||||
|
forceSSL = true;
|
||||||
|
}) hosts;
|
||||||
|
|
||||||
|
in withSSL
|
||||||
|
{
|
||||||
|
"git.ramos.codes" = mkIf module.forgejo.enable {
|
||||||
|
locations = {
|
||||||
|
"/" = {
|
||||||
|
proxyPass = "http://unix:${config.services.forgejo.settings.server.HTTP_ADDR}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
#"btc.ramos.codes" = mkIf module.bitcoin.enable {
|
||||||
|
# locations = {
|
||||||
|
# };
|
||||||
|
#};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue