| 
							
							
							
						 |  |  | @@ -1,410 +0,0 @@ | 
		
	
		
			
				|  |  |  |  | package repositories | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | import ( | 
		
	
		
			
				|  |  |  |  | 	"context" | 
		
	
		
			
				|  |  |  |  | 	"time" | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	"github.com/shopspring/decimal" | 
		
	
		
			
				|  |  |  |  | 	"go.uber.org/zap" | 
		
	
		
			
				|  |  |  |  | 	"gorm.io/gorm" | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	"tyapi-server/internal/domains/finance/entities" | 
		
	
		
			
				|  |  |  |  | 	"tyapi-server/internal/shared/interfaces" | 
		
	
		
			
				|  |  |  |  | ) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GormWalletRepository 钱包GORM仓储实现 | 
		
	
		
			
				|  |  |  |  | type GormWalletRepository struct { | 
		
	
		
			
				|  |  |  |  | 	db     *gorm.DB | 
		
	
		
			
				|  |  |  |  | 	logger *zap.Logger | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // NewGormWalletRepository 创建钱包GORM仓储 | 
		
	
		
			
				|  |  |  |  | func NewGormWalletRepository(db *gorm.DB, logger *zap.Logger) *GormWalletRepository { | 
		
	
		
			
				|  |  |  |  | 	return &GormWalletRepository{ | 
		
	
		
			
				|  |  |  |  | 		db:     db, | 
		
	
		
			
				|  |  |  |  | 		logger: logger, | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Create 创建钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Create(ctx context.Context, wallet entities.Wallet) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("创建钱包", zap.String("user_id", wallet.UserID)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Create(&wallet).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetByID 根据ID获取钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) GetByID(ctx context.Context, id string) (entities.Wallet, error) { | 
		
	
		
			
				|  |  |  |  | 	var wallet entities.Wallet | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("id = ?", id).First(&wallet).Error | 
		
	
		
			
				|  |  |  |  | 	return wallet, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Update 更新钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Update(ctx context.Context, wallet entities.Wallet) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("更新钱包", zap.String("id", wallet.ID)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Save(&wallet).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Delete 删除钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Delete(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("删除钱包", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.Wallet{}, "id = ?", id).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // SoftDelete 软删除钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) SoftDelete(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("软删除钱包", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.Wallet{}, "id = ?", id).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Restore 恢复钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Restore(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("恢复钱包", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Unscoped().Model(&entities.Wallet{}).Where("id = ?", id).Update("deleted_at", nil).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Count 统计钱包数量 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Count(ctx context.Context, options interfaces.CountOptions) (int64, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	query := r.db.WithContext(ctx).Model(&entities.Wallet{}) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Filters != nil { | 
		
	
		
			
				|  |  |  |  | 		for key, value := range options.Filters { | 
		
	
		
			
				|  |  |  |  | 			query = query.Where(key+" = ?", value) | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Search != "" { | 
		
	
		
			
				|  |  |  |  | 		query = query.Where("user_id LIKE ?", "%"+options.Search+"%") | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	return count, query.Count(&count).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Exists 检查钱包是否存在 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) Exists(ctx context.Context, id string) (bool, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("id = ?", id).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count > 0, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // CreateBatch 批量创建钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) CreateBatch(ctx context.Context, wallets []entities.Wallet) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量创建钱包", zap.Int("count", len(wallets))) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Create(&wallets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetByIDs 根据ID列表获取钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) GetByIDs(ctx context.Context, ids []string) ([]entities.Wallet, error) { | 
		
	
		
			
				|  |  |  |  | 	var wallets []entities.Wallet | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("id IN ?", ids).Find(&wallets).Error | 
		
	
		
			
				|  |  |  |  | 	return wallets, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // UpdateBatch 批量更新钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) UpdateBatch(ctx context.Context, wallets []entities.Wallet) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量更新钱包", zap.Int("count", len(wallets))) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Save(&wallets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // DeleteBatch 批量删除钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) DeleteBatch(ctx context.Context, ids []string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量删除钱包", zap.Strings("ids", ids)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.Wallet{}, "id IN ?", ids).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // List 获取钱包列表 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) List(ctx context.Context, options interfaces.ListOptions) ([]entities.Wallet, error) { | 
		
	
		
			
				|  |  |  |  | 	var wallets []entities.Wallet | 
		
	
		
			
				|  |  |  |  | 	query := r.db.WithContext(ctx).Model(&entities.Wallet{}) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Filters != nil { | 
		
	
		
			
				|  |  |  |  | 		for key, value := range options.Filters { | 
		
	
		
			
				|  |  |  |  | 			query = query.Where(key+" = ?", value) | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Search != "" { | 
		
	
		
			
				|  |  |  |  | 		query = query.Where("user_id LIKE ?", "%"+options.Search+"%") | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Sort != "" { | 
		
	
		
			
				|  |  |  |  | 		order := "ASC" | 
		
	
		
			
				|  |  |  |  | 		if options.Order != "" { | 
		
	
		
			
				|  |  |  |  | 			order = options.Order | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 		query = query.Order(options.Sort + " " + order) | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Page > 0 && options.PageSize > 0 { | 
		
	
		
			
				|  |  |  |  | 		offset := (options.Page - 1) * options.PageSize | 
		
	
		
			
				|  |  |  |  | 		query = query.Offset(offset).Limit(options.PageSize) | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	return wallets, query.Find(&wallets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // WithTx 使用事务 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) WithTx(tx interface{}) interfaces.Repository[entities.Wallet] { | 
		
	
		
			
				|  |  |  |  | 	if gormTx, ok := tx.(*gorm.DB); ok { | 
		
	
		
			
				|  |  |  |  | 		return &GormWalletRepository{ | 
		
	
		
			
				|  |  |  |  | 			db:     gormTx, | 
		
	
		
			
				|  |  |  |  | 			logger: r.logger, | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return r | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // FindByUserID 根据用户ID查找钱包 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) FindByUserID(ctx context.Context, userID string) (*entities.Wallet, error) { | 
		
	
		
			
				|  |  |  |  | 	var wallet entities.Wallet | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("user_id = ?", userID).First(&wallet).Error | 
		
	
		
			
				|  |  |  |  | 	if err != nil { | 
		
	
		
			
				|  |  |  |  | 		return nil, err | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return &wallet, nil | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // ExistsByUserID 检查用户钱包是否存在 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) ExistsByUserID(ctx context.Context, userID string) (bool, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("user_id = ?", userID).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count > 0, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // UpdateBalance 更新余额 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) UpdateBalance(ctx context.Context, userID string, balance interface{}) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("user_id = ?", userID).Update("balance", balance).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // AddBalance 增加余额 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) AddBalance(ctx context.Context, userID string, amount interface{}) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("user_id = ?", userID).Update("balance", gorm.Expr("balance + ?", amount)).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // SubtractBalance 减少余额 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) SubtractBalance(ctx context.Context, userID string, amount interface{}) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("user_id = ?", userID).Update("balance", gorm.Expr("balance - ?", amount)).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetTotalBalance 获取总余额 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) GetTotalBalance(ctx context.Context) (interface{}, error) { | 
		
	
		
			
				|  |  |  |  | 	var total decimal.Decimal | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.Wallet{}).Select("COALESCE(SUM(balance), 0)").Scan(&total).Error | 
		
	
		
			
				|  |  |  |  | 	return total, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetActiveWalletCount 获取激活钱包数量 | 
		
	
		
			
				|  |  |  |  | func (r *GormWalletRepository) GetActiveWalletCount(ctx context.Context) (int64, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.Wallet{}).Where("is_active = ?", true).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GormUserSecretsRepository 用户密钥GORM仓储实现 | 
		
	
		
			
				|  |  |  |  | type GormUserSecretsRepository struct { | 
		
	
		
			
				|  |  |  |  | 	db     *gorm.DB | 
		
	
		
			
				|  |  |  |  | 	logger *zap.Logger | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // NewGormUserSecretsRepository 创建用户密钥GORM仓储 | 
		
	
		
			
				|  |  |  |  | func NewGormUserSecretsRepository(db *gorm.DB, logger *zap.Logger) *GormUserSecretsRepository { | 
		
	
		
			
				|  |  |  |  | 	return &GormUserSecretsRepository{ | 
		
	
		
			
				|  |  |  |  | 		db:     db, | 
		
	
		
			
				|  |  |  |  | 		logger: logger, | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Create 创建用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Create(ctx context.Context, secrets entities.UserSecrets) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("创建用户密钥", zap.String("user_id", secrets.UserID)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Create(&secrets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetByID 根据ID获取用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) GetByID(ctx context.Context, id string) (entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("id = ?", id).First(&secrets).Error | 
		
	
		
			
				|  |  |  |  | 	return secrets, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Update 更新用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Update(ctx context.Context, secrets entities.UserSecrets) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("更新用户密钥", zap.String("id", secrets.ID)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Save(&secrets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Delete 删除用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Delete(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("删除用户密钥", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.UserSecrets{}, "id = ?", id).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // SoftDelete 软删除用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) SoftDelete(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("软删除用户密钥", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.UserSecrets{}, "id = ?", id).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Restore 恢复用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Restore(ctx context.Context, id string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("恢复用户密钥", zap.String("id", id)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Unscoped().Model(&entities.UserSecrets{}).Where("id = ?", id).Update("deleted_at", nil).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Count 统计用户密钥数量 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Count(ctx context.Context, options interfaces.CountOptions) (int64, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	query := r.db.WithContext(ctx).Model(&entities.UserSecrets{}) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Filters != nil { | 
		
	
		
			
				|  |  |  |  | 		for key, value := range options.Filters { | 
		
	
		
			
				|  |  |  |  | 			query = query.Where(key+" = ?", value) | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Search != "" { | 
		
	
		
			
				|  |  |  |  | 		query = query.Where("user_id LIKE ? OR access_id LIKE ?", "%"+options.Search+"%", "%"+options.Search+"%") | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	return count, query.Count(&count).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Exists 检查用户密钥是否存在 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) Exists(ctx context.Context, id string) (bool, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("id = ?", id).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count > 0, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // CreateBatch 批量创建用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) CreateBatch(ctx context.Context, secrets []entities.UserSecrets) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量创建用户密钥", zap.Int("count", len(secrets))) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Create(&secrets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetByIDs 根据ID列表获取用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) GetByIDs(ctx context.Context, ids []string) ([]entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets []entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("id IN ?", ids).Find(&secrets).Error | 
		
	
		
			
				|  |  |  |  | 	return secrets, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // UpdateBatch 批量更新用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) UpdateBatch(ctx context.Context, secrets []entities.UserSecrets) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量更新用户密钥", zap.Int("count", len(secrets))) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Save(&secrets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // DeleteBatch 批量删除用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) DeleteBatch(ctx context.Context, ids []string) error { | 
		
	
		
			
				|  |  |  |  | 	r.logger.Info("批量删除用户密钥", zap.Strings("ids", ids)) | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Delete(&entities.UserSecrets{}, "id IN ?", ids).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // List 获取用户密钥列表 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) List(ctx context.Context, options interfaces.ListOptions) ([]entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets []entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	query := r.db.WithContext(ctx).Model(&entities.UserSecrets{}) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Filters != nil { | 
		
	
		
			
				|  |  |  |  | 		for key, value := range options.Filters { | 
		
	
		
			
				|  |  |  |  | 			query = query.Where(key+" = ?", value) | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Search != "" { | 
		
	
		
			
				|  |  |  |  | 		query = query.Where("user_id LIKE ? OR access_id LIKE ?", "%"+options.Search+"%", "%"+options.Search+"%") | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Sort != "" { | 
		
	
		
			
				|  |  |  |  | 		order := "ASC" | 
		
	
		
			
				|  |  |  |  | 		if options.Order != "" { | 
		
	
		
			
				|  |  |  |  | 			order = options.Order | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 		query = query.Order(options.Sort + " " + order) | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if options.Page > 0 && options.PageSize > 0 { | 
		
	
		
			
				|  |  |  |  | 		offset := (options.Page - 1) * options.PageSize | 
		
	
		
			
				|  |  |  |  | 		query = query.Offset(offset).Limit(options.PageSize) | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	return secrets, query.Find(&secrets).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // WithTx 使用事务 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) WithTx(tx interface{}) interfaces.Repository[entities.UserSecrets] { | 
		
	
		
			
				|  |  |  |  | 	if gormTx, ok := tx.(*gorm.DB); ok { | 
		
	
		
			
				|  |  |  |  | 		return &GormUserSecretsRepository{ | 
		
	
		
			
				|  |  |  |  | 			db:     gormTx, | 
		
	
		
			
				|  |  |  |  | 			logger: r.logger, | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return r | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // FindByUserID 根据用户ID查找密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) FindByUserID(ctx context.Context, userID string) (*entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("user_id = ?", userID).First(&secrets).Error | 
		
	
		
			
				|  |  |  |  | 	if err != nil { | 
		
	
		
			
				|  |  |  |  | 		return nil, err | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return &secrets, nil | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // FindByAccessID 根据访问ID查找密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) FindByAccessID(ctx context.Context, accessID string) (*entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("access_id = ?", accessID).First(&secrets).Error | 
		
	
		
			
				|  |  |  |  | 	if err != nil { | 
		
	
		
			
				|  |  |  |  | 		return nil, err | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return &secrets, nil | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // ExistsByUserID 检查用户密钥是否存在 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) ExistsByUserID(ctx context.Context, userID string) (bool, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("user_id = ?", userID).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count > 0, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // ExistsByAccessID 检查访问ID是否存在 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) ExistsByAccessID(ctx context.Context, accessID string) (bool, error) { | 
		
	
		
			
				|  |  |  |  | 	var count int64 | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("access_id = ?", accessID).Count(&count).Error | 
		
	
		
			
				|  |  |  |  | 	return count > 0, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // UpdateLastUsedAt 更新最后使用时间 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) UpdateLastUsedAt(ctx context.Context, accessID string) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("access_id = ?", accessID).Update("last_used_at", time.Now()).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // DeactivateByUserID 停用用户密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) DeactivateByUserID(ctx context.Context, userID string) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("user_id = ?", userID).Update("is_active", false).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // RegenerateAccessKey 重新生成访问密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) RegenerateAccessKey(ctx context.Context, userID string, accessID, accessKey string) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Model(&entities.UserSecrets{}).Where("user_id = ?", userID).Updates(map[string]interface{}{ | 
		
	
		
			
				|  |  |  |  | 		"access_id":  accessID, | 
		
	
		
			
				|  |  |  |  | 		"access_key": accessKey, | 
		
	
		
			
				|  |  |  |  | 		"updated_at": time.Now(), | 
		
	
		
			
				|  |  |  |  | 	}).Error | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // GetExpiredSecrets 获取过期的密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) GetExpiredSecrets(ctx context.Context) ([]entities.UserSecrets, error) { | 
		
	
		
			
				|  |  |  |  | 	var secrets []entities.UserSecrets | 
		
	
		
			
				|  |  |  |  | 	err := r.db.WithContext(ctx).Where("expires_at IS NOT NULL AND expires_at < ?", time.Now()).Find(&secrets).Error | 
		
	
		
			
				|  |  |  |  | 	return secrets, err | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // DeleteExpiredSecrets 删除过期的密钥 | 
		
	
		
			
				|  |  |  |  | func (r *GormUserSecretsRepository) DeleteExpiredSecrets(ctx context.Context) error { | 
		
	
		
			
				|  |  |  |  | 	return r.db.WithContext(ctx).Where("expires_at IS NOT NULL AND expires_at < ?", time.Now()).Delete(&entities.UserSecrets{}).Error | 
		
	
		
			
				|  |  |  |  | } |