You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							96 lines
						
					
					
						
							3.8 KiB
						
					
					
				
			
		
		
	
	
							96 lines
						
					
					
						
							3.8 KiB
						
					
					
				| package vins
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"github.com/hashicorp/terraform-plugin-framework/diag"
 | |
| 	"github.com/hashicorp/terraform-plugin-framework/types/basetypes"
 | |
| 	"github.com/hashicorp/terraform-plugin-log/tflog"
 | |
| 	"repository.basistech.ru/BASIS/terraform-provider-dynamix/internal/client"
 | |
| 	"repository.basistech.ru/BASIS/terraform-provider-dynamix/internal/service/cloudapi/ic"
 | |
| 	"repository.basistech.ru/BASIS/terraform-provider-dynamix/internal/service/cloudapi/vins/models"
 | |
| )
 | |
| 
 | |
| // resourceVINSInputChecks checks if user provided rg_id, account_id, ext_net_id and gid are valid.
 | |
| // It also checks that either rg_id or account_id is specified.
 | |
| func resourceVINSInputChecks(ctx context.Context, plan *models.ResourceVINSModel, c *client.Client) diag.Diagnostics {
 | |
| 	diags := diag.Diagnostics{}
 | |
| 
 | |
| 	if !plan.RGID.IsUnknown() { // RGID is optional & computed
 | |
| 		rgId := uint64(plan.RGID.ValueInt64())
 | |
| 		tflog.Info(ctx, "resourceVINSInputChecks: exist resource group", 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())
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if !plan.ExtNet.IsNull() { // ExtNet is optional
 | |
| 		var extnetPlan models.ExtNetModel
 | |
| 		tflog.Info(ctx, "resourceVINSInputChecks: new extnet specified", map[string]any{"name": plan.Name.ValueString()})
 | |
| 		diags.Append(plan.ExtNet.As(ctx, &extnetPlan, basetypes.ObjectAsOptions{UnhandledNullAsEmpty: true})...)
 | |
| 		if diags.HasError() {
 | |
| 			tflog.Error(ctx, "resourceVINSInputChecks: cannot populate extnet with plan.ExtNet object element")
 | |
| 			return diags
 | |
| 		}
 | |
| 
 | |
| 		extnetId := int(extnetPlan.ExtNetID.ValueInt64())
 | |
| 		tflog.Info(ctx, "resourceVINSInputChecks: exist ext_net check", map[string]any{"ext_net_id": extnetId})
 | |
| 		err := ic.ExistExtNetInVins(ctx, extnetId, c)
 | |
| 		if err != nil {
 | |
| 			diags.AddError(fmt.Sprintf("Cannot get info about ext net with ID %v", extnetId), err.Error())
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if !plan.AccountID.IsUnknown() { // AccountID is optional & computed
 | |
| 		accountId := uint64(plan.AccountID.ValueInt64())
 | |
| 		tflog.Info(ctx, "resourceVINSInputChecks: exist account check", map[string]any{"account_id": accountId})
 | |
| 		err := ic.ExistAccount(ctx, accountId, c)
 | |
| 		if err != nil {
 | |
| 			diags.AddError(fmt.Sprintf("Cannot get info about account with ID %v", accountId), err.Error())
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if !plan.GID.IsUnknown() { // GID is optional & computed
 | |
| 		gid := uint64(plan.GID.ValueInt64())
 | |
| 		tflog.Info(ctx, "resourceVINSInputChecks: exist gid check", map[string]any{"gid": gid})
 | |
| 		err := ic.ExistGID(ctx, gid, c)
 | |
| 		if err != nil {
 | |
| 			diags.AddError(fmt.Sprintf("Cannot get info about gid with ID %v", gid), err.Error())
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if plan.RGID.IsUnknown() && plan.AccountID.IsUnknown() {
 | |
| 		tflog.Error(ctx, "resourceVINSInputChecks: Error providing rg_id or account_id")
 | |
| 		diags.AddError(
 | |
| 			"Neither rg_id nor account_id were provided",
 | |
| 			fmt.Sprintf("Provided values are rg_id %d, account_id %d", plan.RGID.ValueInt64(), plan.AccountID.ValueInt64()),
 | |
| 		)
 | |
| 	}
 | |
| 
 | |
| 	if !plan.RGID.IsUnknown() && !plan.AccountID.IsUnknown() {
 | |
| 		tflog.Error(ctx, "resourceVINSInputChecks: Error providing rg_id and account_id at the same time")
 | |
| 		diags.AddError(
 | |
| 			"Either rg_id or account_id must be provided",
 | |
| 			fmt.Sprintf("Provided values are rg_id %d, account_id %d", plan.RGID.ValueInt64(), plan.AccountID.ValueInt64()),
 | |
| 		)
 | |
| 	}
 | |
| 
 | |
| 	return diags
 | |
| }
 | |
| 
 | |
| // resourceVINSStaticRouteInputChecks checks if user provided vins_id is valid.
 | |
| func resourceVINSStaticRouteInputChecks(ctx context.Context, plan *models.ResourceVINSStaticRouteModel, c *client.Client) diag.Diagnostics {
 | |
| 	diags := diag.Diagnostics{}
 | |
| 
 | |
| 	vinsId := uint64(plan.VinsID.ValueInt64())
 | |
| 	tflog.Info(ctx, "resourceVINSStaticRouteInputChecks: exist vins", map[string]any{"vins_id": vinsId})
 | |
| 	err := ic.ExistVins(ctx, vinsId, c)
 | |
| 	if err != nil {
 | |
| 		diags.AddError(fmt.Sprintf("Cannot get info about vins with ID %v", vinsId), err.Error())
 | |
| 	}
 | |
| 
 | |
| 	return diags
 | |
| }
 |