Commit e95cb5df20a340a4230fc049466bbfdf70f821a3
1 parent
8e3b7275
user registration
Showing
3 changed files
with
45 additions
and
2 deletions
Show diff stats
app/library/App/Controllers/UserController.php
| @@ -41,4 +41,43 @@ class UserController extends CrudResourceController | @@ -41,4 +41,43 @@ class UserController extends CrudResourceController | ||
| 41 | 'password' | 41 | 'password' |
| 42 | ]; | 42 | ]; |
| 43 | } | 43 | } |
| 44 | + | ||
| 45 | + public function registration() { | ||
| 46 | + | ||
| 47 | + $data = $this->getPostedData(); | ||
| 48 | + | ||
| 49 | + if (!$data || count($data) == 0) { | ||
| 50 | + return $this->onNoDataProvided(); | ||
| 51 | + } | ||
| 52 | + | ||
| 53 | + if (!$this->postDataValid($data, false)) { | ||
| 54 | + return $this->onDataInvalid($data); | ||
| 55 | + } | ||
| 56 | + | ||
| 57 | + if (!$this->saveAllowed($data) || !$this->createAllowed($data)) { | ||
| 58 | + return $this->onNotAllowed(); | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + $data = $this->transformPostData($data); | ||
| 62 | + | ||
| 63 | + $item = $this->createModelInstance(); | ||
| 64 | + | ||
| 65 | + $newItem = $this->createItem($item, $data); | ||
| 66 | + | ||
| 67 | + if (!$newItem) { | ||
| 68 | + return $this->onCreateFailed($item, $data); | ||
| 69 | + } | ||
| 70 | + | ||
| 71 | + $primaryKey = $this->getModelPrimaryKey(); | ||
| 72 | + $responseData = $this->getFindData($newItem->$primaryKey); | ||
| 73 | + | ||
| 74 | + $response = $this->getCreateResponse($responseData, $data); | ||
| 75 | + | ||
| 76 | + $this->afterHandleCreate($newItem, $data, $response); | ||
| 77 | + $this->afterHandleWrite(); | ||
| 78 | + $this->afterHandle(); | ||
| 79 | + | ||
| 80 | + return $response; | ||
| 81 | + | ||
| 82 | + } | ||
| 44 | } | 83 | } |
app/library/App/Model/Project.php
| @@ -23,7 +23,7 @@ class Project extends \App\Mvc\DateTrackingModel { | @@ -23,7 +23,7 @@ class Project extends \App\Mvc\DateTrackingModel { | ||
| 23 | public function columnMap() | 23 | public function columnMap() |
| 24 | { | 24 | { |
| 25 | return parent::columnMap() + [ | 25 | return parent::columnMap() + [ |
| 26 | - //'id' => 'id', | 26 | + 'id' => 'id', |
| 27 | 'name' => 'name', | 27 | 'name' => 'name', |
| 28 | 'user_id' => 'user_id' | 28 | 'user_id' => 'user_id' |
| 29 | ]; | 29 | ]; |
app/library/App/Resources/UserResource.php
| @@ -39,6 +39,10 @@ class UserResource extends ApiResource { | @@ -39,6 +39,10 @@ class UserResource extends ApiResource { | ||
| 39 | 'token' => 'co126bbm40wqp41i3bo7pj1gfsvt9lp6', | 39 | 'token' => 'co126bbm40wqp41i3bo7pj1gfsvt9lp6', |
| 40 | 'expires' => 1451139067 | 40 | 'expires' => 1451139067 |
| 41 | ]) | 41 | ]) |
| 42 | - ); | 42 | + ) |
| 43 | + ->endpoint(ApiEndpoint::post('/registration', 'registration')) | ||
| 44 | + ->deny(AclRoles::AUTHORIZED) | ||
| 45 | + ->description('Registration') | ||
| 46 | + ; | ||
| 43 | } | 47 | } |
| 44 | } | 48 | } |
| 45 | \ No newline at end of file | 49 | \ No newline at end of file |