forked from fediversity/fediversity
Compare commits
3 commits
84e51745f8
...
769345ef8e
| Author | SHA1 | Date | |
|---|---|---|---|
| 769345ef8e | |||
| 1da0534ade | |||
| 241331aca5 |
19 changed files with 61 additions and 314 deletions
6
.gitignore
vendored
6
.gitignore
vendored
|
|
@ -1,3 +1,9 @@
|
||||||
|
.npins.json
|
||||||
|
.terraform/
|
||||||
|
.terraform.lock.hcl
|
||||||
|
.terraform.tfstate.lock.info
|
||||||
|
terraform.tfstate*
|
||||||
|
.auto.tfvars.json
|
||||||
.DS_Store
|
.DS_Store
|
||||||
.idea
|
.idea
|
||||||
*.log
|
*.log
|
||||||
|
|
|
||||||
30
README.md
30
README.md
|
|
@ -1,8 +1,7 @@
|
||||||
# The Fediversity project
|
# The Fediversity project
|
||||||
|
|
||||||
This repository contains all the code and code-related files having to do with
|
This repository contains all the code and code-related files having to do with
|
||||||
[the Fediversity project](https://fediversity.eu/), with the notable exception
|
[the Fediversity project](https://fediversity.eu/).
|
||||||
of [NixOps4 that is hosted on GitHub](https://github.com/nixops4/nixops4).
|
|
||||||
|
|
||||||
## Goals
|
## Goals
|
||||||
|
|
||||||
|
|
@ -81,27 +80,15 @@ Not everyone has the expertise and time to run their own server.
|
||||||
The software includes technical configuration that links software components.
|
The software includes technical configuration that links software components.
|
||||||
Most user-facing configuration remains untouched by the deployment process.
|
Most user-facing configuration remains untouched by the deployment process.
|
||||||
|
|
||||||
> Example: NixOps4 is used to deploy [Pixelfed](https://pixelfed.org).
|
> Example: OpenTofu is used to deploy [Pixelfed](https://pixelfed.org).
|
||||||
|
|
||||||
- Migrate
|
- Migrate
|
||||||
|
|
||||||
Move service configurations and user data to a different hosting provider.
|
Move service configurations and user data to a different hosting provider.
|
||||||
|
|
||||||
- [NixOps4](https://github.com/nixops4/nixops4)
|
- [OpenTofu](https://opentofu.org/)
|
||||||
|
|
||||||
A tool for deploying and managing resources through the Nix language.
|
An infrastructure-as-code tool, and open-source (MPL 2.0) fork of Terraform.
|
||||||
NixOps4 development is supported by the Fediversity project
|
|
||||||
|
|
||||||
- Resource
|
|
||||||
|
|
||||||
A [resource for NixOps4](https://nixops.dev/manual/development/concept/resource.html) is any external entity that can be declared with NixOps4 expressions and manipulated with NixOps4, such as a virtual machine, an active NixOS configuration, a DNS entry, or customer database.
|
|
||||||
|
|
||||||
- Resource provider
|
|
||||||
|
|
||||||
A resource provider for NixOps4 is an executable that communicates between a resource and NixOps4 using a standardised protocol, allowing [CRUD operations](https://en.wikipedia.org/wiki/Create,_read,_update_and_delete) on the resources to be performed by NixOps4.
|
|
||||||
Refer to the [NixOps4 manual](https://nixops.dev/manual/development/resource-provider/index.html) for details.
|
|
||||||
|
|
||||||
> Example: We need a resource provider for obtaining deployment secrets from a database.
|
|
||||||
|
|
||||||
## Development
|
## Development
|
||||||
|
|
||||||
|
|
@ -118,9 +105,6 @@ Contact the project team if you have questions or suggestions, or if you're inte
|
||||||
Most of the directories in this repository have their own README going into more
|
Most of the directories in this repository have their own README going into more
|
||||||
details as to what they are for. As an overview:
|
details as to what they are for. As an overview:
|
||||||
|
|
||||||
- [`deployment/`](./deployment) contains work to generate a full Fediversity
|
|
||||||
deployment from a minimal configuration.
|
|
||||||
|
|
||||||
- [`infra/`](./infra) contains the configurations for the various VMs that are
|
- [`infra/`](./infra) contains the configurations for the various VMs that are
|
||||||
in production for the project, for instance the Git instances or the Wiki, as
|
in production for the project, for instance the Git instances or the Wiki, as
|
||||||
well as means to provision and set up new ones.
|
well as means to provision and set up new ones.
|
||||||
|
|
@ -128,14 +112,8 @@ details as to what they are for. As an overview:
|
||||||
- [`keys/`](./keys) contains the public keys of the contributors to this project
|
- [`keys/`](./keys) contains the public keys of the contributors to this project
|
||||||
as well as the systems that we administrate.
|
as well as the systems that we administrate.
|
||||||
|
|
||||||
- [`matrix/`](./matrix) contains everything having to do with setting up a
|
|
||||||
fully-featured Matrix server.
|
|
||||||
|
|
||||||
- [`secrets/`](./secrets) contains the secrets that need to get injected into
|
- [`secrets/`](./secrets) contains the secrets that need to get injected into
|
||||||
machine configurations.
|
machine configurations.
|
||||||
|
|
||||||
- [`services/`](./services) contains our effort to make Fediverse applications
|
- [`services/`](./services) contains our effort to make Fediverse applications
|
||||||
work seemlessly together in our specific setting.
|
work seemlessly together in our specific setting.
|
||||||
|
|
||||||
- [`website/`](./website) contains the framework and the content of [the
|
|
||||||
Fediversity website](https://fediversity.eu/)
|
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,7 @@ infrastructure.
|
||||||
|
|
||||||
NOTE[Niols]: This is very manual and clunky. Two things will happen. In the near
|
NOTE[Niols]: This is very manual and clunky. Two things will happen. In the near
|
||||||
future, I will improve the provisioning script to make this a bit less clunky.
|
future, I will improve the provisioning script to make this a bit less clunky.
|
||||||
In the far future, NixOps4 will be able to communicate with Proxmox directly and
|
In the future, orchestration will be able to communicate with Proxmox directly and
|
||||||
everything will become much cleaner.
|
everything will become much cleaner.
|
||||||
|
|
||||||
1. Choose names for your VMs. It is recommended to choose `fediXXX`, with `XXX`
|
1. Choose names for your VMs. It is recommended to choose `fediXXX`, with `XXX`
|
||||||
|
|
@ -15,8 +15,7 @@ everything will become much cleaner.
|
||||||
|
|
||||||
2. Add a basic configuration for the machine. These typically go in
|
2. Add a basic configuration for the machine. These typically go in
|
||||||
`infra/machines/<name>/default.nix`. You can look at other `fediXXX` VMs to
|
`infra/machines/<name>/default.nix`. You can look at other `fediXXX` VMs to
|
||||||
find inspiration. You probably do not need a `nixos.module` option at this
|
find inspiration.
|
||||||
point.
|
|
||||||
|
|
||||||
2. Add a file for each of those VM's public keys, eg.
|
2. Add a file for each of those VM's public keys, eg.
|
||||||
```
|
```
|
||||||
|
|
@ -59,40 +58,6 @@ everything will become much cleaner.
|
||||||
FIXME: Figure out why the full configuration isn't on the machine at this
|
FIXME: Figure out why the full configuration isn't on the machine at this
|
||||||
point and fix it.
|
point and fix it.
|
||||||
|
|
||||||
## Updating existing VM configurations
|
|
||||||
|
|
||||||
Their configuration can be updated via NixOps4. Run
|
|
||||||
|
|
||||||
```sh
|
|
||||||
nixops4 deployments list
|
|
||||||
```
|
|
||||||
|
|
||||||
to see the available deployments.
|
|
||||||
This should be done from the root of the repository,
|
|
||||||
otherwise NixOps4 will fail with something like:
|
|
||||||
|
|
||||||
```
|
|
||||||
nixops4 error: evaluation: error:
|
|
||||||
… while calling the 'getFlake' builtin
|
|
||||||
|
|
||||||
error: path '/nix/store/05nn7krhvi8wkcyl6bsysznlv60g5rrf-source/flake.nix' does not exist, evaluation: error:
|
|
||||||
… while calling the 'getFlake' builtin
|
|
||||||
|
|
||||||
error: path '/nix/store/05nn7krhvi8wkcyl6bsysznlv60g5rrf-source/flake.nix' does not exist
|
|
||||||
```
|
|
||||||
|
|
||||||
Then, given a deployment (eg. `fedi200`), run
|
|
||||||
|
|
||||||
```sh
|
|
||||||
nixops4 apply <deployment>
|
|
||||||
```
|
|
||||||
|
|
||||||
Alternatively, to run the `default` deployment, which contains all the VMs, run
|
|
||||||
|
|
||||||
```sh
|
|
||||||
nixops4 apply
|
|
||||||
```
|
|
||||||
|
|
||||||
## Removing an existing VM
|
## Removing an existing VM
|
||||||
|
|
||||||
See `infra/proxmox-remove.sh --help`.
|
See `infra/proxmox-remove.sh --help`.
|
||||||
|
|
|
||||||
|
|
@ -93,7 +93,7 @@ in
|
||||||
description = ''
|
description = ''
|
||||||
The IP address of the machine, version 4. It will be injected as a
|
The IP address of the machine, version 4. It will be injected as a
|
||||||
value in `networking.interfaces.eth0`, but it will also be used to
|
value in `networking.interfaces.eth0`, but it will also be used to
|
||||||
communicate with the machine via NixOps4.
|
communicate with the machine.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -118,7 +118,7 @@ in
|
||||||
description = ''
|
description = ''
|
||||||
The IP address of the machine, version 6. It will be injected as a
|
The IP address of the machine, version 6. It will be injected as a
|
||||||
value in `networking.interfaces.eth0`, but it will also be used to
|
value in `networking.interfaces.eth0`, but it will also be used to
|
||||||
communicate with the machine via NixOps4.
|
communicate with the machine.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -141,7 +141,7 @@ in
|
||||||
hostPublicKey = mkOption {
|
hostPublicKey = mkOption {
|
||||||
description = ''
|
description = ''
|
||||||
The ed25519 host public key of the machine. It is used to filter Age
|
The ed25519 host public key of the machine. It is used to filter Age
|
||||||
secrets and only keep the relevant ones, and to feed to NixOps4.
|
secrets and only keep the relevant ones, and to feed to TF.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,64 +0,0 @@
|
||||||
{
|
|
||||||
inputs,
|
|
||||||
lib,
|
|
||||||
config,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (lib) attrValues elem mkDefault;
|
|
||||||
inherit (lib.attrsets) concatMapAttrs optionalAttrs;
|
|
||||||
inherit (lib.strings) removeSuffix;
|
|
||||||
|
|
||||||
secretsPrefix = ../../secrets;
|
|
||||||
secrets = import (secretsPrefix + "/secrets.nix");
|
|
||||||
keys = import ../../keys;
|
|
||||||
|
|
||||||
in
|
|
||||||
{
|
|
||||||
imports = [ ./options.nix ];
|
|
||||||
|
|
||||||
fediversityVm.hostPublicKey = mkDefault keys.systems.${config.fediversityVm.name};
|
|
||||||
|
|
||||||
ssh = {
|
|
||||||
host = config.fediversityVm.ipv4.address;
|
|
||||||
hostPublicKey = config.fediversityVm.hostPublicKey;
|
|
||||||
};
|
|
||||||
|
|
||||||
nixpkgs = inputs.nixpkgs;
|
|
||||||
|
|
||||||
## The configuration of the machine. We strive to keep in this file only the
|
|
||||||
## options that really need to be injected from the resource. Everything else
|
|
||||||
## should go into the `./nixos` subdirectory.
|
|
||||||
nixos.module = {
|
|
||||||
imports = [
|
|
||||||
inputs.agenix.nixosModules.default
|
|
||||||
inputs.disko.nixosModules.default
|
|
||||||
inputs.home-manager.nixosModules.home-manager
|
|
||||||
./options.nix
|
|
||||||
./nixos
|
|
||||||
];
|
|
||||||
|
|
||||||
## Inject the shared options from the resource's `config` into the NixOS
|
|
||||||
## configuration.
|
|
||||||
fediversityVm = config.fediversityVm;
|
|
||||||
|
|
||||||
## Read all the secrets, filter the ones that are supposed to be readable
|
|
||||||
## with this host's public key, and add them correctly to the configuration
|
|
||||||
## as `age.secrets.<name>.file`.
|
|
||||||
age.secrets = concatMapAttrs (
|
|
||||||
name: secret:
|
|
||||||
optionalAttrs (elem config.fediversityVm.hostPublicKey secret.publicKeys) ({
|
|
||||||
${removeSuffix ".age" name}.file = secretsPrefix + "/${name}";
|
|
||||||
})
|
|
||||||
) secrets;
|
|
||||||
|
|
||||||
## FIXME: Remove direct root authentication once the NixOps4 NixOS provider
|
|
||||||
## supports users with password-less sudo.
|
|
||||||
users.users.root.openssh.authorizedKeys.keys = attrValues keys.contributors ++ [
|
|
||||||
# allow our panel vm access to the test machines
|
|
||||||
keys.panel
|
|
||||||
];
|
|
||||||
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -1,116 +1,3 @@
|
||||||
{
|
_: {
|
||||||
inputs,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (builtins) readDir;
|
|
||||||
inherit (lib)
|
|
||||||
attrNames
|
|
||||||
mkOption
|
|
||||||
evalModules
|
|
||||||
filterAttrs
|
|
||||||
;
|
|
||||||
inherit (lib.attrsets) genAttrs;
|
|
||||||
|
|
||||||
## Given a machine's name, make a resource module,
|
|
||||||
## except for its missing provider. (Depending on the use of that resource, we
|
|
||||||
## will provide a different one.)
|
|
||||||
makeResourceModule =
|
|
||||||
{ vmName }:
|
|
||||||
{
|
|
||||||
_module.args = { inherit inputs; };
|
|
||||||
imports = [
|
|
||||||
./common/resource.nix
|
|
||||||
./machines/${vmName}
|
|
||||||
];
|
|
||||||
fediversityVm.name = vmName;
|
|
||||||
};
|
|
||||||
|
|
||||||
## Given a list of machine names, make a deployment with those machines'
|
|
||||||
## configurations as resources.
|
|
||||||
makeDeployment =
|
|
||||||
vmNames:
|
|
||||||
{ providers, ... }:
|
|
||||||
{
|
|
||||||
providers.local = inputs.nixops4.modules.nixops4Provider.local;
|
|
||||||
resources = genAttrs vmNames (vmName: {
|
|
||||||
type = providers.local.exec;
|
|
||||||
imports = [
|
|
||||||
inputs.nixops4-nixos.modules.nixops4Resource.nixos
|
|
||||||
(makeResourceModule {
|
|
||||||
inherit vmName;
|
|
||||||
})
|
|
||||||
];
|
|
||||||
});
|
|
||||||
};
|
|
||||||
makeDeployment' = vmName: makeDeployment [ vmName ];
|
|
||||||
|
|
||||||
nixops4ResourceNixosMockOptions = {
|
|
||||||
## NOTE: We allow the use of a few options from
|
|
||||||
## `inputs.nixops4-nixos.modules.nixops4Resource.nixos` such that we can
|
|
||||||
## reuse modules that make use of them.
|
|
||||||
##
|
|
||||||
## REVIEW: We can probably do much better and cleaner. On the other hand,
|
|
||||||
## this is only needed to expose NixOS configurations for provisioning
|
|
||||||
## purposes, and eventually all of this should be handled by NixOps4.
|
|
||||||
options = {
|
|
||||||
nixos.module = mkOption { }; # NOTE: not just `nixos` otherwise merging will go wrong
|
|
||||||
nixpkgs = mkOption { };
|
|
||||||
ssh = mkOption { };
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
makeResourceConfig =
|
|
||||||
vm:
|
|
||||||
(evalModules {
|
|
||||||
modules = [
|
|
||||||
nixops4ResourceNixosMockOptions
|
|
||||||
(makeResourceModule vm)
|
|
||||||
];
|
|
||||||
}).config;
|
|
||||||
|
|
||||||
## Given a VM name, make a NixOS configuration for this machine.
|
|
||||||
makeConfiguration =
|
|
||||||
vmName:
|
|
||||||
inputs.nixpkgs.lib.nixosSystem {
|
|
||||||
modules = [
|
|
||||||
(makeResourceConfig { inherit vmName; }).nixos.module
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
makeVmOptions = vmName: {
|
|
||||||
inherit ((makeResourceConfig { inherit vmName; }).fediversityVm)
|
|
||||||
proxmox
|
|
||||||
vmId
|
|
||||||
description
|
|
||||||
|
|
||||||
sockets
|
|
||||||
cores
|
|
||||||
memory
|
|
||||||
diskSize
|
|
||||||
|
|
||||||
hostPublicKey
|
|
||||||
unsafeHostPrivateKey
|
|
||||||
;
|
|
||||||
};
|
|
||||||
|
|
||||||
listSubdirectories = path: attrNames (filterAttrs (_: type: type == "directory") (readDir path));
|
|
||||||
|
|
||||||
machines = listSubdirectories ./machines;
|
|
||||||
|
|
||||||
in
|
|
||||||
{
|
|
||||||
flake.lib.makeInstallerIso = import ./makeInstallerIso.nix;
|
flake.lib.makeInstallerIso = import ./makeInstallerIso.nix;
|
||||||
|
|
||||||
## - Each machine gets a NixOS configuration.
|
|
||||||
## - Each machine gets a VM options entry.
|
|
||||||
## - Each machine gets a deployment.
|
|
||||||
## - We add a “default” deployment with all infra machines.
|
|
||||||
nixops4Deployments = genAttrs machines makeDeployment' // {
|
|
||||||
default = makeDeployment machines;
|
|
||||||
};
|
|
||||||
flake.nixosConfigurations = genAttrs machines makeConfiguration;
|
|
||||||
flake.vmOptions = genAttrs machines makeVmOptions;
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -14,10 +14,4 @@
|
||||||
gateway = "2a00:51c0:13:1305::1";
|
gateway = "2a00:51c0:13:1305::1";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
nixos.module = {
|
|
||||||
imports = [
|
|
||||||
./fedipanel.nix
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,4 @@
|
||||||
|
{ lib, ... }:
|
||||||
{
|
{
|
||||||
fediversityVm = {
|
fediversityVm = {
|
||||||
vmId = 2116;
|
vmId = 2116;
|
||||||
|
|
@ -8,31 +9,23 @@
|
||||||
ipv6.address = "2a00:51c0:12:1201::20";
|
ipv6.address = "2a00:51c0:12:1201::20";
|
||||||
};
|
};
|
||||||
|
|
||||||
nixos.module =
|
## vm02116 is running on old hardware based on a Xen VM environment, so it
|
||||||
{ lib, ... }:
|
## needs these extra options. Once the VM gets moved to a newer node, these
|
||||||
{
|
## two options can safely be removed.
|
||||||
imports = [
|
boot.initrd.availableKernelModules = [ "xen_blkfront" ];
|
||||||
./forgejo.nix
|
services.xe-guest-utilities.enable = true;
|
||||||
];
|
|
||||||
|
|
||||||
## vm02116 is running on old hardware based on a Xen VM environment, so it
|
## NOTE: This VM was created manually, which requires us to override the
|
||||||
## needs these extra options. Once the VM gets moved to a newer node, these
|
## default disko-based `fileSystems` definition.
|
||||||
## two options can safely be removed.
|
fileSystems = lib.mkForce {
|
||||||
boot.initrd.availableKernelModules = [ "xen_blkfront" ];
|
"/" = {
|
||||||
services.xe-guest-utilities.enable = true;
|
device = "/dev/disk/by-uuid/3802a66d-e31a-4650-86f3-b51b11918853";
|
||||||
|
fsType = "ext4";
|
||||||
## NOTE: This VM was created manually, which requires us to override the
|
|
||||||
## default disko-based `fileSystems` definition.
|
|
||||||
fileSystems = lib.mkForce {
|
|
||||||
"/" = {
|
|
||||||
device = "/dev/disk/by-uuid/3802a66d-e31a-4650-86f3-b51b11918853";
|
|
||||||
fsType = "ext4";
|
|
||||||
};
|
|
||||||
|
|
||||||
"/boot" = {
|
|
||||||
device = "/dev/disk/by-uuid/2CE2-1173";
|
|
||||||
fsType = "vfat";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
"/boot" = {
|
||||||
|
device = "/dev/disk/by-uuid/2CE2-1173";
|
||||||
|
fsType = "vfat";
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,4 @@
|
||||||
|
{ lib, ... }:
|
||||||
{
|
{
|
||||||
fediversityVm = {
|
fediversityVm = {
|
||||||
vmId = 2187;
|
vmId = 2187;
|
||||||
|
|
@ -8,29 +9,21 @@
|
||||||
ipv6.address = "2a00:51c0:12:1201::187";
|
ipv6.address = "2a00:51c0:12:1201::187";
|
||||||
};
|
};
|
||||||
|
|
||||||
nixos.module =
|
## NOTE: This VM was created manually, which requires us to override the
|
||||||
{ lib, ... }:
|
## default disko-based `fileSystems` definition.
|
||||||
{
|
fileSystems = lib.mkForce {
|
||||||
imports = [
|
"/" = {
|
||||||
./wiki.nix
|
device = "/dev/disk/by-uuid/a46a9c46-e32b-4216-a4aa-8819b2cd0d49";
|
||||||
];
|
fsType = "ext4";
|
||||||
|
|
||||||
## NOTE: This VM was created manually, which requires us to override the
|
|
||||||
## default disko-based `fileSystems` definition.
|
|
||||||
fileSystems = lib.mkForce {
|
|
||||||
"/" = {
|
|
||||||
device = "/dev/disk/by-uuid/a46a9c46-e32b-4216-a4aa-8819b2cd0d49";
|
|
||||||
fsType = "ext4";
|
|
||||||
};
|
|
||||||
|
|
||||||
"/boot" = {
|
|
||||||
device = "/dev/disk/by-uuid/6AB5-4FA8";
|
|
||||||
fsType = "vfat";
|
|
||||||
options = [
|
|
||||||
"fmask=0022"
|
|
||||||
"dmask=0022"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
"/boot" = {
|
||||||
|
device = "/dev/disk/by-uuid/6AB5-4FA8";
|
||||||
|
fsType = "vfat";
|
||||||
|
options = [
|
||||||
|
"fmask=0022"
|
||||||
|
"dmask=0022"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -14,7 +14,7 @@ overwrite a secret without knowing its contents.)
|
||||||
In infra management, the systems' keys are used for security reasons; they
|
In infra management, the systems' keys are used for security reasons; they
|
||||||
identify the machine that we are talking to. The contributor keys are used to
|
identify the machine that we are talking to. The contributor keys are used to
|
||||||
give access to the `root` user on these machines, which allows, among other
|
give access to the `root` user on these machines, which allows, among other
|
||||||
things, to deploy their configurations with NixOps4.
|
things, to deploy their configurations.
|
||||||
|
|
||||||
## Adding a contributor
|
## Adding a contributor
|
||||||
|
|
||||||
|
|
|
||||||
7
launch/.gitignore
vendored
7
launch/.gitignore
vendored
|
|
@ -1,7 +0,0 @@
|
||||||
# generated
|
|
||||||
.auto.tfvars.json
|
|
||||||
.npins.json
|
|
||||||
.terraform/
|
|
||||||
.terraform.lock.hcl
|
|
||||||
.terraform.tfstate.lock.info
|
|
||||||
terraform.tfstate*
|
|
||||||
|
|
@ -22,6 +22,8 @@ then to initialize, or after updating pins or TF providers:
|
||||||
setup
|
setup
|
||||||
```
|
```
|
||||||
|
|
||||||
|
then, one can use the `tofu` CLI.
|
||||||
|
|
||||||
## implementing
|
## implementing
|
||||||
|
|
||||||
proper documentation TODO.
|
proper documentation TODO.
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ let
|
||||||
## and will end up in the Nix store. We don't care as they are only ever
|
## and will end up in the Nix store. We don't care as they are only ever
|
||||||
## used for testing anyway.
|
## used for testing anyway.
|
||||||
##
|
##
|
||||||
## FIXME: Generate and store in NixOps4's state.
|
## FIXME: Generate and store in state.
|
||||||
mastodonS3KeyConfig =
|
mastodonS3KeyConfig =
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -12,6 +12,6 @@ in
|
||||||
mastodon = mastodonS3KeyConfig { inherit pkgs; } // {
|
mastodon = mastodonS3KeyConfig { inherit pkgs; } // {
|
||||||
enable = true;
|
enable = true;
|
||||||
};
|
};
|
||||||
temp.cores = 1; # FIXME: should come from NixOps4 eventually
|
temp.cores = 1; # FIXME: should come from TF eventually
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@ in
|
||||||
enable = true;
|
enable = true;
|
||||||
## NOTE: Only ever used for testing anyway.
|
## NOTE: Only ever used for testing anyway.
|
||||||
##
|
##
|
||||||
## FIXME: Generate and store in NixOps4's state.
|
## FIXME: Generate and store in state.
|
||||||
secretsFile = pkgs.writeText "secret" "574e093907d1157ac0f8e760a6deb1035402003af5763135bae9cbd6abe32b24";
|
secretsFile = pkgs.writeText "secret" "574e093907d1157ac0f8e760a6deb1035402003af5763135bae9cbd6abe32b24";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -241,6 +241,6 @@ if user_settings_file is not None:
|
||||||
|
|
||||||
# PATH to expose to launch button
|
# PATH to expose to launch button
|
||||||
bin_path=env['BIN_PATH']
|
bin_path=env['BIN_PATH']
|
||||||
# path of the root flake to trigger nixops from, see #94.
|
# path of the root flake to deploy from
|
||||||
# to deploy this should be specified, for dev just use a relative path.
|
# to deploy this should be specified, for dev just use a relative path.
|
||||||
repo_dir = env["REPO_DIR"]
|
repo_dir = env["REPO_DIR"]
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@ As an example, let us add a secret in a file “cheeses” whose content should
|
||||||
extension); this will open your `$EDITOR` ; enter “best ones come
|
extension); this will open your `$EDITOR` ; enter “best ones come
|
||||||
unpasteurised”, save and close.
|
unpasteurised”, save and close.
|
||||||
|
|
||||||
3. If you are doing something flake-related such as NixOps4, remember to commit
|
3. If you are doing something flake-related, remember to commit
|
||||||
or at least stage the secret.
|
or at least stage the secret.
|
||||||
|
|
||||||
4. In the machine's configuration, load our `ageSecrets` NixOS module, declare the machine's host key and start using your secrets, eg.:
|
4. In the machine's configuration, load our `ageSecrets` NixOS module, declare the machine's host key and start using your secrets, eg.:
|
||||||
|
|
|
||||||
|
|
@ -31,7 +31,7 @@ in
|
||||||
type = types.submodule {
|
type = types.submodule {
|
||||||
options = {
|
options = {
|
||||||
cores = mkOption {
|
cores = mkOption {
|
||||||
description = "number of cores; should be obtained from NixOps4";
|
description = "number of cores; should be obtained from TF";
|
||||||
type = types.int;
|
type = types.int;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,7 @@ in
|
||||||
description = ''
|
description = ''
|
||||||
Internal option — change at your own risk
|
Internal option — change at your own risk
|
||||||
|
|
||||||
FIXME: should it be provided by NixOps4?
|
FIXME: should it be provided by TF?
|
||||||
or maybe we should just ask for a main secret from which to derive all the others?
|
or maybe we should just ask for a main secret from which to derive all the others?
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue