-
Notifications
You must be signed in to change notification settings - Fork 24
/
main.tf
77 lines (70 loc) · 2.54 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# vim:ts=2:sts=2:sw=2:et
#
# Author: Hari Sekhon
# Date: [% DATE # 2020-08-21 10:14:10 +0100 (Fri, 21 Aug 2020) %]
#
# https://github.com/HariSekhon/Terraform
#
# License: see accompanying Hari Sekhon LICENSE file
#
# If you're using my code you're welcome to connect with me on LinkedIn and optionally send me feedback to help steer this or other code I publish
#
# https://www.linkedin.com/in/HariSekhon
#
# ============================================================================ #
# T e r r a f o r m M a i n
# ============================================================================ #
locals {
region = "eu-west-2" # London
#region = terraform.workspace == "default" ? "eu-west-2" : "eu-west-1" # deploy main in London, else dev in Ireland
}
# define terraform resources and import modules here
# quick thing to create and tear down to test your AWS creds are working
#resource "aws_instance" "test_server" {
# #ami = "ami-0194c3e07668a7e36" # Ubuntu 20.04 LTS in eu-west-2
# ami = lookup(var.aws_amis, var.aws_region) # select the AMI depending on the region by checking the aws_amis variable for a key that matches the region
# instance_type = "t2.micro"
# subnet_id = "subnet-12a3456bc789de0fa" # need to find and populate this if no default VPC eg. when created by Control Tower
#
# tags = {
# Name = "TestServer"
# }
#}
#module "NAME" {
# source = "./modules/NAME"
# project = var.project
# region = local.region
# network = module.vpc.vpc_network
#}
module "eks" {
source = "../modules/eks"
region = local.region
cluster_name = "mycluster"
# https://docs.aws.amazon.com/eks/latest/userguide/add-user-role.html
# https://kubernetes.io/docs/reference/access-authn-authz/rbac/#default-roles-and-role-bindings
map_roles = [
{
rolearn = "arn:aws:iam::123456789012:user/hari-cli"
username = "cluster-admin"
groups = ["system:masters"]
},
{
rolearn = "arn:aws:iam::123456789012:role/AWSReservedSSO_MyGroup_1234a567b890cdef",
username = "myrole"
groups = []
}
]
}
#resource "type" "name" {
# name = "${terraform.workspace}-myname"
# count = terraform.workspace == "default" ? 3 : 1 # spin up 3 nodes in real environment but only 1 node if this is being deployed to an alternate developer workspace
# tags = {
# Name = "web - ${terraform.workspace}"
# }
# #...
# lifecycle {
# create_before_destroy = false
# prevent_destroy = false
# ignore_changes = [] # list of attributes
# }
#}