apimock_server/
respond_response.rs1use apimock_routing::{ParsedRequest, Respond};
12use console::style;
13use std::path::Path;
14
15use crate::{
16 http_util::delay_response,
17 response::{
18 error_response::internal_server_error_response,
19 file_response::FileResponse,
20 status_code_response::{status_code_response, status_code_response_with_message},
21 text_response::text_response,
22 },
23 respond_util::full_file_path,
24 types::BoxBody,
25};
26
27pub async fn respond_response(
41 respond: &Respond,
42 dir_prefix: &str,
43 parsed_request: &ParsedRequest,
44) -> Result<hyper::Response<BoxBody>, hyper::http::Error> {
45 if let Some(delay_ms) = respond.delay_response_milliseconds {
46 delay_response(delay_ms).await;
47 }
48
49 let request_headers = &parsed_request.component_parts.headers;
50
51 if let Some(file_path) = respond.file_path.as_ref() {
53 let Some(full_file_path) = full_file_path(file_path.as_str(), dir_prefix) else {
54 log::error!(
55 "{}:\n{} (prefix = {})",
56 style("file not found").red(),
57 file_path,
58 dir_prefix,
59 );
60 return internal_server_error_response(
61 "failed to get response file",
62 request_headers,
63 );
64 };
65
66 let _ = Path::new(dir_prefix);
69
70 return FileResponse::new_with_csv_records_jsonpath(
71 full_file_path.as_str(),
72 respond.headers.as_ref(),
73 respond.csv_records_key.clone(),
74 request_headers,
75 )
76 .file_content_response()
77 .await;
78 }
79
80 if let Some(text) = respond.text.as_ref() {
81 return match respond.status_code.as_ref() {
82 Some(status_code) => {
83 status_code_response_with_message(status_code, text.as_str(), request_headers)
84 }
85 None => text_response(text.as_str(), None, respond.headers.as_ref(), request_headers),
86 };
87 }
88
89 if let Some(status_code) = respond.status_code.as_ref() {
90 return status_code_response(status_code, request_headers);
91 }
92
93 internal_server_error_response("invalid respond def", request_headers)
94}