User.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: zilongs
  5. * Date: 20-9-23
  6. * Time: 上午11:04
  7. */
  8. namespace App\Models;
  9. class User extends BaseModel
  10. {
  11. public function getCouponNumAttr($value, $data)
  12. {
  13. return UserCoupon::where('user_id', $data['id'])->where('status', 1)->where('expire_time', '>', time())->count();
  14. }
  15. //通过token获取用户信息
  16. public static function getUserByToken()
  17. {
  18. $auth = request()->header('token');
  19. if (empty($auth)) {
  20. exit_out(null, 401, '认证失效,请重新登录');
  21. }
  22. $arr = aes_decrypt($auth);
  23. if (empty($arr['id'])) {
  24. exit_out(null, 401, '认证失效,请重新登录');
  25. }
  26. $user = User::where('id', $arr['id'])->first();
  27. if (empty($user)){
  28. exit_out(null, 601, '该账号已被删除');
  29. }
  30. $user = $user->toArray();
  31. if ($user['status'] == 0){
  32. exit_out(null, 602, '该账号已被冻结');
  33. }
  34. return $user;
  35. }
  36. //改变用户余额
  37. public static function changeBalance($user_id, $change_balance, $type, $relation_id, $remark, $admin_user_id = 0)
  38. {
  39. $user = User::select(['balance'])->where('id', $user_id)->first();
  40. User::where('id', $user_id)->increment('balance', $change_balance);
  41. UserBalanceLog::create([
  42. 'user_id' => $user_id,
  43. 'admin_user_id' => $admin_user_id,
  44. 'type' => $type,
  45. 'relation_id' => $relation_id,
  46. 'before_balance' => $user['balance'],
  47. 'change_balance' => $change_balance,
  48. 'after_balance' => $user['balance'] + $change_balance,
  49. 'remark' => $remark,
  50. ]);
  51. return true;
  52. }
  53. }