selfprivacy-nixos-config/variables.nix
2022-07-13 14:41:47 +03:00

59 lines
2.7 KiB
Nix

{ pkgs, ... }:
let
jsonData = builtins.fromJSON (builtins.readFile ./userdata/userdata.json);
in
{
services.userdata = {
hostname = if jsonData ? "hostname" then jsonData.hostname else null;
domain = if jsonData ? "domain" then jsonData.domain else null;
timezone = if jsonData ? "timezone" then jsonData.timezone else "Europe/Uzhgorod";
autoUpgrade = {
enable = if jsonData ? "autoUpgrade.enable" then jsonData.autoUpgrade.enable else true;
allowReboot = if jsonData ? "autoUpgrade.allowReboot" then jsonData.autoUpgrade.allowReboot else true;
};
username = if jsonData ? "username" then jsonData.username else null;
hashedMasterPassword = if jsonData ? "hashedMasterPassword" then jsonData.hashedMasterPassword else null;
sshKeys = if jsonData ? "sshKeys" then jsonData.sshKeys else [];
api = {
token = jsonData.api.token;
enableSwagger = if jsonData ? "api.enableSwagger" then jsonData.api.enableSwagger else false;
skippedMigrations = if jsonData ? "api.skippedMigrations" then jsonData.api.skippedMigrations else [];
};
backblaze = {
bucket = if jsonData ? "backblaze.bucket" then jsonData.backblaze.bucket else null;
accountId = if jsonData ? "backblaze.accountId" then jsonData.backblaze.accountId else null;
accountKey = if jsonData ? "backblaze.accountKey" then jsonData.backblaze.accountKey else null;
};
cloudflare = {
apiKey = if jsonData ? "cloudflare.apiKey" then jsonData.cloudflare.apiKey else null;
};
databasePassword = if jsonData ? "databasePassword" then jsonData.databasePassword else null;
bitwarden = {
enable = jsonData ? "bitwarden.enable" then jsonData.bitwarden.enable else false;
};
gitea = {
enable = jsonData ? "gitea.enable" then jsonData.gitea.enable else false;
};
nextcloud = {
enable = jsonData ? "nextcloud.enable" then jsonData.nextcloud.enable else false;
adminPassword = jsonData ? "nextcloud.adminPassword" then jsonData.nextcloud.adminPassword else null;
};
pleroma = {
enable = jsonData ? "pleroma.enable" then jsonData.pleroma.enable else false;
};
jitsi = {
enable = jsonData ? "jitsi.enable" then jsonData.jitsi.enable else false;
};
ocserv = {
enable = jsonData ? "ocserv.enable" then jsonData.ocserv.enable else false;
};
resticPassword = jsonData ? "resticPassword" then jsonData.resticPassword else null;
ssh = {
enable = if jsonData ? "ssh.enable" then jsonData.ssh.enable else true;
rootKeys = jsonData.ssh.rootKeys;
passwordAuthentication = jsonData.ssh.passwordAuthentication;
};
users = (if jsonData ? "users" then jsonData.users else [ ]);
};
}