mirror of
https://github.com/xiaoxinpro/nginx-proxy-manager-zh.git
synced 2025-01-25 22:28:13 -05:00
34 lines
991 B
Go
34 lines
991 B
Go
|
package validator
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"npm/internal/entity/certificate"
|
||
|
"npm/internal/entity/host"
|
||
|
"npm/internal/entity/hosttemplate"
|
||
|
)
|
||
|
|
||
|
// ValidateHost will check if associated objects exist and other checks
|
||
|
// will return a nil error if things are OK
|
||
|
func ValidateHost(h host.Model) error {
|
||
|
if h.CertificateID > 0 {
|
||
|
// Check certificate exists and is valid
|
||
|
// This will not determine if the certificate is Ready to use,
|
||
|
// as this validation only cares that the row exists.
|
||
|
if _, cErr := certificate.GetByID(h.CertificateID); cErr != nil {
|
||
|
return fmt.Errorf("Certificate #%d does not exist", h.CertificateID)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Check the host template exists and has the same type.
|
||
|
hostTemplate, tErr := hosttemplate.GetByID(h.HostTemplateID)
|
||
|
if tErr != nil {
|
||
|
return fmt.Errorf("Host Template #%d does not exist", h.HostTemplateID)
|
||
|
}
|
||
|
if hostTemplate.Type != h.Type {
|
||
|
return fmt.Errorf("Host Template #%d is not valid for this host type", h.HostTemplateID)
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|