mirror of
https://github.com/rocky-linux/peridot.git
synced 2024-12-22 10:48:30 +00:00
114 lines
2.9 KiB
Go
114 lines
2.9 KiB
Go
|
// Copyright (c) All respective contributors to the Peridot Project. All rights reserved.
|
||
|
// Copyright (c) 2021-2022 Rocky Enterprise Software Foundation, Inc. All rights reserved.
|
||
|
// Copyright (c) 2021-2022 Ctrl IQ, Inc. All rights reserved.
|
||
|
//
|
||
|
// Redistribution and use in source and binary forms, with or without
|
||
|
// modification, are permitted provided that the following conditions are met:
|
||
|
//
|
||
|
// 1. Redistributions of source code must retain the above copyright notice,
|
||
|
// this list of conditions and the following disclaimer.
|
||
|
//
|
||
|
// 2. Redistributions in binary form must reproduce the above copyright notice,
|
||
|
// this list of conditions and the following disclaimer in the documentation
|
||
|
// and/or other materials provided with the distribution.
|
||
|
//
|
||
|
// 3. Neither the name of the copyright holder nor the names of its contributors
|
||
|
// may be used to endorse or promote products derived from this software without
|
||
|
// specific prior written permission.
|
||
|
//
|
||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||
|
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||
|
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||
|
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||
|
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||
|
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
|
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
|
// POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
||
|
package utils
|
||
|
|
||
|
import (
|
||
|
"database/sql"
|
||
|
"github.com/jmoiron/sqlx"
|
||
|
"github.com/spf13/viper"
|
||
|
"log"
|
||
|
"strings"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
type DbType int
|
||
|
|
||
|
const (
|
||
|
DbPostgres DbType = iota
|
||
|
DbUnknown
|
||
|
)
|
||
|
|
||
|
// GetDbType finds the database type specified in database.url
|
||
|
func GetDbType() DbType {
|
||
|
dbURL := viper.GetString("database.url")
|
||
|
if strings.HasPrefix(dbURL, "postgres") {
|
||
|
return DbPostgres
|
||
|
}
|
||
|
|
||
|
return DbUnknown
|
||
|
}
|
||
|
|
||
|
// PgInit is the base pg init
|
||
|
func PgInit() *sql.DB {
|
||
|
db, err := sql.Open("postgres", viper.GetString("database.url"))
|
||
|
if err != nil {
|
||
|
log.Fatalln(err)
|
||
|
}
|
||
|
|
||
|
db.SetConnMaxLifetime(30 * time.Minute)
|
||
|
|
||
|
return db
|
||
|
}
|
||
|
|
||
|
// PgInitx is the base pg init (sqlx)
|
||
|
func PgInitx() *sqlx.DB {
|
||
|
db, err := sqlx.Open("postgres", viper.GetString("database.url"))
|
||
|
if err != nil {
|
||
|
log.Fatalln(err)
|
||
|
}
|
||
|
|
||
|
db.SetConnMaxLifetime(30 * time.Minute)
|
||
|
|
||
|
return db
|
||
|
}
|
||
|
|
||
|
func MinLimit(limit int32) int32 {
|
||
|
if limit <= 0 || limit > 1000 {
|
||
|
return 20
|
||
|
}
|
||
|
|
||
|
return limit
|
||
|
}
|
||
|
|
||
|
func MinPage(page int32) int32 {
|
||
|
if page < 0 {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
return page
|
||
|
}
|
||
|
|
||
|
func GetOffset(page int32, limit int32) int64 {
|
||
|
if page <= 0 {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
return int64(page * limit)
|
||
|
}
|
||
|
|
||
|
func UnlimitedLimit(limit int32) *int32 {
|
||
|
if limit == -1 {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
return &limit
|
||
|
}
|