forked from Fediversity/Fediversity
special_args -> nix_path + module
This commit is contained in:
parent
ef214ced10
commit
9f689faa32
2 changed files with 58 additions and 5 deletions
53
launch/options.nix
Normal file
53
launch/options.nix
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (lib) types mkOption;
|
||||||
|
inherit (types) str enum submodule;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.terraform = {
|
||||||
|
domain = mkOption {
|
||||||
|
type = enum [
|
||||||
|
"fediversity.net"
|
||||||
|
];
|
||||||
|
description = ''
|
||||||
|
Apex domain under which the services will be deployed.
|
||||||
|
'';
|
||||||
|
default = "fediversity.net";
|
||||||
|
};
|
||||||
|
hostname = mkOption {
|
||||||
|
type = str;
|
||||||
|
description = ''
|
||||||
|
Internal name of the host, e.g. test01
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
initialUser = mkOption {
|
||||||
|
description = ''
|
||||||
|
Some services require an initial user to access them.
|
||||||
|
This option sets the credentials for such an initial user.
|
||||||
|
'';
|
||||||
|
type = submodule {
|
||||||
|
options = {
|
||||||
|
displayName = mkOption {
|
||||||
|
type = str;
|
||||||
|
description = "Display name of the user";
|
||||||
|
};
|
||||||
|
username = mkOption {
|
||||||
|
type = str;
|
||||||
|
description = "Username for login";
|
||||||
|
};
|
||||||
|
email = mkOption {
|
||||||
|
type = str;
|
||||||
|
description = "User's email address";
|
||||||
|
};
|
||||||
|
password = mkOption {
|
||||||
|
type = str;
|
||||||
|
description = "Password for login";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,10 +1,10 @@
|
||||||
{
|
{
|
||||||
pkgs,
|
pkgs,
|
||||||
terraform,
|
config,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (terraform) hostname;
|
inherit (config.terraform) hostname domain initialUser;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
@ -17,12 +17,12 @@ in
|
||||||
];
|
];
|
||||||
fediversityVm.name = hostname;
|
fediversityVm.name = hostname;
|
||||||
fediversity = {
|
fediversity = {
|
||||||
inherit (terraform) domain;
|
inherit domain;
|
||||||
temp.initialUser = {
|
temp.initialUser = {
|
||||||
inherit (terraform.initialUser) username email displayName;
|
inherit (initialUser) username email displayName;
|
||||||
# FIXME: disgusting, but nvm, this is going to be replaced by
|
# FIXME: disgusting, but nvm, this is going to be replaced by
|
||||||
# proper central authentication at some point
|
# proper central authentication at some point
|
||||||
passwordFile = pkgs.writeText "password" terraform.initialUser.password;
|
passwordFile = pkgs.writeText "password" initialUser.password;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue