-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.tf
51 lines (42 loc) · 1.64 KB
/
main.tf
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
variable "token" {}
variable "username" {}
variable "size" {}
variable "nodes" {}
provider "digitalocean" {
token = "${var.token}"
}
locals {
clean_username = "${replace(var.username, ".", "")}"
cluster_name = "${local.clean_username}s-cluster"
}
resource "digitalocean_kubernetes_cluster" "cluster" {
name = "${local.cluster_name}"
region = "fra1"
version = "1.12.1-do.2"
tags = ["${local.clean_username}"]
node_pool {
name = "woker-pool"
size = "${var.size}"
node_count = "${var.nodes}"
}
}
# provider "kubernetes" {
# host = "${digitalocean_kubernetes_cluster.cluster.endpoint}"
# client_certificate = "${base64decode(digitalocean_kubernetes_cluster.cluster.kube_config.0.client_certificate)}"
# client_key = "${base64decode(digitalocean_kubernetes_cluster.cluster.kube_config.0.client_key)}"
# cluster_ca_certificate = "${base64decode(digitalocean_kubernetes_cluster.cluster.kube_config.0.cluster_ca_certificate)}"
# }
data "template_file" "kubeconfig" {
template = "${file("${path.module}/kubeconfig-template.yaml")}"
vars {
name = "${local.cluster_name}"
endpoint = "${digitalocean_kubernetes_cluster.cluster.endpoint}"
tls_authority = "${digitalocean_kubernetes_cluster.cluster.kube_config.0.cluster_ca_certificate}"
tls_certificate = "${digitalocean_kubernetes_cluster.cluster.kube_config.0.client_certificate}"
tls_key = "${digitalocean_kubernetes_cluster.cluster.kube_config.0.client_key}"
}
}
resource "local_file" "kubeconfig" {
content = "${data.template_file.kubeconfig.rendered}"
filename = "${path.module}/kubeconfig.yaml"
}