tapir

Tapir

Contributors Docker Pulls

A Private Terraform Registry

Test Release Docs-deployment

Tapir overview

Tapir is the registry you always wanted if you are using Terraform at enterprise scale. Core values of Tapir is to provide

Feedback

You can send feedback and feature requests via GitHub issues. Either vote existing issues or feel free to raise an issue.

Why?

Modules

Terraform modules are reusable parts of infrastructure code. The most crucial part of re-usability is transparency and visibility. Since Terraform supports Git-based modules there are several disadvantages that come along with this capability.

Providers

If you make use of custom providers, or just want to have them mirrored you need an Artifactory to store the binaries. Additionally, users of the module need to break out the Toolchain and manually setup providers and copy them into the global provider directory. Supporting Terraform providers, Tapir does not help you to get your providers visible, but also keeps the users within the toolchain of Terraform only. That means:

About Tapir

Tapir is an implementation of the official Terraform registry protocol. You can easily run an instance on your own with the full flexibility and power a central registry has.

Apart from the above, this is what Wikipedia knows about Tapirs.

Overview

Deployment

NOTE starting with version 0.6.0 authentication is required. Hence, you need an OIDC IDP to run Tapir. Read more about the authentication below.

You can run Tapir wherever you can run Docker images. Images are available on DockerHub pacovk/tapir and AWS Elastic Container Registry public.ecr.aws/pacovk/tapir. There are samples with Terraform in examples/.

Other deployment options available are:

Configure

Tapir is configured via environment variables. You can learn how to set up Tapir here.

How-to

To see how to use Tapir, please read the usage docs.

Troubleshoot

See troubleshooting docs

Roadmap

Contribution

If you want to contribute to this project, please read the contribution guidelines. A detailed How-to guide on local development can be found in the docs.

Actively searching for contributors.
Feedback is always appreciated :rainbow:
Feel free to open an Issue (Bug- /Feature-Request) or provide a Pull request. :wrench:

Contributors ✨

Thanks go to these wonderful people (emoji key):

PacoVK
PacoVK

πŸ‘€ πŸ“† 🚧 πŸ’‘ πŸ’» πŸ“–
Andrea Defraia
Andrea Defraia

πŸ’‘
Wmxs
Wmxs

πŸ› πŸ€”
Jonasz Łasut-Balcerzak
Jonasz Łasut-Balcerzak

πŸ’‘ πŸ’»
Tim Chaffin
Tim Chaffin

πŸ‘€
Tim Chaffin
Tim Chaffin

πŸ“–
Tom Beckett
Tom Beckett

πŸ’‘ πŸ’»
Oleksandr Kuzminskyi
Oleksandr Kuzminskyi

πŸ›
GrzegorzHejman
GrzegorzHejman

πŸ›
CΓ©dric Braekevelt
CΓ©dric Braekevelt

πŸ›
LoΓ―s Postula
LoΓ―s Postula

πŸ’» πŸ“– πŸ€”