Skip to content

Latest commit

 

History

History

create_account_roles

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Account-wide IAM roles

Prior to creating a ROSA STS cluster, you must create the required account-wide roles and policies. For more information, see Account-wide IAM role and policy reference in the Red Hat Customer Portal.

Prerequisites

  • You have an AWS account.
  • You have installed the latest version of the ROSA command-line interface (CLI) (rosa).
  • You have an offline OpenShift Cluster Manager token. This token can be generated in the Red Hat Hybrid Cloud Console.
  • You have installed Terraform. See the Terraform page for the latest version.

Open issue

This example also creates the policies for the operator roles As result of that, the operator policies are managed by this example, for example: when you update the version, it also updated in the operator role policies.

Account-wide IAM role creation

  1. To run terraform apply you need to set up some variables. This guide uses environmental variables. For more on Terraform variables, see Managing Variables in the Terraform documentation.

    Run the following commands to export your variables. Provide your values in lieu of the brackets. Note that any values declared in the variables.tf are the default values if you do not export a superseding value.

    1. This variable should be your full OpenShift Cluster Manager offline token that you generated in the prerequisites.
      export TF_VAR_token=<ocm_offline_token>
      
    2. This value should be the prefix for your Operator role.
      export TF_operator_role_prefix=<prefix_name>
      
    3. This value should always point to https://api.openshift.com.
      export TF_VAR_url=https://api.openshift.com
      
    4. Optional: You can set the account-role prefix with this variable. This value cannot end with a hyphen (-). If the value is empty, the module generates a string that starts with account-role- and combines it with a string of four random characters.
      export TF_VAR_account_role_prefix=<account_role_prefix>
      
    5. Optional: You can set the desired OpenShift version with this variable. The default is available from the ROSA CLI with rosa list version |grep yes. This should be in the format of x.y, such as 4.13
      export TF_VAR_openshift_version=<choose_openshift_version>
      
    6. Optional: If you want to set any specific AWS tags for your account roles, you can use this variable to declare those tags.
      export TF_VAR_tags=<aws_resource_tags> (Optional) 
      
  2. In your local copy of the account-roles folder, run the following command:

    terraform init
    

    Running this command accesses all the necessary provider information to apply your Terraform plan.

  3. Optional: Run the plan command to ensure that your Terraform files build correctly without errors. This is not required to apply your Terraform plans.

    terraform plan -out account-roles.tfplan
    
  4. Run the apply command to create your account roles.

    Note: If you did not run the plan command, you can simply just apply without specifying a file.

    terraform apply <"account-roles.tfplan">
    
  5. The Terraform applies the plan and creates the account roles. You will see a prompt to confirm you want to create these resources. Enter yes, then the process will complete with your resources.

Verification

  1. In the rosa CLI, run the following command to verify that the account roles are created:
    rosa list account-roles
    
  2. You see your roles when the command finishes.
    I: Fetching account roles
    ROLE NAME                           ROLE TYPE      ROLE ARN                                                    OPENSHIFT VERSION  AWS Managed
    ManagedOpenShift-ControlPlane-Role  Control plane  arn:aws:iam::XXXXX:role/ManagedOpenShift-ControlPlane-Role  4.13               No
    ManagedOpenShift-Installer-Role     Installer      arn:aws:iam::XXXXX:role/ManagedOpenShift-Installer-Role     4.13               No
    ManagedOpenShift-Support-Role       Support        arn:aws:iam::XXXXX:role/ManagedOpenShift-Support-Role       4.13               No
    ManagedOpenShift-Worker-Role        Worker         arn:aws:iam::XXXXX:role/ManagedOpenShift-Worker-Role        4.13               No
    
    

Resource clean up

After you are done with the resources you created, you should not delete them manually, but instead, use the destroy command. Run the following to delete all of your created resources:

terraform destroy

After the command is complete, your resources are deleted.

NOTE: If you manually delete a resource, you create unresolvable issues within your environment.