Terragrunt
Terragrunt is a flexible orchestration tool that allows Infrastructure as Code written in OpenTofu/terragrunt to scale.
🚀 Usage​
Add the following command to your CI configuration file:
fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
fluentci run --wasm terragrunt validate
fluentci run --wasm terragrunt apply
Commands​
| Name | Description | 
|---|---|
| setup | Install terragrunt cli | 
| hclfmt | Recursively find hcl files and rewrite them into a canonical format. | 
| plan | Generate and show an execution plan. | 
| apply | Apply the changes required to reach the desired state. | 
Code Examples​
Add fluentci-pdk crate to your Cargo.toml:
[dependencies]
fluentci-pdk = "0.2.1"
Use the following code to call a module function:
use fluentci_pdk::dag;
// ...
dag().call("https://pkg.fluentci.io/[email protected]?wasm=1", "hclfmt", vec!["-terragrunt-check", "--terragrunt-diff"])?;
dag().call("https://pkg.fluentci.io/[email protected]?wasm=1", "plan", vec![])?;
dag().call("https://pkg.fluentci.io/[email protected]?wasm=1", "apply", vec![])?;
CI/CD pipeline integrations​
The following examples show how to integrate FluentCI with popular CI providers to provision infrastructure using terragrunt:
- Github Actions
 - GitLab CI
 - Circle CI
 - Azure Pipelines
 - AWS CodePipeline
 
ci.yml
name: ci
on:
  push:
    branches:
      - main
jobs:
  tasks:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      - name: Setup Fluent CI
        uses: fluentci-io/setup-fluentci@v5
      - name: check
        run: fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
        env:
          GOOGLE_APPLICATION_CREDENTIALS: ./service-account.json
      - name: plan
        run: fluentci run --wasm terragrunt plan
        env:
          GOOGLE_APPLICATION_CREDENTIALS: ./service-account.json
      - name: apply
        run: fluentci run --wasm terragrunt apply
        env:
          GOOGLE_APPLICATION_CREDENTIALS: ./service-account.json
    
.gitlab-ci.yml
.docker:
  image: denoland/deno:debian-1.42.4
  services:
    - docker:${DOCKER_VERSION}-dind
  variables:
    DOCKER_HOST: tcp://docker:2376
    DOCKER_TLS_VERIFY: "1"
    DOCKER_TLS_CERTDIR: /certs
    DOCKER_CERT_PATH: /certs/client
    DOCKER_DRIVER: overlay2
    DOCKER_VERSION: 20.10.16
    GITLAB_ACCESS_TOKEN: $GITLAB_ACCESS_TOKEN
    GOOGLE_APPLICATION_CREDENTIALS: ./service-account.json
.fluentci:
  extends: .docker
  before_script:
    - apt-get update
    - apt-get install -y curl tar gzip ca-certificates openssl git unzip libncursesw6
    - deno install -A -r https://cli.fluentci.io -n fluentci
    - fluentci --version
    - curl -L https://dl.dagger.io/dagger/install.sh | DAGGER_VERSION=0.12.3 sh
    - mv bin/dagger /usr/local/bin
    - dagger version
check:
  extends: .fluentci
  script:
    - fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
plan:
  extends: .fluentci
  script:
    - fluentci run --wasm terragrunt plan
apply:
  extends: .fluentci
  script:
    - fluentci run --wasm terragrunt apply
.circleci/config.yml
version: 2.1
jobs:
  job:
    steps:
      - checkout
      - run: |
          sudo apt-get update && sudo apt-get install -y curl unzip
          curl -fsSL https://cli.fluentci.io | bash
          fluentci --version
        name: Setup FluentCI
      - run: fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
        name: check
      - run: fluentci run --wasm terragrunt plan
        name: plan
      - run: fluentci run --wasm terragrunt apply
        name: apply
    machine:
      image: ubuntu-2004:2023.07.1
workflows:
  fluentci:
    jobs:
      - job
      
azure-pipelines.yml
trigger:
  - main
pool:
  vmImage: ubuntu-latest
steps:
  - script: |
      curl -fsSL https://cli.fluentci.io | bash
      fluentci --version
      echo "##vso[task.prependpath]${HOME}/.deno/bin
    displayName: Setup FluentCI
  - script: fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
    displayName: check
  - script: fluentci run --wasm terragrunt plan
    displayName: plan
  - script: fluentci run --wasm terragrunt apply
    displayName: apply
    
buildspec.yml
version: 0.2
phases:
  install:
    commands:
      - curl -fsSL https://cli.fluentci.io | bash
      - fluentci --version
  build:
    commands:
      - fluentci run --wasm terragrunt hclfmt --terragrunt-check --terragrunt-diff
      - fluentci run --wasm terragrunt plan
      - fluentci run --wasm terragrunt apply
  post_build:
    commands:
      - echo Build completed on `date`