async-graphql/README.md

176 lines
12 KiB
Markdown
Raw Permalink Normal View History

2020-03-01 13:56:14 +00:00
<div align="center">
2022-09-01 06:11:33 +00:00
<samp>
2020-03-01 13:56:14 +00:00
2022-09-01 06:11:33 +00:00
# async-graphql
2020-03-12 09:21:49 +00:00
2022-09-01 06:11:33 +00:00
**a high-performance graphql server library that's fully specification compliant**
2020-03-01 13:56:14 +00:00
2022-09-01 06:11:33 +00:00
</samp>
[Book](https://async-graphql.github.io/async-graphql/en/index.html) • [中文文档](https://async-graphql.github.io/async-graphql/zh-CN/index.html) • [Docs](https://docs.rs/async-graphql) • [GitHub repository](https://github.com/async-graphql/async-graphql) • [Cargo package](https://crates.io/crates/async-graphql)
2022-09-01 06:11:33 +00:00
---
2020-06-02 23:46:34 +00:00
2022-09-01 06:11:33 +00:00
![ci status](https://github.com/async-graphql/async-graphql/workflows/CI/badge.svg)
[![code coverage](https://codecov.io/gh/async-graphql/async-graphql/branch/master/graph/badge.svg)](https://codecov.io/gh/async-graphql/async-graphql/)
[![Unsafe Rust forbidden](https://img.shields.io/badge/unsafe-forbidden-success.svg)](https://github.com/rust-secure-code/safety-dance/)
[![Crates.io version](https://img.shields.io/crates/v/async-graphql.svg)](https://crates.io/crates/async-graphql)
[![docs.rs docs](https://img.shields.io/badge/docs-latest-blue.svg)](https://docs.rs/async-graphql)
[![downloads](https://img.shields.io/crates/d/async-graphql.svg)](https://crates.io/crates/async-graphql)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](https://github.com/async-graphql/async-graphql/compare)
2020-09-26 03:25:21 +00:00
2022-09-01 06:11:33 +00:00
_This crate uses `#![forbid(unsafe_code)]` to ensure everything is implemented in 100% safe Rust._
2022-09-01 06:11:33 +00:00
</div>
```rs
struct Query;
#[Object]
impl Query {
2022-09-01 10:09:15 +00:00
fn howdy(&self) -> &'static str {
2022-09-01 06:11:33 +00:00
"partner"
}
}
async fn main() {
let schema = Schema::build(Query, EmptyMutation, EmptySubscription).finish();
let app = Route::new()
.at("/",
get(graphiql)
2022-09-01 10:09:15 +00:00
.post(GraphQL::new(schema))
);
2022-09-01 06:11:33 +00:00
println!("GraphiQL: http://localhost:8000");
Server::new(TcpListener::bind("0.0.0.0:8000"))
.run(app)
.await
.unwrap();
}
```
## Features
2022-09-01 06:11:33 +00:00
- Fully supports async/await
- Type safety
- Rustfmt friendly (Procedural Macro)
- Custom scalars
- Minimal overhead
- Easy integration ([poem](https://crates.io/crates/poem), actix_web, tide, warp, rocket ...)
- Upload files (Multipart request)
- Subscriptions (WebSocket transport)
- Custom extensions
- Error extensions
- Limit query complexity/depth
- Batch queries
- Apollo Persisted Queries
- Apollo Tracing extension
2022-09-22 15:34:49 +00:00
- Apollo Federation(v2)
2022-09-01 06:11:33 +00:00
> **Note**: Minimum supported Rust version: 1.59.0 or later
2020-04-14 01:53:17 +00:00
## Examples
2020-03-09 12:44:31 +00:00
2020-10-16 01:21:16 +00:00
All examples are in the [sub-repository](https://github.com/async-graphql/examples), located in the examples directory.
```shell
git submodule update # update the examples repo
cd examples && cargo run --bin [name]
```
2020-03-09 12:44:31 +00:00
2020-03-18 00:44:41 +00:00
## Integrations
2022-09-01 06:11:33 +00:00
Integrations are what glue `async-graphql` with your web server, here are provided ones, or you can build your own!
2020-03-18 00:44:41 +00:00
2022-09-01 06:11:33 +00:00
- Poem [async-graphql-poem](https://crates.io/crates/async-graphql-poem)
- Actix-web [async-graphql-actix-web](https://crates.io/crates/async-graphql-actix-web)
- Warp [async-graphql-warp](https://crates.io/crates/async-graphql-warp)
- Tide [async-graphql-tide](https://crates.io/crates/async-graphql-tide)
- Rocket [async-graphql-rocket](https://github.com/async-graphql/async-graphql/tree/master/integrations/rocket)
- Axum [async-graphql-axum](https://github.com/async-graphql/async-graphql/tree/master/integrations/axum)
## Crate features
This crate offers the following features, all of which are not activated by default:
| feature | enables |
2022-09-22 15:34:49 +00:00
|:-------------------------------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
2022-09-01 06:11:33 +00:00
| **`apollo_tracing`** | Enable the [Apollo tracing extension](extensions/struct.ApolloTracing.html). |
| **`apollo_persisted_queries`** | Enable the [Apollo persisted queries extension](extensions/apollo_persisted_queries/struct.ApolloPersistedQueries.html). |
| **`log`** | Enable the [logger extension](extensions/struct.Logger.html). |
| **`tracing`** | Enable the [tracing extension](extensions/struct.Tracing.html). |
| **`opentelemetry`** | Enable the [OpenTelemetry extension](extensions/struct.OpenTelemetry.html). |
| **`unblock`** | Support [asynchronous reader for Upload](types/struct.Upload.html) |
| **`bson`** | Integrate with the [`bson` crate](https://crates.io/crates/bson). |
| **`chrono`** | Integrate with the [`chrono` crate](https://crates.io/crates/chrono). |
| **`chrono-tz`** | Integrate with the [`chrono-tz` crate](https://crates.io/crates/chrono-tz). |
| **`url`** | Integrate with the [`url` crate](https://crates.io/crates/url). |
| **`uuid`** | Integrate with the [`uuid` crate](https://crates.io/crates/uuid). |
| **`uuid08`** | Integrate with the [`uuid 0.8` crate](https://crates.io/crates/uuid/0.8.2). |
| **`string_number`** | Enable the [StringNumber](types/struct.StringNumber.html). |
| **`dataloader`** | Support [DataLoader](dataloader/struct.DataLoader.html). |
| **`secrecy`** | Integrate with the [`secrecy` crate](https://crates.io/crates/secrecy). |
| **`decimal`** | Integrate with the [`rust_decimal` crate](https://crates.io/crates/rust_decimal). |
| **`bigdecimal`** | Integrate with the [`bigdecimal` crate](https://crates.io/crates/bigdecimal). |
| **`cbor`** | Support for [serde_cbor](https://crates.io/crates/serde_cbor). |
| **`smol_str`** | Integrate with the [`smol_str` crate](https://crates.io/crates/smol_str). |
| **`hashbrown`** | Integrate with the [`hashbrown` crate](https://github.com/rust-lang/hashbrown). |
| **`time`** | Integrate with the [`time` crate](https://github.com/time-rs/time). |
| **`tokio-sync`** | Integrate with the [`tokio::sync::RwLock`](https://docs.rs/tokio/1.18.1/tokio/sync/struct.RwLock.html) and [`tokio::sync::Mutex`](https://docs.rs/tokio/1.18.1/tokio/sync/struct.Mutex.html). |
| **`fast_chemail`** | Integrate with the [`fast_chemail` crate](https://crates.io/crates/fast_chemail). |
### Observability
One of the tools used to monitor your graphql server in production is Apollo Studio. Apollo Studio is a cloud platform that helps you build, monitor, validate, and secure your organization's data graph.
Add the extension crate [`async_graphql_apollo_studio_extension`](https://github.com/async-graphql/async_graphql_apollo_studio_extension) to make this avaliable.
## Who's using `async-graphql` in production?
2021-09-11 00:57:38 +00:00
- [Vector](https://vector.dev/)
2021-09-24 03:20:47 +00:00
- [DiveDB](https://divedb.net)
2021-09-11 00:57:38 +00:00
- [Kairos Sports tech](https://kairostech.io/)
- [AxieInfinity](https://axieinfinity.com/)
- [Nando's](https://www.nandos.co.uk/)
- [Prima.it](https://www.prima.it/)
- [VoxJar](https://voxjar.com/)
- [Zenly](https://zen.ly/)
- [Brevz](https://brevz.io/)
- [thorndyke](https://www.thorndyke.ai/)
2022-07-22 16:12:44 +00:00
- [My Data My Consent](https://mydatamyconsent.com/)
2021-09-11 00:57:38 +00:00
2021-09-24 03:20:47 +00:00
## Community Showcase
- [rust-actix-graphql-sqlx-postgresql](https://github.com/camsjams/rust-actix-graphql-sqlx-postgresql)
Using GraphQL with Rust and Apollo Federation
- [entity-rs](https://github.com/chipsenkbeil/entity-rs) A simplistic framework based on TAO, Facebook's distributed database for Social Graph.
- [vimwiki-server](https://github.com/chipsenkbeil/vimwiki-rs/tree/master/vimwiki-server) Provides graphql server to inspect and manipulate vimwiki files.
- [Diana](https://github.com/arctic-hen7/diana) Diana is a GraphQL system for Rust that's designed to work as simply as possible out of the box, without sacrificing configuration ability.
- [cindythink](https://www.cindythink.com/)
2021-12-06 01:28:00 +00:00
- [sudograph](https://github.com/sudograph/sudograph)
2021-09-24 03:20:47 +00:00
2021-07-14 04:24:50 +00:00
## Blog Posts
- [Async GraphQL with Rust](https://formidable.com/blog/2022/async-graphql-with-rust-1/)
2021-07-14 04:24:50 +00:00
- [GraphQL in Rust](https://romankudryashov.com/blog/2020/12/graphql-rust/)
- [How to implement a Rust micro-service using Rocket, GraphQL, PostgreSQL](https://lionkeng.medium.com/how-to-implement-a-rust-micro-service-using-rocket-graphql-postgresql-a3f455f2ae8b)
- [Running GraphQL on Lambda with Rust](https://dylananthony.com/posts/graphql-lambda-rust)
2022-09-01 06:11:33 +00:00
## References
- [GraphQL](https://graphql.org)
- [GraphQL Multipart Request](https://github.com/jaydenseric/graphql-multipart-request-spec)
- [GraphQL Cursor Connections Specification](https://facebook.github.io/relay/graphql/connections.htm)
- [GraphQL over WebSocket Protocol](https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md)
- [Apollo Tracing](https://github.com/apollographql/apollo-tracing)
- [Apollo Federation](https://www.apollographql.com/docs/apollo-server/federation/introduction)
2020-03-03 03:48:00 +00:00
## License
Licensed under either of
2022-09-01 06:11:33 +00:00
- Apache License, Version 2.0,
2021-04-19 14:38:46 +00:00
([LICENSE-APACHE](./LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
2022-09-01 06:11:33 +00:00
- MIT license ([LICENSE-MIT](./LICENSE-MIT) or http://opensource.org/licenses/MIT)
2020-03-03 03:48:00 +00:00
at your option.