From 028026bfdc274afb675479ec82e125b161b9513b Mon Sep 17 00:00:00 2001 From: Tyler Murphy Date: Tue, 31 Jan 2023 22:57:39 -0500 Subject: [PATCH] remove b64 imgs --- Cargo.lock | 11 -------- Cargo.toml | 1 - public/css/home.css | 2 +- public/css/main.css | 4 +-- public/css/profile.css | 2 +- public/image/arrow.png | Bin 0 -> 153 bytes public/image/change.png | Bin 0 -> 6144 bytes public/image/close.png | Bin 0 -> 170 bytes public/image/icons.png | Bin 0 -> 6181 bytes public/js/main.js | 4 +-- src/main.rs | 7 ++--- src/types/extract.rs | 60 ++++++++++++++++++++++++++++++++++++---- 12 files changed, 64 insertions(+), 27 deletions(-) create mode 100644 public/image/arrow.png create mode 100644 public/image/change.png create mode 100644 public/image/close.png create mode 100644 public/image/icons.png diff --git a/Cargo.lock b/Cargo.lock index 7b16e84..c5e1ac7 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -70,16 +70,6 @@ dependencies = [ "tower-service", ] -[[package]] -name = "axum-client-ip" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ddfb5a3ddd6367075d50629546fb46710584016ae7704cd03b6d41cb5be82e5a" -dependencies = [ - "axum", - "forwarded-header-value", -] - [[package]] name = "axum-core" version = "0.3.2" @@ -1724,7 +1714,6 @@ name = "xssbook" version = "0.0.1" dependencies = [ "axum", - "axum-client-ip", "bytes", "image", "lazy_static", diff --git a/Cargo.toml b/Cargo.toml index 272112f..55be8cf 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -6,7 +6,6 @@ edition = "2021" [dependencies] tokio = { version = "1.23.0", features = ["full"] } axum = { version = "0.6.4", features = ["headers", "query"] } -axum-client-ip = "0.3.1" tower-http = { version = "0.3.5", features = ["fs"] } tower_governor = "0.0.4" tower-cookies = "0.8.0" diff --git a/public/css/home.css b/public/css/home.css index b68314d..60dc3a5 100644 --- a/public/css/home.css +++ b/public/css/home.css @@ -80,7 +80,7 @@ body { } .icons { - background-image: url(''); + background-image: url('/images/icons.png'); display: inline-block; width: 18px; height: 18px; diff --git a/public/css/main.css b/public/css/main.css index 1926ed9..0314b3f 100644 --- a/public/css/main.css +++ b/public/css/main.css @@ -188,7 +188,7 @@ select { border: 1px solid var(--light); color: var(--extreme); font-size: 15px; - background-image: url(""); + background-image: url("/image/arrow.png"); background-position: right 10px center; background-repeat: no-repeat; background-size: 15px; @@ -291,7 +291,7 @@ footer { cursor: pointer; background-size: 20px; background-position: right; - background-image: url(''); + background-image: url('/image/close.png'); } .hidden { diff --git a/public/css/profile.css b/public/css/profile.css index 1077919..4aff91b 100644 --- a/public/css/profile.css +++ b/public/css/profile.css @@ -67,7 +67,7 @@ body { background-color: var(--secondary); z-index: 10000 !important; text-align: center; - background-image: url(''); + background-image: url('/image/change.png'); cursor: pointer; } diff --git a/public/image/arrow.png b/public/image/arrow.png new file mode 100644 index 0000000000000000000000000000000000000000..8220278a3196ee288b6036e48768484fb3f580cb GIT binary patch literal 153 zcmeAS@N?(olHy`uVBq!ia0vp^5+KaP3?%1DUd;wlJOMr-u0ENCtT1rw$KeG)apsaB zzhH*>1u?6X&4FA?PZ!4!j_A1uH}WZFk3E{XVMw7 sSg=|w?dY)=F%x(f9k}zL>hA|eIaXd5>Ed4tfrc=6y85}Sb4q9e08;5LlK=n! literal 0 HcmV?d00001 diff --git a/public/image/change.png b/public/image/change.png new file mode 100644 index 0000000000000000000000000000000000000000..1fcbfea524c684c44a49905c31ed4dbf8976fab1 GIT binary patch literal 6144 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 P-e9gy?v5q){yY8!pTU+9 literal 0 HcmV?d00001 diff --git a/public/image/close.png b/public/image/close.png new file mode 100644 index 0000000000000000000000000000000000000000..516bf05f1b522c66b98344ee28e145182196ba03 GIT binary patch literal 170 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 + return `` } function banner(id) { - return `` + return `` } const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', diff --git a/src/main.rs b/src/main.rs index 74f0a0b..e8f17b0 100644 --- a/src/main.rs +++ b/src/main.rs @@ -5,14 +5,13 @@ use axum::{ response::Response, RequestExt, Router, extract::DefaultBodyLimit, }; -use axum_client_ip::ClientIp; use std::{net::SocketAddr, process::exit, fs}; use tower_cookies::CookieManagerLayer; use tracing::{error, info, metadata::LevelFilter}; use tracing_subscriber::{ filter::filter_fn, prelude::__tracing_subscriber_SubscriberExt, util::SubscriberInitExt, Layer, }; -use types::http::ResponseCode; +use types::{http::ResponseCode, extract::RequestIp}; use crate::api::{pages, image}; @@ -38,7 +37,7 @@ async fn log(mut req: Request, next: Next) -> Response where B: Send + Sync + 'static + HttpBody, { - let Ok(ClientIp(ip)) = req.extract_parts::().await else { + let Ok(RequestIp(ip)) = req.extract_parts::().await else { return next.run(req).await }; @@ -79,7 +78,7 @@ async fn main() { .layer(middleware::from_fn(serve)) .nest("/", pages::router()) .nest("/api", api::router()) - .nest("/image", image::router()) + .nest("/cdn", image::router()) .layer(CookieManagerLayer::new()) .layer(DefaultBodyLimit::max(512_000)); diff --git a/src/types/extract.rs b/src/types/extract.rs index 54f250a..4d7ac51 100644 --- a/src/types/extract.rs +++ b/src/types/extract.rs @@ -1,14 +1,13 @@ -use std::io::{Read, Cursor}; +use std::{io::{Read, Cursor}, net::{IpAddr, SocketAddr}}; use axum::{ async_trait, body::HttpBody, - extract::{FromRequest, FromRequestParts}, + extract::{FromRequest, FromRequestParts, ConnectInfo}, http::{request::Parts, Request}, response::Response, BoxError, RequestExt, }; -use axum_client_ip::ClientIp; use bytes::Bytes; use image::{io::Reader, ImageFormat, DynamicImage}; use serde::de::DeserializeOwned; @@ -23,6 +22,57 @@ use crate::{ }, }; +pub struct RequestIp(pub IpAddr); + +#[async_trait] +impl FromRequestParts for RequestIp +where + S: Send + Sync, +{ + type Rejection = Response; + + async fn from_request_parts(parts: &mut Parts, _state: &S) -> Result { + + let headers = &parts.headers; + + let forwardedfor = headers.get("x-forwarded-for") + .and_then(|h| h.to_str().ok()) + .and_then(|h| + h.split(',') + .rev() + .find_map(|s| s.trim().parse::().ok()) + ); + + if let Some(forwardedfor) = forwardedfor { + return Ok(RequestIp(forwardedfor)) + } + + let realip = headers.get("x-real-ip") + .and_then(|hv| hv.to_str().ok()) + .and_then(|s| s.parse::().ok()); + + if let Some(realip) = realip { + return Ok(RequestIp(realip)) + } + + let realip = headers.get("x-real-ip") + .and_then(|hv| hv.to_str().ok()) + .and_then(|s| s.parse::().ok()); + + if let Some(realip) = realip { + return Ok(RequestIp(realip)) + } + + let info = parts.extensions.get::>(); + + if let Some(info) = info { + return Ok(RequestIp(info.0.ip())) + } + + Err(ResponseCode::Forbidden.text("You have no ip")) + } +} + pub struct AuthorizedUser(pub User); #[async_trait] @@ -189,7 +239,7 @@ where S: Send + Sync, { - let Ok(ClientIp(ip)) = req.extract_parts::().await else { + let Ok(RequestIp(ip)) = req.extract_parts::().await else { tracing::error!("Failed to read client ip"); return Err(ResponseCode::InternalServerError.text("Failed to read client ip")); }; @@ -224,7 +274,7 @@ where B::Error: Into, S: Send + Sync, { - let Ok(ClientIp(ip)) = req.extract_parts::().await else { + let Ok(RequestIp(ip)) = req.extract_parts::().await else { tracing::error!("Failed to read client ip"); return Err(ResponseCode::InternalServerError.text("Failed to read client ip")); };