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 }