app-cloudep-wallet-service/pkg/repository/wallet.go

114 lines
2.5 KiB
Go
Raw Permalink Normal View History

2025-04-10 23:23:42 +00:00
package repository
import (
"code.30cm.net/digimon/app-cloudep-wallet-service/pkg/domain/entity"
"code.30cm.net/digimon/app-cloudep-wallet-service/pkg/domain/repository"
"context"
"database/sql"
"gorm.io/gorm"
)
type WalletRepositoryParam struct {
DB *gorm.DB `name:"dbM"`
}
type WalletRepository struct {
WalletRepositoryParam
}
func MustCategoryRepository(param WalletRepositoryParam) repository.WalletRepository {
return &WalletRepository{
param,
}
}
func (repo *WalletRepository) NewDB() *gorm.DB {
2025-04-16 09:24:54 +00:00
return repo.DB.Begin()
2025-04-10 23:23:42 +00:00
}
2025-04-17 09:00:42 +00:00
// Transaction 指 DB 事務,非記錄一筆交易
2025-04-10 23:23:42 +00:00
func (repo *WalletRepository) Transaction(fn func(db *gorm.DB) error) error {
db := repo.DB.Begin(&sql.TxOptions{
Isolation: sql.LevelReadCommitted,
ReadOnly: false,
})
defer db.Rollback()
if err := fn(db); err != nil {
return err
}
if err := db.Commit().Error; err != nil {
return err
}
return nil
}
func (repo *WalletRepository) Session(uid, asset string) repository.UserWalletService {
2025-04-18 09:10:40 +00:00
return NewWalletService(repo.DB, uid, asset)
2025-04-10 23:23:42 +00:00
}
func (repo *WalletRepository) SessionWithTx(db *gorm.DB, uid, asset string) repository.UserWalletService {
2025-04-18 09:10:40 +00:00
return NewWalletService(db, uid, asset)
2025-04-10 23:23:42 +00:00
}
func (repo *WalletRepository) InitWallets(ctx context.Context, param []repository.Wallet) error {
2025-04-16 09:24:54 +00:00
wallets := make([]entity.Wallet, 0, len(param))
for _, t := range param {
wallets = append(wallets, entity.Wallet{
Brand: t.Brand,
UID: t.UID,
Asset: t.Asset,
Balance: t.Balance,
Type: t.Type,
})
}
if err := repo.DB.Create(&wallets).WithContext(ctx).Error; err != nil {
return err
}
return nil
2025-04-10 23:23:42 +00:00
}
func (repo *WalletRepository) QueryBalances(ctx context.Context, req repository.BalanceQuery) ([]entity.Wallet, error) {
2025-04-16 09:24:54 +00:00
var data []entity.Wallet
s := repo.DB.WithContext(ctx).
Select("id, asset, balance, type, update_at").
Where("uid = ?", req.UID)
if req.Asset != "" {
s = s.Where("asset = ?", req.Asset)
}
err := s.Find(&data).Error
if err != nil {
return nil, err
}
return data, nil
2025-04-10 23:23:42 +00:00
}
func (repo *WalletRepository) QueryBalancesByUIDs(ctx context.Context, uids []string, req repository.BalanceQuery) ([]entity.Wallet, error) {
2025-04-16 09:24:54 +00:00
var data []entity.Wallet
query := repo.DB.WithContext(ctx).
Select("uid, asset, balance, type, update_at").
Where("uid IN ?", uids)
if req.Asset != "" {
query = query.Where("asset = ?", req.Asset)
}
if len(req.Kinds) > 0 {
query = query.Where("type IN ?", req.Kinds)
}
err := query.Find(&data).Error
if err != nil {
return nil, err
}
return data, nil
2025-04-10 23:23:42 +00:00
}