|
@ -45,11 +45,14 @@ func GetCurrentRB(aid, uid, rid int64) (map[string]interface{}, error) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const ( |
|
|
const ( |
|
|
MinRedPackAmount = 1 // 分钱
|
|
|
|
|
|
MaxRedPackAmount = 20000 // 4990
|
|
|
|
|
|
|
|
|
MinRedPackAmount = 100 // 1块钱
|
|
|
|
|
|
MaxRedPackAmount = 20000 // 200块钱
|
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
func GenRedPack(amount, num int) []int { |
|
|
|
|
|
|
|
|
func GenRedPack(amount, num int) ([]int, error) { |
|
|
|
|
|
if amount/num <= 100 { |
|
|
|
|
|
return nil, errors.New("每个红包的平均金额必须在1.00元到200.00元之间") |
|
|
|
|
|
} |
|
|
r := rand.New(rand.NewSource(time.Now().UnixNano())) |
|
|
r := rand.New(rand.NewSource(time.Now().UnixNano())) |
|
|
sumMoney := 0 |
|
|
sumMoney := 0 |
|
|
redPacks := make([]int, 0) |
|
|
redPacks := make([]int, 0) |
|
@ -75,17 +78,15 @@ func GenRedPack(amount, num int) []int { |
|
|
sumMoney += money |
|
|
sumMoney += money |
|
|
redPacks = append(redPacks, money) |
|
|
redPacks = append(redPacks, money) |
|
|
} |
|
|
} |
|
|
return redPacks |
|
|
|
|
|
|
|
|
return redPacks, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// 提前生成红包
|
|
|
// 提前生成红包
|
|
|
func GenRedEnvelope(aid int64, name string, rid int64, rule *models.ShakeRedEnvelopeRule) error { |
|
|
func GenRedEnvelope(aid int64, name string, rid int64, rule *models.ShakeRedEnvelopeRule) error { |
|
|
// 判断红包是否存在
|
|
|
// 判断红包是否存在
|
|
|
// 根据算法提前生成红包
|
|
|
// 根据算法提前生成红包
|
|
|
|
|
|
|
|
|
r := rand.New(rand.NewSource(time.Now().UnixNano())) |
|
|
r := rand.New(rand.NewSource(time.Now().UnixNano())) |
|
|
if rule.Model == define.SHAKERB_RULE_RANDOM { // 随机红包
|
|
|
if rule.Model == define.SHAKERB_RULE_RANDOM { // 随机红包
|
|
|
|
|
|
|
|
|
// 检测红包是否存在
|
|
|
// 检测红包是否存在
|
|
|
for i := 0; i < rule.RedEnvelopeNum; i++ { |
|
|
for i := 0; i < rule.RedEnvelopeNum; i++ { |
|
|
randSum := int(rule.RandSum * 100) |
|
|
randSum := int(rule.RandSum * 100) |
|
|