mirror of
https://github.com/EFForg/rayhunter.git
synced 2026-04-28 08:29:58 -07:00
* first pass at changing the UI color based on state * adding flag to qmdl metadata for when hueristic is triggered * update style for web page to match UI and have color alert on heuristic trigger * add test analyzer * rename example_analyzer to test_analyzer * refactor ui update to not depend on server * refactor to pass around color instead of display state for framebuffer channel * add debug feature flag for test analyzer * remove warning status from qmdl manifest * dont keep has warning around
60 lines
2.3 KiB
Rust
60 lines
2.3 KiB
Rust
use axum::body::Body;
|
|
use axum::http::header::{CONTENT_TYPE, self};
|
|
use axum::extract::State;
|
|
use axum::http::{StatusCode, HeaderValue};
|
|
use axum::response::{Response, IntoResponse};
|
|
use axum::extract::Path;
|
|
use tokio::io::AsyncReadExt;
|
|
use tokio::sync::mpsc::Sender;
|
|
use std::sync::Arc;
|
|
use tokio::sync::RwLock;
|
|
use tokio_util::io::ReaderStream;
|
|
use include_dir::{include_dir, Dir};
|
|
|
|
use crate::{framebuffer, DiagDeviceCtrlMessage};
|
|
use crate::qmdl_store::RecordingStore;
|
|
|
|
pub struct ServerState {
|
|
pub qmdl_store_lock: Arc<RwLock<RecordingStore>>,
|
|
pub diag_device_ctrl_sender: Sender<DiagDeviceCtrlMessage>,
|
|
pub ui_update_sender: Sender<framebuffer::DisplayState>,
|
|
pub readonly_mode: bool
|
|
}
|
|
|
|
pub async fn get_qmdl(State(state): State<Arc<ServerState>>, Path(qmdl_name): Path<String>) -> Result<Response, (StatusCode, String)> {
|
|
let qmdl_store = state.qmdl_store_lock.read().await;
|
|
let entry = qmdl_store.entry_for_name(&qmdl_name)
|
|
.ok_or((StatusCode::NOT_FOUND, format!("couldn't find qmdl file with name {}", qmdl_name)))?;
|
|
let qmdl_file = qmdl_store.open_entry_qmdl(&entry).await
|
|
.map_err(|e| (StatusCode::INTERNAL_SERVER_ERROR, format!("error opening QMDL file: {}", e)))?;
|
|
let limited_qmdl_file = qmdl_file.take(entry.qmdl_size_bytes as u64);
|
|
let qmdl_stream = ReaderStream::new(limited_qmdl_file);
|
|
|
|
let headers = [(CONTENT_TYPE, "application/octet-stream")];
|
|
let body = Body::from_stream(qmdl_stream);
|
|
Ok((headers, body).into_response())
|
|
}
|
|
|
|
// Bundles the server's static files (html/css/js) into the binary for easy distribution
|
|
static STATIC_DIR: Dir<'_> = include_dir!("$CARGO_MANIFEST_DIR/static");
|
|
|
|
pub async fn serve_static(Path(path): Path<String>) -> impl IntoResponse {
|
|
let path = path.trim_start_matches('/');
|
|
let mime_type = mime_guess::from_path(path).first_or_text_plain();
|
|
|
|
match STATIC_DIR.get_file(path) {
|
|
None => Response::builder()
|
|
.status(StatusCode::NOT_FOUND)
|
|
.body(Body::empty())
|
|
.unwrap(),
|
|
Some(file) => Response::builder()
|
|
.status(StatusCode::OK)
|
|
.header(
|
|
header::CONTENT_TYPE,
|
|
HeaderValue::from_str(mime_type.as_ref()).unwrap(),
|
|
)
|
|
.body(Body::from(file.contents()))
|
|
.unwrap(),
|
|
}
|
|
}
|