Blame view

app/library/App/Controllers/UserController.php 3.43 KB
15479603   Alex Savenko   initialize
1
2
3
4
  <?php
  
  namespace App\Controllers;
  
9d682170   Alex Savenko   user registration
5
  use App\Model\User;
06ecc69d   Alex Savenko   email validation
6
7
  use Phalcon\Validation;
  use Phalcon\Validation\Validator\Email;
15479603   Alex Savenko   initialize
8
  use PhalconRest\Mvc\Controllers\CrudResourceController;
06ecc69d   Alex Savenko   email validation
9
10
  use PhalconApi\Exception;
  use PhalconApi\Constants\ErrorCodes;
15479603   Alex Savenko   initialize
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
  
  class UserController extends CrudResourceController
  {
      public function me()
      {
          return $this->createResourceResponse($this->userService->getDetails());
      }
  
      public function authenticate()
      {
          $username = $this->request->getUsername();
          $password = $this->request->getPassword();
  
          $session = $this->authManager->loginWithUsernamePassword(\App\Auth\UsernameAccountType::NAME, $username,
              $password);
15479603   Alex Savenko   initialize
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
  
          $transformer = new \App\Transformers\UserTransformer;
          $transformer->setModelClass('App\Model\User');
  
          $user = $this->createItemResponse(\App\Model\User::findFirst($session->getIdentity()), $transformer);
  
          $response = [
              'token' => $session->getToken(),
              'expires' => $session->getExpirationTime(),
              'user' => $user
          ];
  
          return $this->createArrayResponse($response, 'data');
      }
  
      public function whitelist()
      {
          return [
              'firstName',
              'lastName',
              'password'
          ];
      }
e95cb5df   Alex Savenko   user registration
49
50
51
  
      public function registration() {
  
a07c0bce   Alex Savenko   test
52
53
54
55
          $this->beforeHandle();
          $this->beforeHandleWrite();
          $this->beforeHandleCreate();
  
e8cab5b7   Alex Savenko   test
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
          $data = $this->getPostedData();
  
          if (!$data || count($data) == 0) {
              return $this->onNoDataProvided();
          }
  
          if (!$this->postDataValid($data, false)) {
              return $this->onDataInvalid($data);
          }
  
          if (!$this->saveAllowed($data) || !$this->createAllowed($data)) {
              return $this->onNotAllowed();
          }
  
          $data = $this->transformPostData($data);
  
761fa362   Alex Savenko   test
72
73
74
75
76
77
          $newItem = new User();
          $map = $newItem->columnMap();
          foreach ($data as $key => $value) {
              if (in_array($key, $map))
              $newItem->$key = $value;
          }
ad0d0178   Alex Savenko   test
78
79
  
          if (!$newItem) {
cf5145f7   Alex Savenko   test
80
              return $this->onCreateFailed($newItem, $data);
ad0d0178   Alex Savenko   test
81
82
          }
  
c9f9c602   Alex Savenko   test
83
          $newItem->save();
fae1e3db   Alex Savenko   test
84
  
c9f9c602   Alex Savenko   test
85
86
          $last_id = $newItem->getWriteConnection()->lastInsertId();
  
c9f9c602   Alex Savenko   test
87
          $responseData = $this->getFindData($last_id);
ad0d0178   Alex Savenko   test
88
89
          $response = $this->getCreateResponse($responseData, $data);
  
a07c0bce   Alex Savenko   test
90
91
92
93
          $this->afterHandleCreate($newItem, $data, $response);
          $this->afterHandleWrite();
          $this->afterHandle();
  
ad0d0178   Alex Savenko   test
94
          return $response;
e95cb5df   Alex Savenko   user registration
95
  
e95cb5df   Alex Savenko   user registration
96
      }
852ac6bc   Alex Savenko   user registration
97
  
95622a8c   Alex Savenko   user registration
98
99
      protected function transformPostDataValue($key, $value, $data)
      {
93189714   Alex Savenko   test
100
          if ($key == 'pass') {
95622a8c   Alex Savenko   user registration
101
102
103
104
105
106
              return $this->security->hash($value);
          }
          else {
              return $value;
          }
      }
1a3a0f1d   Alex Savenko   user registration
107
  
06ecc69d   Alex Savenko   email validation
108
109
      protected function beforeHandleWrite()
      {
180ff9a4   Alex Savenko   email validation
110
  
06ecc69d   Alex Savenko   email validation
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
          $email_field = 'email';
  
          $validation = new Validation();
  
          $validation->add(
              $email_field,
              new Email(
                  [
                      "message" => "The e-mail is not valid",
                  ]
              )
          );
  
          $data = $this->getPostedData();
  
180ff9a4   Alex Savenko   email validation
126
  
3e5598de   Alex Savenko   email validation
127
          if (isset($data[$email_field])) {
06ecc69d   Alex Savenko   email validation
128
  
6414b151   Alex Savenko   email validation
129
              $message = $validation->validate($data[$email_field]);
a7b286bf   Alex Savenko   email validation
130
  
06ecc69d   Alex Savenko   email validation
131
132
133
134
135
136
137
138
139
140
141
142
              if (count($message)) {
                  throw new Exception(ErrorCodes::DATA_FAILED, 'Unable to create item', [
                      'messages' => $message,
                      'data' => $data[$email_field]
                  ]);
              }
  
          }
  
  
      }
  
15479603   Alex Savenko   initialize
143
  }