. */ namespace SP\Forms; use SP\Core\Acl\ActionsInterface; use SP\Core\Exceptions\ValidationException; use SP\DataModel\ApiTokenData; use SP\Http\Request; /** * Class ApiTokenForm * * @package SP\Forms */ class ApiTokenForm extends FormBase implements FormInterface { /** * @var ApiTokenData */ protected $apiTokenData; /** * Validar el formulario * * @param $action * @return ApiTokenForm * @throws \SP\Core\Exceptions\ValidationException */ public function validate($action) { switch ($action) { case ActionsInterface::APITOKEN_CREATE: case ActionsInterface::APITOKEN_EDIT: $this->analyzeRequestData(); $this->checkCommon(); break; } return $this; } /** * Analizar los datos de la petición HTTP * * @return void */ protected function analyzeRequestData() { $this->apiTokenData = new ApiTokenData(); $this->apiTokenData->setAuthtokenId($this->itemId); $this->apiTokenData->setAuthtokenUserId(Request::analyze('users', 0)); $this->apiTokenData->setAuthtokenActionId(Request::analyze('actions', 0)); $this->apiTokenData->setAuthtokenHash(Request::analyzeEncrypted('pass')); } /** * @throws ValidationException */ protected function checkCommon() { if ($this->apiTokenData->getAuthtokenUserId() === 0) { throw new ValidationException(__u('Usuario no indicado')); } if ($this->apiTokenData->getAuthtokenActionId() === 0) { throw new ValidationException(__u('Acción no indicada')); } $action = $this->apiTokenData->getAuthtokenActionId(); if (($action === ActionsInterface::ACCOUNT_VIEW_PASS || $action === ActionsInterface::ACCOUNT_CREATE) && $this->apiTokenData->getAuthtokenHash() === '' ) { throw new ValidationException(__u('La clave no puede estar en blanco')); } } /** * @return ApiTokenData */ public function getItemData() { return $this->apiTokenData; } }