2020-11-30 09:37:17 +00:00
|
|
|
// Code generated by go-swagger; DO NOT EDIT.
|
|
|
|
|
|
|
|
package models
|
|
|
|
|
|
|
|
// This file was generated by the swagger tool.
|
|
|
|
// Editing this file might prove futile when you re-run the swagger generate command
|
|
|
|
|
|
|
|
import (
|
2022-01-11 15:45:34 +00:00
|
|
|
"context"
|
|
|
|
|
2020-11-30 09:37:17 +00:00
|
|
|
"github.com/go-openapi/errors"
|
|
|
|
"github.com/go-openapi/strfmt"
|
|
|
|
"github.com/go-openapi/swag"
|
|
|
|
"github.com/go-openapi/validate"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Decision Decision
|
|
|
|
//
|
|
|
|
// swagger:model Decision
|
|
|
|
type Decision struct {
|
|
|
|
|
2022-01-13 15:46:16 +00:00
|
|
|
// the duration of the decisions
|
2020-11-30 09:37:17 +00:00
|
|
|
// Required: true
|
|
|
|
Duration *string `json:"duration"`
|
|
|
|
|
|
|
|
// (only relevant for GET ops) the unique id
|
|
|
|
// Read Only: true
|
|
|
|
ID int64 `json:"id,omitempty"`
|
|
|
|
|
|
|
|
// the origin of the decision : cscli, crowdsec
|
|
|
|
// Required: true
|
|
|
|
Origin *string `json:"origin"`
|
|
|
|
|
|
|
|
// scenario
|
|
|
|
// Required: true
|
|
|
|
Scenario *string `json:"scenario"`
|
|
|
|
|
|
|
|
// the scope of decision : does it apply to an IP, a range, a username, etc
|
|
|
|
// Required: true
|
|
|
|
Scope *string `json:"scope"`
|
|
|
|
|
|
|
|
// true if the decision result from a scenario in simulation mode
|
|
|
|
// Read Only: true
|
|
|
|
Simulated *bool `json:"simulated,omitempty"`
|
|
|
|
|
|
|
|
// the type of decision, might be 'ban', 'captcha' or something custom. Ignored when watcher (cscli/crowdsec) is pushing to APIL.
|
|
|
|
// Required: true
|
|
|
|
Type *string `json:"type"`
|
|
|
|
|
2022-01-13 15:46:16 +00:00
|
|
|
// the date until the decisions must be active
|
|
|
|
Until string `json:"until,omitempty"`
|
|
|
|
|
2023-01-31 13:47:44 +00:00
|
|
|
// only relevant for LAPI->CAPI, ignored for cscli->LAPI and crowdsec->LAPI
|
|
|
|
// Read Only: true
|
|
|
|
UUID string `json:"uuid,omitempty"`
|
|
|
|
|
2020-11-30 09:37:17 +00:00
|
|
|
// the value of the decision scope : an IP, a range, a username, etc
|
|
|
|
// Required: true
|
|
|
|
Value *string `json:"value"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate validates this decision
|
|
|
|
func (m *Decision) Validate(formats strfmt.Registry) error {
|
|
|
|
var res []error
|
|
|
|
|
|
|
|
if err := m.validateDuration(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.validateOrigin(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.validateScenario(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.validateScope(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.validateType(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.validateValue(formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(res) > 0 {
|
|
|
|
return errors.CompositeValidationError(res...)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateDuration(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("duration", "body", m.Duration); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateOrigin(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("origin", "body", m.Origin); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateScenario(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("scenario", "body", m.Scenario); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateScope(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("scope", "body", m.Scope); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateType(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("type", "body", m.Type); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) validateValue(formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.Required("value", "body", m.Value); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-01-11 15:45:34 +00:00
|
|
|
// ContextValidate validate this decision based on the context it is used
|
|
|
|
func (m *Decision) ContextValidate(ctx context.Context, formats strfmt.Registry) error {
|
|
|
|
var res []error
|
|
|
|
|
|
|
|
if err := m.contextValidateID(ctx, formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.contextValidateSimulated(ctx, formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
2023-01-31 13:47:44 +00:00
|
|
|
if err := m.contextValidateUUID(ctx, formats); err != nil {
|
|
|
|
res = append(res, err)
|
|
|
|
}
|
|
|
|
|
2022-01-11 15:45:34 +00:00
|
|
|
if len(res) > 0 {
|
|
|
|
return errors.CompositeValidationError(res...)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) contextValidateID(ctx context.Context, formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.ReadOnly(ctx, "id", "body", int64(m.ID)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Decision) contextValidateSimulated(ctx context.Context, formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.ReadOnly(ctx, "simulated", "body", m.Simulated); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-01-31 13:47:44 +00:00
|
|
|
func (m *Decision) contextValidateUUID(ctx context.Context, formats strfmt.Registry) error {
|
|
|
|
|
|
|
|
if err := validate.ReadOnly(ctx, "uuid", "body", string(m.UUID)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-11-30 09:37:17 +00:00
|
|
|
// MarshalBinary interface implementation
|
|
|
|
func (m *Decision) MarshalBinary() ([]byte, error) {
|
|
|
|
if m == nil {
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
return swag.WriteJSON(m)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalBinary interface implementation
|
|
|
|
func (m *Decision) UnmarshalBinary(b []byte) error {
|
|
|
|
var res Decision
|
|
|
|
if err := swag.ReadJSON(b, &res); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
*m = res
|
|
|
|
return nil
|
|
|
|
}
|