secure database

This commit is contained in:
Grimmauld 2024-01-30 22:00:49 +01:00
parent 30bdaa6e9f
commit 24b26bf4a3
4 changed files with 10 additions and 4 deletions

View File

@ -56,6 +56,7 @@ in {
(writeShellScriptBin "pufferpanel-nix" "pufferpanel --workDir /var/lib/pufferpanel $@") (writeShellScriptBin "pufferpanel-nix" "pufferpanel --workDir /var/lib/pufferpanel $@")
(writeShellScriptBin "nix-referrers" "nix-store --query --referrers $@") (writeShellScriptBin "nix-referrers" "nix-store --query --referrers $@")
(writeShellScriptBin "silent-add" "git add --intent-to-add $@ ; git update-index --assume-unchanged $@") (writeShellScriptBin "silent-add" "git add --intent-to-add $@ ; git update-index --assume-unchanged $@")
(writeShellScriptBin "systemd-owner" "systemctl show -pUser,UID $@")
]; ];
environment.sessionVariables = { environment.sessionVariables = {

View File

@ -15,6 +15,9 @@ in {
}; };
users.groups.${panel_user} = {}; users.groups.${panel_user} = {};
age.secrets.ptero_env = {
file = ../secrets/ptero_env.age;
};
systemd.services.init-ptero-data-dir = { systemd.services.init-ptero-data-dir = {
description = "Create the pterodactyl panel data dir"; description = "Create the pterodactyl panel data dir";
@ -24,7 +27,9 @@ in {
script ='' script =''
mkdir -p ${DATA_DIR}/database mkdir -p ${DATA_DIR}/database
mkdir -p ${DATA_DIR}/cache mkdir -p ${DATA_DIR}/cache
mkdir -p ${DATA_DIR}/panel mkdir -p ${DATA_DIR}/panel/var
mkdir -p ${DATA_DIR}/panel/logs
mkdir -p ${DATA_DIR}/panel/nginx
chown ${panel_user}:${panel_user} -R ${DATA_DIR} chown ${panel_user}:${panel_user} -R ${DATA_DIR}
chmod +777 -R ${DATA_DIR} chmod +777 -R ${DATA_DIR}
''; '';
@ -55,11 +60,10 @@ chmod +777 -R ${DATA_DIR}
workdir = "${DATA_DIR}/database"; workdir = "${DATA_DIR}/database";
extraOptions = [ "--pod=ptero" ]; extraOptions = [ "--pod=ptero" ];
environment = { environment = {
"MYSQL_ROOT_PASSWORD" = "JMK1VmZDwoVAUhvClQ7DncOEw5B1XcKXwqERw45Cw4/CoMKKwqHCocKXwqZrwr9b";
"MYSQL_USER" = "pterodactyl"; "MYSQL_USER" = "pterodactyl";
"MYSQL_PASSWORD" = "JMK1VmZDwoVAUhvClQ7DncOEw5B1XcKXwqERw45Cw4/CoMKKwqHCocKXwqZrwr9b";
"MYSQL_DATABASE" = "panel"; "MYSQL_DATABASE" = "panel";
}; };
environmentFiles = [ config.age.secrets.ptero_env.path ];
volumes = ["${DATA_DIR}/database:/var/lib/mysql" "${DATA_DIR}/database:${DATA_DIR}/database"]; volumes = ["${DATA_DIR}/database:/var/lib/mysql" "${DATA_DIR}/database:${DATA_DIR}/database"];
cmd=["--default-authentication-plugin=mysql_native_password"]; cmd=["--default-authentication-plugin=mysql_native_password"];
}; };
@ -92,7 +96,6 @@ chmod +777 -R ${DATA_DIR}
"MAIL_PASSWORD" = ""; "MAIL_PASSWORD" = "";
"MAIL_ENCRYPTION" = "true"; "MAIL_ENCRYPTION" = "true";
"DB_PASSWORD" = "JMK1VmZDwoVAUhvClQ7DncOEw5B1XcKXwqERw45Cw4/CoMKKwqHCocKXwqZrwr9b";
"APP_ENV"= "production"; "APP_ENV"= "production";
"APP_ENVIRONMENT_ONLY"= "false"; "APP_ENVIRONMENT_ONLY"= "false";
"CACHE_DRIVER" = "redis"; "CACHE_DRIVER" = "redis";
@ -105,6 +108,7 @@ chmod +777 -R ${DATA_DIR}
labels = { labels = {
"traefik.http.routers.pterodactyl_panel.entrypoints"="web"; "traefik.http.routers.pterodactyl_panel.entrypoints"="web";
}; };
environmentFiles = [ config.age.secrets.ptero_env.path ];
}; };
security.acme.certs."${root_host}".extraDomainNames = [ ptero_host ]; security.acme.certs."${root_host}".extraDomainNames = [ ptero_host ];

BIN
secrets/ptero_env.age Normal file

Binary file not shown.

View File

@ -14,4 +14,5 @@ in
"matrix_mjolnir_pass.age".publicKeys = [ contabo_nix_pub ]; "matrix_mjolnir_pass.age".publicKeys = [ contabo_nix_pub ];
"matrix_mjolnir_tle_pass.age".publicKeys = [ contabo_nix_pub ]; "matrix_mjolnir_tle_pass.age".publicKeys = [ contabo_nix_pub ];
"matrix_discord_bridge_token.age".publicKeys = [ contabo_nix_pub ]; "matrix_discord_bridge_token.age".publicKeys = [ contabo_nix_pub ];
"ptero_env.age".publicKeys = [ contabo_nix_pub ];
} }