merchant.card.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636
  1. package shanghu
  2. import (
  3. "context"
  4. "duoduo/apis/common"
  5. "duoduo/apis/pdd"
  6. "duoduo/apis/shanghu/models"
  7. "duoduo/conf"
  8. "duoduo/models/shanghu"
  9. "duoduo/tools"
  10. "duoduo/tools/app"
  11. "encoding/base64"
  12. "encoding/json"
  13. "errors"
  14. "fmt"
  15. "github.com/gin-gonic/gin"
  16. "github.com/qiniu/go-sdk/v7/auth/qbox"
  17. "github.com/qiniu/go-sdk/v7/storage"
  18. "github.com/shopspring/decimal"
  19. "strconv"
  20. "time"
  21. )
  22. func CreateMerchantCard(c *gin.Context) {
  23. var inData models.CreateMerchantCardRequest
  24. var sqlData shanghu.MerchantCard
  25. err := c.ShouldBindJSON(&inData)
  26. if err != nil {
  27. app.Error(c, 400, err, err.Error())
  28. return
  29. }
  30. sqlData.CreatedAt = time.Now()
  31. sqlData.UpdatedAt = time.Now()
  32. jsStr, err := json.Marshal(inData.CardProjectData)
  33. if err != nil {
  34. app.Error(c, 400, err, "包含项目不能为空")
  35. return
  36. }
  37. sqlData.CardProjectData = string(jsStr)
  38. sqlData.CardPrice = inData.CardPrice
  39. sqlData.CardTotalPrice = inData.CardTotalPrice
  40. sqlData.ActivityEndTime, err = tools.TimeToInt64(inData.ActivityEndTime, "2006-01-02")
  41. if err != nil {
  42. app.Error(c, 400, err, err.Error())
  43. return
  44. }
  45. sqlData.ActivityStartTime, err = tools.TimeToInt64(inData.ActivityStartTime, "2006-01-02")
  46. if err != nil {
  47. app.Error(c, 400, err, err.Error())
  48. return
  49. }
  50. sqlData.Inventory, err = strconv.ParseInt(inData.Inventory, 10, 64)
  51. if err != nil {
  52. app.Error(c, 400, err, err.Error())
  53. return
  54. }
  55. sqlData.MerchantCardTime, err = tools.TimeToInt64(inData.MerchantCardTime, "2006-01-02")
  56. if err != nil {
  57. app.Error(c, 400, err, err.Error())
  58. return
  59. }
  60. sqlData.MerchantOpenID = inData.MerchantOpenID
  61. sqlData.Picture = inData.Picture
  62. sqlData.QuotaNum, err = strconv.ParseInt(inData.QuotaNum, 10, 64)
  63. if err != nil {
  64. app.Error(c, 400, err, err.Error())
  65. return
  66. }
  67. sqlData.RebateRate, err = strconv.ParseInt(inData.RebateRate, 10, 64)
  68. if err != nil {
  69. app.Error(c, 400, err, err.Error())
  70. return
  71. }
  72. sqlData.UseRule = inData.UseRule
  73. sqlData.MerchantCardName = inData.MerchantCardName
  74. sqlData.CancelNumber, err = strconv.Atoi(inData.CancelNumber)
  75. if err != nil {
  76. app.Error(c, 400, err, err.Error())
  77. return
  78. }
  79. sqlData.BackgroundImage = inData.BackgroundImage
  80. _, err = sqlData.Create()
  81. if err != nil {
  82. app.Error(c, 500, err, err.Error())
  83. return
  84. }
  85. app.OK(c, nil, app.Success)
  86. }
  87. func GetMerchantCard(c *gin.Context) {
  88. var inData models.GetMerchantCardRequest
  89. var outData models.GetMerchantCardReply
  90. var sqlData shanghu.MerchantCard
  91. var project []int64
  92. err := c.ShouldBindJSON(&inData)
  93. if err != nil {
  94. app.Error(c, 400, err, err.Error())
  95. return
  96. }
  97. sqlData.ID = inData.MerchantId
  98. merchantCard, err := sqlData.GetMerchantCard()
  99. if err != nil {
  100. app.Error(c, 500, err, err.Error())
  101. return
  102. }
  103. err = json.Unmarshal([]byte(merchantCard.CardProjectData), &project)
  104. if err != nil {
  105. app.Error(c, 500, err, err.Error())
  106. return
  107. }
  108. merchantCard.CardProjectData = ""
  109. for i := 0; i < len(project); i++ {
  110. var cardProject shanghu.MerchantCardProject
  111. cardProject.ID = project[i]
  112. projectInfo, err := cardProject.GetMerchantCardProject()
  113. if err != nil {
  114. app.Error(c, 500, err, err.Error())
  115. return
  116. }
  117. merchantCard.CardProjectData = merchantCard.CardProjectData + projectInfo.ProjectName + "x1 "
  118. }
  119. outData.CardProjectData = merchantCard.CardProjectData
  120. outData.MerchantCardName = merchantCard.MerchantCardName
  121. outData.MerchantCardTime = time.Unix(merchantCard.MerchantCardTime, 0).Format("2006-01-02")
  122. outData.ActivityEndTime = time.Unix(merchantCard.ActivityEndTime, 0).Format("2006-01-02")
  123. outData.ActivityStartTime = time.Unix(merchantCard.ActivityStartTime, 0).Format("2006-01-02")
  124. outData.Picture = merchantCard.Picture
  125. outData.UseRule = merchantCard.UseRule
  126. outData.QuotaNum = merchantCard.QuotaNum
  127. outData.Inventory = merchantCard.Inventory
  128. outData.RebateRate = merchantCard.RebateRate
  129. outData.CardPrice = merchantCard.CardPrice
  130. outData.X = merchantCard.X
  131. outData.Y = merchantCard.Y
  132. outData.W = merchantCard.W
  133. outData.H = merchantCard.H
  134. outData.BackgroundImage = merchantCard.BackgroundImage
  135. outData.CardTotalPrice = merchantCard.CardTotalPrice
  136. app.OK(c, outData, app.Success)
  137. }
  138. func GetMerchantCanvasCard(c *gin.Context) {
  139. var inData models.GetMerchantCardRequest
  140. var outData models.GetMerchantCanvasCardReply
  141. var sqlData shanghu.MerchantCard
  142. var project []int64
  143. var qr models.QRRequest
  144. var getQR models.GetQRRequest
  145. confIni, err := conf.ConnIni()
  146. if err != nil {
  147. app.Error(c, 400, err, err.Error())
  148. return
  149. }
  150. err = c.ShouldBindJSON(&inData)
  151. if err != nil {
  152. app.Error(c, 400, err, err.Error())
  153. return
  154. }
  155. sqlData.ID = inData.MerchantId
  156. merchantCard, err := sqlData.GetMerchantCard()
  157. if err != nil {
  158. app.Error(c, 500, err, err.Error())
  159. return
  160. }
  161. outData.Static.Background = "/images/背景.jpg"
  162. var swiperList []models.SwiperList
  163. var rightButton models.RightButton
  164. var swiper models.SwiperList
  165. swiper.ID = 0
  166. swiper.URL = merchantCard.Picture
  167. swiperList = append(swiperList, swiper)
  168. //err = json.Unmarshal([]byte(merchantCard.Picture), &swiperList)
  169. //if err != nil {
  170. // fmt.Println("picture")
  171. // app.Error(c, 500, err, err.Error())
  172. // return
  173. //}
  174. outData.Inventory = merchantCard.Inventory
  175. outData.SwiperList = swiperList
  176. rightButton.ImageURL = "/images/资源 24.png"
  177. outData.RightButton = append(outData.RightButton, rightButton)
  178. rightButton.ImageURL = "/images/资源 25.png"
  179. outData.RightButton = append(outData.RightButton, rightButton)
  180. rightButton.ImageURL = "/images/资源 26.png"
  181. outData.RightButton = append(outData.RightButton, rightButton)
  182. rightButton.ImageURL = "/images/资源 28.png"
  183. outData.RightButton = append(outData.RightButton, rightButton)
  184. var dataList models.DataList
  185. err = json.Unmarshal([]byte(merchantCard.CardProjectData), &project)
  186. if err != nil {
  187. fmt.Println("picture2")
  188. app.Error(c, 500, err, err.Error())
  189. return
  190. }
  191. //merchantCard.CardProjectData = ""
  192. for i := 0; i < len(project); i++ {
  193. var cardProject shanghu.MerchantCardProject
  194. cardProject.ID = project[i]
  195. projectInfo, err := cardProject.GetMerchantCardProject()
  196. if err != nil {
  197. app.Error(c, 500, err, err.Error())
  198. return
  199. }
  200. dataList.Name = projectInfo.ProjectName
  201. dataList.Count = 1
  202. dataList.Price = projectInfo.ProjectUnitPrice
  203. dataList.Unit = projectInfo.ProjectUnit
  204. outData.DataList = append(outData.DataList, dataList)
  205. }
  206. var buy models.BuyKnowList
  207. buy.Icon = "/images/资源 46.png"
  208. buy.Title = "有效期"
  209. buy.Text = "至" + tools.TimeToStr(merchantCard.MerchantCardTime)
  210. outData.BuyKnowList = append(outData.BuyKnowList, buy)
  211. buy.Icon = "/images/资源 48.png"
  212. buy.Title = "限购数量"
  213. buy.Text = "每位用户限购1张"
  214. outData.BuyKnowList = append(outData.BuyKnowList, buy)
  215. buy.Icon = "/images/资源 49.png"
  216. buy.Title = "使用规则"
  217. buy.Text = merchantCard.UseRule
  218. outData.BuyKnowList = append(outData.BuyKnowList, buy)
  219. var shopData models.ShopData
  220. var merchant shanghu.Merchant
  221. merchant.OpenId = merchantCard.MerchantOpenID
  222. merchantInfo, err := merchant.GetMerchant()
  223. if err != nil {
  224. app.Error(c, 500, err, err.Error())
  225. return
  226. }
  227. shopData.Name = merchantInfo.MerchantName
  228. shopData.Address = merchantInfo.Address
  229. outData.ShopData = shopData
  230. outData.FenxiangShow = false
  231. outData.MerchantAmount, err = decimal.NewFromString(merchantCard.CardPrice)
  232. if err != nil {
  233. app.Error(c, 500, err, err.Error())
  234. return
  235. }
  236. outData.MerchantOriginalAmount, err = decimal.NewFromString(merchantCard.CardTotalPrice)
  237. if err != nil {
  238. app.Error(c, 500, err, err.Error())
  239. return
  240. }
  241. //outData.MerchantOriginalAmount = outData.MerchantAmount.Add(decimal.NewFromInt(50))
  242. var outQRData models.ClientCardQRReply
  243. val, err := pdd.DuoDuoGet("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx25357518f710b8ce&secret=83c7dca801a6c93fbfac3c91f57a4eb2")
  244. if err != nil {
  245. app.Error(c, 500, err, err.Error())
  246. return
  247. }
  248. err = tools.JsonUnmarshal(val, &outQRData)
  249. if err != nil {
  250. app.Error(c, 500, err, err.Error())
  251. return
  252. }
  253. if outQRData.AccessToken == "" {
  254. app.Error(c, 500, err, "token error")
  255. return
  256. }
  257. url := "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + outQRData.AccessToken
  258. //1.原始码 不需要购买直接分享 ==原生码直接分享
  259. //2.code 本人openid 需要购买才能分享
  260. //3.空的 官方邀请码
  261. //返回邀请码
  262. if inData.Code == "yuanshima" { //可以分享 code 等于自己的与yuanshima的都给平台
  263. outData.IsShare = true
  264. outData.InvitationCode = "yuanshima"
  265. } else { //查询购买记录,没有购买过不让分享
  266. var payTrans shanghu.ClientPayTrans
  267. var userInfo shanghu.MerchantClientUser
  268. payTrans.MerchantCardID = inData.MerchantId
  269. payTrans.ClientOpenID = inData.Code
  270. payInfo, _ := payTrans.GetPayTransByOpenid()
  271. if payInfo.ID <= 0 {
  272. outData.IsShare = false
  273. } else {
  274. outData.IsShare = true
  275. }
  276. userInfo.ClientOpenID = inData.Code
  277. userInfoReply, _ := userInfo.GetUserInfo()
  278. outData.InvitationCode = userInfoReply.Code
  279. }
  280. //点击购买的时候把code给进去把 原始码购买属于平台
  281. qr.CheckPath = true
  282. qr.Page = "pages/home/home"
  283. qr.EnvVersion = "release"
  284. qr.Scene = "id-" + strconv.FormatInt(inData.MerchantId, 10) + "-c-" + outData.InvitationCode
  285. fmt.Println(qr.Scene)
  286. data, err := json.Marshal(&qr)
  287. if err != nil {
  288. app.Error(c, 500, err, err.Error())
  289. return
  290. }
  291. reply, err := common.Post(data, url)
  292. if err != nil {
  293. app.Error(c, 500, err, err.Error())
  294. return
  295. }
  296. if getQR.Errcode != 0 {
  297. app.Error(c, 500, err, getQR.Errmsg)
  298. return
  299. }
  300. encoded := base64.StdEncoding.EncodeToString(reply)
  301. outData.Base64Img = encoded
  302. //上传二维码文件
  303. timeUnixNano := time.Now().UnixNano() //单位纳秒
  304. fileName := fmt.Sprintf("%d.jpg", timeUnixNano)
  305. //七牛云上传图片
  306. bucket := "imgxx"
  307. key := "shanghuka/" + "erweima/" + time.Now().Format(time.DateOnly) + "/" + fileName
  308. putPolicy := storage.PutPolicy{
  309. Scope: bucket,
  310. }
  311. mac := qbox.NewMac(confIni.MustValue("ly-qn", "access_key"), confIni.MustValue("ly-qn", "secret_key"))
  312. upToken := putPolicy.UploadToken(mac)
  313. cfg := storage.Config{}
  314. // 空间对应的机房
  315. cfg.Zone = &storage.ZoneHuanan
  316. // 是否使用https域名
  317. cfg.UseHTTPS = false
  318. // 上传是否使用CDN上传加速
  319. cfg.UseCdnDomains = false
  320. // 构建表单上传的对象
  321. baseUploader := storage.NewBase64Uploader(&cfg)
  322. ret := storage.PutRet{}
  323. //data, err := base64.RawStdEncoding.DecodeString(inData.Pictures[i])
  324. //if err != nil {
  325. // app.Error(c, 500, err, "上传图片失败")
  326. // return
  327. //}
  328. err = baseUploader.Put(context.Background(), &ret, upToken, key, []byte(encoded), nil)
  329. if err != nil {
  330. app.Error(c, 500, err, "上传图片失败")
  331. return
  332. }
  333. outData.QRUrl = "http://lingyang.shisanmiao.com/" + key
  334. //err = json.Unmarshal([]byte(merchantCard.CardProjectData), &project)
  335. //if err != nil {
  336. // app.Error(c, 500, err, err.Error())
  337. // return
  338. //}
  339. //
  340. //merchantCard.CardProjectData = ""
  341. //for i := 0; i < len(project); i++ {
  342. // var cardProject shanghu.MerchantCardProject
  343. // cardProject.ID = project[i]
  344. // projectInfo, err := cardProject.GetMerchantCardProject()
  345. // if err != nil {
  346. // app.Error(c, 500, err, err.Error())
  347. // return
  348. // }
  349. // merchantCard.CardProjectData = merchantCard.CardProjectData + projectInfo.ProjectName + "x1 "
  350. //}
  351. app.OK(c, outData, app.Success)
  352. }
  353. func MerchantCardList(c *gin.Context) {
  354. var inData models.MerchantCardListRequest
  355. var sqlData shanghu.MerchantCard
  356. var outData []models.MerchantCardListReply
  357. err := c.ShouldBindJSON(&inData)
  358. if err != nil {
  359. app.Error(c, 400, err, err.Error())
  360. return
  361. }
  362. var pageSize = 10
  363. var pageIndex = 1
  364. if inData.PageSize != 0 {
  365. pageSize = inData.PageSize
  366. }
  367. if inData.PageIndex != 0 {
  368. pageIndex = inData.PageIndex
  369. }
  370. sqlData.MerchantOpenID = inData.OpenId
  371. merchantCard, count, err := sqlData.GetOpenIdList(pageSize, pageIndex, inData.TypeList)
  372. if err != nil {
  373. app.Error(c, 500, err, err.Error())
  374. return
  375. }
  376. for _, v := range merchantCard {
  377. var merchant models.MerchantCardListReply
  378. var payNumber shanghu.ClientPayTrans
  379. merchant.ID = v.ID
  380. merchant.MerchantCardName = v.MerchantCardName
  381. merchant.ActivityEnd = tools.TimeToStr(v.ActivityEndTime)
  382. merchant.ActivityStart = tools.TimeToStr(v.ActivityStartTime)
  383. merchant.CardPrice = v.CardPrice
  384. payNumber.MerchantCardID = v.ID
  385. merchant.SaleCardNumber = payNumber.GetNumByCardID()
  386. outData = append(outData, merchant)
  387. }
  388. app.PageOK(c, outData, count, pageIndex, pageSize, app.Success)
  389. return
  390. //app.PageOK(c, merchantCard, count, pageIndex, pageSize, app.Success)
  391. }
  392. // c端获取卡信息
  393. func MerchantClientCardList(c *gin.Context) {
  394. var inData models.MerchantCardListRequest
  395. var sqlData shanghu.MerchantCard
  396. var outData []models.MerchantCardListReply
  397. err := c.ShouldBindJSON(&inData)
  398. if err != nil {
  399. app.Error(c, 400, err, err.Error())
  400. return
  401. }
  402. var pageSize = 10
  403. var pageIndex = 1
  404. if inData.PageSize != 0 {
  405. pageSize = inData.PageSize
  406. }
  407. if inData.PageIndex != 0 {
  408. pageIndex = inData.PageIndex
  409. }
  410. merchantCard, count, err := sqlData.ClientGetOpenIdList(pageSize, pageIndex, inData.TypeList)
  411. if err != nil {
  412. app.Error(c, 500, err, err.Error())
  413. return
  414. }
  415. for i := 0; i < len(merchantCard); i++ {
  416. var reply models.MerchantCardListReply
  417. reply.RebateRate = merchantCard[i].RebateRate
  418. reply.ID = merchantCard[i].ID
  419. reply.QuotaNum = merchantCard[i].QuotaNum
  420. reply.MerchantCardName = merchantCard[i].MerchantCardName
  421. reply.CardPrice = merchantCard[i].CardPrice
  422. priceDec, err := decimal.NewFromString(merchantCard[i].CardPrice)
  423. if err != nil {
  424. app.Error(c, 500, err, err.Error())
  425. return
  426. }
  427. reply.RebateAmount = priceDec.Mul(decimal.NewFromInt(merchantCard[i].RebateRate).Div(decimal.NewFromInt(100))).String()
  428. outData = append(outData, reply)
  429. }
  430. app.PageOK(c, outData, count, pageIndex, pageSize, app.Success)
  431. }
  432. func UpdateMerchantCard(c *gin.Context) {
  433. var inData models.UpdateMerchantCardRequest
  434. var sqlData shanghu.MerchantCard
  435. err := c.ShouldBindJSON(&inData)
  436. if err != nil {
  437. app.Error(c, 400, err, err.Error())
  438. return
  439. }
  440. sqlData.ID = inData.ID
  441. sqlData.QuotaNum = inData.QuotaNum
  442. sqlData.UseRule = inData.UseRule
  443. sqlData.Picture = inData.Picture
  444. sqlData.Inventory = inData.Inventory
  445. sqlData.ActivityStartTime = inData.ActivityStartTime
  446. sqlData.ActivityEndTime = inData.ActivityEndTime
  447. err = sqlData.UpdateMerchantCard()
  448. if err != nil {
  449. app.Error(c, 400, err, err.Error())
  450. return
  451. }
  452. app.OK(c, nil, app.Success)
  453. }
  454. func UpdateMerchantCardWXYZ(c *gin.Context) {
  455. var inData models.UpdateMerchantCardWHXYRequest
  456. var sqlData shanghu.MerchantCard
  457. var whxy []models.WHXYStr
  458. err := c.ShouldBindJSON(&inData)
  459. if err != nil {
  460. app.Error(c, 400, err, err.Error())
  461. return
  462. }
  463. //"json: cannot unmarshal number -0.33279827286174424 into Go struct field WHXYStr.rotate of type int"
  464. err = json.Unmarshal([]byte(inData.Whxy), &whxy)
  465. if err != nil {
  466. app.Error(c, 400, err, err.Error())
  467. return
  468. }
  469. for i := 0; i < len(whxy); i++ {
  470. if !whxy[i].Y.IsZero() {
  471. sqlData.W = whxy[i].W.String()
  472. sqlData.X = whxy[i].X.String()
  473. sqlData.Y = whxy[i].Y.String()
  474. sqlData.H = whxy[i].H.String()
  475. }
  476. }
  477. sqlData.ID = inData.MerchantCardId
  478. err = sqlData.UpdateMerchantWHXY()
  479. if err != nil {
  480. app.Error(c, 400, err, err.Error())
  481. return
  482. }
  483. app.OK(c, nil, app.Success)
  484. }
  485. // 核销次数
  486. func CancelNumber(c *gin.Context) {
  487. var inData models.CancelCardRequest
  488. var sqlData shanghu.MerchantCard
  489. var log shanghu.CancelLog
  490. var qrMessage models.QRData
  491. var clientPay shanghu.ClientPayTrans
  492. err := c.ShouldBindJSON(&inData)
  493. if err != nil {
  494. app.Error(c, 400, err, err.Error())
  495. return
  496. }
  497. err = json.Unmarshal([]byte(inData.QRMessage), &qrMessage)
  498. if err != nil {
  499. app.Error(c, 400, err, err.Error())
  500. return
  501. }
  502. clientPay.MerchantCardID = qrMessage.MerchantId
  503. clientPay.ClientOpenID = qrMessage.ClientOpenId
  504. clientInfo, err := clientPay.GetPayTransByOpenid()
  505. if err != nil {
  506. app.Error(c, 400, err, err.Error())
  507. return
  508. }
  509. if clientInfo.ID == 0 {
  510. app.Error(c, 200, errors.New("用户未购买此卡"), "用户未购买此卡")
  511. return
  512. }
  513. sqlData.ID = qrMessage.MerchantId
  514. merchantInfo, err := sqlData.GetMerchantCard()
  515. if err != nil {
  516. app.Error(c, 500, err, err.Error())
  517. return
  518. }
  519. log.MerchantID = qrMessage.MerchantId
  520. log.ClientOpenID = qrMessage.ClientOpenId
  521. if log.GetNumber() >= merchantInfo.CancelNumber {
  522. app.Error(c, 200, errors.New("卡已使用完,请重新购买"), "卡已使用完,请重新购买")
  523. return
  524. }
  525. if merchantInfo.MerchantOpenID != inData.MerchantOpenId {
  526. app.Error(c, 200, errors.New("核销商家与发卡商家不一致"), "核销商家与发卡商家不一致")
  527. return
  528. }
  529. log.MerchantID = qrMessage.MerchantId
  530. log.ClientOpenID = qrMessage.ClientOpenId
  531. log.MerchantOpenID = inData.MerchantOpenId
  532. log.CreatedAt = time.Now()
  533. log.UpdatedAt = time.Now()
  534. _, err = log.Create()
  535. if err != nil {
  536. app.Error(c, 500, err, err.Error())
  537. return
  538. }
  539. app.OK(c, nil, "核销成功")
  540. }