blob: 8a5e599b07dd22a79cc310453c7747c18d665347 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
variable "secret_hcloud_token" {
type = "string"
}
variable "secret_cloudflare_token" {
type = "string"
}
provider "hcloud" {
token = "${var.secret_hcloud_token}"
}
provider "cloudflare" {
email = "jakob@odersky.com"
token = "${var.secret_cloudflare_token}"
}
provider "acme" {
#server_url = "https://acme-staging-v02.api.letsencrypt.org/directory"
server_url = "https://acme-v02.api.letsencrypt.org/directory"
}
################################################################################
# Main ssh key
resource "hcloud_ssh_key" "root" {
name = "root"
public_key = "${file("~/.ssh/id_rsa.pub")}"
}
module "vps" {
source = "./stdvps"
location = "nbg1"
ssh_key_name = "${hcloud_ssh_key.root.name}"
}
module "volume" {
source = "./volume"
server_id = "${module.vps.id}"
server_fqdn = "${module.vps.fqdn}"
}
module "roles" {
source = "./role"
secret_cloudflare_token = "${var.secret_cloudflare_token}"
host = "${module.vps.fqdn}"
id = "${module.volume.server_id}"
roles = ["ip", "git"]
}
output "vps_address" {
value = "${module.vps.fqdn}"
}
output "vps_roles" {
value = "${join(" ", module.roles.roles)}"
}
|