The international conference on the API Platform Framework
Lear more about the event, register for the conference, and get ready for two days of inspiration, ideas, and knowledge-sharing with our incredible lineup of renowned specialists and advocates.
This edition is shaping up to be our biggest yet — secure your seat now at the best price before we sell out!
JSON-LD allows to define classes and properties of your API with open vocabularies such as Schema.org and Good Relations.
API Platform provides attributes usable on PHP classes and properties for specifying a related external IRI.
<?php
// api/src/ApiResource/Book.php with Symfony or app/ApiResource/Book.php with Laravel
namespace App\ApiResource;
use ApiPlatform\Metadata\ApiProperty;
use ApiPlatform\Metadata\ApiResource;
#[ApiResource(types: ['https://schema.org/Book'])]
class Book
{
// ...
#[ApiProperty(types: ['https://schema.org/name'])]
public $name;
// ...
}
The generated JSON for products and the related context document will now use external IRIs according to the specified attributes:
GET /books/22
{
"@context": "/contexts/Book",
"@id": "/books/22",
"@type": "https://schema.org/Book",
"name": "My awesome book"
}
GET /contexts/Book
{
"@context": {
"@vocab": "http://example.com/apidoc#",
"hydra": "http://www.w3.org/ns/hydra/core#",
"name": "https://schema.org/name"
}
}
An extended list of existing open vocabularies is available on the Linked Open Vocabularies (LOV) database.
By default, when using validations API Platform will try to define known Schema.org
types as IRIs for your properties if you did not provide any in your #[ApiProperty]
attributes.
Symfony built-in mapping is:
Constraints | Schema.org type |
---|---|
Symfony\Component\Validator\Constraints\Url | https://schema.org/url |
Symfony\Component\Validator\Constraints\Email | https://schema.org/email |
Symfony\Component\Validator\Constraints\Uuid | https://schema.org/identifier |
Symfony\Component\Validator\Constraints\CardScheme | https://schema.org/identifier |
Symfony\Component\Validator\Constraints\Bic | https://schema.org/identifier |
Symfony\Component\Validator\Constraints\Iban | https://schema.org/identifier |
Symfony\Component\Validator\Constraints\Date | https://schema.org/Date |
Symfony\Component\Validator\Constraints\DateTime | https://schema.org/DateTime |
Symfony\Component\Validator\Constraints\Time | https://schema.org/Time |
Symfony\Component\Validator\Constraints\Image | https://schema.org/image |
Symfony\Component\Validator\Constraints\File | https://schema.org/MediaObject |
Symfony\Component\Validator\Constraints\Currency | https://schema.org/priceCurrency |
Symfony\Component\Validator\Constraints\Isbn | https://schema.org/isbn |
Symfony\Component\Validator\Constraints\Issn | https://schema.org/issn |
Laravel built-in mapping is:
Laravel Validation Rule | Schema.org Type |
---|---|
url | https://schema.org/url |
email | https://schema.org/email |
uuid | https://schema.org/identifier |
date | https://schema.org/Date |
date_format:Y-m-d H:i:s | https://schema.org/DateTime |
date_format:H:i | https://schema.org/Time |
image | https://schema.org/image |
mimes or mimetypes | https://schema.org/MediaObject |
You can also help us improve the documentation of this page.
Made with love by
Les-Tilleuls.coop can help you design and develop your APIs and web projects, and train your teams in API Platform, Symfony, Next.js, Kubernetes and a wide range of other technologies.
Learn more