1
0
Fork 0

Initial commit

This commit is contained in:
Vojtěch Mareš 2023-09-26 21:42:33 +00:00
commit ac2201f72c
5 changed files with 121 additions and 0 deletions

13
.editorconfig Normal file
View file

@ -0,0 +1,13 @@
root = true
[*]
indent_style = space
indent_size = 2
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
end_of_line = lf
max_line_length = null
[Makefile]
indent_style = tab

3
.gitignore vendored Normal file
View file

@ -0,0 +1,3 @@
.terraform
.terraform.lock.hcl
variables.auto.tfvars

79
main.tf Normal file
View file

@ -0,0 +1,79 @@
variable "hcloud_token" {
type = string
}
provider "hcloud" {
token = var.hcloud_token
}
data "hcloud_ssh_key" "vojtechmares" {
name = "iam@vojtechmares.com"
}
resource "hcloud_ssh_key" "ssh_key" {
name = "ssh-key"
public_key = var.ssh_public_key
}
data "ct_config" "ignition" {
content = file("templates/config.yaml")
strict = true
pretty_print = true
}
resource "hcloud_server" "server" {
name = "flatcar-linux--test"
server_type = "cx11"
labels = {
"os" = "flatcar-linux"
}
location = "nbg1"
// Unused because of rescue mode, but required field
image = "debian-11"
rescue = "linux64"
ssh_keys = [data.hcloud_ssh_key.vojtechmares.id]
connection {
host = hcloud_server.test.ipv4_address
timeout = "5m"
user = "root"
}
provisioner "file" {
content = data.ct_config.ignition.rendered
destination = "/root/ignition.json"
}
provisioner "remote-exec" {
inline = [
"set -ex",
"apt update -y",
"apt install -y gawk",
"curl -fsSLO --retry-delay 1 --retry 60 --retry-connrefused --retry-max-time 60 --connect-timeout 20 https://raw.githubusercontent.com/kinvolk/init/flatcar-master/bin/flatcar-install",
"chmod +x flatcar-install",
"./flatcar-install -s -i /root/ignition.json",
"shutdown -r +1",
]
}
# Configure after installation
provisioner "remote-exec" {
connection {
host = self.ipv4_address
timeout = "3m"
user = "core"
}
inline = [
"sudo hostnamectl set-hostname ${self.name}",
]
}
}
output "ip" {
value = hcloud_server.server.ipv4_address
}

14
templates/config.yaml Normal file
View file

@ -0,0 +1,14 @@
---
passwd:
users:
- name: core
ssh_authorized_keys:
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIEUz21xFatGKfSwjeg/BOBus2Jn17o8xVthrMFAsDtRD iam@vojtechmares.com
systemd:
units:
# Using flatcar-linux-update-operator instead. See: https://github.com/flatcar-linux/flatcar-linux-update-operator#requirements for more information
- name: locksmithd.service
mask: true
- name: update-engine.service
enabled: true

12
versions.tf Normal file
View file

@ -0,0 +1,12 @@
terraform {
required_providers {
hcloud = {
source = "hetznercloud/hcloud"
version = "1.32.1"
}
ct = {
source = "poseidon/ct"
version = "0.9.1"
}
}
}