Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/minamijoyo/tfschema
A schema inspector for Terraform / OpenTofu providers
https://github.com/minamijoyo/tfschema
go opentofu terraform
Last synced: 7 days ago
JSON representation
A schema inspector for Terraform / OpenTofu providers
- Host: GitHub
- URL: https://github.com/minamijoyo/tfschema
- Owner: minamijoyo
- License: mit
- Created: 2018-01-11T15:39:31.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-10T14:33:31.000Z (5 months ago)
- Last Synced: 2024-12-28T20:07:20.983Z (14 days ago)
- Topics: go, opentofu, terraform
- Language: Go
- Homepage:
- Size: 740 KB
- Stars: 295
- Watchers: 6
- Forks: 15
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome - tfschema - A schema inspector for Terraform providers (Go)
- awesome-opentofu - tfschema - Schema inspector for providers. (Tools / Providers)
- awesome-terraform - tfschema - Schema inspector for Terraform providers. (Tools / Miscellaneous)
- awesome-tf - tfschema - Schema inspector for Terraform providers. (Tools / Community providers)
README
# tfschema
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
[![GitHub release](https://img.shields.io/github/release/minamijoyo/tfschema.svg)](https://github.com/minamijoyo/tfschema/releases/latest)
[![GoDoc](https://godoc.org/github.com/minamijoyo/tfschema/tfschema?status.svg)](https://godoc.org/github.com/minamijoyo/tfschema)A schema inspector for Terraform / OpenTofu providers.
# Features
- Get resource type definitions dynamically from Terraform / OpenTofu providers via go-plugin protocol.
- List available resource types.
- Autocomplete resource types in bash/zsh.
- Open official provider documents quickly by your system web browser.
- Terraform v1.x support (minimum requirements: Terraform >= v0.12)
- OpenTofu v1.6+ support![demo](/images/tfschema-demo.gif)
# Getting Started
```
$ brew install minamijoyo/tfschema/tfschema$ echo 'provider "aws" {}' > main.tf
$ terraform init
``````
$ tfschema resource list aws | grep aws_iam_user
aws_iam_user
aws_iam_user_group_membership
aws_iam_user_login_profile
aws_iam_user_policy
aws_iam_user_policy_attachment
aws_iam_user_ssh_key
``````
$ tfschema resource show aws_iam_user
+----------------------+-------------+----------+----------+----------+-----------+
| ATTRIBUTE | TYPE | REQUIRED | OPTIONAL | COMPUTED | SENSITIVE |
+----------------------+-------------+----------+----------+----------+-----------+
| arn | string | false | false | true | false |
| force_destroy | bool | false | true | false | false |
| id | string | false | true | true | false |
| name | string | true | false | false | false |
| path | string | false | true | false | false |
| permissions_boundary | string | false | true | false | false |
| tags | map(string) | false | true | false | false |
| unique_id | string | false | false | true | false |
+----------------------+-------------+----------+----------+----------+-----------+
```# Install
If you are Mac OSX user:
```
$ brew install minamijoyo/tfschema/tfschema
```or
If you have Go 1.17+ development environment:
```bash
$ git clone https://github.com/minamijoyo/tfschema
$ cd tfschema
$ go install
```or
Download the latest compiled binaries and put it anywhere in your executable path.
https://github.com/minamijoyo/tfschema/releases
# Rules of finding provider's binary
When `terraform init` command is executed, provider's binary is installed under the auto installed directory ( .terraform/providers/``/``/`_` ) by default.
The tfschema can use the same provider's binary as terraform uses, so you can run `tfschema` command in the same directory where you run the `terraform` command
Alternatively, you can set the environment variable `$TFSCHEMA_ROOT_DIR` to be this directory. If `$TFSCHEMA_ROOT_DIR` is not set, it will default to the current directoryThe tfschema finds provider's binary under the following directories.
1. `$TFSCHEMA_ROOT_DIR`
2. same directory as `tfschema` executable
3. user vendor directory ( `$TFSCHEMA_ROOT_DIR`/terraform.d/plugins/`_` )
4. auto installed directory for Terraform v0.14+ ( `$TFSCHEMA_ROOT_DIR`/.terraform/providers/``/``/`_` )
5. auto installed directory for Terraform v0.13 ( `$TFSCHEMA_ROOT_DIR`/.terraform/plugins/``/``/`_` )
6. legacy auto installed directory for Terraform < v0.13 ( `$TFSCHEMA_ROOT_DIR`/.terraform/plugins/`_` )
7. global plugin directory ( $HOME/.terraform.d/plugins )
8. global plugin directory with os and arch ( $HOME/.terraform.d/plugins/`_` )
9. gopath ( $GOPATH/bin )If you are Mac OSX user, `_` is `darwin_amd64`.
The `` is a fully qualified provider name in Terraform 0.13+. (e.g. `registry.terraform.io/hashicorp/aws`)Note that it doesn't have exactly the same behavior of Terraform because of some reasons:
- Support multiple Terraform versions
- Can't import internal packages of Terraform and it's too complicated to support
- For debug# Autocomplete
To enable autocomplete, execute the following command:
```
$ tfschema -install-autocomplete
```The above command adds the following line to your ~/.bashrc and ~/.zshrc:
.bashrc
```bash
complete -C tfschema
```.zshrc
```bash
autoload -U +X bashcompinit && bashcompinit
complete -o nospace -C tfschema
```Check your .bashrc and/or .zshrc and reload it.
# Usage
```
$ tfschema --help
Usage: tfschema [--version] [--help] []Available commands are:
data
provider
resource
``````
$ tfschema resource --help
This command is accessed by using one of the subcommands below.Subcommands:
browse Browse a documentation of resource
list List resource types
show Show a type definition of resource
``````
$ tfschema resource show --help
Usage: tfschema resource show [options] RESOURCE_TYPEOptions:
-format=type Set output format to table or json (default: table)
```
# Contributions
Any feedback and contributions are welcome. Feel free to open an issue and submit a pull request.# Acknowledgments
The tfschema is built on Terraform and its providers. I'm sincerely grateful to those authors.# License
MIT