UserController.php
2.7 KB
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
<?php
namespace App\Controllers;
use App\Model\Project;
use App\Model\User;
use PhalconRest\Mvc\Controllers\CrudResourceController;
class UserController extends CrudResourceController
{
    public function whitelist()
    {
        return [
            'username',
            'password',
            'email'
        ];
    }
    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');
    }
    public function register() {
        $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);
        if (!$newItem) {
            return $this->onCreateFailed($item, $data);
        }
        $last_id = $newItem->getWriteConnection()->lastInsertId();
        $responseData = $this->getFindData($last_id);
        $response = $this->getCreateResponse($responseData, $data);
        $this->afterHandleCreate($newItem, $data, $response);
        $this->afterHandleWrite();
        $this->afterHandle();
        return $response;
    }
    protected function transformPostData($data)
    {
        $result = [];
        foreach ($data as $key => $value) {
            $result[$key] = $this->transformPostDataValue($key, $value, $data);
        }
        return $result;
    }
    protected function transformPostDataValue($key, $value, $data)
    {
        if ($key == 'password') {
            return $this->security->hash($value);
        } else {
            return $value;
        }
    }
}