mirror of
https://github.com/harness/drone.git
synced 2025-05-06 06:41:35 +08:00
75 lines
1.7 KiB
Go
75 lines
1.7 KiB
Go
// Copyright 2022 Harness Inc. All rights reserved.
|
|
// Use of this source code is governed by the Polyform Free Trial License
|
|
// that can be found in the LICENSE.md file for this repository.
|
|
|
|
package database
|
|
|
|
import (
|
|
"database/sql"
|
|
"fmt"
|
|
|
|
"github.com/harness/gitness/internal/store"
|
|
|
|
"github.com/lib/pq"
|
|
"github.com/mattn/go-sqlite3"
|
|
"github.com/pkg/errors"
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
// default query range limit.
|
|
const defaultLimit = 100
|
|
|
|
// limit returns the page size to a sql limit.
|
|
func limit(size int) int {
|
|
if size == 0 {
|
|
size = defaultLimit
|
|
}
|
|
return size
|
|
}
|
|
|
|
// offset converts the page to a sql offset.
|
|
func offset(page, size int) int {
|
|
if page == 0 {
|
|
page = 1
|
|
}
|
|
if size == 0 {
|
|
size = defaultLimit
|
|
}
|
|
page--
|
|
return page * size
|
|
}
|
|
|
|
// Logs the error and message, returns either the provided message or a gitrpc equivalent if possible.
|
|
// Always logs the full message with error as warning.
|
|
func processSQLErrorf(err error, format string, args ...interface{}) error {
|
|
// create fallback error returned if we can't map it
|
|
fallbackErr := fmt.Errorf(format, args...)
|
|
|
|
// always log internal error together with message.
|
|
log.Debug().Msgf("%v: [SQL] %v", fallbackErr, err)
|
|
|
|
// If it's a known error, return converted error instead.
|
|
switch {
|
|
case errors.Is(err, sql.ErrNoRows):
|
|
return store.ErrResourceNotFound
|
|
case isSQLUniqueConstraintError(err):
|
|
return store.ErrDuplicate
|
|
default:
|
|
return fallbackErr
|
|
}
|
|
}
|
|
|
|
func isSQLUniqueConstraintError(original error) bool {
|
|
var sqliteErr sqlite3.Error
|
|
if errors.As(original, &sqliteErr) {
|
|
return errors.Is(sqliteErr.ExtendedCode, sqlite3.ErrConstraintUnique)
|
|
}
|
|
|
|
var pqErr *pq.Error
|
|
if errors.As(original, &pqErr) {
|
|
return pqErr.Code == "23505" // unique_violation
|
|
}
|
|
|
|
return false
|
|
}
|