mirror of
https://github.com/safing/portmaster
synced 2025-04-19 10:29:11 +00:00
131 lines
2.8 KiB
Go
131 lines
2.8 KiB
Go
// Code generated by BobGen sqlite v0.30.0. DO NOT EDIT.
|
|
// This file is meant to be re-generated in place and/or deleted at any time.
|
|
|
|
package models
|
|
|
|
import (
|
|
"hash/maphash"
|
|
"strings"
|
|
|
|
"github.com/stephenafamo/bob"
|
|
"github.com/stephenafamo/bob/clause"
|
|
"github.com/stephenafamo/bob/dialect/sqlite"
|
|
"github.com/stephenafamo/bob/dialect/sqlite/dialect"
|
|
sqliteDriver "modernc.org/sqlite"
|
|
)
|
|
|
|
var TableNames = struct {
|
|
Records string
|
|
}{
|
|
Records: "records",
|
|
}
|
|
|
|
var ColumnNames = struct {
|
|
Records recordColumnNames
|
|
}{
|
|
Records: recordColumnNames{
|
|
Key: "key",
|
|
Format: "format",
|
|
Value: "value",
|
|
Created: "created",
|
|
Modified: "modified",
|
|
Expires: "expires",
|
|
Deleted: "deleted",
|
|
Secret: "secret",
|
|
Crownjewel: "crownjewel",
|
|
},
|
|
}
|
|
|
|
var (
|
|
SelectWhere = Where[*dialect.SelectQuery]()
|
|
InsertWhere = Where[*dialect.InsertQuery]()
|
|
UpdateWhere = Where[*dialect.UpdateQuery]()
|
|
DeleteWhere = Where[*dialect.DeleteQuery]()
|
|
)
|
|
|
|
func Where[Q sqlite.Filterable]() struct {
|
|
Records recordWhere[Q]
|
|
} {
|
|
return struct {
|
|
Records recordWhere[Q]
|
|
}{
|
|
Records: buildRecordWhere[Q](RecordColumns),
|
|
}
|
|
}
|
|
|
|
var (
|
|
SelectJoins = getJoins[*dialect.SelectQuery]
|
|
UpdateJoins = getJoins[*dialect.UpdateQuery]
|
|
)
|
|
|
|
type joinSet[Q interface{ aliasedAs(string) Q }] struct {
|
|
InnerJoin Q
|
|
LeftJoin Q
|
|
RightJoin Q
|
|
}
|
|
|
|
func (j joinSet[Q]) AliasedAs(alias string) joinSet[Q] {
|
|
return joinSet[Q]{
|
|
InnerJoin: j.InnerJoin.aliasedAs(alias),
|
|
LeftJoin: j.LeftJoin.aliasedAs(alias),
|
|
RightJoin: j.RightJoin.aliasedAs(alias),
|
|
}
|
|
}
|
|
|
|
type joins[Q dialect.Joinable] struct{}
|
|
|
|
func buildJoinSet[Q interface{ aliasedAs(string) Q }, C any, F func(C, string) Q](c C, f F) joinSet[Q] {
|
|
return joinSet[Q]{
|
|
InnerJoin: f(c, clause.InnerJoin),
|
|
LeftJoin: f(c, clause.LeftJoin),
|
|
RightJoin: f(c, clause.RightJoin),
|
|
}
|
|
}
|
|
|
|
func getJoins[Q dialect.Joinable]() joins[Q] {
|
|
return joins[Q]{}
|
|
}
|
|
|
|
type modAs[Q any, C interface{ AliasedAs(string) C }] struct {
|
|
c C
|
|
f func(C) bob.Mod[Q]
|
|
}
|
|
|
|
func (m modAs[Q, C]) Apply(q Q) {
|
|
m.f(m.c).Apply(q)
|
|
}
|
|
|
|
func (m modAs[Q, C]) AliasedAs(alias string) bob.Mod[Q] {
|
|
m.c = m.c.AliasedAs(alias)
|
|
return m
|
|
}
|
|
|
|
func randInt() int64 {
|
|
out := int64(new(maphash.Hash).Sum64())
|
|
|
|
if out < 0 {
|
|
return -out % 10000
|
|
}
|
|
|
|
return out % 10000
|
|
}
|
|
|
|
// ErrUniqueConstraint captures all unique constraint errors by explicitly leaving `s` empty.
|
|
var ErrUniqueConstraint = &UniqueConstraintError{s: ""}
|
|
|
|
type UniqueConstraintError struct {
|
|
// s is a string uniquely identifying the constraint in the raw error message returned from the database.
|
|
s string
|
|
}
|
|
|
|
func (e *UniqueConstraintError) Error() string {
|
|
return e.s
|
|
}
|
|
|
|
func (e *UniqueConstraintError) Is(target error) bool {
|
|
err, ok := target.(*sqliteDriver.Error)
|
|
if !ok {
|
|
return false
|
|
}
|
|
return err.Code() == 2067 && strings.Contains(err.Error(), e.s)
|
|
}
|