admin.go 9.9 KB

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