劲创营---任务项目
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.
 
 
 

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