harness-drone/store/datastore/utils.go

80 lines
1.8 KiB
Go
Raw Normal View History

package datastore
2015-09-30 01:21:17 +00:00
import (
"strconv"
2015-10-21 23:39:43 +00:00
"strings"
2015-09-30 01:21:17 +00:00
2015-10-21 23:39:43 +00:00
"github.com/drone/drone/model"
2015-09-30 01:21:17 +00:00
"github.com/russross/meddler"
)
// rebind is a helper function that changes the sql
2015-09-30 01:21:17 +00:00
// bind type from ? to $ for postgres queries.
func rebind(query string) string {
2015-09-30 01:21:17 +00: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 01:21:17 +00:00
rqb = append(rqb, '$')
for _, b := range strconv.Itoa(j) {
rqb = append(rqb, byte(b))
}
j++
case '`':
rqb = append(rqb, ' ')
default:
2015-09-30 01:21:17 +00:00
rqb = append(rqb, b)
}
}
return string(rqb)
}
2015-10-21 23:39:43 +00: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)
switch {
case meddler.Default == meddler.SQLite && size > 999:
size = 999
listof = listof[:999]
case size > 15000:
size = 15000
listof = listof[:15000]
}
2015-10-21 23:39:43 +00:00
var qs = make([]string, size, size)
var in = make([]interface{}, size, size)
for i, repo := range listof {
qs[i] = "?"
2015-10-21 23:39:43 +00:00
in[i] = repo.FullName
}
return strings.Join(qs, ","), in
}
// helper function that converts a simple repository list
// to a sql IN statement compatible with postgres.
2016-09-02 11:32:17 +00:00
func toListPostgres(listof []*model.RepoLite) (string, []interface{}) {
2015-10-21 23:39:43 +00:00
var size = len(listof)
switch {
case meddler.Default == meddler.SQLite && size > 999:
size = 999
listof = listof[:999]
case size > 15000:
size = 15000
listof = listof[:15000]
}
2015-10-21 23:39:43 +00:00
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
}