-
Notifications
You must be signed in to change notification settings - Fork 141
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
167 additions
and
0 deletions.
There are no files selected for viewing
17 changes: 17 additions & 0 deletions
17
terraform-modules/aws/helm/kubernetes-external-secrets/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# kubernetes-external-secrets | ||
|
||
Source project: https://github.com/external-secrets/kubernetes-external-secrets | ||
Source chart: https://github.com/external-secrets/kubernetes-external-secrets/tree/master/charts/kubernetes-external-secrets | ||
|
||
EKS Kubernetes v1.19+ | ||
|
||
## Useful guides | ||
Getting the IAM policies and trust relationships to all align up is tricky. If something is not set correctly like | ||
the name is off in one of the place, the entire sequence of chained identity fails and it is hard to figure out where | ||
exactly. You can guess and see if it is something obvious but if it is not, then you should just follow each of the | ||
resources through to make sure everything is setup correctly. | ||
|
||
Here is the doc on how to setup IAM for ServiceAccounts: https://docs.aws.amazon.com/eks/latest/userguide/iam-roles-for-service-accounts.html | ||
|
||
At the bottom of this doc it will link to how to create each of the items. Following each one through to make sure these | ||
items exist and the names all match up is critical for this entire setup. |
9 changes: 9 additions & 0 deletions
9
terraform-modules/aws/helm/kubernetes-external-secrets/helm_values.tpl.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
--- | ||
env: | ||
AWS_REGION: us-east-1 | ||
AWS_DEFAULT_REGION: us-east-1 | ||
|
||
serviceAccount: | ||
name: ${resource_name} | ||
annotations: | ||
eks.amazonaws.com/role-arn: "arn:aws:iam::${awsAccountID}:role/${resource_name}" |
20 changes: 20 additions & 0 deletions
20
terraform-modules/aws/helm/kubernetes-external-secrets/iam-policy.tpl.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
{ | ||
"Version": "2012-10-17", | ||
"Statement": [ | ||
{ | ||
"Effect": "Allow", | ||
"Action": [ | ||
"secretsmanager:GetResourcePolicy", | ||
"secretsmanager:GetSecretValue", | ||
"secretsmanager:DescribeSecret", | ||
"secretsmanager:ListSecretVersionIds", | ||
"sts:AssumeRole" | ||
], | ||
"Resource": [ | ||
"arn:aws:iam::016733450475:role/kubernetes-external-secrets-${envName}", | ||
"arn:aws:secretsmanager:${awsRegion}:${awsAccountID}:secret:${secretsPrefix}*" | ||
] | ||
} | ||
] | ||
} | ||
|
68 changes: 68 additions & 0 deletions
68
terraform-modules/aws/helm/kubernetes-external-secrets/main.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
locals { | ||
base_name = "kubernetes-external-secrets" | ||
iam_policy_file = "iam-policy.tpl.json" | ||
k8s_service_account_name = "kubernetes-external-secrets" | ||
} | ||
|
||
data "aws_caller_identity" "current" {} | ||
data "aws_region" "current" {} | ||
|
||
module "iam_assumable_role_admin" { | ||
source = "terraform-aws-modules/iam/aws//modules/iam-assumable-role-with-oidc" | ||
version = "3.6.0" | ||
create_role = true | ||
role_name = "${local.base_name}-${var.environment_name}" | ||
# role_path = "/token-file-web-identity/" | ||
provider_url = replace(var.eks_cluster_oidc_issuer_url, "https://", "") | ||
role_policy_arns = [aws_iam_policy.cluster_autoscaler.arn] | ||
oidc_fully_qualified_subjects = ["system:serviceaccount:${var.namespace}:${local.k8s_service_account_name}-${var.environment_name}"] | ||
} | ||
|
||
data "template_file" "iam_policy" { | ||
template = file("${path.module}/iam-policy.tpl.json") | ||
vars = { | ||
awsAccountID = data.aws_caller_identity.current.account_id | ||
awsRegion = data.aws_region.current.name | ||
secretsPrefix = var.secrets_prefix | ||
envName = var.environment_name | ||
} | ||
} | ||
|
||
# Policy doc: https://github.com/kubernetes-sigs/aws-efs-csi-driver/blob/master/docs/iam-policy-example.json | ||
resource "aws_iam_policy" "cluster_autoscaler" { | ||
name_prefix = "${local.base_name}-${var.environment_name}" | ||
description = "${local.base_name} for ${var.environment_name}" | ||
policy = data.template_file.iam_policy.rendered | ||
} | ||
|
||
# | ||
# Helm templating | ||
# | ||
data "template_file" "helm_values" { | ||
template = file("${path.module}/helm_values.tpl.yaml") | ||
vars = { | ||
awsAccountID = data.aws_caller_identity.current.account_id | ||
awsRegion = data.aws_region.current.name | ||
serviceAccountName = local.k8s_service_account_name | ||
resource_name = "${local.base_name}-${var.environment_name}" | ||
} | ||
} | ||
|
||
resource "helm_release" "helm_chart" { | ||
chart = "kubernetes-external-secrets" | ||
namespace = var.namespace | ||
create_namespace = var.create_namespace | ||
name = var.chart_name | ||
version = var.helm_version | ||
verify = var.verify | ||
repository = "https://external-secrets.github.io/kubernetes-external-secrets/" | ||
|
||
values = [ | ||
data.template_file.helm_values.rendered, | ||
var.helm_values, | ||
] | ||
|
||
depends_on = [ | ||
module.iam_assumable_role_admin | ||
] | ||
} |
53 changes: 53 additions & 0 deletions
53
terraform-modules/aws/helm/kubernetes-external-secrets/variables.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
variable "helm_version" { | ||
type = string | ||
default = "8.3.0" | ||
description = "Helm chart version" | ||
} | ||
|
||
variable "verify" { | ||
type = bool | ||
default = false | ||
description = "Verify the helm download" | ||
} | ||
|
||
variable "create_namespace" { | ||
type = bool | ||
default = true | ||
description = "Create namespace if it does not exist" | ||
} | ||
|
||
variable "namespace" { | ||
type = string | ||
default = "kubernetes-external-secrets" | ||
description = "Namespace to install in" | ||
} | ||
|
||
variable "chart_name" { | ||
type = string | ||
default = "kubernetes-external-secrets" | ||
description = "Name to set the helm deployment to" | ||
} | ||
|
||
variable "helm_values" { | ||
type = string | ||
default = "" | ||
description = "Additional helm values to pass in. These values would override the default in this module." | ||
} | ||
|
||
variable "environment_name" { | ||
type = string | ||
default = "env" | ||
description = "An environment name to attach to some resources. Optional only needed if you are going to create more than one of these items in an AWS account" | ||
} | ||
|
||
variable "eks_cluster_oidc_issuer_url" { | ||
type = string | ||
default = "" | ||
description = "EKS cluster oidc issuer url" | ||
} | ||
|
||
variable "secrets_prefix" { | ||
type = string | ||
default = "" | ||
description = "The prefix to your AWS Secrets. This allows this module to craft a more tightly controlled set of IAM policies to only allow it to get certain secrets" | ||
} |