2020-06-16 09:40:18 +00:00
|
|
|
package model
|
|
|
|
|
2020-08-06 13:03:03 +00:00
|
|
|
import (
|
|
|
|
http_util "github.com/caos/zitadel/internal/api/http"
|
|
|
|
"github.com/caos/zitadel/internal/crypto"
|
|
|
|
es_models "github.com/caos/zitadel/internal/eventstore/models"
|
|
|
|
)
|
2020-06-16 09:40:18 +00:00
|
|
|
|
|
|
|
type OrgDomain struct {
|
|
|
|
es_models.ObjectRoot
|
2020-08-06 13:03:03 +00:00
|
|
|
Domain string
|
|
|
|
Primary bool
|
|
|
|
Verified bool
|
|
|
|
ValidationType OrgDomainValidationType
|
|
|
|
ValidationCode *crypto.CryptoValue
|
|
|
|
}
|
|
|
|
|
|
|
|
type OrgDomainValidationType int32
|
|
|
|
|
|
|
|
const (
|
|
|
|
OrgDomainValidationTypeUnspecified OrgDomainValidationType = iota
|
|
|
|
OrgDomainValidationTypeHTTP
|
|
|
|
OrgDomainValidationTypeDNS
|
|
|
|
)
|
|
|
|
|
|
|
|
func (t OrgDomainValidationType) CheckType() (http_util.CheckType, bool) {
|
|
|
|
switch t {
|
|
|
|
case OrgDomainValidationTypeHTTP:
|
|
|
|
return http_util.CheckTypeHTTP, true
|
|
|
|
case OrgDomainValidationTypeDNS:
|
|
|
|
return http_util.CheckTypeDNS, true
|
|
|
|
default:
|
|
|
|
return -1, false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t OrgDomainValidationType) IsDNS() bool {
|
|
|
|
return t == OrgDomainValidationTypeDNS
|
2020-06-16 09:40:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewOrgDomain(orgID, domain string) *OrgDomain {
|
|
|
|
return &OrgDomain{ObjectRoot: es_models.ObjectRoot{AggregateID: orgID}, Domain: domain}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (domain *OrgDomain) IsValid() bool {
|
|
|
|
return domain.AggregateID != "" && domain.Domain != ""
|
|
|
|
}
|
2020-08-06 13:03:03 +00:00
|
|
|
|
|
|
|
func (domain *OrgDomain) GenerateVerificationCode(codeGenerator crypto.Generator) (string, error) {
|
|
|
|
validationCodeCrypto, validationCode, err := crypto.NewCode(codeGenerator)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
domain.ValidationCode = validationCodeCrypto
|
|
|
|
return validationCode, nil
|
|
|
|
}
|