terraform-provider-docker/internal/provider/resource_docker_registry_image.go

75 lines
2.6 KiB
Go

package provider
import (
"time"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
)
const (
dockerRegistryImageCreateDefaultTimeout = 20 * time.Minute
dockerRegistryImageUpdateDefaultTimeout = 20 * time.Minute
dockerRegistryImageDeleteDefaultTimeout = 20 * time.Minute
)
func resourceDockerRegistryImage() *schema.Resource {
return &schema.Resource{
Description: "Manages the lifecycle of docker image in a registry. You can upload images to a registry (= `docker push`) and also delete them again",
CreateContext: resourceDockerRegistryImageCreate,
ReadContext: resourceDockerRegistryImageRead,
DeleteContext: resourceDockerRegistryImageDelete,
UpdateContext: resourceDockerRegistryImageUpdate,
Timeouts: &schema.ResourceTimeout{
Create: schema.DefaultTimeout(dockerRegistryImageCreateDefaultTimeout),
Update: schema.DefaultTimeout(dockerRegistryImageUpdateDefaultTimeout),
Delete: schema.DefaultTimeout(dockerRegistryImageDeleteDefaultTimeout),
},
Schema: map[string]*schema.Schema{
"name": {
Type: schema.TypeString,
Description: "The name of the Docker image.",
Required: true,
ForceNew: true,
},
"keep_remotely": {
Type: schema.TypeBool,
Description: "If true, then the Docker image won't be deleted on destroy operation. If this is false, it will delete the image from the docker registry on destroy operation. Defaults to `false`",
Default: false,
Optional: true,
},
"insecure_skip_verify": {
Type: schema.TypeBool,
Description: "If `true`, the verification of TLS certificates of the server/registry is disabled. Defaults to `false`",
Optional: true,
Default: false,
},
"triggers": {
Description: "A map of arbitrary strings that, when changed, will force the `docker_registry_image` resource to be replaced. This can be used to repush a local image",
Type: schema.TypeMap,
Optional: true,
ForceNew: true,
},
"sha256_digest": {
Type: schema.TypeString,
Description: "The sha256 digest of the image.",
Computed: true,
},
"auth_config": AuthConfigSchema,
"build": {
Type: schema.TypeSet,
Description: "Configuration to build an image. Requires the `Use containerd for pulling and storing images` option to be disabled in the Docker Host(https://github.com/kreuzwerker/terraform-provider-docker/issues/534). Please see [docker build command reference](https://docs.docker.com/engine/reference/commandline/build/#options) too.",
Optional: true,
MaxItems: 1,
Elem: buildSchema,
},
},
}
}