From 9315db60d7def53f725cca895d2f03a1c6060218 Mon Sep 17 00:00:00 2001 From: badra001 Date: Wed, 25 May 2022 15:53:10 -0400 Subject: [PATCH] extend iam saml to pass url --- iam-saml/README.md | 2 ++ iam-saml/bin/external_get-saml-metadata.sh | 26 +++++++++++++++++----- iam-saml/main.tf | 3 ++- iam-saml/variables.tf | 12 ++++++++++ 4 files changed, 36 insertions(+), 7 deletions(-) diff --git a/iam-saml/README.md b/iam-saml/README.md index 22340fa..30c5729 100644 --- a/iam-saml/README.md +++ b/iam-saml/README.md @@ -65,6 +65,8 @@ No modules. | [account\_alias](#input\_account\_alias) | AWS Account Alias | `string` | `""` | no | | [account\_id](#input\_account\_id) | AWS Account ID (default will pull from current user) | `string` | `""` | no | | [component\_tags](#input\_component\_tags) | Additional tags for Components (s3, kms, ddb) | `map(map(string))` |
{
"ddb": {},
"kms": {},
"s3": {}
}
| no | +| [idp\_metadata\_selector](#input\_idp\_metadata\_selector) | URL Query parameter for selecting urn:amazon:webservices string for EW or gov | `string` | `"PID="` | no | +| [idp\_metadata\_url](#input\_idp\_metadata\_url) | ID Provider Metadata URL | `string` | `null` | no | | [override\_prefixes](#input\_override\_prefixes) | Override built-in prefixes by component (efs, s3, ebs, kms, role, policy, security-group). This should be used primarily for common infrastructure things | `map(string)` | `{}` | no | | [saml\_provider\_name](#input\_saml\_provider\_name) | SAML Provider Name | `string` | `"Census_TCO_IDMS"` | no | | [tags](#input\_tags) | AWS Tags to apply to appropriate resources (S3, KMS). Do not include safeguard tags here, use the data\_safeguard field for such things. | `map(string)` | `{}` | no | diff --git a/iam-saml/bin/external_get-saml-metadata.sh b/iam-saml/bin/external_get-saml-metadata.sh index 8e15fe4..c8dd96b 100755 --- a/iam-saml/bin/external_get-saml-metadata.sh +++ b/iam-saml/bin/external_get-saml-metadata.sh @@ -1,16 +1,18 @@ #!/bin/bash +VERSION="1.1.0" + #set -e -eval "$(jq -r '@sh "AWS_ENVIRONMENT=\(.aws_environment) OUTPUT=\(.output_file) URL_PREFIX=\(.url_prefix)"')" +eval "$(jq -r '@sh "AWS_ENVIRONMENT=\(.aws_environment) OUTPUT=\(.output_file) URL=\(.url) URL_SELECTOR=\(.url_selector)"')" if [[ -z $AWS_ENVIRONMENT ]] || [[ "$AWS_ENVIRONMENT" == "null" ]] then AWS_ENVIRONMENT="east-west" fi -if [[ -z "$URL_PREFIX" ]] || [[ "$URL_PREFIX" == "null" ]] +if [[ -z "$URL" ]] || [[ "$URL" == "null" ]] then - URL_PREFIX="https://id-provider.tco.census.gov/nidp/saml2/metadata?PID=" + URL="https://id-provider.tco.census.gov/nidp/saml2/metadata" fi if [[ $AWS_ENVIRONMENT == "east-west" ]] || [[ $AWS_ENVIRONMENT == "ew" ]] @@ -41,14 +43,26 @@ fi # if output file exists, do not re-run this +if [ "$URL_SELECTOR" = "null" ] +then + URL_SELECTOR="" +fi + +if [ ! -z "$URL_SELECTOR" ] +then + FULL_URL="${URL}?${URL_SELECTOR}${SELECT}" +else + FULL_URL=$URL +fi + if [ ! -r $OUTPUT ] then - URL="${URL_PREFIX}${SELECT}" - curl -q -k $URL > $OUTPUT + curl -q -k ${FULL_URL} > $OUTPUT status=$? else status=0 fi result=$(cat $OUTPUT) -jq -n --arg output_file "$OUTPUT" --arg value "$result" --arg status "$status" '{"output_file":$output_file,"value":$value,"status":$status}' +jq -n --arg output_file "$OUTPUT" --arg value "$result" --arg status "$status" --arg url "$FULL_URL" --arg version "$VERSION" \ + '{"output_file":$output_file,"value":$value,"status":$status,"url":$url,"version":$version}' diff --git a/iam-saml/main.tf b/iam-saml/main.tf index 1ed4417..473195e 100644 --- a/iam-saml/main.tf +++ b/iam-saml/main.tf @@ -74,7 +74,8 @@ data "external" "saml_metadata" { query = { "aws_environment" = local.account_environment "output_file" = local.saml_metadata_file - # "url_prefix" = "" + "url" = var.idp_metadata_url + "url_selector" = var.idp_metadata_selector } } diff --git a/iam-saml/variables.tf b/iam-saml/variables.tf index e5fc5c7..729ddfa 100644 --- a/iam-saml/variables.tf +++ b/iam-saml/variables.tf @@ -9,3 +9,15 @@ variable "component_tags" { type = map(map(string)) default = { "s3" = {}, "kms" = {}, "ddb" = {} } } + +variable "idp_metadata_url" { + description = "ID Provider Metadata URL" + type = string + default = null +} + +variable "idp_metadata_selector" { + description = "URL Query parameter for selecting urn:amazon:webservices string for EW or gov" + type = string + default = "PID=" +}