复制项目
This commit is contained in:
62
pkg/common/storage/database/redpacket.go
Normal file
62
pkg/common/storage/database/redpacket.go
Normal file
@@ -0,0 +1,62 @@
|
||||
// Copyright © 2023 OpenIM. All rights reserved.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package database
|
||||
|
||||
import (
|
||||
"context"
|
||||
"time"
|
||||
|
||||
"git.imall.cloud/openim/open-im-server-deploy/pkg/common/storage/model"
|
||||
"github.com/openimsdk/tools/db/pagination"
|
||||
)
|
||||
|
||||
// RedPacket defines the operations for managing red packets in MongoDB.
|
||||
type RedPacket interface {
|
||||
// Create creates a new red packet record.
|
||||
Create(ctx context.Context, redPacket *model.RedPacket) error
|
||||
// Take retrieves a red packet by ID. Returns an error if not found.
|
||||
Take(ctx context.Context, redPacketID string) (*model.RedPacket, error)
|
||||
// UpdateStatus updates the status of a red packet.
|
||||
UpdateStatus(ctx context.Context, redPacketID string, status int32) error
|
||||
// UpdateRemain updates the remain amount and count of a red packet.
|
||||
UpdateRemain(ctx context.Context, redPacketID string, remainAmount int64, remainCount int32) error
|
||||
// DecreaseRemainAtomic 原子性地减少红包剩余数量和金额(防止并发问题)
|
||||
// 只有在 remain_count > 0 时才会更新,返回更新后的红包信息
|
||||
DecreaseRemainAtomic(ctx context.Context, redPacketID string, amount int64) (*model.RedPacket, error)
|
||||
// FindExpiredRedPackets finds red packets that have expired.
|
||||
FindExpiredRedPackets(ctx context.Context, beforeTime time.Time) ([]*model.RedPacket, error)
|
||||
// FindRedPacketsByUser finds red packets sent by a user with pagination.
|
||||
FindRedPacketsByUser(ctx context.Context, userID string, pagination pagination.Pagination) (total int64, redPackets []*model.RedPacket, err error)
|
||||
// FindRedPacketsByGroup finds red packets in a group with pagination.
|
||||
FindRedPacketsByGroup(ctx context.Context, groupID string, pagination pagination.Pagination) (total int64, redPackets []*model.RedPacket, err error)
|
||||
// FindAllRedPackets finds all red packets with pagination.
|
||||
FindAllRedPackets(ctx context.Context, pagination pagination.Pagination) (total int64, redPackets []*model.RedPacket, err error)
|
||||
}
|
||||
|
||||
// RedPacketReceive defines the operations for managing red packet receives in MongoDB.
|
||||
type RedPacketReceive interface {
|
||||
// Create creates a new red packet receive record.
|
||||
Create(ctx context.Context, receive *model.RedPacketReceive) error
|
||||
// Take retrieves a receive record by ID. Returns an error if not found.
|
||||
Take(ctx context.Context, receiveID string) (*model.RedPacketReceive, error)
|
||||
// FindByRedPacketID finds all receive records for a red packet.
|
||||
FindByRedPacketID(ctx context.Context, redPacketID string) ([]*model.RedPacketReceive, error)
|
||||
// FindByUserAndRedPacketID finds if a user has received a specific red packet.
|
||||
FindByUserAndRedPacketID(ctx context.Context, userID, redPacketID string) (*model.RedPacketReceive, error)
|
||||
// FindByUser finds all red packets received by a user with pagination.
|
||||
FindByUser(ctx context.Context, userID string, pagination pagination.Pagination) (total int64, receives []*model.RedPacketReceive, err error)
|
||||
// DeleteByReceiveID deletes a receive record by receive ID (for cleanup on failure).
|
||||
DeleteByReceiveID(ctx context.Context, receiveID string) error
|
||||
}
|
||||
Reference in New Issue
Block a user