Graphoquent is a Laravel packages that turns Eloquent models into queryable GraphQL objects.
By default, Graphoquent tries to infer your model's type from three places:
- The model's
$casts
array - The model's
$dates
array - The model's
@property
and@property-read
DocBlock annotations
Given the following model:
/**
* @property int $count
*/
class Foo extends Model
{
use \Galahad\Graphoquent\Queryable;
protected $casts = [
'stars' => 'float',
];
protected $dates = [
'created_at',
];
}
Graphoquent will build the following GraphQL Type:
type Foo {
count: Int
stars: Float
created_at: String
}
Graphoquent uses Laravel Gates for default authorization:
expose
: Can this user (ornull
if not logged in) use introspection to lear about this Type?
You may provide custom authorization for any Model by defining an
authorizeGraphQL
method on the model:
public function authorizeGraphQL($actor, $ability)
{
if ('expose' === $ability) {
return true;
}
return $actor && $actor->id === $this->owner_id;
}