2015-10-21 23:14:02 +00:00
|
|
|
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"
|
|
|
|
)
|
|
|
|
|
2015-10-21 23:14:02 +00:00
|
|
|
// rebind is a helper function that changes the sql
|
2015-09-30 01:21:17 +00:00
|
|
|
// bind type from ? to $ for postgres queries.
|
2015-10-21 23:14:02 +00:00
|
|
|
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 {
|
2015-10-20 07:08:09 +00:00
|
|
|
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++
|
2015-10-20 07:08:09 +00:00
|
|
|
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)
|
2017-02-05 02:45:25 +00:00
|
|
|
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 {
|
2015-11-11 23:09:12 +00:00
|
|
|
qs[i] = "?"
|
2015-10-21 23:39:43 +00:00
|
|
|
in[i] = repo.FullName
|
|
|
|
}
|
|
|
|
return strings.Join(qs, ","), in
|
|
|
|
}
|
|
|
|
|
2016-03-27 00:14:00 +00:00
|
|
|
// 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)
|
2017-02-11 20:12:34 +00:00
|
|
|
if size > 15000 {
|
2017-02-05 02:45:25 +00:00
|
|
|
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
|
|
|
|
}
|