Makes use of io::read_to_string

pull/553/head
Tpt 2 years ago committed by Thomas Tanon
parent 76deca135c
commit 785df9b00b
  1. 39
      server/src/main.rs

@ -471,10 +471,7 @@ pub fn main() -> anyhow::Result<()> {
format!("Not able to read query file {}", query_file.display()) format!("Not able to read query file {}", query_file.display())
})? })?
} else { } else {
// TODO: use io::read_to_string io::read_to_string(stdin().lock())?
let mut query = String::new();
stdin().lock().read_to_string(&mut query)?;
query
}; };
let query = Query::parse(&query, query_base.as_deref())?; let query = Query::parse(&query, query_base.as_deref())?;
let store = Store::open_read_only( let store = Store::open_read_only(
@ -621,10 +618,7 @@ pub fn main() -> anyhow::Result<()> {
format!("Not able to read update file {}", update_file.display()) format!("Not able to read update file {}", update_file.display())
})? })?
} else { } else {
// TODO: use io::read_to_string io::read_to_string(stdin().lock())?
let mut update = String::new();
stdin().lock().read_to_string(&mut update)?;
update
}; };
let update = Update::parse(&update, update_base.as_deref())?; let update = Update::parse(&update, update_base.as_deref())?;
let store = Store::open( let store = Store::open(
@ -862,16 +856,12 @@ fn handle_request(
let content_type = let content_type =
content_type(request).ok_or_else(|| bad_request("No Content-Type given"))?; content_type(request).ok_or_else(|| bad_request("No Content-Type given"))?;
if content_type == "application/sparql-query" { if content_type == "application/sparql-query" {
let mut buffer = String::new(); let query = io::read_to_string(request.body_mut().take(MAX_SPARQL_BODY_SIZE))
request
.body_mut()
.take(MAX_SPARQL_BODY_SIZE)
.read_to_string(&mut buffer)
.map_err(bad_request)?; .map_err(bad_request)?;
configure_and_evaluate_sparql_query( configure_and_evaluate_sparql_query(
&store, &store,
&[url_query(request)], &[url_query(request)],
Some(buffer), Some(query),
request, request,
) )
} else if content_type == "application/x-www-form-urlencoded" { } else if content_type == "application/x-www-form-urlencoded" {
@ -898,16 +888,12 @@ fn handle_request(
let content_type = let content_type =
content_type(request).ok_or_else(|| bad_request("No Content-Type given"))?; content_type(request).ok_or_else(|| bad_request("No Content-Type given"))?;
if content_type == "application/sparql-update" { if content_type == "application/sparql-update" {
let mut buffer = String::new(); let update = io::read_to_string(request.body_mut().take(MAX_SPARQL_BODY_SIZE))
request
.body_mut()
.take(MAX_SPARQL_BODY_SIZE)
.read_to_string(&mut buffer)
.map_err(bad_request)?; .map_err(bad_request)?;
configure_and_evaluate_sparql_update( configure_and_evaluate_sparql_update(
&store, &store,
&[url_query(request)], &[url_query(request)],
Some(buffer), Some(update),
request, request,
) )
} else if content_type == "application/x-www-form-urlencoded" { } else if content_type == "application/x-www-form-urlencoded" {
@ -1728,6 +1714,7 @@ mod tests {
use oxhttp::model::Method; use oxhttp::model::Method;
use predicates::prelude::*; use predicates::prelude::*;
use std::fs::remove_dir_all; use std::fs::remove_dir_all;
use std::io::read_to_string;
fn cli_command() -> Result<Command> { fn cli_command() -> Result<Command> {
Ok(Command::from_std( Ok(Command::from_std(
@ -2748,18 +2735,16 @@ mod tests {
} }
fn check_status(mut response: Response, expected_status: Status) -> Result<()> { fn check_status(mut response: Response, expected_status: Status) -> Result<()> {
let mut buf = String::new(); let body = read_to_string(response.body_mut())?;
response.body_mut().read_to_string(&mut buf)?; assert_eq!(response.status(), expected_status, "Error message: {body}");
assert_eq!(response.status(), expected_status, "Error message: {buf}");
Ok(()) Ok(())
} }
fn test_body(&self, request: Request, expected_body: &str) -> Result<()> { fn test_body(&self, request: Request, expected_body: &str) -> Result<()> {
let mut response = self.exec(request); let mut response = self.exec(request);
let mut buf = String::new(); let body = read_to_string(response.body_mut())?;
response.body_mut().read_to_string(&mut buf)?; assert_eq!(response.status(), Status::OK, "Error message: {body}");
assert_eq!(response.status(), Status::OK, "Error message: {buf}"); assert_eq!(&body, expected_body);
assert_eq!(&buf, expected_body);
Ok(()) Ok(())
} }
} }

Loading…
Cancel
Save