|
- package financial_center
-
- import (
- "applet/app/cfg"
- "applet/app/db"
- "applet/app/e"
- md "applet/app/md/financial_center"
- svc "applet/app/svc/financial_center"
- "applet/app/utils"
- "code.fnuoos.com/EggPlanet/egg_models.git/src/implement"
- "code.fnuoos.com/EggPlanet/egg_models.git/src/model"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/enum"
- md3 "code.fnuoos.com/EggPlanet/egg_system_rules.git/md"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule"
- md2 "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule/egg_energy/md"
- "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit"
- "errors"
- "github.com/gin-gonic/gin"
- "github.com/jinzhu/copier"
- "github.com/tidwall/gjson"
- "strings"
- "time"
- )
-
- // GetWithdrawSetting
- // @Summary 财务中心-提现-基础设置(获取)
- // @Tags 提现
- // @Description 基础设置(获取)
- // @Accept json
- // @Produce json
- // @param Authorization header string true "验证参数Bearer和token空格拼接"
- // @Success 200 {object} md.GetWithdrawSettingResp "具体数据"
- // @Failure 400 {object} md.Response "具体错误"
- // @Router /api/financialCenter/withdraw/setting [get]
- func GetWithdrawSetting(c *gin.Context) {
-
- // 等级列表
- levelDb := implement.NewUserLevelDb(db.Db)
- levels, err1 := levelDb.UserLevelAllByAsc()
- if err1 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err1.Error())
- return
- }
- levelsList := make([]map[string]interface{}, 0)
- levelsMap := make(map[int]string)
- for _, level := range levels {
- levelsList = append(levelsList, map[string]interface{}{
- "id": level.Id,
- "name": level.LevelName,
- })
- levelsMap[level.Id] = level.LevelName
- }
-
- settingDb := implement.NewFinWithdrawSettingDb(db.Db)
- setting, err := settingDb.FinWithdrawSettingGetOne()
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- // 不存在则初始化
- var emptyNum []string
- if setting == nil {
- now := time.Now()
- frequency := md2.WithdrawFrequencySettingStruct{
- Duration: 1,
- Num: emptyNum,
- }
- withdrawFeeSet := md2.WithdrawFeeSetStruct{
- Kind: 1,
- Value: 0,
- }
- firstWithdrawSet := md2.FirstWithdrawSet{
- IsNeedRealName: 0,
- FirstWithdrawAmountLimit: "",
- }
- frequencyStr := utils.SerializeStr(frequency)
- withdrawFeeSetStr := utils.SerializeStr(withdrawFeeSet)
- firstWithdrawSetStr := utils.SerializeStr(firstWithdrawSet)
- m := model.FinWithdrawSetting{
- FrequencySet: frequencyStr,
- WithdrawType: 1,
- VipLevelLimit: 0,
- IsRealName: 0,
- WithdrawNumsLimit: 0,
- WithdrawAmountLimit: "",
- WithdrawMultipleLimit: "",
- IsSupportDecimalPoint: 0,
- IsAuto: 0,
- IsAutoAmountLimit: "",
- WithdrawTimeInterval: "00:00-00:00",
- WithdrawFeeSet: withdrawFeeSetStr,
- PendingOrdersIsCanApply: 0,
- ConditionIsOpen: 0,
- FirstWithdrawSet: firstWithdrawSetStr,
- Tips: "",
- CreateAt: now.Format("2006-01-02 15:04:05"),
- }
- _, err2 := settingDb.FinWithdrawSettingInsert(&m)
- if err2 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err2.Error())
- return
- }
-
- setting, err = settingDb.FinWithdrawSettingGetOne()
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- }
- var frequency md2.WithdrawFrequencySettingStruct
- var withdrawFeeSet md2.WithdrawFeeSetStruct
- var firstWithdrawSet md2.FirstWithdrawSet
- utils.Unserialize([]byte(setting.FrequencySet), &frequency)
- utils.Unserialize([]byte(setting.WithdrawFeeSet), &withdrawFeeSet)
- utils.Unserialize([]byte(setting.FirstWithdrawSet), &firstWithdrawSet)
- withdrawTimeIntervals := strings.Split(setting.WithdrawTimeInterval, "-")
- withdrawTimeInterval := md2.WithdrawTimeIntervalStruct{
- StartAt: withdrawTimeIntervals[0],
- EndAt: withdrawTimeIntervals[1],
- }
- resp := md.GetWithdrawSettingResp{
- Id: setting.Id,
- FrequencySet: frequency,
- WithdrawType: setting.WithdrawType,
- VipLevelLimit: setting.VipLevelLimit,
- IsRealName: setting.IsRealName,
- WithdrawNumsLimit: setting.WithdrawNumsLimit,
- WithdrawAmountLimit: setting.WithdrawAmountLimit,
- WithdrawMultipleLimit: setting.WithdrawMultipleLimit,
- IsSupportDecimalPoint: setting.IsSupportDecimalPoint,
- IsAuto: setting.IsAuto,
- IsAutoAmountLimit: setting.IsAutoAmountLimit,
- WithdrawTimeInterval: withdrawTimeInterval,
- WithdrawFeeSet: withdrawFeeSet,
- FirstWithdrawSet: firstWithdrawSet,
- PendingOrdersIsCanApply: setting.PendingOrdersIsCanApply,
- ConditionIsOpen: setting.ConditionIsOpen,
- LevelList: levelsList,
- Tips: setting.Tips,
- }
-
- e.OutSuc(c, resp, nil)
- }
-
- // UpdateWithdrawSetting
- // @Summary 财务中心-提现-基础设置(更新)
- // @Tags 提现
- // @Description 基础设置(更新)
- // @Accept json
- // @Produce json
- // @param Authorization header string true "验证参数Bearer和token空格拼接"
- // @Param req body md.UpdateWithdrawSettingReq true "id 必填"
- // @Success 200 {int} "修改数据条数"
- // @Failure 400 {object} md.Response "具体错误"
- // @Router /api/financialCenter/withdraw/updateWithdrawSetting [POST]
- func UpdateWithdrawSetting(c *gin.Context) {
- var req *md.UpdateWithdrawSettingReq
- if err1 := c.ShouldBindJSON(&req); err1 != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err1.Error())
- return
- }
- if req.WithdrawTimeInterval.StartAt != "" {
- res := utils.IsTimeFormat(req.WithdrawTimeInterval.StartAt)
- if req.WithdrawTimeInterval.StartAt > "23:59" {
- res = false
- }
- if !res {
- e.OutErr(c, e.ERR_INVALID_ARGS, errors.New("开始时间应为 xx:xx 且不超过 23:59").Error())
- return
- }
- }
- if req.WithdrawTimeInterval.EndAt != "" {
- res := utils.IsTimeFormat(req.WithdrawTimeInterval.EndAt)
- if req.WithdrawTimeInterval.EndAt > "23:59" {
- res = false
- }
- if !res {
- e.OutErr(c, e.ERR_INVALID_ARGS, errors.New("结束时间应为 xx:xx 且不超过 23:59").Error())
- return
- }
- }
-
- frequencyStr := utils.SerializeStr(req.FrequencySet)
- withdrawFeeSetStr := utils.SerializeStr(req.WithdrawFeeSet)
- firstWithdrawSetStr := utils.SerializeStr(req.FirstWithdrawSet)
- var withdrawTimeInterval []string
- withdrawTimeInterval = append(withdrawTimeInterval, req.WithdrawTimeInterval.StartAt)
- withdrawTimeInterval = append(withdrawTimeInterval, req.WithdrawTimeInterval.EndAt)
- withdrawTimeIntervalStr := strings.Join(withdrawTimeInterval, "-")
- m := model.FinWithdrawSetting{
- Id: req.Id,
- FrequencySet: frequencyStr,
- WithdrawType: req.WithdrawType,
- VipLevelLimit: req.VipLevelLimit,
- IsRealName: req.IsRealName,
- WithdrawNumsLimit: req.WithdrawNumsLimit,
- WithdrawAmountLimit: req.WithdrawAmountLimit,
- WithdrawMultipleLimit: req.WithdrawMultipleLimit,
- IsSupportDecimalPoint: req.IsSupportDecimalPoint,
- IsAuto: req.IsAuto,
- IsAutoAmountLimit: req.IsAutoAmountLimit,
- WithdrawTimeInterval: withdrawTimeIntervalStr,
- WithdrawFeeSet: withdrawFeeSetStr,
- PendingOrdersIsCanApply: req.PendingOrdersIsCanApply,
- ConditionIsOpen: req.ConditionIsOpen,
- FirstWithdrawSet: firstWithdrawSetStr,
- Tips: req.Tips,
- }
-
- forceColumns := []string{"withdraw_type", "is_real_name", "withdraw_nums_limit",
- "withdraw_amount_limit", "withdraw_multiple_limit", "is_support_decimal_point",
- "is_auto", "first_withdraw_set", "is_auto_amount_limit", "pending_orders_is_can_apply",
- "condition_is_open",
- }
- settingDb := implement.NewFinWithdrawSettingDb(db.Db)
- affected, err := settingDb.FinWithdrawSettingUpdate(req.Id, &m, forceColumns...)
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- e.OutSuc(c, affected, nil)
- }
-
- // GetWithdrawApplyList
- // @Summary 财务中心-提现-提现申请列表(获取)
- // @Tags 提现
- // @Description 提现申请列表(获取)
- // @Accept json
- // @Produce json
- // @param Authorization header string true "验证参数Bearer和token空格拼接"
- // @Param req body md.GetWithdrawApplyListReq false "筛选条件"
- // @Success 200 {object} md.GetWithdrawApplyListResp "具体数据"
- // @Failure 400 {object} md.Response "具体错误"
- // @Router /api/financialCenter/withdraw/applyList [POST]
- func GetWithdrawApplyList(c *gin.Context) {
- var req *md.GetWithdrawApplyListReq
- if err1 := c.ShouldBindJSON(&req); err1 != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err1.Error())
- return
- }
-
- levelDb := implement.NewUserLevelDb(db.Db)
- levels, err1 := levelDb.UserLevelAllByAsc()
- if err1 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err1.Error())
- return
- }
- levelsList := make([]map[string]interface{}, 0)
- levelsMap := make(map[int]string)
- for _, level := range levels {
- levelsList = append(levelsList, map[string]interface{}{
- "id": level.Id,
- "name": level.LevelName,
- })
- levelsMap[level.Id] = level.LevelName
- }
-
- tagDb := implement.NewUserTagDb(db.Db)
- tags, err2 := tagDb.UserTagAllByAsc()
- if err2 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err2.Error())
- return
- }
- tagsList := make([]map[string]interface{}, 0)
- tagsMap := make(map[int]string)
- for _, tag := range tags {
- tagsList = append(tagsList, map[string]interface{}{
- "id": tag.Id,
- "name": tag.TagName,
- })
- tagsMap[tag.Id] = tag.TagName
- }
-
- applies, total, err3 := svc.WithDrawManagementGetApply(db.Db, req)
- if err3 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err3.Error())
- return
- }
-
- list := make([]md.GetWithdrawApplyListNode, len(*applies))
- parentIDs := make([]int64, len(*applies))
- UserIDs := make([]int64, len(*applies))
- for _, apply := range *applies {
- parentIDs = append(parentIDs, apply.ParentID)
- UserIDs = append(UserIDs, apply.Uid)
- }
-
- // 查询上级
- userDb := implement.NewUserDb(db.Db)
- parents, err := userDb.UserFindByParams(map[string]interface{}{
- "key": "id",
- "value": parentIDs,
- })
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- parentsMap := make(map[int64]model.User)
- for _, parent := range parents {
- parentsMap[parent.Id] = parent
- }
-
- // 查询标签
- recordsDb := implement.NewUserTagRecordsDb(db.Db)
- records, err := recordsDb.UserTagRecordsFindByParams(map[string]interface{}{
- "key": "uid",
- "value": UserIDs,
- })
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- recordsMap := make(map[int64][]md.TagNode)
- for _, record := range *records {
- temp := md.TagNode{
- TagID: record.TagId,
- TagName: "",
- }
- tagName, ok := tagsMap[record.TagId]
- temp.TagName = tagName
- v, ok := recordsMap[record.Uid]
- if ok {
- recordsMap[record.Uid] = append(v, temp)
- } else {
- recordsMap[record.Uid] = []md.TagNode{temp}
- }
- }
-
- amountDb := implement.NewUserVirtualAmountDb(db.Db)
- virtualList, _ := amountDb.UserVirtualAllWalletFindByParams(map[string]interface{}{
- "key": "uid",
- "value": UserIDs,
- })
- virtualMap := make(map[int64]model.UserVirtualAmount)
- virtualMap1 := make(map[int64]model.UserVirtualAmount)
- settingDb := implement.NewEggEnergyBasicSettingDb(db.Db)
- setting, _ := settingDb.EggEnergyBasicSettingGetOne()
-
- if virtualList != nil {
- for _, record := range *virtualList {
- if record.CoinId == setting.PersonEggEnergyCoinId {
- virtualMap[record.Uid] = record
- }
- if record.CoinId == setting.TeamEggEnergyCoinId {
- virtualMap1[record.Uid] = record
- }
- }
- }
- for i, apply := range *applies {
- list[i] = md.GetWithdrawApplyListNode{
- WithdrawApplyId: utils.Int64ToStr(apply.Id),
- UserID: apply.Uid,
- Nickname: apply.Nickname,
- ParentID: apply.ParentID,
- AliPayName: apply.AliPayName,
- WechatPayName: apply.WxPayName,
- AliPayAccount: apply.AliPayAccount,
- WechatPayAccount: apply.WxPayAccount,
- WithdrawType: apply.WithdrawKind,
- InviteCode: apply.InviteCode,
- Amount: apply.Amount,
- ActualReceipt: apply.RealAmount,
- SysFee: apply.Fee,
- State: apply.State,
- ApplyAt: apply.CreateAt,
- PayAt: apply.UpdateAt,
- Memo: apply.Memo,
- ErrorMsg: gjson.Get(apply.ErrorMsg, "sub_msg").String(),
- }
- virAmount, ok := virtualMap[apply.Uid]
- if ok {
- list[i].CoinAmount = virAmount.Amount
- }
- virAmount1, ok1 := virtualMap1[apply.Uid]
- if ok1 {
- list[i].WaitCoinAmount = virAmount1.Amount
- }
- if apply.CustomInviteCode != "" {
- list[i].InviteCode = apply.CustomInviteCode
- }
- if apply.Amount != "" && apply.Fee != "" {
- actualReceipt := utils.StrToFloat64(apply.Amount) - utils.StrToFloat64(apply.Fee)
- list[i].ActualReceipt = utils.Float64ToStr(actualReceipt)
- }
- if apply.ParentID != 0 {
- v, ok := parentsMap[apply.ParentID]
- if ok {
- list[i].ParentPhone = v.Phone
- }
- }
- tagList, ok := recordsMap[apply.Uid]
- if ok {
- list[i].Tag = tagList
- }
- }
-
- resp := md.GetWithdrawApplyListResp{
- AuditList: []map[string]interface{}{
- {
- "value": 1,
- "name": "同意",
- },
- {
- "value": 2,
- "name": "拒绝",
- },
- },
- ReasonList: []map[string]interface{}{
- {
- "value": enum.FinWithdrawApplyReasonForNotRule,
- "name": enum.FinWithdrawApplyReasonForNotRule.String(),
- },
- {
- "value": enum.FinWithdrawApplyReasonForAccountAbnormal,
- "name": enum.FinWithdrawApplyReasonForAccountAbnormal.String(),
- },
- {
- "value": enum.FinWithdrawApplyReasonForFundAbnormal,
- "name": enum.FinWithdrawApplyReasonForFundAbnormal.String(),
- },
- },
- LevelsList: levelsList,
- TagsList: tagsList,
- List: list,
- Paginate: md.Paginate{
- Limit: req.Limit,
- Page: req.Page,
- Total: total,
- },
- }
- e.OutSuc(c, resp, nil)
- }
-
- // GetWithdrawApplyTotal
- // @Summary 财务中心-提现-提现统计
- // @Tags 提现
- // @Description 提现统计(获取)
- // @Accept json
- // @Produce json
- // @param Authorization header string true "验证参数Bearer和token空格拼接"
- // @Param req body md.GetWithdrawApplyListReq false "筛选条件"
- // @Success 200 {object} md.GetWithdrawApplyListResp "具体数据"
- // @Failure 400 {object} md.Response "具体错误"
- // @Router /api/financialCenter/withdraw/total [POST]
- func GetWithdrawApplyTotal(c *gin.Context) {
- var req *md.GetWithdrawApplyListReq
- if err1 := c.ShouldBindJSON(&req); err1 != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err1.Error())
- return
- }
- applies, err3 := svc.WithDrawManagementGetApplyTotal(db.Db, req)
- if err3 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err3.Error())
- return
- }
- resp := md.GetWithdrawApplyListResp{
- PendingAmount: applies.PendingAmount,
- PayFailedAmount: applies.FailAmount,
- PaySucceedAmount: applies.Amount,
- }
- e.OutSuc(c, resp, nil)
- }
-
- // WithdrawApplyAudit
- // @Summary 财务中心-提现-审核
- // @Tags 提现
- // @Description 提现审核
- // @Accept json
- // @Produce json
- // @param Authorization header string true "验证参数Bearer和token空格拼接"
- // @Param req body md.WithdrawApplyAuditReq false "筛选条件"
- // @Success 200 {string} "success"
- // @Failure 400 {object} md.Response "具体错误"
- // @Router /api/financialCenter/withdraw/audit [POST]
- func WithdrawApplyAudit(c *gin.Context) {
- var req *md.WithdrawApplyAuditReq
- if err1 := c.ShouldBindJSON(&req); err1 != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err1.Error())
- return
- }
-
- //1、查找对应提现申请单
- finWithdrawApplyDb := implement.NewFinWithdrawApplyDb(db.Db)
- finWithdrawApply, err := finWithdrawApplyDb.FinWithdrawApplyGet(utils.StrToInt64(req.WithdrawApplyId))
- if err != nil {
- e.OutErr(c, e.ERR_DB_ORM, err.Error())
- return
- }
- if finWithdrawApply == nil {
- e.OutErr(c, e.ERR_NOT_FAN, "提现记录不存在")
- return
- }
-
- //2、判断审核状态
- if req.AuditState == 1 {
- //通过(推mq、修改提现单成功)
- finWithdrawApply.State = int(enum.FinWithdrawApplyStateForIng)
- updateAffected, err1 := finWithdrawApplyDb.UpdateFinWithdrawApply(finWithdrawApply, "state")
- if err1 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err1.Error())
- return
- }
- if updateAffected <= 0 {
- e.OutErr(c, e.ERR_DB_ORM, "更新提现单状态失败")
- return
- }
-
- ch, err1 := rabbit.Cfg.Pool.GetChannel()
- if err1 != nil {
- e.OutErr(c, e.ERR_INIT_RABBITMQ, err1.Error())
- return
- }
- defer ch.Release()
- var data md2.EggFinWithdrawApplyData
- err = copier.Copy(&data, &finWithdrawApply)
- if err != nil {
- e.OutErr(c, e.ERR, err.Error())
- return
- }
-
- ch.Publish(md2.EggAppExchange, data, md2.EggFinWithdrawApply)
- } else {
- //拒绝(退余额、修改提现单失败)
- session := db.Db.NewSession()
- defer session.Close()
- session.Begin()
-
- finWithdrawApply.State = int(enum.FinWithdrawApplyStateForBad)
- updateAffected, err1 := finWithdrawApplyDb.UpdateFinWithdrawApplyBySession(session, finWithdrawApply, "state")
- if err1 != nil {
- e.OutErr(c, e.ERR_DB_ORM, err1.Error())
- return
- }
- if updateAffected <= 0 {
- e.OutErr(c, e.ERR_DB_ORM, "更新提现单状态失败")
- return
- }
-
- dealUserWalletReq := md3.DealUserWalletReq{
- Direction: "add",
- Kind: int(enum.UserWithdrawBad),
- Title: enum.UserWithdrawBad.String(),
- Uid: finWithdrawApply.Uid,
- Amount: utils.StrToFloat64(finWithdrawApply.Amount),
- }
-
- egg_system_rules.Init(cfg.RedisAddr)
- err = rule.DealUserWallet(session, dealUserWalletReq)
- if err != nil {
- session.Rollback()
- e.OutErr(c, e.ERR, err.Error())
- return
- }
-
- err = session.Commit()
- if err != nil {
- _ = session.Rollback()
- e.OutErr(c, e.ERR_DB_ORM, err)
- return
- }
- }
-
- e.OutSuc(c, "success", nil)
- }
|