Initial commit
This commit is contained in:
		
						commit
						ac2201f72c
					
				
					 5 changed files with 121 additions and 0 deletions
				
			
		
							
								
								
									
										13
									
								
								.editorconfig
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								.editorconfig
									
										
									
									
									
										Normal 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
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | ||||||
|  | .terraform | ||||||
|  | .terraform.lock.hcl | ||||||
|  | variables.auto.tfvars | ||||||
							
								
								
									
										79
									
								
								main.tf
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								main.tf
									
										
									
									
									
										Normal 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
									
								
							
							
						
						
									
										14
									
								
								templates/config.yaml
									
										
									
									
									
										Normal 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
									
								
							
							
						
						
									
										12
									
								
								versions.tf
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | ||||||
|  | terraform { | ||||||
|  |   required_providers { | ||||||
|  |     hcloud = { | ||||||
|  |       source  = "hetznercloud/hcloud" | ||||||
|  |       version = "1.32.1" | ||||||
|  |     } | ||||||
|  |     ct = { | ||||||
|  |       source  = "poseidon/ct" | ||||||
|  |       version = "0.9.1" | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
		Reference in a new issue