Skip to content

Commit

Permalink
Added cache for RelationList, Added deprecated and @throws for loadRe…
Browse files Browse the repository at this point in the history
…lations in contracts
  • Loading branch information
mateuszdebinski committed Apr 19, 2024
1 parent 8c1e042 commit c152fb4
Show file tree
Hide file tree
Showing 8 changed files with 84 additions and 21 deletions.
2 changes: 2 additions & 0 deletions src/contracts/Persistence/Content/Handler.php
Original file line number Diff line number Diff line change
Expand Up @@ -283,6 +283,8 @@ public function removeRelation($relationId, $type, ?int $destinationContentId =
/**
* Loads relations from $sourceContentId. Optionally, loads only those with $type and $sourceContentVersionNo.
*
* @deprecated since 4.5, use loadRelationList() instead.
*
* @param mixed $sourceContentId Source Content ID
* @param mixed|null $sourceContentVersionNo Source Content Version, null if not specified
* @param int|null $type {@see \Ibexa\Contracts\Core\Repository\Values\Content\Relation::COMMON,
Expand Down
8 changes: 7 additions & 1 deletion src/contracts/Repository/ContentService.php
Original file line number Diff line number Diff line change
Expand Up @@ -400,7 +400,7 @@ public function copyContent(ContentInfo $contentInfo, LocationCreateStruct $dest
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\UnauthorizedException if the user is not allowed to read this version
*
* @deprecated since 4.5, use loadRelationList().
* @deprecated since 4.5, use loadRelationList() instead.
*
* @return \Ibexa\Contracts\Core\Repository\Values\Content\Relation[]
*/
Expand All @@ -411,6 +411,9 @@ public function loadRelations(VersionInfo $versionInfo): iterable;
*
* If the user is not allowed to read specific version then UnauthorizedRelationListItem is returned
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\BadStateException
*
* @see \Ibexa\Contracts\Core\Repository\Values\Content\RelationList\Item\UnauthorizedRelationListItem
*/
public function loadRelationList(
Expand All @@ -421,6 +424,9 @@ public function loadRelationList(

/**
* Counts all outgoing relations for the given version.
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\BadStateException
*/
public function countRelations(VersionInfo $versionInfo): int;

Expand Down
65 changes: 55 additions & 10 deletions src/lib/Persistence/Cache/ContentHandler.php
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ class ContentHandler extends AbstractInMemoryPersistenceHandler implements Conte
private const CONTENT_RELATIONS_COUNT_WITH_TYPE_IDENTIFIER = 'content_relations_count_with_type';
private const CONTENT_RELATIONS_COUNT_WITH_TYPE_AND_VERSION_IDENTIFIER = 'content_relations_count_with_type_and_version';
private const CONTENT_RELATIONS_COUNT_WITH_VERSION_IDENTIFIER = 'content_relations_count_with_version';
private const CONTENT_RELATIONS_LIST_IDENTIFIER = 'content_relations_list';
private const CONTENT_RELATIONS_LIST_WITH_TYPE_IDENTIFIER = 'content_relations_list_with_type';
private const CONTENT_RELATIONS_LIST_WITH_TYPE_AND_VERSION_IDENTIFIER = 'content_relations_list_with_type_and_version';
private const CONTENT_RELATIONS_LIST_WITH_VERSION_IDENTIFIER = 'content_relations_list_with_version';
private const CONTENT_REVERSE_RELATIONS_COUNT_IDENTIFIER = 'content_reverse_relations_count';
private const RELATION_IDENTIFIER = 'relation';

Expand Down Expand Up @@ -546,12 +550,12 @@ public function countRelations(int $sourceContentId, ?int $sourceContentVersionN
);

if ($cacheItem->isHit()) {
$this->logger->logCacheHit(['content' => $sourceContentId, 'version' => $sourceContentVersionNo]);
$this->logger->logCacheHit(['content' => $sourceContentId, 'version' => $sourceContentVersionNo, 'type' => $type]);

return $cacheItem->get();
}

$this->logger->logCacheMiss(['content' => $sourceContentId, 'version' => $sourceContentVersionNo]);
$this->logger->logCacheMiss(['content' => $sourceContentId, 'version' => $sourceContentVersionNo, 'type' => $type]);
$relationsCount = $this->persistenceHandler->contentHandler()->countRelations(
$sourceContentId,
$sourceContentVersionNo,
Expand All @@ -571,31 +575,72 @@ public function countRelations(int $sourceContentId, ?int $sourceContentVersionN
return $relationsCount;
}

/**
* {@inheritdoc}
*/
public function loadRelationList(
int $sourceContentId,
int $limit,
int $offset = 0,
?int $sourceContentVersionNo = null,
?int $type = null
): array {
$this->logger->logCall(__METHOD__, [
$values = [$sourceContentId, $limit, $offset];

if ($sourceContentVersionNo === null && $type !== null) {
$patternName = self::CONTENT_RELATIONS_LIST_WITH_TYPE_IDENTIFIER;
$values[] = $type;
} elseif ($sourceContentVersionNo !== null && $type === null) {
$patternName = self::CONTENT_RELATIONS_LIST_WITH_VERSION_IDENTIFIER;
$values[] = $sourceContentVersionNo;
} elseif ($sourceContentVersionNo !== null && $type !== null) {
$patternName = self::CONTENT_RELATIONS_LIST_WITH_TYPE_AND_VERSION_IDENTIFIER;
$values = array_merge($values, [$type, $sourceContentVersionNo]);
} else {
$patternName = self::CONTENT_RELATIONS_LIST_IDENTIFIER;
}

$cacheItem = $this->cache->getItem(
$this->cacheIdentifierGenerator->generateKey(
$patternName,
$values,
true
)
);

$logCacheArguments = [
'content' => $sourceContentId,
'version' => $sourceContentVersionNo,
'offset' => $offset,
'limit' => $limit,
'type' => $type,
]);
'limit' => $limit,
'offset' => $offset,
];

if ($cacheItem->isHit()) {
$this->logger->logCacheHit($logCacheArguments);

return $cacheItem->get();
}

$this->logger->logCacheMiss($logCacheArguments);

return $this->persistenceHandler->contentHandler()->loadRelationList(
$relationList = $this->persistenceHandler->contentHandler()->loadRelationList(
$sourceContentId,
$limit,
$offset,
$sourceContentVersionNo,
$type
);

$cacheItem->set($relationList);
$tags = [
$this->cacheIdentifierGenerator->generateTag(
self::CONTENT_IDENTIFIER,
[$sourceContentId]
),
];

$cacheItem->tag($tags);
$this->cache->save($cacheItem);

return $relationList;
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1435,10 +1435,10 @@ private function prepareRelationQuery(
->innerJoin(
'l',
self::CONTENT_ITEM_TABLE,
'ezcontentobject_to',
'c_to',
$expr->and(
'l.to_contentobject_id = ezcontentobject_to.id',
'ezcontentobject_to.status = :status'
'l.to_contentobject_id = c_to.id',
'c_to.status = :status'
)
)
->where(
Expand All @@ -1460,7 +1460,7 @@ private function prepareRelationQuery(
// from published version only
$query
->innerJoin(
'ezcontentobject_to',
'c_to',
self::CONTENT_ITEM_TABLE,
'c',
$expr->and(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -404,9 +404,6 @@ public function countRelations(
}
}

/**
* {@inheritdoc}
*/
public function listRelations(
int $contentId,
int $limit,
Expand Down
3 changes: 0 additions & 3 deletions src/lib/Persistence/Legacy/Content/Handler.php
Original file line number Diff line number Diff line change
Expand Up @@ -827,9 +827,6 @@ public function countRelations(int $sourceContentId, ?int $sourceContentVersionN
return $this->contentGateway->countRelations($sourceContentId, $sourceContentVersionNo, $type);
}

/**
* {@inheritdoc}
*/
public function loadRelationList(
int $sourceContentId,
int $limit,
Expand Down
4 changes: 4 additions & 0 deletions src/lib/Resources/settings/storage_engines/cache.yml
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,10 @@ parameters:
content_relations_count_with_type: 'crc-%%s-t-%%s'
content_relations_count_with_type_and_version: 'crc-%%s-t-%%s-v-%%s'
content_relations_count_with_version: 'crc-%%s-v-%%s'
content_relations_list: 'crl-%%s-l-%%s-o-%%s'
content_relations_list_with_type: 'crl-%%s-l-%%s-o-%%s-t-%%s'
content_relations_list_with_type_and_version: 'crl-%%s-l-%%s-o-%%s-t-%%s-v-%%s'
content_relations_list_with_version: 'crl-%%s-l-%%s-o-%%s-v-%%s'
content_reverse_relations_count: 'crrc-%s'
content_version_info: 'cvi-%s'
content_version_list: 'c-%s-vl'
Expand Down
12 changes: 12 additions & 0 deletions tests/lib/Persistence/Cache/ContentHandlerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
use Ibexa\Contracts\Core\Persistence\Content\CreateStruct;
use Ibexa\Contracts\Core\Persistence\Content\Handler as SPIContentHandler;
use Ibexa\Contracts\Core\Persistence\Content\MetadataUpdateStruct;
use Ibexa\Contracts\Core\Persistence\Content\Relation;
use Ibexa\Contracts\Core\Persistence\Content\Relation as SPIRelation;
use Ibexa\Contracts\Core\Persistence\Content\Relation\CreateStruct as RelationCreateStruct;
use Ibexa\Contracts\Core\Persistence\Content\UpdateStruct;
Expand Down Expand Up @@ -82,6 +83,13 @@ public function providerForCachedLoadMethodsHit(): array
$info = new ContentInfo(['id' => 2]);
$version = new VersionInfo(['versionNo' => 1, 'contentInfo' => $info]);
$content = new Content(['fields' => [], 'versionInfo' => $version]);
$relation = new Relation();
$relation->id = 1;
$relation->sourceContentId = 2;
$relation->sourceContentVersionNo = 2;
$relation->destinationContentId = 1;
$relation->type = 1;
$relationList[1] = $relation;

// string $method, array $arguments, string $key, array? $tagGeneratingArguments, array? $tagGeneratingResults, array? $keyGeneratingArguments, array? $keyGeneratingResults, mixed? $data, bool $multi = false, array $additionalCalls
return [
Expand All @@ -90,6 +98,10 @@ public function providerForCachedLoadMethodsHit(): array
['countRelations', [2, 2], 'ibx-crc-2-v-2', null, null, [['content_relations_count_with_version', [2, 2], true]], ['ibx-crc-2-v-2'], 10],
['countRelations', [2, null, 1], 'ibx-crc-2-t-1', null, null, [['content_relations_count_with_type', [2, 1], true]], ['ibx-crc-2-t-1'], 10],
['countRelations', [2, 2, 1], 'ibx-crc-2-t-1-v-2', null, null, [['content_relations_count_with_type_and_version', [2, 1, 2], true]], ['ibx-crc-2-t-1-v-2'], 10],
['loadRelationList', [2, 1, 0], 'ibx-crl-2-l-1-o-0', null, null, [['content_relations_list', [2, 1, 0], true]], ['ibx-crl-2-l-1-o-0'], $relationList],
['loadRelationList', [2, 1, 0, 2], 'ibx-crl-2-l-1-o-0-v-2', null, null, [['content_relations_list_with_version', [2, 1, 0, 2], true]], ['ibx-crl-2-l-1-o-0-v-2'], $relationList],
['loadRelationList', [2, 1, 0, null, 1], 'ibx-crl-2-l-1-o-0-t-1', null, null, [['content_relations_list_with_type', [2, 1, 0, 1], true]], ['ibx-crl-2-l-1-o-0-t-1'], $relationList],
['loadRelationList', [2, 1, 0, 2, 1], 'ibx-crl-2-l-1-o-0-t-1-v-2', null, null, [['content_relations_list_with_type_and_version', [2, 1, 0, 1, 2], true]], ['ibx-crl-2-l-1-o-0-t-1-v-2'], $relationList],
['load', [2, 1], 'ibx-c-2-1-' . ContentHandler::ALL_TRANSLATIONS_KEY, null, null, [['content', [], true]], ['ibx-c'], $content],
['load', [2, 1, ['eng-GB', 'eng-US']], 'ibx-c-2-1-eng-GB|eng-US', null, null, [['content', [], true]], ['ibx-c'], $content],
['load', [2], 'ibx-c-2-' . ContentHandler::ALL_TRANSLATIONS_KEY, null, null, [['content', [], true]], ['ibx-c'], $content],
Expand Down

0 comments on commit c152fb4

Please sign in to comment.