mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-14 20:08:02 +00:00
710652ef24
* feat: project role remove * feat: search queries * feat: search queries * feat: cascade remove/change project role * fix: comment in project grant * fix: remove projecr grant * fix: only search usergrants of my org * fix: delete usergrants * fix: delete usergrants * fix: check if role exists on project grant * feat: bulk add project role * fix: tests * fix: update user grants on project update * fix: return roles * feat: add resourceowner name on project grants * fix: migration number * fix: tests * fix: generate protos * fix: some unnecessary code
96 lines
2.4 KiB
Go
96 lines
2.4 KiB
Go
package model
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/caos/logging"
|
|
caos_errs "github.com/caos/zitadel/internal/errors"
|
|
es_models "github.com/caos/zitadel/internal/eventstore/models"
|
|
"github.com/caos/zitadel/internal/usergrant/model"
|
|
"reflect"
|
|
)
|
|
|
|
const (
|
|
UserGrantVersion = "v1"
|
|
)
|
|
|
|
type UserGrant struct {
|
|
es_models.ObjectRoot
|
|
|
|
State int32 `json:"-"`
|
|
UserID string `json:"userId,omitempty"`
|
|
ProjectID string `json:"projectId,omitempty"`
|
|
RoleKeys []string `json:"roleKeys,omitempty"`
|
|
}
|
|
|
|
type UserGrantID struct {
|
|
es_models.ObjectRoot
|
|
GrantID string `json:"grantId"`
|
|
}
|
|
|
|
func (g *UserGrant) Changes(changed *UserGrant) map[string]interface{} {
|
|
changes := make(map[string]interface{}, 1)
|
|
if !reflect.DeepEqual(g.RoleKeys, changed.RoleKeys) {
|
|
changes["roleKeys"] = changed.RoleKeys
|
|
}
|
|
return changes
|
|
}
|
|
|
|
func UserGrantFromModel(grant *model.UserGrant) *UserGrant {
|
|
return &UserGrant{
|
|
ObjectRoot: grant.ObjectRoot,
|
|
UserID: grant.UserID,
|
|
ProjectID: grant.ProjectID,
|
|
State: int32(grant.State),
|
|
RoleKeys: grant.RoleKeys,
|
|
}
|
|
}
|
|
|
|
func UserGrantToModel(grant *UserGrant) *model.UserGrant {
|
|
return &model.UserGrant{
|
|
ObjectRoot: grant.ObjectRoot,
|
|
UserID: grant.UserID,
|
|
ProjectID: grant.ProjectID,
|
|
State: model.UserGrantState(grant.State),
|
|
RoleKeys: grant.RoleKeys,
|
|
}
|
|
}
|
|
|
|
func (g *UserGrant) AppendEvents(events ...*es_models.Event) error {
|
|
for _, event := range events {
|
|
if err := g.AppendEvent(event); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (g *UserGrant) AppendEvent(event *es_models.Event) error {
|
|
g.ObjectRoot.AppendEvent(event)
|
|
switch event.Type {
|
|
case UserGrantAdded,
|
|
UserGrantChanged,
|
|
UserGrantCascadeChanged:
|
|
return g.setData(event)
|
|
case UserGrantDeactivated:
|
|
g.appendGrantStateEvent(model.USERGRANTSTATE_INACTIVE)
|
|
case UserGrantReactivated:
|
|
g.appendGrantStateEvent(model.USERGRANTSTATE_ACTIVE)
|
|
case UserGrantRemoved,
|
|
UserGrantCascadeRemoved:
|
|
g.appendGrantStateEvent(model.USERGRANTSTATE_REMOVED)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (g *UserGrant) appendGrantStateEvent(state model.UserGrantState) {
|
|
g.State = int32(state)
|
|
}
|
|
|
|
func (g *UserGrant) setData(event *es_models.Event) error {
|
|
if err := json.Unmarshal(event.Data, g); err != nil {
|
|
logging.Log("EVEN-lso9x").WithError(err).Error("could not unmarshal event data")
|
|
return caos_errs.ThrowInternal(err, "MODEL-o0se3", "could not unmarshal event")
|
|
}
|
|
return nil
|
|
}
|