Skip to content

Commit

Permalink
Add warp_async example
Browse files Browse the repository at this point in the history
  • Loading branch information
theduke authored and LegNeato committed Oct 10, 2019
1 parent 92871a9 commit 57ecd4b
Show file tree
Hide file tree
Showing 4 changed files with 118 additions and 0 deletions.
1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,5 @@ members = [
]
exclude = [
"docs/book/tests",
"examples/warp_async",
]
1 change: 1 addition & 0 deletions examples/warp_async/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
target
17 changes: 17 additions & 0 deletions examples/warp_async/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
[package]
name = "warp_async"
version = "0.1.0"
authors = ["Christoph Herzog <[email protected]>"]
edition = "2018"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
juniper = { git = "https://github.com/graphql-rust/juniper", branch = "async-await", features = ["async"] }
juniper_warp = { git = "https://github.com/graphql-rust/juniper", branch = "async-await", features = ["async"] }
log = "0.4.8"
env_logger = "0.6.2"
warp = "0.1.19"
futures-preview = { version = "0.3.0-alpha.18", features = ["nightly", "async-await", "compat"] }
reqwest = "0.9.19"

99 changes: 99 additions & 0 deletions examples/warp_async/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
//!
//! This example demonstrates async/await usage with warp.
//! NOTE: this uses tokio 0.1 , not the alpha tokio 0.2.
#![feature(async_await, async_closure)]

use juniper::{EmptyMutation, RootNode, FieldError};
use warp::{http::Response, Filter};

#[derive(Clone)]
struct Context {

}
impl juniper::Context for Context {}

struct User {
id: i32,
name: String,
}

#[juniper::object(Context = Context)]
impl User {
fn id(&self) -> i32 {
self.id
}

fn name(&self) -> &str {
&self.name
}

async fn friends(&self) -> Vec<User> {
vec![]
}
}

struct Query;

#[juniper::object(Context = Context)]
impl Query {
async fn users() -> Vec<User> {
vec![
User{
id: 1,
name: "user1".into(),
},
]
}

/// Fetch a URL and return the response body text.
async fn request(url: String) -> Result<String, FieldError> {
use futures::{ compat::{Stream01CompatExt, Future01CompatExt}, stream::TryStreamExt};

let res = reqwest::r#async::Client::new()
.get(&url)
.send()
.compat()
.await?;

let body_raw = res.into_body().compat().try_concat().await?;
let body = std::str::from_utf8(&body_raw).unwrap_or("invalid utf8");
Ok(body.to_string())
}
}

type Schema = RootNode<'static, Query, EmptyMutation<Context>>;

fn schema() -> Schema {
Schema::new(Query, EmptyMutation::<Context>::new())
}

fn main() {
::std::env::set_var("RUST_LOG", "warp_async");
env_logger::init();

let log = warp::log("warp_server");

let homepage = warp::path::end().map(|| {
Response::builder()
.header("content-type", "text/html")
.body(format!(
"<html><h1>juniper_warp</h1><div>visit <a href=\"/graphiql\">/graphiql</a></html>"
))
});

log::info!("Listening on 127.0.0.1:8080");

let state = warp::any().map(move || Context{} );
let graphql_filter = juniper_warp::make_graphql_filter_async(schema(), state.boxed());

warp::serve(
warp::get2()
.and(warp::path("graphiql"))
.and(juniper_warp::graphiql_filter("/graphql"))
.or(homepage)
.or(warp::path("graphql").and(graphql_filter))
.with(log),
)
.run(([127, 0, 0, 1], 8080));
}

0 comments on commit 57ecd4b

Please sign in to comment.