mirror of
https://github.com/zitadel/zitadel.git
synced 2025-05-17 08:38:20 +00:00
faet: add usermemberships request to auth api (#2139)
This commit is contained in:
parent
c9290dc1a5
commit
ae50f57c2c
@ -533,6 +533,19 @@ Returns a list of roles for the authorized user and project
|
|||||||
POST: /permissions/me/_search
|
POST: /permissions/me/_search
|
||||||
|
|
||||||
|
|
||||||
|
### ListMyMemberships
|
||||||
|
|
||||||
|
> **rpc** ListMyMemberships([ListMyMembershipsRequest](#listmymembershipsrequest))
|
||||||
|
[ListMyMembershipsResponse](#listmymembershipsresponse)
|
||||||
|
|
||||||
|
Show all the permissions my user has in ZITADEL (ZITADEL Manager)
|
||||||
|
Limit should always be set, there is a default limit set by the service
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
POST: /memberships/me/_search
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -774,6 +787,30 @@ This is an empty request
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### ListMyMembershipsRequest
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Field | Type | Description | Validation |
|
||||||
|
| ----- | ---- | ----------- | ----------- |
|
||||||
|
| query | zitadel.v1.ListQuery | the field the result is sorted | |
|
||||||
|
| queries | repeated zitadel.user.v1.MembershipQuery | criterias the client is looking for | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### ListMyMembershipsResponse
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Field | Type | Description | Validation |
|
||||||
|
| ----- | ---- | ----------- | ----------- |
|
||||||
|
| details | zitadel.v1.ListDetails | - | |
|
||||||
|
| result | repeated zitadel.user.v1.Membership | - | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### ListMyPasswordlessRequest
|
### ListMyPasswordlessRequest
|
||||||
This is an empty request
|
This is an empty request
|
||||||
|
|
||||||
|
@ -6246,7 +6246,7 @@ This is an empty request
|
|||||||
|
|
||||||
|
|
||||||
### ResetCustomPasswordlessRegistrationMessageTextToDefaultRequest
|
### ResetCustomPasswordlessRegistrationMessageTextToDefaultRequest
|
||||||
This is an empty request
|
|
||||||
|
|
||||||
|
|
||||||
| Field | Type | Description | Validation |
|
| Field | Type | Description | Validation |
|
||||||
|
@ -3,6 +3,8 @@ package auth
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
|
obj_grpc "github.com/caos/zitadel/internal/api/grpc/object"
|
||||||
|
user_grpc "github.com/caos/zitadel/internal/api/grpc/user"
|
||||||
auth_pb "github.com/caos/zitadel/pkg/grpc/auth"
|
auth_pb "github.com/caos/zitadel/pkg/grpc/auth"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -25,3 +27,22 @@ func (s *Server) ListMyProjectPermissions(ctx context.Context, _ *auth_pb.ListMy
|
|||||||
Result: perms,
|
Result: perms,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *Server) ListMyMemberships(ctx context.Context, req *auth_pb.ListMyMembershipsRequest) (*auth_pb.ListMyMembershipsResponse, error) {
|
||||||
|
request, err := ListMyMembershipsRequestToModel(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response, err := s.repo.SearchMyUserMemberships(ctx, request)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &auth_pb.ListMyMembershipsResponse{
|
||||||
|
Result: user_grpc.MembershipsToMembershipsPb(response.Result),
|
||||||
|
Details: obj_grpc.ToListDetails(
|
||||||
|
response.TotalResult,
|
||||||
|
response.Sequence,
|
||||||
|
response.Timestamp,
|
||||||
|
),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
23
internal/api/grpc/auth/permission_converter.go
Normal file
23
internal/api/grpc/auth/permission_converter.go
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
package auth
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/caos/zitadel/internal/api/grpc/object"
|
||||||
|
user_grpc "github.com/caos/zitadel/internal/api/grpc/user"
|
||||||
|
user_model "github.com/caos/zitadel/internal/user/model"
|
||||||
|
auth_pb "github.com/caos/zitadel/pkg/grpc/auth"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ListMyMembershipsRequestToModel(req *auth_pb.ListMyMembershipsRequest) (*user_model.UserMembershipSearchRequest, error) {
|
||||||
|
offset, limit, asc := object.ListQueryToModel(req.Query)
|
||||||
|
queries, err := user_grpc.MembershipQueriesToModel(req.Queries)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &user_model.UserMembershipSearchRequest{
|
||||||
|
Offset: offset,
|
||||||
|
Limit: limit,
|
||||||
|
Asc: asc,
|
||||||
|
//SortingColumn: //TODO: sorting
|
||||||
|
Queries: queries,
|
||||||
|
}, nil
|
||||||
|
}
|
@ -107,6 +107,7 @@ func (repo *UserGrantRepo) SearchMyUserMemberships(ctx context.Context, request
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
request.AppendUserIDQuery(authz.GetCtxData(ctx).UserID)
|
||||||
sequence, sequenceErr := repo.View.GetLatestUserMembershipSequence()
|
sequence, sequenceErr := repo.View.GetLatestUserMembershipSequence()
|
||||||
logging.Log("EVENT-Dn7sf").OnError(sequenceErr).Warn("could not read latest user sequence")
|
logging.Log("EVENT-Dn7sf").OnError(sequenceErr).Warn("could not read latest user sequence")
|
||||||
|
|
||||||
|
@ -534,6 +534,19 @@ service AuthService {
|
|||||||
permission: "authenticated"
|
permission: "authenticated"
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Show all the permissions my user has in ZITADEL (ZITADEL Manager)
|
||||||
|
// Limit should always be set, there is a default limit set by the service
|
||||||
|
rpc ListMyMemberships(ListMyMembershipsRequest) returns (ListMyMembershipsResponse) {
|
||||||
|
option (google.api.http) = {
|
||||||
|
post: "/memberships/me/_search"
|
||||||
|
body: "*"
|
||||||
|
};
|
||||||
|
|
||||||
|
option (zitadel.v1.auth_option) = {
|
||||||
|
permission: "authenticated"
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//This is an empty request
|
//This is an empty request
|
||||||
@ -896,3 +909,15 @@ message ListMyProjectPermissionsRequest {}
|
|||||||
message ListMyProjectPermissionsResponse {
|
message ListMyProjectPermissionsResponse {
|
||||||
repeated string result = 1;
|
repeated string result = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message ListMyMembershipsRequest {
|
||||||
|
//the field the result is sorted
|
||||||
|
zitadel.v1.ListQuery query = 1;
|
||||||
|
//criterias the client is looking for
|
||||||
|
repeated zitadel.user.v1.MembershipQuery queries = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message ListMyMembershipsResponse {
|
||||||
|
zitadel.v1.ListDetails details = 1;
|
||||||
|
repeated zitadel.user.v1.Membership result = 2;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user