// Code generated by go-swagger; DO NOT EDIT. // This file is part of MinIO Console Server // Copyright (c) 2021 MinIO, Inc. // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . // 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 ( "context" "strconv" "github.com/go-openapi/errors" "github.com/go-openapi/strfmt" "github.com/go-openapi/swag" "github.com/go-openapi/validate" ) // NotificationConfig notification config // // swagger:model notificationConfig type NotificationConfig struct { // arn // Required: true Arn *string `json:"arn"` // filter specific type of event. Defaults to all event (default: '[put,delete,get]') Events []NotificationEventType `json:"events"` // id ID string `json:"id,omitempty"` // filter event associated to the specified prefix Prefix string `json:"prefix,omitempty"` // filter event associated to the specified suffix Suffix string `json:"suffix,omitempty"` } // Validate validates this notification config func (m *NotificationConfig) Validate(formats strfmt.Registry) error { var res []error if err := m.validateArn(formats); err != nil { res = append(res, err) } if err := m.validateEvents(formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *NotificationConfig) validateArn(formats strfmt.Registry) error { if err := validate.Required("arn", "body", m.Arn); err != nil { return err } return nil } func (m *NotificationConfig) validateEvents(formats strfmt.Registry) error { if swag.IsZero(m.Events) { // not required return nil } for i := 0; i < len(m.Events); i++ { if err := m.Events[i].Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("events" + "." + strconv.Itoa(i)) } return err } } return nil } // ContextValidate validate this notification config based on the context it is used func (m *NotificationConfig) ContextValidate(ctx context.Context, formats strfmt.Registry) error { var res []error if err := m.contextValidateEvents(ctx, formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *NotificationConfig) contextValidateEvents(ctx context.Context, formats strfmt.Registry) error { for i := 0; i < len(m.Events); i++ { if err := m.Events[i].ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("events" + "." + strconv.Itoa(i)) } return err } } return nil } // MarshalBinary interface implementation func (m *NotificationConfig) MarshalBinary() ([]byte, error) { if m == nil { return nil, nil } return swag.WriteJSON(m) } // UnmarshalBinary interface implementation func (m *NotificationConfig) UnmarshalBinary(b []byte) error { var res NotificationConfig if err := swag.ReadJSON(b, &res); err != nil { return err } *m = res return nil }