From 8a90f867d41b7c27602020240e99d6de99baa59d Mon Sep 17 00:00:00 2001 From: tyranron Date: Wed, 21 Jul 2021 20:45:01 +0300 Subject: [PATCH] Expose GraphQLRequest fields (#750) --- integration_tests/juniper_tests/src/api.rs | 12 ---------- integration_tests/juniper_tests/src/lib.rs | 2 -- juniper/CHANGELOG.md | 1 + juniper/src/http/mod.rs | 28 ++++++++++++++-------- 4 files changed, 19 insertions(+), 24 deletions(-) delete mode 100644 integration_tests/juniper_tests/src/api.rs diff --git a/integration_tests/juniper_tests/src/api.rs b/integration_tests/juniper_tests/src/api.rs deleted file mode 100644 index fcfd895e..00000000 --- a/integration_tests/juniper_tests/src/api.rs +++ /dev/null @@ -1,12 +0,0 @@ -#[test] -fn operation_name_is_public() { - use juniper::{http::GraphQLRequest, DefaultScalarValue}; - - let request = GraphQLRequest::::new( - "query".to_string(), - Some("name".to_string()), - None, - ); - - assert_eq!(request.operation_name(), Some("name")); -} diff --git a/integration_tests/juniper_tests/src/lib.rs b/integration_tests/juniper_tests/src/lib.rs index 3a07b3fc..43a922da 100644 --- a/integration_tests/juniper_tests/src/lib.rs +++ b/integration_tests/juniper_tests/src/lib.rs @@ -1,6 +1,4 @@ #[cfg(test)] -mod api; -#[cfg(test)] mod arc_fields; #[cfg(test)] mod codegen; diff --git a/juniper/CHANGELOG.md b/juniper/CHANGELOG.md index 2741f350..5121175f 100644 --- a/juniper/CHANGELOG.md +++ b/juniper/CHANGELOG.md @@ -1,6 +1,7 @@ # master - Allow spreading interface fragments on unions and other interfaces ([#965](https://github.com/graphql-rust/juniper/pull/965), [#798](https://github.com/graphql-rust/juniper/issues/798)) +- Expose `GraphQLRequest` fields ([#750](https://github.com/graphql-rust/juniper/issues/750)) # [[0.15.7] 2021-07-08](https://github.com/graphql-rust/juniper/releases/tag/juniper-v0.15.7) diff --git a/juniper/src/http/mod.rs b/juniper/src/http/mod.rs index 5b56a7c2..8ff13c59 100644 --- a/juniper/src/http/mod.rs +++ b/juniper/src/http/mod.rs @@ -29,23 +29,31 @@ pub struct GraphQLRequest where S: ScalarValue, { - query: String, + /// GraphQL query representing this request. + pub query: String, + + /// Optional name of the operation associated with this request. #[serde(rename = "operationName")] - operation_name: Option, + pub operation_name: Option, + + /// Optional variables to execute the GraphQL operation with. #[serde(bound(deserialize = "InputValue: Deserialize<'de> + Serialize"))] - variables: Option>, + pub variables: Option>, } impl GraphQLRequest where S: ScalarValue, { + // TODO: Remove in 0.17 `juniper` version. /// Returns the `operation_name` associated with this request. + #[deprecated(since = "0.16", note = "Use the direct field access instead.")] pub fn operation_name(&self) -> Option<&str> { self.operation_name.as_deref() } - fn variables(&self) -> Variables { + /// Returns operation [`Variables`] defined withing this request. + pub fn variables(&self) -> Variables { self.variables .as_ref() .and_then(|iv| { @@ -64,7 +72,7 @@ where operation_name: Option, variables: Option>, ) -> Self { - GraphQLRequest { + Self { query, operation_name, variables, @@ -88,7 +96,7 @@ where { GraphQLResponse(crate::execute_sync( &self.query, - self.operation_name(), + self.operation_name.as_deref(), root_node, &self.variables(), context, @@ -114,7 +122,7 @@ where SubscriptionT::TypeInfo: Sync, S: ScalarValue + Send + Sync, { - let op = self.operation_name(); + let op = self.operation_name.as_deref(); let vars = &self.variables(); let res = crate::execute(&self.query, op, root_node, vars, context).await; GraphQLResponse(res) @@ -143,7 +151,7 @@ where SubscriptionT::TypeInfo: Sync, S: ScalarValue + Send + Sync, { - let op = req.operation_name(); + let op = req.operation_name.as_deref(); let vars = req.variables(); crate::resolve_into_stream(&req.query, op, root_node, &vars, context).await @@ -316,8 +324,8 @@ where /// The operation names of the request. pub fn operation_names(&self) -> Vec> { match self { - Self::Single(req) => vec![req.operation_name()], - Self::Batch(reqs) => reqs.iter().map(|req| req.operation_name()).collect(), + Self::Single(req) => vec![req.operation_name.as_deref()], + Self::Batch(reqs) => reqs.iter().map(|r| r.operation_name.as_deref()).collect(), } } }