劲创营---任务项目
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

354 line
10 KiB

  1. package svc
  2. import (
  3. "applet/app/comm/db"
  4. "applet/app/comm/e"
  5. md2 "applet/app/comm/md"
  6. "applet/app/comm/svc"
  7. "applet/app/comm/utils"
  8. "applet/app/comm/utils/qrcode"
  9. "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit"
  10. "code.fnuoos.com/go_rely_warehouse/zyos_model.git/src/models"
  11. "fmt"
  12. "github.com/gin-gonic/gin"
  13. "strings"
  14. "time"
  15. )
  16. func TaskQrcodeOrderCate(c *gin.Context) {
  17. var args map[string]string
  18. if err := c.ShouldBindJSON(&args); err != nil {
  19. e.OutErr(c, e.ERR_INVALID_ARGS)
  20. return
  21. }
  22. user, _ := svc.GetDefaultUser(c, c.GetHeader("Authorization"))
  23. uid := 0
  24. if args["qrcode_id"] != "" {
  25. var data models.CampTaskUserPromotionQrcode
  26. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  27. uid = data.Uid
  28. } else if user != nil {
  29. uid = user.Info.Uid
  30. }
  31. where := "uid=" + utils.IntToStr(uid)
  32. if args["qrcode_id"] != "" {
  33. where += " and qrcode_id=" + args["qrcode_id"]
  34. }
  35. if args["task_id"] != "" {
  36. where += " and task_id=" + args["task_id"]
  37. }
  38. sql := `select count(*) as count,state,task_id from camp_task_user_promotion_order where %s group by state`
  39. sql = fmt.Sprintf(sql, where)
  40. nativeString, _ := db.QueryNativeString(svc.MasterDb(c), sql)
  41. list := []map[string]string{
  42. {"name": "审核中", "value": "0"},
  43. {"name": "审核通过", "value": "1"},
  44. {"name": "审核驳回", "value": "2"},
  45. }
  46. id := "0"
  47. for k, v := range list {
  48. for _, v1 := range nativeString {
  49. id = v1["task_id"]
  50. if v["value"] == v1["state"] {
  51. list[k]["name"] += "(" + v1["count"] + ")"
  52. }
  53. }
  54. }
  55. var task models.CampTaskList
  56. svc.MasterDb(c).Where("id=?", id).Get(&task)
  57. re := map[string]interface{}{
  58. "list": list,
  59. "task_name": task.Name,
  60. }
  61. e.OutSuc(c, re, nil)
  62. return
  63. }
  64. func TaskQrcodeOrder(c *gin.Context) {
  65. var args map[string]string
  66. if err := c.ShouldBindJSON(&args); err != nil {
  67. e.OutErr(c, e.ERR_INVALID_ARGS)
  68. return
  69. }
  70. user, _ := svc.GetDefaultUser(c, c.GetHeader("Authorization"))
  71. uid := 0
  72. if args["qrcode_id"] != "" {
  73. var data models.CampTaskUserPromotionQrcode
  74. svc.MasterDb(c).Where("id=?", args["qrcode_id"]).Get(&data)
  75. args["task_id"] = utils.IntToStr(data.TaskId)
  76. uid = data.Uid
  77. } else if user != nil {
  78. uid = user.Info.Uid
  79. }
  80. where := "uid=" + utils.IntToStr(uid)
  81. if args["qrcode_id"] != "" {
  82. where += " and qrcode_id=" + args["qrcode_id"]
  83. }
  84. if args["task_id"] != "" {
  85. where += " and task_id=" + args["task_id"]
  86. }
  87. if args["state"] != "" {
  88. where += " and state=" + args["state"]
  89. }
  90. sql := `select * from camp_task_user_promotion_order where %s order by id desc %s`
  91. sql = fmt.Sprintf(sql, where, "limit "+utils.IntToStr((utils.StrToInt(args["p"])-1)*10)+",10")
  92. nativeString, _ := db.QueryNativeString(svc.MasterDb(c), sql)
  93. list := make([]map[string]interface{}, 0)
  94. for _, v := range nativeString {
  95. var task models.CampTaskList
  96. svc.MasterDb(c).Where("id=?", v["task_id"]).Get(&task)
  97. dataList := []map[string]string{
  98. {"name": "提交时间:" + v["create_time"]},
  99. {"name": "姓名:" + v["name"]},
  100. {"name": "手机号:" + v["phone"]},
  101. {"name": "作业地区:" + v["province"] + v["city"]},
  102. }
  103. if v["state"] == "2" {
  104. dataList = append(dataList, map[string]string{"name": "驳回原因:" + v["store_reason"]})
  105. }
  106. img := strings.Split(v["img"], ",")
  107. tmp := map[string]interface{}{
  108. "task_name": task.Name,
  109. "data_list": dataList,
  110. "img": img,
  111. "state": v["state"],
  112. "oid": v["oid"],
  113. "qr_id": v["qrcode_id"],
  114. "id": v["id"],
  115. }
  116. list = append(list, tmp)
  117. }
  118. res := map[string]interface{}{
  119. "list": list,
  120. }
  121. e.OutSuc(c, res, nil)
  122. return
  123. }
  124. func TaskQrcodeSubmit(c *gin.Context) {
  125. var args map[string]string
  126. if err := c.ShouldBindJSON(&args); err != nil {
  127. e.OutErr(c, e.ERR_INVALID_ARGS)
  128. return
  129. }
  130. var data models.CampTaskUserPromotionQrcode
  131. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  132. if data.Id == 0 {
  133. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  134. return
  135. }
  136. user, _ := db.UserFindByID(svc.MasterDb(c), data.Uid)
  137. if user == nil {
  138. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  139. return
  140. }
  141. topUid := TopUidBySubmit(c, data.Uid)
  142. if topUid != data.FormUid {
  143. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  144. return
  145. }
  146. cb, err := svc.HandleCampTaskLockDistributedLock(c.GetString("mid"), utils.IntToStr(data.TaskId), "camp_task")
  147. if err != nil {
  148. e.OutErr(c, e.ERR, e.NewErr(400000, "操作过快,请稍后再试"))
  149. return
  150. }
  151. // 处理完毕释放锁
  152. if cb != nil {
  153. defer cb()
  154. }
  155. sess := svc.MasterDb(c).NewSession()
  156. defer sess.Close()
  157. sess.Begin()
  158. var campTask models.CampTaskList
  159. sess.Where("id=?", data.TaskId).Get(&campTask)
  160. if campTask.UpDownState == 0 {
  161. sess.Rollback()
  162. e.OutErr(c, 400, e.NewErr(400, "任务已下架"))
  163. return
  164. }
  165. if campTask.Num-1 < 0 {
  166. sess.Rollback()
  167. e.OutErr(c, 400, e.NewErr(400, "任务数量不足"))
  168. return
  169. }
  170. campTask.Num--
  171. update, err := sess.Where("id=?", campTask.Id).Cols("num").Update(&campTask)
  172. if update == 0 || err != nil {
  173. sess.Rollback()
  174. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  175. return
  176. }
  177. var changeLog = models.CampTaskDeductList{
  178. TaskId: campTask.Id,
  179. Type: 1,
  180. Num: 1,
  181. AfterNum: campTask.Num,
  182. CreateTime: time.Now(),
  183. StoreId: campTask.StoreId,
  184. Title: "交单扣除",
  185. OrdType: "task_success",
  186. }
  187. update, err = sess.Insert(&changeLog)
  188. if update == 0 || err != nil {
  189. sess.Rollback()
  190. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  191. return
  192. }
  193. var order = models.CampTaskUserPromotionOrder{
  194. Uid: user.Uid,
  195. TaskId: campTask.Id,
  196. CreateTime: time.Now(),
  197. FormUid: data.FormUid,
  198. Name: data.Name,
  199. Phone: data.Phone,
  200. Province: data.Province,
  201. City: data.City,
  202. Code: data.Code,
  203. Remark: data.Remark,
  204. QrcodeId: data.Id,
  205. Oid: utils.StrToInt64(utils.OrderUUID(user.Uid)),
  206. Payment: campTask.Price,
  207. StoreId: campTask.StoreId,
  208. UserLv: user.Level,
  209. Img: args["img"],
  210. SettleType: campTask.SettleType,
  211. }
  212. update, err = sess.Insert(&order)
  213. if update == 0 || err != nil {
  214. sess.Rollback()
  215. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  216. return
  217. }
  218. sess.Commit()
  219. ch, _ := rabbit.Cfg.Pool.GetChannel()
  220. arg := md2.ZhiosCampOrderSettle{Id: utils.IntToStr(order.Id), Mid: c.GetString("mid")}
  221. err = ch.PublishV2(md2.ZhiosCampTask, utils.SerializeStr(arg), md2.ZhiosCampTaskOrderCommissionRoutKey)
  222. if err != nil {
  223. err = ch.PublishV2(md2.ZhiosCampTask, utils.SerializeStr(arg), md2.ZhiosCampTaskOrderCommissionRoutKey)
  224. }
  225. e.OutSuc(c, "success", nil)
  226. return
  227. }
  228. func TaskQrcodeContinueSubmit(c *gin.Context) {
  229. var args map[string]string
  230. if err := c.ShouldBindJSON(&args); err != nil {
  231. e.OutErr(c, e.ERR_INVALID_ARGS)
  232. return
  233. }
  234. var data models.CampTaskUserPromotionOrder
  235. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  236. if data.Id == 0 {
  237. e.OutErr(c, 400, e.NewErr(400, "订单不存在"))
  238. return
  239. }
  240. if data.State != 2 {
  241. e.OutErr(c, 400, e.NewErr(400, "订单已审核或审核中,不可操作"))
  242. return
  243. }
  244. data.Img = args["img"]
  245. data.State = 0
  246. svc.MasterDb(c).Where("id=?", data.Id).Cols("img,state").Update(&data)
  247. e.OutSuc(c, "success", nil)
  248. return
  249. }
  250. func TaskQrcodeDetail(c *gin.Context) {
  251. var args map[string]string
  252. if err := c.ShouldBindJSON(&args); err != nil {
  253. e.OutErr(c, e.ERR_INVALID_ARGS)
  254. return
  255. }
  256. var data models.CampTaskUserPromotionQrcode
  257. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  258. var task models.CampTaskList
  259. svc.MasterDb(c).Where("id=?", data.TaskId).Get(&task)
  260. res := map[string]string{
  261. "name": data.Name, "task_name": task.Name,
  262. "phone": data.Phone,
  263. "id": utils.IntToStr(data.Id),
  264. "address": data.Province + data.City,
  265. }
  266. e.OutSuc(c, res, nil)
  267. return
  268. }
  269. func TaskQrcodeList(c *gin.Context) {
  270. var args map[string]string
  271. if err := c.ShouldBindJSON(&args); err != nil {
  272. e.OutErr(c, e.ERR_INVALID_ARGS)
  273. return
  274. }
  275. user := svc.GetUser(c)
  276. var data []models.CampTaskUserPromotionQrcode
  277. size := 10
  278. p := utils.StrToInt(args["p"])
  279. sess := svc.MasterDb(c).Where("uid=?", user.Info.Uid)
  280. if args["task_id"] != "" {
  281. var taskQrcode models.CampTaskUserPromotionQrcode
  282. svc.MasterDb(c).Where("id=?", args["task_id"]).Get(&taskQrcode)
  283. args["task_id"] = utils.IntToStr(taskQrcode.TaskId)
  284. sess.And("task_id=?", args["task_id"])
  285. }
  286. sess.Limit(size, (p-1)*size).OrderBy("id desc").Find(&data)
  287. list := make([]map[string]string, 0)
  288. h5Domain := svc.GetWebSiteDomainInfo(c, "wap")
  289. for _, v := range data {
  290. var task models.CampTaskList
  291. svc.MasterDb(c).Where("id=?", v.TaskId).Get(&task)
  292. QrCode := qrcode.GetPNGBase64(h5Domain + "/#/zy-base-widget-sub/pages/jcy-task-page/order-detail-page?qr_id=" + utils.IntToStr(v.Id))
  293. QrCode = strings.ReplaceAll(QrCode, "\u0000", "")
  294. tmp := map[string]string{
  295. "name": v.Name,
  296. "create_time": v.CreateTime.Format("2006-01-02 15:04:05"),
  297. "phone": v.Phone,
  298. "address": v.Province + v.City,
  299. "remark": v.Remark,
  300. "id": utils.IntToStr(v.Id),
  301. "qrcode": QrCode,
  302. "code": utils.IntToStr(v.Id),
  303. "task_name": task.Name,
  304. }
  305. list = append(list, tmp)
  306. }
  307. res := map[string]interface{}{
  308. "list": list,
  309. }
  310. e.OutSuc(c, res, nil)
  311. return
  312. }
  313. func TaskQrcodeApply(c *gin.Context) {
  314. var args map[string]string
  315. if err := c.ShouldBindJSON(&args); err != nil {
  316. e.OutErr(c, e.ERR_INVALID_ARGS)
  317. return
  318. }
  319. user := svc.GetUser(c)
  320. var CampTaskOperatorTask models.CampTaskOperatorTask
  321. svc.MasterDb(c).Where("id=?", args["id"]).Get(&CampTaskOperatorTask)
  322. if CampTaskOperatorTask.Id == 0 {
  323. e.OutErr(c, 400, e.NewErr(400, "任务不存在"))
  324. return
  325. }
  326. count, _ := svc.MasterDb(c).Where("uid=? and task_id=? and phone=?", user.Info.Uid, CampTaskOperatorTask.TaskId, args["phone"]).Count(&models.CampTaskUserPromotionQrcode{})
  327. if count > 0 {
  328. e.OutErr(c, 400, e.NewErr(400, "当前号码重复,请重新输入"))
  329. return
  330. }
  331. var data = models.CampTaskUserPromotionQrcode{
  332. Uid: user.Info.Uid,
  333. TaskId: CampTaskOperatorTask.TaskId,
  334. FormUid: CampTaskOperatorTask.Uid,
  335. CreateTime: time.Now(),
  336. Name: args["name"],
  337. Phone: args["phone"],
  338. Province: args["province"],
  339. City: args["city"],
  340. Remark: args["remark"],
  341. State: 1,
  342. }
  343. insert, _ := svc.MasterDb(c).Insert(&data)
  344. if insert == 0 {
  345. e.OutErr(c, 400, e.NewErr(400, "申请失败"))
  346. return
  347. }
  348. e.OutSuc(c, "success", nil)
  349. return
  350. }