This commit is contained in:
asteam
2025-09-23 14:34:24 +03:00
parent b924e85e49
commit f1ffb4c0fd
1108 changed files with 72020 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
package k8s
import (
"context"
"encoding/json"
"net/http"
"repository.basistech.ru/BASIS/dynamix-golang-sdk/v9/internal/validators"
)
// FindGroupByLabelRequest struct for get information about group of kubernetes cluster
type FindGroupByLabelRequest struct {
// Kubernetes cluster ID
// Required: true
K8SID uint64 `url:"k8sId" json:"k8sId" validate:"required"`
// List of labels to search
// Required: true
Labels []string `url:"labels" json:"labels" validate:"min=1"`
// If true and more than one label provided, select only groups that have all provided labels.
// If false - groups that have at least one label
// Required: false
Strict bool `url:"strict,omitempty" json:"strict,omitempty"`
}
// FindGroupByLabel finds worker group information by one on more labels
func (k K8S) FindGroupByLabel(ctx context.Context, req FindGroupByLabelRequest) (ListK8SGroup, error) {
err := validators.ValidateRequest(req)
if err != nil {
return nil, validators.ValidationErrors(validators.GetErrors(err))
}
url := "/cloudbroker/k8s/findGroupByLabel"
res, err := k.client.DecortApiCall(ctx, http.MethodPost, url, req)
if err != nil {
return nil, err
}
list := ListK8SGroup{}
err = json.Unmarshal(res, &list)
if err != nil {
return nil, err
}
return list, nil
}