| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Oxbow; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Illuminate\Auth\Authenticatable; | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							|  |  |  | use Illuminate\Auth\Passwords\CanResetPassword; | 
					
						
							|  |  |  | use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract; | 
					
						
							|  |  |  | use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class User extends Model implements AuthenticatableContract, CanResetPasswordContract | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     use Authenticatable, CanResetPassword; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The database table used by the model. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $table = 'users'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The attributes that are mass assignable. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var array | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-09-01 00:59:45 +08:00
										 |  |  |     protected $fillable = ['name', 'email', 'password']; | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The attributes excluded from the model's JSON form. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $hidden = ['password', 'remember_token']; | 
					
						
							| 
									
										
										
										
											2015-08-23 20:41:35 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-25 04:10:04 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns a default guest user. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function getDefault() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return new static([ | 
					
						
							|  |  |  |             'email' => 'guest', | 
					
						
							| 
									
										
										
										
											2015-08-29 22:03:42 +08:00
										 |  |  |             'name'  => 'Guest' | 
					
						
							| 
									
										
										
										
											2015-08-25 04:10:04 +08:00
										 |  |  |         ]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:03:42 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Permissions and roles | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The roles that belong to the user. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function roles() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->belongsToMany('Oxbow\Role'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getRoleAttribute() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->roles()->first(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Check if the user has a particular permission. | 
					
						
							|  |  |  |      * @param $permissionName | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function can($permissionName) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-08-31 19:29:48 +08:00
										 |  |  |         if($this->email == 'guest') { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-08-29 22:03:42 +08:00
										 |  |  |         $permissions = $this->role->permissions()->get(); | 
					
						
							|  |  |  |         $permissionSearch = $permissions->search(function ($item, $key) use ($permissionName) { | 
					
						
							|  |  |  |             return $item->name == $permissionName; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         return $permissionSearch !== false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Attach a role to this user. | 
					
						
							|  |  |  |      * @param Role $role | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function attachRole(Role $role) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->attachRoleId($role->id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Attach a role id to this user. | 
					
						
							|  |  |  |      * @param $id | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function attachRoleId($id) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->roles()->sync([$id]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 03:40:36 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the social account associated with this user. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Database\Eloquent\Relations\HasMany | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function socialAccounts() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->hasMany('Oxbow\SocialAccount'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Check if the user has a social account, | 
					
						
							|  |  |  |      * If a driver is passed it checks for that single account type. | 
					
						
							|  |  |  |      * @param bool|string $socialDriver | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function hasSocialAccount($socialDriver = false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if($socialDriver === false) { | 
					
						
							|  |  |  |             return $this->socialAccounts()->count() > 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->socialAccounts()->where('driver', '=', $socialDriver)->exists(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-23 20:41:35 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Returns the user's avatar, | 
					
						
							|  |  |  |      * Uses Gravatar as the avatar service. | 
					
						
							| 
									
										
										
										
											2015-08-29 22:03:42 +08:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-08-23 20:41:35 +08:00
										 |  |  |      * @param int $size | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getAvatar($size = 50) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $emailHash = md5(strtolower(trim($this->email))); | 
					
						
							|  |  |  |         return '//www.gravatar.com/avatar/' . $emailHash . '?s=' . $size . '&d=identicon'; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-05 03:40:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function getEditUrl() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return '/users/' . $this->id; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-13 03:01:42 +08:00
										 |  |  | } |