Skip to content

duplocloud/actions

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Duplo Setup Action

An Action to set up duplocloud cli and the underlying cloud. During this process, duplo discovers the underlying cloud which is either aws, gcp, or azure. Once the cloud is known, the corresponding cli is installed. Finally the action will authenticate with the cloud provider. It provides the following features:

  • Setting up Python.
  • Installing duploctl.
  • when AWS
    • Installing AWS CLI.
    • Running Duplo JIT (Just-In-Time) for AWS.
    • Configuring AWS IAM Credentials.
  • when GCP
    • Installing GCP CLI.
    • Configuring GCP SA Credentials.
  • when Azure
    • Installing Azure CLI.
    • Configuring Azure SCP Credentials.

Inputs

The following input variables can be configured:

Name Description Required Default Value
mask-account-id Mask AWS Account ID in logs false yes
region Overide the cloud region from the default. For gcp this is required. false
account-id Overide the cloud account id from the default. Required when on gcp/azure where this would be the project name or directory name. false
credentials Cloud credentials for Azure or GCP. false
version Duplo version to install. false latest

Usage

AWS Example:

name: Simple AWS Setup
on: 
- push
jobs:
  build:
    runs-on: ubuntu-latest
    env:
      DUPLO_TOKEN: ${{ secrets.DUPLO_TOKEN }}
      DUPLO_HOST: ${{ vars.DUPLO_HOST  }}
      DUPLO_TENANT: ${{ vars.DUPLO_TENANT }}
    steps:
    - name: Duplo Setup
      uses: duplocloud/actions@main

GCP or Azure Example:
The only difference is there is no JIT for GCP or Azure. This means the job needs to have some pre-configured credentials to use for authentication. The name of the account is required for GCP and Azure as well.

steps:
- name: Duplo Setup
  uses: duplocloud/actions@main
  with:
    account-id: ${{ vars.CLOUD_ACCOUNT }}
    credentials: ${{ secrets.CLOUD_CREDENTIALS }}

Authentication

Each underlying cloud has their own unique way of authenticating.

AWS

Using the JIT functionality built into the portal, the action uses retreives an sts session from the duplo portal and uses these credentials to authenticate with the AWS CLI. Magical.

Azure

The action uses the azure/login action to authenticate with Azure. To keep things consistent this action will use the CLOUD_CREDENTIALS secret to authenticate which expects the following format:

{
  "clientId": "<client-id>",
  "clientSecret": "<client-secret>",
  "subscriptionId": "<subscription-id>",
  "tenantId": "<tenant-id>"
}

GCP

The action uses the google-github-actions/setup-gcloud action to authenticate with GCP. To keep things consistent this action will use the CLOUD_CREDENTIALS secret to authenticate which expects the following format:

{
  "type": "service_account",
  "project_id": "<project-id>",
  "private_key_id": "<private-key-id>",
  "private_key": "<private-key>",
  "client_email": "<client-email>",
  "client_id": "<client-id>",
  "auth_uri": "https://accounts.google.com/o/oauth2/auth",
  "token_uri": "https://accounts.google.com/o/oauth2/token",
  "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
  "client_x509_cert_url": "<client-x509-cert-url>"
}

Contained Actions

This repo is a mono repo for a number of useful actions. The main action is the setup action. Once all the tools are installed by running the setup action, the other actions can be used.

This action is used to update the image of a service in Duplo. It is a simple action that takes the service name and the image name as inputs.

A wrapper for the docker build or buildx command. This action is used to build a docker image and push it to a registry.

This action is used to install the necessary dependencies for working with Terraform. It supports caching of Terraform and TFLint plugins to improve performance.

Sets up a Terraform module for use in a GitHub Action.

Runs plan/apply/destroy on a Terraform module.

Import a list resources into a Terraform state file.

Import a list resources into a Terraform state file.

License

The scripts and documentation in this project are released under the MIT License.

References

About

Shared Github Actions for common situations.

Resources

Stars

Watchers

Forks

Packages

No packages published