user.go 18KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689
  1. package service
  2. import (
  3. "errors"
  4. "spaceofcheng/services/models"
  5. "spaceofcheng/services/models/card"
  6. "spaceofcheng/services/models/cases"
  7. "spaceofcheng/services/models/coupon"
  8. "spaceofcheng/services/models/customer"
  9. "spaceofcheng/services/models/goods"
  10. "spaceofcheng/services/models/model"
  11. "spaceofcheng/services/models/system"
  12. "spaceofcheng/services/utils"
  13. "github.com/astaxie/beego"
  14. "github.com/yl10/kit/encrypt"
  15. )
  16. // UserServ 系统处理
  17. type UserServ struct {
  18. ctx *utils.Context
  19. dao *system.UserDAO
  20. casedao *cases.CaseDAO
  21. customerdao *customer.CustomerDAO
  22. carddao *card.CardDAO
  23. coupondao *coupon.CouponDAO
  24. ordersdao *goods.GoodsDAO
  25. }
  26. // NewUserServ 初始化
  27. func NewUserServ(ctx *utils.Context) *UserServ {
  28. return &UserServ{
  29. ctx: ctx,
  30. dao: system.NewUserDAO(ctx),
  31. casedao: cases.NewCaseDAO(ctx),
  32. customerdao: customer.NewCustomerDAO(ctx),
  33. carddao: card.NewCardDAO(ctx),
  34. coupondao: coupon.NewCouponDAO(ctx),
  35. ordersdao: goods.NewGoodsDAO(ctx),
  36. }
  37. }
  38. // GetUserList 获取用户列表
  39. func (s *UserServ) GetUserList(username, typeid, caseids string, page int, pageSize int) (map[string]interface{}, error) {
  40. if pageSize == 0 {
  41. pageSize = PAGENUM
  42. }
  43. if page == 0 {
  44. page = 1
  45. }
  46. userList, err := s.dao.GetUserList(username, typeid, caseids, page, pageSize)
  47. if err != nil {
  48. beego.Error(err)
  49. return nil, err
  50. }
  51. total, err := s.dao.GetUserCount(username, typeid, caseids)
  52. if err != nil {
  53. beego.Error(err)
  54. return nil, err
  55. }
  56. return map[string]interface{}{
  57. "list": userList,
  58. "pagesize": pageSize,
  59. "pagenum": total,
  60. "page": page,
  61. }, nil
  62. }
  63. // GetCurrentEnvVars 获取当前环境相关变量
  64. func (s *UserServ) GetCurrentEnvVars() (map[string]interface{}, error) {
  65. // 当前用户信息
  66. userRaw := s.ctx.Get("user")
  67. if userRaw == nil {
  68. return nil, utils.LogError("无有效用户信息")
  69. }
  70. user := userRaw.(model.SysUser)
  71. user.Pwd = ""
  72. // 当前用户案场
  73. sessionCase := s.ctx.Get("cases").([]model.SysUserCase)
  74. // caseIDs := ""
  75. // for _, value := range sessionCase {
  76. // if caseIDs != "" {
  77. // caseIDs = caseIDs + ","
  78. // }
  79. // caseIDs = caseIDs + value.CaseId
  80. // }
  81. // cases, err := s.casedao.GetCaseByIDs(caseIDs)
  82. // if err != nil {
  83. // beego.Error(err)
  84. // return nil, err
  85. // }
  86. // 当前用户角色
  87. roles, err := s.dao.GetUserRole(user.UserId)
  88. if err != nil {
  89. return nil, utils.LogError(err)
  90. }
  91. // 当前用户菜单
  92. menus, err := s.dao.GetUserMenu(user.UserId)
  93. if err != nil {
  94. beego.Error(err)
  95. return nil, utils.LogError(err)
  96. }
  97. rtn := map[string]interface{}{
  98. "user": user,
  99. "cases": sessionCase,
  100. "roles": roles,
  101. "menus": menus,
  102. "clienturl": beego.AppConfig.String("clienturl"),
  103. }
  104. return rtn, nil
  105. }
  106. // GetUserByID 根据用户ID获取用户信息
  107. func (s *UserServ) GetUserByID(userid string) (*system.UserInfo, error) {
  108. userinfo, err := s.dao.GetUserByID(userid)
  109. if err != nil {
  110. beego.Error(err)
  111. return nil, err
  112. }
  113. if userinfo != nil {
  114. userinfo.Pwd = ""
  115. usertype, err := s.dao.GetUserType(userid)
  116. if err != nil {
  117. beego.Error(err)
  118. return nil, err
  119. }
  120. userinfo.UserType = usertype
  121. usertag, err := s.dao.GetUserTag(userid)
  122. if err != nil {
  123. beego.Error(err)
  124. return nil, err
  125. }
  126. userinfo.UserTag = usertag
  127. usercase, err := s.dao.GetUserCase(userid)
  128. if err != nil {
  129. beego.Error(err)
  130. return nil, err
  131. }
  132. userinfo.UserCase = usercase
  133. }
  134. // userrole, err := s.dao.GetUserRole(userid)
  135. // if err != nil {
  136. // return nil, err
  137. // }
  138. // userinfo.UserRole = userrole
  139. // usermenu, err := s.dao.GetUserMenu(userid)
  140. // if err != nil {
  141. // return nil, err
  142. // }
  143. // userinfo.UserMenu = usermenu
  144. return userinfo, nil
  145. }
  146. // SaveUser 用户保存
  147. func (s *UserServ) SaveUser(user system.SysUserForm) (*model.SysUser, error) {
  148. var userInfo model.SysUser
  149. userInfo.UserId = user.UserId
  150. userInfo.UserId = user.UserId
  151. userInfo.UserId = user.UserId
  152. userInfo.UserName = user.UserName
  153. userInfo.RealName = user.RealName
  154. userInfo.OrgId = user.OrgId
  155. userInfo.Sex = user.Sex
  156. userInfo.WorkNo = user.WorkNo
  157. userInfo.Email = user.Email
  158. userInfo.Phone = user.Phone
  159. userInfo.Headimgurl = user.Headimgurl
  160. var flag bool = true
  161. for i := 0; i < 4; i++ {
  162. code := s.dao.GenerateRecommendCode()
  163. i, err := s.dao.IsCodeExist(code)
  164. if err != nil {
  165. return nil, errors.New("生成推荐码失败!请重新点击保存。")
  166. }
  167. if i <= 0 {
  168. userInfo.RecommendCode = code
  169. flag = false
  170. break
  171. }
  172. }
  173. if flag {
  174. return nil, errors.New("生成推荐码失败!请重新点击保存。")
  175. }
  176. org := s.ctx.Get("org").(model.SysOrg)
  177. user.OrgId = org.OrgId
  178. userInfo.OrgId = user.OrgId
  179. var err error
  180. var newUSer *model.SysUser
  181. if user.UserName == "" {
  182. return nil, errors.New("用户名不允许为空!")
  183. }
  184. if user.RealName == "" {
  185. return nil, errors.New("用户真实姓名不允许为空!")
  186. }
  187. if user.Phone == "" {
  188. return nil, errors.New("用户手机号不能为空!")
  189. }
  190. // 手机号码与用户名校验
  191. var isok bool
  192. isok, err = s.dao.CheckUserName(user.UserId, user.UserName, user.OrgId)
  193. if err != nil {
  194. beego.Error(err)
  195. return nil, err
  196. }
  197. if !isok {
  198. return nil, errors.New("用户名重复!")
  199. }
  200. isok, err = s.dao.CheckUserPhone(user.UserId, user.Phone, user.OrgId)
  201. if err != nil {
  202. beego.Error(err)
  203. return nil, err
  204. }
  205. if !isok {
  206. return nil, errors.New("手机号码重复!")
  207. }
  208. if user.UserId != "" {
  209. err = s.dao.UpdateUser(userInfo)
  210. if err != nil {
  211. beego.Error(err)
  212. return nil, err
  213. }
  214. // 删除用户对应的标签、用户类型及所属案场
  215. err = s.dao.DelUserTag(user.UserId)
  216. if err != nil {
  217. beego.Error(err)
  218. return nil, err
  219. }
  220. err = s.dao.DelUserType(user.UserId)
  221. if err != nil {
  222. beego.Error(err)
  223. return nil, err
  224. }
  225. // err = s.dao.DelUserBelongCase(user.UserId)
  226. // if err != nil {
  227. // beego.Error(err)
  228. // return nil, err
  229. // }
  230. err = s.dao.DelUserCase(user.UserId)
  231. if err != nil {
  232. beego.Error(err)
  233. return nil, err
  234. }
  235. newUSer = &userInfo
  236. } else {
  237. l, err := s.dao.IsCodeExist(userInfo.RecommendCode)
  238. if err != nil {
  239. beego.Error(err)
  240. return nil, err
  241. }
  242. if l > 0 {
  243. return nil, errors.New("此推荐码已被使用!")
  244. }
  245. newUSer, err = s.dao.AddUser(userInfo)
  246. if err != nil {
  247. beego.Error(err)
  248. return nil, err
  249. }
  250. }
  251. // 保存用户的标签、用户类型及所属案场
  252. err = s.dao.SaveUserTag(newUSer.UserId, user.TagIds)
  253. if err != nil {
  254. beego.Error(err)
  255. return nil, err
  256. }
  257. err = s.dao.SaveUserType(newUSer.UserId, user.TypeId)
  258. if err != nil {
  259. beego.Error(err)
  260. return nil, err
  261. }
  262. caseInfo, err := s.casedao.GetCaseByID(user.BelongCaseId)
  263. if err != nil {
  264. beego.Error(err)
  265. return nil, err
  266. }
  267. if caseInfo == nil {
  268. return nil, errors.New("所属案场不存在!")
  269. }
  270. has, err := s.dao.GetUserCreatedCaseHas(newUSer.UserId, user.BelongCaseId)
  271. if err != nil {
  272. return nil, errors.New("获取用户所属案场失败!")
  273. }
  274. if has {
  275. err = s.dao.UpdateUserCaseBelong(newUSer.UserId, user.BelongCaseId)
  276. if err != nil {
  277. beego.Error(err)
  278. return nil, err
  279. }
  280. } else {
  281. var userCase model.SysUserCase
  282. userCase.CaseId = user.BelongCaseId
  283. userCase.CaseName = caseInfo.CaseName
  284. userCase.IsBelong = 1
  285. userCase.UserId = newUSer.UserId
  286. err = s.dao.SaveUserCase(userCase)
  287. if err != nil {
  288. beego.Error(err)
  289. return nil, err
  290. }
  291. }
  292. // 保存用户标签案场信息
  293. err = s.dao.SaveUserCaseByUserTag(newUSer.UserId, user.BelongCaseId)
  294. if err != nil {
  295. beego.Error(err)
  296. return nil, err
  297. }
  298. newUSer.Pwd = ""
  299. // 保存用户后判断用户是否在客户表中,如果存在,更新
  300. cust, err := s.customerdao.GetCustomerByPhone(newUSer.Phone)
  301. if err != nil {
  302. utils.LogError(err.Error())
  303. return nil, err
  304. }
  305. if cust != nil {
  306. cust.UserId = newUSer.UserId
  307. err = s.customerdao.UpdateCustomer(cust, []string{
  308. "user_id",
  309. })
  310. if err != nil {
  311. utils.LogError(err.Error())
  312. return nil, err
  313. }
  314. // 更新用户映射信息
  315. customerMap, err := s.customerdao.GetCustWithWXByID(cust.CustomerId)
  316. if err != nil {
  317. utils.LogError(err.Error())
  318. return nil, err
  319. }
  320. var userMap = model.TaUserMapping{
  321. UserId: cust.CustomerId,
  322. MappingId: customerMap.MappingId,
  323. }
  324. if err := s.dao.UpdateUserMapping(&userMap, []string{"user_id"}); err != nil {
  325. utils.LogError("更新用户映射信息失败:" + err.Error())
  326. return nil, errors.New("映射用户信息失败")
  327. }
  328. }
  329. return newUSer, err
  330. }
  331. // UpdatePassword 密码修改
  332. func (s *UserServ) UpdatePassword(oriPasswd, newPasswd string, user *model.SysUser) error {
  333. if !s.dao.ValidatePassword(user, oriPasswd) {
  334. return errors.New("密码错误!")
  335. }
  336. if err := s.dao.UpdatePassword(user.UserId, newPasswd); err != nil {
  337. return err
  338. }
  339. return nil
  340. }
  341. // ResetPassword 重设密码
  342. func (s *UserServ) ResetPassword(userid string) error {
  343. newPasswd := encrypt.Md5("123456")
  344. if err := s.dao.UpdatePassword(userid, newPasswd); err != nil {
  345. return err
  346. }
  347. return nil
  348. }
  349. // UserMapping 用户隐射
  350. func (s *UserServ) UserMapping(userMapping model.TaUserMapping) error {
  351. err := s.dao.SaveUserMapping(&userMapping)
  352. if err != nil {
  353. return err
  354. }
  355. // info := make(map[string]string)
  356. // err = json.Unmarshal([]byte(userMapping.AccountInfo), &info)
  357. // if err != nil {
  358. // beego.Error("Umarshal failed:", err)
  359. // return err
  360. // }
  361. // // 根据用户类型更新用户表中的数据
  362. // switch userMapping.UserType {
  363. // case USERTYPE_USER:
  364. // err = s.dao.UpdateUserHeadImg(userMapping.UserId, info["headimgurl"])
  365. // break
  366. // case USERTYPE_CUSTOMER:
  367. // err = s.dao.UpdateCustomerHeadImg(userMapping.UserId, info["nickname"], info["headimgurl"])
  368. // break
  369. // }
  370. return nil
  371. }
  372. // DelUser 删除用户
  373. func (s *UserServ) DelUser(userid string) error {
  374. err := s.dao.DelUser(userid)
  375. if err != nil {
  376. return err
  377. }
  378. // 删除与前台客户的关联
  379. err = s.dao.UnleashCustomerUser(userid)
  380. return err
  381. }
  382. // GetUserTypes 获取用户类型
  383. func (s *UserServ) GetUserTypes(orgid string) ([]model.TdUserType, error) {
  384. types, err := s.dao.GetUserTypes(orgid)
  385. return types, err
  386. }
  387. // GetUserRoles 获取用户角色
  388. func (s *UserServ) GetUserRoles(userid string) ([]model.SysRole, error) {
  389. if userid == "" {
  390. return nil, utils.LogError("没有对应的用户信息!")
  391. }
  392. userroles, err := s.dao.GetUserRole(userid)
  393. return userroles, err
  394. }
  395. // SaveUserRole 保存用户对应角色
  396. func (s *UserServ) SaveUserRole(userid, roleids string) error {
  397. if userid == "" {
  398. return utils.LogError("没有对应的用户信息!")
  399. }
  400. if roleids == "" {
  401. return utils.LogError("没有对应的角色信息!")
  402. }
  403. err := s.dao.DelUserRole(userid)
  404. if err != nil {
  405. return err
  406. }
  407. err = s.dao.SaveUserRole(userid, roleids)
  408. if err != nil {
  409. return err
  410. }
  411. err = s.dao.DelUserMenu(userid)
  412. if err != nil {
  413. return err
  414. }
  415. err = s.dao.SaveUserMenu(userid)
  416. return err
  417. }
  418. // GetUserCustomer 获取我的推荐客户
  419. func (s *UserServ) GetUserCustomer(userid, isrecommend, key string, page int, pageSize int) ([]system.CustomerInfo, error) {
  420. if pageSize == 0 {
  421. pageSize = PAGENUM
  422. }
  423. if page == 0 {
  424. page = 1
  425. }
  426. customers, err := s.dao.GetUserCustomer(userid, isrecommend, key, page, pageSize)
  427. return customers, err
  428. }
  429. // CheckUserSignIn 校验用户登录
  430. func (s *UserServ) CheckUserSignIn(userName, userPassword string) (*model.SysUser, error) {
  431. user, err := s.dao.GetUserByName(userName)
  432. if err != nil {
  433. beego.Error(err)
  434. return nil, err
  435. }
  436. if user == nil {
  437. return nil, errors.New("账户不存在")
  438. }
  439. if user.Status != models.STATUS_NORMAL {
  440. return nil, errors.New("用户账户异常")
  441. }
  442. if !s.dao.ValidatePassword(user, userPassword) {
  443. return nil, errors.New("用户密码不正确")
  444. }
  445. return user, nil
  446. }
  447. // GetUserByTel 根据电话获取用户信息
  448. func (s *UserServ) GetUserByTel(tel string) (*model.SysUser, error) {
  449. user, err := s.dao.GetUserByPhone(tel)
  450. return user, err
  451. }
  452. // GetForbidUsers 获取所有禁止人员信息
  453. func (s *UserServ) GetForbidUsers() ([]model.TaForbidUser, error) {
  454. customer := s.ctx.Get("customer").(model.TaCustomer)
  455. if customer.CustomerId == "" || customer.UserId == "" {
  456. return nil, errors.New("当前用户没有权限查看用户信息")
  457. }
  458. caseinfo, err := s.dao.GetUserBelongCase(customer.UserId)
  459. if err != nil {
  460. return nil, err
  461. }
  462. // if err := utils.NewAuthEngine(s.ctx).CheckCase(caseid); err != nil {
  463. // return nil, err
  464. // }
  465. users, err := s.dao.GetForbidUsers(caseinfo.CaseId)
  466. return users, err
  467. }
  468. // SaveForbidUser 保存禁止人员信息
  469. func (s *UserServ) SaveForbidUser(userid string, forbidtype string) error {
  470. user, err := s.dao.GetUserByID(userid)
  471. if err != nil {
  472. return err
  473. }
  474. if user.Status != models.STATUS_NORMAL {
  475. return errors.New("设置的用户状态异常!不允许操作!")
  476. }
  477. usercase, err := s.dao.GetUserBelongCase(userid)
  478. if err != nil {
  479. return err
  480. }
  481. if usercase.CaseId == "" {
  482. return errors.New("用户不存在所属案场!不允许操作!")
  483. }
  484. if err := utils.NewAuthEngine(s.ctx).CheckCase(usercase.CaseId); err != nil {
  485. return err
  486. }
  487. fibUsers, err := s.dao.GetForbidUserByUserID(userid)
  488. if err != nil {
  489. return err
  490. }
  491. if fibUsers != nil && len(fibUsers) > 0 {
  492. for _, u := range fibUsers {
  493. if u.ForbidType == forbidtype && u.Status == models.STATUS_NORMAL {
  494. return errors.New("当前人员已经被禁止!不允许重复禁止")
  495. }
  496. }
  497. }
  498. var usertype = ""
  499. if len(user.UserType) > 0 {
  500. usertype = user.UserType[0].TypeId
  501. }
  502. var forbiduser = model.TaForbidUser{
  503. UserId: user.UserId,
  504. UserType: usertype,
  505. ForbidType: forbidtype,
  506. CaseId: usercase.CaseId,
  507. }
  508. err = s.dao.SaveForbidUser(&forbiduser)
  509. if err != nil {
  510. return err
  511. }
  512. // 发送短信
  513. if forbidtype == models.FORBID_COUPON {
  514. utils.SendSMS("couponclose", user.Phone)
  515. } else {
  516. utils.SendSMS("goodsclose", user.Phone)
  517. }
  518. return nil
  519. }
  520. // OpenForbidUser 开启禁止人员
  521. func (s *UserServ) OpenForbidUser(userid string, forbidtype string) error {
  522. user, err := s.dao.GetUserByID(userid)
  523. if err != nil {
  524. return err
  525. }
  526. if user.Status != models.STATUS_NORMAL {
  527. return errors.New("设置的用户状态异常!不允许操作!")
  528. }
  529. usercase, err := s.dao.GetUserBelongCase(userid)
  530. if err != nil {
  531. return err
  532. }
  533. if usercase.CaseId == "" {
  534. return errors.New("用户不存在所属案场!不允许操作!")
  535. }
  536. if err := utils.NewAuthEngine(s.ctx).CheckCase(usercase.CaseId); err != nil {
  537. return err
  538. }
  539. fibUsers, err := s.dao.GetForbidUserByUserID(userid)
  540. if err != nil {
  541. return err
  542. }
  543. var ishas = false
  544. var forbiduser = model.TaForbidUser{}
  545. if fibUsers != nil && len(fibUsers) > 0 {
  546. for _, u := range fibUsers {
  547. if u.ForbidType == forbidtype && u.Status == models.STATUS_NORMAL {
  548. ishas = true
  549. forbiduser = u
  550. }
  551. }
  552. }
  553. if !ishas {
  554. return errors.New("用户没有被关闭的功能!")
  555. }
  556. err = s.dao.OpenForbidUser(&forbiduser)
  557. return err
  558. }
  559. // GetCaseUserByType 根据用户类型获取人员信息
  560. func (s *UserServ) GetCaseUserByType(usertype string) ([]system.UserWithCouponAndCard, error) {
  561. customer := s.ctx.Get("customer").(model.TaCustomer)
  562. if customer.CustomerId == "" || customer.UserId == "" {
  563. return nil, errors.New("当前用户没有权限查看用户信息")
  564. }
  565. caseinfo, err := s.dao.GetUserBelongCase(customer.UserId)
  566. if err != nil {
  567. utils.LogError("获取人员归属案场失败: " + err.Error())
  568. return nil, errors.New("获取人员信息失败")
  569. }
  570. users, err := s.dao.GetCaseUserByType(caseinfo.CaseId, usertype)
  571. if err != nil {
  572. utils.LogError("获取人员信息失败: " + err.Error())
  573. return nil, errors.New("获取人员信息失败")
  574. }
  575. for inx, user := range users {
  576. err := s.GetUserWithDetail(caseinfo.CaseId, &user)
  577. if err != nil {
  578. return nil, err
  579. }
  580. users[inx] = user
  581. }
  582. return users, nil
  583. }
  584. // GetCaseUserByUserID 根据用户id获取人员信息
  585. func (s *UserServ) GetCaseUserByUserID(userid string) (*system.UserWithCouponAndCard, error) {
  586. customer := s.ctx.Get("customer").(model.TaCustomer)
  587. if customer.CustomerId == "" || customer.UserId == "" {
  588. return nil, errors.New("当前用户没有权限查看用户信息")
  589. }
  590. caseinfo, err := s.dao.GetUserBelongCase(customer.UserId)
  591. if err != nil {
  592. utils.LogError("获取人员归属案场失败: " + err.Error())
  593. return nil, errors.New("获取人员信息失败")
  594. }
  595. usercaseinfo, err := s.dao.GetUserBelongCase(userid)
  596. if err != nil {
  597. utils.LogError("获取人员归属案场失败: " + err.Error())
  598. return nil, errors.New("获取人员信息失败")
  599. }
  600. if usercaseinfo.CaseId != caseinfo.CaseId {
  601. return nil, errors.New("您没有权限查看此用户的数据!")
  602. }
  603. user, err := s.dao.GetUserDetailByID(userid)
  604. if err != nil {
  605. utils.LogError("获取人员信息失败: " + err.Error())
  606. return nil, errors.New("获取人员信息失败")
  607. }
  608. err = s.GetUserWithDetail(usercaseinfo.CaseId, user)
  609. if err != nil {
  610. return nil, err
  611. }
  612. return user, nil
  613. }
  614. // GetUserWithDetail 获取用户详情
  615. func (s *UserServ) GetUserWithDetail(caseid string, user *system.UserWithCouponAndCard) error {
  616. cards, err := s.carddao.GetCustomerCardByUser(caseid, user.UserId)
  617. if err != nil {
  618. utils.LogError("获取发送卡信息失败: " + err.Error())
  619. return errors.New("获取人员信息失败")
  620. }
  621. user.CustomerCard = cards
  622. coupons, err := s.coupondao.GetCustomerCouponByUser(caseid, user.UserId)
  623. if err != nil {
  624. utils.LogError("获取发送券信息失败: " + err.Error())
  625. return errors.New("获取人员信息失败")
  626. }
  627. user.CustomerCoupon = coupons
  628. details, err := s.ordersdao.GetOrderDetailByUser(caseid, user.UserId)
  629. if err != nil {
  630. utils.LogError("获取用户点单信息失败: " + err.Error())
  631. return errors.New("获取人员信息失败")
  632. }
  633. user.OrdersDetail = details
  634. return nil
  635. }