/
AccountApiController.php
80 lines (68 loc) · 1.98 KB
/
AccountApiController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php namespace App\Http\Controllers;
use Gzero\Repository\UserRepository;
use Gzero\Validator\BaseUserValidator;
use Gzero\Validator\ValidationException;
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Response;
class AccountApiController extends BaseController {
/**
* @var UserRepository
*/
protected $userRepo;
/**
* @var BaseUserValidator
*/
protected $validator;
public function __construct(UserRepository $userRepo, BaseUserValidator $validator)
{
$this->userRepo = $userRepo;
$this->validator = $validator->setData(\Input::all());
parent::__construct(); // TODO: Change the autogenerated stub
}
//
///**
// * Display the specified resource.
// *
// * @param int $id
// *
// * @return Response
// */
//public function show($id)
//{
// return Response::json($this->enSerializer->toArray(Auth::user()));
//}
/**
* Update the specified resource in storage.
*
* @param int $id
*
* @return Response
*/
public function update($id)
{
try {
if (!Input::has('password')) {
$this->validator->setData(Input::except(['password', 'password_confirmation']));
}
$user = $this->userRepo->getById($id);
$input = $this->validator->bind('nickName', ['userId' => $user->id])->bind('email', ['userId' => $user->id])
->validate('update');
$this->userRepo->update($user, $input);
return Response::json(['success' => true]);
} catch (ValidationException $e) {
// @TODO Use response code from ValidationException class
return Response::json(['success' => false, 'errors' => $e->getErrors()], 400);
}
}
/**
* Remove the specified resource from storage.
*
* @param int $id
*
* @return Response
*/
public function destroy($id)
{
//
}
}