Blame view

app/library/App/Controllers/UserController.php 3.01 KB
15479603   Alex Savenko   initialize
1
2
3
4
  <?php
  
  namespace App\Controllers;
  
a6aec719   Alex Savenko   registration
5
  use App\Model\User;
15479603   Alex Savenko   initialize
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
  use PhalconRest\Mvc\Controllers\CrudResourceController;
  
  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);
  
          $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');
      }
  
3582f649   Alex Savenko   registration
37
      public function register() {
95d1b70c   Alex Savenko   registration
38
  
3754fbeb   Alex Savenko   registration
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
          $this->beforeHandle();
          $this->beforeHandleWrite();
          $this->beforeHandleCreate();
  
          $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);
  
          $item = $this->createModelInstance();
  
          $newItem = $this->createItem($item, $data);
ec0b097a   Alex Savenko   registration
62
63
64
65
66
          $messages = $newItem->getMessages();
  
          foreach ($messages as $message) {
              echo $message, "\n";
          }
3754fbeb   Alex Savenko   registration
67
68
69
70
71
  
          if (!$newItem) {
              return $this->onCreateFailed($item, $data);
          }
  
eff4a925   Alex Savenko   registration
72
          die(var_dump($newItem));
3754fbeb   Alex Savenko   registration
73
          $primaryKey = $this->getModelPrimaryKey();
a777cb69   Alex Savenko   registration
74
          $responseData = $this->getFindData($newItem->$primaryKey);
c23be67b   Alex Savenko   registration
75
  
3754fbeb   Alex Savenko   registration
76
77
78
79
80
81
82
83
          $response = $this->getCreateResponse($responseData, $data);
  
          $this->afterHandleCreate($newItem, $data, $response);
          $this->afterHandleWrite();
          $this->afterHandle();
  
          return $response;
  
3582f649   Alex Savenko   registration
84
85
      }
  
15479603   Alex Savenko   initialize
86
87
88
      public function whitelist()
      {
          return [
c5ed21cc   Alex Savenko   registration
89
90
91
              'username',
              'password',
              'email'
15479603   Alex Savenko   initialize
92
93
          ];
      }
5a57cafe   Alex Savenko   registration
94
95
96
97
98
  
      protected function getModelPrimaryKey()
      {
          return 'id';
      }
ed3514b8   Alex Savenko   registration
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
  
      protected function getFindData($id)
      {
          $phqlBuilder = $this->phqlQueryParser->fromQuery($this->query, $this->getResource());
  
          $phqlBuilder
              ->andWhere('[' . $this->getResource()->getModel() . '].' . $this->getModelPrimaryKey() . ' = :id:',
                  ['id' => $id])
              ->limit(1);
  
          $this->modifyReadQuery($phqlBuilder);
          $this->modifyFindQuery($phqlBuilder, $id);
  
          $results = $phqlBuilder->getQuery()->execute();
  
          return count($results) >= 1 ? $results->getFirst() : null;
      }
a777cb69   Alex Savenko   registration
116
  
15479603   Alex Savenko   initialize
117
  }