0
0
mirror of https://github.com/bpg/terraform-provider-proxmox.git synced 2025-06-30 02:31:10 +00:00
terraform-provider-proxmox/fwprovider/ha/datasource_hagroup.go
Pavel Boldyrev 72f7cb81a8
feat(provider): reliable sequential and random vm_id generation (#1557)
Signed-off-by: Pavel Boldyrev <627562+bpg@users.noreply.github.com>
2024-10-03 20:18:37 -04:00

132 lines
3.9 KiB
Go

/*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
*/
package ha
import (
"context"
"fmt"
"github.com/hashicorp/terraform-plugin-framework/datasource"
"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
"github.com/hashicorp/terraform-plugin-framework/types"
"github.com/bpg/terraform-provider-proxmox/fwprovider/attribute"
"github.com/bpg/terraform-provider-proxmox/fwprovider/config"
hagroups "github.com/bpg/terraform-provider-proxmox/proxmox/cluster/ha/groups"
)
// Ensure the implementation satisfies the expected interfaces.
var (
_ datasource.DataSource = &haGroupDatasource{}
_ datasource.DataSourceWithConfigure = &haGroupDatasource{}
)
// NewHAGroupDataSource is a helper function to simplify the provider implementation.
func NewHAGroupDataSource() datasource.DataSource {
return &haGroupDatasource{}
}
// haGroupDatasource is the data source implementation for full information about
// specific High Availability groups.
type haGroupDatasource struct {
client *hagroups.Client
}
// Metadata returns the data source type name.
func (d *haGroupDatasource) Metadata(
_ context.Context,
req datasource.MetadataRequest,
resp *datasource.MetadataResponse,
) {
resp.TypeName = req.ProviderTypeName + "_hagroup"
}
// Schema returns the schema for the data source.
func (d *haGroupDatasource) Schema(_ context.Context, _ datasource.SchemaRequest, resp *datasource.SchemaResponse) {
resp.Schema = schema.Schema{
Description: "Retrieves information about a specific High Availability group.",
Attributes: map[string]schema.Attribute{
"id": attribute.ID(),
"group": schema.StringAttribute{
Description: "The identifier of the High Availability group to read.",
Required: true,
},
"comment": schema.StringAttribute{
Description: "The comment associated with this group",
Computed: true,
},
"nodes": schema.MapAttribute{
Description: "The member nodes for this group. They are provided as a map, where the keys are the node " +
"names and the values represent their priority: integers for known priorities or `null` for unset " +
"priorities.",
Computed: true,
ElementType: types.Int64Type,
},
"no_failback": schema.BoolAttribute{
Description: "A flag that indicates that failing back to a higher priority node is disabled for this HA group.",
Computed: true,
},
"restricted": schema.BoolAttribute{
Description: "A flag that indicates that other nodes may not be used to run resources associated to this HA group.",
Computed: true,
},
},
}
}
// Configure adds the provider-configured client to the data source.
func (d *haGroupDatasource) Configure(
_ context.Context,
req datasource.ConfigureRequest,
resp *datasource.ConfigureResponse,
) {
if req.ProviderData == nil {
return
}
cfg, ok := req.ProviderData.(config.DataSource)
if !ok {
resp.Diagnostics.AddError(
"Unexpected DataSource Configure Type",
fmt.Sprintf("Expected config.DataSource, got: %T", req.ProviderData),
)
return
}
d.client = cfg.Client.Cluster().HA().Groups()
}
// Read fetches the list of HA groups from the Proxmox cluster then converts it to a list of strings.
func (d *haGroupDatasource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) {
var state GroupModel
resp.Diagnostics.Append(req.Config.Get(ctx, &state)...)
if resp.Diagnostics.HasError() {
return
}
groupID := state.Group.ValueString()
group, err := d.client.Get(ctx, groupID)
if err != nil {
resp.Diagnostics.AddError(
fmt.Sprintf("Unable to read High Availability group '%s'", groupID),
err.Error(),
)
return
}
state.ID = types.StringValue(groupID)
resp.Diagnostics.Append(state.ImportFromAPI(*group)...)
resp.Diagnostics.Append(resp.State.Set(ctx, &state)...)
}