Blame view

app/library/App/Controllers/UserController.php 2.58 KB
15479603   Alex Savenko   initialize
1
2
3
4
  <?php
  
  namespace App\Controllers;
  
9d682170   Alex Savenko   user registration
5
  use App\Model\User;
15479603   Alex Savenko   initialize
6
  use PhalconRest\Mvc\Controllers\CrudResourceController;
15479603   Alex Savenko   initialize
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  
  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
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
  
          $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
45
46
47
  
      public function registration() {
  
a07c0bce   Alex Savenko   test
48
49
50
51
          $this->beforeHandle();
          $this->beforeHandleWrite();
          $this->beforeHandleCreate();
  
e8cab5b7   Alex Savenko   test
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
          $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
68
69
70
71
72
73
          $newItem = new User();
          $map = $newItem->columnMap();
          foreach ($data as $key => $value) {
              if (in_array($key, $map))
              $newItem->$key = $value;
          }
ad0d0178   Alex Savenko   test
74
75
  
          if (!$newItem) {
cf5145f7   Alex Savenko   test
76
              return $this->onCreateFailed($newItem, $data);
ad0d0178   Alex Savenko   test
77
78
          }
  
c9f9c602   Alex Savenko   test
79
          $newItem->save();
fae1e3db   Alex Savenko   test
80
  
c9f9c602   Alex Savenko   test
81
82
          $last_id = $newItem->getWriteConnection()->lastInsertId();
  
c9f9c602   Alex Savenko   test
83
          $responseData = $this->getFindData($last_id);
ad0d0178   Alex Savenko   test
84
85
          $response = $this->getCreateResponse($responseData, $data);
  
a07c0bce   Alex Savenko   test
86
87
88
89
          $this->afterHandleCreate($newItem, $data, $response);
          $this->afterHandleWrite();
          $this->afterHandle();
  
ad0d0178   Alex Savenko   test
90
          return $response;
e95cb5df   Alex Savenko   user registration
91
  
e95cb5df   Alex Savenko   user registration
92
      }
852ac6bc   Alex Savenko   user registration
93
  
95622a8c   Alex Savenko   user registration
94
95
      protected function transformPostDataValue($key, $value, $data)
      {
93189714   Alex Savenko   test
96
          if ($key == 'pass') {
95622a8c   Alex Savenko   user registration
97
98
99
100
101
102
              return $this->security->hash($value);
          }
          else {
              return $value;
          }
      }
1a3a0f1d   Alex Savenko   user registration
103
  
15479603   Alex Savenko   initialize
104
  }