Skip to content

Latest commit

 

History

History
executable file
·
221 lines (189 loc) · 14.8 KB

README.md

File metadata and controls

executable file
·
221 lines (189 loc) · 14.8 KB
title description
Hashicorp Vault Authentication - OIDC Provider for Azure AD / Entra
Integrate HashiCorp Vault OIDC Authentication with Third Party Azure AD / Entra IDP

HashiCorp Vault Authentication - OIDC Provider for Azure AD / Entra

REQUIREMENTS

OVERVIEW

Based on the tutorial for HashiCorp Vault OIDC Provider Authentication Method for Azure AD (Entra), this is the High Level Overview workflow:

HashiCorp Vault Authentication - OIDC Provider for Azure Active Directory

Resources

This Repo codifies some highlighted Azure and HashiCorp Vault resources (not comprehensive):

  • Provider: hashicorp/azuread
    • azuread_application
    • azuread_group
  • Provider: hashicorp/vault
    • vault_jwt_auth_backend
    • vault_jwt_auth_backend_role
    • vault_policy
    • vault_identity_group
    • vault_identity_group_alias
    • vault_kv_secret_v2
      • secret/app1 (vault kv metadata get -mount=secret app1)
      • secret/app2 (vault kv metadata get -mount=secret app2)

Groups: Azure AD / Entra <=> Vault Mapping

Place your user into the appropriate Azure AD / Entra Group(s) to apply the correct Group Policies.

AZURE GROUP VAULT GROUP VAULT SECRETS PATH VAULT POLICY
{{user}}-demo-oidc-group-example vault_identity_group.oidc_provider_azure_group_example
{{user}}-demo-oidc-group-app1 vault_identity_group.oidc_provider_azure_group_app1 secrets/app1 app1_owner_policy.tpl
{{user}}-demo-oidc-group-app2 vault_identity_group.oidc_provider_azure_group_app2 secrets/app2 app2_owner_policy.tpl
{{user}}-demo-oidc-group-admin vault_identity_group.oidc_provider_azure_group_admin secrets/* vault_admin_owner_policy.tpl
{{user}}-demo-oidc-group-super-admin vault_identity_group.oidc_provider_azure_group_super_admin secrets/* vault_super_admin_policy.tpl

TLDR

  • Set Azure and HashiCorp Vault logins and addresses - can be set via Environment Variables and/or az CLI
  • Go to ./terraform directory, execute terraform init and terraform apply
  • Place your user into the appropriate Azure AD / Entra Group(s) to apply the correct Group Policies.
  • Log in to Vault UI via OIDC Authentication and set the More Options => Mount Path to your TF Variable value for var.vault_auth_mount_path (default: oidc-azure)
  • Verify ability to read secrets at secret/app1 or secret/app2 KVv2 Secrets paths.
  • Log out
  • Repeat with other Azure AD / Entra Group(s)
  • Log back in

FILES

Repo Layout

.
├── LICENSE
├── Makefile
├── README.md
├── assets
│   ├── convergence-scenarios-webapp-webapi.svg
│   ├── convergence-scenarios-webapp.svg
│   └── vault.auth-oidc-azure.01.png
└── terraform
    ├── 00.variables.tf
    ├── 00.versions.tf
    ├── 01-01.azuread_application.tf
    ├── 01-02.azuread.groups.tf
    ├── 02-01.vault.oidc_provider.tf
    ├── 02-02.vault.policies.tf
    ├── 02-03.vault.aliases_groups.tf
    ├── 02-04.vault.secrets.tf
    ├── 99.outputs.tf
    ├── templates
    │   ├── app1_owner_policy.tpl
    │   ├── app1_reader_policy.tpl
    │   ├── app2_owner_policy.tpl
    │   ├── app2_reader_policy.tpl
    │   ├── vault_admin_policy.tpl
    │   └── vault_super_admin_policy.tpl
    ├── terraform.auto.tfvars
    ├── terraform.tfstate
    └──  terraform.tfstate.backup

TERRAFORM

Requirements

Name Version
terraform >= 0.13
azuread >= 2.47.0
azurerm >= 3.97.1
vault >= 4.1.0

Providers

Name Version
azuread 2.47.0
random 3.6.0
vault 4.1.0

Modules

No modules.

Resources

Name Type
azuread_application.demo-oidc-example resource
azuread_application_password.demo-oidc-password-example resource
azuread_group.demo-oidc-group-admin resource
azuread_group.demo-oidc-group-app1 resource
azuread_group.demo-oidc-group-app2 resource
azuread_group.demo-oidc-group-example resource
azuread_group.demo-oidc-group-super-admin resource
azuread_service_principal.demo-oidc-example resource
random_pet.example resource
vault_identity_group.oidc_provider_azure_group_admin resource
vault_identity_group.oidc_provider_azure_group_app1 resource
vault_identity_group.oidc_provider_azure_group_app2 resource
vault_identity_group.oidc_provider_azure_group_example resource
vault_identity_group.oidc_provider_azure_group_super_admin resource
vault_identity_group_alias.oidc_provider_azure_group_admin_alias resource
vault_identity_group_alias.oidc_provider_azure_group_app1_alias resource
vault_identity_group_alias.oidc_provider_azure_group_app2_alias resource
vault_identity_group_alias.oidc_provider_azure_group_example_alias resource
vault_identity_group_alias.oidc_provider_azure_group_super_admin_alias resource
vault_jwt_auth_backend.oidc_provider_azure resource
vault_jwt_auth_backend_role.oidc_provider_azure_role resource
vault_kv_secret_v2.app1_secret resource
vault_kv_secret_v2.app2_secret resource
vault_mount.kvv2 resource
vault_policy.app1_owner resource
vault_policy.app1_reader resource
vault_policy.app2_owner resource
vault_policy.app2_reader resource
vault_policy.vault_admin resource
vault_policy.vault_super_admin resource
azuread_application_published_app_ids.well_known data source
azuread_client_config.current data source
azuread_service_principal.msgraph data source

Inputs

Name Description Type Default Required
azure_tenant_id Azure Tenant ID string "" yes
user Demo User string "user" no
vault_auth_mount_path Vault Authentication Mount Path string "oidc-azure" yes
vault_cli_port Vault CLI Port string "8250" no
vault_port Vault Port string "8200" no
vault_root_token Vault Root Token string "" yes
vault_url Vault URL string "http://localhost:8200" yes

Outputs

Name Description
azuread_application_client_id oidc_client_id
azuread_application_id oidc_client_id
azuread_application_object_id n/a
azuread_application_oidc_metadata_document oidc_discovery_url
azuread_application_password oidc_client_secret
azuread_application_password_id n/a
azuread_application_password_key_id n/a
azuread_group_id n/a
azuread_group_object_id n/a
azuread_group_owner n/a
oidc_client_id oidc_client_id
oidc_client_secret oidc_client_secret
oidc_discovery_url oidc_discovery_url

APPENDIX:

References:

Terraform Providers:
Vault Auth OIDC
Azure
Miscellaneous