v1.3.0
This commit is contained in:
@@ -2,7 +2,6 @@ package k8ci
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
@@ -13,11 +12,11 @@ import (
|
||||
type CreateRequest struct {
|
||||
// Name of catalog item
|
||||
// Required: true
|
||||
Name string `url:"name" json:"name"`
|
||||
Name string `url:"name" json:"name" validate:"required"`
|
||||
|
||||
// Version tag
|
||||
// Required: true
|
||||
Version string `url:"version" json:"version"`
|
||||
Version string `url:"version" json:"version" validate:"required"`
|
||||
|
||||
// Optional description
|
||||
// Required: false
|
||||
@@ -25,7 +24,7 @@ type CreateRequest struct {
|
||||
|
||||
// Image ID for master K8S node
|
||||
// Required: true
|
||||
MasterImageID uint64 `url:"masterImageId" json:"masterImageId"`
|
||||
MasterImageID uint64 `url:"masterImageId" json:"masterImageId" validate:"required"`
|
||||
|
||||
// Compute driver
|
||||
// Should be one of:
|
||||
@@ -33,11 +32,11 @@ type CreateRequest struct {
|
||||
// - KVM_PPC
|
||||
// - etc
|
||||
// Required: true
|
||||
MasterDriver string `url:"masterDriver" json:"masterDriver"`
|
||||
MasterDriver string `url:"masterDriver" json:"masterDriver" validate:"driver"`
|
||||
|
||||
// Image ID for worker K8S node
|
||||
// Required: true
|
||||
WorkerImageID uint64 `url:"workerImageId" json:"workerImageId"`
|
||||
WorkerImageID uint64 `url:"workerImageId" json:"workerImageId" validate:"required"`
|
||||
|
||||
// Compute driver
|
||||
// Should be one of
|
||||
@@ -45,11 +44,11 @@ type CreateRequest struct {
|
||||
// - KVM_PPC
|
||||
// - etc
|
||||
// Required: true
|
||||
WorkerDriver string `url:"workerDriver" json:"workerDriver"`
|
||||
WorkerDriver string `url:"workerDriver" json:"workerDriver" validate:"driver"`
|
||||
|
||||
// Image ID for load balancer node
|
||||
// Required: true
|
||||
LBImageID uint64 `url:"lbImageId" json:"lbImageId"`
|
||||
LBImageID uint64 `url:"lbImageId" json:"lbImageId" validate:"required"`
|
||||
|
||||
// List of account IDs, which have access to this item.
|
||||
// If empty, any account has access
|
||||
@@ -65,51 +64,13 @@ type CreateRequest struct {
|
||||
MaxWorkerCount uint64 `url:"maxWorkerCount" json:"maxWorkerCount"`
|
||||
}
|
||||
|
||||
func (krq CreateRequest) validate() error {
|
||||
if krq.Name == "" {
|
||||
return errors.New("validation-error: field Name must be set")
|
||||
}
|
||||
if krq.Version == "" {
|
||||
return errors.New("validation-error: field Version must be set")
|
||||
}
|
||||
if krq.MasterImageID == 0 {
|
||||
return errors.New("validation-error: field MasterImageID must be set")
|
||||
}
|
||||
if krq.MasterDriver == "" {
|
||||
return errors.New("validation-error: field MasterDriver must be set")
|
||||
}
|
||||
if krq.WorkerImageID == 0 {
|
||||
return errors.New("validation-error: field WorkerImageID must be set")
|
||||
}
|
||||
if krq.WorkerDriver == "" {
|
||||
return errors.New("validation-error: field WorkerDriver must be set")
|
||||
}
|
||||
if krq.LBImageID == 0 {
|
||||
return errors.New("validation-error: field LBImageID must be set")
|
||||
}
|
||||
if krq.MaxMasterCount == 0 {
|
||||
return errors.New("validation-error: field MaxMasterCount must be set")
|
||||
}
|
||||
if krq.MaxWorkerCount == 0 {
|
||||
return errors.New("validation-error: field MaxWorkerCount must be set")
|
||||
}
|
||||
validate := validators.StringInSlice(krq.MasterDriver, []string{"KVM_X86", "KVM_PPC"})
|
||||
if !validate {
|
||||
return errors.New("validation-error: field MasterDriver must be one of KVM_X86, KVM_PPC")
|
||||
}
|
||||
validate = validators.StringInSlice(krq.WorkerDriver, []string{"KVM_X86", "KVM_PPC"})
|
||||
if !validate {
|
||||
return errors.New("validation-error: field WorkerDriver must be one of KVM_X86, KVM_PPC")
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// Create creates a new K8CI instance
|
||||
func (k K8CI) Create(ctx context.Context, req CreateRequest) (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 := "/cloudbroker/k8ci/create"
|
||||
|
||||
@@ -2,35 +2,30 @@ package k8ci
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||||
)
|
||||
|
||||
// Request struct for delete K8CI
|
||||
type DeleteRequest struct {
|
||||
// K8CI ID
|
||||
// Required: true
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId"`
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId" validate:"required"`
|
||||
|
||||
// Delete permanently or not
|
||||
// Required: false
|
||||
Permanently bool `url:"permanently,omitempty" json:"permanently,omitempty"`
|
||||
}
|
||||
|
||||
func (krq DeleteRequest) validate() error {
|
||||
if krq.K8CIID == 0 {
|
||||
return errors.New("validation-error: field K8CIID must be set")
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// Delete deletes K8CI by ID
|
||||
func (k K8CI) Delete(ctx context.Context, req DeleteRequest) (bool, error) {
|
||||
err := req.validate()
|
||||
err := validators.ValidateRequest(req)
|
||||
if err != nil {
|
||||
return false, err
|
||||
for _, validationError := range validators.GetErrors(err) {
|
||||
return false, validators.ValidationError(validationError)
|
||||
}
|
||||
}
|
||||
|
||||
url := "/cloudbroker/k8ci/delete"
|
||||
|
||||
@@ -2,31 +2,26 @@ package k8ci
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||||
)
|
||||
|
||||
// Request struct for disable K8CI
|
||||
type DisableRequest struct {
|
||||
// K8CI ID
|
||||
// Required: true
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId"`
|
||||
}
|
||||
|
||||
func (krq DisableRequest) validate() error {
|
||||
if krq.K8CIID == 0 {
|
||||
return errors.New("validation-error: field K8CIID must be set")
|
||||
}
|
||||
|
||||
return nil
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId" validate:"required"`
|
||||
}
|
||||
|
||||
// Disable disables K8CI
|
||||
func (k K8CI) Disable(ctx context.Context, req DisableRequest) (bool, error) {
|
||||
err := req.validate()
|
||||
err := validators.ValidateRequest(req)
|
||||
if err != nil {
|
||||
return false, err
|
||||
for _, validationError := range validators.GetErrors(err) {
|
||||
return false, validators.ValidationError(validationError)
|
||||
}
|
||||
}
|
||||
|
||||
url := "/cloudbroker/k8ci/disable"
|
||||
|
||||
@@ -2,31 +2,26 @@ package k8ci
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||||
)
|
||||
|
||||
// Request struct for enable K8CI
|
||||
type EnableRequest struct {
|
||||
// K8CI ID
|
||||
// Required: true
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId"`
|
||||
}
|
||||
|
||||
func (krq EnableRequest) validate() error {
|
||||
if krq.K8CIID == 0 {
|
||||
return errors.New("validation-error: field K8CIID must be set")
|
||||
}
|
||||
|
||||
return nil
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId" validate:"required"`
|
||||
}
|
||||
|
||||
// Enable enables K8CI
|
||||
func (k K8CI) Enable(ctx context.Context, req EnableRequest) (bool, error) {
|
||||
err := req.validate()
|
||||
err := validators.ValidateRequest(req)
|
||||
if err != nil {
|
||||
return false, err
|
||||
for _, validationError := range validators.GetErrors(err) {
|
||||
return false, validators.ValidationError(validationError)
|
||||
}
|
||||
}
|
||||
|
||||
url := "/cloudbroker/k8ci/enable"
|
||||
|
||||
@@ -3,30 +3,25 @@ package k8ci
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"net/http"
|
||||
|
||||
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||||
)
|
||||
|
||||
// Request struct for get information about K8CI
|
||||
type GetRequest struct {
|
||||
// ID of the K8 catalog item to get
|
||||
// Required: true
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId"`
|
||||
}
|
||||
|
||||
func (krq GetRequest) validate() error {
|
||||
if krq.K8CIID == 0 {
|
||||
return errors.New("validation-error: field K8CIID must be set")
|
||||
}
|
||||
|
||||
return nil
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId" validate:"required"`
|
||||
}
|
||||
|
||||
// Get gets details of the specified K8 catalog item
|
||||
func (k K8CI) Get(ctx context.Context, req GetRequest) (*RecordK8CI, error) {
|
||||
err := req.validate()
|
||||
err := validators.ValidateRequest(req)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
for _, validationError := range validators.GetErrors(err) {
|
||||
return nil, validators.ValidationError(validationError)
|
||||
}
|
||||
}
|
||||
|
||||
url := "/cloudbroker/k8ci/get"
|
||||
|
||||
@@ -2,31 +2,26 @@ package k8ci
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||||
)
|
||||
|
||||
// Request struct for restore K8CI
|
||||
type RestoreRequest struct {
|
||||
// K8CI ID
|
||||
// Required: true
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId"`
|
||||
}
|
||||
|
||||
func (krq RestoreRequest) validate() error {
|
||||
if krq.K8CIID == 0 {
|
||||
return errors.New("validation-error: field K8CIID must be set")
|
||||
}
|
||||
|
||||
return nil
|
||||
K8CIID uint64 `url:"k8ciId" json:"k8ciId" validate:"required"`
|
||||
}
|
||||
|
||||
// Restore restores K8CI
|
||||
func (k K8CI) Restore(ctx context.Context, req RestoreRequest) (bool, error) {
|
||||
err := req.validate()
|
||||
err := validators.ValidateRequest(req)
|
||||
if err != nil {
|
||||
return false, err
|
||||
for _, validationError := range validators.GetErrors(err) {
|
||||
return false, validators.ValidationError(validationError)
|
||||
}
|
||||
}
|
||||
|
||||
url := "/cloudbroker/k8ci/restore"
|
||||
|
||||
Reference in New Issue
Block a user