Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/PacoVK/tapir
A Private Terraform Registry
https://github.com/PacoVK/tapir
cloud hacktoberfest hashicorp hashicorp-terraform infrastructure-as-code registry terraform terraform-modules terraform-provider
Last synced: about 1 month ago
JSON representation
A Private Terraform Registry
- Host: GitHub
- URL: https://github.com/PacoVK/tapir
- Owner: PacoVK
- License: apache-2.0
- Created: 2022-11-23T21:16:58.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-23T19:08:28.000Z (about 2 months ago)
- Last Synced: 2024-10-25T01:19:46.438Z (about 2 months ago)
- Topics: cloud, hacktoberfest, hashicorp, hashicorp-terraform, infrastructure-as-code, registry, terraform, terraform-modules, terraform-provider
- Language: Java
- Homepage: https://pascal.euhus.dev/tapir/
- Size: 95.8 MB
- Stars: 199
- Watchers: 4
- Forks: 14
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Changelog: changelog.adoc
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-opentofu - tapir - Private registry for modules and providers with a UI. (Tools / Registry)
- awesome-tf - tapir - Private Terraform Registry. (Self-Hosted Registries / Miscellaneous)
README
# Tapir
### A Private Terraform Registry[![Test](https://github.com/PacoVK/tapir/actions/workflows/build.yml/badge.svg)](https://github.com/PacoVK/tapir/actions/workflows/build.yml)
[![Release](https://github.com/PacoVK/tapir/actions/workflows/deploy.yml/badge.svg)](https://github.com/PacoVK/tapir/actions/workflows/deploy.yml)
[![Docs-deployment](https://github.com/PacoVK/tapir/actions/workflows/pages/pages-build-deployment/badge.svg)](https://github.com/PacoVK/tapir/actions/workflows/pages/pages-build-deployment)![Tapir overview](./docs/images/tapir.gif)
Tapir is the registry you always wanted if you are using Terraform at enterprise scale.
Core values of Tapir is to provide
* visibility
* transparency
* increases adoption rate
* security
* quality for your Terraform modules.## 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.
* Access to Git repos are often designed on team level, no access for others per default
* Search capabilities are very limited, in terms you are searching for specific Terraform modules
* You may not get insights in the codes quality and security measures
* Module versioning is not enforced
* Documentation formats vary or docs are missing at all.
This is where Tapir jumps in.### 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:
* Build providers with the same process and pipeline and make use of [official HashiCorp provider project template](https://github.com/hashicorp/terraform-provider-scaffolding).
* Increase security and enforce providers to be GPG signed. Running `terraform init` will check if SHASUMS are valid before downloading the actual provider binary.
* Help your users to focus on the infrastructure code rather that the setup. Tapir provides ready-to-copy code with
a proper provider config example.## About Tapir
Tapir is an implementation of the [official Terraform registry protocol](https://developer.hashicorp.com/terraform/internals/module-registry-protocol).
You can easily run an instance on your own with the full flexibility and power a central registry has.
* It will provide you a simple, but powerful UI to search for modules and providers that are available
across your organization.
* It implements the official Terraform registry protocols
* modules and providers supported
* It scans the module source code on push, you will have insights about the code quality and security measures
* Tapir integrates [Trivy](https://trivy.dev/) for that purpose
* It generates documentation and stats for the module
* See module dependencies, inputs, outputs and resources that will be generated
* Tapir integrates [terraform-docs](https://terraform-docs.io/) for that purpose
* It provides several storage adapters
* currently S3, AzureBlob and Local
* It provides several database adapters for the data
* currently Dynamodb (default), Elasticsearch, CosmosDb
* It provides a REST-API for custom integrations and further automation
Tapir is build on [Quarkus](https://quarkus.io/) and [ReactJS](https://reactjs.org/). You can run Tapir wherever you can run Docker images.
* If you run Tapir with local storage, it can even be operated in an **air-gaped** environment, with no internet accessApart from the above, [this is what Wikipedia knows about Tapirs](https://en.wikipedia.org/wiki/Tapir).
## 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](./docs/configuration.md#authentication) below.You can run Tapir wherever you can run Docker images.
Images are available on [DockerHub](https://hub.docker.com/r/pacovk/tapir) `pacovk/tapir` and [AWS Elastic Container Registry](https://gallery.ecr.aws/pacovk/tapir) `public.ecr.aws/pacovk/tapir`.
There are samples with Terraform in `examples/`.
* [AWS AppRunner](./examples/aws/apprunner)
* [AWS EKS](./examples/aws/eks)
* [Azure Containers](./examples/azure/containerapps)Other deployment options available are:
* [Helm Chart](https://github.com/PacoVK/tapir-helm)### Configure
Tapir is configured via environment variables. You can learn how to set up Tapir [here](./docs/configuration.md).
### How-to
To see how to use Tapir, please read the [usage docs](./docs/usage.md).
## Troubleshoot
See [troubleshooting docs](./docs/TROUBLESHOOT.md)
## Roadmap
* Add more storage adapter
* GCP
* Add more Database adapter
* Postgresql
* Provide a Github/ Gitlab integration to crawl for additional code metrics and ownership informations## Contribution
If you want to contribute to this project, please read the [contribution guidelines](./CONTRIBUTING.md).
A detailed How-to guide on local development can be found in the [docs](dev/docs/RUNBOOK.md).**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](https://allcontributors.org/docs/en/emoji-key)):
PacoVK
π π π§ π‘ π» π
Andrea Defraia
π‘
Wmxs
π π€
Jonasz Εasut-Balcerzak
π‘ π»
Tim Chaffin
π
Tim Chaffin
π
Tom Beckett
π‘ π»
Oleksandr Kuzminskyi
π
GrzegorzHejman
π
CΓ©dric Braekevelt
π
LoΓ―s Postula
π» π π€