mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-12 05:34:05 +00:00
74688394d8
* docs: add scope to request private labeling * feat: add enum to project * fix: remove unused code, add private labeling setting to query side * fix: set private labeling depending on setting * fix: private labeling depending on project setting * Update proto/zitadel/management.proto Co-authored-by: Livio Amstutz <livio.a@gmail.com> * fix: rename sql file * fix: private labeling setting Co-authored-by: Livio Amstutz <livio.a@gmail.com>
116 lines
2.6 KiB
Go
116 lines
2.6 KiB
Go
package model
|
|
|
|
import (
|
|
"github.com/golang/protobuf/ptypes/timestamp"
|
|
|
|
"github.com/caos/zitadel/internal/domain"
|
|
es_models "github.com/caos/zitadel/internal/eventstore/v1/models"
|
|
)
|
|
|
|
type Project struct {
|
|
es_models.ObjectRoot
|
|
|
|
State ProjectState
|
|
Name string
|
|
Members []*ProjectMember
|
|
Roles []*ProjectRole
|
|
Applications []*Application
|
|
Grants []*ProjectGrant
|
|
ProjectRoleAssertion bool
|
|
ProjectRoleCheck bool
|
|
HasProjectCheck bool
|
|
PrivateLabelingSetting domain.PrivateLabelingSetting
|
|
}
|
|
type ProjectChanges struct {
|
|
Changes []*ProjectChange
|
|
LastSequence uint64
|
|
}
|
|
|
|
type ProjectChange struct {
|
|
ChangeDate *timestamp.Timestamp `json:"changeDate,omitempty"`
|
|
EventType string `json:"eventType,omitempty"`
|
|
Sequence uint64 `json:"sequence,omitempty"`
|
|
ModifierId string `json:"modifierUser,omitempty"`
|
|
ModifierName string `json:"-"`
|
|
ModifierLoginName string `json:"-"`
|
|
ModifierAvatarURL string `json:"-"`
|
|
Data interface{} `json:"data,omitempty"`
|
|
}
|
|
|
|
type ProjectState int32
|
|
|
|
const (
|
|
ProjectStateActive ProjectState = iota
|
|
ProjectStateInactive
|
|
ProjectStateRemoved
|
|
)
|
|
|
|
func NewProject(id string) *Project {
|
|
return &Project{ObjectRoot: es_models.ObjectRoot{AggregateID: id}, State: ProjectStateActive}
|
|
}
|
|
|
|
func (p *Project) IsActive() bool {
|
|
return p.State == ProjectStateActive
|
|
}
|
|
|
|
func (p *Project) IsValid() bool {
|
|
return p.Name != ""
|
|
}
|
|
|
|
func (p *Project) ContainsRole(role *ProjectRole) bool {
|
|
for _, r := range p.Roles {
|
|
if r.Key == role.Key {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (p *Project) GetApp(appID string) (int, *Application) {
|
|
for i, a := range p.Applications {
|
|
if a.AppID == appID {
|
|
return i, a
|
|
}
|
|
}
|
|
return -1, nil
|
|
}
|
|
|
|
func (p *Project) GetGrant(grantID string) (int, *ProjectGrant) {
|
|
for i, g := range p.Grants {
|
|
if g.GrantID == grantID {
|
|
return i, g
|
|
}
|
|
}
|
|
return -1, nil
|
|
}
|
|
|
|
func (p *Project) ContainsGrantForOrg(orgID string) bool {
|
|
for _, g := range p.Grants {
|
|
if g.GrantedOrgID == orgID {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (p *Project) ContainsRoles(roleKeys []string) bool {
|
|
for _, r := range roleKeys {
|
|
if !p.ContainsRole(&ProjectRole{Key: r}) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
func (p *Project) ContainsGrantMember(member *ProjectGrantMember) bool {
|
|
for _, g := range p.Grants {
|
|
if g.GrantID != member.GrantID {
|
|
continue
|
|
}
|
|
if _, m := g.GetMember(member.UserID); m != nil {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|