mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-13 11:34:26 +00:00
a321d850ae
* fix logging * token verification * feat: assert roles * feat: add project role assertion on project and token type on app * id and access token role assertion * add project role check * user grant required step in login * update library * fix merge * fix merge * fix merge * update oidc library * fix tests * add tests for GrantRequiredStep * add missing field ProjectRoleCheck on project view model * fix project create * fix project create
93 lines
3.4 KiB
Go
93 lines
3.4 KiB
Go
package view
|
|
|
|
import (
|
|
usr_model "github.com/caos/zitadel/internal/user/model"
|
|
"github.com/caos/zitadel/internal/user/repository/view"
|
|
"github.com/caos/zitadel/internal/user/repository/view/model"
|
|
"github.com/caos/zitadel/internal/view/repository"
|
|
)
|
|
|
|
const (
|
|
userMembershipTable = "auth.user_memberships"
|
|
)
|
|
|
|
func (v *View) UserMembershipByIDs(userID, aggregateID, objectID string, memberType usr_model.MemberType) (*model.UserMembershipView, error) {
|
|
return view.UserMembershipByIDs(v.Db, userMembershipTable, userID, aggregateID, objectID, memberType)
|
|
}
|
|
|
|
func (v *View) UserMembershipsByAggregateID(aggregateID string) ([]*model.UserMembershipView, error) {
|
|
return view.UserMembershipsByAggregateID(v.Db, userMembershipTable, aggregateID)
|
|
}
|
|
|
|
func (v *View) UserMembershipsByResourceOwner(resourceOwner string) ([]*model.UserMembershipView, error) {
|
|
return view.UserMembershipsByResourceOwner(v.Db, userMembershipTable, resourceOwner)
|
|
}
|
|
|
|
func (v *View) SearchUserMemberships(request *usr_model.UserMembershipSearchRequest) ([]*model.UserMembershipView, uint64, error) {
|
|
return view.SearchUserMemberships(v.Db, userMembershipTable, request)
|
|
}
|
|
|
|
func (v *View) PutUserMembership(membership *model.UserMembershipView, sequence uint64) error {
|
|
err := view.PutUserMembership(v.Db, userMembershipTable, membership)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return v.ProcessedUserMembershipSequence(sequence)
|
|
}
|
|
|
|
func (v *View) BulkPutUserMemberships(memberships []*model.UserMembershipView, sequence uint64) error {
|
|
err := view.PutUserMemberships(v.Db, userMembershipTable, memberships...)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return v.ProcessedUserMembershipSequence(sequence)
|
|
}
|
|
|
|
func (v *View) DeleteUserMembership(userID, aggregateID, objectID string, memberType usr_model.MemberType, eventSequence uint64) error {
|
|
err := view.DeleteUserMembership(v.Db, userMembershipTable, userID, aggregateID, objectID, memberType)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedUserMembershipSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteUserMembershipsByUserID(userID string, eventSequence uint64) error {
|
|
err := view.DeleteUserMembershipsByUserID(v.Db, userMembershipTable, userID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedUserMembershipSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteUserMembershipsByAggregateID(aggregateID string, eventSequence uint64) error {
|
|
err := view.DeleteUserMembershipsByAggregateID(v.Db, userMembershipTable, aggregateID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedUserMembershipSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) DeleteUserMembershipsByAggregateIDAndObjectID(aggregateID, objectID string, eventSequence uint64) error {
|
|
err := view.DeleteUserMembershipsByAggregateIDAndObjectID(v.Db, userMembershipTable, aggregateID, objectID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
return v.ProcessedUserMembershipSequence(eventSequence)
|
|
}
|
|
|
|
func (v *View) GetLatestUserMembershipSequence() (*repository.CurrentSequence, error) {
|
|
return v.latestSequence(userMembershipTable)
|
|
}
|
|
|
|
func (v *View) ProcessedUserMembershipSequence(eventSequence uint64) error {
|
|
return v.saveCurrentSequence(userMembershipTable, eventSequence)
|
|
}
|
|
|
|
func (v *View) GetLatestUserMembershipFailedEvent(sequence uint64) (*repository.FailedEvent, error) {
|
|
return v.latestFailedEvent(userMembershipTable, sequence)
|
|
}
|
|
|
|
func (v *View) ProcessedUserMembershipFailedEvent(failedEvent *repository.FailedEvent) error {
|
|
return v.saveFailedEvent(failedEvent)
|
|
}
|