Skip to content
Snippets Groups Projects
Forked from project / cloud
463 commits behind the upstream repository.
Takumaru Sekine's avatar
Issue #3360272 by sekinet, yas: Fix an error: Call to undefined method...
Takumaru Sekine authored
Issue #3360272 by sekinet, yas: Fix an error: Call to undefined method Drupal\openstack\Service\Rest\OpenStackService::updateKeyPair()
59a37fd3
History

Introduction

Cloud is a set of modules to enable Cloud orchestration: A Drupal-based Cloud dashboard for AWS, Kubernetes, OpenStack, VMware and Terraform Cloud as a one-stop portal to manage multiple cloud service providers.

Requirements

  • PHP 8.0 or higher (128 MB memory or higher)
  • MySQL 5.7 or higher OR MariaDB 10.3 or higher
  • Drupal 9.5 or higher
  • Cloud 6.x
    • This branch includes support for AWS, Kubernetes, OpenStack, VMware and Terraform Cloud
    • Future support includes GCP and MS Azure

Limitations

Installation

Configuration

IAM Policy (AWS)

  • Before you create a new AWS Cloud service provider, you may want to configure IAM Policy as follows:
    • Mandatory IAM policy for creating an AWS Cloud service provider are:
      {
          "Version": "2012-10-17",
          "Statement": [
              {
                  "Sid": "Mandatory",
                  "Effect": "Allow",
                  "Action": [
                      "ec2:DescribeAddresses",
                      "ec2:DescribeAvailabilityZones",
                      "ec2:DescribeIamInstanceProfileAssociations",
                      "ec2:DescribeCarrierGateways",
                      "ec2:DescribeFlowLogs",
                      "ec2:DescribeImageAttribute",
                      "ec2:DescribeImages",
                      "ec2:DescribeInstanceAttribute",
                      "ec2:DescribeInstances",
                      "ec2:DescribeInternetGateways",
                      "ec2:DescribeKeyPairs",
                      "ec2:DescribeLaunchTemplates",
                      "ec2:DescribeLaunchTemplateVersions",
                      "ec2:DescribeNetworkInterfaces",
                      "ec2:DescribeSecurityGroups",
                      "ec2:DescribeSnapshots",
                      "ec2:DescribeSubnets",
                      "ec2:DescribeTransitGateways",
                      "ec2:DescribeVolumes",
                      "ec2:DescribeVpcPeeringConnections",
                      "ec2:DescribeVpcs",
                      "iam:ListInstanceProfiles"
                  ],
                  "Resource": "*"
              }
          ]
      }
    • Optional IAM policy for creating an AWS Cloud service provider are:
      {
          "Version": "2012-10-17",
          "Statement": [
              {
                  "Sid": "Optional",
                  "Effect": "Allow",
                  "Action": [
                      "cloudwatch:GetMetricData",
                      "ec2:AuthorizeSecurityGroupEgress",
                      "ec2:AuthorizeSecurityGroupIngress",
                      "ec2:CreateKeyPair",
                      "ec2:CreateLaunchTemplate",
                      "ec2:CreateNetworkInterface",
                      "ec2:CreateSecurityGroup",
                      "ec2:CreateSnapshot",
                      "ec2:CreateSubnet",
                      "ec2:CreateTags",
                      "ec2:CreateVpc",
                      "ec2:GetConsoleOutput",
                      "ec2:RevokeSecurityGroupEgress",
                      "ec2:RevokeSecurityGroupIngress"
                  ],
                  "Resource": "*"
              }
          ]
      }
    • The resource field should limit to the AWS account number and target resource e.g. "Resource": "arn:aws:ec2:*:049876562615:key-pair/*".
    • See also: Example policies for working in the Amazon EC2 console

Basic Setup (AWS)

  1. Add a new AWS Cloud service provider based on your needs. Go to Structure > Cloud service providers and click + Add cloud service provider for AWS Cloud

  2. Enter all required configuration parameters. The system will automatically set up all regions from your AWS account. There are three options for specifying AWS credentials:

    1. Instance credentials - If cloud module is running on an EC2 instance and the EC2 instance has an IAM role attached, you have the option to check Use Instance Credentials. Doing so is secure and does not require Access key ID and Secret access key to be entered into Drupal. Please refer to this AWS tutorial about IAM role and EC2 Instance:

      https://aws.amazon.com/blogs/security/easily-replace-or-attach-an-iam-role-to-an-existing-ec2-instance-by-using-the-ec2-console/

    2. Simple access - Specify Access key ID and Secret access key to access a particular account's EC2 instances.

    3. Assume role - Specify Access key ID, Secret access key and the Assume role section. With this combination, the cloud module can assume the role of another AWS account and access their EC2 instances. To learn more about setting up assume role setup, please read this AWS tutorial:

      https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use_permissions-to-switch.html

  3. Run cron to update your specific Cloud region.

  4. Use the links under Cloud service providers > [Cloud service provider] to manage your Amazon EC2 entities.

  5. Import Images using the tab: Cloud service providers > [Cloud service provider] | Images

    • Click on + Import AWS Cloud image
    • Search for images by AMI name. For example, to import Anaconda images based on Ubuntu, type in anaconda*ubuntu*. Use the AWS Console on aws.amazon.com to search for images to import
  6. Import or Add AWS Cloud key pair. The key pair is used to log into any system you launch. Use the links under the tab: Cloud service providers > [Cloud service provider] | Key pair

    • Use the + Import AWS Cloud key pair button to import an existing key pair. You will be uploading your public key.
    • Use + Add AWS Cloud key pair to have AWS generate a new private key. You will be prompted to download the key after it is created.
  7. Setup Security groups, Network interfaces as needed.

Launching Instance

  1. Create a launch template under Design > Launch template > [Cloud service provider]
  2. After creating a template, change the workflow status to Approved.
  3. Click the Launch tab to launch it.

Permissions

Module Structure

cloud is the heart of modules of the Cloud and Cloud service provider packages.

cloud
`-- modules
    |-- cloud_budget
    |-- cloud_cluster_worker
    |-- cloud_dashboard
    |-- cloud_service_providers
    |   |-- aws_cloud
    |   |-- cloud_cluster
    |   |-- docker
    |   |-- k8s
    |   |-- openstack
    |   |-- terraform
    |   `-- vmware
    |-- gapps
    `-- tools
        |-- k8s_to_s3
        `-- s3_to_k8s

Known Issues

  • When adding a Metrics Server enabled Kubernetes cluster, the metrics importing operation can potentially take a long time to complete. During this process, there might be database corruption if the aws_cloud module is enabled.
  • As a workaround, enable aws_cloud when the server is idle and not processing an Add cloud service provider for Kubernetes operation.

License

Cloud Orchestrator is released under the terms of the GPLv2 license.

Maintainers