Download the PHP package plato-solutions/yii2-graphql without Composer
On this page you can find all versions of the php package plato-solutions/yii2-graphql. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download plato-solutions/yii2-graphql
More information about plato-solutions/yii2-graphql
Files in plato-solutions/yii2-graphql
Package yii2-graphql
Short Description graphql server side for yii2 php framework
License BSD-3-Clause
Informations about the package yii2-graphql
yii2-graphql
Using GraphQL PHP server implementation. A fork of yii2-graphql which extends graphql-php to apply to Yii2.
Guide (For Yii Basic Template)
Same as for Yii Advanced Template, but
- instead of the
backend
namespace, it'sapp
- eg the namespace should be
namespace app\modules\graphql\...
- eg the namespace should be
- Instead of
main.php
, it'sweb.php
eg `- eg the config is in
config/web.php
- eg the config is in
Guide (For Yii Advanced Template)
Install
Using composer
Enable Yii JsonParser
To enable parsing for JSON requests in backend/config/main.php
Create a GraphQLModule
-
Create a folder
modules
in your base path (iebackend
) -
Create a
graphql
folder in the modules folder. Thusbackend/modules/graphql
-
Create a
GraphqlModule.php
file in there with the following content:backend/modules/graphql/GraphqlModule.php
- In
backend/config/main.php
find themodules
config and add to it so it looks like this:
- In
Create a Controller
- In your
modules/graphql
folder create acontrollers
folder. - Create a
DefaultController.php
file in there with the following content:
Create GraphQL Types
For a model in folder backend/models
like the example below,
where Person is another Model with it's own attributes just like the Country
- Create a folder in your module
modules/graphql/
and name ittypes
. - Create a
CountryType.php
(name it after your model class, suffix with Type) the following content
Do the above for all the models in backend\models
.
For a full list of the types available under Type, see Scalar Types below.
Create GraphQL Queries for Models
- Create a folder in your module
modules/graphql/
and name itqueries
. - Create a
CountryQuery.php
(name it after your model class, suffix with Query) the following content
Do the above for all the models in backend\models
you want to have queries for.
Set Up Schema
-
In
backend/modules/graphql/
create a php fileschema.php
with the content: - In
backend/config/main.php
in the part aboutmodules
add a path to theschema.php
as follows (make sure the directory path toschema
is right).
Docs
Type
The type system is the core of GraphQL, which is embodied in GraphQLType
. By deconstructing the GraphQL protocol and using the graph-php library to achieve fine-grained control of all elements, it is convenient to extend the class according to its own needs
Scalar Types
The GraphQL specification describes several built-in scalar types. In graphql-php they are exposed as static methods of the class GraphQL\Type\Definition\Type:
Data Type | GraphQL Type |
---|---|
id | Type::id() |
int | Type::int() |
string | Type::string() |
boolean | Type::boolean() |
float | Type::float() |
The main elements of GraphQLType
The following elements can be declared in the $attributes
property of the class, or as a method, unless stated otherwise. This also applies to all elements after this.
Element | Type | Description |
---|---|---|
name |
string | Required Each type needs to be named, with unique names preferred to resolve potential conflicts. The property needs to be defined in the $attributes property. |
description |
string | A description of the type and its use. The property needs to be defined in the $attributes property. |
fields |
array | Required The included field content is represented by the fields () method. |
resolveField |
callback | function($value, $args, $context, GraphQL\Type\Definition\ResolveInfo $info) For the interpretation of a field. For example: the fields definition of the user property, the corresponding method is resolveUserField() , and $value is the passed type instance defined by type . |
Query
GraphQLQuery
and GraphQLMutation
inherit GraphQLField
. The element structure is consistent, and if you would like a reusable Field
, you can inherit it.
Each query of Graphql
needs to correspond to a GraphQLQuery
object. ModelQuery
inherits from GraphQLQuery
.
The main elements of GraphQLField
Element | Type | Description |
---|---|---|
type |
ObjectType | For the corresponding query type. The single type is specified by GraphQL::type , and a list by Type::listOf(GraphQL::type) . |
args |
array | The available query parameters, each of which is defined by Field . |
resolve |
callback | function($value, $args, $context, GraphQL\Type\Definition\ResolveInfo $info) $value is the root data, $args is the query parameters, $context is the yii\web\Application object, and $info resolves the object for the query. The root object is handled in this method. |
Mutation
Definition is similar to GraphQLQuery
, please refer to the above.
Simplified Field Definition
Simplifies the declarations of Field
, removing the need to defined as an array with the type key.
Standard Definition
Simplified Definition
Input validation
Validation rules are supported. In addition to graphql based validation, you can also use Yii Model validation, which is currently used for the validation of input parameters. The rules method is added directly to the mutation definition.
Authorization verification
Since graphql queries can be combined, such as when a query merges two query, and the two query have different authorization constraints, custom authentication is required. I refer to this query as "graphql actions"; when all graphql actions conditions are configured, it passes the authorization check.
Authenticate
In the behavior method of controller, the authorization method is set as follows
If you want to support IntrospectionQuery authorization, the corresponding graphql action is __schema
Authorization
If the user has passed authentication, you may want to check the access for the resource. You can use GraphqlAction
's checkAccess
method
in the controller. It will check all graphql actions.
All versions of yii2-graphql with dependencies
yiisoft/yii2 Version ^2.0.
webonyx/graphql-php Version ^14.6.2
ecodev/graphql-upload Version ^6.1.0
zendframework/zend-diactoros Version ^2.1
phpunit/php-code-coverage Version 9.2.x-dev