This commit is contained in:
asteam
2024-07-25 14:33:38 +03:00
commit 6f40af6a5f
946 changed files with 98335 additions and 0 deletions

View File

@@ -0,0 +1,118 @@
package lb
import (
"context"
"fmt"
"github.com/hashicorp/terraform-plugin-framework/diag"
"github.com/hashicorp/terraform-plugin-log/tflog"
decort "repository.basistech.ru/BASIS/decort-golang-sdk"
"repository.basistech.ru/BASIS/terraform-provider-dynamix/internal/service/cloudapi/ic"
"repository.basistech.ru/BASIS/terraform-provider-dynamix/internal/service/cloudapi/lb/models"
)
// resourceLBInputChecks checks if rg_id, extnet_id and vins_id are valid.
func resourceLBInputChecks(ctx context.Context, plan *models.ResourceLBModel, c *decort.DecortClient) diag.Diagnostics {
diags := diag.Diagnostics{}
rgID := uint64(plan.RGID.ValueInt64())
tflog.Info(ctx, "resourceLBInputChecks: exist resource rg", map[string]any{"rg_id": rgID})
err := ic.ExistRG(ctx, rgID, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about rg with ID %v", rgID), err.Error())
}
extNetId := uint64(plan.ExtNetID.ValueInt64())
vinsId := uint64(plan.VINSID.ValueInt64())
tflog.Info(ctx, "resourceLBInputChecks: exist resource extNet", map[string]any{" extnet_id": extNetId})
err = ic.ExistExtNetInLb(ctx, extNetId, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about extNet with ID %v", extNetId), err.Error())
}
tflog.Info(ctx, "resourceLBInputChecks: exist resource VINS", map[string]any{" vins_id": vinsId})
err = ic.ExistVinsInLb(ctx, vinsId, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about VINS with ID %v", vinsId), err.Error())
}
return diags
}
// resourceLBBackendInputChecks checks if lb_id are valid.
func resourceLBBackendInputChecks(ctx context.Context, plan *models.ResourceLBBackendModel, c *decort.DecortClient) diag.Diagnostics {
diags := diag.Diagnostics{}
lbID := uint64(plan.LBID.ValueInt64())
tflog.Info(ctx, "resourceLBBackendInputChecks: exist resource lb", map[string]any{"lb_id": lbID})
err := ic.ExistLB(ctx, lbID, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about lb with ID %v", lbID), err.Error())
}
return diags
}
// resourceLBFrontendInputChecks checks if lb_id and backend_name are valid.
func resourceLBFrontendInputChecks(ctx context.Context, plan *models.ResourceLBFrontendModel, c *decort.DecortClient) diag.Diagnostics {
diags := diag.Diagnostics{}
lbID := uint64(plan.LBID.ValueInt64())
bName := plan.Backend.ValueString()
tflog.Info(ctx, "resourceLBFrontendInputChecks: exist resource lb", map[string]any{"lb_id": lbID})
err := ic.ExistLB(ctx, lbID, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about lb with ID %v", lbID), err.Error())
} else {
tflog.Info(ctx, "resourceLBFrontendInputChecks: exist resource lbBackend", map[string]any{"name": bName})
err = ic.ExistLBBackend(ctx, lbID, bName, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about backend with name %v", bName), err.Error())
}
}
return diags
}
// resourceLBFrontendBindInputChecks checks if lb_id and backend_name are valid.
func resourceLBFrontendBindInputChecks(ctx context.Context, plan *models.ResourceLBFrontendBindModel, c *decort.DecortClient) diag.Diagnostics {
diags := diag.Diagnostics{}
lbID := uint64(plan.LBID.ValueInt64())
fName := plan.Frontend.ValueString()
tflog.Info(ctx, "resourceLBFrontendBindInputChecks: exist resource lb", map[string]any{"lb_id": lbID})
err := ic.ExistLB(ctx, lbID, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about lb with ID %v", lbID), err.Error())
} else {
tflog.Info(ctx, "resourceLBFrontendInputChecks: exist resource lbFrontend", map[string]any{"name": fName})
err = ic.ExistLBFrontend(ctx, lbID, fName, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about frontend with name %v", fName), err.Error())
}
}
return diags
}
// resourceLBBackendServerInputChecks checks if lb_id and backend_name are valid.
func resourceLBBackendServerInputChecks(ctx context.Context, plan *models.ResourceLBBackendServerModel, c *decort.DecortClient) diag.Diagnostics {
diags := diag.Diagnostics{}
lbID := uint64(plan.LBID.ValueInt64())
bName := plan.Backend.ValueString()
tflog.Info(ctx, "resourceLBBackendServerInputChecks: exist resource lb", map[string]any{"lb_id": lbID})
err := ic.ExistLB(ctx, lbID, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about lb with ID %v", lbID), err.Error())
} else {
tflog.Info(ctx, "resourceLBBackendServerInputChecks: exist resource lbBackend", map[string]any{"name": bName})
err = ic.ExistLBBackend(ctx, lbID, bName, c)
if err != nil {
diags.AddError(fmt.Sprintf("Cannot get info about backend with name %v", bName), err.Error())
}
}
return diags
}