2020-05-12 04:30:53 +00:00
|
|
|
package model
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2020-05-26 14:46:16 +00:00
|
|
|
"time"
|
|
|
|
|
2020-05-12 04:30:53 +00:00
|
|
|
"github.com/caos/logging"
|
2020-10-16 05:49:38 +00:00
|
|
|
"github.com/lib/pq"
|
|
|
|
|
2020-05-12 04:30:53 +00:00
|
|
|
caos_errs "github.com/caos/zitadel/internal/errors"
|
2021-02-23 14:13:04 +00:00
|
|
|
"github.com/caos/zitadel/internal/eventstore/v1/models"
|
2020-05-12 04:30:53 +00:00
|
|
|
"github.com/caos/zitadel/internal/usergrant/model"
|
|
|
|
es_model "github.com/caos/zitadel/internal/usergrant/repository/eventsourcing/model"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
UserGrantKeyID = "id"
|
|
|
|
UserGrantKeyUserID = "user_id"
|
|
|
|
UserGrantKeyProjectID = "project_id"
|
2020-08-27 12:44:52 +00:00
|
|
|
UserGrantKeyGrantID = "grant_id"
|
2020-05-12 04:30:53 +00:00
|
|
|
UserGrantKeyResourceOwner = "resource_owner"
|
|
|
|
UserGrantKeyState = "state"
|
2020-06-05 05:50:04 +00:00
|
|
|
UserGrantKeyOrgName = "org_name"
|
2020-06-19 13:32:03 +00:00
|
|
|
UserGrantKeyRole = "role_keys"
|
2020-11-03 06:52:49 +00:00
|
|
|
UserGrantKeyUserName = "user_name"
|
|
|
|
UserGrantKeyFirstName = "first_name"
|
|
|
|
UserGrantKeyLastName = "last_name"
|
|
|
|
UserGrantKeyEmail = "email"
|
|
|
|
UserGrantKeyOrgDomain = "org_primary_domain"
|
|
|
|
UserGrantKeyProjectName = "project_name"
|
|
|
|
UserGrantKeyDisplayName = "display_name"
|
2020-05-12 04:30:53 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type UserGrantView struct {
|
2020-10-16 05:49:38 +00:00
|
|
|
ID string `json:"-" gorm:"column:id;primary_key"`
|
|
|
|
ResourceOwner string `json:"-" gorm:"resource_owner"`
|
|
|
|
UserID string `json:"userId" gorm:"user_id"`
|
|
|
|
ProjectID string `json:"projectId" gorm:"column:project_id"`
|
|
|
|
GrantID string `json:"grantId" gorm:"column:grant_id"`
|
|
|
|
UserName string `json:"-" gorm:"column:user_name"`
|
|
|
|
FirstName string `json:"-" gorm:"column:first_name"`
|
|
|
|
LastName string `json:"-" gorm:"column:last_name"`
|
|
|
|
DisplayName string `json:"-" gorm:"column:display_name"`
|
|
|
|
Email string `json:"-" gorm:"column:email"`
|
|
|
|
ProjectName string `json:"-" gorm:"column:project_name"`
|
2020-11-19 13:13:07 +00:00
|
|
|
ProjectOwner string `json:"-" gorm:"column:project_owner"`
|
2020-10-16 05:49:38 +00:00
|
|
|
OrgName string `json:"-" gorm:"column:org_name"`
|
|
|
|
OrgPrimaryDomain string `json:"-" gorm:"column:org_primary_domain"`
|
|
|
|
RoleKeys pq.StringArray `json:"roleKeys" gorm:"column:role_keys"`
|
2020-05-12 04:30:53 +00:00
|
|
|
|
|
|
|
CreationDate time.Time `json:"-" gorm:"column:creation_date"`
|
|
|
|
ChangeDate time.Time `json:"-" gorm:"column:change_date"`
|
|
|
|
State int32 `json:"-" gorm:"column:grant_state"`
|
|
|
|
|
|
|
|
Sequence uint64 `json:"-" gorm:"column:sequence"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func UserGrantToModel(grant *UserGrantView) *model.UserGrantView {
|
|
|
|
return &model.UserGrantView{
|
2020-10-16 05:49:38 +00:00
|
|
|
ID: grant.ID,
|
|
|
|
ResourceOwner: grant.ResourceOwner,
|
|
|
|
UserID: grant.UserID,
|
|
|
|
ProjectID: grant.ProjectID,
|
|
|
|
ChangeDate: grant.ChangeDate,
|
|
|
|
CreationDate: grant.CreationDate,
|
|
|
|
State: model.UserGrantState(grant.State),
|
|
|
|
UserName: grant.UserName,
|
|
|
|
FirstName: grant.FirstName,
|
|
|
|
LastName: grant.LastName,
|
|
|
|
DisplayName: grant.DisplayName,
|
|
|
|
Email: grant.Email,
|
|
|
|
ProjectName: grant.ProjectName,
|
|
|
|
OrgName: grant.OrgName,
|
|
|
|
OrgPrimaryDomain: grant.OrgPrimaryDomain,
|
|
|
|
RoleKeys: grant.RoleKeys,
|
|
|
|
Sequence: grant.Sequence,
|
2020-10-19 15:10:02 +00:00
|
|
|
GrantID: grant.GrantID,
|
2020-05-12 04:30:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func UserGrantsToModel(grants []*UserGrantView) []*model.UserGrantView {
|
|
|
|
result := make([]*model.UserGrantView, len(grants))
|
|
|
|
for i, g := range grants {
|
|
|
|
result[i] = UserGrantToModel(g)
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
|
|
|
func (g *UserGrantView) AppendEvent(event *models.Event) (err error) {
|
|
|
|
g.ChangeDate = event.CreationDate
|
|
|
|
g.Sequence = event.Sequence
|
|
|
|
switch event.Type {
|
|
|
|
case es_model.UserGrantAdded:
|
2020-06-23 12:47:47 +00:00
|
|
|
g.State = int32(model.UserGrantStateActive)
|
2020-05-12 04:30:53 +00:00
|
|
|
g.CreationDate = event.CreationDate
|
|
|
|
g.setRootData(event)
|
|
|
|
err = g.setData(event)
|
2020-06-19 13:32:03 +00:00
|
|
|
case es_model.UserGrantChanged, es_model.UserGrantCascadeChanged:
|
2020-05-12 04:30:53 +00:00
|
|
|
err = g.setData(event)
|
|
|
|
case es_model.UserGrantDeactivated:
|
2020-06-23 12:47:47 +00:00
|
|
|
g.State = int32(model.UserGrantStateInactive)
|
2020-05-12 04:30:53 +00:00
|
|
|
case es_model.UserGrantReactivated:
|
2020-06-23 12:47:47 +00:00
|
|
|
g.State = int32(model.UserGrantStateActive)
|
2020-05-12 04:30:53 +00:00
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (u *UserGrantView) setRootData(event *models.Event) {
|
|
|
|
u.ID = event.AggregateID
|
|
|
|
u.ResourceOwner = event.ResourceOwner
|
|
|
|
}
|
|
|
|
|
|
|
|
func (u *UserGrantView) setData(event *models.Event) error {
|
|
|
|
if err := json.Unmarshal(event.Data, u); err != nil {
|
|
|
|
logging.Log("EVEN-l9sw4").WithError(err).Error("could not unmarshal event data")
|
|
|
|
return caos_errs.ThrowInternal(nil, "MODEL-7xhke", "could not unmarshal data")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|