admin.go 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. package services
  2. import (
  3. "errors"
  4. "hongze/hongze_mobile_admin/models/custom"
  5. "hongze/hongze_mobile_admin/models/tables/admin"
  6. "hongze/hongze_mobile_admin/models/tables/admin_record"
  7. "hongze/hongze_mobile_admin/models/tables/h5_admin_session"
  8. "hongze/hongze_mobile_admin/utils"
  9. "strconv"
  10. "time"
  11. )
  12. var ERR_NO_ADMIN_RECORD = errors.New("用户关系没有入库")
  13. var ERR_ADMIN_NOT_BIND = errors.New("用户没有绑定")
  14. //通过openid获取用户信息
  15. func GetAdminUserItemByOpenId(openid string) (item *custom.AdminWx, err error) {
  16. item = &custom.AdminWx{}
  17. //通过openid获取用户关联信息
  18. adminRecord, adminRecordErr := admin_record.GetAdminRecordByOpenId(openid)
  19. if adminRecordErr != nil {
  20. if adminRecordErr.Error() == utils.ErrNoRow() {
  21. err = ERR_NO_ADMIN_RECORD
  22. return
  23. } else {
  24. err = adminRecordErr
  25. return
  26. }
  27. }
  28. //该openid在系统中没有关联关系
  29. if adminRecord == nil {
  30. err = ERR_NO_ADMIN_RECORD
  31. return
  32. }
  33. //该openid没有绑定用户
  34. if adminRecord.UserId <= 0 {
  35. err = ERR_ADMIN_NOT_BIND
  36. //格式化返回用户数据
  37. formatWxUserAndUserRecord(item, adminRecord)
  38. return
  39. }
  40. //获取用户信息
  41. item, adminInfoErr := admin.GetAdminWxById(adminRecord.UserId)
  42. if adminInfoErr != nil {
  43. //用户被删除了,但是user_record没有删除对应的关系,那么去解除绑定
  44. userUnbindErr := admin_record.UnBindAdminRecordByOpenid(openid)
  45. if userUnbindErr != nil {
  46. err = userUnbindErr
  47. return
  48. }
  49. //返回状态为 用户未绑定 逻辑代码
  50. err = ERR_ADMIN_NOT_BIND
  51. adminRecord.UserId = 0
  52. //格式化返回用户数据
  53. formatWxUserAndUserRecord(item, adminRecord)
  54. return
  55. err = adminInfoErr
  56. //如果是下面这个错误,那么这个可能是用户信息被删除,然后user_record表没有移除该条记录所绑定的user_id信息
  57. if adminInfoErr.Error() == utils.ErrNoRow() {
  58. err = errors.New("用户信息不存在")
  59. }
  60. return
  61. }
  62. //格式化返回用户数据
  63. formatWxUserAndUserRecord(item, adminRecord)
  64. return
  65. }
  66. //根据管理员id和平台id获取用户信息
  67. func GetAdminUserItemByAdminId(adminId, platform int) (item *custom.AdminWx, err error) {
  68. item = &custom.AdminWx{}
  69. //获取用户信息
  70. item, adminErr := admin.GetAdminWxById(adminId)
  71. if adminErr != nil {
  72. err = adminErr
  73. return
  74. }
  75. //格式化返回用户数据
  76. formatWxUser(item, platform)
  77. return
  78. }
  79. //通过用户 关系表记录 和 用户记录 格式化返回 用户数据
  80. func formatWxUserAndUserRecord(adminWx *custom.AdminWx, adminRecord *admin_record.AdminRecord) {
  81. adminWx.OpenId = adminRecord.OpenId
  82. adminWx.UnionId = adminRecord.UnionId
  83. adminWx.NickName = adminRecord.NickName
  84. adminWx.BindAccount = adminRecord.BindAccount
  85. adminWx.Sex = adminRecord.Sex
  86. adminWx.Province = adminRecord.Province
  87. adminWx.City = adminRecord.City
  88. adminWx.Country = adminRecord.Country
  89. adminWx.Headimgurl = adminRecord.Headimgurl
  90. adminWx.AdminId = adminRecord.UserId
  91. //adminWx.Subscribe = adminRecord.Subscribe
  92. //wxUser.RealName = userRecord.RealName
  93. //wxUser.BindAccount = userRecord.BindAccount
  94. }
  95. //通过用户 用户记录 和 来源平台 格式化返回 用户数据
  96. func formatWxUser(adminWx *custom.AdminWx, platform int) {
  97. //根据用户id和平台id获取用户关系
  98. adminRecord, adminRecordErr := admin_record.GetAdminRecordByAdminId(adminWx.AdminId, platform)
  99. if adminRecordErr != nil {
  100. if adminRecordErr.Error() != utils.ErrNoRow() {
  101. return
  102. }
  103. if adminRecordErr.Error() == utils.ErrNoRow() {
  104. return
  105. }
  106. }
  107. //该openid在系统中没有关联关系
  108. if adminRecord == nil {
  109. return
  110. }
  111. formatWxUserAndUserRecord(adminWx, adminRecord)
  112. return
  113. }
  114. //用户绑定
  115. func BindWxUser(openid, userName, password string, registerPlatform int) (adminWx *custom.AdminWx, err error) {
  116. if userName == "" || password == "" {
  117. err = errors.New("账号密码必填")
  118. return
  119. }
  120. //根据账号密码获取管理员信息(校验账号密码是否正常)
  121. adminInfo, err := admin.CheckAdmin(userName, password)
  122. if err != nil {
  123. if err.Error() != utils.ErrNoRow() {
  124. err = errors.New("账号或密码错误")
  125. }
  126. return
  127. }
  128. if adminInfo.Enabled == 0 {
  129. err = errors.New("您的账号已被禁用,如需登录,请联系管理员")
  130. return
  131. }
  132. //获取用户信息
  133. adminWx, err = admin.GetAdminWxById(adminInfo.AdminId)
  134. if err != nil {
  135. return
  136. }
  137. //查询openid的第三方(微信)信息
  138. adminRecord, err := admin_record.GetAdminRecordByOpenId(openid)
  139. if err != nil {
  140. return
  141. }
  142. //如果查询出来的用户是nil,那么需要新增用户
  143. //如果存在该手机号/邮箱,那么需要校验
  144. if adminRecord.UserId > 0 && adminRecord.UserId != adminInfo.AdminId {
  145. err = errors.New("用户已绑定,不允许重复绑定")
  146. return
  147. }
  148. if adminRecord.UserId == 0 {
  149. err = admin_record.BindAdminRecordByOpenid(adminInfo.AdminId, openid)
  150. if err != nil {
  151. return
  152. }
  153. adminRecord.UserId = adminInfo.AdminId
  154. }
  155. //如果当前该第三方用户信息的昵称为空串的话,那么需要去查询该用户的第一个绑定信息的数据作为来源做数据修复
  156. //if adminRecord.NickName == "" {
  157. // oldUserRecord, err := admin_record.GetAdminThirdRecordByAdminId(adminInfo.AdminId)
  158. // if err == nil && oldUserRecord != nil {
  159. // //如果该用户绑定的第一条数据的头像信息不为空串,那么就去做新数据的修复
  160. // if oldUserRecord.NickName != "" {
  161. // _ = admin_record.ModifyAdminRecordInfo(adminRecord.OpenId, oldUserRecord.NickName, oldUserRecord.Headimgurl, oldUserRecord.City, oldUserRecord.Province, oldUserRecord.Country, oldUserRecord.Sex, adminInfo.AdminId)
  162. // }
  163. // }
  164. //}
  165. //格式化用户数据
  166. formatWxUserAndUserRecord(adminWx, adminRecord)
  167. return
  168. }
  169. //微信登录
  170. func WxLogin(wxPlatform int, wxAccessToken *WxAccessToken, wxUserInfo *WxUserInfo) (token string, adminWx *custom.AdminWx, err error) {
  171. openId := wxAccessToken.Openid
  172. unionId := wxAccessToken.Unionid
  173. if unionId == "" {
  174. unionId = wxUserInfo.Unionid
  175. }
  176. //firstLogin==1,强制绑定手机号或者邮箱
  177. QUERY_WX_USER:
  178. adminWx, adminWxErr := GetAdminUserItemByOpenId(openId)
  179. if adminWxErr == ERR_NO_ADMIN_RECORD { //没有用户openid记录
  180. _, recordErr := AddUserRecord(openId, unionId, wxUserInfo.Nickname, "", wxUserInfo.Province, wxUserInfo.City, wxUserInfo.Country, wxUserInfo.Headimgurl, "", wxPlatform, wxUserInfo.Sex, 0)
  181. //如果插入失败,那么直接将错误信息返回
  182. if recordErr != nil {
  183. err = recordErr
  184. return
  185. }
  186. //插入成功后,需要重新查询该用户,并进入下面的逻辑
  187. goto QUERY_WX_USER
  188. } else if adminWxErr == ERR_ADMIN_NOT_BIND {
  189. //没有用户信息
  190. //wxUser.FirstLogin = 1
  191. } else if adminWxErr != nil {
  192. err = adminWxErr
  193. return
  194. }
  195. adminId := adminWx.AdminId
  196. //获取登录token
  197. tokenItem, tokenErr := h5_admin_session.GetTokenByOpenId(openId)
  198. if tokenErr != nil && tokenErr.Error() != utils.ErrNoRow() {
  199. err = errors.New("登录失败,获取token失败:" + tokenErr.Error())
  200. return
  201. }
  202. if tokenItem == nil || (tokenErr != nil && tokenErr.Error() == utils.ErrNoRow()) {
  203. timeUnix := time.Now().Unix()
  204. timeUnixStr := strconv.FormatInt(timeUnix, 10)
  205. token = utils.MD5(openId) + utils.MD5(timeUnixStr)
  206. //新增session
  207. {
  208. session := &h5_admin_session.H5AdminSession{
  209. OpenId: openId,
  210. AdminId: adminWx.AdminId,
  211. CreatedTime: time.Now(),
  212. LastUpdatedTime: time.Now(),
  213. ExpireTime: time.Now().AddDate(0, 3, 0),
  214. AccessToken: token,
  215. }
  216. session.AccessToken = token
  217. sessionErr := h5_admin_session.AddSession(session)
  218. if err != nil {
  219. err = errors.New("登录失败,新增用户session信息失败:" + sessionErr.Error())
  220. return
  221. }
  222. }
  223. } else {
  224. token = tokenItem.AccessToken
  225. //如果联系人编号不为空,且联系人编号与session里面的联系人编号不一致的时候,需要做session变更
  226. if adminId > 0 && tokenItem.AdminId != adminId {
  227. _ = h5_admin_session.UpdateSession(tokenItem.SessionId, adminId, time.Now().AddDate(0, 1, 0))
  228. }
  229. }
  230. return
  231. }
  232. //添加第三方用户(微信)记录
  233. func AddUserRecord(openId, unionId, nickName, realName, province, city, country, headimgurl, sessionKey string, platform, sex, subscribe int) (adminRecord *admin_record.AdminRecord, err error) {
  234. find, err := admin_record.GetAdminRecordByOpenId(openId)
  235. if err != nil && err.Error() != utils.ErrNoRow() {
  236. return
  237. }
  238. if find != nil {
  239. adminRecord = find
  240. return
  241. }
  242. adminRecord = &admin_record.AdminRecord{
  243. OpenId: openId, //用户open_id
  244. UnionId: unionId, //用户union_id
  245. Subscribe: subscribe,
  246. NickName: nickName, //用户昵称,最大长度:32
  247. RealName: realName, //用户实际名称,最大长度:32
  248. Sex: sex, //普通用户性别,1为男性,2为女性
  249. Province: province, //普通用户个人资料填写的省份,最大长度:30
  250. City: city, //普通用户个人资料填写的城市,最大长度:30
  251. Country: country, //国家,如中国为CN,最大长度:30
  252. Headimgurl: headimgurl, //用户第三方(微信)头像,最大长度:512
  253. CreateTime: time.Now(), //创建时间,关系添加时间、用户授权时间
  254. CreatePlatform: platform, //注册平台,1:日度点评公众号,2:管理后台,3:pc端网站,4:查研观向小程序;默认:1
  255. SessionKey: sessionKey, //微信小程序会话密钥,最大长度:255
  256. }
  257. recordId, err := admin_record.AddAdminRecord(adminRecord)
  258. if err != nil {
  259. return
  260. }
  261. adminRecord.UserRecordId = int(recordId)
  262. return
  263. }