This project is deprecated in favor of https://github.com/nuwave/lighthouse
Use Facebook GraphQL with React Relay. This package extends graphql-php to work with Laravel and is currently a work in progress. You can reference what specifications GraphQL needs to provide to work with Relay in the documentation.
Although this package no longer depends on laraval-graphql, it laid the foundation for this package which likely wouldn't exist without it. It is also a great alternative if you are using GraphQL w/o support for Relay.
Because this package is still in the early stages, breaking changes will occur. We will keep the documentation updated with the current release. Please feel free to contribute, PR are absolutely welcome!
You must then modify your composer.json file and run composer update to include the latest version of the package in your project.
"require": {
"nuwave/laravel-graphql-relay": "0.3.*"
}
Or you can use the composer require command from your terminal.
composer require nuwave/laravel-graphql-relay
Add the service provider to your config/app.php
file
Nuwave\Relay\LaravelServiceProvider::class
Add the Relay & GraphQL facade to your app/config.php file
'GraphQL' => Nuwave\Relay\Facades\GraphQL::class,
'Relay' => Nuwave\Relay\Facades\Relay::class,
Publish the configuration file
php artisan vendor:publish --provider="Nuwave\Relay\LaravelServiceProvider"
Create a schema.php
file and add the path to the config. See the Schema wiki page for more information on schema.php
.
// config/relay.php
// ...
'schema' => [
'path' => 'Http/schema.php',
'output' => null,
],
To generate a schema.json
file (used with the Babel Relay Plugin):
php artisan relay:schema
You can customize the output path in the relay.php
config file under schema.output
For additional documentation, look through the docs folder or read the Wiki.