// 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 ( "context" "github.com/go-openapi/errors" "github.com/go-openapi/strfmt" "github.com/go-openapi/swag" ) // NotificationSubject NotificationSubject contains the notification subject (Issue/Pull/Commit) // // swagger:model NotificationSubject type NotificationSubject struct { // HTML URL HTMLURL string `json:"html_url,omitempty"` // latest comment HTML URL LatestCommentHTMLURL string `json:"latest_comment_html_url,omitempty"` // latest comment URL LatestCommentURL string `json:"latest_comment_url,omitempty"` // title Title string `json:"title,omitempty"` // URL URL string `json:"url,omitempty"` // state State StateType `json:"state,omitempty"` // type Type NotifySubjectType `json:"type,omitempty"` } // Validate validates this notification subject func (m *NotificationSubject) Validate(formats strfmt.Registry) error { var res []error if err := m.validateState(formats); err != nil { res = append(res, err) } if err := m.validateType(formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *NotificationSubject) validateState(formats strfmt.Registry) error { if swag.IsZero(m.State) { // not required return nil } if err := m.State.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("state") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("state") } return err } return nil } func (m *NotificationSubject) validateType(formats strfmt.Registry) error { if swag.IsZero(m.Type) { // not required return nil } if err := m.Type.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("type") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("type") } return err } return nil } // ContextValidate validate this notification subject based on the context it is used func (m *NotificationSubject) ContextValidate(ctx context.Context, formats strfmt.Registry) error { var res []error if err := m.contextValidateState(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateType(ctx, formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *NotificationSubject) contextValidateState(ctx context.Context, formats strfmt.Registry) error { if swag.IsZero(m.State) { // not required return nil } if err := m.State.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("state") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("state") } return err } return nil } func (m *NotificationSubject) contextValidateType(ctx context.Context, formats strfmt.Registry) error { if swag.IsZero(m.Type) { // not required return nil } if err := m.Type.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("type") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("type") } return err } return nil } // MarshalBinary interface implementation func (m *NotificationSubject) MarshalBinary() ([]byte, error) { if m == nil { return nil, nil } return swag.WriteJSON(m) } // UnmarshalBinary interface implementation func (m *NotificationSubject) UnmarshalBinary(b []byte) error { var res NotificationSubject if err := swag.ReadJSON(b, &res); err != nil { return err } *m = res return nil }