mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-14 20:08:02 +00:00
d2ea9a1b8c
* refactor(domain): add user type * fix(projections): start with login names * fix(login_policy): correct handling of user domain claimed event * fix(projections): add members * refactor: simplify member projections * add migration for members * add metadata to member projections * refactor: login name projection * fix: set correct suffixes on login name projections * test(projections): login name reduces * fix: correct cols in reduce member * test(projections): org, iam, project members * member additional cols and conds as opt, add project grant members * fix(migration): members * fix(migration): correct database name * migration version * migs * better naming for member cond and col * split project and project grant members * prepare member columns * feat(queries): membership query * test(queries): membership prepare * fix(queries): multiple projections for latest sequence * fix(api): use query for membership queries in auth and management * feat: org member queries * fix(api): use query for iam member calls * fix(queries): org members * fix(queries): project members * fix(queries): project grant members * fix(query): member queries and user avatar column * member cols * fix(queries): membership stmt * fix user test * fix user test * fix(membership): correct display name * fix(projection): additional member manipulation events * additional member tests * fix(projections): additional events of idp links * fix: use query for memberships (#2797) * fix(api): use query for memberships * remove comment * handle err * refactor(projections): idp user link user aggregate type * fix(projections): handle old user events * fix(api): add asset prefix * no image for iam members
77 lines
2.0 KiB
Go
77 lines
2.0 KiB
Go
package management
|
|
|
|
import (
|
|
"google.golang.org/grpc"
|
|
|
|
"github.com/caos/zitadel/internal/api/authz"
|
|
"github.com/caos/zitadel/internal/api/grpc/server"
|
|
"github.com/caos/zitadel/internal/command"
|
|
"github.com/caos/zitadel/internal/config/systemdefaults"
|
|
"github.com/caos/zitadel/internal/management/repository"
|
|
"github.com/caos/zitadel/internal/management/repository/eventsourcing"
|
|
"github.com/caos/zitadel/internal/query"
|
|
"github.com/caos/zitadel/pkg/grpc/management"
|
|
)
|
|
|
|
const (
|
|
mgmtName = "Management-API"
|
|
)
|
|
|
|
var _ management.ManagementServiceServer = (*Server)(nil)
|
|
|
|
type Server struct {
|
|
management.UnimplementedManagementServiceServer
|
|
command *command.Commands
|
|
query *query.Queries
|
|
project repository.ProjectRepository
|
|
org repository.OrgRepository
|
|
user repository.UserRepository
|
|
usergrant repository.UserGrantRepository
|
|
iam repository.IamRepository
|
|
authZ authz.Config
|
|
systemDefaults systemdefaults.SystemDefaults
|
|
assetAPIPrefix string
|
|
}
|
|
|
|
type Config struct {
|
|
Repository eventsourcing.Config
|
|
}
|
|
|
|
func CreateServer(command *command.Commands, query *query.Queries, repo repository.Repository, sd systemdefaults.SystemDefaults, assetAPIPrefix string) *Server {
|
|
return &Server{
|
|
command: command,
|
|
query: query,
|
|
project: repo,
|
|
org: repo,
|
|
user: repo,
|
|
usergrant: repo,
|
|
iam: repo,
|
|
systemDefaults: sd,
|
|
assetAPIPrefix: assetAPIPrefix,
|
|
}
|
|
}
|
|
|
|
func (s *Server) RegisterServer(grpcServer *grpc.Server) {
|
|
management.RegisterManagementServiceServer(grpcServer, s)
|
|
}
|
|
|
|
func (s *Server) AppName() string {
|
|
return mgmtName
|
|
}
|
|
|
|
func (s *Server) MethodPrefix() string {
|
|
return management.ManagementService_MethodPrefix
|
|
}
|
|
|
|
func (s *Server) AuthMethods() authz.MethodMapping {
|
|
return management.ManagementService_AuthMethods
|
|
}
|
|
|
|
func (s *Server) RegisterGateway() server.GatewayFunc {
|
|
return management.RegisterManagementServiceHandlerFromEndpoint
|
|
}
|
|
|
|
func (s *Server) GatewayPathPrefix() string {
|
|
return "/management/v1"
|
|
}
|