12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- <?php
- /**
- * @link http://www.yiiframework.com/
- * @copyright Copyright (c) 2008 Yii Software LLC
- * @license http://www.yiiframework.com/license/
- */
- namespace yii\rest;
- use Yii;
- use yii\base\Model;
- use yii\helpers\Url;
- use yii\web\ServerErrorHttpException;
- /**
- * CreateAction implements the API endpoint for creating a new model from the given data.
- *
- * For more details and usage information on CreateAction, see the [guide article on rest controllers](guide:rest-controllers).
- *
- * @author Qiang Xue <qiang.xue@gmail.com>
- * @since 2.0
- */
- class CreateAction extends Action
- {
- /**
- * @var string the scenario to be assigned to the new model before it is validated and saved.
- */
- public $scenario = Model::SCENARIO_DEFAULT;
- /**
- * @var string the name of the view action. This property is needed to create the URL when the model is successfully created.
- */
- public $viewAction = 'view';
- /**
- * Creates a new model.
- * @return \yii\db\ActiveRecordInterface the model newly created
- * @throws ServerErrorHttpException if there is any error when creating the model
- */
- public function run()
- {
- if ($this->checkAccess) {
- call_user_func($this->checkAccess, $this->id);
- }
- /* @var $model \yii\db\ActiveRecord */
- $model = new $this->modelClass([
- 'scenario' => $this->scenario,
- ]);
- $model->load(Yii::$app->getRequest()->getBodyParams(), '');
- if ($model->save()) {
- $response = Yii::$app->getResponse();
- $response->setStatusCode(201);
- $id = implode(',', array_values($model->getPrimaryKey(true)));
- $response->getHeaders()->set('Location', Url::toRoute([$this->viewAction, 'id' => $id], true));
- } elseif (!$model->hasErrors()) {
- throw new ServerErrorHttpException('Failed to create the object for unknown reason.');
- }
- return $model;
- }
- }
|