drone/internal/store/database/util.go
Johannes Batzill 4668e94027 [Harness] Adding JWT/PAT/SAT Support, Harness Clients, Inline User/ServiceAccount Creation, harness Build flag, ... (#22)
This change adds the initial stepping stones for harness integration:
- Authentication: JWT/PAT/SAT support
- Authorization: ACL integration (acl currently denies requests as gitness hasn't been integrated yet)
- Remote Clients for Token, User, ServiceAccount, ACL
- User Integration: Syncs harness users during authentication if unknown
- SA integration: syncs harness service accounts during authentication if unknown
- Initial harness API: THIS WILL BE CHANGED IN THE FUTURE!
- single harness subpackage (all marked with harness build flag)
- harness & standalone wire + make build commands
2022-09-30 16:22:12 -07:00

60 lines
1.4 KiB
Go

// Copyright 2021 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/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 original error or a store equivalent if possible.
func processSQLErrorf(err error, format string, args ...interface{}) error {
// always log DB error (print formated message)
log.Debug().Msgf("%s %s", fmt.Sprintf(format, args...), err)
// If it's a known error, return converted error instead.
if errors.Is(err, sql.ErrNoRows) {
return store.ErrResourceNotFound
} else if isSQLUniqueConstraintError(err) {
return store.ErrDuplicate
}
return err
}
func isSQLUniqueConstraintError(original error) bool {
err := sqlite3.Error{}
ok := errors.As(original, &err)
return ok && errors.Is(err.ExtendedCode, sqlite3.ErrConstraintUnique)
}