This image is used for rapid deployment by Walrus, it's close to ghcr.io/opentofu/opentofu, but provides Terraform mirroring ability.
OpenTofu is a painless replacement of Terraform, see https://opentofu.org/manifesto.
This tool is maintained by Seal.
To build specific OpenTofu version with the following script.
$ docker build --build-arg OPENTOFU_VERSION=<VERSION> --tag sealio/opentofu-deployer:dev -f Dockerfile .
The Implied Local Mirror Directories power this mode.
OpenTofu will try all configs below provider_installation
to select the newest Provider version available across them, this causes local mirroring cache failure due to a new remote version.
To caching succeed, OpenTofu Deployer searches the Provider Mirror directory(/usr/share/terraform/providers/plugins
) and construct a proper OpenTofu Client Configuration as below for OpenTofu running.
# find /usr/share/terraform/providers -type d -maxdepth 3 -mindepth 3
provider_installation {
filesystem_mirror {
path = "/usr/share/terraform/providers/plugins"
}
direct {
exclude = [
"registry.terraform.io/hashicorp/kubernetes",
"registry.terraform.io/hashicorp/helm",
"registry.terraform.io/hashicorp/aws",
...
]
}
}
Please use opentofu providers mirror to generate the Provider Mirror directory.
By default, this image hosts the Terraform Providers retrived from the Walrus Catalog.
Generally, when Terraform template declares its Provider version that matches or ranges in the caching versions of Implied Mirroring, the Implied Mirroring works well. But if out of the Version Constraints, the Implied Mirroring will panic.
╷
│ Error: Failed to query available provider packages
│
│ Could not retrieve the list of available versions for provider
At the same time, Implied Mirroring always outputs some annoying warning messages, even if the Provider not be used in the Terraform template.
2023-12-25T14:48:09.013Z [WARN] ignoring file "registry.terraform.io/aliyun/alicloud/1.214.0.json" as possible package for registry.terraform.io/aliyun/alicloud: filename lacks expected prefix "terraform-provider-alicloud_"
...
OpenTofu Deployer has cleaned the non-provider files in the Provider Mirror directory, so the warning messages are not presented.
Fortunately, we can reduce the preparation latency for the first deployment and not worry about the version constraints through network_mirror.
OpenTofu Provider Network Mirror Protocol wants HTTPS access and always verifies the CA available. But for development or private usage, we may need a way to skip insecure(CA) verification.
OpenTofu Deploy detects the TF_CLI_NETWORK_MIRROR_URL
environment variable to construct the following OpenTofu Client Configuration, and allows accessing insecure network mirror server by TF_CLI_NETWORK_MIRROR_INSECURE_SKIP_VERIFY
.
# TF_CLI_NETWORK_MIRROR_URL="https://example.com/v1/providers/"
provider_installation {
network_mirror {
url = "https://example.com/v1/providers/"
}
}
Copyright (c) 2024 Seal, Inc.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at LICENSE file for details.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.