UnlockUser.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2017~2021 https://www.thinkphp.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
  8. // +----------------------------------------------------------------------
  9. // | Author: thinkphp <admin@yiovo.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\common\model;
  13. use cores\BaseModel;
  14. /**
  15. * 解锁生源用户模型类
  16. * Class UnlockUser
  17. * @package app\common\model
  18. */
  19. class UnlockUser extends BaseModel
  20. {
  21. protected $globalScope = [''];
  22. // 定义表名
  23. protected $name = 'unlock_users';
  24. // 定义主键
  25. protected $pk = 'id';
  26. /**
  27. * 获取老师已解锁的用户ID
  28. * @param $userId
  29. * @return array
  30. */
  31. public static function getUserByUser($userId, $schoolId=0)
  32. {
  33. $where = ['uo.user_id'=> $userId, 'uo.status'=>2];
  34. if($schoolId>0){
  35. $where['uo.school_id'] = $schoolId;
  36. }
  37. return self::alias('a')
  38. ->leftJoin('unlock_order uo','a.order_id=uo.order_id')
  39. ->where($where)
  40. ->column('a.user_id');
  41. }
  42. /**
  43. * 验证老师是否已经解锁该用户
  44. * @param $lockUserId 解锁用户
  45. * @param $userId 老师用户ID
  46. * @param int $schoolId 生源学校ID
  47. * @return mixed
  48. */
  49. public static function checkUserByUser($lockUserId, $userId, $schoolId=0)
  50. {
  51. $lockedUids = $userId? UserInfo::getLockedIds($userId) : [];
  52. if($lockedUids && in_array($lockUserId, $lockedUids)){
  53. return 1;
  54. }
  55. $where = ['uo.user_id'=> $userId, 'a.user_id'=> $lockUserId, 'uo.status'=>2];
  56. if($schoolId>0){
  57. $where['uo.school_id'] = $schoolId;
  58. }
  59. return self::alias('a')
  60. ->leftJoin('unlock_order uo','a.order_id=uo.order_id')
  61. ->where($where)
  62. ->value('a.user_id')? 1 : 2;
  63. }
  64. /**
  65. * 计算老师已解锁的用户数量
  66. * @param $userId
  67. * @return array
  68. */
  69. public static function getCountByUser($userId, $schoolId)
  70. {
  71. $where = ['uo.user_id'=> $userId, 'uo.status'=>2];
  72. if($schoolId>0){
  73. $where['uo.school_id'] = $schoolId;
  74. }
  75. return self::alias('a')
  76. ->leftJoin('unlock_order uo','a.order_id=uo.order_id')
  77. ->where($where)
  78. ->count('a.user_id');
  79. }
  80. }