Files
spend-sparrow/internal/db/error.go
Tim Wundenberg 63ade5916e
All checks were successful
Build Docker Image / Build-Docker-Image (push) Successful in 5m33s
Build and Push Docker Image / Build-And-Push-Docker-Image (push) Successful in 5m4s
fix(observabillity): include otel logs
2025-06-07 15:32:43 +02:00

39 lines
738 B
Go

package db
import (
"database/sql"
"errors"
"log/slog"
"spend-sparrow/internal/types"
)
var (
ErrNotFound = errors.New("the value does not exist")
ErrAlreadyExists = errors.New("row already exists")
)
func TransformAndLogDbError(module string, r sql.Result, err error) error {
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return ErrNotFound
}
slog.Error("database sql", "module", module, "err", err)
return types.ErrInternal
}
if r != nil {
rows, err := r.RowsAffected()
if err != nil {
slog.Error("database rows affected", "module", module, "err", err)
return types.ErrInternal
}
if rows == 0 {
slog.Info("row not found", "module", module)
return ErrNotFound
}
}
return nil
}