mirror of
https://github.com/harness/drone.git
synced 2025-05-04 23:40:24 +08:00
58 lines
1.4 KiB
Go
58 lines
1.4 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/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
|
|
}
|
|
}
|