activity_signin.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package models
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. type CygxActivitySignin struct {
  7. Id int `orm:"column(id);pk"`
  8. ActivityId int `description:"活动ID"`
  9. UserId int `description:"用户ID"`
  10. CreateTime time.Time `description:"创建时间"`
  11. Mobile string `description:"手机号"`
  12. Email string `description:"邮箱"`
  13. CompanyId int `description:"公司id"`
  14. CompanyName string `description:"公司名称"`
  15. BusinessCard string `description:"名片"`
  16. RealName string `description:"用户实际名称"`
  17. IsSignup int `description:"是否报名了"`
  18. CountryCode string `description:"手机国家区号"`
  19. OpenId string `description:"Openid"`
  20. }
  21. type CygxActivitySigninLog struct {
  22. Id int `orm:"column(id);pk"`
  23. ActivityId int `description:"活动ID"`
  24. UserId int `description:"用户ID"`
  25. CreateTime time.Time `description:"创建时间"`
  26. Mobile string `description:"手机号"`
  27. Email string `description:"邮箱"`
  28. CompanyId int `description:"公司id"`
  29. CompanyName string `description:"公司名称"`
  30. BusinessCard string `description:"名片"`
  31. RealName string `description:"用户实际名称"`
  32. IsSignup int `description:"是否报名了"`
  33. CountryCode string `description:"手机国家区号"`
  34. OpenId string `description:"Openid"`
  35. }
  36. type CygxActivitySigninResp struct {
  37. ActivityId int `description:"活动ID"`
  38. ActivityName string `description:"活动名称"`
  39. RealName string `description:"用户实际名称"`
  40. Mobile string `description:"手机号"`
  41. CompanyName string `description:"公司名称"`
  42. BusinessCard string `description:"名片"`
  43. IsNewUser bool `description:"是否属于新客户"`
  44. IsSignup bool `description:"是否报名了"`
  45. }
  46. type CygxActivitySigninDetailResp struct {
  47. Detail *CygxActivitySigninResp
  48. IsBindingMobile bool `description:"是否绑定手机号"`
  49. }
  50. // 获取数量
  51. func GetCygxActivitySigninCount(condition string, pars []interface{}) (count int, err error) {
  52. sqlCount := ` SELECT COUNT(1) AS count FROM cygx_activity_signin as art WHERE 1= 1 `
  53. if condition != "" {
  54. sqlCount += condition
  55. }
  56. o := orm.NewOrm()
  57. err = o.Raw(sqlCount, pars).QueryRow(&count)
  58. return
  59. }
  60. func GetCygxActivitySigninDetail(condition string, pars []interface{}) (item *CygxActivitySignin, err error) {
  61. sql := `SELECT * FROM cygx_activity_signin as art WHERE 1= 1 `
  62. if condition != "" {
  63. sql += condition
  64. }
  65. err = orm.NewOrm().Raw(sql, pars).QueryRow(&item)
  66. return
  67. }
  68. // 修改是否推送消息状态
  69. func UpdatedateCygxActivitySignin(item *CygxActivitySignin) (err error) {
  70. sql := ` UPDATE cygx_activity_signin SET create_time= NOW() WHERE user_id = ? AND activity_id = ? `
  71. o := orm.NewOrm()
  72. _, err = o.Raw(sql, item.UserId, item.ActivityId).Exec()
  73. return
  74. }
  75. // 添加
  76. func AddCygxActivitySignin(item *CygxActivitySignin) (err error) {
  77. o := orm.NewOrm()
  78. _, err = o.Insert(item)
  79. return
  80. }
  81. // 修改
  82. func UpdateCygxActivitySignin(item *CygxActivitySignin) (err error) {
  83. o := orm.NewOrm()
  84. updateParams := make(map[string]interface{})
  85. updateParams["Mobile"] = item.Mobile
  86. updateParams["Email"] = item.Email
  87. updateParams["CompanyId"] = item.CompanyId
  88. updateParams["CompanyName"] = item.CompanyName
  89. updateParams["BusinessCard"] = item.BusinessCard
  90. updateParams["RealName"] = item.RealName
  91. updateParams["CountryCode"] = item.CountryCode
  92. ptrStructOrTableName := "cygx_activity_signin"
  93. whereParam := map[string]interface{}{"id": item.Id}
  94. qs := o.QueryTable(ptrStructOrTableName)
  95. for expr, exprV := range whereParam {
  96. qs = qs.Filter(expr, exprV)
  97. }
  98. _, err = qs.Update(updateParams)
  99. return
  100. }
  101. // 添加日志
  102. func AddCygxActivitySigninLog(item *CygxActivitySigninLog) (err error) {
  103. o := orm.NewOrm()
  104. _, err = o.Insert(item)
  105. return
  106. }
  107. type CygxActivitySigninReq struct {
  108. ActivityId int `description:"活动id"`
  109. CountryCode string `description:"手机国家区号"`
  110. Mobile string `description:"手机号"`
  111. VCode string `description:"验证码"`
  112. CompanyName string `description:"公司名称"`
  113. BusinessCard string `description:"名片"`
  114. RealName string `description:"用户实际名称"`
  115. SigninType int `description:"签到方式,1:填写手机号/机构名称;2:上传名片"`
  116. }