mirror of
https://github.com/retailcrm/graphql-php.git
synced 2025-02-19 22:03:13 +03:00
56 lines
3.1 KiB
Markdown
56 lines
3.1 KiB
Markdown
[data:image/s3,"s3://crabby-images/5eb8a/5eb8a5ea0b3f4e1fcf83b570c42b6023c2a3641d" alt="GitHub stars"](https://github.com/webonyx/graphql-php)
|
|
[data:image/s3,"s3://crabby-images/02372/02372f0422fb4f0a255c7140ecd69a4ede061ad7" alt="Build Status"](https://travis-ci.org/webonyx/graphql-php)
|
|
[data:image/s3,"s3://crabby-images/c622f/c622fb34707194dbf26b8dce7f4a8984fdd359b1" alt="Coverage Status"](https://coveralls.io/github/webonyx/graphql-php)
|
|
[data:image/s3,"s3://crabby-images/ad102/ad10214577b5c359295a5876ae1de17084de53a7" alt="Latest Stable Version"](https://packagist.org/packages/webonyx/graphql-php)
|
|
[data:image/s3,"s3://crabby-images/a3931/a3931133bf8f9647004ee15ca5eefd08d1bda995" alt="License"](https://packagist.org/packages/webonyx/graphql-php)
|
|
|
|
# About GraphQL
|
|
|
|
GraphQL is a modern way to build HTTP APIs consumed by the web and mobile clients.
|
|
It is intended to be a replacement for REST and SOAP APIs (even for **existing applications**).
|
|
|
|
GraphQL itself is a [specification](https://github.com/facebook/graphql) designed by Facebook
|
|
engineers. Various implementations of this specification were written
|
|
[in different languages and environments](http://graphql.org/code/).
|
|
|
|
Great overview of GraphQL features and benefits is presented on [the official website](http://graphql.org/).
|
|
All of them equally apply to this PHP implementation.
|
|
|
|
|
|
# About graphql-php
|
|
|
|
**graphql-php** is a feature-complete implementation of GraphQL specification in PHP (5.5+, 7.0+).
|
|
It was originally inspired by [reference JavaScript implementation](https://github.com/graphql/graphql-js)
|
|
published by Facebook.
|
|
|
|
This library is a thin wrapper around your existing data layer and business logic.
|
|
It doesn't dictate how these layers are implemented or which storage engines
|
|
are used. Instead, it provides tools for creating rich API for your existing app.
|
|
|
|
Library features include:
|
|
|
|
- Primitives to express your app as a [Type System](type-system/index.md)
|
|
- Validation and introspection of this Type System (for compatibility with tools like [GraphiQL](complementary-tools.md#tools))
|
|
- Parsing, validating and [executing GraphQL queries](executing-queries.md) against this Type System
|
|
- Rich [error reporting](error-handling.md), including query validation and execution errors
|
|
- Optional tools for [parsing GraphQL Type language](type-system/type-language.md)
|
|
- Tools for [batching requests](data-fetching.md#solving-n1-problem) to backend storage
|
|
- [Async PHP platforms support](data-fetching.md#async-php) via promises
|
|
- [Standard HTTP server](executing-queries.md#using-server)
|
|
|
|
Also, several [complementary tools](complementary-tools.md) are available which provide integrations with
|
|
existing PHP frameworks, add support for Relay, etc.
|
|
|
|
## Current Status
|
|
The first version of this library (v0.1) was released on August 10th 2015.
|
|
|
|
The current version (v0.10) supports all features described by GraphQL specification
|
|
(including April 2016 add-ons) as well as some experimental features like
|
|
[Schema Language parser](type-system/type-language.md) and
|
|
[Schema printer](reference.md#graphqlutilsschemaprinter).
|
|
|
|
Ready for real-world usage.
|
|
|
|
## GitHub
|
|
Project source code is [hosted on GitHub](https://github.com/webonyx/graphql-php).
|