mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 20:38:48 +00:00 
			
		
		
		
	feat(eventstore): increase parallel write capabilities (#5940)
This implementation increases parallel write capabilities of the eventstore. Please have a look at the technical advisories: [05](https://zitadel.com/docs/support/advisory/a10005) and [06](https://zitadel.com/docs/support/advisory/a10006). The implementation of eventstore.push is rewritten and stored events are migrated to a new table `eventstore.events2`. If you are using cockroach: make sure that the database user of ZITADEL has `VIEWACTIVITY` grant. This is used to query events.
This commit is contained in:
		| @@ -4,37 +4,30 @@ import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"github.com/zitadel/zitadel/internal/authz/repository" | ||||
| 	"github.com/zitadel/zitadel/internal/authz/repository/eventsourcing/eventstore" | ||||
| 	authz_es "github.com/zitadel/zitadel/internal/authz/repository/eventsourcing/eventstore" | ||||
| 	authz_view "github.com/zitadel/zitadel/internal/authz/repository/eventsourcing/view" | ||||
| 	"github.com/zitadel/zitadel/internal/crypto" | ||||
| 	"github.com/zitadel/zitadel/internal/database" | ||||
| 	v1 "github.com/zitadel/zitadel/internal/eventstore/v1" | ||||
| 	"github.com/zitadel/zitadel/internal/id" | ||||
| 	"github.com/zitadel/zitadel/internal/eventstore" | ||||
| 	"github.com/zitadel/zitadel/internal/query" | ||||
| ) | ||||
|  | ||||
| type EsRepository struct { | ||||
| 	eventstore.UserMembershipRepo | ||||
| 	eventstore.TokenVerifierRepo | ||||
| 	authz_es.UserMembershipRepo | ||||
| 	authz_es.TokenVerifierRepo | ||||
| } | ||||
|  | ||||
| func Start(queries *query.Queries, dbClient *database.DB, keyEncryptionAlgorithm crypto.EncryptionAlgorithm, externalSecure, allowOrderByCreationDate bool) (repository.Repository, error) { | ||||
| 	es, err := v1.Start(dbClient, allowOrderByCreationDate) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	idGenerator := id.SonyFlakeGenerator() | ||||
| 	view, err := authz_view.StartView(dbClient, idGenerator, queries) | ||||
| func Start(queries *query.Queries, es *eventstore.Eventstore, dbClient *database.DB, keyEncryptionAlgorithm crypto.EncryptionAlgorithm, externalSecure bool) (repository.Repository, error) { | ||||
| 	view, err := authz_view.StartView(dbClient, queries) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return &EsRepository{ | ||||
| 		eventstore.UserMembershipRepo{ | ||||
| 		authz_es.UserMembershipRepo{ | ||||
| 			Queries: queries, | ||||
| 		}, | ||||
| 		eventstore.TokenVerifierRepo{ | ||||
| 		authz_es.TokenVerifierRepo{ | ||||
| 			TokenVerificationKey: keyEncryptionAlgorithm, | ||||
| 			Eventstore:           es, | ||||
| 			View:                 view, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Silvan
					Silvan