dotnet-terraform 1.5.3

dotnet tool install --global dotnet-terraform --version 1.5.3                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local dotnet-terraform --version 1.5.3                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=dotnet-terraform&version=1.5.3                
nuke :add-package dotnet-terraform --version 1.5.3                

NuGet

Terraform as a .NET CLI Tool

Terraform packaged as a .NET CLI tool available for Windows x64, Linux x64, Linux arm64, and MacOS arm64. Only LTS versions will be supported. If any requests to support additional versions are submitted that could change.

Why

I created this project to solve two problems that I was experiencing and I hope this solves the same issues for you. The first issue is related to needing a simple and effective way to install Terraform on a target environment. I don't like my logic tied up in platform specific YAML steps since I can't often run that locally. By wrapping Terraform as a .NET CLI tool, I can ensure that I can easily install Terraform locally. The second benefit is ensuring that I am always using the same version of Terraform that I used to write the infrastructure locally and on the build server. Installing Terraform as a local tool ensures I always have the correct version that a specific project requires.

Getting Started

You can install this project as either a global tool or a local tool. The intention of this project is as use as a local tool while a global install works just as well.

Local Install

First step is to ensure you have a manifest created. This will also need to be checked into source control.

dotnet new tool-manifest

Now install the tool using the version you want.

dotnet install dotnet-terraform --version "*-rc*"

Global Install

The command is:

dotnet install -g dotnet-terraform --version "*-rc*"

Usage

This tool is just a wrapper around Terraform. You can pass the exact commands and arguments and it all should work. The tool command is dotnet-terraform. This ensures that there are no conflicts with Terraform installed by other methods. This tool relies on how the naming conventions work as specified here for global tools and local tools. My advice is to always use the following command style dotnet terraform and you should get the desired behavior you expect.

Examples:

$ dotnet terraform version
Terraform v1.5.0
on linux_amd64

Your version of Terraform is out of date! The latest version
is 1.5.2. You can update by downloading from https://www.terraform.io/downloads.html
$ dotnet terraform fmt --help
Usage: terraform [global options] fmt [options] [target...]

  Rewrites all Terraform configuration files to a canonical format. Both
  configuration files (.tf) and variables files (.tfvars) are updated.
  JSON files (.tf.json or .tfvars.json) are not modified.

  By default, fmt scans the current directory for configuration files. If you
  provide a directory for the target argument, then fmt will scan that
  directory instead. If you provide a file, then fmt will process just that
  file. If you provide a single dash ("-"), then fmt will read from standard
  input (STDIN).

  The content must be in the Terraform language native syntax; JSON is not
  supported.
...

Credits

Terraform for being an awesome tool.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
1.5.3 706 7/15/2023
1.5.2.1 648 7/6/2023
1.5.2 627 6/30/2023
1.5.1.1 586 7/6/2023
1.5.1 648 6/30/2023
1.5.0.1 493 7/6/2023
1.5.0 570 6/30/2023
1.5.0-beta 620 6/30/2023