120 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
// 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"
 | 
						|
)
 | 
						|
 | 
						|
var (
 | 
						|
	Q         = new(Query)
 | 
						|
	Space     *space
 | 
						|
	SpaceUser *spaceUser
 | 
						|
	User      *user
 | 
						|
)
 | 
						|
 | 
						|
func SetDefault(db *gorm.DB, opts ...gen.DOOption) {
 | 
						|
	*Q = *Use(db, opts...)
 | 
						|
	Space = &Q.Space
 | 
						|
	SpaceUser = &Q.SpaceUser
 | 
						|
	User = &Q.User
 | 
						|
}
 | 
						|
 | 
						|
func Use(db *gorm.DB, opts ...gen.DOOption) *Query {
 | 
						|
	return &Query{
 | 
						|
		db:        db,
 | 
						|
		Space:     newSpace(db, opts...),
 | 
						|
		SpaceUser: newSpaceUser(db, opts...),
 | 
						|
		User:      newUser(db, opts...),
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
type Query struct {
 | 
						|
	db *gorm.DB
 | 
						|
 | 
						|
	Space     space
 | 
						|
	SpaceUser spaceUser
 | 
						|
	User      user
 | 
						|
}
 | 
						|
 | 
						|
func (q *Query) Available() bool { return q.db != nil }
 | 
						|
 | 
						|
func (q *Query) clone(db *gorm.DB) *Query {
 | 
						|
	return &Query{
 | 
						|
		db:        db,
 | 
						|
		Space:     q.Space.clone(db),
 | 
						|
		SpaceUser: q.SpaceUser.clone(db),
 | 
						|
		User:      q.User.clone(db),
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (q *Query) ReadDB() *Query {
 | 
						|
	return q.ReplaceDB(q.db.Clauses(dbresolver.Read))
 | 
						|
}
 | 
						|
 | 
						|
func (q *Query) WriteDB() *Query {
 | 
						|
	return q.ReplaceDB(q.db.Clauses(dbresolver.Write))
 | 
						|
}
 | 
						|
 | 
						|
func (q *Query) ReplaceDB(db *gorm.DB) *Query {
 | 
						|
	return &Query{
 | 
						|
		db:        db,
 | 
						|
		Space:     q.Space.replaceDB(db),
 | 
						|
		SpaceUser: q.SpaceUser.replaceDB(db),
 | 
						|
		User:      q.User.replaceDB(db),
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
type queryCtx struct {
 | 
						|
	Space     ISpaceDo
 | 
						|
	SpaceUser ISpaceUserDo
 | 
						|
	User      IUserDo
 | 
						|
}
 | 
						|
 | 
						|
func (q *Query) WithContext(ctx context.Context) *queryCtx {
 | 
						|
	return &queryCtx{
 | 
						|
		Space:     q.Space.WithContext(ctx),
 | 
						|
		SpaceUser: q.SpaceUser.WithContext(ctx),
 | 
						|
		User:      q.User.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 {
 | 
						|
	tx := q.db.Begin(opts...)
 | 
						|
	return &QueryTx{Query: q.clone(tx), Error: tx.Error}
 | 
						|
}
 | 
						|
 | 
						|
type QueryTx struct {
 | 
						|
	*Query
 | 
						|
	Error error
 | 
						|
}
 | 
						|
 | 
						|
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
 | 
						|
}
 |