user.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555
  1. package services
  2. import (
  3. "errors"
  4. "hongze/hongze_clpt/models"
  5. "hongze/hongze_clpt/utils"
  6. "strings"
  7. "time"
  8. )
  9. var ERR_NO_USER_RECORD = errors.New("用户关系没有入库")
  10. var ERR_USER_NOT_BIND = errors.New("用户没有绑定")
  11. // 通过用户 关系表记录 和 用户记录 格式化返回 用户数据
  12. func formatWxUserAndUserRecord(wxUser *models.WxUserItem, userRecord *models.UserRecord) {
  13. wxUser.OpenId = userRecord.OpenId
  14. wxUser.UnionId = userRecord.UnionId
  15. wxUser.NickName = userRecord.NickName
  16. //wxUser.RealName = userRecord.RealName
  17. //wxUser.BindAccount = userRecord.BindAccount
  18. wxUser.Headimgurl = userRecord.Headimgurl
  19. wxUser.SessionKey = userRecord.SessionKey
  20. }
  21. func GetWxUserItemByOpenId(unionId string) (item *models.WxUserItem, err error) {
  22. //通过openid获取用户关联信息
  23. item = new(models.WxUserItem)
  24. item.UnionId = unionId // 先写入 unionId
  25. userRecord, userRecordErr := models.GetUserRecordByUnionId(unionId)
  26. if userRecordErr != nil && userRecordErr.Error() != utils.ErrNoRow() {
  27. err = userRecordErr
  28. return
  29. }
  30. //如果 userRecord 表中的手机号不为空,那么就通过手机号来获取详情
  31. if userRecord != nil {
  32. if userRecord.BindAccount != "" {
  33. user, userErr := models.GetWxUserItemByUserMobile(userRecord.BindAccount)
  34. if userErr != nil && userErr.Error() != utils.ErrNoRow() {
  35. err = userErr
  36. return
  37. }
  38. if user != nil {
  39. item = user
  40. }
  41. }
  42. }
  43. return
  44. }
  45. // 获取 用户类型 //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户;6、冻结客户;7、流失客户
  46. func GetUserType(companyId int) (userType int, permissionStrnew string, err error) {
  47. var permissionStr, permissionZhengShiStr string
  48. if companyId <= 1 {
  49. userType = 0
  50. } else {
  51. total, errs := models.GetCountCompanyDetailByIdGroup(companyId)
  52. if errs != nil {
  53. err = errs
  54. return
  55. }
  56. if total == 0 {
  57. userType = 0
  58. } else {
  59. companyDetail, errs := models.GetCompanyDetailByIdGroup(companyId)
  60. if errs != nil {
  61. err = errs
  62. return
  63. }
  64. permissionStr, errs = models.GetCompanyPermission(companyId)
  65. if errs != nil {
  66. err = errs
  67. return
  68. }
  69. permissionStrnew = permissionStr
  70. //大套餐客户,数据库添加标识,
  71. companyUserTypeDetail, errs := models.GetCygxCompanyUserType(companyId)
  72. if errs != nil && errs.Error() != utils.ErrNoRow() {
  73. err = errs
  74. return
  75. }
  76. if companyUserTypeDetail != nil {
  77. if companyUserTypeDetail.CustomerTypeId != 0 {
  78. userType = companyUserTypeDetail.CustomerTypeId
  79. return
  80. }
  81. }
  82. permissionZhengShiStr, errs = models.GetCompanyPermissionByUserZhengShi(companyId)
  83. if errs != nil {
  84. err = errs
  85. return
  86. }
  87. //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户、 10: 30W套餐客户
  88. //大套餐客户定义:医药、消费、科技、智造、策略。5个行业中任意4个及以上是正式权限的,属于大套餐客户(医药、消费、科技、智造需要主客观都开)
  89. if companyDetail.Status == "永续" {
  90. userType = 1
  91. } else if companyDetail.Status == "试用" {
  92. userType = 5
  93. } else if companyDetail.Status == "冻结" {
  94. userType = 6
  95. } else if companyDetail.Status == "流失" {
  96. userType = 7
  97. }
  98. //大套餐客户定义:医药、消费、科技、智造、策略。5个行业中任意4个及以上是正式权限的,属于大套餐客户(医药、消费、科技、智造需要主客观都开)
  99. if userType == 0 && companyDetail.Status == "正式" {
  100. var permissionZhegnshiNum int
  101. if strings.Count(permissionZhengShiStr, "医药") == 2 {
  102. permissionZhegnshiNum++
  103. }
  104. if strings.Count(permissionZhengShiStr, "消费") == 2 {
  105. permissionZhegnshiNum++
  106. }
  107. if strings.Count(permissionZhengShiStr, "科技") == 2 {
  108. permissionZhegnshiNum++
  109. }
  110. if strings.Count(permissionZhengShiStr, "智造") == 2 {
  111. permissionZhegnshiNum++
  112. }
  113. if strings.Count(permissionZhengShiStr, "策略") == 1 {
  114. permissionZhegnshiNum++
  115. }
  116. if strings.Count(permissionZhengShiStr, "路演服务") == 1 {
  117. permissionZhegnshiNum++
  118. }
  119. //if permissionZhegnshiNum == 6 {
  120. // userType = 2
  121. //} else
  122. //大套餐客户,数据库添加标识,条件大于等于四的都是 30W套餐客户
  123. if permissionZhegnshiNum >= 4 {
  124. userType = 10
  125. } else {
  126. userType = 3
  127. }
  128. }
  129. }
  130. }
  131. permissionStrnew = permissionStr
  132. return
  133. }
  134. func GetUserTypeZhengShi(companyId int) (userType int, permissionStrnew, permissionStrZhengShinew string, err error) {
  135. var permissionStr, permissionZhengShiStr string
  136. if companyId <= 1 {
  137. userType = 0
  138. } else {
  139. total, errs := models.GetCountCompanyDetailByIdGroup(companyId)
  140. if errs != nil {
  141. err = errs
  142. return
  143. }
  144. if total == 0 {
  145. userType = 0
  146. } else {
  147. companyDetail, errs := models.GetCompanyDetailByIdGroup(companyId)
  148. if errs != nil {
  149. err = errs
  150. return
  151. }
  152. permissionStr, errs = models.GetCompanyPermission(companyId)
  153. if errs != nil {
  154. err = errs
  155. return
  156. }
  157. permissionStrnew = permissionStr
  158. //大套餐客户,数据库添加标识,
  159. companyUserTypeDetail, errs := models.GetCygxCompanyUserType(companyId)
  160. if errs != nil && errs.Error() != utils.ErrNoRow() {
  161. err = errs
  162. return
  163. }
  164. if companyUserTypeDetail != nil {
  165. if companyUserTypeDetail.CustomerTypeId != 0 {
  166. userType = companyUserTypeDetail.CustomerTypeId
  167. return
  168. }
  169. }
  170. permissionZhengShiStr, errs = models.GetCompanyPermissionByUserZhengShi(companyId)
  171. if errs != nil {
  172. err = errs
  173. return
  174. }
  175. //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户、 10: 30W套餐客户
  176. //大套餐客户定义:医药、消费、科技、智造、策略。5个行业中任意4个及以上是正式权限的,属于大套餐客户(医药、消费、科技、智造需要主客观都开)
  177. if companyDetail.Status == "永续" {
  178. userType = 1
  179. } else if companyDetail.Status == "试用" {
  180. userType = 5
  181. } else if companyDetail.Status == "冻结" {
  182. userType = 6
  183. } else if companyDetail.Status == "流失" {
  184. userType = 7
  185. }
  186. //大套餐客户定义:医药、消费、科技、智造、策略。5个行业中任意4个及以上是正式权限的,属于大套餐客户(医药、消费、科技、智造需要主客观都开)
  187. if userType == 0 && companyDetail.Status == "正式" {
  188. var permissionZhegnshiNum int
  189. if strings.Count(permissionZhengShiStr, "医药") == 2 {
  190. permissionZhegnshiNum++
  191. }
  192. if strings.Count(permissionZhengShiStr, "消费") == 2 {
  193. permissionZhegnshiNum++
  194. }
  195. if strings.Count(permissionZhengShiStr, "科技") == 2 {
  196. permissionZhegnshiNum++
  197. }
  198. if strings.Count(permissionZhengShiStr, "智造") == 2 {
  199. permissionZhegnshiNum++
  200. }
  201. if strings.Count(permissionZhengShiStr, "策略") == 1 {
  202. permissionZhegnshiNum++
  203. }
  204. if strings.Count(permissionZhengShiStr, "路演服务") == 1 {
  205. permissionZhegnshiNum++
  206. }
  207. //if permissionZhegnshiNum == 6 {
  208. // userType = 2
  209. //} else
  210. //大套餐客户,数据库添加标识,条件大于等于四的都是 30W套餐客户
  211. if permissionZhegnshiNum >= 4 {
  212. userType = 10
  213. } else {
  214. userType = 3
  215. }
  216. }
  217. }
  218. }
  219. permissionStrnew = permissionStr
  220. permissionStrZhengShinew = permissionZhengShiStr
  221. return
  222. }
  223. // 用户绑定
  224. func BindWxUser(mobile, countryCode string) (wxUser *models.WxUserItem, err error) {
  225. if mobile == "" {
  226. err = errors.New("手机号或邮箱必填一个")
  227. return
  228. }
  229. //根据手机号获取用户信息
  230. if mobile != "" {
  231. tmpWxUser, wxUserErr := models.GetWxUserItemByMobile(mobile)
  232. if wxUserErr != nil && wxUserErr.Error() != utils.ErrNoRow() {
  233. err = wxUserErr
  234. return
  235. }
  236. wxUser = tmpWxUser
  237. }
  238. var userId int
  239. //如果查询出来的用户是nil,那么需要新增用户
  240. if wxUser == nil {
  241. user := &models.WxUser{
  242. CompanyId: 1,
  243. CreatedTime: time.Now(),
  244. FirstLogin: 1,
  245. Enabled: 1,
  246. RegisterPlatform: 7,
  247. RegisterTime: time.Now(),
  248. Mobile: mobile,
  249. //Email: email,
  250. IsRegister: 1,
  251. Source: 3,
  252. CountryCode: countryCode,
  253. OutboundMobile: mobile,
  254. OutboundCountryCode: countryCode,
  255. }
  256. tmpUserId, addUserErr := models.AddWxUser(user)
  257. if addUserErr != nil {
  258. err = addUserErr
  259. return
  260. }
  261. user.UserId = int(tmpUserId)
  262. userId = int(tmpUserId)
  263. wxUser, err = models.GetWxUserItemByUserId(userId)
  264. } else {
  265. userId = wxUser.UserId
  266. err = models.BindUserOutboundMobile(mobile, countryCode, userId)
  267. if err != nil {
  268. return
  269. }
  270. if wxUser.IsRegister == 0 {
  271. models.ModifyWxUserRegisterStatus(userId)
  272. }
  273. }
  274. return
  275. }
  276. // 用户绑定用户手机号以及openid
  277. func BindWxUserMobileAndOpenid(mobile, openid, countryCode string) (wxUser *models.WxUserItem, err error) {
  278. if mobile == "" {
  279. err = errors.New("手机号或邮箱必填一个")
  280. return
  281. }
  282. var bindAccount string
  283. //根据手机号获取用户信息
  284. if mobile != "" {
  285. tmpWxUser, wxUserErr := models.GetWxUserItemByMobile(mobile)
  286. if wxUserErr != nil && wxUserErr.Error() != utils.ErrNoRow() {
  287. err = wxUserErr
  288. return
  289. }
  290. wxUser = tmpWxUser
  291. bindAccount = mobile
  292. }
  293. //查询openid的第三方(微信)信息
  294. userRecord, err := models.GetUserRecordByOpenId(openid)
  295. if err != nil {
  296. return
  297. }
  298. var userId int
  299. //如果查询出来的用户是nil,那么需要新增用户
  300. if wxUser == nil {
  301. user := &models.WxUser{
  302. CompanyId: 1,
  303. CreatedTime: time.Now(),
  304. FirstLogin: 1,
  305. Enabled: 1,
  306. RegisterPlatform: 7,
  307. RegisterTime: time.Now(),
  308. Mobile: mobile,
  309. //Email: email,
  310. IsRegister: 1,
  311. Source: 3,
  312. CountryCode: countryCode,
  313. OutboundMobile: mobile,
  314. OutboundCountryCode: countryCode,
  315. }
  316. tmpUserId, addUserErr := models.AddWxUser(user)
  317. if addUserErr != nil {
  318. err = addUserErr
  319. return
  320. }
  321. user.UserId = int(tmpUserId)
  322. userId = int(tmpUserId)
  323. wxUser, err = models.GetWxUserItemByUserId(userId)
  324. } else {
  325. userId = wxUser.UserId
  326. err = models.BindUserOutboundMobile(mobile, countryCode, userId)
  327. if err != nil {
  328. return
  329. }
  330. if wxUser.IsRegister == 0 {
  331. models.ModifyWxUserRegisterStatus(userId)
  332. }
  333. }
  334. //如果存在该手机号/邮箱,那么需要校验
  335. if userRecord.UserId > 0 && userRecord.UserId != userId {
  336. err = errors.New("用户已绑定,不允许重复绑定")
  337. return
  338. }
  339. err = models.BindUserRecordByOpenid(userId, openid, bindAccount)
  340. if err != nil {
  341. return
  342. }
  343. userRecord.UserId = userId
  344. //如果当前该第三方用户信息的昵称为空串的话,那么需要去查询该用户的第一个绑定信息的数据作为来源做数据修复
  345. if userRecord.NickName == "" {
  346. oldUserRecord, err := models.GetUserThirdRecordByUserId(userId)
  347. if err == nil && oldUserRecord != nil {
  348. //如果该用户绑定的第一条数据的头像信息不为空串,那么就去做新数据的修复
  349. if oldUserRecord.NickName != "" {
  350. _ = models.ModifyUserRecordByDetail(userRecord.OpenId, userRecord.UnionId, oldUserRecord.NickName, oldUserRecord.Headimgurl, oldUserRecord.City, oldUserRecord.Province, oldUserRecord.Country, oldUserRecord.Sex, userId)
  351. }
  352. }
  353. }
  354. //格式化用户数据
  355. formatWxUserAndUserRecord(wxUser, userRecord)
  356. return
  357. }
  358. // 添加第三方用户(微信)记录
  359. func AddUserRecord(openId, unionId, nickName, realName, province, city, country, headimgurl, sessionKey string, platform, sex, subscribe int) (userRecord *models.UserRecord, err error) {
  360. find, err := models.GetUserRecordByOpenId(openId)
  361. if err != nil && err.Error() != utils.ErrNoRow() {
  362. return
  363. }
  364. if find != nil {
  365. userRecord = find
  366. return
  367. }
  368. userRecord = &models.UserRecord{
  369. OpenId: openId, //用户open_id
  370. UnionId: unionId, //用户union_id
  371. Subscribe: subscribe,
  372. NickName: nickName, //用户昵称,最大长度:32
  373. RealName: realName, //用户实际名称,最大长度:32
  374. Sex: sex, //普通用户性别,1为男性,2为女性
  375. Province: province, //普通用户个人资料填写的省份,最大长度:30
  376. City: city, //普通用户个人资料填写的城市,最大长度:30
  377. Country: country, //国家,如中国为CN,最大长度:30
  378. Headimgurl: headimgurl, //用户第三方(微信)头像,最大长度:512
  379. CreateTime: time.Now(), //创建时间,关系添加时间、用户授权时间
  380. CreatePlatform: platform, //注册平台,1:日度点评公众号,2:管理后台,3:pc端网站,4:查研观向小程序;默认:1
  381. SessionKey: sessionKey, //微信小程序会话密钥,最大长度:255
  382. }
  383. //recordId, err := models.AddUserRecord(userRecord)
  384. if err != nil {
  385. return
  386. }
  387. //userRecord.UserRecordId = int(recordId)
  388. return
  389. }
  390. // 用户绑定
  391. func BindSession(mobile, countryCode string) (wxUser *models.WxUserItem, err error) {
  392. if mobile == "" {
  393. err = errors.New("手机号或邮箱必填一个")
  394. return
  395. }
  396. //var bindAccount string
  397. //根据手机号获取用户信息
  398. if mobile != "" {
  399. tmpWxUser, wxUserErr := models.GetWxUserItemByMobile(mobile)
  400. if wxUserErr != nil && wxUserErr.Error() != utils.ErrNoRow() {
  401. err = wxUserErr
  402. return
  403. }
  404. wxUser = tmpWxUser
  405. //bindAccount = mobile
  406. }
  407. var userId int
  408. //如果查询出来的用户是nil,那么需要新增用户
  409. if wxUser == nil {
  410. user := &models.WxUser{
  411. CompanyId: 1,
  412. CreatedTime: time.Now(),
  413. FirstLogin: 1,
  414. Enabled: 1,
  415. RegisterPlatform: 7,
  416. RegisterTime: time.Now(),
  417. Mobile: mobile,
  418. //Email: email,
  419. IsRegister: 1,
  420. Source: 3,
  421. CountryCode: countryCode,
  422. OutboundMobile: mobile,
  423. OutboundCountryCode: countryCode,
  424. }
  425. tmpUserId, addUserErr := models.AddWxUser(user)
  426. if addUserErr != nil {
  427. err = addUserErr
  428. return
  429. }
  430. user.UserId = int(tmpUserId)
  431. userId = int(tmpUserId)
  432. wxUser, err = models.GetWxUserItemByUserId(userId)
  433. } else {
  434. userId = wxUser.UserId
  435. err = models.BindUserOutboundMobile(mobile, countryCode, userId)
  436. if err != nil {
  437. return
  438. }
  439. if wxUser.IsRegister == 0 {
  440. models.ModifyWxUserRegisterStatus(userId)
  441. }
  442. }
  443. return
  444. }
  445. // 我的收藏
  446. func GetMicroRoadShowMycollect(pageSize, currentIndex int, audioIds, videoIds, activityVideoIds string) (respList []*models.MicroRoadShowPageList, total int, err error) {
  447. var e error
  448. // 根据每页数据量获取音视频配比
  449. startSize := utils.StartIndex(currentIndex, pageSize)
  450. videoList := make([]*models.MicroRoadShowPageList, 0)
  451. //音频的查询
  452. var audioCond string
  453. var audioPars []interface{}
  454. // 如果筛选条件为指定视频ID或只看视频则不做音频查询
  455. // 活动已发布且已结束
  456. audioCond += ` AND b.publish_status = 1 AND b.active_state = 3`
  457. if audioIds != "" {
  458. sliceId := strings.Split(audioIds, ",")
  459. var idSqlStr string
  460. for _, v := range sliceId {
  461. idSqlStr += "'" + v + "',"
  462. }
  463. idSqlStr = strings.TrimRight(idSqlStr, ",")
  464. audioCond += ` AND a.activity_voice_id IN (` + idSqlStr + `)`
  465. } else {
  466. audioCond += ` AND a.activity_voice_id = 0 `
  467. }
  468. //视频的处理
  469. var videoCond string
  470. var videoCondAct string
  471. if activityVideoIds != "" {
  472. sliceId := strings.Split(activityVideoIds, ",")
  473. var idSqlStr string
  474. for _, v := range sliceId {
  475. idSqlStr += "'" + v + "',"
  476. }
  477. idSqlStr = strings.TrimRight(idSqlStr, ",")
  478. videoCondAct += ` AND v.video_id IN (` + idSqlStr + `)`
  479. } else {
  480. videoCondAct += ` AND v.video_id = 0 `
  481. }
  482. var videoPars []interface{}
  483. var videoParsAct []interface{}
  484. if videoIds != "" {
  485. sliceId := strings.Split(videoIds, ",")
  486. var idSqlStr string
  487. for _, v := range sliceId {
  488. idSqlStr += "'" + v + "',"
  489. }
  490. idSqlStr = strings.TrimRight(idSqlStr, ",")
  491. videoCond += ` AND video_id IN (` + idSqlStr + `)`
  492. } else {
  493. videoCond += ` AND video_id = 0 `
  494. }
  495. videoCond += ` AND publish_status = 1`
  496. total, videoList, e = models.GetMicroRoadShowVideoPageListV8(startSize, pageSize, videoCond, videoPars, videoCondAct, videoParsAct, audioCond, audioPars, 0, 0, 0, 0)
  497. if e != nil {
  498. err = errors.New("获取微路演音视频列表失败, Err: " + e.Error())
  499. return
  500. }
  501. respList = videoList
  502. return
  503. }
  504. // 获取用户权限
  505. func GetUserhasPermission(user *models.WxUserItem) (hasPermission int, err error) {
  506. //判断是否已经申请过
  507. applyCount, err := models.GetApplyRecordCount(user.UserId)
  508. if err != nil && err.Error() != utils.ErrNoRow() {
  509. return
  510. }
  511. if applyCount > 0 {
  512. hasPermission = 3
  513. } else {
  514. hasPermission = 5
  515. }
  516. //HasPermission int `description:"1:有该行业权限,正常展示,2:无该行业权限,不存在权益客户下,3:无该品类权限,已提交过申请,4:无该行业权限,未提交过申请,5:潜在客户,未提交过申请,6:潜在客户,已提交过申请"`
  517. if user.CompanyId > 1 {
  518. companyPermission, errPer := models.GetCompanyPermission(user.CompanyId)
  519. if errPer != nil {
  520. err = errPer
  521. return
  522. }
  523. if companyPermission == "" {
  524. if applyCount > 0 {
  525. hasPermission = 3
  526. } else {
  527. hasPermission = 4
  528. }
  529. } else {
  530. if strings.Contains(companyPermission, "医药") || strings.Contains(companyPermission, "科技") || strings.Contains(companyPermission, "消费") || strings.Contains(companyPermission, "智造") || strings.Contains(companyPermission, "策略") {
  531. hasPermission = 1
  532. }
  533. }
  534. }
  535. return
  536. }