2022-01-26 09:16:33 +00:00
|
|
|
package eventstore
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2022-04-26 23:01:45 +00:00
|
|
|
"github.com/zitadel/zitadel/internal/api/authz"
|
|
|
|
"github.com/zitadel/zitadel/internal/authz/repository/eventsourcing/view"
|
|
|
|
"github.com/zitadel/zitadel/internal/domain"
|
|
|
|
user_model "github.com/zitadel/zitadel/internal/user/model"
|
|
|
|
user_view_model "github.com/zitadel/zitadel/internal/user/repository/view/model"
|
2022-01-26 09:16:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type UserMembershipRepo struct {
|
|
|
|
View *view.View
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *UserMembershipRepo) Health() error {
|
|
|
|
return repo.View.Health()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *UserMembershipRepo) SearchMyMemberships(ctx context.Context) ([]*authz.Membership, error) {
|
|
|
|
memberships, err := repo.searchUserMemberships(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return userMembershipsToMemberships(memberships), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *UserMembershipRepo) searchUserMemberships(ctx context.Context) ([]*user_view_model.UserMembershipView, error) {
|
|
|
|
ctxData := authz.GetCtxData(ctx)
|
2022-03-23 08:02:39 +00:00
|
|
|
instance := authz.GetInstance(ctx)
|
2022-01-26 09:16:33 +00:00
|
|
|
orgMemberships, orgCount, err := repo.View.SearchUserMemberships(&user_model.UserMembershipSearchRequest{
|
|
|
|
Queries: []*user_model.UserMembershipSearchQuery{
|
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyUserID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
Value: ctxData.UserID,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyResourceOwner,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
Value: ctxData.OrgID,
|
|
|
|
},
|
2022-03-23 08:02:39 +00:00
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyInstanceID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
2022-03-29 09:53:19 +00:00
|
|
|
Value: instance.InstanceID(),
|
2022-03-23 08:02:39 +00:00
|
|
|
},
|
2022-01-26 09:16:33 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
iamMemberships, iamCount, err := repo.View.SearchUserMemberships(&user_model.UserMembershipSearchRequest{
|
|
|
|
Queries: []*user_model.UserMembershipSearchQuery{
|
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyUserID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
|
|
|
Value: ctxData.UserID,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyAggregateID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
2022-04-05 05:58:09 +00:00
|
|
|
Value: instance.InstanceID(),
|
2022-01-26 09:16:33 +00:00
|
|
|
},
|
2022-03-23 08:02:39 +00:00
|
|
|
{
|
|
|
|
Key: user_model.UserMembershipSearchKeyInstanceID,
|
|
|
|
Method: domain.SearchMethodEquals,
|
2022-03-29 09:53:19 +00:00
|
|
|
Value: instance.InstanceID(),
|
2022-03-23 08:02:39 +00:00
|
|
|
},
|
2022-01-26 09:16:33 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if orgCount == 0 && iamCount == 0 {
|
|
|
|
return []*user_view_model.UserMembershipView{}, nil
|
|
|
|
}
|
|
|
|
return append(orgMemberships, iamMemberships...), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func userMembershipToMembership(membership *user_view_model.UserMembershipView) *authz.Membership {
|
|
|
|
return &authz.Membership{
|
|
|
|
MemberType: authz.MemberType(membership.MemberType),
|
|
|
|
AggregateID: membership.AggregateID,
|
|
|
|
ObjectID: membership.ObjectID,
|
|
|
|
Roles: membership.Roles,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func userMembershipsToMemberships(memberships []*user_view_model.UserMembershipView) []*authz.Membership {
|
|
|
|
result := make([]*authz.Membership, len(memberships))
|
|
|
|
for i, m := range memberships {
|
|
|
|
result[i] = userMembershipToMembership(m)
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|