float32validator

package
v0.16.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 12, 2024 License: MPL-2.0 Imports: 10 Imported by: 0

Documentation

Overview

Package float32validator provides validators for types.Float32 attributes or function parameters.

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

func All

func All(validators ...validator.Float32) validator.Float32

All returns a validator which ensures that any configured attribute value attribute value validates against all the given validators.

Use of All is only necessary when used in conjunction with Any or AnyWithAllWarnings as the Validators field automatically applies a logical AND.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate this Float32 value must either be:
					//  - 1.0
					//  - At least 2.0, but not 3.0
					float32validator.Any(
						float32validator.OneOf(1.0),
						float32validator.All(
							float32validator.AtLeast(2.0),
							float32validator.NoneOf(3.0),
						),
					),
				},
			},
		},
	}
}
Output:

func AlsoRequires

func AlsoRequires(expressions ...path.Expression) validator.Float32

AlsoRequires checks that a set of path.Expression has a non-null value, if the current attribute also has a non-null value.

This implements the validation logic declaratively within the schema. Refer to [datasourcevalidator.RequiredTogether], [providervalidator.RequiredTogether], or [resourcevalidator.RequiredTogether] for declaring this type of validation outside the schema definition.

Relative path.Expression will be resolved using the attribute being validated.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/path"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Optional: true,
				Validators: []validator.Float32{
					// Validate this attribute must be configured with other_attr.
					float32validator.AlsoRequires(path.Expressions{
						path.MatchRoot("other_attr"),
					}...),
				},
			},
			"other_attr": schema.StringAttribute{
				Optional: true,
			},
		},
	}
}
Output:

func Any

func Any(validators ...validator.Float32) validator.Float32

Any returns a validator which ensures that any configured attribute value passes at least one of the given validators.

To prevent practitioner confusion should non-passing validators have conflicting logic, only warnings from the passing validator are returned. Use AnyWithAllWarnings() to return warnings from non-passing validators as well.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate this Float32 value must either be:
					//  - 1.0
					//  - At least 2.0
					float32validator.Any(
						float32validator.OneOf(1.0),
						float32validator.AtLeast(2.0),
					),
				},
			},
		},
	}
}
Output:

func AnyWithAllWarnings

func AnyWithAllWarnings(validators ...validator.Float32) validator.Float32

AnyWithAllWarnings returns a validator which ensures that any configured attribute value passes at least one of the given validators. This validator returns all warnings, including failed validators.

Use Any() to return warnings only from the passing validator.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate this Float32 value must either be:
					//  - 1.0
					//  - At least 2.0
					float32validator.AnyWithAllWarnings(
						float32validator.OneOf(1.0),
						float32validator.AtLeast(2.0),
					),
				},
			},
		},
	}
}
Output:

func AtLeast

func AtLeast(minVal float32) atLeastValidator

AtLeast returns an AttributeValidator which ensures that any configured attribute or function parameter value:

  • Is a number, which can be represented by a 32-bit floating point.
  • Is greater than or equal to the given minimum.

Null (unconfigured) and unknown (known after apply) values are skipped.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate floating point value must be at least 42.42
					float32validator.AtLeast(42.42),
				},
			},
		},
	}
}
Output:

Example (Function)
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/function"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	_ = function.Definition{
		Parameters: []function.Parameter{
			function.Float32Parameter{
				Name: "example_param",
				Validators: []function.Float32ParameterValidator{
					// Validate floating point value must be at least 42.42
					float32validator.AtLeast(42.42),
				},
			},
		},
	}
}
Output:

func AtLeastOneOf

func AtLeastOneOf(expressions ...path.Expression) validator.Float32

AtLeastOneOf checks that of a set of path.Expression, including the attribute this validator is applied to, at least one has a non-null value.

This implements the validation logic declaratively within the tfsdk.Schema. Refer to [datasourcevalidator.AtLeastOneOf], [providervalidator.AtLeastOneOf], or [resourcevalidator.AtLeastOneOf] for declaring this type of validation outside the schema definition.

Any relative path.Expression will be resolved using the attribute being validated.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/path"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Optional: true,
				Validators: []validator.Float32{
					// Validate at least this attribute or other_attr should be configured.
					float32validator.AtLeastOneOf(path.Expressions{
						path.MatchRoot("other_attr"),
					}...),
				},
			},
			"other_attr": schema.StringAttribute{
				Optional: true,
			},
		},
	}
}
Output:

func AtMost

func AtMost(maxVal float32) atMostValidator

AtMost returns an AttributeValidator which ensures that any configured attribute or function parameter value:

  • Is a number, which can be represented by a 32-bit floating point.
  • Is less than or equal to the given maximum.

Null (unconfigured) and unknown (known after apply) values are skipped.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate floating point value must be at most 42.42
					float32validator.AtMost(42.42),
				},
			},
		},
	}
}
Output:

Example (Function)
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/function"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	_ = function.Definition{
		Parameters: []function.Parameter{
			function.Float32Parameter{
				Name: "example_param",
				Validators: []function.Float32ParameterValidator{
					// Validate floating point value must be at most 42.42
					float32validator.AtMost(42.42),
				},
			},
		},
	}
}
Output:

func Between

func Between(minVal, maxVal float32) betweenValidator

Between returns an AttributeValidator which ensures that any configured attribute or function parameter value:

  • Is a number, which can be represented by a 32-bit floating point.
  • Is greater than or equal to the given minimum and less than or equal to the given maximum.

Null (unconfigured) and unknown (known after apply) values are skipped.

minVal cannot be greater than maxVal. Invalid combinations of minVal and maxVal will result in an implementation error message during validation.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate floating point value must be at least 0.0 and at most 1.0
					float32validator.Between(0.0, 1.0),
				},
			},
		},
	}
}
Output:

Example (Function)
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/function"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	_ = function.Definition{
		Parameters: []function.Parameter{
			function.Float32Parameter{
				Name: "example_param",
				Validators: []function.Float32ParameterValidator{
					// Validate floating point value must be at least 0.0 and at most 1.0
					float32validator.Between(0.0, 1.0),
				},
			},
		},
	}
}
Output:

func ConflictsWith

func ConflictsWith(expressions ...path.Expression) validator.Float32

ConflictsWith checks that a set of path.Expression, including the attribute the validator is applied to, do not have a value simultaneously.

This implements the validation logic declaratively within the schema. Refer to [datasourcevalidator.Conflicting], [providervalidator.Conflicting], or [resourcevalidator.Conflicting] for declaring this type of validation outside the schema definition.

Relative path.Expression will be resolved using the attribute being validated.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/path"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Optional: true,
				Validators: []validator.Float32{
					// Validate this attribute must not be configured with other_attr.
					float32validator.ConflictsWith(path.Expressions{
						path.MatchRoot("other_attr"),
					}...),
				},
			},
			"other_attr": schema.StringAttribute{
				Optional: true,
			},
		},
	}
}
Output:

func ExactlyOneOf

func ExactlyOneOf(expressions ...path.Expression) validator.Float32

ExactlyOneOf checks that of a set of path.Expression, including the attribute the validator is applied to, one and only one attribute has a value. It will also cause a validation error if none are specified.

This implements the validation logic declaratively within the schema. Refer to [datasourcevalidator.ExactlyOneOf], [providervalidator.ExactlyOneOf], or [resourcevalidator.ExactlyOneOf] for declaring this type of validation outside the schema definition.

Relative path.Expression will be resolved using the attribute being validated.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/path"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Optional: true,
				Validators: []validator.Float32{
					// Validate only this attribute or other_attr is configured.
					float32validator.ExactlyOneOf(path.Expressions{
						path.MatchRoot("other_attr"),
					}...),
				},
			},
			"other_attr": schema.StringAttribute{
				Optional: true,
			},
		},
	}
}
Output:

func NoneOf

func NoneOf(values ...float32) noneOfValidator

NoneOf checks that the float32 held in the attribute or function parameter is none of the given `values`.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate floating point value must not be 1.2, 2.4, or 4.8
					float32validator.NoneOf([]float32{1.2, 2.4, 4.8}...),
				},
			},
		},
	}
}
Output:

Example (Function)
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/function"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	_ = function.Definition{
		Parameters: []function.Parameter{
			function.Float32Parameter{
				Name: "example_param",
				Validators: []function.Float32ParameterValidator{
					// Validate floating point value must not be 1.2, 2.4, or 4.8
					float32validator.NoneOf([]float32{1.2, 2.4, 4.8}...),
				},
			},
		},
	}
}
Output:

func OneOf

func OneOf(values ...float32) oneOfValidator

OneOf checks that the float32 held in the attribute or function parameter is one of the given `values`.

Example
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
	"github.com/hashicorp/terraform-plugin-framework/schema/validator"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	// Used within a Schema method of a DataSource, Provider, or Resource
	_ = schema.Schema{
		Attributes: map[string]schema.Attribute{
			"example_attr": schema.Float32Attribute{
				Required: true,
				Validators: []validator.Float32{
					// Validate floating point value must be 1.2, 2.4, or 4.8
					float32validator.OneOf([]float32{1.2, 2.4, 4.8}...),
				},
			},
		},
	}
}
Output:

Example (Function)
package main

import (
	"github.com/hashicorp/terraform-plugin-framework/function"

	"github.com/hashicorp/terraform-plugin-framework-validators/float32validator"
)

func main() {
	_ = function.Definition{
		Parameters: []function.Parameter{
			function.Float32Parameter{
				Name: "example_param",
				Validators: []function.Float32ParameterValidator{
					// Validate floating point value must be 1.2, 2.4, or 4.8
					float32validator.OneOf([]float32{1.2, 2.4, 4.8}...),
				},
			},
		},
	}
}
Output:

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL