refactor: exposed untransactional queries for transactional db helper again but with a clearer name this time since it still may be useful
84 lines
1.4 KiB
Go
84 lines
1.4 KiB
Go
package database
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/jackc/pgx/v5"
|
|
)
|
|
|
|
type DbHelperTransaction interface {
|
|
Commit() error
|
|
Rollback() error
|
|
}
|
|
|
|
type DbHelper struct {
|
|
CTX context.Context
|
|
Queries Queries
|
|
}
|
|
|
|
type dbHelperTransactionImpl struct {
|
|
CTX context.Context
|
|
TXlessQueries Queries
|
|
TX pgx.Tx
|
|
TXQueries Queries
|
|
}
|
|
|
|
func NewDbHelper(dbContext DbContext) DbHelper {
|
|
|
|
ctx := context.Background()
|
|
queries := New(dbContext)
|
|
|
|
return DbHelper{
|
|
CTX: ctx,
|
|
Queries: *queries,
|
|
}
|
|
}
|
|
|
|
func NewDbHelperTransaction(dbContext DbContext) (DbHelperTransaction, *dbHelperTransactionImpl, error) {
|
|
|
|
ctx := context.Background()
|
|
queries := New(dbContext)
|
|
tx, err := dbContext.BeginTx(ctx)
|
|
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
txQueries := queries.WithTx(tx)
|
|
|
|
obj := &dbHelperTransactionImpl{
|
|
CTX: ctx,
|
|
TXlessQueries: *queries,
|
|
TX: tx,
|
|
TXQueries: *txQueries,
|
|
}
|
|
|
|
return obj, obj, nil
|
|
}
|
|
|
|
// Commit implements DbHelperTransaction.
|
|
func (d *dbHelperTransactionImpl) Commit() error {
|
|
errCommit := d.TX.Commit(d.CTX)
|
|
|
|
if errCommit != nil {
|
|
errRollback := d.TX.Rollback(d.CTX)
|
|
|
|
if errRollback != nil {
|
|
return errRollback
|
|
}
|
|
|
|
return errCommit
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Rollback implements DbHelperTransaction.
|
|
func (d *dbHelperTransactionImpl) Rollback() error {
|
|
err := d.TX.Rollback(d.CTX)
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|