RegisterController.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use App\User;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Auth\Events\Registered;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Auth;
  8. use Illuminate\Support\Facades\Hash;
  9. use Illuminate\Support\Facades\Validator;
  10. use Illuminate\Foundation\Auth\RegistersUsers;
  11. use Illuminate\Support\Str;
  12. class RegisterController extends Controller
  13. {
  14. /*
  15. |--------------------------------------------------------------------------
  16. | Register Controller
  17. |--------------------------------------------------------------------------
  18. |
  19. | This controller handles the registration of new users as well as their
  20. | validation and creation. By default this controller uses a trait to
  21. | provide this functionality without requiring any additional code.
  22. |
  23. */
  24. use RegistersUsers;
  25. /**
  26. * Where to redirect users after registration.
  27. *
  28. * @var string
  29. */
  30. protected $redirectTo = '/home';
  31. /**
  32. * Create a new controller instance.
  33. *
  34. * @return void
  35. */
  36. public function __construct()
  37. {
  38. // $this->middleware('auth');
  39. }
  40. /**
  41. * Get a validator for an incoming registration request.
  42. *
  43. * @param array $data
  44. * @return \Illuminate\Contracts\Validation\Validator
  45. */
  46. protected function validator(array $data)
  47. {
  48. return Validator::make($data, [
  49. 'name' => ['required', 'string', 'max:255', 'unique:users'],
  50. 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
  51. 'password' => ['required', 'string', 'min:6', 'confirmed'],
  52. ]);
  53. }
  54. /**
  55. * Create a new user instance after a valid registration.
  56. *
  57. * @param array $data
  58. * @return \App\User
  59. */
  60. protected function create(array $data)
  61. {
  62. return User::create([
  63. 'name' => $data['name'],
  64. 'email' => $data['email'],
  65. 'password' => Hash::make($data['password']),
  66. ]);
  67. }
  68. public function register(Request $request)
  69. {
  70. $headTo=$request->input('headTo')??'';
  71. $this->validator($request->all())->validate();
  72. event(new Registered($user = $this->create($request->all())));
  73. $rolesIds=$request->input('role')??'';
  74. if($rolesIds){
  75. $roleIdArr=explode(',',$rolesIds);
  76. $user->roles()->sync($roleIdArr);
  77. }
  78. // $this->guard()->login($user);
  79. $carrierIds=$request->input('carrier')??'';
  80. if ($carrierIds){
  81. $carrierIds=explode(',',$carrierIds);
  82. $user->logistics()->sync($carrierIds);
  83. }
  84. $userWorkgroupId=$request->input('userWorkgroupID');
  85. if ($userWorkgroupId){
  86. $user->userWorkgroups()->sync([$userWorkgroupId]);
  87. }
  88. app('LogService')->log(__METHOD__,__FUNCTION__,json_encode($request->toArray()),$user['id']);
  89. if($headTo){return redirect(url($headTo))->with('successTip',"录入用户 {$user->name} 成功");}
  90. return $this->registered($request, $user)
  91. ?: redirect($this->redirectPath());
  92. }
  93. }