Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enhance PHPDoc #463

Open
wants to merge 32 commits into
base: 4.6
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
4b52f8b
Enhance `DateMetadata::TRASHED` phpdoc
adriendupuis Dec 6, 2024
072cfa6
Enhance `Criterion::getSpecifications()` phpdoc
adriendupuis Dec 10, 2024
0a7e0de
Enhance `Specifications` phpdoc
adriendupuis Dec 10, 2024
53a474e
Capable.php: Fix phpdoc summary
adriendupuis Dec 11, 2024
8a4c287
VersionBuilder.php: Fix phpdoc summary, arrays and self usages
adriendupuis Dec 11, 2024
45960d5
ConstraintViolationAdapter's PHPDoc: Add a summary, reword description
adriendupuis Dec 12, 2024
decfe12
Enhance `Criterion::getSpecifications()` phpdoc
adriendupuis Dec 12, 2024
053071c
Enhance `DateMetadata::TRASHED` phpdoc
adriendupuis Dec 12, 2024
8163ec9
Enhance `DateMetadata` phpdoc
adriendupuis Dec 12, 2024
9a28e14
Enhance `UserMetadata` phpdoc
adriendupuis Dec 12, 2024
ad9ea00
Enhance `DateMetadata` phpdoc
adriendupuis Dec 12, 2024
8f1ecce
Enhance `Capable` phpdoc
adriendupuis Dec 12, 2024
e7e9ec0
Enhance `Criterion` phpdoc
adriendupuis Dec 12, 2024
97ac58f
Enhance `UserMetadata` phpdoc (fix typo)
adriendupuis Dec 12, 2024
9f1aabd
Enhance `UserMetadata` phpdoc
adriendupuis Dec 12, 2024
7b33e26
Enhance `FieldType\Generic\Type` phpdoc
adriendupuis Dec 13, 2024
1799d56
Enhance `Limitation\Type` phpdoc
adriendupuis Dec 13, 2024
b4e1ad3
LocationService: Fix count() phpdoc
adriendupuis Dec 16, 2024
1da7437
Enhance `LocationService` phpdoc
adriendupuis Dec 16, 2024
879e59a
Enhance `Location` phpdoc
adriendupuis Dec 16, 2024
c59a8a9
Enhance `Location` phpdoc: @deprecated can't be nested nor used inline.
adriendupuis Dec 16, 2024
ccbff09
Enhance `Location` phpdoc: Add an internal link
adriendupuis Dec 16, 2024
ee31d5a
Enhance `ValueObject` phpdoc
adriendupuis Dec 16, 2024
ad70f77
Enhance `FieldType\Generic\Type` phpdoc: Fix internal links
adriendupuis Dec 17, 2024
bfd1697
Enhance `FieldType\FieldType` phpdoc: Fix code blocks
adriendupuis Dec 17, 2024
44aede1
Values\Content\Location: Set protected/read-only property as internal
adriendupuis Dec 19, 2024
1cdc9c4
Revert "Values\Content\Location: Set protected/read-only property as …
adriendupuis Dec 19, 2024
bd4475f
Revert src/lib/Limitation/
adriendupuis Dec 20, 2024
8aadd04
`Limitation\Type`: type array keys
adriendupuis Dec 20, 2024
88964b1
ValueObject: Format desc
adriendupuis Dec 22, 2024
259f236
ValueObject: Format desc
adriendupuis Dec 22, 2024
931b98e
ValueObject: Format desc
adriendupuis Dec 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,10 @@
use Symfony\Component\Validator\ConstraintViolationInterface;

/**
* {@see \Symfony\Component\Validator\ConstraintViolationInterface} to
* {@see \Ibexa\Contracts\Core\FieldType\ValidationError} adapter.
* Constraint violation validation error.
*
* Adapts {@see \Symfony\Component\Validator\ConstraintViolationInterface} to
* {@see \Ibexa\Contracts\Core\FieldType\ValidationError}.
*/
final class ConstraintViolationAdapter implements ValidationErrorInterface
{
Expand Down
22 changes: 13 additions & 9 deletions src/contracts/Limitation/Target/Builder/VersionBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@
use Ibexa\Core\Base\Exceptions\InvalidArgumentException;

/**
* Version builder.
*
* Builder of {@see \Ibexa\Contracts\Core\Limitation\Target\Version} instance.
*/
final class VersionBuilder
Expand All @@ -28,6 +30,8 @@ public function build(): Target\Version

/**
* @param \Ibexa\Contracts\Core\Repository\Values\Content\Field[] $updatedFields
*
* @return VersionBuilder
*/
public function updateFields(array $updatedFields): self
{
Expand All @@ -41,7 +45,7 @@ public function updateFields(array $updatedFields): self
*
* @param array $languageCodes
*
* @return self
* @return VersionBuilder
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
*/
Expand All @@ -61,9 +65,9 @@ public function translateToAnyLanguageOf(array $languageCodes): self
/**
* Set intent to create Content from unspecified (yet) content type, any from the given list.
*
* @param int[] $contentTypeIds
* @param array<int, int> $contentTypeIds
*
* @return self
* @return VersionBuilder
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
*/
Expand All @@ -83,13 +87,13 @@ public function createFromAnyContentTypeOf(array $contentTypeIds): self
/**
* Set intent to change Version status.
*
* Supported: <code>VersionInfo::STATUS_DRAFT, VersionInfo::STATUS_PUBLISHED, VersionInfo::STATUS_ARCHIVED</code>
* Supported: {@see \Ibexa\Contracts\Core\Repository\Values\Content\VersionInfo::STATUS_DRAFT}, {@see \Ibexa\Contracts\Core\Repository\Values\Content\VersionInfo::STATUS_PUBLISHED}, {@see \Ibexa\Contracts\Core\Repository\Values\Content\VersionInfo::STATUS_ARCHIVED}
*
* @see \Ibexa\Contracts\Core\Repository\Values\Content\VersionInfo
*
* @param int $status
*
* @return self
* @return VersionBuilder
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
*/
Expand All @@ -114,9 +118,9 @@ public function changeStatusTo(int $status): self
* Set intent to update Content Version Fields.
*
* @param string|null $initialLanguageCode
* @param \Ibexa\Contracts\Core\Repository\Values\Content\Field[] $fields
* @param array<int, \Ibexa\Contracts\Core\Repository\Values\Content\Field> $fields
*
* @return self
* @return VersionBuilder
*/
public function updateFieldsTo(?string $initialLanguageCode, array $fields): self
{
Expand All @@ -138,9 +142,9 @@ static function (Field $field) {
/**
* Set intent to publish, to specified translations, all from the given list.
*
* @param string[] $languageCodes
* @param array<int, string> $languageCodes
*
* @return self
* @return VersionBuilder
*
* @throws \Ibexa\Contracts\Core\Repository\Exceptions\InvalidArgumentException
*/
Expand Down
26 changes: 14 additions & 12 deletions src/contracts/Repository/Values/Content/Query/Criterion.php
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,15 @@ abstract class Criterion implements CriterionInterface
public $valueData;

/**
* Performs operator validation based on the Criterion specifications returned by {@see getSpecifications()}.
* Creates a Criterion.
*
* Performs operator validation based on the Criterion specifications returned by {@see Criterion::getSpecifications()}.
*
* @param string|null $target The target the Criterion applies to: metadata identifier, field identifier...
* @param string|null $operator
* The operator the Criterion uses. If null is given, will default to Operator::IN if $value is an array,
* Operator::EQ if it is not.
* @param scalar[]|scalar $value
* The operator the Criterion uses. If null is given, will default to {@see Operator::IN} if $value is an array,
* {@see Operator::EQ} if it isn't.
* @param array<int, scalar>|scalar $value
* @param \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion\Value|null $valueData
*
* @todo Add a dedicated exception
Expand Down Expand Up @@ -118,12 +120,12 @@ public function __construct(?string $target, ?string $operator, $value, ?Value $
*
* Returns the combination of the Criterion's supported operator/value,
* as an array of {@see \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion\Operator\Specifications} objects
* - Operator is one supported Operator, as an Operator::* constant
* - ValueType is the type of input value this operator requires, either array or single
* - SupportedTypes is an array of types the operator will accept
* - ValueCountLimitation is an integer saying how many values are expected.
* - {@see Specifications::$operator} is a supported {@see Operator} constant.
* - {@see Specifications::$valueFormat} is the type of input value this operator requires, either array ({@see Specifications::FORMAT_ARRAY}) or single ({@see Specifications::FORMAT_SINGLE}).
* - {@see Specifications::$valueTypes} are bitwise flags of types the operator will accept ({@see Specifications::TYPE_BOOLEAN}, {@see Specifications::TYPE_INTEGER}, and/or {@see Specifications::TYPE_STRING}).
* - {@see Specifications::$valueCount} is an integer saying how many values are expected.
*
* <code>
* ```
* // IN and EQ are supported
* return [
* // The EQ operator expects a single value, either as an integer or a string
Expand All @@ -139,16 +141,16 @@ public function __construct(?string $target, ?string $operator, $value, ?Value $
* Specifications::TYPE_INTEGER | Specifications::TYPE_STRING
* )
* ]
* </code>
* ```
*
* @return \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion\Operator\Specifications[]
* @return array<int, \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion\Operator\Specifications>
*/
abstract public function getSpecifications(): array;

/**
* Returns a callback that checks the values types depending on the operator specifications.
*
* @param int $valueTypes The accepted values, as a bit field of Specifications::TYPE_* constants
* @param int $valueTypes The accepted values, as a bit field of {@see Specifications}::TYPE_* constants
*
* @return callable
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,19 +18,19 @@
* A criterion that matches content based on one of the date metadata (created or modified).
*
* Supported Operators:
* EQ, IN: matches content whose date is or belongs to a list of timestamps
* GT, GTE: matches content whose date is greater than/greater than or equals the given timestamp
* LT, LTE: matches content whose date is lower than/lower than or equals the given timestamp
* BETWEEN: matches content whose date is between (included) the TWO given timestamps
* - {@see Operator::EQ EQ}, {@see Operator::IN IN}: matches content whose date is or belongs to a list of timestamps.
* - {@see Operator::GT GT}, {@see Operator::GTE GTE}: matches content whose date is greater than/greater than or equals the given timestamp.
* - {@see Operator::LT LT}, {@see Operator::LTE LTE}: matches content whose date is lower than/lower than or equals the given timestamp.
* - {@see Operator::BETWEEN BETWEEN}: matches content whose date is between TWO (included) given timestamps.
*
* Example:
* <code>
* The following example is a criterion for contents created yesterday or today:
* ```
* $createdCriterion = new Criterion\DateMetadata(
* Criterion\DateMetadata::CREATED,
* Operator::GTE,
* strtotime( 'yesterday' )
* Criterion\Operator::GTE,
* strtotime('yesterday')
* );
* </code>
* ```
*/
class DateMetadata extends Criterion implements TrashCriterion, FilteringCriterion
{
Expand All @@ -41,7 +41,9 @@ class DateMetadata extends Criterion implements TrashCriterion, FilteringCriteri
public const PUBLISHED = 'published';

/**
* (applies to TrashService::findTrashItems only).
* To search for contents based on when they have been sent to trash.
*
* Applies to {@see \Ibexa\Contracts\Core\Repository\TrashService::findTrashItems()} only.
*/
public const TRASHED = 'trashed';

Expand All @@ -53,12 +55,12 @@ class DateMetadata extends Criterion implements TrashCriterion, FilteringCriteri
];

/**
* Creates a new DateMetadata criterion on $metadata.
* Creates a new DateMetadata criterion.
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't find such property in the contracts namespace. (I may haven't look well enough in the namespace.) It might not be in this contracts namespace, and hidden by abstraction. If no link can be made to it, it probably don't worth being mentioned.

*
* @throws \InvalidArgumentException If target is unknown
*
* @param string $target One of DateMetadata::CREATED, DateMetadata::MODIFIED or DateMetadata::TRASHED (applies to TrashService::findTrashItems only)
* @param string $operator One of the Operator constants
* @param string $target One of {@see DateMetadata::CREATED}, {@see DateMetadata::MODIFIED}, or {@see DateMetadata::TRASHED} (applies to {@see \Ibexa\Contracts\Core\Repository\TrashService::findTrashItems()} only)
* @param string $operator One of the {@see Operator} constants
* @param mixed $value The match value, either as an array of as a single value, depending on the operator
*/
public function __construct(string $target, string $operator, $value)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,7 @@
/**
* This class is used by Criteria to describe which operators they support.
*
* Instances of this class are returned in an array by the Criterion::getSpecifications() method
*
* @see \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion::getSpecifications()
* Instances of this class are returned in an array by the {@see \Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion::getSpecifications()} method.
*/
class Specifications
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,16 @@
* group, modifier).
*
* Supported Operators:
* EQ, IN: Matches the provided user ID(s) against the user IDs in the database
* - {@see Operator::EQ EQ}, {@see Operator::IN}: Matches the provided user ID(s) against the user IDs in the database.
*
* Example:
* <code>
* The following example is a criterion for contents owned by a user with ID 10 or 14:
* ```
* $createdCriterion = new Criterion\UserMetadata(
* Criterion\UserMetadata::OWNER,
* Operator::IN,
* array( 10, 14 )
* Criterion\Operator::IN,
* [10, 14]
* );
* </code>
* ```
*/
class UserMetadata extends Criterion implements TrashCriterion, FilteringCriterion
{
Expand All @@ -48,13 +48,13 @@ class UserMetadata extends Criterion implements TrashCriterion, FilteringCriteri
public const MODIFIER = 'modifier';

/**
* Creates a new UserMetadata criterion on $metadata.
* Creates a new UserMetadata criterion.
*
* @throws \InvalidArgumentException If target is unknown
*
* @param string $target One of UserMetadata::OWNER, UserMetadata::GROUP or UserMetadata::MODIFIED
* @param string|null $operator The operator the Criterion uses. If null is given, will default to Operator::IN if $value is an array, Operator::EQ if it is not.
* @param mixed $value The match value, either as an array of as a single value, depending on the operator
* @param string $target One of {@see UserMetadata::OWNER}, {@see UserMetadata::GROUP}, or {@see UserMetadata::MODIFIER}.
* @param string|null $operator The operator the Criterion uses. If null is given, will default to {@see Operator::IN} if $value is an array, {@see Operator::EQ} if it isn't.
* @param mixed $value The match value, either as an array of as a single value, depending on the operator.
*/
public function __construct(string $target, ?string $operator, $value)
{
Expand Down
4 changes: 3 additions & 1 deletion src/contracts/Search/Capable.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@
namespace Ibexa\Contracts\Core\Search;

/**
* Capability interface for search engines.
*
* Capability interface for search engines needed for {@see \Ibexa\Contracts\Core\Repository\SearchService::supports()}.
*
* @since 6.12 And ported to 6.7.6 for search engine forward compatibility.
Expand All @@ -18,7 +20,7 @@ interface Capable
/**
* Query for supported capability of currently configured search engine.
*
* @param int $capabilityFlag One of \Ibexa\Contracts\Core\Repository\SearchService::CAPABILITY_* constants.
* @param int $capabilityFlag One of {@see \Ibexa\Contracts\Core\Repository\SearchService}::CAPABILITY_* constants.
*
* @return bool
*/
Expand Down
Loading