THIS IS A FORK OF api-platform
PWA and Mercure has been removed!
API Platform is a next-generation web framework designed to easily create API-first projects without compromising extensibility and flexibility:
- 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 and Kubernetes.
- 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)
cp .env.example .env
edit .env file and set SERVER_NAME
SERVER_NAME=example.local
Also, you can config your db name and credentials.
docker-compose build --pull --no-cache
docker-compose up -d
Set your os always trust to below certificate
docker-compose cp caddy:/data/caddy/certificates/local/example.local/example.local.crt /any/location/in/your/machine
See https://tosbourn.com/getting-os-x-to-trust-self-signed-ssl-certificates/
sudo echo '127.0.0.1 example.local' >> /etc/hosts
Read the official "Getting Started" guide.
Created by Kévin Dunglas. Commercial support available at Les-Tilleuls.coop.