You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.1 KiB
75 lines
2.1 KiB
|
4 days ago
|
package secpolicies
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
"encoding/json"
|
||
|
|
"net/http"
|
||
|
|
|
||
|
|
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
||
|
|
)
|
||
|
|
|
||
|
|
// ListRequest struct to get a list of security group
|
||
|
|
type ListRequest struct {
|
||
|
|
// Display name
|
||
|
|
// Required: false
|
||
|
|
DisplayName string `url:"display_name,omitempty" json:"display_name,omitempty"`
|
||
|
|
|
||
|
|
// Enabled status
|
||
|
|
// Required: false
|
||
|
|
Enabled interface{} `url:"enabled,omitempty" json:"enabled,omitempty" validate:"omitempty,isBool"`
|
||
|
|
|
||
|
|
// Filter by access group ID
|
||
|
|
// Required: false
|
||
|
|
AccessGroupID string `url:"access_group_id,omitempty" json:"access_group_id,omitempty"`
|
||
|
|
|
||
|
|
// Filter by applied to net object group ID
|
||
|
|
// Required: false
|
||
|
|
AppliedToNetObjectGroupID string `url:"applied_to_net_object_group_id,omitempty" json:"applied_to_net_object_group_id,omitempty"`
|
||
|
|
|
||
|
|
// Page number for pagination
|
||
|
|
// Required: false
|
||
|
|
Page uint64 `url:"page,omitempty" json:"page,omitempty"`
|
||
|
|
|
||
|
|
// Number of results per page
|
||
|
|
// Required: false
|
||
|
|
PerPage uint64 `url:"per_page,omitempty" json:"per_page,omitempty"`
|
||
|
|
|
||
|
|
// Field to sort by (display_name, enabled, created_at, updated_at, deleted_at, start_priority)
|
||
|
|
// Required: false
|
||
|
|
SortBy string `url:"sort_by,omitempty" json:"sort_by,omitempty"`
|
||
|
|
|
||
|
|
// Sort order (asc/desc)
|
||
|
|
// Required: false
|
||
|
|
SortOrder string `url:"sort_order,omitempty" json:"sort_order,omitempty"`
|
||
|
|
}
|
||
|
|
|
||
|
|
// List of security policies
|
||
|
|
func (i SecurityPolicies) List(ctx context.Context, req ListRequest) (SecurityPolicyList, error) {
|
||
|
|
res, err := i.ListRaw(ctx, req)
|
||
|
|
if err != nil {
|
||
|
|
return nil, err
|
||
|
|
}
|
||
|
|
|
||
|
|
result := []SecurityPolicySummary{}
|
||
|
|
|
||
|
|
err = json.Unmarshal(res, &result)
|
||
|
|
if err != nil {
|
||
|
|
return nil, err
|
||
|
|
}
|
||
|
|
|
||
|
|
return result, nil
|
||
|
|
}
|
||
|
|
|
||
|
|
// ListRaw gets a list of all security policies as an array of bytes
|
||
|
|
func (a SecurityPolicies) ListRaw(ctx context.Context, req ListRequest) ([]byte, error) {
|
||
|
|
|
||
|
|
if err := validators.ValidateRequest(req); err != nil {
|
||
|
|
return nil, validators.ValidationErrors(validators.GetErrors(err))
|
||
|
|
}
|
||
|
|
|
||
|
|
url := "/sdn/security_policy/list"
|
||
|
|
|
||
|
|
res, err := a.client.DecortApiCall(ctx, http.MethodGet, url, req)
|
||
|
|
return res, err
|
||
|
|
}
|