Page MenuHomePhabricator

[terraform] Replace all config options with terraform variables and remove sops
ClosedPublic

Authored by will on Jun 5 2024, 5:06 PM.
Tags
None
Referenced Files
F3763477: D12324.id41069.diff
Sat, Jan 11, 4:29 AM
Unknown Object (File)
Sun, Jan 5, 4:52 PM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Unknown Object (File)
Tue, Dec 24, 2:37 AM
Subscribers

Details

Summary

Bartek pointed out that SOPS was overkill for self-hosting. Additionally, several configuration options required the user to make terraform changes.

In this diff, I introduce the usage of terraform variables to

  1. configure mariadb username/password that was previously configured through sops
  2. configure the aws region, subnets, and user ip

Depends on D12323

Test Plan

terraform apply and successfully connected mysql client to rds endpoint

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

will retitled this revision from [terraform] Replace all config options with .tfvars and remove sops to [terraform] Replace all config options with terraform variables and remove sops.Jun 5 2024, 5:07 PM
will added inline comments.
services/terraform/self-host/aws_vpc.tf
9 ↗(On Diff #41000)

Changed to numbers to avoid possible confusion with the letters used by availability zones

will requested review of this revision.Jun 5 2024, 5:23 PM
will edited the summary of this revision. (Show Details)EditedJun 5 2024, 5:49 PM

Was thinking similar to the dev folder, we can create a simple run.sh script with:

terraform init

terraform apply -var-file="secrets.tfvars"
services/terraform/self-host/aws_vpc.tf
33 ↗(On Diff #41000)

32 as the mask means the block resolves to a single exact ip address

Two comments here:

  • When using one of "default" filenames (I recall terraform.tfvars), you don't have to use the -var-file="secrets.tfvars" arg
  • It's a good practice to commit terraform.tfvars.example (while gitignoring actual terraform.tfvars) with example variables (usually required ones, that don't have defaults in variables.tf). This file can be copied and renamed by individual users.

What do you think?

I like @bartek's suggestions. I'm probably a bad reviewer for Terraform stuff since I'm not familiar

Two comments here:

  • When using one of "default" filenames (I recall terraform.tfvars), you don't have to use the -var-file="secrets.tfvars" arg
  • It's a good practice to commit terraform.tfvars.example (while gitignoring actual terraform.tfvars) with example variables (usually required ones, that don't have defaults in variables.tf). This file can be copied and renamed by individual users.

What do you think?

Really good ideas. Adding to new next rebase and modified the notion doc to use terraform.tfvars
https://www.notion.so/commapp/Moving-local-Keyserver-MariaDB-data-to-a-Self-hosted-AWS-RDS-instance-ed4fd1b02f944e3ab1ea074c65f553f3

This revision is now accepted and ready to land.Jun 6 2024, 12:02 PM

to be removed but zones should be included in the terraform variables for this diff