|
- package platform
-
- import (
- "applet/app/db"
- "applet/app/db/model"
- "applet/app/e"
- "applet/app/utils"
- "applet/app/utils/cache"
- "encoding/json"
- "fmt"
- "github.com/gin-gonic/gin"
- "time"
- )
-
- func WithdrawalIncome(c *gin.Context) {
- args, mid, err := commArg(c)
- if err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- fmt.Println(args)
- fmt.Println(mid)
- if args["type"] == "" {
- args["type"] = "playlet"
- }
- amountMap := masterAmount(mid, args["type"])
- monthAmountMap := masterMonthAmount(mid)
- isNeedBingAlipay := "1"
- if amountMap["alipay"] != "" {
- isNeedBingAlipay = "0"
- }
- var res = []map[string]string{
- {"name": "账户余额", "value": amountMap["amount"], "type": "amount", "tip": "", "alipay": amountMap["alipay"], "alipay_name": amountMap["alipay_name"], "is_need_bing_alipay": isNeedBingAlipay, "is_show_withdrawal": "1"},
- {"name": "上月预估收益", "value": monthAmountMap["last_month_amount"], "type": "last_month_amount", "tip": "", "is_need_bing_alipay": "0", "is_show_withdrawal": "0"},
- {"name": "上月预估结算收益", "value": amountMap["last_month_settle_amount"], "type": "last_month_settle_amount", "tip": "", "is_need_bing_alipay": "0", "is_show_withdrawal": "0"},
- {"name": "本月预估收益", "value": monthAmountMap["month_amount"], "type": "month_amount", "tip": "", "is_need_bing_alipay": "0", "is_show_withdrawal": "0"},
- {"name": "本月预估结算收益", "value": monthAmountMap["month_settle_amount"], "type": "month_settle_amount", "tip": "", "is_need_bing_alipay": "0", "is_show_withdrawal": "0"},
- }
- e.OutSuc(c, res, nil)
- return
- }
- func WithdrawalList(c *gin.Context) {
- args, mid, err := commArg(c)
- if err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- amountMap := masterAmount(mid, args["type"])
- masterWithdrawalFlowDb := db.MasterWithdrawalFlowDb{}
- masterWithdrawalFlowDb.Set()
- list, total := masterWithdrawalFlowDb.GetWithdrawalFlowListWithTotal(amountMap["id"], args)
- data := make([]map[string]string, 0)
- if list != nil {
- for _, v := range *list {
- var tmp = map[string]string{
- "id": utils.IntToStr(v.Id),
- "alipay": v.Alipay,
- "alipay_name": v.AlipayName,
- "amount": v.Amount,
- "real_amount": v.RealAmount,
- "fee": v.Fee,
- "time": v.Time.Format("2006-01-02 15:04:05"),
- "check_time": "",
- "status": v.Status,
- "remark": v.Remark,
- "reason": v.Reason,
- "img": v.Img,
- "is_need_upload_invoice": utils.IntToStr(v.HasInvoice),
- }
- if v.Img != "" {
- tmp["is_need_upload_invoice"] = "0"
- }
- if v.CheckTime.IsZero() == false {
- tmp["check_time"] = v.CheckTime.Format("2006-01-02 15:04:05")
- }
- data = append(data, tmp)
- }
- }
- statusList := []map[string]string{
- {"name": "提现审核", "value": "提现审核"},
- {"name": "提现成功", "value": "提现成功"},
- {"name": "提现失败", "value": "提现失败"},
- }
- var res = map[string]interface{}{
- "list": data, "total": total, "status_list": statusList,
- }
- e.OutSuc(c, res, nil)
- return
- }
- func WithdrawalDoing(c *gin.Context) {
- args, mid, err := commArg(c)
- if err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- if utils.StrToFloat64(args["amount"]) <= 0 {
- e.OutErr(c, 400, e.NewErr(400, "金额不正确"))
- return
- }
- amountMap := masterAmount(mid, args["type"])
- leaveAmount := utils.StrToFloat64(amountMap["amount"]) - utils.StrToFloat64(args["amount"])
- if leaveAmount < 0 {
- e.OutErr(c, 400, e.NewErr(400, "余额不足"))
- return
- }
- masterListCfgDb := db.MasterListCfgDb{}
- masterListCfgDb.Set()
- withdrawalBili := masterListCfgDb.MasterListCfgGetOneData("0", "withdrawal_bili")
- invoiceBili := masterListCfgDb.MasterListCfgGetOneData("0", "invoice_bili")
- withdrawalDay := masterListCfgDb.MasterListCfgGetOneData("0", "withdrawal_day")
- if time.Now().Day() != utils.StrToInt(withdrawalDay) && utils.StrToInt(withdrawalDay) > 0 {
- e.OutErr(c, 400, e.NewErr(400, "每月"+withdrawalDay+"号提现"))
- return
- }
- var fee float64 = 0
- if utils.StrToFloat64(withdrawalBili) > 0 {
- bili := utils.StrToFloat64(withdrawalBili) / 100
- var invoiceBiliMap = make([]string, 0)
- json.Unmarshal([]byte(invoiceBili), &invoiceBiliMap)
- if utils.InArr(args["invoice_bili"], invoiceBiliMap) == false && utils.StrToInt(args["has_invoice"]) == 1 {
- e.OutErr(c, 400, e.NewErr(400, "发票税率不正确"))
- return
- }
- //开了发票的话再扣掉对应的发票比例
- if utils.InArr(args["invoice_bili"], invoiceBiliMap) && utils.StrToInt(args["has_invoice"]) == 1 {
- bili -= utils.StrToFloat64(args["invoice_bili"]) / 100
- }
- fee = utils.StrToFloat64(args["amount"]) * bili
- }
- realAmount := utils.StrToFloat64(args["amount"]) - fee
- if amountMap["alipay"] == "" {
- e.OutErr(c, 400, e.NewErr(400, "未绑定支付宝"))
- return
- }
-
- mutexKey := fmt.Sprintf("withdrawal:%s", amountMap["id"])
- withdrawAvailable, err := cache.Do("SET", mutexKey, 1, "EX", 30, "NX")
- if err != nil {
- e.OutErr(c, e.ERR, err)
- return
- }
- if withdrawAvailable != "OK" {
- e.OutErr(c, e.ERR, e.NewErr(400000, "操作过于频繁,请稍后再试"))
- return
- }
- sess := db.ZhimengDb.NewSession()
- err = sess.Begin()
- if err != nil {
- sess.Rollback()
- e.OutErr(c, 400, e.NewErr(400000, "请重试"))
- return
- }
- defer sess.Close()
- //先扣钱
- amountData := db.GetMasterAmountByListIdWithSess(sess, amountMap["list_id"])
- if amountData == nil {
- sess.Rollback()
- e.OutErr(c, e.ERR, e.NewErr(400000, "提现失败"))
- return
- }
- oldAmount := amountData.Amount
- leaveAmount = utils.StrToFloat64(amountData.Amount) - utils.StrToFloat64(args["amount"])
- if leaveAmount < 0 {
- e.OutErr(c, 400, e.NewErr(400, "余额不足"))
- return
- }
- amountData.Amount = utils.Float64ToStr(leaveAmount)
- update := db.MasterAmountUpdateWithSess(sess, amountData.Id, amountData)
- if update == false {
- e.OutErr(c, e.ERR, e.NewErr(400000, "提现失败"))
- return
- }
- //再写入明细
- var tmpFlow = model.MasterAmountFlow{
- Uid: amountMap["id"],
- Time: time.Now(),
- BeforeAmount: oldAmount,
- Amount: args["amount"],
- AfterAmount: amountData.Amount,
- Platform: args["type"],
- Oid: "",
- Title: "提现",
- FlowType: "withdrawal",
- }
- flowInsert := db.MasterAmountFlowInsertWithSess(sess, &tmpFlow)
- if flowInsert == false {
- e.OutErr(c, e.ERR, e.NewErr(400000, "提现失败"))
- return
- }
- var tmp = model.MasterWithdrawalFlow{
- Uid: amountMap["id"],
- Time: time.Now(),
- UpdateTime: time.Now(),
- Remark: args["remark"],
- Alipay: amountMap["alipay"],
- AlipayName: amountMap["alipay_name"],
- Amount: args["amount"],
- RealAmount: utils.Float64ToStr(realAmount),
- Fee: utils.Float64ToStr(fee),
- Reason: "",
- Status: "提现审核",
- HasInvoice: utils.StrToInt(args["has_invoice"]),
- InvoiceBili: args["invoice_bili"],
- }
- insert := db.MasterWithdrawalFlowInsertWithSess(sess, &tmp)
- if insert == false {
- e.OutErr(c, e.ERR, e.NewErr(400000, "提现失败"))
- return
- }
- sess.Commit()
- e.OutSuc(c, "success", nil)
- return
- }
- func WithdrawalOutput(c *gin.Context) {
- args, mid, err := commArg(c)
- if err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- args["size"] = "3000"
- amountMap := masterAmount(mid, args["type"])
- masterWithdrawalFlowDb := db.MasterWithdrawalFlowDb{}
- masterWithdrawalFlowDb.Set()
- list := masterWithdrawalFlowDb.GetWithdrawalFlowList(amountMap["id"], args)
- name := "订单_" + args["p"]
- //写入数据
- data := map[string]string{
- "A1": "提现支付宝账号",
- "B1": "提现支付宝姓名",
- "C1": "提现金额",
- "D1": "实际金额",
- "E1": "手续费",
- "F1": "提现状态",
- "G1": "申请时间",
- "H1": "审核时间",
- "I1": "备注",
- "J1": "失败原因",
- }
- if list != nil {
- for k, v := range *list {
- checkTime := ""
- if v.CheckTime.IsZero() == false {
- checkTime = v.CheckTime.Format("2006-01-02 15:04:05")
- }
- i := utils.IntToStr(k + 2)
- data["A"+i] = v.Alipay
- data["B"+i] = v.AlipayName
- data["C"+i] = v.Amount
- data["D"+i] = v.RealAmount
- data["E"+i] = v.Fee
- data["F"+i] = v.Status
- data["G"+i] = v.Time.Format("2006-01-02 15:04:05")
- data["H"+i] = checkTime
- data["I"+i] = v.Remark
- data["J"+i] = v.Reason
- }
- }
- file := utils.Output(c, name, data)
- filename := name + ".xlsx"
- r := map[string]string{
- "file": file,
- "filename": filename,
- }
- e.OutSuc(c, r, nil)
- return
- }
- func WithdrawalInvoiceImg(c *gin.Context) {
- var args map[string]string
- if err := c.ShouldBindJSON(&args); err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- masterWithdrawalFlowDb := db.MasterWithdrawalFlowDb{}
- masterWithdrawalFlowDb.Set()
- flow := masterWithdrawalFlowDb.MasterWithdrawalFlowById(args["id"])
- flow.Img = args["img"]
- update := masterWithdrawalFlowDb.MasterWithdrawalFlowInsertUpdate(flow)
- if update == false {
- e.OutErr(c, 400, e.NewErr(400, "上传失败"))
- return
- }
- e.OutSuc(c, "success", nil)
- return
- }
-
- func WithdrawalBindAlipay(c *gin.Context) {
- var args map[string]string
- if err := c.ShouldBindJSON(&args); err != nil {
- e.OutErr(c, e.ERR_INVALID_ARGS, err)
- return
- }
- if args["alipay"] == "" || args["alipay_name"] == "" {
- e.OutErr(c, 400, e.NewErr(400, "支付宝信息不能为空"))
- return
- }
- masterId, _ := c.Get("master_id")
- mid := utils.AnyToString(masterId)
- masterDb := db.MasterDb{}
- masterDb.Set()
- master := masterDb.GetMaster(mid)
- master.AlipayName = args["alipay_name"]
- master.Alipay = args["alipay"]
- update := masterDb.MasterUpdate(master)
- if update == false {
- e.OutErr(c, 400, e.NewErr(400, "修改失败"))
- return
- }
- e.OutSuc(c, "success", nil)
- return
- }
-
- func commArg(c *gin.Context) (map[string]string, string, error) {
- masterId, _ := c.Get("master_id")
- mid := utils.AnyToString(masterId)
- fmt.Println(mid)
- var args map[string]string
- if err := c.ShouldBindJSON(&args); err != nil {
- return args, mid, err
- }
- return args, mid, nil
-
- }
-
- func masterInfo(mid string) map[string]string {
- masterDb := db.MasterDb{}
- masterDb.Set()
- master := masterDb.GetMaster(mid)
- res := make(map[string]string)
- if master != nil {
- res["id"] = utils.IntToStr(master.Id)
- res["alipay"] = master.Alipay
- res["alipay_name"] = master.AlipayName
- }
- return res
- }
- func masterAmount(mid, types string) map[string]string {
- masterInfos := masterInfo(mid)
- res := map[string]string{
- "amount": "0.00",
- "last_month_settle_amount": "0.00",
- }
- if masterInfos["id"] == "" {
- return res
- }
- masterAmountDb := db.MasterAmountDb{}
- masterAmountDb.Set()
- masterAmounts := masterAmountDb.GetMasterAmount(masterInfos["id"], types)
- if masterAmounts == nil {
- return res
- }
- res["amount"] = masterAmounts.Amount
- if res["amount"] == "" {
- res["amount"] = "0"
- }
- res["id"] = masterAmounts.Uid
- res["list_id"] = utils.IntToStr(masterAmounts.Id)
- res["alipay"] = masterInfos["alipay"]
- res["alipay_name"] = masterInfos["alipay_name"]
- res["last_month_settle_amount"] = masterAmounts.LastMonthAmount
- if res["last_month_settle_amount"] == "" {
- res["last_month_settle_amount"] = "0"
- }
- return res
- }
- func masterMonthAmount(mid string) map[string]string {
- playletSaleOrder := db.PlayletSaleOrderDb{}
- playletSaleOrder.Set()
- lastMonthSum := playletSaleOrder.PlayletVideoOrderSum(mid, "", "last_month")
- monthSum := playletSaleOrder.PlayletVideoOrderSum(mid, "", "current_month")
- monthSettleSum := playletSaleOrder.PlayletVideoOrderSum(mid, "订单结算", "current_month")
- res := map[string]string{
- "last_month_amount": utils.Float64ToStr(lastMonthSum),
- "month_amount": utils.Float64ToStr(monthSum),
- "month_settle_amount": utils.Float64ToStr(monthSettleSum),
- }
- return res
- }
|