a2e20c93ae
Initially we duplicated the code to avoid large scale changes to the packages. Now we are past metainfo refactor we can remove the duplication. Change-Id: I9d0b2756cc6e2a2f4d576afa408a15273a7e1cef
79 lines
1.8 KiB
Go
79 lines
1.8 KiB
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package dbx
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/spacemonkeygo/monkit/v3"
|
|
"github.com/zeebo/errs"
|
|
|
|
"storj.io/private/dbutil/cockroachutil"
|
|
"storj.io/private/dbutil/txutil"
|
|
"storj.io/private/tagsql"
|
|
)
|
|
|
|
//go:generate sh gen.sh
|
|
|
|
var mon = monkit.Package()
|
|
|
|
func init() {
|
|
// catch dbx errors
|
|
class := errs.Class("satellitedb")
|
|
WrapErr = func(e *Error) error {
|
|
switch e.Code {
|
|
case ErrorCode_NoRows:
|
|
return e.Err
|
|
case ErrorCode_ConstraintViolation:
|
|
return class.Wrap(&constraintError{e.Constraint, e.Err})
|
|
}
|
|
return class.Wrap(e)
|
|
}
|
|
ShouldRetry = func(driver string, err error) bool {
|
|
if driver == "pgxcockroach" || driver == "cockroach" {
|
|
return cockroachutil.NeedsRetry(err)
|
|
}
|
|
return false
|
|
}
|
|
}
|
|
|
|
// Unwrap returns the underlying error.
|
|
func (e *Error) Unwrap() error { return e.Err }
|
|
|
|
// Cause returns the underlying error.
|
|
func (e *Error) Cause() error { return e.Err }
|
|
|
|
type constraintError struct {
|
|
constraint string
|
|
err error
|
|
}
|
|
|
|
// Unwrap returns the underlying error.
|
|
func (err *constraintError) Unwrap() error { return err.err }
|
|
|
|
// Cause returns the underlying error.
|
|
func (err *constraintError) Cause() error { return err.err }
|
|
|
|
// IsConstraintError returns true if the error is a constraint error.
|
|
func IsConstraintError(err error) bool {
|
|
_, ok := err.(*constraintError)
|
|
return ok
|
|
}
|
|
|
|
// Error implements the error interface.
|
|
func (err *constraintError) Error() string {
|
|
return fmt.Sprintf("violates constraint %q: %v", err.constraint, err.err)
|
|
}
|
|
|
|
// WithTx wraps DB code in a transaction.
|
|
func (db *DB) WithTx(ctx context.Context, fn func(context.Context, *Tx) error) (err error) {
|
|
return txutil.WithTx(ctx, db, nil, func(ctx context.Context, tx tagsql.Tx) error {
|
|
return fn(ctx, &Tx{
|
|
Tx: tx,
|
|
txMethods: db.wrapTx(tx),
|
|
})
|
|
})
|
|
}
|