|
| 1 | +Demo |
| 2 | +==== |
| 3 | + |
| 4 | +This article demonstrates how to install vault, add and configure plugin and |
| 5 | +perform invoke Terraform to query image_id for the image by name. |
| 6 | + |
| 7 | +- Install vault |
| 8 | + |
| 9 | +- Modify vault config file adding ``plugin_dir = "/opt/vault/plugin"`` |
| 10 | + |
| 11 | +- Deploy the plugin |
| 12 | + |
| 13 | + .. code-block:: console |
| 14 | +
|
| 15 | + wget https://github.com/opentelekomcloud/vault-plugin-secrets-openstack/releases/download/v1.0.2/vault-plugin-secrets-openstack_1.0.2_linux_amd64.tar.gz |
| 16 | + tar xvf vault-plugin-secrets-openstack_1.0.2_linux_arm64.tar.gz -C /opt/vault/plugins |
| 17 | +
|
| 18 | +- Register the plugin |
| 19 | + |
| 20 | + .. code-block:: |
| 21 | +
|
| 22 | + vault secrets enable -path="openstack" -plugin-name="vault-plugin-secrets-openstack" plugin |
| 23 | +
|
| 24 | +- Register password policy |
| 25 | + |
| 26 | + .. code-block:: |
| 27 | + :caption: os_policy.hcl |
| 28 | +
|
| 29 | + length = 20 |
| 30 | + rule "charset" { |
| 31 | + charset = "abcdefghijklmnopqrstuvwxyz" |
| 32 | + min-chars = 1 |
| 33 | + } |
| 34 | + rule "charset" { |
| 35 | + charset = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" |
| 36 | + min-chars = 1 |
| 37 | + } |
| 38 | + rule "charset" { |
| 39 | + charset = "0123456789" |
| 40 | + min-chars = 1 |
| 41 | + } |
| 42 | + rule "charset" { |
| 43 | + charset = "!@#$%^&*" |
| 44 | + min-chars = 1 |
| 45 | + } |
| 46 | +
|
| 47 | + .. code-block:: console |
| 48 | +
|
| 49 | + vault write sys/policies/password/os-policy policy=@os_policy.hcl |
| 50 | +
|
| 51 | +
|
| 52 | +- Configure cloud root account |
| 53 | + |
| 54 | + .. code-block:: |
| 55 | +
|
| 56 | + vault write openstack/cloud/demo auth_url=https://<AUTH_URL> username=<USER> password=<PASSWORD> user_domain_name=<USER_DOMAIN_NAME> password_policy=os-policy |
| 57 | +
|
| 58 | +- Configure root token role |
| 59 | + |
| 60 | + .. code-block:: console |
| 61 | +
|
| 62 | + vault write /openstack/role/root_token cloud=demo project_name=<PROJECT_NAME> domain_name=<DOMAIN_NAME> root=true |
| 63 | +
|
| 64 | +- Prepare Terraform configuration |
| 65 | + |
| 66 | + .. literalinclude:: terraform_vault_openstack/settings.tf |
| 67 | + :caption: settings.tf |
| 68 | + |
| 69 | + .. literalinclude:: terraform_vault_openstack/vault_os_creds.tf |
| 70 | + :caption: vault_os_cred.tf |
| 71 | + |
| 72 | + .. literalinclude:: terraform_vault_openstack/variables.tf |
| 73 | + :caption: variables.tf |
| 74 | + |
| 75 | + It is required to populate tenant_name (project_name) of the OpenStack |
| 76 | + provider when root token role is used. |
| 77 | + |
| 78 | +- Apply Terraform plan |
| 79 | + |
| 80 | + .. code-block:: console |
| 81 | +
|
| 82 | + terraform apply |
0 commit comments