/
gen.go
113 lines (91 loc) · 2.94 KB
/
gen.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.
package query
import (
"context"
"database/sql"
"gorm.io/gorm"
"gorm.io/gen"
"gorm.io/plugin/dbresolver"
)
func Use(db *gorm.DB, opts ...gen.DOOption) *Query {
return &Query{
db: db,
CexBinanceKlineCsv: newCexBinanceKlineCsv(db, opts...),
CexOrder: newCexOrder(db, opts...),
CexSellOrder: newCexSellOrder(db, opts...),
ChainbotBot: newChainbotBot(db, opts...),
ChainbotBotTemplate: newChainbotBotTemplate(db, opts...),
}
}
type Query struct {
db *gorm.DB
CexBinanceKlineCsv cexBinanceKlineCsv
CexOrder cexOrder
CexSellOrder cexSellOrder
ChainbotBot chainbotBot
ChainbotBotTemplate chainbotBotTemplate
}
func (q *Query) Available() bool { return q.db != nil }
func (q *Query) clone(db *gorm.DB) *Query {
return &Query{
db: db,
CexBinanceKlineCsv: q.CexBinanceKlineCsv.clone(db),
CexOrder: q.CexOrder.clone(db),
CexSellOrder: q.CexSellOrder.clone(db),
ChainbotBot: q.ChainbotBot.clone(db),
ChainbotBotTemplate: q.ChainbotBotTemplate.clone(db),
}
}
func (q *Query) ReadDB() *Query {
return q.clone(q.db.Clauses(dbresolver.Read))
}
func (q *Query) WriteDB() *Query {
return q.clone(q.db.Clauses(dbresolver.Write))
}
func (q *Query) ReplaceDB(db *gorm.DB) *Query {
return &Query{
db: db,
CexBinanceKlineCsv: q.CexBinanceKlineCsv.replaceDB(db),
CexOrder: q.CexOrder.replaceDB(db),
CexSellOrder: q.CexSellOrder.replaceDB(db),
ChainbotBot: q.ChainbotBot.replaceDB(db),
ChainbotBotTemplate: q.ChainbotBotTemplate.replaceDB(db),
}
}
type queryCtx struct {
CexBinanceKlineCsv *cexBinanceKlineCsvDo
CexOrder *cexOrderDo
CexSellOrder *cexSellOrderDo
ChainbotBot *chainbotBotDo
ChainbotBotTemplate *chainbotBotTemplateDo
}
func (q *Query) WithContext(ctx context.Context) *queryCtx {
return &queryCtx{
CexBinanceKlineCsv: q.CexBinanceKlineCsv.WithContext(ctx),
CexOrder: q.CexOrder.WithContext(ctx),
CexSellOrder: q.CexSellOrder.WithContext(ctx),
ChainbotBot: q.ChainbotBot.WithContext(ctx),
ChainbotBotTemplate: q.ChainbotBotTemplate.WithContext(ctx),
}
}
func (q *Query) Transaction(fc func(tx *Query) error, opts ...*sql.TxOptions) error {
return q.db.Transaction(func(tx *gorm.DB) error { return fc(q.clone(tx)) }, opts...)
}
func (q *Query) Begin(opts ...*sql.TxOptions) *QueryTx {
return &QueryTx{q.clone(q.db.Begin(opts...))}
}
type QueryTx struct{ *Query }
func (q *QueryTx) Commit() error {
return q.db.Commit().Error
}
func (q *QueryTx) Rollback() error {
return q.db.Rollback().Error
}
func (q *QueryTx) SavePoint(name string) error {
return q.db.SavePoint(name).Error
}
func (q *QueryTx) RollbackTo(name string) error {
return q.db.RollbackTo(name).Error
}