Parses the default sort order from the given $defaultSortOrderString.
public parseDefaultSortOrder ( string $defaultSortOrderString ) : integer | ||
$defaultSortOrderString | string | |
return | integer |
/** * Parse input structure * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @return \eZ\Publish\API\Repository\Values\Content\LocationCreateStruct */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { if (!array_key_exists('ParentLocation', $data) || !is_array($data['ParentLocation'])) { throw new Exceptions\Parser("Missing or invalid 'ParentLocation' element for LocationCreate."); } if (!array_key_exists('_href', $data['ParentLocation'])) { throw new Exceptions\Parser("Missing '_href' attribute for ParentLocation element in LocationCreate."); } $locationHrefParts = explode('/', $this->requestParser->parseHref($data['ParentLocation']['_href'], 'locationPath')); $locationCreateStruct = $this->locationService->newLocationCreateStruct(array_pop($locationHrefParts)); if (array_key_exists('priority', $data)) { $locationCreateStruct->priority = (int) $data['priority']; } if (array_key_exists('hidden', $data)) { $locationCreateStruct->hidden = $this->parserTools->parseBooleanValue($data['hidden']); } if (array_key_exists('remoteId', $data)) { $locationCreateStruct->remoteId = $data['remoteId']; } if (!array_key_exists('sortField', $data)) { throw new Exceptions\Parser("Missing 'sortField' element for LocationCreate."); } $locationCreateStruct->sortField = $this->parserTools->parseDefaultSortField($data['sortField']); if (!array_key_exists('sortOrder', $data)) { throw new Exceptions\Parser("Missing 'sortOrder' element for LocationCreate."); } $locationCreateStruct->sortOrder = $this->parserTools->parseDefaultSortOrder($data['sortOrder']); return $locationCreateStruct; }
/** * Parse input structure * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @return \eZ\Publish\API\Repository\Values\ContentType\ContentType * @todo Error handling * @todo What about missing properties? Set them here, using the service to * load? Or better set them in the service, since loading is really * unsuitable here? */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { $creatorId = $this->parserTools->parseObjectElement($data['Creator'], $parsingDispatcher); $modifierId = $this->parserTools->parseObjectElement($data['Modifier'], $parsingDispatcher); $fieldDefinitionListReference = $this->parserTools->parseObjectElement($data['FieldDefinitions'], $parsingDispatcher); $contentType = new Values\ContentType\ContentType($this->contentTypeService, array('id' => $data['_href'], 'status' => $this->parserTools->parseStatus($data['status']), 'identifier' => $data['identifier'], 'names' => isset($data['names']) ? $this->parserTools->parseTranslatableList($data['names']) : null, 'descriptions' => isset($data['descriptions']) ? $this->parserTools->parseTranslatableList($data['descriptions']) : null, 'creationDate' => new \DateTime($data['creationDate']), 'modificationDate' => new \DateTime($data['modificationDate']), 'creatorId' => $creatorId, 'modifierId' => $modifierId, 'remoteId' => $data['remoteId'], 'urlAliasSchema' => $data['urlAliasSchema'], 'nameSchema' => $data['nameSchema'], 'isContainer' => $this->parserTools->parseBooleanValue($data['isContainer']), 'mainLanguageCode' => $data['mainLanguageCode'], 'defaultAlwaysAvailable' => $this->parserTools->parseBooleanValue($data['defaultAlwaysAvailable']), 'defaultSortOrder' => $this->parserTools->parseDefaultSortOrder($data['defaultSortOrder']), 'defaultSortField' => $this->parserTools->parseDefaultSortField($data['defaultSortField']), 'fieldDefinitionListReference' => $fieldDefinitionListReference)); if ($contentType->status === Values\ContentType\ContentType::STATUS_DRAFT) { return new Values\ContentType\ContentTypeDraft($contentType); } return $contentType; }
/** * Parse input structure. * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @return \eZ\Publish\API\Repository\Values\ContentType\ContentTypeUpdateStruct */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { $contentTypeUpdateStruct = $this->contentTypeService->newContentTypeUpdateStruct(); if (array_key_exists('identifier', $data)) { $contentTypeUpdateStruct->identifier = $data['identifier']; } if (array_key_exists('mainLanguageCode', $data)) { $contentTypeUpdateStruct->mainLanguageCode = $data['mainLanguageCode']; } if (array_key_exists('remoteId', $data)) { $contentTypeUpdateStruct->remoteId = $data['remoteId']; } if (array_key_exists('urlAliasSchema', $data)) { $contentTypeUpdateStruct->urlAliasSchema = $data['urlAliasSchema']; } if (array_key_exists('nameSchema', $data)) { $contentTypeUpdateStruct->nameSchema = $data['nameSchema']; } if (array_key_exists('isContainer', $data)) { $contentTypeUpdateStruct->isContainer = $this->parserTools->parseBooleanValue($data['isContainer']); } if (array_key_exists('defaultSortField', $data)) { $contentTypeUpdateStruct->defaultSortField = $this->parserTools->parseDefaultSortField($data['defaultSortField']); } if (array_key_exists('defaultSortOrder', $data)) { $contentTypeUpdateStruct->defaultSortOrder = $this->parserTools->parseDefaultSortOrder($data['defaultSortOrder']); } if (array_key_exists('defaultAlwaysAvailable', $data)) { $contentTypeUpdateStruct->defaultAlwaysAvailable = $this->parserTools->parseBooleanValue($data['defaultAlwaysAvailable']); } if (array_key_exists('names', $data)) { if (!is_array($data['names']) || !array_key_exists('value', $data['names']) || !is_array($data['names']['value'])) { throw new Exceptions\Parser("Invalid 'names' element for ContentTypeUpdate."); } $contentTypeUpdateStruct->names = $this->parserTools->parseTranslatableList($data['names']); } if (array_key_exists('descriptions', $data)) { if (!is_array($data['descriptions']) || !array_key_exists('value', $data['descriptions']) || !is_array($data['descriptions']['value'])) { throw new Exceptions\Parser("Invalid 'descriptions' element for ContentTypeUpdate."); } $contentTypeUpdateStruct->descriptions = $this->parserTools->parseTranslatableList($data['descriptions']); } if (array_key_exists('modificationDate', $data)) { $contentTypeUpdateStruct->modificationDate = new DateTime($data['modificationDate']); } if (array_key_exists('User', $data)) { if (!array_key_exists('_href', $data['User'])) { throw new Exceptions\Parser("Missing '_href' attribute for User element in ContentTypeUpdate."); } $contentTypeUpdateStruct->modifierId = $this->requestParser->parseHref($data['User']['_href'], 'userId'); } return $contentTypeUpdateStruct; }
/** * Parse input structure. * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @return \eZ\Publish\Core\REST\Server\Values\RestLocationUpdateStruct */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { $locationUpdateStruct = $this->locationService->newLocationUpdateStruct(); if (array_key_exists('priority', $data)) { $locationUpdateStruct->priority = (int) $data['priority']; } if (array_key_exists('remoteId', $data)) { $locationUpdateStruct->remoteId = $data['remoteId']; } $hidden = null; if (array_key_exists('hidden', $data)) { $hidden = $this->parserTools->parseBooleanValue($data['hidden']); } if (!array_key_exists('sortField', $data)) { throw new Exceptions\Parser("Missing 'sortField' element for LocationUpdate."); } $locationUpdateStruct->sortField = $this->parserTools->parseDefaultSortField($data['sortField']); if (!array_key_exists('sortOrder', $data)) { throw new Exceptions\Parser("Missing 'sortOrder' element for LocationUpdate."); } $locationUpdateStruct->sortOrder = $this->parserTools->parseDefaultSortOrder($data['sortOrder']); return new RestLocationUpdateStruct($locationUpdateStruct, $hidden); }
/** * Parse input structure * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @todo Error handling * * @return \eZ\Publish\API\Repository\Values\Content\Location */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { $content = $parsingDispatcher->parse($data['Content'], 'Content'); return new Values\Content\Location(array('contentInfo' => $content instanceof APIContent ? $content->getVersionInfo()->getContentInfo() : null, 'id' => $data['_href'], 'priority' => (int) $data['priority'], 'hidden' => $data['hidden'] === 'true' ? true : false, 'invisible' => $data['invisible'] === 'true' ? true : false, 'remoteId' => $data['remoteId'], 'parentLocationId' => $data['ParentLocation']['_href'], 'pathString' => $data['pathString'], 'depth' => (int) $data['depth'], 'sortField' => $this->parserTools->parseDefaultSortField($data['sortField']), 'sortOrder' => $this->parserTools->parseDefaultSortOrder($data['sortOrder']))); }
/** * Parse input structure. * * @param array $data * @param \eZ\Publish\Core\REST\Common\Input\ParsingDispatcher $parsingDispatcher * * @return \eZ\Publish\API\Repository\Values\ContentType\ContentTypeCreateStruct */ public function parse(array $data, ParsingDispatcher $parsingDispatcher) { if (!array_key_exists('identifier', $data)) { throw new Exceptions\Parser("Missing 'identifier' element for ContentTypeCreate."); } $contentTypeCreateStruct = $this->contentTypeService->newContentTypeCreateStruct($data['identifier']); if (!array_key_exists('mainLanguageCode', $data)) { throw new Exceptions\Parser("Missing 'mainLanguageCode' element for ContentTypeCreate."); } $contentTypeCreateStruct->mainLanguageCode = $data['mainLanguageCode']; if (array_key_exists('remoteId', $data)) { $contentTypeCreateStruct->remoteId = $data['remoteId']; } if (array_key_exists('urlAliasSchema', $data)) { $contentTypeCreateStruct->urlAliasSchema = $data['urlAliasSchema']; } // @todo XSD says that nameSchema is mandatory, but it is not in create struct if (array_key_exists('nameSchema', $data)) { $contentTypeCreateStruct->nameSchema = $data['nameSchema']; } // @todo XSD says that isContainer is mandatory, but it is not in create struct if (array_key_exists('isContainer', $data)) { $contentTypeCreateStruct->isContainer = $this->parserTools->parseBooleanValue($data['isContainer']); } // @todo XSD says that defaultSortField is mandatory, but it is not in create struct if (array_key_exists('defaultSortField', $data)) { $contentTypeCreateStruct->defaultSortField = $this->parserTools->parseDefaultSortField($data['defaultSortField']); } // @todo XSD says that defaultSortOrder is mandatory, but it is not in create struct if (array_key_exists('defaultSortOrder', $data)) { $contentTypeCreateStruct->defaultSortOrder = $this->parserTools->parseDefaultSortOrder($data['defaultSortOrder']); } // @todo XSD says that defaultAlwaysAvailable is mandatory, but it is not in create struct if (array_key_exists('defaultAlwaysAvailable', $data)) { $contentTypeCreateStruct->defaultAlwaysAvailable = $this->parserTools->parseBooleanValue($data['defaultAlwaysAvailable']); } if (array_key_exists('names', $data)) { if (!is_array($data['names']) || !array_key_exists('value', $data['names']) || !is_array($data['names']['value'])) { throw new Exceptions\Parser("Invalid 'names' element for ContentTypeCreate."); } $contentTypeCreateStruct->names = $this->parserTools->parseTranslatableList($data['names']); } // @todo XSD says that descriptions is mandatory, but content type can be created without descriptions if (array_key_exists('descriptions', $data)) { if (!is_array($data['descriptions']) || !array_key_exists('value', $data['descriptions']) || !is_array($data['descriptions']['value'])) { throw new Exceptions\Parser("Invalid 'descriptions' element for ContentTypeCreate."); } $contentTypeCreateStruct->descriptions = $this->parserTools->parseTranslatableList($data['descriptions']); } // @todo 1: XSD says that modificationDate is mandatory, but it is not in create struct // @todo 2: mismatch between XSD naming and create struct naming if (array_key_exists('modificationDate', $data)) { $contentTypeCreateStruct->creationDate = new DateTime($data['modificationDate']); } if (array_key_exists('User', $data)) { if (!array_key_exists('_href', $data['User'])) { throw new Exceptions\Parser("Missing '_href' attribute for User element in ContentTypeCreate."); } $contentTypeCreateStruct->creatorId = $this->requestParser->parseHref($data['User']['_href'], 'userId'); } if (!array_key_exists('FieldDefinitions', $data)) { throw new Exceptions\Parser("Missing 'FieldDefinitions' element for ContentTypeCreate."); } if (!is_array($data['FieldDefinitions']) || !array_key_exists('FieldDefinition', $data['FieldDefinitions']) || !is_array($data['FieldDefinitions']['FieldDefinition'])) { throw new Exceptions\Parser("Invalid 'FieldDefinitions' element for ContentTypeCreate."); } // With no field definitions given and when ContentType is immediately published we must return HTTP 400 BadRequest, // instead of relying on service to throw InvalidArgumentException if (isset($data['__publish']) && $data['__publish'] === true && empty($data['FieldDefinitions']['FieldDefinition'])) { throw new Exceptions\Parser('ContentTypeCreate should provide at least one field definition.'); } foreach ($data['FieldDefinitions']['FieldDefinition'] as $fieldDefinitionData) { if (!is_array($fieldDefinitionData)) { throw new Exceptions\Parser("Invalid 'FieldDefinition' element for ContentTypeCreate."); } $contentTypeCreateStruct->addFieldDefinition($this->fieldDefinitionCreateParser->parse($fieldDefinitionData, $parsingDispatcher)); } return $contentTypeCreateStruct; }