mirror of
https://github.com/zitadel/zitadel.git
synced 2025-08-11 17:27:31 +00:00
start
This commit is contained in:
34
backend/v3/api/org/v2/domain.go
Normal file
34
backend/v3/api/org/v2/domain.go
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
package org
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"connectrpc.com/connect"
|
||||||
|
|
||||||
|
org "github.com/zitadel/zitadel/pkg/grpc/org/v2beta"
|
||||||
|
)
|
||||||
|
|
||||||
|
// AddOrganizationDomain implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) AddOrganizationDomain(ctx context.Context, req *connect.Request[org.AddOrganizationDomainRequest]) (*connect.Response[org.AddOrganizationDomainResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.AddOrganizationDomain(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeleteOrganizationDomain implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) DeleteOrganizationDomain(ctx context.Context, req *connect.Request[org.DeleteOrganizationDomainRequest]) (*connect.Response[org.DeleteOrganizationDomainResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.DeleteOrganizationDomain(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GenerateOrganizationDomainValidation implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) GenerateOrganizationDomainValidation(ctx context.Context, req *connect.Request[org.GenerateOrganizationDomainValidationRequest]) (*connect.Response[org.GenerateOrganizationDomainValidationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.GenerateOrganizationDomainValidation(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ListOrganizationDomains implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) ListOrganizationDomains(ctx context.Context, req *connect.Request[org.ListOrganizationDomainsRequest]) (*connect.Response[org.ListOrganizationDomainsResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.ListOrganizationDomains(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// VerifyOrganizationDomain implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) VerifyOrganizationDomain(ctx context.Context, req *connect.Request[org.VerifyOrganizationDomainRequest]) (*connect.Response[org.VerifyOrganizationDomainResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.VerifyOrganizationDomain(ctx, req)
|
||||||
|
}
|
24
backend/v3/api/org/v2/metadata.go
Normal file
24
backend/v3/api/org/v2/metadata.go
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package org
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"connectrpc.com/connect"
|
||||||
|
|
||||||
|
org "github.com/zitadel/zitadel/pkg/grpc/org/v2beta"
|
||||||
|
)
|
||||||
|
|
||||||
|
// DeleteOrganizationMetadata implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) DeleteOrganizationMetadata(ctx context.Context, req *connect.Request[org.DeleteOrganizationMetadataRequest]) (*connect.Response[org.DeleteOrganizationMetadataResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.DeleteOrganizationMetadata(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ListOrganizationMetadata implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) ListOrganizationMetadata(ctx context.Context, req *connect.Request[org.ListOrganizationMetadataRequest]) (*connect.Response[org.ListOrganizationMetadataResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.ListOrganizationMetadata(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetOrganizationMetadata implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) SetOrganizationMetadata(ctx context.Context, req *connect.Request[org.SetOrganizationMetadataRequest]) (*connect.Response[org.SetOrganizationMetadataResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.SetOrganizationMetadata(ctx, req)
|
||||||
|
}
|
@@ -1,4 +1,12 @@
|
|||||||
package orgv2
|
package org
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"connectrpc.com/connect"
|
||||||
|
|
||||||
|
org "github.com/zitadel/zitadel/pkg/grpc/org/v2beta"
|
||||||
|
)
|
||||||
|
|
||||||
// import (
|
// import (
|
||||||
// "context"
|
// "context"
|
||||||
@@ -31,3 +39,33 @@ package orgv2
|
|||||||
// }
|
// }
|
||||||
// return cmds
|
// return cmds
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
// ActivateOrganization implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) ActivateOrganization(ctx context.Context, req *connect.Request[org.ActivateOrganizationRequest]) (*connect.Response[org.ActivateOrganizationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.ActivateOrganization(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// CreateOrganization implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) CreateOrganization(ctx context.Context, req *connect.Request[org.CreateOrganizationRequest]) (*connect.Response[org.CreateOrganizationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.CreateOrganization(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeactivateOrganization implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) DeactivateOrganization(ctx context.Context, req *connect.Request[org.DeactivateOrganizationRequest]) (*connect.Response[org.DeactivateOrganizationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.DeactivateOrganization(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeleteOrganization implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) DeleteOrganization(ctx context.Context, req *connect.Request[org.DeleteOrganizationRequest]) (*connect.Response[org.DeleteOrganizationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.DeleteOrganization(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ListOrganizations implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) ListOrganizations(ctx context.Context, req *connect.Request[org.ListOrganizationsRequest]) (*connect.Response[org.ListOrganizationsResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.ListOrganizations(ctx, req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateOrganization implements [orgconnect.OrganizationServiceHandler].
|
||||||
|
func (s *Server) UpdateOrganization(ctx context.Context, req *connect.Request[org.UpdateOrganizationRequest]) (*connect.Response[org.UpdateOrganizationResponse], error) {
|
||||||
|
return s.UnimplementedOrganizationServiceHandler.UpdateOrganization(ctx, req)
|
||||||
|
}
|
||||||
|
@@ -1,21 +1,23 @@
|
|||||||
package orgv2
|
package org
|
||||||
|
|
||||||
// this file has been commented out to pass the linter
|
import (
|
||||||
|
"github.com/zitadel/zitadel/backend/v3/telemetry/logging"
|
||||||
|
"github.com/zitadel/zitadel/backend/v3/telemetry/tracing"
|
||||||
|
"github.com/zitadel/zitadel/pkg/grpc/org/v2beta/orgconnect"
|
||||||
|
)
|
||||||
|
|
||||||
// import (
|
var _ orgconnect.OrganizationServiceHandler = (*Server)(nil)
|
||||||
// "github.com/zitadel/zitadel/backend/v3/telemetry/logging"
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/telemetry/tracing"
|
|
||||||
// )
|
|
||||||
|
|
||||||
// var (
|
type Server struct {
|
||||||
// logger logging.Logger
|
orgconnect.UnimplementedOrganizationServiceHandler
|
||||||
// tracer tracing.Tracer
|
|
||||||
// )
|
|
||||||
|
|
||||||
// func SetLogger(l logging.Logger) {
|
logger logging.Logger
|
||||||
// logger = l
|
tracer tracing.Tracer
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func SetTracer(t tracing.Tracer) {
|
func NewServer(logger logging.Logger, tracer tracing.Tracer) *Server {
|
||||||
// tracer = t
|
return &Server{
|
||||||
// }
|
logger: logger,
|
||||||
|
tracer: tracer,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -1,131 +1,135 @@
|
|||||||
package domain
|
package domain
|
||||||
|
|
||||||
// import (
|
import (
|
||||||
// "context"
|
"context"
|
||||||
// "fmt"
|
"fmt"
|
||||||
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/storage/database"
|
"github.com/zitadel/zitadel/backend/v3/storage/database"
|
||||||
// )
|
)
|
||||||
|
|
||||||
// // Commander is the all it needs to implement the command pattern.
|
// Commander is all it needs to implement the [command pattern](https://refactoring.guru/design-patterns/command).
|
||||||
// // It is the interface all manipulations need to implement.
|
// It is the interface all manipulations need to implement.
|
||||||
// // If possible it should also be used for queries. We will find out if this is possible in the future.
|
// If possible it should also be used for queries. We will find out if this is possible in the future.
|
||||||
// type Commander interface {
|
type Commander interface {
|
||||||
// Execute(ctx context.Context, opts *CommandOpts) (err error)
|
Execute(ctx context.Context, opts *CommandOpts) (err error)
|
||||||
// fmt.Stringer
|
fmt.Stringer
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // Invoker is part of the command pattern.
|
// Invoker is part of the command pattern.
|
||||||
// // It is the interface that is used to execute commands.
|
// It is the interface that is used to execute commands.
|
||||||
// type Invoker interface {
|
type Invoker interface {
|
||||||
// Invoke(ctx context.Context, command Commander, opts *CommandOpts) error
|
Invoke(ctx context.Context, command Commander, opts *CommandOpts) error
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // CommandOpts are passed to each command
|
// CommandOpts are passed to each command
|
||||||
// // the provide common fields used by commands like the database client.
|
// they provide common fields used by commands like the database client.
|
||||||
// type CommandOpts struct {
|
type CommandOpts struct {
|
||||||
// DB database.QueryExecutor
|
DB database.QueryExecutor
|
||||||
// Invoker Invoker
|
Invoker Invoker
|
||||||
// }
|
}
|
||||||
|
|
||||||
// type ensureTxOpts struct {
|
type ensureTxOpts struct {
|
||||||
// *database.TransactionOptions
|
*database.TransactionOptions
|
||||||
// }
|
}
|
||||||
|
|
||||||
// type EnsureTransactionOpt func(*ensureTxOpts)
|
type EnsureTransactionOpt func(*ensureTxOpts)
|
||||||
|
|
||||||
// // EnsureTx ensures that the DB is a transaction. If it is not, it will start a new transaction.
|
// EnsureTx ensures that o.DB is a [database.Transaction]. If it is not, it will start a new [database.Transaction].
|
||||||
// // The returned close function will end the transaction. If the DB is already a transaction, the close function
|
// The returned close function will end the [database.Transaction]. If the DB is already a [database.Transaction], the close function
|
||||||
// // will do nothing because another [Commander] is already responsible for ending the transaction.
|
// will do nothing because another [Commander] is already responsible for ending the [database.Transaction].
|
||||||
// func (o *CommandOpts) EnsureTx(ctx context.Context, opts ...EnsureTransactionOpt) (close func(context.Context, error) error, err error) {
|
func (o *CommandOpts) EnsureTx(ctx context.Context, opts ...EnsureTransactionOpt) (close func(context.Context, error) error, err error) {
|
||||||
// beginner, ok := o.DB.(database.Beginner)
|
beginner, ok := o.DB.(database.Beginner)
|
||||||
// if !ok {
|
if !ok {
|
||||||
// // db is already a transaction
|
// db is already a transaction
|
||||||
// return func(_ context.Context, err error) error {
|
return func(_ context.Context, err error) error {
|
||||||
// return err
|
return err
|
||||||
// }, nil
|
}, nil
|
||||||
// }
|
}
|
||||||
|
|
||||||
// txOpts := &ensureTxOpts{
|
txOpts := &ensureTxOpts{
|
||||||
// TransactionOptions: new(database.TransactionOptions),
|
TransactionOptions: new(database.TransactionOptions),
|
||||||
// }
|
}
|
||||||
// for _, opt := range opts {
|
for _, opt := range opts {
|
||||||
// opt(txOpts)
|
opt(txOpts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// tx, err := beginner.Begin(ctx, txOpts.TransactionOptions)
|
tx, err := beginner.Begin(ctx, txOpts.TransactionOptions)
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// return nil, err
|
return nil, err
|
||||||
// }
|
}
|
||||||
// o.DB = tx
|
o.DB = tx
|
||||||
|
|
||||||
// return func(ctx context.Context, err error) error {
|
return func(ctx context.Context, err error) error {
|
||||||
// return tx.End(ctx, err)
|
return tx.End(ctx, err)
|
||||||
// }, nil
|
}, nil
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // EnsureClient ensures that the o.DB is a client. If it is not, it will get a new client from the [database.Pool].
|
// EnsureClient ensures that o.DB is a [database.Client]. If it is not, it will get a new [database.Client] from the [database.Pool].
|
||||||
// // The returned close function will release the client. If the o.DB is already a client or transaction, the close function
|
// The returned close function will release the [database.Client]. If the o.DB is already a [database.Client] or transaction, the close function
|
||||||
// // will do nothing because another [Commander] is already responsible for releasing the client.
|
// will do nothing because another [Commander] is already responsible for releasing the [database.Client].
|
||||||
// func (o *CommandOpts) EnsureClient(ctx context.Context) (close func(_ context.Context) error, err error) {
|
func (o *CommandOpts) EnsureClient(ctx context.Context) (close func(_ context.Context) error, err error) {
|
||||||
// pool, ok := o.DB.(database.Pool)
|
pool, ok := o.DB.(database.Pool)
|
||||||
// if !ok {
|
if !ok {
|
||||||
// // o.DB is already a client
|
// o.DB is already a client
|
||||||
// return func(_ context.Context) error {
|
return func(_ context.Context) error {
|
||||||
// return nil
|
return nil
|
||||||
// }, nil
|
}, nil
|
||||||
// }
|
}
|
||||||
// client, err := pool.Acquire(ctx)
|
client, err := pool.Acquire(ctx)
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// return nil, err
|
return nil, err
|
||||||
// }
|
}
|
||||||
// o.DB = client
|
o.DB = client
|
||||||
// return func(ctx context.Context) error {
|
return func(ctx context.Context) error {
|
||||||
// return client.Release(ctx)
|
return client.Release(ctx)
|
||||||
// }, nil
|
}, nil
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (o *CommandOpts) Invoke(ctx context.Context, command Commander) error {
|
// Invoke implements the [Invoker] interface.
|
||||||
// if o.Invoker == nil {
|
func (o *CommandOpts) Invoke(ctx context.Context, command Commander) error {
|
||||||
// return command.Execute(ctx, o)
|
if o.Invoker == nil {
|
||||||
// }
|
return command.Execute(ctx, o)
|
||||||
// return o.Invoker.Invoke(ctx, command, o)
|
}
|
||||||
// }
|
return o.Invoker.Invoke(ctx, command, o)
|
||||||
|
}
|
||||||
|
|
||||||
// func DefaultOpts(invoker Invoker) *CommandOpts {
|
func DefaultOpts(invoker Invoker) *CommandOpts {
|
||||||
// if invoker == nil {
|
if invoker == nil {
|
||||||
// invoker = &noopInvoker{}
|
invoker = &noopInvoker{}
|
||||||
// }
|
}
|
||||||
// return &CommandOpts{
|
return &CommandOpts{
|
||||||
// DB: pool,
|
DB: pool,
|
||||||
// Invoker: invoker,
|
Invoker: invoker,
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // commandBatch is a batch of commands.
|
// commandBatch is a batch of commands.
|
||||||
// // It uses the [Invoker] provided by the opts to execute each command.
|
// It uses the [Invoker] provided by the opts to execute each command.
|
||||||
// type commandBatch struct {
|
type commandBatch struct {
|
||||||
// Commands []Commander
|
Commands []Commander
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func BatchCommands(cmds ...Commander) *commandBatch {
|
// BatchCommands creates a new command batch.
|
||||||
// return &commandBatch{
|
// The commands are executed in the order they are provided.
|
||||||
// Commands: cmds,
|
// If any command fails, the batch will stop executing and return the error.
|
||||||
// }
|
func BatchCommands(cmds ...Commander) *commandBatch {
|
||||||
// }
|
return &commandBatch{
|
||||||
|
Commands: cmds,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// // String implements [Commander].
|
// String implements [Commander].
|
||||||
// func (cmd *commandBatch) String() string {
|
func (cmd *commandBatch) String() string {
|
||||||
// return "commandBatch"
|
return "commandBatch"
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (b *commandBatch) Execute(ctx context.Context, opts *CommandOpts) (err error) {
|
func (b *commandBatch) Execute(ctx context.Context, opts *CommandOpts) (err error) {
|
||||||
// for _, cmd := range b.Commands {
|
for _, cmd := range b.Commands {
|
||||||
// if err = opts.Invoke(ctx, cmd); err != nil {
|
if err = opts.Invoke(ctx, cmd); err != nil {
|
||||||
// return err
|
return err
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// return nil
|
return nil
|
||||||
// }
|
}
|
||||||
|
|
||||||
// var _ Commander = (*commandBatch)(nil)
|
var _ Commander = (*commandBatch)(nil)
|
||||||
|
63
backend/v3/domain/constants.go
Normal file
63
backend/v3/domain/constants.go
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
package domain
|
||||||
|
|
||||||
|
import (
|
||||||
|
"math/rand/v2"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/zitadel/zitadel/backend/v3/storage/database"
|
||||||
|
"github.com/zitadel/zitadel/backend/v3/telemetry/logging"
|
||||||
|
"github.com/zitadel/zitadel/backend/v3/telemetry/tracing"
|
||||||
|
)
|
||||||
|
|
||||||
|
// The variables could also be moved to a struct.
|
||||||
|
// I just started with the [singleton pattern](https://refactoring.guru/design-patterns/singleton) and kept it like this.
|
||||||
|
var (
|
||||||
|
pool database.Pool
|
||||||
|
// userCodeAlgorithm crypto.EncryptionAlgorithm
|
||||||
|
tracer tracing.Tracer
|
||||||
|
logger logging.Logger
|
||||||
|
|
||||||
|
userRepo func(database.QueryExecutor) UserRepository
|
||||||
|
orgRepo func(database.QueryExecutor) OrganizationRepository
|
||||||
|
// instanceRepo func(database.QueryExecutor) InstanceRepository
|
||||||
|
// cryptoRepo func(database.QueryExecutor) CryptoRepository
|
||||||
|
|
||||||
|
// instanceCache cache.Cache[instanceCacheIndex, string, *Instance]
|
||||||
|
// orgCache cache.Cache[orgCacheIndex, string, *Organization]
|
||||||
|
|
||||||
|
generateID func() (string, error) = func() (string, error) {
|
||||||
|
return strconv.FormatUint(rand.Uint64(), 10), nil
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func SetPool(p database.Pool) {
|
||||||
|
pool = p
|
||||||
|
}
|
||||||
|
|
||||||
|
// func SetUserCodeAlgorithm(algorithm crypto.EncryptionAlgorithm) {
|
||||||
|
// userCodeAlgorithm = algorithm
|
||||||
|
// }
|
||||||
|
|
||||||
|
func SetTracer(t tracing.Tracer) {
|
||||||
|
tracer = t
|
||||||
|
}
|
||||||
|
|
||||||
|
func SetLogger(l logging.Logger) {
|
||||||
|
logger = l
|
||||||
|
}
|
||||||
|
|
||||||
|
func SetUserRepository(repo func(database.QueryExecutor) UserRepository) {
|
||||||
|
userRepo = repo
|
||||||
|
}
|
||||||
|
|
||||||
|
func SetOrgRepository(repo func(database.QueryExecutor) OrganizationRepository) {
|
||||||
|
orgRepo = repo
|
||||||
|
}
|
||||||
|
|
||||||
|
// func SetInstanceRepository(repo func(database.QueryExecutor) InstanceRepository) {
|
||||||
|
// instanceRepo = repo
|
||||||
|
// }
|
||||||
|
|
||||||
|
// func SetCryptoRepository(repo func(database.QueryExecutor) CryptoRepository) {
|
||||||
|
// cryptoRepo = repo
|
||||||
|
// }
|
@@ -63,68 +63,3 @@ type domainChanges interface {
|
|||||||
// This is used for reducing events.
|
// This is used for reducing events.
|
||||||
SetUpdatedAt(t time.Time) database.Change
|
SetUpdatedAt(t time.Time) database.Change
|
||||||
}
|
}
|
||||||
|
|
||||||
// import (
|
|
||||||
// "math/rand/v2"
|
|
||||||
// "strconv"
|
|
||||||
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/storage/cache"
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/storage/database"
|
|
||||||
|
|
||||||
// // "github.com/zitadel/zitadel/backend/v3/telemetry/logging"
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/telemetry/tracing"
|
|
||||||
// "github.com/zitadel/zitadel/internal/crypto"
|
|
||||||
// )
|
|
||||||
|
|
||||||
// // The variables could also be moved to a struct.
|
|
||||||
// // I just started with the singleton pattern and kept it like this.
|
|
||||||
// var (
|
|
||||||
// pool database.Pool
|
|
||||||
// userCodeAlgorithm crypto.EncryptionAlgorithm
|
|
||||||
// tracer tracing.Tracer
|
|
||||||
// // logger logging.Logger
|
|
||||||
|
|
||||||
// userRepo func(database.QueryExecutor) UserRepository
|
|
||||||
// // instanceRepo func(database.QueryExecutor) InstanceRepository
|
|
||||||
// cryptoRepo func(database.QueryExecutor) CryptoRepository
|
|
||||||
// orgRepo func(database.QueryExecutor) OrgRepository
|
|
||||||
|
|
||||||
// // instanceCache cache.Cache[instanceCacheIndex, string, *Instance]
|
|
||||||
// orgCache cache.Cache[orgCacheIndex, string, *Org]
|
|
||||||
|
|
||||||
// generateID func() (string, error) = func() (string, error) {
|
|
||||||
// return strconv.FormatUint(rand.Uint64(), 10), nil
|
|
||||||
// }
|
|
||||||
// )
|
|
||||||
|
|
||||||
// func SetPool(p database.Pool) {
|
|
||||||
// pool = p
|
|
||||||
// }
|
|
||||||
|
|
||||||
// func SetUserCodeAlgorithm(algorithm crypto.EncryptionAlgorithm) {
|
|
||||||
// userCodeAlgorithm = algorithm
|
|
||||||
// }
|
|
||||||
|
|
||||||
// func SetTracer(t tracing.Tracer) {
|
|
||||||
// tracer = t
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // func SetLogger(l logging.Logger) {
|
|
||||||
// // logger = l
|
|
||||||
// // }
|
|
||||||
|
|
||||||
// func SetUserRepository(repo func(database.QueryExecutor) UserRepository) {
|
|
||||||
// userRepo = repo
|
|
||||||
// }
|
|
||||||
|
|
||||||
// func SetOrgRepository(repo func(database.QueryExecutor) OrgRepository) {
|
|
||||||
// orgRepo = repo
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // func SetInstanceRepository(repo func(database.QueryExecutor) InstanceRepository) {
|
|
||||||
// // instanceRepo = repo
|
|
||||||
// // }
|
|
||||||
|
|
||||||
// func SetCryptoRepository(repo func(database.QueryExecutor) CryptoRepository) {
|
|
||||||
// cryptoRepo = repo
|
|
||||||
// }
|
|
||||||
|
@@ -1,158 +1,165 @@
|
|||||||
package domain
|
package domain
|
||||||
|
|
||||||
// import (
|
import (
|
||||||
// "context"
|
"context"
|
||||||
// "fmt"
|
"fmt"
|
||||||
|
|
||||||
// "github.com/zitadel/zitadel/backend/v3/storage/eventstore"
|
"github.com/zitadel/zitadel/backend/v3/storage/eventstore"
|
||||||
// )
|
)
|
||||||
|
|
||||||
// // Invoke provides a way to execute commands within the domain package.
|
// Invoke provides a way to execute commands within the domain package.
|
||||||
// // It uses a chain of responsibility pattern to handle the command execution.
|
// It uses the [chain of responsibility](https://refactoring.guru/design-patterns/chain-of-responsibility) pattern to handle the command execution.
|
||||||
// // The default chain includes logging, tracing, and event publishing.
|
// The default chain includes logging, tracing, and event publishing.
|
||||||
// // If you want to invoke multiple commands in a single transaction, you can use the [commandBatch].
|
// If you want to invoke multiple commands in a single transaction, you can use the [commandBatch].
|
||||||
// func Invoke(ctx context.Context, cmd Commander) error {
|
func Invoke(ctx context.Context, cmd Commander) error {
|
||||||
// invoker := newEventStoreInvoker(newLoggingInvoker(newTraceInvoker(nil)))
|
invoker := newEventStoreInvoker(newLoggingInvoker(newTraceInvoker(nil)))
|
||||||
// opts := &CommandOpts{
|
opts := &CommandOpts{
|
||||||
// Invoker: invoker.collector,
|
Invoker: invoker.collector,
|
||||||
// DB: pool,
|
DB: pool,
|
||||||
// }
|
}
|
||||||
// return invoker.Invoke(ctx, cmd, opts)
|
return invoker.Invoke(ctx, cmd, opts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // eventStoreInvoker checks if the command implements the [eventer] interface.
|
// eventStoreInvoker checks if the command implements the [eventer] interface.
|
||||||
// // If it does, it collects the events and publishes them to the event store.
|
// If it does, it collects the events and publishes them to the event store.
|
||||||
// type eventStoreInvoker struct {
|
type eventStoreInvoker struct {
|
||||||
// collector *eventCollector
|
collector *eventCollector
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func newEventStoreInvoker(next Invoker) *eventStoreInvoker {
|
func newEventStoreInvoker(next Invoker) *eventStoreInvoker {
|
||||||
// return &eventStoreInvoker{collector: &eventCollector{next: next}}
|
return &eventStoreInvoker{collector: &eventCollector{next: next}}
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (i *eventStoreInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
// Invoke implements the [Invoker] interface.
|
||||||
// err = i.collector.Invoke(ctx, command, opts)
|
func (i *eventStoreInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
||||||
// if err != nil {
|
err = i.collector.Invoke(ctx, command, opts)
|
||||||
// return err
|
if err != nil {
|
||||||
// }
|
return err
|
||||||
// if len(i.collector.events) > 0 {
|
}
|
||||||
// err = eventstore.Publish(ctx, i.collector.events, opts.DB)
|
if len(i.collector.events) > 0 {
|
||||||
// if err != nil {
|
err = eventstore.Publish(ctx, i.collector.events, opts.DB)
|
||||||
// return err
|
if err != nil {
|
||||||
// }
|
return err
|
||||||
// }
|
}
|
||||||
// return nil
|
}
|
||||||
// }
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// // eventCollector collects events from all commands. The [eventStoreInvoker] pushes the collected events after all commands are executed.
|
// eventCollector collects events from all commands. The [eventStoreInvoker] pushes the collected events after all commands are executed.
|
||||||
// type eventCollector struct {
|
type eventCollector struct {
|
||||||
// next Invoker
|
next Invoker
|
||||||
// events []*eventstore.Event
|
events []*eventstore.Event
|
||||||
// }
|
}
|
||||||
|
|
||||||
// type eventer interface {
|
type eventer interface {
|
||||||
// Events() []*eventstore.Event
|
Events() []*eventstore.Event
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (i *eventCollector) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
// Invoke implements the [Invoker] interface.
|
||||||
// if e, ok := command.(eventer); ok && len(e.Events()) > 0 {
|
func (i *eventCollector) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
||||||
// // we need to ensure all commands are executed in the same transaction
|
if e, ok := command.(eventer); ok && len(e.Events()) > 0 {
|
||||||
// close, err := opts.EnsureTx(ctx)
|
// we need to ensure all commands are executed in the same transaction
|
||||||
// if err != nil {
|
close, err := opts.EnsureTx(ctx)
|
||||||
// return err
|
if err != nil {
|
||||||
// }
|
return err
|
||||||
// defer func() { err = close(ctx, err) }()
|
}
|
||||||
|
defer func() { err = close(ctx, err) }()
|
||||||
|
|
||||||
// i.events = append(i.events, e.Events()...)
|
i.events = append(i.events, e.Events()...)
|
||||||
// }
|
}
|
||||||
// if i.next != nil {
|
if i.next != nil {
|
||||||
// return i.next.Invoke(ctx, command, opts)
|
return i.next.Invoke(ctx, command, opts)
|
||||||
// }
|
}
|
||||||
// return command.Execute(ctx, opts)
|
return command.Execute(ctx, opts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // traceInvoker decorates each command with tracing.
|
// traceInvoker decorates each command with tracing.
|
||||||
// type traceInvoker struct {
|
type traceInvoker struct {
|
||||||
// next Invoker
|
next Invoker
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func newTraceInvoker(next Invoker) *traceInvoker {
|
func newTraceInvoker(next Invoker) *traceInvoker {
|
||||||
// return &traceInvoker{next: next}
|
return &traceInvoker{next: next}
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (i *traceInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
// Invoke implements the [Invoker] interface.
|
||||||
// ctx, span := tracer.Start(ctx, fmt.Sprintf("%T", command))
|
func (i *traceInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
||||||
// defer func() {
|
ctx, span := tracer.Start(ctx, fmt.Sprintf("%T", command))
|
||||||
// if err != nil {
|
defer func() {
|
||||||
// span.RecordError(err)
|
if err != nil {
|
||||||
// }
|
span.RecordError(err)
|
||||||
// span.End()
|
}
|
||||||
// }()
|
span.End()
|
||||||
|
}()
|
||||||
|
|
||||||
// if i.next != nil {
|
if i.next != nil {
|
||||||
// return i.next.Invoke(ctx, command, opts)
|
return i.next.Invoke(ctx, command, opts)
|
||||||
// }
|
}
|
||||||
// return command.Execute(ctx, opts)
|
return command.Execute(ctx, opts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // loggingInvoker decorates each command with logging.
|
// loggingInvoker decorates each command with logging.
|
||||||
// // It is an example implementation and logs the command name at the beginning and success or failure after the command got executed.
|
// It is an example implementation and logs the command name at the beginning and success or failure after the command got executed.
|
||||||
// type loggingInvoker struct {
|
type loggingInvoker struct {
|
||||||
// next Invoker
|
next Invoker
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func newLoggingInvoker(next Invoker) *loggingInvoker {
|
func newLoggingInvoker(next Invoker) *loggingInvoker {
|
||||||
// return &loggingInvoker{next: next}
|
return &loggingInvoker{next: next}
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (i *loggingInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
// Invoke implements the [Invoker] interface.
|
||||||
// logger.InfoContext(ctx, "Invoking command", "command", command.String())
|
func (i *loggingInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
||||||
|
logger.InfoContext(ctx, "Invoking command", "command", command.String())
|
||||||
|
|
||||||
// if i.next != nil {
|
if i.next != nil {
|
||||||
// err = i.next.Invoke(ctx, command, opts)
|
err = i.next.Invoke(ctx, command, opts)
|
||||||
// } else {
|
} else {
|
||||||
// err = command.Execute(ctx, opts)
|
err = command.Execute(ctx, opts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// logger.ErrorContext(ctx, "Command invocation failed", "command", command.String(), "error", err)
|
logger.ErrorContext(ctx, "Command invocation failed", "command", command.String(), "error", err)
|
||||||
// return err
|
return err
|
||||||
// }
|
}
|
||||||
// logger.InfoContext(ctx, "Command invocation succeeded", "command", command.String())
|
logger.InfoContext(ctx, "Command invocation succeeded", "command", command.String())
|
||||||
// return nil
|
return nil
|
||||||
// }
|
}
|
||||||
|
|
||||||
// type noopInvoker struct {
|
// noopInvoker executes the command without any additional decoration.
|
||||||
// next Invoker
|
type noopInvoker struct {
|
||||||
// }
|
next Invoker
|
||||||
|
}
|
||||||
|
|
||||||
// func (i *noopInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) error {
|
// Invoke implements the [Invoker] interface.
|
||||||
// if i.next != nil {
|
func (i *noopInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) error {
|
||||||
// return i.next.Invoke(ctx, command, opts)
|
if i.next != nil {
|
||||||
// }
|
return i.next.Invoke(ctx, command, opts)
|
||||||
// return command.Execute(ctx, opts)
|
}
|
||||||
// }
|
return command.Execute(ctx, opts)
|
||||||
|
}
|
||||||
|
|
||||||
// // cacheInvoker could be used in the future to do the caching.
|
// cacheInvoker could be used in the future to do the caching.
|
||||||
// // My goal would be to have two interfaces:
|
// My goal would be to have two interfaces:
|
||||||
// // - cacheSetter: which caches an object
|
// - cacheSetter: which caches an object
|
||||||
// // - cacheGetter: which gets an object from the cache, this should also skip the command execution
|
// - cacheGetter: which gets an object from the cache, this should also skip the command execution
|
||||||
// type cacheInvoker struct {
|
type cacheInvoker struct {
|
||||||
// next Invoker
|
next Invoker
|
||||||
// }
|
}
|
||||||
|
|
||||||
// type cacher interface {
|
type cacher interface {
|
||||||
// Cache(opts *CommandOpts)
|
Cache(opts *CommandOpts)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// func (i *cacheInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
// Invoke implements the [Invoker] interface.
|
||||||
// if c, ok := command.(cacher); ok {
|
func (i *cacheInvoker) Invoke(ctx context.Context, command Commander, opts *CommandOpts) (err error) {
|
||||||
// c.Cache(opts)
|
if c, ok := command.(cacher); ok {
|
||||||
// }
|
c.Cache(opts)
|
||||||
// if i.next != nil {
|
}
|
||||||
// err = i.next.Invoke(ctx, command, opts)
|
if i.next != nil {
|
||||||
// } else {
|
err = i.next.Invoke(ctx, command, opts)
|
||||||
// err = command.Execute(ctx, opts)
|
} else {
|
||||||
// }
|
err = command.Execute(ctx, opts)
|
||||||
// return err
|
}
|
||||||
// }
|
return err
|
||||||
|
}
|
||||||
|
@@ -88,8 +88,8 @@ type OrganizationRepository interface {
|
|||||||
Delete(ctx context.Context, id OrgIdentifierCondition, instance_id string) (int64, error)
|
Delete(ctx context.Context, id OrgIdentifierCondition, instance_id string) (int64, error)
|
||||||
|
|
||||||
// Domains returns the domain sub repository for the organization.
|
// Domains returns the domain sub repository for the organization.
|
||||||
// If shouldLoad is true, the domains will be loaded from the database and written to the [Instance].Domains field.
|
// If shouldLoad is true, the domains will be loaded from the database and written to the [Organization].Domains field.
|
||||||
// If shouldLoad is set to true once, the Domains field will be set event if shouldLoad is false in the future.
|
// If shouldLoad is set to true once, the Domains field will be set even if shouldLoad is false in the future.
|
||||||
Domains(shouldLoad bool) OrganizationDomainRepository
|
Domains(shouldLoad bool) OrganizationDomainRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user