PHP API¶
The public PHP API enables you to interact with Ibexa DXP's Repository and content model from your PHP code.
You can use it to create, read, update, manage, and delete all objects available in Ibexa DXP, namely content and related objects such as sections, locations, content types, or languages.
The PHP API is built on top of a layered architecture, including a persistence SPI that abstracts storage. Using the API ensures that your code is forward compatible with future releases based on other storage engines.
Using API services¶
The API provides access to content, user, content types, and other features through various services.
The full list of available services covers:
- BatchOrderService
- CorporateAccountService (recommended for company creation)
- CompanyService
- ContentService
- ContentTypeService
- FieldTypeService
- InvitationService
- LanguageService
- LocationService
- MemberService
- NotificationService
- ObjectStateService
- RoleService
- SearchService
- SectionService
- ShippingAddressService
- SpreadsheetProcessorInterface
- TaxonomyService
- TranslationService
- TrashService
- URLAliasService
- URLService
- URLWildcardService
- UserPreferenceService
- UserService
You can access the PHP API by injecting relevant services into your code:
- By using auto-wiring, and the service classname in the
Ibexa\Contracts
namespace (seebin/console debug:autowiring | grep Ibexa.Contracts
). - By using service parameters, and service aliases (see
bin/console debug:autowiring | grep ibexa.api
). - By using the repository's
get[ServiceName]()
methods, for example,Repository::getContentService()
, orgetUserService()
. (Prefer injecting several Repository's dedicated services instead of the whole Repository if the Repository itself isn't needed.)
Caution
The PHP API's services can be accessed with Ibexa\Bundle\Core\Controller::getRepository()
by extending it from a custom controller, but such approach isn't recommended, and you should prefer dependency injection.
Value objects¶
The services provide interaction with read-only value objects from the Ibexa\Contracts\Core\Repository\Values
namespace.
Those objects are divided into sub-namespaces, such as Content
, User
or ObjectState
.
Each sub-namespace contains a set of value objects,
such as Content\Content
or User\Role
.
Value objects come with their own properties, such as $content->id
or $location->hidden
, and with methods that provide access to more related information, such as Content\Relation::getSourceContentInfo()
or User\Role::getPolicies()
.
Creating and updating objects¶
Value objects fetch data from the repository and are read-only.
To create and modify repository values, use data structures, such as ContentService::newContentCreateStruct()
or LocationService::newLocationUpdateStruct()
.
Value info objects¶
Some complex value objects have an Info
counterpart, for example ContentInfo
for Content
.
These objects provide you with lower-level information.
For instance, ContentInfo
contains currentVersionNo
or remoteId
, while Content
enables you to retrieve fields, content type, or previous versions.
Note
The public PHP API value objects should not be serialized.
Serialization of value objects, for example, Ibexa\Contracts\Core\Repository\Values\Content\ContentInfo
/ Ibexa\Contracts\Core\Repository\Values\Content\VersionInfo
or Ibexa\Contracts\Core\Repository\Values\Content\Location
results in memory limit exceeded error.
Authentication¶
One of the responsibilities of the repository is user authentication. Every action is executed as a user.
When you use the PHP API, authentication is performed in three ways:
Back office authentication¶
When actions are performed through the back office, they're executed as the logged-in user. This user's permissions affects the behavior of the repository. The user may, for example, not be allowed to create content, or view a particular section.
Using sudo()
¶
To skip permission checks, you can use the sudo()
method.
It allows API execution to be performed with full access, sand-boxed.
You can use this method to perform an action that the current user doesn't have permissions for.
For example, to hide a Location, use:
1 2 3 4 5 6 7 |
|
Setting the repository user¶
In a command line script, the repository runs as if executed by the anonymous user.
While using sudo()
is the recommended option, you can also set the current user to a user with necessary permissions to achieve the same effect.
To identify as a different user, you need to use the UserService
together with PermissionResolver
(in the example admin
is the login of the administrator user):
1 2 |
|
Tip
Ibexa\Contracts\Core\Repository\PermissionService
can be injected to have a Service which provides both PermissionResolver
and PermissionCriterionResolver
.
It supports auto-wiring.
This isn't required in template functions or controller code, as the HTTP layer takes care of identifying the user, and automatically sets it in the repository.
If you want to identify a user with their credentials instead, provide them in the following way:
1 2 |
|
Exception handling¶
PHP API uses Exceptions to handle errors. Each API method may throw different exceptions, depending on what it does.
It's good practice to cover every exception you expect to happen.
For example if you're using a command which takes the content ID as a parameter, the ID may either not exist, or the referenced content item may not be visible to the user.
Both cases should be covered with error messages:
1 2 3 4 5 6 7 |
|
Service container¶
Ibexa DXP uses the Symfony service container for dependency resolution.
Symfony dependency injection ensures that any required services are available in your custom code (for example, controllers) when you inject them into the constructor.
Symfony service container uses service tags to dedicate services to a specific purpose. They're usually used for extension points.
Ibexa DXP uses service tags to expose multiple features.
For example, field types are tagged ibexa.field_type
.
Tip
For a list of all service tags exposed by Symfony, see its reference documentation.