// Code generated by go-swagger; DO NOT EDIT. // This file is part of MinIO Console Server // Copyright (c) 2022 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" ) // CreateTenantRequest create tenant request // // swagger:model createTenantRequest type CreateTenantRequest struct { // access key AccessKey string `json:"access_key,omitempty"` // annotations Annotations map[string]string `json:"annotations,omitempty"` // domains Domains *DomainsConfiguration `json:"domains,omitempty"` // enable console EnableConsole *bool `json:"enable_console,omitempty"` // enable prometheus EnablePrometheus *bool `json:"enable_prometheus,omitempty"` // enable tls EnableTLS *bool `json:"enable_tls,omitempty"` // encryption Encryption *EncryptionConfiguration `json:"encryption,omitempty"` // erasure coding parity ErasureCodingParity int64 `json:"erasureCodingParity,omitempty"` // expose console ExposeConsole bool `json:"expose_console,omitempty"` // expose minio ExposeMinio bool `json:"expose_minio,omitempty"` // idp Idp *IdpConfiguration `json:"idp,omitempty"` // image Image string `json:"image,omitempty"` // image pull secret ImagePullSecret string `json:"image_pull_secret,omitempty"` // image registry ImageRegistry *ImageRegistry `json:"image_registry,omitempty"` // labels Labels map[string]string `json:"labels,omitempty"` // log search configuration LogSearchConfiguration *LogSearchConfiguration `json:"logSearchConfiguration,omitempty"` // mounth path MounthPath string `json:"mounth_path,omitempty"` // name // Required: true // Pattern: ^[a-z0-9-]{3,63}$ Name *string `json:"name"` // namespace // Required: true Namespace *string `json:"namespace"` // pools // Required: true Pools []*Pool `json:"pools"` // prometheus configuration PrometheusConfiguration *PrometheusConfiguration `json:"prometheusConfiguration,omitempty"` // secret key SecretKey string `json:"secret_key,omitempty"` // tls TLS *TLSConfiguration `json:"tls,omitempty"` } // Validate validates this create tenant request func (m *CreateTenantRequest) Validate(formats strfmt.Registry) error { var res []error if err := m.validateDomains(formats); err != nil { res = append(res, err) } if err := m.validateEncryption(formats); err != nil { res = append(res, err) } if err := m.validateIdp(formats); err != nil { res = append(res, err) } if err := m.validateImageRegistry(formats); err != nil { res = append(res, err) } if err := m.validateLogSearchConfiguration(formats); err != nil { res = append(res, err) } if err := m.validateName(formats); err != nil { res = append(res, err) } if err := m.validateNamespace(formats); err != nil { res = append(res, err) } if err := m.validatePools(formats); err != nil { res = append(res, err) } if err := m.validatePrometheusConfiguration(formats); err != nil { res = append(res, err) } if err := m.validateTLS(formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *CreateTenantRequest) validateDomains(formats strfmt.Registry) error { if swag.IsZero(m.Domains) { // not required return nil } if m.Domains != nil { if err := m.Domains.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("domains") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("domains") } return err } } return nil } func (m *CreateTenantRequest) validateEncryption(formats strfmt.Registry) error { if swag.IsZero(m.Encryption) { // not required return nil } if m.Encryption != nil { if err := m.Encryption.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("encryption") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("encryption") } return err } } return nil } func (m *CreateTenantRequest) validateIdp(formats strfmt.Registry) error { if swag.IsZero(m.Idp) { // not required return nil } if m.Idp != nil { if err := m.Idp.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("idp") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("idp") } return err } } return nil } func (m *CreateTenantRequest) validateImageRegistry(formats strfmt.Registry) error { if swag.IsZero(m.ImageRegistry) { // not required return nil } if m.ImageRegistry != nil { if err := m.ImageRegistry.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("image_registry") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("image_registry") } return err } } return nil } func (m *CreateTenantRequest) validateLogSearchConfiguration(formats strfmt.Registry) error { if swag.IsZero(m.LogSearchConfiguration) { // not required return nil } if m.LogSearchConfiguration != nil { if err := m.LogSearchConfiguration.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("logSearchConfiguration") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("logSearchConfiguration") } return err } } return nil } func (m *CreateTenantRequest) validateName(formats strfmt.Registry) error { if err := validate.Required("name", "body", m.Name); err != nil { return err } if err := validate.Pattern("name", "body", *m.Name, `^[a-z0-9-]{3,63}$`); err != nil { return err } return nil } func (m *CreateTenantRequest) validateNamespace(formats strfmt.Registry) error { if err := validate.Required("namespace", "body", m.Namespace); err != nil { return err } return nil } func (m *CreateTenantRequest) validatePools(formats strfmt.Registry) error { if err := validate.Required("pools", "body", m.Pools); err != nil { return err } for i := 0; i < len(m.Pools); i++ { if swag.IsZero(m.Pools[i]) { // not required continue } if m.Pools[i] != nil { if err := m.Pools[i].Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("pools" + "." + strconv.Itoa(i)) } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("pools" + "." + strconv.Itoa(i)) } return err } } } return nil } func (m *CreateTenantRequest) validatePrometheusConfiguration(formats strfmt.Registry) error { if swag.IsZero(m.PrometheusConfiguration) { // not required return nil } if m.PrometheusConfiguration != nil { if err := m.PrometheusConfiguration.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("prometheusConfiguration") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("prometheusConfiguration") } return err } } return nil } func (m *CreateTenantRequest) validateTLS(formats strfmt.Registry) error { if swag.IsZero(m.TLS) { // not required return nil } if m.TLS != nil { if err := m.TLS.Validate(formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("tls") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("tls") } return err } } return nil } // ContextValidate validate this create tenant request based on the context it is used func (m *CreateTenantRequest) ContextValidate(ctx context.Context, formats strfmt.Registry) error { var res []error if err := m.contextValidateDomains(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateEncryption(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateIdp(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateImageRegistry(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateLogSearchConfiguration(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidatePools(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidatePrometheusConfiguration(ctx, formats); err != nil { res = append(res, err) } if err := m.contextValidateTLS(ctx, formats); err != nil { res = append(res, err) } if len(res) > 0 { return errors.CompositeValidationError(res...) } return nil } func (m *CreateTenantRequest) contextValidateDomains(ctx context.Context, formats strfmt.Registry) error { if m.Domains != nil { if err := m.Domains.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("domains") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("domains") } return err } } return nil } func (m *CreateTenantRequest) contextValidateEncryption(ctx context.Context, formats strfmt.Registry) error { if m.Encryption != nil { if err := m.Encryption.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("encryption") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("encryption") } return err } } return nil } func (m *CreateTenantRequest) contextValidateIdp(ctx context.Context, formats strfmt.Registry) error { if m.Idp != nil { if err := m.Idp.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("idp") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("idp") } return err } } return nil } func (m *CreateTenantRequest) contextValidateImageRegistry(ctx context.Context, formats strfmt.Registry) error { if m.ImageRegistry != nil { if err := m.ImageRegistry.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("image_registry") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("image_registry") } return err } } return nil } func (m *CreateTenantRequest) contextValidateLogSearchConfiguration(ctx context.Context, formats strfmt.Registry) error { if m.LogSearchConfiguration != nil { if err := m.LogSearchConfiguration.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("logSearchConfiguration") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("logSearchConfiguration") } return err } } return nil } func (m *CreateTenantRequest) contextValidatePools(ctx context.Context, formats strfmt.Registry) error { for i := 0; i < len(m.Pools); i++ { if m.Pools[i] != nil { if err := m.Pools[i].ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("pools" + "." + strconv.Itoa(i)) } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("pools" + "." + strconv.Itoa(i)) } return err } } } return nil } func (m *CreateTenantRequest) contextValidatePrometheusConfiguration(ctx context.Context, formats strfmt.Registry) error { if m.PrometheusConfiguration != nil { if err := m.PrometheusConfiguration.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("prometheusConfiguration") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("prometheusConfiguration") } return err } } return nil } func (m *CreateTenantRequest) contextValidateTLS(ctx context.Context, formats strfmt.Registry) error { if m.TLS != nil { if err := m.TLS.ContextValidate(ctx, formats); err != nil { if ve, ok := err.(*errors.Validation); ok { return ve.ValidateName("tls") } else if ce, ok := err.(*errors.CompositeError); ok { return ce.ValidateName("tls") } return err } } return nil } // MarshalBinary interface implementation func (m *CreateTenantRequest) MarshalBinary() ([]byte, error) { if m == nil { return nil, nil } return swag.WriteJSON(m) } // UnmarshalBinary interface implementation func (m *CreateTenantRequest) UnmarshalBinary(b []byte) error { var res CreateTenantRequest if err := swag.ReadJSON(b, &res); err != nil { return err } *m = res return nil }