diff options
Diffstat (limited to 'src/controllers/UserController.php')
-rw-r--r-- | src/controllers/UserController.php | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/controllers/UserController.php b/src/controllers/UserController.php new file mode 100644 index 0000000..6af3fe8 --- /dev/null +++ b/src/controllers/UserController.php @@ -0,0 +1,63 @@ +<?php +namespace CamilStaps\BotleaguesApi\Controllers; + +use CamilStaps\BotleaguesApi\Database\User; +use CamilStaps\BotleaguesApi\Exception\ValidationException; +use Illuminate\Support\Facades\Auth; +use Illuminate\Support\Facades\Hash; +use Illuminate\Support\Facades\Input; +use Illuminate\Support\Facades\Validator; + +class UserController extends BaseController { + + protected $user; + + public function __construct(User $user) { + $this->user = $user; + + $this->beforeFilter('current_user', array('only' => ['update', 'destroy'])); + } + + public function index() { + return $this->user->all(); + } + + public function show($id) { + return $this->user->findOrFail($id); + } + + public function update($id) { + $s = $this->user->find($id); + + if (!empty(Input::get('password'))) + $s->password = Hash::make(Input::get('password')); + + if ($s->save()) { + return $this->show($id); + } else { + throw new \Dingo\Api\Exception\UpdateResourceFailedException; + } + } + + public function store() { + $rules = [ + 'email' => ['required', 'email', 'unique:users'], + 'password' => ['required', 'min:7'] + ]; + $payload = Input::only('email', 'password'); + $validator = Validator::make($payload, $rules); + if ($validator->fails()) { + throw new ValidationException('Could not create new user.', $validator->errors()); + } + + $this->user->email = Input::get('email'); + $this->user->password = empty(Input::get('password')) ? null : Hash::make(Input::get('password')); + + if ($this->user->save()) { + return $this->response->created(); + } else { + throw new \Dingo\Api\Exception\StoreResourceFailedException; + } + } + +}
\ No newline at end of file |