PacoVK / tapir

A Private Terraform Registry
https://pascal.euhus.dev/tapir/
Apache License 2.0
206 stars 15 forks source link
cloud hacktoberfest hashicorp hashicorp-terraform infrastructure-as-code registry terraform terraform-modules terraform-provider

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

๐Ÿ’ป ๐Ÿ“– ๐Ÿค”