Constellation runs entirely in your cloud environment and can be controlled via a dedicated [command-line interface (CLI)](../reference/cli.md) or a [Terraform provider](../workflows/terraform-provider.md).
## Prerequisites
Make sure the following requirements are met:
* Your machine is running Linux or macOS
* You have admin rights on your machine
* [kubectl](https://kubernetes.io/docs/tasks/tools/) is installed
If you prefer to use Terraform, you can alternatively use the [Terraform provider](../workflows/terraform-provider.md) to manage the cluster's lifecycle.
:::
The CLI executable is available at [GitHub](https://github.com/edgelesssys/constellation/releases).
The CLI supports autocompletion for various shells. To set it up, run `constellation completion` and follow the given steps.
:::
## Set up cloud credentials
Constellation makes authenticated calls to the CSP API. Therefore, you need to set up Constellation with the credentials for your CSP.
:::tip
If you don't have a cloud subscription, you can also set up a [local Constellation cluster using virtualization](../getting-started/first-steps-local.md) for testing.
The following [resource providers need to be registered](https://learn.microsoft.com/en-us/azure/azure-resource-manager/management/resource-providers-and-types#register-resource-provider) in your subscription:
The built-in `Contributor` role is a superset of these permissions.
Follow Microsoft's guide on [understanding](https://learn.microsoft.com/en-us/azure/role-based-access-control/role-definitions) and [assigning roles](https://learn.microsoft.com/en-us/azure/role-based-access-control/role-assignments).
1: You can omit `*/register/Action` if the resource providers mentioned above are already registered and the `ARM_SKIP_PROVIDER_REGISTRATION` environment variable is set to `true` when creating the IAM configuration.
Create a new project for Constellation or use an existing one.
Enable the [Compute Engine API](https://console.cloud.google.com/apis/library/compute.googleapis.com) on it.
To [create the IAM configuration](../workflows/config.md#creating-an-iam-configuration) for Constellation, you need the following permissions:
*`iam.serviceAccountKeys.create`
*`iam.serviceAccountKeys.delete`
*`iam.serviceAccountKeys.get`
*`iam.serviceAccounts.create`
*`iam.serviceAccounts.delete`
*`iam.serviceAccounts.get`
*`resourcemanager.projects.getIamPolicy`
*`resourcemanager.projects.setIamPolicy`
Together, the built-in roles `roles/editor` and `roles/resourcemanager.projectIamAdmin` form a superset of these permissions.
To [create a Constellation cluster](../workflows/create.md), you need the following permissions:
*`compute.addresses.createInternal`
*`compute.addresses.deleteInternal`
*`compute.addresses.get`
*`compute.addresses.useInternal`
*`compute.backendServices.create`
*`compute.backendServices.delete`
*`compute.backendServices.get`
*`compute.backendServices.use`
*`compute.disks.create`
*`compute.firewalls.create`
*`compute.firewalls.delete`
*`compute.firewalls.get`
*`compute.firewalls.update`
*`compute.globalAddresses.create`
*`compute.globalAddresses.delete`
*`compute.globalAddresses.get`
*`compute.globalAddresses.use`
*`compute.globalForwardingRules.create`
*`compute.globalForwardingRules.delete`
*`compute.globalForwardingRules.get`
*`compute.globalForwardingRules.setLabels`
*`compute.globalOperations.get`
*`compute.healthChecks.create`
*`compute.healthChecks.delete`
*`compute.healthChecks.get`
*`compute.healthChecks.useReadOnly`
*`compute.instanceGroupManagers.create`
*`compute.instanceGroupManagers.delete`
*`compute.instanceGroupManagers.get`
*`compute.instanceGroupManagers.update`
*`compute.instanceGroups.create`
*`compute.instanceGroups.delete`
*`compute.instanceGroups.get`
*`compute.instanceGroups.update`
*`compute.instanceGroups.use`
*`compute.instances.create`
*`compute.instances.setLabels`
*`compute.instances.setMetadata`
*`compute.instances.setTags`
*`compute.instanceTemplates.create`
*`compute.instanceTemplates.delete`
*`compute.instanceTemplates.get`
*`compute.instanceTemplates.useReadOnly`
*`compute.networks.create`
*`compute.networks.delete`
*`compute.networks.get`
*`compute.networks.updatePolicy`
*`compute.routers.create`
*`compute.routers.delete`
*`compute.routers.get`
*`compute.routers.update`
*`compute.subnetworks.create`
*`compute.subnetworks.delete`
*`compute.subnetworks.get`
*`compute.subnetworks.use`
*`compute.targetTcpProxies.create`
*`compute.targetTcpProxies.delete`
*`compute.targetTcpProxies.get`
*`compute.targetTcpProxies.use`
*`iam.serviceAccounts.actAs`
Together, the built-in roles `roles/editor`, `roles/compute.instanceAdmin` and `roles/resourcemanager.projectIamAdmin` form a superset of these permissions.
Follow Google's guide on [understanding](https://cloud.google.com/iam/docs/understanding-roles) and [assigning roles](https://cloud.google.com/iam/docs/granting-changing-revoking-access).
To set up a Constellation cluster, you need to perform two tasks that require permissions: create the infrastructure and create roles for cluster nodes. Both of these actions can be performed by different users, e.g., an administrator to create roles and a DevOps engineer to create the infrastructure.
To [create the IAM configuration](../workflows/config.md#creating-an-iam-configuration) for Constellation, you need the following permissions:
```json
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:DescribeAccountAttributes",
"iam:AddRoleToInstanceProfile",
"iam:AttachRolePolicy",
"iam:CreateInstanceProfile",
"iam:CreatePolicy",
"iam:CreateRole",
"iam:DeleteInstanceProfile",
"iam:DeletePolicy",
"iam:DeletePolicyVersion",
"iam:DeleteRole",
"iam:DetachRolePolicy",
"iam:GetInstanceProfile",
"iam:GetPolicy",
"iam:GetPolicyVersion",
"iam:GetRole",
"iam:ListAttachedRolePolicies",
"iam:ListInstanceProfilesForRole",
"iam:ListPolicyVersions",
"iam:ListRolePolicies",
"iam:PassRole",
"iam:RemoveRoleFromInstanceProfile",
"sts:GetCallerIdentity"
],
"Resource": "*"
}
]
}
```
The built-in `AdministratorAccess` policy is a superset of these permissions.
To [create a Constellation cluster](../workflows/create.md), see the permissions of [main.tf](https://github.com/edgelesssys/constellation/blob/main/terraform/infrastructure/iam/aws/main.tf).
The built-in `PowerUserAccess` policy is a superset of these permissions.
Follow Amazon's guide on [understanding](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html) and [managing policies](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_managed-vs-inline.html).
You can use the [Google Cloud Shell](https://cloud.google.com/shell). Make sure your [session is authorized](https://cloud.google.com/shell/docs/auth). For example, execute `gsutil` and accept the authorization prompt.
**Production**
Use one of the following options on a trusted machine:
* Use the [`gcloud` CLI](https://cloud.google.com/sdk/gcloud)
```bash
gcloud auth application-default login
```
This will ask you to log-in to your Google account and create your credentials.
The Constellation CLI will automatically load these credentials when needed.
* Set up a service account and pass the credentials manually
Follow [Google's guide](https://cloud.google.com/docs/authentication/production#manually) for setting up your credentials.
You can use the [AWS CloudShell](https://console.aws.amazon.com/cloudshell/home). Make sure you are [authorized to use it](https://docs.aws.amazon.com/cloudshell/latest/userguide/sec-auth-with-identities.html).
**Production**
Use the latest version of the [AWS CLI](https://aws.amazon.com/cli/) on a trusted machine:
```bash
aws configure
```
Options and first steps are described in the [AWS CLI documentation](https://docs.aws.amazon.com/cli/index.html).