diff --git a/CHANGELOG.md b/CHANGELOG.md index 47bc84e..61c4b31 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,53 +1,50 @@ -## Version 13.4.0 +## Version 13.5.0 Методы `Audits` в cloudapi/compute, cloudbroker/compute, cloudapi/account, cloudbroker/account, cloudapi/vins, cloudbroker/vins, cloudapi/rg и cloudbroker/rg стали deprecated и в следующих версиях будут удалены, вместо них необходимо использовать метод `List` в cloudapi/audit и cloudbroker/audit с соответствующими фильтрами Метод `ListNodes` в cloudbroker/image стал deprecated и в следующих версиях будет удалён -Методы `AccessGrant`, `AccessGrantToPool`, `AccessRevoke`, `AccessRevokeToPool` в cloudbroker/sep стали deprecated и в следующих версиях будут удалены -Методы `ComputeCISet`, `ComputeCIUnset`, `GetAudits` в cloudbroker/computeGetAudits и `GetAudits` в cloudbroker/compute стали deprecated и будут удалены в следующих версиях +Методы `AccessGrant`, `AccessGrantToPool`, `AccessRevoke`, `AccessRevokeToPool` в cloudbroker/sep стали deprecated и в следующих версиях будут удалены +Методы `ComputeCISet`, `ComputeCIUnset`, `GetAudits` в cloudbroker/computeGetAudits и `GetAudits` в cloudbroker/compute стали deprecated и будут удалены в следующих версиях +Методы `ComputeCISet`, `ComputeCIUnset` в cloudbroker/image стали deprecated и будут удалены в следующих версиях Все методы группы `.SDN()` находятся в альфа-версии. ### Добавлено -#### compute -| Идентификатор
задачи | Описание | -| --- | --- | -| BGOS-732 | Опциональное поле `NetMask` в структуру запроса `NetAttachRequest` в cloudapi/compute | -| BGOS-727 | Опциональное поле `Cache` в структуру запроса `DiskAddRequest` в cloudapi/compute и в cloudbroker/compute | -| BGOS-727 | Поле `Cache` в структуры ответа `ItemComputeDisk` в cloudapi/compute и в `ItemDisk` в cloudbroker/compute | - #### disks | Идентификатор
задачи | Описание | | --- | --- | -| BGOS-725 | Структура запроса `UpdateRequest`, метод `Update` в cloudbroker/disks | -| BGOS-725 | Опциональное поле `Cache` в структуру запроса `CreateRequest` в cloudapi/disks и в cloudbroker/disks | -| BGOS-725 | Поле `Cache` в структуру ответа `InfoDisk` в cloudbroker/disks | -| BGOS-725 | Поле `Cache` в структуры ответа `RecordDisk`,`ItemDisk` в cloudapi/disks | +| BGOS-735 | Вычисляемое поле `Cache` в структуры ответа `ItemDiskUnattached` в cloudapi/disks и в cloudbroker/disks | -#### kvmx86 +#### node | Идентификатор
задачи | Описание | | --- | --- | -| BGOS-727 | Опциональное поле `BootDiskCache` в структуры запроса `CreateRequest`, `CreateBlankRequest` в cloudapi/kvmx86 и в cloudbroker/kvmx86 | -| BGOS-727 | Опциональное поле `BootDiskCache` в структуру запроса `MassCreateRequest` в cloudbroker/kvmx86 | +| BGOS-738 | Структура запроса `AutoStartRequest`, метод `AutoStart` в cloudbroker/node | +| BGOS-738 | Опциональное поле `AutoStart` в структуру запроса `MaintenanceRequest` в cloudbroker/node | +| BGOS-738 | Вычисляемые поля `AutoStart`, `AutoStartCount` в структуры ответов `ItemNode` и `RecordNode` в cloudbroker/node | +| BGOS-743 | Структура запроса `NodeAutoStartRequest`, метод `NodeAutoStart` в cloudbroker/zone | + +#### zone +| Идентификатор
задачи | Описание | +| --- | --- | +| BGOS-737 | Опциональное поле `AutoStart` в структуру запроса `UpdateRequest` в cloudbroker/zone | +| BGOS-737 | Вычисляемое поле `AutoStart` в структуры ответа `RecordZone` в cloudapi/zone и в cloudbroker/zone | ### Изменено +#### sep +| Идентификатор
задачи | Описание | +| --- | --- | +| BGOS-740 | Тип поля `Force` с обязательного на опциональный в структуре запроса `DelConsumerNodesRequest` в cloudbroker/sep | + +### Удалено + #### bservice | Идентификатор
задачи | Описание | | --- | --- | -| BGOS-728 | Тип полей `Chipset` и `Mode` с обязательного на опциональный в структуре запроса `GroupResizeRequest` в cloudapi/bservice и в cloudbroker/bservice | +| BGOS-739 | Обязательное поле `Driver` в структурах запроса `GroupAddRequest` в cloudapi/bservice и в cloudbroker/bservice | -#### lb +#### flipgroup | Идентификатор
задачи | Описание | | --- | --- | -| BGOS-733 | Тип поля `Start` с обязательного на опциональный в структуре запроса `CreateRequest`в cloudapi/lb и в cloudbroker/lb | - -#### trunk -| Идентификатор
задачи | Описание | -| --- | --- | -| BGOS-730 | Тип полей `Name` и `TrunkTags` с обязательного на опциональный в структуре запроса `UpdateRequest` в cloudbroker/trunk | - -#### user -| Идентификатор
задачи | Описание | -| --- | --- | -| BGOS-729 | Тип поля `Limit` с обязательного на опциональный в структуре запроса `GetMatchingUsernamesRequest` в cloudbroker/user | \ No newline at end of file +| BGOS-742 | Опциональное поле `RGID` из структуры запроса `ListRequest` в cloudapi/flipgroup и в cloudbroker/flipgroup | +| BGOS-742 | Вычисляемые поля `RGName` и `RGID` из структуры ответа `RecordFLIPGroup` в cloudapi/flipgroup и в cloudbroker/flipgroup | diff --git a/pkg/cloudapi/bservice/group_add.go b/pkg/cloudapi/bservice/group_add.go index 48adb3f..940f4d4 100644 --- a/pkg/cloudapi/bservice/group_add.go +++ b/pkg/cloudapi/bservice/group_add.go @@ -38,10 +38,6 @@ type GroupAddRequest struct { // Required: true ImageID uint64 `url:"imageId" json:"imageId" validate:"required"` - // Compute driver like a KVM_X86, etc. - // Required: true - Driver string `url:"driver" json:"driver" validate:"required"` - // Storage endpoint provider ID // Required: false SEPID uint64 `url:"sepId,omitempty" json:"sepId,omitempty"` diff --git a/pkg/cloudapi/disks/models.go b/pkg/cloudapi/disks/models.go index 430f414..5218173 100644 --- a/pkg/cloudapi/disks/models.go +++ b/pkg/cloudapi/disks/models.go @@ -163,6 +163,9 @@ type ItemDiskUnattached struct { // Boot Partition BootPartition uint64 `json:"bootPartition"` + // Cache + Cache string `json:"cache"` + // Created time CreatedTime uint64 `json:"createdTime"` diff --git a/pkg/cloudapi/flipgroup/list.go b/pkg/cloudapi/flipgroup/list.go index 3be8d8f..27238a9 100644 --- a/pkg/cloudapi/flipgroup/list.go +++ b/pkg/cloudapi/flipgroup/list.go @@ -34,10 +34,6 @@ type ListRequest struct { // Required: false AccountId uint64 `url:"accountId,omitempty" json:"accountId,omitempty"` - // Find by resource group ID - // Required: false - RGID uint64 `url:"rgId,omitempty" json:"rgId,omitempty"` - // Find by id // Required: false ByID uint64 `url:"by_id,omitempty" json:"by_id,omitempty"` diff --git a/pkg/cloudapi/flipgroup/models.go b/pkg/cloudapi/flipgroup/models.go index 2d718da..c7f130d 100644 --- a/pkg/cloudapi/flipgroup/models.go +++ b/pkg/cloudapi/flipgroup/models.go @@ -85,12 +85,6 @@ type RecordFLIPGroup struct { // Network Network string `json:"network"` - // Resource group ID - RGID uint64 `json:"rgId"` - - // Resource group name - RGName string `json:"rgName"` - // Status Status string `json:"status"` diff --git a/pkg/cloudapi/zone/models.go b/pkg/cloudapi/zone/models.go index 110f9f9..3c22c6b 100644 --- a/pkg/cloudapi/zone/models.go +++ b/pkg/cloudapi/zone/models.go @@ -10,6 +10,9 @@ type ListZones struct { // Detailed information about the zone record type RecordZone struct { + // If true, all nodes belonging to the given zone will be marked for autostart + AutoStart bool `json:"autostart"` + // ID ID uint64 `json:"id"` diff --git a/pkg/cloudbroker/bservice/group_add.go b/pkg/cloudbroker/bservice/group_add.go index f4390b5..a6dcc27 100644 --- a/pkg/cloudbroker/bservice/group_add.go +++ b/pkg/cloudbroker/bservice/group_add.go @@ -38,10 +38,6 @@ type GroupAddRequest struct { // Required: true ImageID uint64 `url:"imageId" json:"imageId" validate:"required"` - // Compute driver like a KVM_X86, etc. - // Required: true - Driver string `url:"driver" json:"driver" validate:"required"` - // Storage endpoint provider ID // Required: false SEPID uint64 `url:"sepId,omitempty" json:"sepId,omitempty"` diff --git a/pkg/cloudbroker/flipgroup/list.go b/pkg/cloudbroker/flipgroup/list.go index 7632f33..60d0ed0 100644 --- a/pkg/cloudbroker/flipgroup/list.go +++ b/pkg/cloudbroker/flipgroup/list.go @@ -34,10 +34,6 @@ type ListRequest struct { // Required: false AccountId uint64 `url:"accountId,omitempty" json:"accountId,omitempty"` - // Find by resource group ID - // Required: false - RGID uint64 `url:"rgId,omitempty" json:"rgId,omitempty"` - // Find by id // Required: false ByID uint64 `url:"by_id,omitempty" json:"by_id,omitempty"` diff --git a/pkg/cloudbroker/flipgroup/models.go b/pkg/cloudbroker/flipgroup/models.go index 904536c..c7f130d 100644 --- a/pkg/cloudbroker/flipgroup/models.go +++ b/pkg/cloudbroker/flipgroup/models.go @@ -11,7 +11,7 @@ type RecordFLIPGroupCreated struct { // IP IP string `json:"ip"` - // Name + // Name Name string `json:"name"` // Network mask @@ -85,12 +85,6 @@ type RecordFLIPGroup struct { // Network Network string `json:"network"` - // Resource group ID - RGID uint64 `json:"rgId"` - - // Resource group name - RGName string `json:"rgName"` - // Status Status string `json:"status"` diff --git a/pkg/cloudbroker/node/autostart.go b/pkg/cloudbroker/node/autostart.go new file mode 100644 index 0000000..c78f0e9 --- /dev/null +++ b/pkg/cloudbroker/node/autostart.go @@ -0,0 +1,42 @@ +package node + +import ( + "context" + "net/http" + "strconv" + + "repository.basistech.ru/BASIS/dynamix-golang-sdk/v13/internal/validators" +) + +// AutoStartRequest struct to set node autostart +type AutoStartRequest struct { + // Node ID + // Required: true + NodeID uint64 `url:"node_id" json:"node_id" validate:"required"` + + // Auto start + // Required: true + AutoStart bool `url:"autostart" json:"autostart" validate:"required"` +} + +// AutoStart sets node autostart +func (n Node) AutoStart(ctx context.Context, req AutoStartRequest) (bool, error) { + err := validators.ValidateRequest(req) + if err != nil { + return false, validators.ValidationErrors(validators.GetErrors(err)) + } + + url := "/cloudbroker/node/autostart" + + res, err := n.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 +} diff --git a/pkg/cloudbroker/node/maintenance.go b/pkg/cloudbroker/node/maintenance.go index e1192ea..7172a2a 100644 --- a/pkg/cloudbroker/node/maintenance.go +++ b/pkg/cloudbroker/node/maintenance.go @@ -26,6 +26,11 @@ type MaintenanceRequest struct { // Reason // Required: false Reason string `url:"reason,omitempty" json:"reason,omitempty"` + + // Allow node auto-enable + // Default: false + // Required: false + AutoStart bool `url:"autostart" json:"autostart"` } // Maintenance places node in maintenance state diff --git a/pkg/cloudbroker/node/models.go b/pkg/cloudbroker/node/models.go index d1b7e84..321a6d1 100644 --- a/pkg/cloudbroker/node/models.go +++ b/pkg/cloudbroker/node/models.go @@ -85,6 +85,12 @@ type RecordNode struct { // CPU used by the node UsableCPUs []string `json:"usable_cpus"` + + // AutoStart + AutoStart bool `json:"autostart"` + + // AutoStart Count + AutoStartCount uint64 `json:"autostart_count"` } // Resource consumption of the node @@ -301,6 +307,12 @@ type ItemNode struct { // CPU used by the node UsableCPUs []string `json:"usable_cpus"` + + // AutoStart + AutoStart bool `json:"autostart"` + + // AutoStart Count + AutoStartCount uint64 `json:"autostart_count"` } type PackageInfo struct { diff --git a/pkg/cloudbroker/sep/del_consumer_nodes.go b/pkg/cloudbroker/sep/del_consumer_nodes.go index 39d4fec..b284562 100644 --- a/pkg/cloudbroker/sep/del_consumer_nodes.go +++ b/pkg/cloudbroker/sep/del_consumer_nodes.go @@ -20,8 +20,8 @@ type DelConsumerNodesRequest struct { // The force flag must be set to true only if the node will never come back online // Default: false - // Required: true - Force bool `url:"force" json:"force" validate:"required"` + // Required: false + Force bool `url:"force" json:"force"` } // DelConsumerNodes excludes consumer nodes from SEP parameters diff --git a/pkg/cloudbroker/zone/models.go b/pkg/cloudbroker/zone/models.go index 110f9f9..3c22c6b 100644 --- a/pkg/cloudbroker/zone/models.go +++ b/pkg/cloudbroker/zone/models.go @@ -10,6 +10,9 @@ type ListZones struct { // Detailed information about the zone record type RecordZone struct { + // If true, all nodes belonging to the given zone will be marked for autostart + AutoStart bool `json:"autostart"` + // ID ID uint64 `json:"id"` diff --git a/pkg/cloudbroker/zone/node_autostart.go b/pkg/cloudbroker/zone/node_autostart.go new file mode 100644 index 0000000..82f0d2a --- /dev/null +++ b/pkg/cloudbroker/zone/node_autostart.go @@ -0,0 +1,43 @@ +package zone + +import ( + "context" + "net/http" + "strconv" + + "repository.basistech.ru/BASIS/dynamix-golang-sdk/v13/internal/validators" +) + +// NodeAutoStartRequest struct to set node autostart in zone +type NodeAutoStartRequest struct { + // ID of zone + // Required: true + ZoneID uint64 `url:"zone_id" json:"zone_id" validate:"required"` + + // AutoStart nodes in zone + // Required: true + AutoStart bool `url:"autostart" json:"autostart" validate:"required"` +} + +// NodeAutoStart sets node autostart in zone +func (e Zone) NodeAutoStart(ctx context.Context, req NodeAutoStartRequest) (bool, error) { + err := validators.ValidateRequest(req) + if err != nil { + return false, validators.ValidationErrors(validators.GetErrors(err)) + } + + url := "/cloudbroker/zone/node_autostart" + + res, err := e.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 +} diff --git a/pkg/cloudbroker/zone/update.go b/pkg/cloudbroker/zone/update.go index 12d7947..27e319e 100644 --- a/pkg/cloudbroker/zone/update.go +++ b/pkg/cloudbroker/zone/update.go @@ -21,6 +21,10 @@ type UpdateRequest struct { // Description // Required: false Description string `url:"description,omitempty" json:"description,omitempty"` + + // If true, all nodes belonging to the given zone will be marked for autostart + // Required: false + AutoStart interface{} `url:"autostart,omitempty" json:"autostart,omitempty" validate:"omitempty,isBool"` } // Update updates zone object