本文整理匯總了PHP中eZ\Publish\SPI\Persistence\Content\Type\Handler::updateFieldDefinition方法的典型用法代碼示例。如果您正苦於以下問題:PHP Handler::updateFieldDefinition方法的具體用法?PHP Handler::updateFieldDefinition怎麽用?PHP Handler::updateFieldDefinition使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類eZ\Publish\SPI\Persistence\Content\Type\Handler
的用法示例。
在下文中一共展示了Handler::updateFieldDefinition方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: updateFieldDefinition
/**
* Update a field definition
*
* @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException If the field id in the update struct is not found or does not belong to the content type
* If the given identifier is used in an existing field of the given content type
* @throws \eZ\Publish\API\Repository\Exceptions\UnauthorizedException if the user is not allowed to edit a content type
*
* @param \eZ\Publish\API\Repository\Values\ContentType\ContentTypeDraft $contentTypeDraft the content type draft
* @param \eZ\Publish\API\Repository\Values\ContentType\FieldDefinition $fieldDefinition the field definition which should be updated
* @param \eZ\Publish\API\Repository\Values\ContentType\FieldDefinitionUpdateStruct $fieldDefinitionUpdateStruct
*/
public function updateFieldDefinition(APIContentTypeDraft $contentTypeDraft, APIFieldDefinition $fieldDefinition, FieldDefinitionUpdateStruct $fieldDefinitionUpdateStruct)
{
if ($this->repository->hasAccess('class', 'update') !== true) {
throw new UnauthorizedException('ContentType', 'update');
}
$loadedContentTypeDraft = $this->loadContentTypeDraft($contentTypeDraft->id);
$foundFieldId = false;
foreach ($loadedContentTypeDraft->fieldDefinitions as $existingFieldDefinition) {
if ($existingFieldDefinition->id == $fieldDefinition->id) {
$foundFieldId = true;
} else {
if ($existingFieldDefinition->identifier == $fieldDefinitionUpdateStruct->identifier) {
throw new InvalidArgumentException("\$fieldDefinitionUpdateStruct", "Another FieldDefinition with identifier '{$fieldDefinitionUpdateStruct->identifier}' exists in the ContentType");
}
}
}
if (!$foundFieldId) {
throw new InvalidArgumentException("\$fieldDefinition", "The given FieldDefinition does not belong to the ContentType");
}
$spiFieldDefinitionUpdateStruct = $this->buildSPIFieldDefinitionUpdate($fieldDefinitionUpdateStruct, $fieldDefinition);
$this->repository->beginTransaction();
try {
$this->contentTypeHandler->updateFieldDefinition($contentTypeDraft->id, SPIContentType::STATUS_DRAFT, $spiFieldDefinitionUpdateStruct);
$this->repository->commit();
} catch (Exception $e) {
$this->repository->rollback();
throw $e;
}
}
示例2: updateFieldDefinition
/**
* This method updates the given $fieldDefinition on a Type.
*
* This method creates a new status of the Type with the updated
* $fieldDefinition. It does not update existing content objects depending
* on the
* field (default) values.
*
* @param mixed $contentTypeId
* @param \eZ\Publish\SPI\Persistence\Content\Type\FieldDefinition $fieldDefinition
* @return void
*/
public function updateFieldDefinition($contentTypeId, $status, FieldDefinition $fieldDefinition)
{
$this->clearCache();
return $this->innerHandler->updateFieldDefinition($contentTypeId, $status, $fieldDefinition);
}