Skip to content

Commit

Permalink
docs: Explicitly call out object parameter attributes are required
Browse files Browse the repository at this point in the history
Reference: #955

This attempts to document the existing behavior of Terraform and the framework with relation to object parameters requiring all object attributes to be explicitly configured by adding an early paragraph about the behavior. The other updates on the page are to continue the overall parameter page consistency of configuration examples being used in the implementation examples later in the pages, so here the `attr3` and `null` value handling is shown in all the examples.

In the future, there may be enhancements which could enable "optional" object attributes at which time this new documentation can be updated in relation to that potential new functionality.
  • Loading branch information
bflad committed Mar 15, 2024
1 parent 6f28bad commit c25211d
Showing 1 changed file with 10 additions and 3 deletions.
13 changes: 10 additions & 3 deletions website/docs/plugin/framework/functions/parameters/object.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,15 @@ description: >-

Object function parameters expect a single structure mapping explicit attribute names to type definitions from a practitioner configuration. Values are accessible in function logic by a Go structure type annotated with `tfsdk` field tags or the [framework object type](/terraform/plugin/framework/handling-data/types/object).

In this Terraform configuration example, a object parameter is set to the mapped values of `attr1` to `"value1"` and `attr2` to `123`:
Configurations must include all object attributes or a configuration error is raised. Configurations explicitly setting object attribute values to `null` will prevent this type of configuration error while leaving that object attribute value unset. The `AllowNullValue` setting does not need to be enabled for object attribute `null` values to work in this manner.

In this Terraform configuration example, a object parameter is set to the mapped values of `attr1` to `"value1"`, `attr2` to `123`, and `attr3` to `null`:

```hcl
provider::example::example({
attr1 = "value1",
attr2 = 123,
attr1 = "value1"
attr2 = 123
attr3 = null
})
```

Expand All @@ -34,6 +37,7 @@ func (f ExampleFunction) Definition(ctx context.Context, req function.Definition
AttributeTypes: map[string]attr.Type{
"attr1": types.StringType,
"attr2": types.Int64Type,
"attr3": types.BoolType,
},
// ... potentially other ObjectParameter fields ...
},
Expand Down Expand Up @@ -92,6 +96,7 @@ func (f ExampleFunction) Definition(ctx context.Context, req function.Definition
AttributeTypes: map[string]attr.Type{
"attr1": types.StringType,
"attr2": types.Int64Type,
"attr3": types.BoolType,
},
},
},
Expand All @@ -102,11 +107,13 @@ func (f ExampleFunction) Run(ctx context.Context, req function.RunRequest, resp
var objectArg struct{
Attr1 *string `tfsdk:"attr1"`
Attr2 *int64 `tfsdk:"attr2"`
Attr3 *bool `tfsdk:"attr3"`
}
// e.g. with AllowNullValues
// var objectArg *struct{
// Attr1 *string `tfsdk:"attr1"`
// Attr2 *int64 `tfsdk:"attr2"`
// Attr3 *bool `tfsdk:"attr3"`
// }
// var objectArg types.Object // e.g. with AllowUnknownValues or AllowNullValues

Expand Down

0 comments on commit c25211d

Please sign in to comment.