thecodingmachine/graphqlite-bundle
最新稳定版本:v7.4.0
Composer 安装命令:
composer require thecodingmachine/graphqlite-bundle
包简介
A Symfony bundle for thecodingmachine/graphqlite.
README 文档
README
GraphQLite bundle
Symfony bundle for the thecodingmachine/graphqlite package.
It discovers your annotated controllers and types, builds the schema, exposes the /graphql endpoint through a PSR-7
bridge (with optional upload handling), and keeps the Symfony request available as the GraphQL context.
Part of the bundle docs: https://graphqlite.thecodingmachine.io/docs/symfony-bundle
See thecodingmachine/graphqlite.
Requirements
- PHP 8.1+
- Supports:
- Symfony 6.4/7.0/8.0
- GraphQLite ^8
Installation
composer require thecodingmachine/graphqlite-bundle
Ensure the bundle is enabled (Symfony Flex does this automatically via config/bundles.php after composer require).
Configure routes
Import the bundle routes to expose /graphql:
# config/routes/graphqlite.yaml graphqlite_bundle: resource: '@GraphQLiteBundle/Resources/config/routes.php'
Configure namespaces
Tell GraphQLite where to look for controllers and types:
# config/packages/graphqlite.yaml graphqlite: namespace: controllers: App\\GraphQL\\Controller types: - App\\GraphQL\\Type - App\\Entity
Quickstart
Create a controller with GraphQLite attributes:
<?php // src/GraphQL/Controller/HelloController.php namespace App\GraphQL\Controller; use TheCodingMachine\GraphQLite\Annotations\Query; final class HelloController { #[Query] public function hello(string $name = 'world'): string { return sprintf('Hello %s', $name); } }
Features
- Auto-discovers controllers and types from configured namespaces and registers GraphQLite services, query providers, type mappers, and middleware through Symfony autoconfiguration
- Ships a
/graphqlroute that converts Symfony requests to PSR-7 and keeps the Symfony request in the GraphQL context - Passes the Symfony request as context to allow using them in queries/mutations
- Supports multipart uploads when
graphql-uploadis installed - Integrates with Symfony Security for
#[Logged]/#[Right]checks - Expose
login/logoutmutations plus amequery (opt-out) - Symfony Validator-based user input validation
- Lets you cap introspection, query depth, and query complexity via configuration
- Uses Symfony cache (APCu or PHP files) for schema caching
- Includes a
graphqlite:dump-schemaconsole command to export GraphQL SDL
GraphiQL (playground)
The bundle wires Overblog’s GraphiQL bundle if it is installed. See https://github.com/overblog/GraphiQLBundle for
enabling the UI alongside the /graphql endpoint.
Development
- Tests:
vendor/bin/phpunit - Static analysis:
composer phpstan
统计信息
- 总下载量: 1.49M
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 36
- 点击次数: 1
- 依赖项目数: 3
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2019-01-29