mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-05 21:53:04 -06:00
73 lines
2.1 KiB
Go
73 lines
2.1 KiB
Go
package schema
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
// The functions below are the CRUD function types for a Resource.
|
|
//
|
|
// The second parameter is the meta value sent to the resource when
|
|
// different operations are called.
|
|
type CreateFunc func(*ResourceData, interface{}) error
|
|
type ReadFunc func(*ResourceData, interface{}) error
|
|
type UpdateFunc func(*ResourceData, interface{}) error
|
|
type DeleteFunc func(*ResourceData, interface{}) error
|
|
|
|
// Resource represents a thing in Terraform that has a set of configurable
|
|
// attributes and generally also has a lifecycle (create, read, update,
|
|
// delete).
|
|
//
|
|
// The Resource schema is an abstraction that allows provider writers to
|
|
// worry only about CRUD operations while off-loading validation, diff
|
|
// generation, etc. to this higher level library.
|
|
type Resource struct {
|
|
Schema map[string]*Schema
|
|
|
|
Create CreateFunc
|
|
Read ReadFunc
|
|
Update UpdateFunc
|
|
Delete DeleteFunc
|
|
}
|
|
|
|
// Diff returns a diff of this resource and is API compatible with the
|
|
// ResourceProvider interface.
|
|
func (r *Resource) Diff(
|
|
s *terraform.ResourceState,
|
|
c *terraform.ResourceConfig) (*terraform.ResourceDiff, error) {
|
|
return schemaMap(r.Schema).Diff(s, c)
|
|
}
|
|
|
|
// Validate validates the resource configuration against the schema.
|
|
func (r *Resource) Validate(c *terraform.ResourceConfig) ([]string, []error) {
|
|
return schemaMap(r.Schema).Validate(c)
|
|
}
|
|
|
|
// Refresh refreshes the state of the resource.
|
|
func (r *Resource) Refresh(
|
|
s *terraform.ResourceState,
|
|
meta interface{}) (*terraform.ResourceState, error) {
|
|
data, err := schemaMap(r.Schema).Data(s, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = r.Read(data, meta)
|
|
return data.State(), err
|
|
}
|
|
|
|
// InternalValidate should be called to validate the structure
|
|
// of the resource.
|
|
//
|
|
// This should be called in a unit test for any resource to verify
|
|
// before release that a resource is properly configured for use with
|
|
// this library.
|
|
func (r *Resource) InternalValidate() error {
|
|
if r == nil {
|
|
return errors.New("resource is nil")
|
|
}
|
|
|
|
return schemaMap(r.Schema).InternalValidate()
|
|
}
|