劲创营---任务项目
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 regels
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. "id": v["id"],
  114. }
  115. list = append(list, tmp)
  116. }
  117. res := map[string]interface{}{
  118. "list": list,
  119. }
  120. e.OutSuc(c, res, nil)
  121. return
  122. }
  123. func TaskQrcodeSubmit(c *gin.Context) {
  124. var args map[string]string
  125. if err := c.ShouldBindJSON(&args); err != nil {
  126. e.OutErr(c, e.ERR_INVALID_ARGS)
  127. return
  128. }
  129. var data models.CampTaskUserPromotionQrcode
  130. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  131. if data.Id == 0 {
  132. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  133. return
  134. }
  135. user, _ := db.UserFindByID(svc.MasterDb(c), data.Uid)
  136. if user == nil {
  137. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  138. return
  139. }
  140. topUid := TopUidBySubmit(c, data.Uid)
  141. if topUid != data.FormUid {
  142. e.OutErr(c, 400, e.NewErr(400, "二维码已失效"))
  143. return
  144. }
  145. cb, err := svc.HandleCampTaskLockDistributedLock(c.GetString("mid"), utils.IntToStr(data.TaskId), "camp_task")
  146. if err != nil {
  147. e.OutErr(c, e.ERR, e.NewErr(400000, "操作过快,请稍后再试"))
  148. return
  149. }
  150. // 处理完毕释放锁
  151. if cb != nil {
  152. defer cb()
  153. }
  154. sess := svc.MasterDb(c).NewSession()
  155. defer sess.Close()
  156. sess.Begin()
  157. var campTask models.CampTaskList
  158. sess.Where("id=?", data.TaskId).Get(&campTask)
  159. if campTask.UpDownState == 0 {
  160. sess.Rollback()
  161. e.OutErr(c, 400, e.NewErr(400, "任务已下架"))
  162. return
  163. }
  164. if campTask.Num-1 < 0 {
  165. sess.Rollback()
  166. e.OutErr(c, 400, e.NewErr(400, "任务数量不足"))
  167. return
  168. }
  169. campTask.Num--
  170. update, err := sess.Where("id=?", campTask.Id).Cols("num").Update(&campTask)
  171. if update == 0 || err != nil {
  172. sess.Rollback()
  173. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  174. return
  175. }
  176. var changeLog = models.CampTaskDeductList{
  177. TaskId: campTask.Id,
  178. Type: 1,
  179. Num: 1,
  180. AfterNum: campTask.Num,
  181. CreateTime: time.Now(),
  182. StoreId: campTask.StoreId,
  183. Title: "交单扣除",
  184. OrdType: "task_success",
  185. }
  186. update, err = sess.Insert(&changeLog)
  187. if update == 0 || err != nil {
  188. sess.Rollback()
  189. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  190. return
  191. }
  192. var order = models.CampTaskUserPromotionOrder{
  193. Uid: user.Uid,
  194. TaskId: campTask.Id,
  195. CreateTime: time.Now(),
  196. FormUid: data.FormUid,
  197. Name: data.Name,
  198. Phone: data.Phone,
  199. Province: data.Province,
  200. City: data.City,
  201. Code: data.Code,
  202. Remark: data.Remark,
  203. QrcodeId: data.Id,
  204. Oid: utils.StrToInt64(utils.OrderUUID(user.Uid)),
  205. Payment: campTask.Price,
  206. StoreId: campTask.StoreId,
  207. UserLv: user.Level,
  208. Img: args["img"],
  209. SettleType: campTask.SettleType,
  210. }
  211. update, err = sess.Insert(&order)
  212. if update == 0 || err != nil {
  213. sess.Rollback()
  214. e.OutErr(c, 400, e.NewErr(400, "任务提交失败"))
  215. return
  216. }
  217. sess.Commit()
  218. ch, _ := rabbit.Cfg.Pool.GetChannel()
  219. arg := md2.ZhiosCampOrderSettle{Id: utils.IntToStr(order.Id), Mid: c.GetString("mid")}
  220. err = ch.PublishV2(md2.ZhiosCampTask, utils.SerializeStr(arg), md2.ZhiosCampTaskOrderCommissionRoutKey)
  221. if err != nil {
  222. err = ch.PublishV2(md2.ZhiosCampTask, utils.SerializeStr(arg), md2.ZhiosCampTaskOrderCommissionRoutKey)
  223. }
  224. e.OutSuc(c, "success", nil)
  225. return
  226. }
  227. func TaskQrcodeContinueSubmit(c *gin.Context) {
  228. var args map[string]string
  229. if err := c.ShouldBindJSON(&args); err != nil {
  230. e.OutErr(c, e.ERR_INVALID_ARGS)
  231. return
  232. }
  233. var data models.CampTaskUserPromotionOrder
  234. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  235. if data.Id == 0 {
  236. e.OutErr(c, 400, e.NewErr(400, "订单不存在"))
  237. return
  238. }
  239. if data.State != 2 {
  240. e.OutErr(c, 400, e.NewErr(400, "订单已审核或审核中,不可操作"))
  241. return
  242. }
  243. data.Img = args["img"]
  244. data.State = 0
  245. svc.MasterDb(c).Where("id=?", data.Id).Cols("img,state").Update(&data)
  246. e.OutSuc(c, "success", nil)
  247. return
  248. }
  249. func TaskQrcodeDetail(c *gin.Context) {
  250. var args map[string]string
  251. if err := c.ShouldBindJSON(&args); err != nil {
  252. e.OutErr(c, e.ERR_INVALID_ARGS)
  253. return
  254. }
  255. var data models.CampTaskUserPromotionQrcode
  256. svc.MasterDb(c).Where("id=?", args["id"]).Get(&data)
  257. var task models.CampTaskList
  258. svc.MasterDb(c).Where("id=?", data.TaskId).Get(&task)
  259. res := map[string]string{
  260. "name": data.Name, "task_name": task.Name,
  261. "phone": data.Phone,
  262. "id": utils.IntToStr(data.Id),
  263. "address": data.Province + data.City,
  264. }
  265. e.OutSuc(c, res, nil)
  266. return
  267. }
  268. func TaskQrcodeList(c *gin.Context) {
  269. var args map[string]string
  270. if err := c.ShouldBindJSON(&args); err != nil {
  271. e.OutErr(c, e.ERR_INVALID_ARGS)
  272. return
  273. }
  274. user := svc.GetUser(c)
  275. var data []models.CampTaskUserPromotionQrcode
  276. size := 10
  277. p := utils.StrToInt(args["p"])
  278. sess := svc.MasterDb(c).Where("uid=?", user.Info.Uid)
  279. if args["task_id"] != "" {
  280. var taskQrcode models.CampTaskUserPromotionQrcode
  281. svc.MasterDb(c).Where("id=?", args["task_id"]).Get(&taskQrcode)
  282. args["task_id"] = utils.IntToStr(taskQrcode.TaskId)
  283. sess.And("task_id=?", args["task_id"])
  284. }
  285. sess.Limit(size, (p-1)*size).OrderBy("id desc").Find(&data)
  286. list := make([]map[string]string, 0)
  287. h5Domain := svc.GetWebSiteDomainInfo(c, "wap")
  288. for _, v := range data {
  289. var task models.CampTaskList
  290. svc.MasterDb(c).Where("id=?", v.TaskId).Get(&task)
  291. //TODO 要前端的链接
  292. QrCode := qrcode.GetPNGBase64(h5Domain + "/#/zy-landing-page/pages/push-hand-login/push-hand-login?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. }