mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 11:59:02 +00:00 
			
		
		
		
	 ab4daa0ebb
			
		
	
	ab4daa0ebb
	
	
	
		
			
			# Which Problems Are Solved When Web keys with a large RSA Bitsize were generated, the new web key did not get projected. Zitadel logs printed the following errors: ``` time="2024-08-15T09:18:47Z" level=debug msg="execution of statements failed" caller="/home/tim/Repositories/zitadel/zitadel/internal/eventstore/handler/v2/handler.go:518" error="statement failed: ID=CRDB-pKtsr Message=exec failed Parent=(ERROR: index row size 3400 exceeds btree version 4 maximum 2704 for index \"web_keys_web_key_state_idx\" (SQLSTATE 54000))" lastProcessedIndex=-1 projection=projections.web_keys ``` # How the Problems Are Solved Remove the the `WithInclude` option with the Private key from the `web_keys` projection index and bump the projection version. # Additional Changes - Correct RPC summaries for documentation - Fix docs slug in sidebar.js # Additional Context - Found during release review.
		
			
				
	
	
		
			163 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package projection
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/domain"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore"
 | |
| 	old_handler "github.com/zitadel/zitadel/internal/eventstore/handler"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore/handler/v2"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/instance"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/webkey"
 | |
| 	"github.com/zitadel/zitadel/internal/zerrors"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	WebKeyTable = "projections.web_keys1"
 | |
| 
 | |
| 	WebKeyInstanceIDCol   = "instance_id"
 | |
| 	WebKeyKeyIDCol        = "key_id"
 | |
| 	WebKeyCreationDateCol = "creation_date"
 | |
| 	WebKeyChangeDateCol   = "change_date"
 | |
| 	WebKeySequenceCol     = "sequence"
 | |
| 	WebKeyStateCol        = "state"
 | |
| 	WebKeyPrivateKeyCol   = "private_key"
 | |
| 	WebKeyPublicKeyCol    = "public_key"
 | |
| 	WebKeyConfigCol       = "config"
 | |
| 	WebKeyConfigTypeCol   = "config_type"
 | |
| )
 | |
| 
 | |
| type webKeyProjection struct{}
 | |
| 
 | |
| func newWebKeyProjection(ctx context.Context, config handler.Config) *handler.Handler {
 | |
| 	return handler.NewHandler(ctx, &config, new(webKeyProjection))
 | |
| }
 | |
| 
 | |
| func (*webKeyProjection) Name() string {
 | |
| 	return WebKeyTable
 | |
| }
 | |
| 
 | |
| func (*webKeyProjection) Init() *old_handler.Check {
 | |
| 	return handler.NewTableCheck(
 | |
| 		handler.NewTable(
 | |
| 			[]*handler.InitColumn{
 | |
| 				handler.NewColumn(WebKeyInstanceIDCol, handler.ColumnTypeText),
 | |
| 				handler.NewColumn(WebKeyKeyIDCol, handler.ColumnTypeText),
 | |
| 				handler.NewColumn(WebKeyCreationDateCol, handler.ColumnTypeTimestamp),
 | |
| 				handler.NewColumn(WebKeyChangeDateCol, handler.ColumnTypeTimestamp),
 | |
| 				handler.NewColumn(WebKeySequenceCol, handler.ColumnTypeInt64),
 | |
| 				handler.NewColumn(WebKeyStateCol, handler.ColumnTypeInt64),
 | |
| 				handler.NewColumn(WebKeyPrivateKeyCol, handler.ColumnTypeJSONB),
 | |
| 				handler.NewColumn(WebKeyPublicKeyCol, handler.ColumnTypeJSONB),
 | |
| 				handler.NewColumn(WebKeyConfigCol, handler.ColumnTypeJSONB),
 | |
| 				handler.NewColumn(WebKeyConfigTypeCol, handler.ColumnTypeInt64),
 | |
| 			},
 | |
| 			handler.NewPrimaryKey(WebKeyInstanceIDCol, WebKeyKeyIDCol),
 | |
| 
 | |
| 			// index to find the current active private key for an instance.
 | |
| 			handler.WithIndex(handler.NewIndex(
 | |
| 				"web_key_state",
 | |
| 				[]string{WebKeyInstanceIDCol, WebKeyStateCol},
 | |
| 			)),
 | |
| 		),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func (p *webKeyProjection) Reducers() []handler.AggregateReducer {
 | |
| 	return []handler.AggregateReducer{{
 | |
| 		Aggregate: webkey.AggregateType,
 | |
| 		EventReducers: []handler.EventReducer{
 | |
| 			{
 | |
| 				Event:  webkey.AddedEventType,
 | |
| 				Reduce: p.reduceWebKeyAdded,
 | |
| 			},
 | |
| 			{
 | |
| 				Event:  webkey.ActivatedEventType,
 | |
| 				Reduce: p.reduceWebKeyActivated,
 | |
| 			},
 | |
| 			{
 | |
| 				Event:  webkey.DeactivatedEventType,
 | |
| 				Reduce: p.reduceWebKeyDeactivated,
 | |
| 			},
 | |
| 			{
 | |
| 				Event:  webkey.RemovedEventType,
 | |
| 				Reduce: p.reduceWebKeyRemoved,
 | |
| 			},
 | |
| 			{
 | |
| 				Event:  instance.InstanceRemovedEventType,
 | |
| 				Reduce: reduceInstanceRemovedHelper(WebKeyInstanceIDCol),
 | |
| 			},
 | |
| 		},
 | |
| 	}}
 | |
| }
 | |
| 
 | |
| func (p *webKeyProjection) reduceWebKeyAdded(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*webkey.AddedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, zerrors.ThrowInvalidArgumentf(nil, "PROJE-jei2K", "reduce.wrong.event.type %s", webkey.AddedEventType)
 | |
| 	}
 | |
| 	return handler.NewCreateStatement(e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(WebKeyInstanceIDCol, e.Agg.InstanceID),
 | |
| 			handler.NewCol(WebKeyKeyIDCol, e.Agg.ID),
 | |
| 			handler.NewCol(WebKeyCreationDateCol, e.CreationDate()),
 | |
| 			handler.NewCol(WebKeyChangeDateCol, e.CreationDate()),
 | |
| 			handler.NewCol(WebKeySequenceCol, e.Sequence()),
 | |
| 			handler.NewCol(WebKeyStateCol, domain.WebKeyStateInitial),
 | |
| 			handler.NewCol(WebKeyPrivateKeyCol, e.PrivateKey),
 | |
| 			handler.NewCol(WebKeyPublicKeyCol, e.PublicKey),
 | |
| 			handler.NewCol(WebKeyConfigCol, e.Config),
 | |
| 			handler.NewCol(WebKeyConfigTypeCol, e.ConfigType),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *webKeyProjection) reduceWebKeyActivated(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*webkey.ActivatedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, zerrors.ThrowInvalidArgumentf(nil, "PROJE-iiQu2", "reduce.wrong.event.type %s", webkey.ActivatedEventType)
 | |
| 	}
 | |
| 	return handler.NewUpdateStatement(e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(WebKeyChangeDateCol, e.CreationDate()),
 | |
| 			handler.NewCol(WebKeySequenceCol, e.Sequence()),
 | |
| 			handler.NewCol(WebKeyStateCol, domain.WebKeyStateActive),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(WebKeyInstanceIDCol, e.Agg.InstanceID),
 | |
| 			handler.NewCond(WebKeyKeyIDCol, e.Agg.ID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *webKeyProjection) reduceWebKeyDeactivated(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*webkey.DeactivatedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, zerrors.ThrowInvalidArgumentf(nil, "PROJE-zei3E", "reduce.wrong.event.type %s", webkey.DeactivatedEventType)
 | |
| 	}
 | |
| 	return handler.NewUpdateStatement(e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(WebKeyChangeDateCol, e.CreationDate()),
 | |
| 			handler.NewCol(WebKeySequenceCol, e.Sequence()),
 | |
| 			handler.NewCol(WebKeyStateCol, domain.WebKeyStateInactive),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(WebKeyInstanceIDCol, e.Agg.InstanceID),
 | |
| 			handler.NewCond(WebKeyKeyIDCol, e.Agg.ID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *webKeyProjection) reduceWebKeyRemoved(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*webkey.RemovedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, zerrors.ThrowInvalidArgumentf(nil, "PROJE-Zei6f", "reduce.wrong.event.type %s", webkey.RemovedEventType)
 | |
| 	}
 | |
| 	return handler.NewDeleteStatement(e,
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(WebKeyInstanceIDCol, e.Agg.InstanceID),
 | |
| 			handler.NewCond(WebKeyKeyIDCol, e.Agg.ID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 |