當前位置: 首頁>>代碼示例>>PHP>>正文


PHP User::roles方法代碼示例

本文整理匯總了PHP中app\models\User::roles方法的典型用法代碼示例。如果您正苦於以下問題:PHP User::roles方法的具體用法?PHP User::roles怎麽用?PHP User::roles使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在app\models\User的用法示例。


在下文中一共展示了User::roles方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: updateManager

 /**
  * 更新管理型用戶
  *
  * @param  App\Models\User $manager
  * @param  array $inputs
  * @return void
  */
 private function updateManager($manager, $inputs)
 {
     $manager->nickname = e($inputs['nickname']);
     $manager->realname = e($inputs['realname']);
     $manager->is_lock = e($inputs['is_lock']);
     if (!empty($inputs['password']) && !empty($inputs['password_confirmation'])) {
         $manager->password = bcrypt(e($inputs['password']));
     }
     if ($manager->save()) {
         //確保一個管理型用戶隻擁有一個角色
         $roles = $manager->roles;
         if ($roles->isEmpty()) {
             //判斷角色結果集是否為空
             $manager->roles()->attach($inputs['role']);
             //空角色,則直接同步角色
         } else {
             if (is_array($roles)) {
                 //如果為對象數組,則表明該管理用戶擁有多個角色
                 //則刪除多個角色,再同步新的角色
                 $manager->detachRoles($roles);
                 $manager->roles()->attach($inputs['role']);
                 //同步角色
             } else {
                 if ($roles->first()->id !== $inputs['role']) {
                     $manager->detachRole($roles->first());
                     $manager->roles()->attach($inputs['role']);
                     //同步角色
                 }
             }
         }
         //上麵這一大段代碼就是保證一個管理型用戶隻擁有一個角色
         //Entrust擴展包自身是支持一個用戶擁有多個角色的,但在本內容管理框架係統中,限定一個用戶隻能擁有一個角色
     }
 }
開發者ID:Zachary-Leung,項目名稱:wine_platform,代碼行數:41,代碼來源:UserRepository.php

示例2: store

 /**
  * Store a newly created resource in storage.
  *
  * @param  \Illuminate\Http\Request  $request
  * @return \Illuminate\Http\Response
  */
 public function store(Request $request)
 {
     //
     $person = new User();
     $person->first_name = $request->input('first-name');
     $person->last_name = $request->input('last-name');
     $person->email = $request->input('work-email');
     $person->personal_email = $request->input('personal-email');
     $person->password = Hash::make(uniqid());
     $person->address1 = $request->input('address-one');
     $person->address2 = $request->input('address-two');
     $person->zip = $request->input('postcode');
     $person->city = $request->input('city');
     $person->state = $request->input('state');
     $person->country = $request->input('country');
     $person->dob = Carbon::createFromFormat('d/m/Y', $request->input('dob'))->toDateString();
     $person->work_telephone = $request->input('work-telephone');
     $person->personal_telephone = $request->input('personal-telephone');
     $person->gender = $request->input('gender');
     $person->save();
     // Placeholder face until one is submitted
     $path = 'people/' . $person->id . '/face.jpg';
     \Illuminate\Support\Facades\Storage::put($path, file_get_contents('http://api.adorable.io/avatar/400/' . md5($person->id . $person->email . Carbon::now()->getTimestamp()) . ''));
     $person->save();
     // Default job position
     $person->jobPositions()->attach(1, ['primary' => true]);
     // Default role
     $person->roles()->attach(1, ['primary' => true]);
     return redirect()->intended('/people/');
 }
開發者ID:TeenageHelpline,項目名稱:Progress,代碼行數:36,代碼來源:UserController.php

示例3: update

 public function update(User $user, UserRequest $request)
 {
     $user->update($request->all());
     $user->roles()->sync($request->input('roleList'));
     Flash::success(trans('general.updated_msg'));
     return redirect(route('admin.users'));
 }
開發者ID:AlexYaroma,項目名稱:mightyducks,代碼行數:7,代碼來源:UsersController.php

示例4: setupFoundorAndBaseRolsPermission

 public function setupFoundorAndBaseRolsPermission()
 {
     // Create Roles
     $founder = new Role();
     $founder->name = 'Founder';
     $founder->save();
     $admin = new Role();
     $admin->name = 'Admin';
     $admin->save();
     // Create User
     $user = new User();
     $user->username = 'admin';
     $user->display_name = 'Admin';
     $user->email = 'admin@local.com';
     $user->password = 'admin';
     if (!$user->save()) {
         Log::info('Unable to create user ' . $user->username, (array) $user->errors());
     } else {
         Log::info('Created user "' . $user->username . '" <' . $user->email . '>');
     }
     // Attach Roles to user
     $user->roles()->attach($founder->id);
     // Create Permissions
     $manageContent = new Permission();
     $manageContent->name = 'manage_contents';
     $manageContent->display_name = 'Manage Content';
     $manageContent->save();
     $manageUsers = new Permission();
     $manageUsers->name = 'manage_users';
     $manageUsers->display_name = 'Manage Users';
     $manageUsers->save();
     // Assign Permission to Role
     $founder->perms()->sync([$manageContent->id, $manageUsers->id]);
     $admin->perms()->sync([$manageContent->id]);
 }
開發者ID:axex,項目名稱:kratos,代碼行數:35,代碼來源:2016_01_25_135943_entrust_setup_tables.php

示例5: signUp

 /**
  * Register a user
  *
  * @param  Request  $request
  * @return Response
  */
 public function signUp(Request $request)
 {
     if (intval(getenv('APP_PHASE')) < 2) {
         return ['error' => 'applications are not open'];
     }
     $validator = Validator::make($request->all(), ['first_name' => 'required', 'last_name' => 'required', 'email' => 'required|email|unique:users', 'password' => 'required']);
     if ($validator->fails()) {
         return $validator->errors()->all();
     } else {
         $user = new User();
         $user->first_name = $request['first_name'];
         $user->last_name = $request['last_name'];
         $user->password = Hash::make($request['password']);
         $user->email = $request['email'];
         $user->save();
         $user->postSignupActions();
         // Attach roles
         $roles = $user->roles()->get()->lists('name');
         $token = JWTAuth::fromUser($user, ['exp' => strtotime('+1 year'), 'roles' => $roles, 'slug' => $user->slug()]);
         Mail::send('emails.welcome', ['user' => $user], function ($message) use($user) {
             $message->from('hello@boilermake.org', 'Laravel');
             $message->to($user->email);
         });
         return compact('token');
     }
 }
開發者ID:BoilerMake,項目名稱:backend,代碼行數:32,代碼來源:AuthController.php

示例6: handle

 /**
  * Execute the job.
  * @return String
  * @internal param Role $role
  */
 public function handle()
 {
     $this->user->update($this->data->except('newsletter')->toArray());
     $this->user->setAttribute('newsletter', filter_var($this->data->get('newsletter', false), FILTER_VALIDATE_BOOLEAN));
     foreach ($this->association as $key => $value) {
         if ($value != '') {
             if ($key == 'role_id') {
                 $this->user->roles()->sync(array($value));
             } else {
                 $this->user->setAttribute($key, $value);
             }
         }
     }
     $this->user->save();
     event(new UserWasUpdated($this->user));
     return $this->user;
 }
開發者ID:SkysoulDesign,項目名稱:mirage.dev,代碼行數:22,代碼來源:UpdateUserJob.php

示例7: doAdd

 public function doAdd(Request $request)
 {
     $user_form = $request->get('user');
     $user = new User();
     $user->fill($user_form);
     $user->password = Hash::make($user_form['password']);
     $user->faculty_id = $user_form["faculty_id"];
     $user->save();
     $user->roles()->sync($user_form["role_ids"]);
     return redirect('/backend/user');
 }
開發者ID:pchaow,項目名稱:SuccessModel5,代碼行數:11,代碼來源:UserController.php

示例8: createByVkData

 public function createByVkData($vkData)
 {
     $user = new User();
     $user->provider_id = $vkData['uid'];
     $user->name = $vkData['first_name'] . ' ' . $vkData['last_name'];
     $user->screen_name = $vkData['screen_name'];
     $user->save();
     $user->roles()->attach(Role::getDefaultRole());
     copy($vkData['photo_big'], public_path() . '/img/avatars/users/' . $user->id . '.jpg');
     return $user;
 }
開發者ID:AlexYaroma,項目名稱:mightyducks,代碼行數:11,代碼來源:UserRepository.php

示例9: postAdd

 /**
  * Adds an user
  *
  * @param AddUserRequest $request
  * @return \Illuminate\Http\RedirectResponse
  */
 public function postAdd(AddUserRequest $request)
 {
     $user = new User();
     $user->changeProfile($request);
     $user->roles()->attach($request->input('roles'));
     $user->changeSettings($request);
     if ($request->file('avatar')) {
         $user->changeAvatar($request);
     }
     $user->save();
     User::flushCache($user);
     flash()->success(trans('users.add_success'));
     return redirect()->back();
 }
開發者ID:noikiy,項目名稱:Laravel5Starter,代碼行數:20,代碼來源:AdminUsersController.php

示例10: handle

 /**
  * Execute the job.
  *
  * @throws CannotRemoveRolesException
  *
  * @return bool
  */
 public function handle()
 {
     $this->user->name = $this->request->input('name', $this->user->name);
     $this->user->email = $this->request->input('email');
     $password = $this->request->input('password');
     // Verify before changing the users password that it's not empty.
     if (!empty($password)) {
         // If the user doesn't have a set password mutator,
         // we'll encrypt the password.
         if (!$this->user->hasSetMutator('password')) {
             $password = bcrypt($password);
         }
         $this->user->password = $password;
     }
     // Retrieve the administrators name.
     $adminName = Role::getAdministratorName();
     $roles = $this->request->input('roles', []);
     // Retrieve all administrator users.
     $administrators = $this->user->whereHas('roles', function (Builder $builder) use($adminName) {
         $builder->whereName($adminName);
     })->get();
     // Retrieve the administrator role.
     $admin = Role::whereName($adminName)->first();
     // We need to verify that if the user is trying to remove all roles on themselves,
     // and they are the only administrator, that we throw an exception notifying them
     // that they can't do that. Though we want to allow the user to remove the
     // administrator role if more than one administrator exists.
     if (count($roles) === 0 && $this->user->hasRole($admin) && $this->user->getKey() === auth()->user()->getKey() && count($administrators) === 1) {
         throw new CannotRemoveRolesException("Unable to remove the administrator role. You're the only administrator.");
     }
     if ($this->user->save()) {
         $this->user->roles()->sync($roles);
         return true;
     }
     return false;
 }
開發者ID:stevebauman,項目名稱:administration,代碼行數:43,代碼來源:Update.php

示例11: storeUser

 public function storeUser($request)
 {
     $user = new User();
     //find a new api_token
     $token = "";
     do {
         $token = str_random(60);
     } while (User::where("api_token", "=", $token)->first() instanceof User);
     $user->api_token = $token;
     $user->name = $request->name;
     $user->email = $request->email;
     $user->password = bcrypt($request->password);
     $result = $user->save();
     $roles = array_flatten($request->roles);
     $user->roles()->attach($roles);
     return $result;
 }
開發者ID:jaumesala,項目名稱:opendata-maps,代碼行數:17,代碼來源:UserRepository.php

示例12: createUserFromSoap

 private function createUserFromSoap($username, $password)
 {
     $infoResult = $this->getUserInfoFromSoap($username, $password);
     $user = new User();
     $user->username = $username;
     $user->title = $infoResult->Title;
     $user->firstname = $infoResult->FirstName_TH;
     $user->lastname = $infoResult->LastName_TH;
     $user->email = $username . "@up.ac.th";
     //        $user->save();
     $faculty = Faculty::where('name_th', '=', $infoResult->Faculty)->first();
     if ($faculty) {
         $user->faculty_id = $faculty->id;
     }
     $user->save();
     $role = Role::where('key', '=', 'researcher')->first();
     $user->roles()->attach($role->id);
     $user->faculty;
     return $user;
 }
開發者ID:pchaow,項目名稱:SuccessModel5,代碼行數:20,代碼來源:BackendController.php

示例13: save

 public function save()
 {
     $chk = User::where("email", "=", Input::get('email'))->first();
     if (empty($chk)) {
         $user = new User();
         $user->first_name = Input::get('first_name');
         $user->last_name = Input::get('last_name');
         $user->email = Input::get('email');
         $user->password = Hash::make(Input::get('password'));
         $user->user_type = 1;
         $user->save();
         if (!empty(Input::get('roles'))) {
             $user->roles()->sync([Input::get('roles')]);
         }
         return redirect()->route('admin.systemusers.view');
     } else {
         Session::flash("usenameError", "Username already exist");
         return redirect()->back();
     }
 }
開發者ID:sushilcs111,項目名稱:td,代碼行數:20,代碼來源:SystemUsersController.php

示例14: run

 public function run()
 {
     $faker = Faker\Factory::create();
     $user = new User();
     $user->username = 'admin';
     $user->password = Hash::make('admin');
     $user->email = 'admin@domain.com';
     $user->deleted_at = null;
     $user->confirmed_at = \Carbon\Carbon::now();
     $user->save();
     $user->roles()->save(Role::find(1));
     for ($i = 0; $i < 50; $i++) {
         $user = new User();
         $user->username = $faker->userName;
         $user->password = Hash::make('password');
         $user->email = $faker->safeEmail;
         $user->deleted_at = null;
         $user->confirmed_at = \Carbon\Carbon::now();
         $user->save();
         $user->roles()->save(Role::find(2));
     }
 }
開發者ID:Denniskevin,項目名稱:Laravel5Starter,代碼行數:22,代碼來源:UsersSeeder.php

示例15: postAdd

 /**
  * Adds an user
  *
  * @param AddUserRequest $request
  *
  * @return \Illuminate\Http\RedirectResponse
  */
 public function postAdd(AddUserRequest $request)
 {
     $user = new User();
     $user->changeProfile($request);
     $user->roles()->attach($request->input('roles'));
     $user->changeSettings($request);
     if ($request->file('avatar') && Settings::get('use_avatars')) {
         $response = Icr::uploadImage($request->file('avatar'), 'avatar');
         if ($response instanceof \Exception) {
             flash()->error($response->getMessage());
             return redirect()->back();
         }
         $user->changeAvatar($response);
     }
     $user->save();
     User::flushCache($user);
     flash()->success(trans('users.add_success'));
     return redirect()->back();
 }
開發者ID:Denniskevin,項目名稱:Laravel5Starter,代碼行數:26,代碼來源:AdminUsersController.php


注:本文中的app\models\User::roles方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。