This commit is contained in:
stSolo
2022-12-22 17:56:47 +03:00
parent 8712561853
commit d4b1ab7133
672 changed files with 28509 additions and 4419 deletions

View File

@@ -7,16 +7,21 @@ import (
"net/http"
)
// Request struct for get detailed information about Compute Group
type GroupGetRequest struct {
ServiceID uint64 `url:"serviceId"`
// ID of the Basic Service of Compute Group
// Required: true
ServiceID uint64 `url:"serviceId"`
// ID of the Compute Group
// Required: true
CompGroupID uint64 `url:"compgroupId"`
}
func (bsrq GroupGetRequest) Validate() error {
func (bsrq GroupGetRequest) validate() error {
if bsrq.ServiceID == 0 {
return errors.New("field ServiceID can not be empty or equal to 0")
}
if bsrq.CompGroupID == 0 {
return errors.New("field CompGroupID can not be empty or equal to 0")
}
@@ -24,21 +29,26 @@ func (bsrq GroupGetRequest) Validate() error {
return nil
}
func (b BService) GroupGet(ctx context.Context, req GroupGetRequest) (*Group, error) {
if err := req.Validate(); err != nil {
return nil, err
}
url := "/cloudapi/bservice/groupGet"
groupRaw, err := b.client.DecortApiCall(ctx, http.MethodPost, url, req)
// GroupGet gets detailed specifications for the Compute Group
func (b BService) GroupGet(ctx context.Context, req GroupGetRequest) (*RecordGroup, error) {
err := req.validate()
if err != nil {
return nil, err
}
group := &Group{}
if err := json.Unmarshal(groupRaw, group); err != nil {
url := "/cloudapi/bservice/groupGet"
res, err := b.client.DecortApiCall(ctx, http.MethodPost, url, req)
if err != nil {
return nil, err
}
return group, nil
info := RecordGroup{}
err = json.Unmarshal(res, &info)
if err != nil {
return nil, err
}
return &info, nil
}