AdminCheck.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. /**
  3. +-----------------------------------------------------------------------------------------------
  4. * GouGuOPEN [ 左手研发,右手开源,未来可期!]
  5. +-----------------------------------------------------------------------------------------------
  6. * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
  7. +-----------------------------------------------------------------------------------------------
  8. * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
  9. +-----------------------------------------------------------------------------------------------
  10. * @Author 勾股工作室 <hdm58@qq.com>
  11. +-----------------------------------------------------------------------------------------------
  12. */
  13. namespace app\user\validate;
  14. use think\facade\Db;
  15. use think\Validate;
  16. class AdminCheck extends Validate
  17. {
  18. protected $regex = [ 'checkUser' => '/^[A-Za-z]{1}[A-Za-z0-9_-]{3,19}$/'];
  19. // 自定义验证规则
  20. protected function checkUnique($value, $rule, $data)
  21. {
  22. [$table, $field, $id] = explode(',', $rule);
  23. $idField = $id ?: 'id';
  24. $idValue = $data[$idField] ?? null;
  25. $map = [
  26. [$field, '=', $value],
  27. ];
  28. if (!is_null($idValue)) {
  29. $map[] = [$idField, '<>', $idValue];
  30. }
  31. $map[] = ['status', 'in', [0,1]];
  32. $map[] = ['delete_time', '=', 0];
  33. return !Db::name($table)->where($map)->count();
  34. }
  35. protected $rule = [
  36. 'name' => 'require|chs',
  37. 'username' => 'require|regex:checkUser',
  38. 'mobile' => 'require|mobile|checkUnique:Admin,mobile,id',
  39. 'email' => 'require|email|checkUnique:Admin,email,id',
  40. 'reg_pwd' => 'require|min:6',
  41. 'did' => 'require',
  42. 'position_id' => 'require',
  43. 'type' => 'require',
  44. 'entry_time' => 'require',
  45. 'id' => 'require',
  46. 'pwd' => 'require|min:6|confirm',
  47. 'old_pwd' => 'require|different:pwd',
  48. ];
  49. protected $message = [
  50. 'name.require' => '员工姓名不能为空',
  51. 'name.chs' => '员工姓名只能是汉字',
  52. 'username.require' => '登录账号不能为空',
  53. 'username.regex' => '登录账号必须是以字母开头,只能包含字母数字下划线和减号,4到20位',
  54. 'mobile.require' => '手机不能为空',
  55. 'mobile.mobile' => '手机格式错误',
  56. 'mobile.checkUnique' => '同样的手机号码已经存在,请检查一下是否被离职或者禁用员工占用',
  57. 'email.require' => '邮箱不能为空',
  58. 'email.email' => '邮箱格式错误',
  59. 'email.checkUnique' => '同样的邮箱已经存在,请检查一下是否被离职或者禁用员工占用',
  60. 'reg_pwd.require' => '密码不能为空',
  61. 'reg_pwd.min' => '密码至少要6个字符',
  62. 'did.require' => '请选择所在部门',
  63. 'position_id.require' => '请选择职位',
  64. 'type.require' => '请选择员工类型',
  65. 'entry_time.require' => '请选择入职时间',
  66. 'id.require' => '缺少更新条件',
  67. 'pwd.require' => '密码不能为空',
  68. 'pwd.min' => '密码至少要6个字符',
  69. 'pwd.confirm' => '两次密码不一致',
  70. 'old_pwd.require' => '请提供旧密码',
  71. 'old_pwd.different' => '新密码不能和旧密码一样',
  72. ];
  73. protected $scene = [
  74. 'add' => ['name', 'username', 'mobile','email','reg_pwd', 'did', 'position_id', 'type', 'entry_time'],
  75. 'edit' => ['name', 'mobile','email', 'did', 'position_id', 'entry_time', 'id'],
  76. 'editPwd' => ['old_pwd', 'pwd'],
  77. ];
  78. }