update go.mod and imports

This commit is contained in:
2023-03-17 12:54:34 +03:00
parent f3a1a4c83f
commit 437841c8dd
268 changed files with 4019 additions and 2045 deletions

View File

@@ -2,22 +2,21 @@ package compute
import (
"context"
"errors"
"net/http"
"strconv"
"repos.digitalenergy.online/BASIS/decort-golang-sdk/internal/validators"
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
)
// Request struct for add port forward rule
type PFWAddRequest struct {
// ID of compute instance
// Required: true
ComputeID uint64 `url:"computeId" json:"computeId"`
ComputeID uint64 `url:"computeId" json:"computeId" validate:"required"`
// External start port number for the rule
// Required: true
PublicPortStart uint64 `url:"publicPortStart" json:"publicPortStart"`
PublicPortStart uint64 `url:"publicPortStart" json:"publicPortStart" validate:"required"`
// End port number (inclusive) for the ranged rule
// Required: false
@@ -25,40 +24,21 @@ type PFWAddRequest struct {
// Internal base port number
// Required: true
LocalBasePort uint64 `url:"localBasePort" json:"localBasePort"`
LocalBasePort uint64 `url:"localBasePort" json:"localBasePort" validate:"required"`
// Network protocol
// either "tcp" or "udp"
// Required: true
Proto string `url:"proto" json:"proto"`
}
func (crq PFWAddRequest) validate() error {
if crq.ComputeID == 0 {
return errors.New("validation-error: field ComputeID can not be empty or equal to 0")
}
if crq.PublicPortStart == 0 {
return errors.New("validation-error: field PublicPortStart can not be empty or equal to 0")
}
if crq.LocalBasePort == 0 {
return errors.New("validation-error: field LocalBasePort can not be empty or equal to 0")
}
if crq.Proto == "" {
return errors.New("validation-error: field Proto can not be empty")
}
validator := validators.StringInSlice(crq.Proto, []string{"tcp", "udp"})
if !validator {
return errors.New("validation-error: field Proto can be only tcp or udp")
}
return nil
Proto string `url:"proto" json:"proto" validate:"computeProto"`
}
// PFWAdd add port forward rule
func (c Compute) PFWAdd(ctx context.Context, req PFWAddRequest) (uint64, error) {
err := req.validate()
err := validators.ValidateRequest(req)
if err != nil {
return 0, err
for _, validationError := range validators.GetErrors(err) {
return 0, validators.ValidationError(validationError)
}
}
url := "/cloudapi/compute/pfwAdd"