Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fluentci-io/opentofu-plugin

CI/CD Plugin for OpenTofu
https://github.com/fluentci-io/opentofu-plugin

cicd infrastructure-as-code opentofu rust wasm webassembly

Last synced: about 1 month ago
JSON representation

CI/CD Plugin for OpenTofu

Awesome Lists containing this project

README

        

# OpenTofu Plugin

[![fluentci pipeline](https://shield.fluentci.io/x/opentofu)](https://pkg.fluentci.io/opentofu)
[![ci](https://github.com/fluentci-io/opentofu-plugin/actions/workflows/ci.yml/badge.svg)](https://github.com/fluentci-io/opentofu-plugin/actions/workflows/ci.yml)

This plugin sets up your CI/CD pipeline with a specific version of [OpenTofu](https://opentofu.org).

## 🚀 Usage

Add the following command to your CI configuration file:

```bash
fluentci run --wasm opentofu setup
```

## Functions

| Name | Description |
| -------- | -------------------------------------------------- |
| setup | Install a specific version of OpenTofu. |
| init | Prepare your working directory for other commands |
| validate | Check whether the configuration is valid |
| plan | Show changes required by the current configuration |
| apply | Create or update infrastructure |
| destroy | Destroy previously-created infrastructure |

## Code Usage

Add `fluentci-pdk` crate to your `Cargo.toml`:

```toml
[dependencies]
fluentci-pdk = "0.2.1"
```

Use the following code to call the plugin:

```rust
use fluentci_pdk::dag;

// ...

dag().call("https://pkg.fluentci.io/[email protected]?wasm=1", "setup", vec!["latest"])?;
```

## 📚 Examples

Github Actions:

```yaml
- name: Setup Fluent CI CLI
uses: fluentci-io/setup-fluentci@v5
with:
wasm: true
plugin: opentofu
args: |
init
validate
plan
apply -auto-approve
```