API Platform is a next-generation web framework designed to easily create API-first projects without compromising extensibility
- Design your own data model as plain old PHP classes or import an existing one
from the Schema.org vocabulary.
Expose in minutes a hypermedia REST or a GraphQL API with pagination, data validation, access control, relation embedding,
filters and error handling...
- Benefit from Content Negotiation: GraphQL, JSON-LD, Hydra,
HAL, JSONAPI, YAML, JSON, XML and CSV are supported out of the box.
- Enjoy the beautiful automatically generated API documentation (Swagger/OpenAPI).
- Add a convenient Material Design administration interface built with React
without writing a line of code.
Scaffold fully functional Progressive-Web-Apps and mobile apps built with Next.js (React),
Nuxt.js (Vue.js) or React Native
thanks to the client generator (a Vue.js generator is also available).
- Install a development environment and deploy your project in production using Docker
- Easily add OAuth authentication.
- Create specs and tests with a developer friendly API testing tool.
The official project documentation is available on the API Platform website.
API Platform embraces open web standards (OpenAPI, RDF/JSON-LD/Hydra, GraphQL, JSON:API, HAL, OAuth...) and the
Linked Data movement. Your API will automatically expose structured data
in Schema.org / JSON-LD. It means that your API Platform application is usable out of the box with technologies of
the semantic web.
It also means that your SEO will be improved because Google leverages these formats.
Last but not least, the server component of API Platform is built on top of the Symfony framework,
while client components leverage React (a Vue.js flavor is also available).
It means that you can:
- Use thousands of Symfony bundles and React components with API Platform.
- Integrate API Platform in any existing Symfony or React application.
- Reuse all your Symfony and React skills, benefit of the incredible amount of documentation available.
- Enjoy the popular Doctrine ORM (used by default, but fully optional:
you can use the data provider you want, including but not limited to MongoDB and Elasticsearch)
Read the official "Getting Started" guide.
Created by Kvin Dunglas. Commercial support available at Les-Tilleuls.coop.