mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-09 23:54:17 -06:00
6c71504073
A "Layer" is a particular service that forms part of the infrastructure for a set of applications. Some layers are application servers and others are pure infrastructure, like MySQL servers or load balancers. Although the AWS API only has one type called "Layer", it actually has a number of different "soft" types that each have slightly different validation rules and extra properties that are packed into the Attributes map. To make the validation rule differences explicit in Terraform, and to make the Terraform structure more closely resemble the OpsWorks UI than its API, we use a separate resource type per layer type, with the common code factored out into a shared struct type.
28 lines
640 B
Go
28 lines
640 B
Go
package aws
|
|
|
|
import (
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
)
|
|
|
|
func resourceAwsOpsworksMysqlLayer() *schema.Resource {
|
|
layerType := &opsworksLayerType{
|
|
TypeName: "db-master",
|
|
DefaultLayerName: "MySQL",
|
|
|
|
Attributes: map[string]*opsworksLayerTypeAttribute{
|
|
"root_password": &opsworksLayerTypeAttribute{
|
|
AttrName: "MysqlRootPassword",
|
|
Type: schema.TypeString,
|
|
WriteOnly: true,
|
|
},
|
|
"root_password_on_all_instances": &opsworksLayerTypeAttribute{
|
|
AttrName: "MysqlRootPasswordUbiquitous",
|
|
Type: schema.TypeBool,
|
|
Default: true,
|
|
},
|
|
},
|
|
}
|
|
|
|
return layerType.SchemaResource()
|
|
}
|