parent
							
								
									f1e0f7abb6
								
							
						
					
					
						commit
						80491ed643
					
				| @ -1,9 +1,131 @@ | |||||||
| ## Version 1.8.3 | ## Version 1.9.0 | ||||||
|  | 
 | ||||||
|  | ### Feature | ||||||
|  | 
 | ||||||
|  | #### account | ||||||
|  | - Delete field RecursiveDelete in DeleteUserRequest in cloudapi/account and cloudbroker/account | ||||||
|  | - Add field UniqPools in UpdateRequest in cloudapi/account | ||||||
|  | - Add field ClearUniqPools in UpdateRequest in cloudbroker/account | ||||||
|  | - Add field SortBy in listFlipGroups in cloudapi/account | ||||||
|  | - Change Ratio field from required to optional in SetCPUAllocationRatioRequest in cloudbroker/compute | ||||||
|  | 
 | ||||||
|  | #### audit | ||||||
|  | - Add endpoint Get in cloudapi/audit | ||||||
|  | - Add endpoint ExportAuditsToFile in cloudbroker/audit | ||||||
|  | - Delete field Apitask in model RecordAudit in cloudbroker/audit | ||||||
|  | 
 | ||||||
|  | #### compute | ||||||
|  | - Add support DPDK network net type in NetAttach endpoints in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Add field Force in CloneRequest in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Change TargetStackID field from required to optional (add default 0 value) in PinToStackRequest in cloudbroker/compute | ||||||
|  | - Change return value type from bool to string in SnapshotDelete in cloudbroker/compute and cloudapi/compute | ||||||
|  | - Add field StatusCheck in MigrateStorageAbortRequest in cloudbroker/compute | ||||||
|  | - Add function SnapshotDeleteAsync in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Add field StackID in ListRequest in cloudbroker/compute | ||||||
|  | - Add field NodeID in model RecordCompute in cloudbroker/compute | ||||||
|  | - Add function SetNetConfig in cloudbroker/compute | ||||||
|  | - Add field MTU in model RecordNetAttach in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Change Mode field from required to optional in DiskMigrateRequest in cloudapi/compute | ||||||
|  | - Add field Chipset in model RecordCompute in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Add field BusNumber in model RecordCompute, ItemComputeDisk, ItemDisk, InfoDisk in cloudapi/compute and cloudbroker/compute | ||||||
|  | - Add field ImageID in ListRequest in cloudbroker/compute | ||||||
|  | - Change Mode field from required to optional in DiskMigrateRequest in cloudbroker/compute | ||||||
|  | - Add field Chipset in ListRequest in cloudbroker/compute | ||||||
|  | - Add endpoints ChangeIP in cloudapi/compute and cloudbroker/compute | ||||||
|  | 
 | ||||||
|  | #### disks | ||||||
|  | - Change drivers field from optional to required in FromPlatformDiskRequest in cloudapi/disks, cloudbroker/disks | ||||||
|  | 
 | ||||||
|  | #### dpdknet | ||||||
|  | - Add endpoints List, Get in cloudapi/dpdk | ||||||
|  | - Add endpoints Create, Delete, Disable Enable, Get, List, Update in cloudbroker/dpdk | ||||||
|  | 
 | ||||||
|  | #### extnet | ||||||
|  | - Change StackId field from required to optional in DeviceMigrateRequest in cloudbroker/extnet | ||||||
|  | 
 | ||||||
|  | #### flipgroup | ||||||
|  | - Change ClientIDs field from []uint64 to []string in ListRequest, cloudapi/flipgroup | ||||||
|  | 
 | ||||||
|  | #### grid | ||||||
|  | - Change PasswordLength field from required to optional (add default 9 value) in SetPasswordPolicyRequest in cloudbroker/grid | ||||||
|  | - Set Default value (true) in fields Digits and Uppercase in SetPasswordPolicyRequest in cloudbroker/grid | ||||||
|  | - Add fields ckey, meta in model RecordGrid in cloudbroker/grid | ||||||
|  | - Change GID field from uint64 to string in ExecuteMaintenanceScriptRequest in cloudbroker/grid | ||||||
|  | - Add endpoints GetSettings and GetSettingsRaw in cloudbroker/grid | ||||||
|  | 
 | ||||||
|  | #### group | ||||||
|  | - Change StackId field from uint64 to string in ListRequest in cloudbroker/group | ||||||
|  | 
 | ||||||
|  | #### image: | ||||||
|  | - Change Drivers field from required to optional in CreateCDROMImageRequest in cloudbroker/image | ||||||
|  | - Add field Enabled in ListRequest in cloudapi/image and cloudbroker/image | ||||||
|  | - Delete field GID in SyncCreateRequest in cloudbroker/image | ||||||
|  | - Delete field Permanently in DeleteRequest in cloudapi/image and cloudbroker/image | ||||||
|  | - Delete field Permanently in DeleteImagesRequest in cloudbroker/image | ||||||
|  | 
 | ||||||
|  | #### k8s | ||||||
|  | - Add fields HighlyAvailableLB, AddressVip, ExtnetOnly, WithLB in model RecordK8S in cloudbroker/k8s and cloudapi/k8s | ||||||
|  | - Change MasterIds field from a slice of string to a slice of integers in DeleteMasterFromGroupRequest in cloudbroker/k8s and cloudapi/k8s | ||||||
|  | - Add field Chipset in WorkerAddRequest, WorkersGroupAddRequest in cloudapi/k8s, cloudbroker/k8s | ||||||
|  | - Add field Chipset in CreateRequest in cloudapi/k8s, cloudbroker/k8s | ||||||
|  | 
 | ||||||
|  | #### kvmx86 | ||||||
|  | - Add support DPDK network interface in Create endpoints in cloudapi/kvmx86 and cloudbroker/kvmx8 | ||||||
|  | - Add field Chipset in CreateRequest, CreateBlankRequest, MassCreateRequest, CreateBlankRequest in cloudapi/kvmx86 and cloudbroker/kvmx86 | ||||||
|  | - Add function MassCreateAsync in cloudbroker/kvmx86 | ||||||
|  | 
 | ||||||
|  | #### lb | ||||||
|  | - Change ExtNetID field from uint64 to int64 in CreateRequest, ItemLBList, RecordLB in cloudapi/lb, cloudbroker/lb | ||||||
|  | - Change ExtNetID, VINSID fields from required to optional in CreateRequest in cloudapi/lb | ||||||
|  | 
 | ||||||
|  | #### node | ||||||
|  | - Add field Force in EnableRequest in cloudbroker/node | ||||||
|  | - Add function EnableAsync in cloudbroker/node | ||||||
|  | 
 | ||||||
|  | #### rg | ||||||
|  | - Add endpoints removeDefNet in cloudapi/rg and cloudbroker/rg | ||||||
|  | - Add field ClearUniqPools in UpdateRequest in cloudbroker/rg and cloudapi/rg | ||||||
|  | - Add field UniqPools in UpdateRequest in cloudapi/rg | ||||||
|  | - Delete field IPCIDR in CreateRequest in cloudbroker/rg | ||||||
|  | 
 | ||||||
|  | #### sep | ||||||
|  | - Add endpoints SharedLockStart and SharedLockStop in cloudbroker/sep | ||||||
|  | 
 | ||||||
|  | #### user | ||||||
|  | - Add field GUID in models ItemAudit in cloudapi/user and cloudbroker/user | ||||||
|  | - Add fields MaxStatusCode and MinStatusCode in GetAuditRequest in cloudapi/user | ||||||
|  | 
 | ||||||
|  | #### vins | ||||||
|  | - Add field Computes in model ListVINS in cloudbroker/vins | ||||||
|  | - Add fields VNFDevId in ListRequest in cloudapi/vins and in ListDeletedRequest in cloudbroker/vins | ||||||
|  | - Add field MTU, LibvirtSettings in model ItemInterface in cloudapi/vins and cloudbroker/vins | ||||||
|  | - Add field BusNumber in model ItemInterface in cloudapi/vins and cloudbroker/vins | ||||||
|  | 
 | ||||||
|  | ### Removed | ||||||
|  | 
 | ||||||
|  | #### common | ||||||
|  | - The reason field has been deleted everywhere | ||||||
|  | 
 | ||||||
|  | #### accounts | ||||||
|  | - The GetConsumption function was removed in cloudapi/account | ||||||
|  | 
 | ||||||
|  | #### grid | ||||||
|  | - The CheckVMs function was removed in cloudbroker/grid | ||||||
|  | - The CreateSystemSpace function was removed in cloudbroker/grid | ||||||
|  | 
 | ||||||
|  | #### image | ||||||
|  | - The Permanently field has been removed from DeleteCDROMImageRequest in cloudbroker/image | ||||||
|  | 
 | ||||||
|  | #### kvmppc | ||||||
|  | - The group has been completely deleted | ||||||
|  | 
 | ||||||
|  | #### sizes | ||||||
|  | - The group has been completely deleted | ||||||
|  | 
 | ||||||
|  | #### user | ||||||
|  | - The StatusCode field has been deleted from GetAuditRequest in cloudapi/user | ||||||
| 
 | 
 | ||||||
| ### Bugfix | ### Bugfix | ||||||
| 
 | 
 | ||||||
| - Change validation conditions in field type in models IPReserveRequest (cloudapi/vins/ip_reserve and cloudbroker/vins/ip_reserve). | #### backup | ||||||
| - Fixed the return value in cloudbroker/sep/AddPool | - Fixed RestoreDisksFromBackupRequest in cloudbroker/backup | ||||||
| - Fixed the InfoDisk model in cloudbroker/disks/models |  | ||||||
| - Change variable types in fields freeIPs in models ItemVINS (cloudapi/account/listVins, cloudbroker/account/listVins, cloudapi/rg/listVins, cloudbroker/rg/listVins, cloudapi/vins/list, cloudapi/vins/listDeleted, cloudbroker/vins/list, cloudbroker/vins/listdeleted) |  | ||||||
| - Change variable types in fields freeIPs in models RecordExtNet (cloudapi/extnet/get, cloudbroker/extnet/get) and ItemExtNet(cloudbroker/extnet/list) |  | ||||||
|  | |||||||
| @ -1,58 +0,0 @@ | |||||||
| package account |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"context" |  | ||||||
| 	"net/http" |  | ||||||
| 
 |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // GetConsumptionRequest struct to download the resources tracking files for an account
 |  | ||||||
| type GetConsumptionRequest struct { |  | ||||||
| 	// ID an account
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	AccountID uint64 `url:"accountId" json:"accountId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Epoch represents the start time
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	Start float64 `url:"start" json:"start" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Epoch represents the end time
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	End float64 `url:"end" json:"end" validate:"required"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // GetConsumption downloads the resources tracking files for an account within a given period
 |  | ||||||
| func (a Account) GetConsumption(ctx context.Context, req GetConsumptionRequest) (string, error) { |  | ||||||
| 	err := validators.ValidateRequest(req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", validators.ValidationErrors(validators.GetErrors(err)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	url := "/cloudapi/account/getConsumption" |  | ||||||
| 
 |  | ||||||
| 	res, err := a.client.DecortApiCall(ctx, http.MethodPost, url, req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return string(res), nil |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // GetConsumptionGet downloads the resources tracking files for an account within a given period
 |  | ||||||
| func (a Account) GetConsumptionGet(ctx context.Context, req GetConsumptionRequest) (string, error) { |  | ||||||
| 	err := validators.ValidateRequest(req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", validators.ValidationErrors(validators.GetErrors(err)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	url := "/cloudapi/account/getConsumption" |  | ||||||
| 
 |  | ||||||
| 	res, err := a.client.DecortApiCall(ctx, http.MethodGet, url, req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return "", err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return string(res), nil |  | ||||||
| } |  | ||||||
| @ -0,0 +1,10 @@ | |||||||
|  | package cloudapi | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/pkg/cloudapi/audit" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // Accessing the Stack method group
 | ||||||
|  | func (ca *CloudAPI) Audit() *audit.Audit { | ||||||
|  | 	return audit.New(ca.client) | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package audit | ||||||
|  | 
 | ||||||
|  | import "repository.basistech.ru/BASIS/decort-golang-sdk/interfaces" | ||||||
|  | 
 | ||||||
|  | // Structure for creating request to audit
 | ||||||
|  | type Audit struct { | ||||||
|  | 	client interfaces.Caller | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Builder for audit endpoint
 | ||||||
|  | func New(client interfaces.Caller) *Audit{ | ||||||
|  | 	return &Audit{ | ||||||
|  | 		client: client, | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -0,0 +1,46 @@ | |||||||
|  | package audit | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"encoding/json" | ||||||
|  | 	"net/http" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // GetRequest struct to get information about account
 | ||||||
|  | type GetRequest struct { | ||||||
|  | 	// Audit GUID
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	AuditGuid string `url:"auditGuid" json:"auditGuid" validate:"required"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Get gets information about audit as a RecordAudit struct
 | ||||||
|  | func (a Audit) Get(ctx context.Context, req GetRequest) (*RecordAudit, error) { | ||||||
|  | 	res, err := a.GetRaw(ctx, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	info := RecordAudit{} | ||||||
|  | 
 | ||||||
|  | 	err = json.Unmarshal(res, &info) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return &info, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // GetRaw gets information about audit as an array of bytes
 | ||||||
|  | func (a Audit) GetRaw(ctx context.Context, req GetRequest) ([]byte, error) { | ||||||
|  | 	err := validators.ValidateRequest(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudapi/audit/get" | ||||||
|  | 
 | ||||||
|  | 	res, err := a.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	return res, err | ||||||
|  | } | ||||||
| @ -0,0 +1,41 @@ | |||||||
|  | package audit | ||||||
|  | 
 | ||||||
|  | // Main info about audit
 | ||||||
|  | type RecordAudit struct { | ||||||
|  | 
 | ||||||
|  | 	// Arguments
 | ||||||
|  | 	Arguments string `json:"args"` | ||||||
|  | 
 | ||||||
|  | 	// Call
 | ||||||
|  | 	Call string `json:"call"` | ||||||
|  | 
 | ||||||
|  | 	// GUID
 | ||||||
|  | 	GUID string `json:"guid"` | ||||||
|  | 
 | ||||||
|  | 	// Kwargs
 | ||||||
|  | 	Kwargs string `json:"kwargs"` | ||||||
|  | 
 | ||||||
|  | 	// RemoteAddr
 | ||||||
|  | 	RemoteAddr string `json:"remote_addr"` | ||||||
|  | 
 | ||||||
|  | 	// Response time
 | ||||||
|  | 	ResponseTime float64 `json:"responsetime"` | ||||||
|  | 
 | ||||||
|  | 	// Result
 | ||||||
|  | 	Result string `json:"result"` | ||||||
|  | 
 | ||||||
|  | 	// Status code
 | ||||||
|  | 	StatusCode uint64 `json:"statuscode"` | ||||||
|  | 
 | ||||||
|  | 	// Tags
 | ||||||
|  | 	Tags string `json:"tags"` | ||||||
|  | 
 | ||||||
|  | 	// Timestamp
 | ||||||
|  | 	Timestamp float64 `json:"timestamp"` | ||||||
|  | 
 | ||||||
|  | 	// TimestampEnd
 | ||||||
|  | 	TimestampEnd float64 `json:"timestampEnd"` | ||||||
|  | 
 | ||||||
|  | 	// User
 | ||||||
|  | 	User string `json:"user"` | ||||||
|  | } | ||||||
| @ -0,0 +1,54 @@ | |||||||
|  | package compute | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"net/http" | ||||||
|  | 	"strconv" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // ChangeIPRequest struct to change IP for network
 | ||||||
|  | type ChangeIPRequest struct { | ||||||
|  | 	// ID of compute instance
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	ComputeID uint64 `url:"computeId" json:"computeId" validate:"required"` | ||||||
|  | 
 | ||||||
|  | 	// Network type
 | ||||||
|  | 	// 'EXTNET' for connect to external network directly
 | ||||||
|  | 	// 'VINS' for connect to ViNS
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	NetType string `url:"netType" json:"netType" validate:"computeNetType"` | ||||||
|  | 
 | ||||||
|  | 	// Network ID for connect to
 | ||||||
|  | 	// For EXTNET - external network ID
 | ||||||
|  | 	// For VINS - VINS ID
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	NetID uint64 `url:"netId" json:"netId" validate:"required"` | ||||||
|  | 
 | ||||||
|  | 	// IP address to which we will change the existing one, it must be from the same subnet
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	IPAddr string `url:"ipAddr" json:"ipAddr" validate:"required"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // ChangeIP change reserved IP for compute instance
 | ||||||
|  | func (c Compute) ChangeIP(ctx context.Context, req ChangeIPRequest) (bool, error) { | ||||||
|  | 	err := validators.ValidateRequest(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudapi/compute/changeIp" | ||||||
|  | 
 | ||||||
|  | 	res, err := c.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	result, err := strconv.ParseBool(string(res)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return result, nil | ||||||
|  | } | ||||||
| @ -0,0 +1,8 @@ | |||||||
|  | package cloudapi | ||||||
|  | 
 | ||||||
|  | import "repository.basistech.ru/BASIS/decort-golang-sdk/pkg/cloudapi/dpdknet" | ||||||
|  | 
 | ||||||
|  | // Accessing the DPDKNet method group
 | ||||||
|  | func (ca *CloudAPI) DPDKNet() *dpdknet.DPDKNet { | ||||||
|  | 	return dpdknet.New(ca.client) | ||||||
|  | } | ||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package dpdknet | ||||||
|  | 
 | ||||||
|  | import "repository.basistech.ru/BASIS/decort-golang-sdk/interfaces" | ||||||
|  | 
 | ||||||
|  | // Structure for creating request to DPDK network
 | ||||||
|  | type DPDKNet struct { | ||||||
|  | 	client interfaces.Caller | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Builder for dpdk endpoints
 | ||||||
|  | func New(client interfaces.Caller) *DPDKNet { | ||||||
|  | 	return &DPDKNet{ | ||||||
|  | 		client, | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -0,0 +1,46 @@ | |||||||
|  | package dpdknet | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"encoding/json" | ||||||
|  | 	"net/http" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // GetRequest struct to get information about DPDK network
 | ||||||
|  | type GetRequest struct { | ||||||
|  | 	// ID of the DPDK network
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	DPDKID uint64 `url:"dpdkId" json:"dpdkId" validate:"required"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Get DPDK network details as a RecordDPDKNet struct
 | ||||||
|  | func (d DPDKNet) Get(ctx context.Context, req GetRequest) (*RecordDPDKNet, error) { | ||||||
|  | 	res, err := d.GetRaw(ctx, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	info := RecordDPDKNet{} | ||||||
|  | 
 | ||||||
|  | 	err = json.Unmarshal(res, &info) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return &info, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // GetRaw gets DPDK network details as an array of bytes
 | ||||||
|  | func (d DPDKNet) GetRaw(ctx context.Context, req GetRequest) ([]byte, error) { | ||||||
|  | 	err := validators.ValidateRequest(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudapi/dpdknet/get" | ||||||
|  | 
 | ||||||
|  | 	res, err := d.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	return res, err | ||||||
|  | } | ||||||
| @ -0,0 +1,79 @@ | |||||||
|  | package dpdknet | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"encoding/json" | ||||||
|  | 	"net/http" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // ListRequest struct to get list of DPDK networks
 | ||||||
|  | type ListRequest struct { | ||||||
|  | 	// Find by id
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	ByID uint64 `url:"by_id,omitempty" json:"by_id,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Find by gid
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	GID uint64 `url:"gid,omitempty" json:"gid,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Find by name
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	Name string `url:"name,omitempty" json:"name,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Find by description
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	Description string `url:"description,omitempty" json:"description,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Find by status
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	Status string `url:"status,omitempty" json:"status,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Find by computeIDs
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	ComputeIDs []uint64 `url:"computeIds,omitempty" json:"computeIds,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Sort by one of supported fields, format +|-(field)
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	SortBy string `url:"sortBy,omitempty" json:"sortBy,omitempty" validate:"omitempty,sortBy"` | ||||||
|  | 
 | ||||||
|  | 	// Page number
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	Page uint64 `url:"page,omitempty" json:"page,omitempty"` | ||||||
|  | 
 | ||||||
|  | 	// Page size
 | ||||||
|  | 	// Required: false
 | ||||||
|  | 	Size uint64 `url:"size,omitempty" json:"size,omitempty"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // List gets list of the created DPDK networks belonging to an account as a ListDPDKNet struct
 | ||||||
|  | func (d DPDKNet) List(ctx context.Context, req ListRequest) (*ListDPDKNet, error) { | ||||||
|  | 
 | ||||||
|  | 	res, err := d.ListRaw(ctx, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	list := ListDPDKNet{} | ||||||
|  | 
 | ||||||
|  | 	err = json.Unmarshal(res, &list) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return &list, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // ListRaw gets list of the created DPDK networks belonging to an account as an array of bytes
 | ||||||
|  | func (d DPDKNet) ListRaw(ctx context.Context, req ListRequest) ([]byte, error) { | ||||||
|  | 
 | ||||||
|  | 	if err := validators.ValidateRequest(req); err != nil { | ||||||
|  | 		return nil, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudapi/dpdknet/list" | ||||||
|  | 
 | ||||||
|  | 	res, err := d.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	return res, err | ||||||
|  | } | ||||||
| @ -0,0 +1,92 @@ | |||||||
|  | package dpdknet | ||||||
|  | 
 | ||||||
|  | // Detailed information about DPDK network
 | ||||||
|  | type RecordDPDKNet struct { | ||||||
|  | 	// List of accounts with access
 | ||||||
|  | 	AccountAccess []uint64 `json:"accountAccess"` | ||||||
|  | 
 | ||||||
|  | 	// Created time
 | ||||||
|  | 	CreatedTime uint64 `json:"createdTime"` | ||||||
|  | 
 | ||||||
|  | 	// Updated time
 | ||||||
|  | 	UpdatedTime uint64 `json:"updatedTime"` | ||||||
|  | 
 | ||||||
|  | 	// Description
 | ||||||
|  | 	Description string `json:"description"` | ||||||
|  | 
 | ||||||
|  | 	// Grid ID
 | ||||||
|  | 	GID uint64 `json:"gid"` | ||||||
|  | 
 | ||||||
|  | 	// Guid ID
 | ||||||
|  | 	GUID uint64 `json:"guid"` | ||||||
|  | 
 | ||||||
|  | 	// ID
 | ||||||
|  | 	ID uint64 `json:"id"` | ||||||
|  | 
 | ||||||
|  | 	// Name
 | ||||||
|  | 	Name string `json:"name"` | ||||||
|  | 
 | ||||||
|  | 	// List of resource groups with access
 | ||||||
|  | 	RGAccess []uint64 `json:"rgAccess"` | ||||||
|  | 
 | ||||||
|  | 	// Status
 | ||||||
|  | 	Status string `json:"status"` | ||||||
|  | 
 | ||||||
|  | 	// OVS bridge
 | ||||||
|  | 	OVSBridge string `json:"ovsBridge"` | ||||||
|  | 
 | ||||||
|  | 	// Vlan ID
 | ||||||
|  | 	VlanID uint64 `json:"vlanId"` | ||||||
|  | 
 | ||||||
|  | 	// Compute IDs
 | ||||||
|  | 	ComputeIDs []uint64 `json:"computeIds"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type ListDPDKNet struct { | ||||||
|  | 	// Data
 | ||||||
|  | 	Data []ItemDPDKNet `json:"data"` | ||||||
|  | 
 | ||||||
|  | 	// Entry count
 | ||||||
|  | 	EntryCount uint64 `json:"entryCount"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type ItemDPDKNet struct { | ||||||
|  | 	// List of accounts with access
 | ||||||
|  | 	AccountAccess []uint64 `json:"accountAccess"` | ||||||
|  | 
 | ||||||
|  | 	// Created time
 | ||||||
|  | 	CreatedTime uint64 `json:"createdTime"` | ||||||
|  | 
 | ||||||
|  | 	// Updated time
 | ||||||
|  | 	UpdatedTime uint64 `json:"updatedTime"` | ||||||
|  | 
 | ||||||
|  | 	// Description
 | ||||||
|  | 	Description string `json:"description"` | ||||||
|  | 
 | ||||||
|  | 	// Grid ID
 | ||||||
|  | 	GID uint64 `json:"gid"` | ||||||
|  | 
 | ||||||
|  | 	// Guid ID
 | ||||||
|  | 	GUID uint64 `json:"guid"` | ||||||
|  | 
 | ||||||
|  | 	// ID
 | ||||||
|  | 	ID uint64 `json:"id"` | ||||||
|  | 
 | ||||||
|  | 	// Name
 | ||||||
|  | 	Name string `json:"name"` | ||||||
|  | 
 | ||||||
|  | 	// List of resource groups with access
 | ||||||
|  | 	RGAccess []uint64 `json:"rgAccess"` | ||||||
|  | 
 | ||||||
|  | 	// Status
 | ||||||
|  | 	Status string `json:"status"` | ||||||
|  | 
 | ||||||
|  | 	// OVS bridge
 | ||||||
|  | 	OVSBridge string `json:"ovsBridge"` | ||||||
|  | 
 | ||||||
|  | 	// Vlan ID
 | ||||||
|  | 	VlanID uint64 `json:"vlanId"` | ||||||
|  | 
 | ||||||
|  | 	// Compute IDs
 | ||||||
|  | 	ComputeIDs []uint64 `json:"computeIds"` | ||||||
|  | } | ||||||
| @ -1,8 +0,0 @@ | |||||||
| package cloudapi |  | ||||||
| 
 |  | ||||||
| import "repository.basistech.ru/BASIS/decort-golang-sdk/pkg/cloudapi/kvmppc" |  | ||||||
| 
 |  | ||||||
| // Accessing the KVMPPC method group
 |  | ||||||
| func (ca *CloudAPI) KVMPPC() *kvmppc.KVMPPC { |  | ||||||
| 	return kvmppc.New(ca.client) |  | ||||||
| } |  | ||||||
| @ -1,202 +0,0 @@ | |||||||
| package kvmppc |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"context" |  | ||||||
| 	"encoding/json" |  | ||||||
| 	"net/http" |  | ||||||
| 	"strconv" |  | ||||||
| 
 |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| type Interface struct { |  | ||||||
| 	// Network type
 |  | ||||||
| 	// Should be one of:
 |  | ||||||
| 	//	- VINS
 |  | ||||||
| 	//	- EXTNET
 |  | ||||||
| 	NetType string `url:"netType" json:"netType" validate:"required,kvmNetType"` |  | ||||||
| 
 |  | ||||||
| 	// Network ID for connect to,
 |  | ||||||
| 	// for EXTNET - external network ID,
 |  | ||||||
| 	// for VINS - VINS ID,
 |  | ||||||
| 	NetID uint64 `url:"netId" json:"netId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// IP address to assign to this VM when connecting to the specified network
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	IPAddr string `url:"ipAddr,omitempty" json:"ipAddr,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // DataDisk detailed struct for DataDisks field in CreateRequest and CreateBlankRequest
 |  | ||||||
| type DataDisk struct { |  | ||||||
| 	// Name for disk
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	DiskName string `url:"diskName" json:"diskName" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Disk size in GB
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	Size uint64 `url:"size" json:"size" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Storage endpoint provider ID
 |  | ||||||
| 	// By default the same with boot disk
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	SepID uint64 `url:"sepId,omitempty" json:"sepId,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Pool name
 |  | ||||||
| 	// By default will be chosen automatically
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Pool string `url:"pool,omitempty" json:"pool,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Optional description
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Description string `url:"desc,omitempty" json:"desc,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Specify image id for create disk from template
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	ImageID uint64 `url:"imageId,omitempty" json:"imageId,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // CreateRequest struct to create KVM PowerPC VM
 |  | ||||||
| type CreateRequest struct { |  | ||||||
| 	// ID of the resource group, which will own this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	RGID uint64 `url:"rgId" json:"rgId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Name of this VM.
 |  | ||||||
| 	// Must be unique among all VMs (including those in DELETED state) in target resource group
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	Name string `url:"name" json:"name" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Number CPUs to allocate to this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	CPU uint64 `url:"cpu" json:"cpu" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Volume of RAM in MB to allocate to this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	RAM uint64 `url:"ram" json:"ram" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// ID of the OS image to base this VM on;
 |  | ||||||
| 	// Could be boot disk image or CD-ROM image
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	ImageID uint64 `url:"imageId" json:"imageId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Size of the boot disk in GB
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	BootDisk uint64 `url:"bootDisk,omitempty" json:"bootDisk,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// ID of SEP to create boot disk on.
 |  | ||||||
| 	// Uses images SEP ID if not set
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	SEPID uint64 `url:"sepId,omitempty" json:"sepId,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Pool to use if sepId is set, can be also empty if needed to be chosen by system
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Pool string `url:"pool,omitempty" json:"pool,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Slice of structs with data disk description. Each disk has parameters: required - diskName, size; optional - sepId, pool, desc and imageId.
 |  | ||||||
| 	// If not specified, compute will be created without disks.
 |  | ||||||
| 	// To create compute without disks, pass initialized empty slice .
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	DataDisks []DataDisk `url:"-" json:"dataDisks,omitempty" validate:"omitempty,dive"` |  | ||||||
| 
 |  | ||||||
| 	// Slice of structs with net interface description.
 |  | ||||||
| 	// If not specified, compute will be created with default interface from RG.
 |  | ||||||
| 	// To create compute without interfaces, pass initialized empty slice .
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Interfaces []Interface `url:"-" json:"interfaces,omitempty" validate:"omitempty,dive"` |  | ||||||
| 
 |  | ||||||
| 	// Input data for cloud-init facility
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Userdata string `url:"userdata,omitempty" json:"userdata,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Text description of this VM
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Description string `url:"desc,omitempty" json:"desc,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Start VM upon success
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Start bool `url:"start" json:"start"` |  | ||||||
| 
 |  | ||||||
| 	// System name
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	IS string `url:"IS,omitempty" json:"IS,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Compute purpose
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	IPAType string `url:"ipaType,omitempty" json:"ipaType,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // GetRAM returns RAM field values
 |  | ||||||
| func (r CreateRequest) GetRAM() map[string]uint64 { |  | ||||||
| 
 |  | ||||||
| 	res := make(map[string]uint64, 1) |  | ||||||
| 
 |  | ||||||
| 	res["RAM"] = r.RAM |  | ||||||
| 
 |  | ||||||
| 	return res |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| type wrapperCreateRequest struct { |  | ||||||
| 	CreateRequest |  | ||||||
| 	Interfaces []string `url:"interfaces,omitempty"` |  | ||||||
| 	DataDisks  []string `url:"dataDisks,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Create creates KVM PowerPC VM based on specified OS image
 |  | ||||||
| func (k KVMPPC) Create(ctx context.Context, req CreateRequest) (uint64, error) { |  | ||||||
| 	err := validators.ValidateRequest(req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, validators.ValidationErrors(validators.GetErrors(err)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var interfaces []string |  | ||||||
| 
 |  | ||||||
| 	if req.Interfaces != nil && len(req.Interfaces) != 0 { |  | ||||||
| 		interfaces = make([]string, 0, len(req.Interfaces)) |  | ||||||
| 
 |  | ||||||
| 		for i := range req.Interfaces { |  | ||||||
| 			b, err := json.Marshal(req.Interfaces[i]) |  | ||||||
| 			if err != nil { |  | ||||||
| 				return 0, err |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			interfaces = append(interfaces, string(b)) |  | ||||||
| 		} |  | ||||||
| 	} else if req.Interfaces != nil && len(req.Interfaces) == 0 { |  | ||||||
| 		interfaces = []string{"[]"} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var dataDisks []string |  | ||||||
| 
 |  | ||||||
| 	if req.DataDisks != nil && len(req.DataDisks) != 0 { |  | ||||||
| 		dataDisks = make([]string, 0, len(req.DataDisks)) |  | ||||||
| 
 |  | ||||||
| 		for i := range req.DataDisks { |  | ||||||
| 			b, err := json.Marshal(req.DataDisks[i]) |  | ||||||
| 			if err != nil { |  | ||||||
| 				return 0, err |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			dataDisks = append(dataDisks, string(b)) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	reqWrapped := wrapperCreateRequest{ |  | ||||||
| 		CreateRequest: req, |  | ||||||
| 		Interfaces:    interfaces, |  | ||||||
| 		DataDisks:     dataDisks, |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	url := "/cloudapi/kvmppc/create" |  | ||||||
| 
 |  | ||||||
| 	res, err := k.client.DecortApiCall(ctx, http.MethodPost, url, reqWrapped) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	result, err := strconv.ParseUint(string(res), 10, 64) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return result, nil |  | ||||||
| } |  | ||||||
| @ -1,135 +0,0 @@ | |||||||
| package kvmppc |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"context" |  | ||||||
| 	"encoding/json" |  | ||||||
| 	"net/http" |  | ||||||
| 	"strconv" |  | ||||||
| 
 |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // CreateBlankRequest struct to create KVM PowerPC VM from scratch
 |  | ||||||
| type CreateBlankRequest struct { |  | ||||||
| 	// ID of the resource group, which will own this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	RGID uint64 `url:"rgId" json:"rgId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Name of this VM.
 |  | ||||||
| 	// Must be unique among all VMs (including those in DELETED state) in target resource group
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	Name string `url:"name" json:"name" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Number CPUs to allocate to this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	CPU uint64 `url:"cpu" json:"cpu" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Volume of RAM in MB to allocate to this VM
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	RAM uint64 `url:"ram" json:"ram" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Size of the boot disk in GB
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	BootDisk uint64 `url:"bootDisk" json:"bootDisk" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// ID of SEP to create boot disk on
 |  | ||||||
| 	// Uses images SEP ID if not set
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	SEPID uint64 `url:"sepId" json:"sepId" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Pool to use if SEP ID is set, can be also empty if needed to be chosen by system
 |  | ||||||
| 	// Required: true
 |  | ||||||
| 	Pool string `url:"pool" json:"pool" validate:"required"` |  | ||||||
| 
 |  | ||||||
| 	// Slice of structs with data disk description. Each disk has parameters: required - diskName, size; optional - sepId, pool, desc and imageId.
 |  | ||||||
| 	// If not specified, compute will be created without disks.
 |  | ||||||
| 	// To create compute without disks, pass initialized empty slice .
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	DataDisks []DataDisk `url:"-" json:"dataDisks,omitempty" validate:"omitempty,dive"` |  | ||||||
| 
 |  | ||||||
| 	// Slice of structs with net interface description.
 |  | ||||||
| 	// If not specified, compute will be created with default interface from RG.
 |  | ||||||
| 	// To create compute without interfaces, pass initialized empty slice .
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Interfaces []Interface `url:"-" json:"interfaces,omitempty" validate:"omitempty,dive"` |  | ||||||
| 
 |  | ||||||
| 	// Text description of this VM
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Description string `url:"desc,omitempty" json:"desc,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // GetRAM returns RAM field values
 |  | ||||||
| func (r CreateBlankRequest) GetRAM() map[string]uint64 { |  | ||||||
| 
 |  | ||||||
| 	res := make(map[string]uint64, 1) |  | ||||||
| 
 |  | ||||||
| 	res["RAM"] = r.RAM |  | ||||||
| 
 |  | ||||||
| 	return res |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| type wrapperCreateBlankRequest struct { |  | ||||||
| 	CreateBlankRequest |  | ||||||
| 	Interfaces []string `url:"interfaces,omitempty"` |  | ||||||
| 	DataDisks  []string `url:"dataDisks,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // CreateBlank creates KVM PowerPC VM from scratch
 |  | ||||||
| func (k KVMPPC) CreateBlank(ctx context.Context, req CreateBlankRequest) (uint64, error) { |  | ||||||
| 	err := validators.ValidateRequest(req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, validators.ValidationErrors(validators.GetErrors(err)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var interfaces []string |  | ||||||
| 
 |  | ||||||
| 	if req.Interfaces != nil && len(req.Interfaces) != 0 { |  | ||||||
| 		interfaces = make([]string, 0, len(req.Interfaces)) |  | ||||||
| 
 |  | ||||||
| 		for i := range req.Interfaces { |  | ||||||
| 			b, err := json.Marshal(req.Interfaces[i]) |  | ||||||
| 			if err != nil { |  | ||||||
| 				return 0, err |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			interfaces = append(interfaces, string(b)) |  | ||||||
| 		} |  | ||||||
| 	} else if req.Interfaces != nil && len(req.Interfaces) == 0 { |  | ||||||
| 		interfaces = []string{"[]"} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var dataDisks []string |  | ||||||
| 
 |  | ||||||
| 	if req.DataDisks != nil && len(req.DataDisks) != 0 { |  | ||||||
| 		dataDisks = make([]string, 0, len(req.DataDisks)) |  | ||||||
| 
 |  | ||||||
| 		for i := range req.DataDisks { |  | ||||||
| 			b, err := json.Marshal(req.DataDisks[i]) |  | ||||||
| 			if err != nil { |  | ||||||
| 				return 0, err |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			dataDisks = append(dataDisks, string(b)) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	reqWrapped := wrapperCreateBlankRequest{ |  | ||||||
| 		CreateBlankRequest: req, |  | ||||||
| 		Interfaces:         interfaces, |  | ||||||
| 		DataDisks:          dataDisks, |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	url := "/cloudapi/kvmppc/createBlank" |  | ||||||
| 
 |  | ||||||
| 	res, err := k.client.DecortApiCall(ctx, http.MethodPost, url, reqWrapped) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	result, err := strconv.ParseUint(string(res), 10, 64) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return 0, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return result, nil |  | ||||||
| } |  | ||||||
| @ -1,18 +0,0 @@ | |||||||
| // API to manage KVM PowerPC compute instances (PPC VMs)
 |  | ||||||
| package kvmppc |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/interfaces" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // Structure for creating request to KVMPPC
 |  | ||||||
| type KVMPPC struct { |  | ||||||
| 	client interfaces.Caller |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Builder for KVMPPC endpoints
 |  | ||||||
| func New(client interfaces.Caller) *KVMPPC { |  | ||||||
| 	return &KVMPPC{ |  | ||||||
| 		client, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @ -0,0 +1,38 @@ | |||||||
|  | package rg | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"net/http" | ||||||
|  | 	"strconv" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // RemoveDefNetRequest struct to remove default network
 | ||||||
|  | type RemoveDefNetRequest struct { | ||||||
|  | 	// Resource group ID
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	RGID uint64 `url:"rgId" json:"rgId" validate:"required"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // RemoveDefNet removes default network from resource group
 | ||||||
|  | func (r RG) RemoveDefNet(ctx context.Context, req RemoveDefNetRequest) (bool, error) { | ||||||
|  | 	err := validators.ValidateRequest(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudapi/rg/removeDefNet" | ||||||
|  | 
 | ||||||
|  | 	res, err := r.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	result, err := strconv.ParseBool(string(res)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return result, nil | ||||||
|  | } | ||||||
| @ -1,10 +0,0 @@ | |||||||
| package cloudapi |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/pkg/cloudapi/sizes" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // Accessing the Sizes method group
 |  | ||||||
| func (ca *CloudAPI) Sizes() *sizes.Sizes { |  | ||||||
| 	return sizes.New(ca.client) |  | ||||||
| } |  | ||||||
| @ -1,44 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| // FilterByID returns ListSizes with specified ID.
 |  | ||||||
| func (ls ListSizes) FilterByID(id uint64) ListSizes { |  | ||||||
| 	predicate := func(is ItemSize) bool { |  | ||||||
| 		return is.ID == id |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return ls.FilterFunc(predicate) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // FilterByName returns ListSizes with specified Name.
 |  | ||||||
| func (ls ListSizes) FilterByName(name string) ListSizes { |  | ||||||
| 	predicate := func(is ItemSize) bool { |  | ||||||
| 		return is.Name == name |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return ls.FilterFunc(predicate) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // FilterFunc allows filtering ListSizes based on a user-specified predicate.
 |  | ||||||
| func (ls ListSizes) FilterFunc(predicate func(ItemSize) bool) ListSizes { |  | ||||||
| 	var result ListSizes |  | ||||||
| 
 |  | ||||||
| 	for _, item := range ls.Data { |  | ||||||
| 		if predicate(item) { |  | ||||||
| 			result.Data = append(result.Data, item) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	result.EntryCount = uint64(len(result.Data)) |  | ||||||
| 
 |  | ||||||
| 	return result |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // FindOne returns first found ItemSize
 |  | ||||||
| // If none was found, returns an empty struct.
 |  | ||||||
| func (ls ListSizes) FindOne() ItemSize { |  | ||||||
| 	if len(ls.Data) == 0 { |  | ||||||
| 		return ItemSize{} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return ls.Data[0] |  | ||||||
| } |  | ||||||
| @ -1,65 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| import "testing" |  | ||||||
| 
 |  | ||||||
| var sizeItems = ListSizes{ |  | ||||||
| 	Data: []ItemSize{ |  | ||||||
| 		{ |  | ||||||
| 			Description: "", |  | ||||||
| 			Disks:       []uint64{}, |  | ||||||
| 			ID:          1, |  | ||||||
| 			Memory:      512, |  | ||||||
| 			Name:        "size_1", |  | ||||||
| 			VCPUs:       2, |  | ||||||
| 		}, |  | ||||||
| 		{ |  | ||||||
| 			Description: "", |  | ||||||
| 			Disks:       []uint64{}, |  | ||||||
| 			ID:          2, |  | ||||||
| 			Memory:      1024, |  | ||||||
| 			Name:        "size_2", |  | ||||||
| 			VCPUs:       4, |  | ||||||
| 		}, |  | ||||||
| 		{ |  | ||||||
| 			Description: "", |  | ||||||
| 			Disks:       []uint64{}, |  | ||||||
| 			ID:          2, |  | ||||||
| 			Memory:      2048, |  | ||||||
| 			Name:        "size_3", |  | ||||||
| 			VCPUs:       6, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	EntryCount: 3, |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestFilterByID(t *testing.T) { |  | ||||||
| 	actual := sizeItems.FilterByID(1).FindOne() |  | ||||||
| 
 |  | ||||||
| 	if actual.ID != 1 { |  | ||||||
| 		t.Fatal("expected ID 1, found: ", actual.ID) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestFilterByName(t *testing.T) { |  | ||||||
| 	actual := sizeItems.FilterByName("size_2").FindOne() |  | ||||||
| 
 |  | ||||||
| 	if actual.Name != "size_2" { |  | ||||||
| 		t.Fatal("expected Name 'size_2', found: ", actual.Name) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func TestFilterFunc(t *testing.T) { |  | ||||||
| 	actual := sizeItems.FilterFunc(func(is ItemSize) bool { |  | ||||||
| 		return is.Memory > 512 |  | ||||||
| 	}) |  | ||||||
| 
 |  | ||||||
| 	if len(actual.Data) != 2 { |  | ||||||
| 		t.Fatal("expected 2 found, actual: ", len(actual.Data)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	for _, item := range actual.Data { |  | ||||||
| 		if item.Memory <= 512 { |  | ||||||
| 			t.Fatal("expected Memory greater than 512, found: ", item.Memory) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @ -1,10 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| // IDs gets array of configured available flavours IDs from ListSizes struct
 |  | ||||||
| func (ls ListSizes) IDs() []uint64 { |  | ||||||
| 	res := make([]uint64, 0, len(ls.Data)) |  | ||||||
| 	for _, s := range ls.Data { |  | ||||||
| 		res = append(res, s.ID) |  | ||||||
| 	} |  | ||||||
| 	return res |  | ||||||
| } |  | ||||||
| @ -1,63 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"context" |  | ||||||
| 	"encoding/json" |  | ||||||
| 	"net/http" |  | ||||||
| 
 |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // ListRequest struct for list of the available flavors
 |  | ||||||
| type ListRequest struct { |  | ||||||
| 	// ID of the cloudspace
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	CloudspaceID uint64 `url:"cloudspaceId,omitempty" json:"cloudspaceId,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Location code for the sizes
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Location string `url:"location,omitempty" json:"location,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Sort by one of supported fields, format +|-(field)
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	SortBy string `url:"sortBy,omitempty" json:"sortBy,omitempty" validate:"omitempty,sortBy"` |  | ||||||
| 
 |  | ||||||
| 	// Page number
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Page uint64 `url:"page,omitempty" json:"page,omitempty"` |  | ||||||
| 
 |  | ||||||
| 	// Page size
 |  | ||||||
| 	// Required: false
 |  | ||||||
| 	Size uint64 `url:"size,omitempty" json:"size,omitempty"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // List gets list of the available flavors as a ListSizes struct, filtering can be based on the user which is doing the request
 |  | ||||||
| func (s Sizes) List(ctx context.Context, req ListRequest) (*ListSizes, error) { |  | ||||||
| 
 |  | ||||||
| 	res, err := s.ListRaw(ctx, req) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	list := &ListSizes{} |  | ||||||
| 
 |  | ||||||
| 	err = json.Unmarshal(res, &list) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return list, nil |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // ListRaw gets list of the available flavors as an array of bytes
 |  | ||||||
| func (s Sizes) ListRaw(ctx context.Context, req ListRequest) ([]byte, error) { |  | ||||||
| 
 |  | ||||||
| 	if err := validators.ValidateRequest(req); err != nil { |  | ||||||
| 		return nil, validators.ValidationErrors(validators.GetErrors(err)) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	url := "/cloudapi/sizes/list" |  | ||||||
| 
 |  | ||||||
| 	res, err := s.client.DecortApiCall(ctx, http.MethodPost, url, req) |  | ||||||
| 	return res, err |  | ||||||
| } |  | ||||||
| @ -1,31 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| // Main onformation about configured available flavors
 |  | ||||||
| type ItemSize struct { |  | ||||||
| 	// Description
 |  | ||||||
| 	Description string `json:"desc"` |  | ||||||
| 
 |  | ||||||
| 	// List of disk IDs
 |  | ||||||
| 	Disks []uint64 `json:"disks"` |  | ||||||
| 
 |  | ||||||
| 	// ID
 |  | ||||||
| 	ID uint64 `json:"id"` |  | ||||||
| 
 |  | ||||||
| 	// Memory
 |  | ||||||
| 	Memory uint64 `json:"memory"` |  | ||||||
| 
 |  | ||||||
| 	// Name
 |  | ||||||
| 	Name string `json:"name"` |  | ||||||
| 
 |  | ||||||
| 	// VCPUs
 |  | ||||||
| 	VCPUs uint64 `json:"vcpus"` |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // List of configured available flavors
 |  | ||||||
| type ListSizes struct { |  | ||||||
| 	// Data
 |  | ||||||
| 	Data []ItemSize `json:"data"` |  | ||||||
| 
 |  | ||||||
| 	// Entry count
 |  | ||||||
| 	EntryCount uint64 `json:"entryCount"` |  | ||||||
| } |  | ||||||
| @ -1,43 +0,0 @@ | |||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"encoding/json" |  | ||||||
| 
 |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/serialization" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // Serialize returns JSON-serialized []byte. Used as a wrapper over json.Marshal and json.MarshalIndent functions.
 |  | ||||||
| //
 |  | ||||||
| // In order to serialize with indent make sure to follow these guidelines:
 |  | ||||||
| //   - First argument -> prefix
 |  | ||||||
| //   - Second argument -> indent
 |  | ||||||
| func (ls ListSizes) Serialize(params ...string) (serialization.Serialized, error) { |  | ||||||
| 	if len(ls.Data) == 0 { |  | ||||||
| 		return []byte{}, nil |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if len(params) > 1 { |  | ||||||
| 		prefix := params[0] |  | ||||||
| 		indent := params[1] |  | ||||||
| 
 |  | ||||||
| 		return json.MarshalIndent(ls, prefix, indent) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return json.Marshal(ls) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Serialize returns JSON-serialized []byte. Used as a wrapper over json.Marshal and json.MarshalIndent functions.
 |  | ||||||
| //
 |  | ||||||
| // In order to serialize with indent make sure to follow these guidelines:
 |  | ||||||
| //   - First argument -> prefix
 |  | ||||||
| //   - Second argument -> indent
 |  | ||||||
| func (is ItemSize) Serialize(params ...string) (serialization.Serialized, error) { |  | ||||||
| 	if len(params) > 1 { |  | ||||||
| 		prefix := params[0] |  | ||||||
| 		indent := params[1] |  | ||||||
| 
 |  | ||||||
| 		return json.MarshalIndent(is, prefix, indent) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return json.Marshal(is) |  | ||||||
| } |  | ||||||
| @ -1,19 +0,0 @@ | |||||||
| // Lists all the configured flavors available.
 |  | ||||||
| // A flavor is a combination of amount of compute capacity(CU) and disk capacity(GB).
 |  | ||||||
| package sizes |  | ||||||
| 
 |  | ||||||
| import ( |  | ||||||
| 	"repository.basistech.ru/BASIS/decort-golang-sdk/interfaces" |  | ||||||
| ) |  | ||||||
| 
 |  | ||||||
| // Structure for creatig request to sizes
 |  | ||||||
| type Sizes struct { |  | ||||||
| 	client interfaces.Caller |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Builder for sizes endpoints
 |  | ||||||
| func New(client interfaces.Caller) *Sizes { |  | ||||||
| 	return &Sizes{ |  | ||||||
| 		client, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @ -0,0 +1,18 @@ | |||||||
|  | package audit | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"net/http" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // ExportAuditsToFile Get audits in csv file, return []byte which should be written to a file *tar.gz
 | ||||||
|  | func (a Audit) ExportAuditsToFile(ctx context.Context) ([]byte, error) { | ||||||
|  | 	url := "/cloudbroker/audit/exportAuditsToFile" | ||||||
|  | 
 | ||||||
|  | 	res, err := a.client.DecortApiCall(ctx, http.MethodPost, url, nil) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return res, nil | ||||||
|  | } | ||||||
| @ -0,0 +1,54 @@ | |||||||
|  | package compute | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"net/http" | ||||||
|  | 	"strconv" | ||||||
|  | 
 | ||||||
|  | 	"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // ChangeIPRequest struct to change IP for network
 | ||||||
|  | type ChangeIPRequest struct { | ||||||
|  | 	// ID of compute instance
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	ComputeID uint64 `url:"computeId" json:"computeId" validate:"required"` | ||||||
|  | 
 | ||||||
|  | 	// Network type
 | ||||||
|  | 	// 'EXTNET' for connect to external network directly
 | ||||||
|  | 	// 'VINS' for connect to ViNS
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	NetType string `url:"netType" json:"netType" validate:"computeNetType"` | ||||||
|  | 
 | ||||||
|  | 	// Network ID for connect to
 | ||||||
|  | 	// For EXTNET - external network ID
 | ||||||
|  | 	// For VINS - VINS ID
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	NetID uint64 `url:"netId" json:"netId" validate:"required"` | ||||||
|  | 
 | ||||||
|  | 	// IP address to which we will change the existing one, it must be from the same subnet
 | ||||||
|  | 	// Required: true
 | ||||||
|  | 	IPAddr string `url:"ipAddr" json:"ipAddr" validate:"required"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // ChangeIP change reserved IP for compute instance
 | ||||||
|  | func (c Compute) ChangeIP(ctx context.Context, req ChangeIPRequest) (bool, error) { | ||||||
|  | 	err := validators.ValidateRequest(req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, validators.ValidationErrors(validators.GetErrors(err)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	url := "/cloudbroker/compute/changeIp" | ||||||
|  | 
 | ||||||
|  | 	res, err := c.client.DecortApiCall(ctx, http.MethodPost, url, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	result, err := strconv.ParseBool(string(res)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return result, nil | ||||||
|  | } | ||||||
Some files were not shown because too many files have changed in this diff Show More
					Loading…
					
					
				
		Reference in new issue