IPA Server Provisioning
✅ This template can be safely applied from any local work environment, even running outside an EWC tenancy's private network.
IPA (acronym for identity, policy and audit) and its open-source implementation FreeIPA, serve both as a user management system and as your internal DNS nameserver.
This is a configuration template (i.e. an Ansible Playbook) to customize your environment in the European Weather Cloud (EWC).
Functionality
The template is designed to:
- Provision an instance via Terraform,
with your specified VM image and desired flavor (a.k.a VM plan):
-
If a
terraform.tfstatestate file is not found under the user-defined directory, attempts to create the instance from scratchOR
-
If a
terraform.tfstatefile is found, leverages Terraform's out-of-the-box functionality to update the instance referenced on it
-
- Validate that network/subnet configuration in the EWC tenancy
- Configure the existing or newly provisioned instance such that it:
- Provides DNS resolutions for discovery of resources (i.e. other virtual machines)
- Enables centralized user and credentials creation/edition/deletion/authentication
- Allows centralized authorization between users and resources
- Automatically update the underlying subnet DNS nameserver to point to the newly configured IPA server
After successful provisioning, you can leverage Terraform's functionality to modify or delete individual components safely. Each will have its own main.tf definition and terraform.tfstate state file under the corresponding user-defined local directories.
To learn the basics about managing infrastructure with Terraform, check out Terraform in 100 seconds on YouTube. You can also find a step-by-step example applied to the EWC on the official EWC documentation.
💡 This template can be deployed in combination with complementary infrastructure as part of the Default Stack Provisioning Community Hub Item.
Prerequisites
- Install git (version 2.0 or higher )
- Install python (version 3.9 or higher)
- Install ansible (version 2.15 or higher)
- Install terraform (version 1.0 or higher)
- Get OpenStack API credentials (see How to request OpenStack Application Credentials section of the EWC documentation)
- Create an SSH keypair (see Creating Keys section of the EWC documentation)
- Import your public SSH key to OpenStack (see Import SSH Key section of the EWC documentation).
Usage
⚠️ Only RockyLinux version 8 supported due to constrains imposed by dependencies.
💡 A VM plan with at least 4GB of RAM is recommended for successful setup and stable operation.
1. Clone the repository
git clone https://github.com/ewcloud/ewc-ansible-playbook-flavours-and-provisioning.git
1.1. Change to the specific Item's subdirectory
cd ewc-ansible-playbook-flavours-and-provisioning/playbooks/ipa-server-provisioning
1.2. (Optional) Checkout an specific Item's version
⚠️ Make sure to replace
x.y.zin the command below, with your version of preference.
git checkout x.y.z
2. Download Ansible dependencies
💡 By default, Ansible Roles are installed under the
~/.ansible/rolesdirectory within your working environment.
Download the correct version of the Ansible dependencies, if you haven't done so already:
ansible-galaxy role install -r requirements.yml
3. Configure and apply the template
3.1. Interactive Mode
By running the following command, you can trigger an interactive session that prompts you for the necessary user inputs, and then applies changes to your target EWC environment:
ansible-playbook ipa-server-provisioning.yml
3.2. Non-Interactive Mode
💡 To learn more about defining variables at runtime, checkout the official Ansible documentation.
You can also run in non-interactive mode by passing the
--extra-vars or -e flag, followed by a map of key-value pairs; one for
each and every available input (see inputs section below). For example:
ansible-playbook \
-e '{
"ewc_provider": "eumetsat",
"ipa_server_tf_project_path":"~/ewc/ipa-server-1",
"ipa_server_app_name":"ipa",
"ipa_server_instance_name":"server",
"ipa_server_instance_index": 1,
"ipa_server_flavor_name":"eo1.large",
"ipa_server_image_name":"Rocky-8.10-20250604144456",
"public_keypair_name":"my-public-key-name",
"private_keypair_path":"~/.ssh/id_rsa",
"private_network_name": "private",
"security_group_name": "ipa",
"ipa_domain":"eumetsat.sandbox.ewc",
"ipa_admin_username":"ipaadmin",
"ipa_admin_password":"my-secret-password",
"ipa_admin_givenname": "IPAADMIN",
"ipa_admin_surname": "EWC"
}' \
ipa-server-provisioning.yml
4. Manullay update DNS nameserver(s)
⛔ Changes described in this section can potentially affect DNS resolution on existing VMs within your subnet. To prevent issues, enroll them to the new IPA server via the IPA Client Enroll Flavour CommunityHub Item, OR manually edit nameservers in their DNS configuration.
After successful execution of the template, additional changes to the OpenStack subnet are required. You can edit your specific OpenStack subnet, as well as any other OpenStack resource, with the native OpenStack CLI.
First, take note of the IP address of your newly configured IPA server and the subnet attached to it, replace these information in the command below, and execute:
openstack subnet set \
--dns-nameserver <IPV4 address of the IPA server> \
<ID or name of the OpenStack Subnet attached to the IPA server>
Then remove any default DNS nameservers which where added to the subnet prior to the IPA server configuration:
openstack subnet unset \
--dns-nameserver <IPV4 address of any prior default DNS nameserver> \
<ID or name of the OpenStack Subnet attached to the IPA server>
Inputs
| Name | Description | Type | Default | Required |
|---|---|---|---|---|
| ewc_provider | your target EWC provider. Must match that the provider of your OpenStack application credentials. Valid input values are ecmwf or eumetsat. |
string |
eumetsat |
yes |
| ipa_server_tf_project_path | path to terraform working directory | string |
~/ewc/ipa-server-1 |
yes |
| ipa_server_app_name | application name, used as prefix in the full instance name | string |
ipa |
yes |
| ipa_server_instance_name | name of the instance, used in the full instance name | string |
server |
yes |
| ipa_server_instance_index | index or identifier for the instance, used as suffix in the full instance name | number |
1 |
yes |
| ipa_server_flavor_name | name the flavor to use for the instance. To learn about available options, checkout the official EWC VM plans documentation | string |
eo1.large |
yes |
| ipa_server_image_name | name of the image to use for the instance. For complete information on available options, see the official EWC Images documentation | string |
Rocky-8.10-20250604144456 |
yes |
| public_keypair_name | name of public keypair (stored in OpenStack) to be copied into the instance for remote SSH access | string |
n/a | yes |
| private_keypair_path | path to the local private keypair to use for SSH access to the instance | string |
~/.ssh/id_rsa |
yes |
| private_network_name | private network name to attach the instance | string |
private |
yes |
| security_group_name | security group name to apply to the instance | string |
ipa |
yes |
| ipa_domain | domain name to be managed by the IPA server. Example: eumetsat.sandbox.ewc |
string |
n/a | yes |
| ipa_admin_username | username of administrator account to replace the default IPA admin | string |
ipaadmin |
yes |
| ipa_admin_password | password of administrator account to replace the default IPA admin | string |
n/a | yes |
| ipa_admin_givenname | given name of the administrator to replace the default IPA admin (needs not be a physical person) | string |
EWC |
yes |
| ipa_admin_surname | surname of the administrator to replace the default IPA admin (needs not to belong to a physical person) | string |
IPAADMIN |
yes |