sms.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_robot/cache"
  6. "hongze/hongze_robot/models"
  7. "hongze/hongze_robot/services"
  8. "hongze/hongze_robot/utils"
  9. "strconv"
  10. "strings"
  11. "time"
  12. )
  13. //短信管理
  14. type SmsController struct {
  15. BaseCommonController
  16. }
  17. // @Title 短信转发接口
  18. // @Description 短信转发接口
  19. // @Param request body company.CompanyApplyApproveReq true "type json string"
  20. // @Success Ret=200 转发成功
  21. // @router /send [post]
  22. func (this *SmsController) SmsSend() {
  23. br := new(models.BaseResponse).Init()
  24. var err error
  25. defer func() {
  26. if err != nil {
  27. utils.FileLog.Info("send msg err: %s", err.Error())
  28. }
  29. this.Data["json"] = br
  30. this.ServeJSON()
  31. }()
  32. reqBody := this.Ctx.Input.RequestBody
  33. utils.FileLog.Info("%s", string(reqBody))
  34. req := make([]*models.SmsReq, 0)
  35. err = json.Unmarshal(reqBody, &req)
  36. if err != nil {
  37. br.Msg = "参数解析异常!"
  38. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  39. return
  40. }
  41. addList := make([]*models.SmsRecord, 0)
  42. for _, v := range req {
  43. v.Address=strings.Trim(v.Address," ")
  44. if v.Sign != utils.Sign {
  45. br.Msg = "签名错误"
  46. br.ErrMsg = "签名错误;get sign:" + v.Sign + ";check sign:" + utils.Sign
  47. return
  48. }
  49. count, err := models.GetSmsRecordCount(v.Address, v.Date)
  50. if err != nil && err.Error() != utils.ErrNoRow() {
  51. br.Msg = "失败,请联系技术"
  52. br.ErrMsg = "失败;Err:" + err.Error()
  53. return
  54. }
  55. fmt.Println("count:", count)
  56. item, err := cache.GetSmsConfigByCache("mobile")
  57. if err != nil {
  58. br.Msg = "失败,请联系技术"
  59. br.ErrMsg = "获取配置信息失败;Err:" + err.Error()
  60. return
  61. }
  62. if item.ConfigValue == "" {
  63. br.Msg = "失败,请联系技术"
  64. br.ErrMsg = "配置信息为空"
  65. return
  66. }
  67. fmt.Println(item.ConfigValue)
  68. fmt.Println(v.Address)
  69. fmt.Println(strings.Contains(item.ConfigValue, v.Address))
  70. //判断记录是否存在
  71. if count <= 0 && strings.Contains(item.ConfigValue, v.Address) {
  72. var tm time.Time
  73. if v.Date != "" {
  74. smsDateInt64, _ := strconv.ParseInt(v.Date, 10, 64)
  75. tm = time.Unix(smsDateInt64/1e3, 0)
  76. }
  77. record := new(models.SmsRecord)
  78. record.CreateTime = time.Now()
  79. record.ModifyTime = time.Now()
  80. record.IsSend = 0
  81. record.SmsDateTime = tm
  82. record.Mobile = v.Address
  83. record.SmsDate = v.Date
  84. record.Body = v.Body
  85. addList = append(addList, record)
  86. }
  87. }
  88. if len(addList) > 0 {
  89. _, err = models.AddSmsRecordMulti(addList)
  90. if err != nil {
  91. br.Msg = "失败,请联系技术"
  92. br.ErrMsg = "新增记录失败;Err:" + err.Error()
  93. return
  94. }
  95. time.Sleep(1 * time.Second)
  96. go services.SendSms()
  97. }
  98. br.Ret = 200
  99. br.Success = true
  100. br.Msg = "发送成功"
  101. }
  102. //func init() {
  103. // fmt.Println("start")
  104. // smsDate:=`1620290685894`
  105. // int64, err := strconv.ParseInt(smsDate, 10, 64)
  106. // fmt.Println(err)
  107. // tm:=time.Unix(int64/1e3,0)
  108. // fmt.Println(tm)
  109. // fmt.Println(tm.Format(utils.FormatDateTime))
  110. // fmt.Println("end")
  111. //}
  112. //func init() {
  113. // fmt.Println("start")
  114. // services.SendSms()
  115. // fmt.Println("end")
  116. // return
  117. //}