1
0
mirror of https://github.com/woodpecker-ci/woodpecker.git synced 2024-12-24 10:07:21 +02:00
woodpecker/store/datastore/utils.go

72 lines
1.5 KiB
Go
Raw Normal View History

package datastore
2015-09-30 03:21:17 +02:00
import (
"strconv"
2015-10-22 01:39:43 +02:00
"strings"
2015-09-30 03:21:17 +02:00
2015-10-22 01:39:43 +02:00
"github.com/drone/drone/model"
2015-09-30 03:21:17 +02:00
"github.com/russross/meddler"
)
// rebind is a helper function that changes the sql
2015-09-30 03:21:17 +02:00
// bind type from ? to $ for postgres queries.
func rebind(query string) string {
2015-09-30 03:21:17 +02:00
if meddler.Default != meddler.PostgreSQL {
return query
}
qb := []byte(query)
// Add space enough for 5 params before we have to allocate
rqb := make([]byte, 0, len(qb)+5)
j := 1
for _, b := range qb {
switch b {
case '?':
2015-09-30 03:21:17 +02:00
rqb = append(rqb, '$')
for _, b := range strconv.Itoa(j) {
rqb = append(rqb, byte(b))
}
j++
case '`':
rqb = append(rqb, ' ')
default:
2015-09-30 03:21:17 +02:00
rqb = append(rqb, b)
}
}
return string(rqb)
}
2015-10-22 01:39:43 +02:00
// helper function that converts a simple repsitory list
// to a sql IN statment.
func toList(listof []*model.RepoLite) (string, []interface{}) {
var size = len(listof)
if size > 999 {
size = 999
listof = listof[:999]
}
var qs = make([]string, size, size)
var in = make([]interface{}, size, size)
for i, repo := range listof {
qs[i] = "?"
2015-10-22 01:39:43 +02:00
in[i] = repo.FullName
}
return strings.Join(qs, ","), in
}
// helper function that converts a simple repsitory list
// to a sql IN statment compatible with postgres.
func toListPosgres(listof []*model.RepoLite) (string, []interface{}) {
var size = len(listof)
if size > 999 {
size = 999
listof = listof[:999]
}
var qs = make([]string, size, size)
var in = make([]interface{}, size, size)
for i, repo := range listof {
qs[i] = "$" + strconv.Itoa(i+1)
in[i] = repo.FullName
}
return strings.Join(qs, ","), in
}