mirror of
https://github.com/zitadel/zitadel.git
synced 2025-12-23 04:57:13 +00:00
45 lines
1.1 KiB
Go
45 lines
1.1 KiB
Go
|
|
package setup
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
"database/sql"
|
||
|
|
_ "embed"
|
||
|
|
"fmt"
|
||
|
|
|
||
|
|
"github.com/zitadel/zitadel/internal/database"
|
||
|
|
"github.com/zitadel/zitadel/internal/eventstore"
|
||
|
|
)
|
||
|
|
|
||
|
|
var (
|
||
|
|
//go:embed 64.sql
|
||
|
|
changePushPosition string
|
||
|
|
)
|
||
|
|
|
||
|
|
type ChangePushPosition struct {
|
||
|
|
dbClient *database.DB
|
||
|
|
}
|
||
|
|
|
||
|
|
func (mig *ChangePushPosition) Execute(ctx context.Context, _ eventstore.Event) error {
|
||
|
|
inTxOrderType, err := mig.inTxOrderType(ctx)
|
||
|
|
if err != nil {
|
||
|
|
return err
|
||
|
|
}
|
||
|
|
stmt := fmt.Sprintf(changePushPosition, inTxOrderType)
|
||
|
|
_, err = mig.dbClient.ExecContext(ctx, stmt)
|
||
|
|
return err
|
||
|
|
}
|
||
|
|
|
||
|
|
func (mig *ChangePushPosition) String() string {
|
||
|
|
return "64_change_push_position"
|
||
|
|
}
|
||
|
|
|
||
|
|
func (mig *ChangePushPosition) inTxOrderType(ctx context.Context) (typeName string, err error) {
|
||
|
|
err = mig.dbClient.QueryRowContext(ctx, func(row *sql.Row) error {
|
||
|
|
return row.Scan(&typeName)
|
||
|
|
}, `SELECT data_type FROM information_schema.columns WHERE table_schema = 'eventstore' AND table_name = 'events2' AND column_name = 'in_tx_order'`)
|
||
|
|
if err != nil {
|
||
|
|
return "", fmt.Errorf("get in_tx_order_type: %w", err)
|
||
|
|
}
|
||
|
|
return typeName, nil
|
||
|
|
}
|