| // Code generated by go-swagger; DO NOT EDIT. |
| |
| // Copyright 2018 The go-netbox Authors. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| 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 ( |
| strfmt "github.com/go-openapi/strfmt" |
| |
| "github.com/go-openapi/errors" |
| "github.com/go-openapi/swag" |
| "github.com/go-openapi/validate" |
| ) |
| |
| // IPAddress IP address |
| // swagger:model IPAddress |
| type IPAddress struct { |
| |
| // Address |
| // |
| // IPv4 or IPv6 address (with mask) |
| // Required: true |
| Address *string `json:"address"` |
| |
| // Created |
| // Read Only: true |
| Created strfmt.Date `json:"created,omitempty"` |
| |
| // Custom fields |
| CustomFields interface{} `json:"custom_fields,omitempty"` |
| |
| // Description |
| // Max Length: 100 |
| Description string `json:"description,omitempty"` |
| |
| // Family |
| // Read Only: true |
| Family int64 `json:"family,omitempty"` |
| |
| // ID |
| // Read Only: true |
| ID int64 `json:"id,omitempty"` |
| |
| // interface |
| // Required: true |
| Interface *IPAddressInterface `json:"interface"` |
| |
| // Last updated |
| // Read Only: true |
| LastUpdated strfmt.DateTime `json:"last_updated,omitempty"` |
| |
| // nat inside |
| // Required: true |
| NatInside *NestedIPAddress `json:"nat_inside"` |
| |
| // nat outside |
| // Required: true |
| NatOutside *NestedIPAddress `json:"nat_outside"` |
| |
| // role |
| // Required: true |
| Role *IPAddressRole `json:"role"` |
| |
| // status |
| // Required: true |
| Status *IPAddressStatus `json:"status"` |
| |
| // tenant |
| // Required: true |
| Tenant *NestedTenant `json:"tenant"` |
| |
| // vrf |
| // Required: true |
| Vrf *NestedVRF `json:"vrf"` |
| } |
| |
| // Validate validates this IP address |
| func (m *IPAddress) Validate(formats strfmt.Registry) error { |
| var res []error |
| |
| if err := m.validateAddress(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateDescription(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateInterface(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateNatInside(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateNatOutside(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateRole(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateStatus(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateTenant(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if err := m.validateVrf(formats); err != nil { |
| // prop |
| res = append(res, err) |
| } |
| |
| if len(res) > 0 { |
| return errors.CompositeValidationError(res...) |
| } |
| return nil |
| } |
| |
| func (m *IPAddress) validateAddress(formats strfmt.Registry) error { |
| |
| if err := validate.Required("address", "body", m.Address); err != nil { |
| return err |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateDescription(formats strfmt.Registry) error { |
| |
| if swag.IsZero(m.Description) { // not required |
| return nil |
| } |
| |
| if err := validate.MaxLength("description", "body", string(m.Description), 100); err != nil { |
| return err |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateInterface(formats strfmt.Registry) error { |
| |
| if err := validate.Required("interface", "body", m.Interface); err != nil { |
| return err |
| } |
| |
| if m.Interface != nil { |
| |
| if err := m.Interface.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("interface") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateNatInside(formats strfmt.Registry) error { |
| |
| if err := validate.Required("nat_inside", "body", m.NatInside); err != nil { |
| return err |
| } |
| |
| if m.NatInside != nil { |
| |
| if err := m.NatInside.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("nat_inside") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateNatOutside(formats strfmt.Registry) error { |
| |
| if err := validate.Required("nat_outside", "body", m.NatOutside); err != nil { |
| return err |
| } |
| |
| if m.NatOutside != nil { |
| |
| if err := m.NatOutside.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("nat_outside") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateRole(formats strfmt.Registry) error { |
| |
| if err := validate.Required("role", "body", m.Role); err != nil { |
| return err |
| } |
| |
| if m.Role != nil { |
| |
| if err := m.Role.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("role") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateStatus(formats strfmt.Registry) error { |
| |
| if err := validate.Required("status", "body", m.Status); err != nil { |
| return err |
| } |
| |
| if m.Status != nil { |
| |
| if err := m.Status.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("status") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateTenant(formats strfmt.Registry) error { |
| |
| if err := validate.Required("tenant", "body", m.Tenant); err != nil { |
| return err |
| } |
| |
| if m.Tenant != nil { |
| |
| if err := m.Tenant.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("tenant") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| func (m *IPAddress) validateVrf(formats strfmt.Registry) error { |
| |
| if err := validate.Required("vrf", "body", m.Vrf); err != nil { |
| return err |
| } |
| |
| if m.Vrf != nil { |
| |
| if err := m.Vrf.Validate(formats); err != nil { |
| if ve, ok := err.(*errors.Validation); ok { |
| return ve.ValidateName("vrf") |
| } |
| return err |
| } |
| } |
| |
| return nil |
| } |
| |
| // MarshalBinary interface implementation |
| func (m *IPAddress) MarshalBinary() ([]byte, error) { |
| if m == nil { |
| return nil, nil |
| } |
| return swag.WriteJSON(m) |
| } |
| |
| // UnmarshalBinary interface implementation |
| func (m *IPAddress) UnmarshalBinary(b []byte) error { |
| var res IPAddress |
| if err := swag.ReadJSON(b, &res); err != nil { |
| return err |
| } |
| *m = res |
| return nil |
| } |