Blame view

app/library/App/Controllers/UserController.php 2.09 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;
9d682170   Alex Savenko   user registration
7
  use Phalcon\Mvc\Model;
15479603   Alex Savenko   initialize
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
  
  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
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
  
          $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
46
47
48
  
      public function registration() {
  
e8cab5b7   Alex Savenko   test
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
          $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);
  
          $user = new User();
          $user->name = $data['name'];
          $user->pass = $data['pass'];
          $user->save();
e95cb5df   Alex Savenko   user registration
69
70
  
      }
852ac6bc   Alex Savenko   user registration
71
  
95622a8c   Alex Savenko   user registration
72
73
74
75
76
77
78
79
80
      protected function transformPostDataValue($key, $value, $data)
      {
          if ($key == 'password') {
              return $this->security->hash($value);
          }
          else {
              return $value;
          }
      }
1a3a0f1d   Alex Savenko   user registration
81
  
3293216b   Alex Savenko   test
82
83
84
85
86
87
88
      /**
       * fix phql for PG
       */
      protected function getModelPrimaryKey()
      {
          return 'id';
      }
9d682170   Alex Savenko   user registration
89
  
15479603   Alex Savenko   initialize
90
  }