User.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. namespace App\Models;
  3. // // 关键:导入正确的 Builder 类(Eloquent 构建器)
  4. // use Illuminate\Database\Eloquent\Builder;
  5. use Carbon\Carbon;
  6. /**
  7. * @property int $id
  8. * @property string $member_id
  9. * @property string $username
  10. * @property string $first_name
  11. * @property string $language
  12. * @property string $register_ip
  13. * @property integer $status
  14. * @property string $visitor_id
  15. * @property string $phone 用户手机号
  16. * @property string $admin_note
  17. * @property $last_active_time 最后活跃时间
  18. */
  19. class User extends BaseModel
  20. {
  21. protected $table = 'users';
  22. protected $fillable = ['usdt', 'is_banned', 'last_active_time', 'visitor_id', 'register_ip', 'status', 'admin_note', 'member_id', 'first_name',
  23. 'game_id', 'username', 'secret_key', 'secret_pass', 'language','user_code', 'agent_user_code','level','recharge_channel_group_id'];
  24. protected $attributes = [
  25. 'language' => 'zh',
  26. ];
  27. protected $hidden = ['updated_at'];
  28. // public function newQuery($excludeDeleted = true): Builder
  29. // {
  30. // // 1. 获取原生 Eloquent 查询构建器
  31. // $query = parent::newQuery($excludeDeleted);
  32. // // 2. 强制清空当前连接的表前缀(从根源阻止拼接)
  33. // $this->getConnection()->setTablePrefix('');
  34. // // 3. 强制指定查询的表名为 la_operation(覆盖所有拼接逻辑)
  35. // $query->from('bot_users');
  36. // return $query;
  37. // }
  38. function getLastActiveTimeAttribute($value): string
  39. {
  40. if ($value > 0 && !is_numeric($value)) {
  41. return date('Y-m-d H:i', strtotime($value));
  42. }
  43. return "";
  44. }
  45. function getCreatedAtAttribute($value): string
  46. {
  47. return Carbon::parse($value)->setTimezone('Asia/Shanghai')->format('Y-m-d');
  48. }
  49. public function wallet()
  50. {
  51. return $this->belongsTo(Wallet::class, 'member_id', 'member_id');
  52. }
  53. public function level()
  54. {
  55. return $this->belongsTo(Level::class, 'level', 'level')->select('id', 'level', 'level_name','img','recharge');
  56. }
  57. public function agent()
  58. {
  59. return $this->belongsTo(User::class, 'agent_user_code', 'user_code')->select('id', 'user_code', 'account','first_name','member_id');
  60. }
  61. public function setLanguage($language): void
  62. {
  63. $this->language = $language;
  64. }
  65. public function getMemberId()
  66. {
  67. return $this->member_id;
  68. }
  69. public function getUsername()
  70. {
  71. return $this->username;
  72. }
  73. public function getFirstName()
  74. {
  75. return $this->first_name;
  76. }
  77. /**
  78. * 生成8位数字+大写字母混合邀请码
  79. * @return string 生成的邀请码
  80. */
  81. public static function generateUserCode($num_len = 6, $letter_len = 2) {
  82. // 生成num_len位安全随机数字
  83. $numbers = '';
  84. for ($i = 0; $i < $num_len; $i++) {
  85. $numbers .= random_int(0, 9);
  86. }
  87. // 生成letter_len位安全随机字母
  88. $letters = '';
  89. $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  90. $charLength = strlen($chars);
  91. for ($i = 0; $i < $letter_len; $i++) {
  92. $letters .= $chars[random_int(0, $charLength - 1)];
  93. }
  94. // 打乱顺序
  95. $user_code = str_shuffle($numbers . $letters);
  96. if (User::where('user_code', $user_code)->value('id')) {
  97. return self::generateUserCode();
  98. }
  99. return $user_code;
  100. }
  101. }