fix(eventstore): differentiate unique constraint error (#6832)

* fix(eventstore): differentiate unique constraint error format

* docs: add comment to eventstore vars

* fix(eventstore): return correct error type if unique constraint already exists
This commit is contained in:
Silvan
2023-10-27 14:10:01 +02:00
committed by GitHub
parent a4626f9bdb
commit f8bf8ea256
2 changed files with 12 additions and 6 deletions

View File

@@ -6,8 +6,12 @@ import (
"github.com/zitadel/zitadel/internal/database"
)
// pushPlaceholderFmt defines how data are inserted into the events table
var pushPlaceholderFmt string
var (
// pushPlaceholderFmt defines how data are inserted into the events table
pushPlaceholderFmt string
// uniqueConstraintPlaceholderFmt defines the format of the unique constraint error returned from the database
uniqueConstraintPlaceholderFmt string
)
type Eventstore struct {
client *database.DB
@@ -17,8 +21,10 @@ func NewEventstore(client *database.DB) *Eventstore {
switch client.Type() {
case "cockroach":
pushPlaceholderFmt = "($%d, $%d, $%d, $%d, $%d, $%d, $%d, $%d, $%d, hlc_to_timestamp(cluster_logical_timestamp()), cluster_logical_timestamp(), $%d)"
uniqueConstraintPlaceholderFmt = "('%s', '%s', '%s')"
case "postgres":
pushPlaceholderFmt = "($%d, $%d, $%d, $%d, $%d, $%d, $%d, $%d, $%d, statement_timestamp(), EXTRACT(EPOCH FROM clock_timestamp()), $%d)"
uniqueConstraintPlaceholderFmt = "(%s, %s, %s)"
}
return &Eventstore{client: client}