appview: db: add FilterBetween #520

closed
opened by ptr.pet targeting master from ptr.pet/core: pipeline-paginated
Changed files
+7
appview
db
+7
appview/db/db.go
···
func FilterIs(key string, arg any) filter { return newFilter(key, "is", arg) }
func FilterIsNot(key string, arg any) filter { return newFilter(key, "is not", arg) }
func FilterIn(key string, arg any) filter { return newFilter(key, "in", arg) }
+
func FilterBetween(key string, arg1, arg2 any) filter {
+
return newFilter(key, "between", []any{arg1, arg2})
+
}
func (f filter) Condition() string {
rv := reflect.ValueOf(f.arg)
kind := rv.Kind()
+
if f.cmp == "between" {
+
return fmt.Sprintf("%s %s ? and ?", f.key, f.cmp)
+
}
+
// if we have `FilterIn(k, [1, 2, 3])`, compile it down to `k in (?, ?, ?)`
if (kind == reflect.Slice && rv.Type().Elem().Kind() != reflect.Uint8) || kind == reflect.Array {
if rv.Len() == 0 {