Fix Rocket integration
Rocket's traits have changed in version 0.3.0, this commit adjusts the existing implementation to be compatible with the latest version of the traits.
This commit is contained in:
parent
714af0148c
commit
82ecd92090
3 changed files with 23 additions and 16 deletions
|
@ -45,8 +45,8 @@ serde_json = { version = "^1.0.2", optional = true }
|
||||||
iron = { version = "^0.5.1", optional = true }
|
iron = { version = "^0.5.1", optional = true }
|
||||||
urlencoded = { version = "^0.5.0", optional = true }
|
urlencoded = { version = "^0.5.0", optional = true }
|
||||||
|
|
||||||
rocket = { version = "^0.2.8", optional = true }
|
rocket = { version = "^0.3.0", optional = true }
|
||||||
rocket_codegen = { version = "^0.2.8", optional = true }
|
rocket_codegen = { version = "^0.3.0", optional = true }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
iron = "^0.5.1"
|
iron = "^0.5.1"
|
||||||
|
|
|
@ -15,7 +15,7 @@ use juniper::rocket_handlers;
|
||||||
type Schema = RootNode<'static, Database, EmptyMutation<Database>>;
|
type Schema = RootNode<'static, Database, EmptyMutation<Database>>;
|
||||||
|
|
||||||
#[get("/")]
|
#[get("/")]
|
||||||
fn graphiql() -> content::HTML<String> {
|
fn graphiql() -> content::Html<String> {
|
||||||
rocket_handlers::graphiql_source("/graphql")
|
rocket_handlers::graphiql_source("/graphql")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,4 +43,4 @@ fn main() {
|
||||||
.manage(Schema::new(Database::new(), EmptyMutation::<Database>::new()))
|
.manage(Schema::new(Database::new(), EmptyMutation::<Database>::new()))
|
||||||
.mount("/", routes![graphiql, get_graphql_handler, post_graphql_handler])
|
.mount("/", routes![graphiql, get_graphql_handler, post_graphql_handler])
|
||||||
.launch();
|
.launch();
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ use std::error::Error;
|
||||||
use serde_json;
|
use serde_json;
|
||||||
|
|
||||||
use rocket::Request;
|
use rocket::Request;
|
||||||
use rocket::request::{FromForm, FormItems, FromFormValue};
|
use rocket::request::{FromForm, FormItems};
|
||||||
use rocket::data::{FromData, Outcome as FromDataOutcome};
|
use rocket::data::{FromData, Outcome as FromDataOutcome};
|
||||||
use rocket::response::{Responder, Response, content};
|
use rocket::response::{Responder, Response, content};
|
||||||
use rocket::http::{ContentType, Status};
|
use rocket::http::{ContentType, Status};
|
||||||
|
@ -37,8 +37,8 @@ pub struct GraphQLRequest(http::GraphQLRequest);
|
||||||
pub struct GraphQLResponse(Status, String);
|
pub struct GraphQLResponse(Status, String);
|
||||||
|
|
||||||
/// Generate an HTML page containing GraphiQL
|
/// Generate an HTML page containing GraphiQL
|
||||||
pub fn graphiql_source(graphql_endpoint_url: &str) -> content::HTML<String> {
|
pub fn graphiql_source(graphql_endpoint_url: &str) -> content::Html<String> {
|
||||||
content::HTML(::graphiql::graphiql_source(graphql_endpoint_url))
|
content::Html(::graphiql::graphiql_source(graphql_endpoint_url))
|
||||||
}
|
}
|
||||||
|
|
||||||
impl GraphQLRequest {
|
impl GraphQLRequest {
|
||||||
|
@ -63,19 +63,22 @@ impl GraphQLRequest {
|
||||||
impl<'f> FromForm<'f> for GraphQLRequest {
|
impl<'f> FromForm<'f> for GraphQLRequest {
|
||||||
type Error = String;
|
type Error = String;
|
||||||
|
|
||||||
fn from_form_items(form_items: &mut FormItems<'f>) -> Result<Self, String> {
|
fn from_form(
|
||||||
|
form_items: &mut FormItems<'f>,
|
||||||
|
strict: bool
|
||||||
|
) -> Result<Self, String> {
|
||||||
let mut query = None;
|
let mut query = None;
|
||||||
let mut operation_name = None;
|
let mut operation_name = None;
|
||||||
let mut variables = None;
|
let mut variables = None;
|
||||||
|
|
||||||
for (key, value) in form_items {
|
for (key, value) in form_items {
|
||||||
match key {
|
match key.as_str() {
|
||||||
"query" => {
|
"query" => {
|
||||||
if query.is_some() {
|
if query.is_some() {
|
||||||
return Err("Query parameter must not occur more than once".to_owned());
|
return Err("Query parameter must not occur more than once".to_owned());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
query = Some(String::from_form_value(value)?);
|
query = Some(value.as_str().to_string());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"operation_name" => {
|
"operation_name" => {
|
||||||
|
@ -83,7 +86,7 @@ impl<'f> FromForm<'f> for GraphQLRequest {
|
||||||
return Err("Operation name parameter must not occur more than once".to_owned());
|
return Err("Operation name parameter must not occur more than once".to_owned());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
operation_name = Some(String::from_form_value(value)?);
|
operation_name = Some(value.as_str().to_string());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"variables" => {
|
"variables" => {
|
||||||
|
@ -91,11 +94,15 @@ impl<'f> FromForm<'f> for GraphQLRequest {
|
||||||
return Err("Variables parameter must not occur more than once".to_owned());
|
return Err("Variables parameter must not occur more than once".to_owned());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
variables = Some(serde_json::from_str::<InputValue>(&String::from_form_value(value)?)
|
variables = Some(serde_json::from_str::<InputValue>(value.as_str())
|
||||||
.map_err(|err| err.description().to_owned())?);
|
.map_err(|err| err.description().to_owned())?);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {
|
||||||
|
if strict {
|
||||||
|
return Err(format!("Prohibited extra field '{}'", key).to_owned());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,7 +122,7 @@ impl<'f> FromForm<'f> for GraphQLRequest {
|
||||||
impl FromData for GraphQLRequest {
|
impl FromData for GraphQLRequest {
|
||||||
type Error = String;
|
type Error = String;
|
||||||
|
|
||||||
fn from_data(request: &Request, data: Data) -> FromDataOutcome<Self, String> {
|
fn from_data(request: &Request, data: Data) -> FromDataOutcome<Self, Self::Error> {
|
||||||
if !request.content_type().map_or(false, |ct| ct.is_json()) {
|
if !request.content_type().map_or(false, |ct| ct.is_json()) {
|
||||||
return Forward(data);
|
return Forward(data);
|
||||||
}
|
}
|
||||||
|
@ -135,7 +142,7 @@ impl FromData for GraphQLRequest {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'r> Responder<'r> for GraphQLResponse {
|
impl<'r> Responder<'r> for GraphQLResponse {
|
||||||
fn respond(self) -> Result<Response<'r>, Status> {
|
fn respond_to(self, _: &Request) -> Result<Response<'r>, Status> {
|
||||||
let GraphQLResponse(status, body) = self;
|
let GraphQLResponse(status, body) = self;
|
||||||
|
|
||||||
Ok(Response::build()
|
Ok(Response::build()
|
||||||
|
@ -230,4 +237,4 @@ mod tests {
|
||||||
content_type: content_type,
|
content_type: content_type,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue