Fix all Errors n Warns
This commit is contained in:
parent
9ef4176091
commit
a60713a4b0
36
Cargo.lock
generated
36
Cargo.lock
generated
@ -55,9 +55,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "async-trait"
|
name = "async-trait"
|
||||||
version = "0.1.77"
|
version = "0.1.81"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c980ee35e870bd1a4d2c8294d4c04d0499e67bca1e4b5cefcc693c2fa00caea9"
|
checksum = "6e0c28dcc82d7c8ead5cb13beb15405b57b8546e93215673ff8ca0349a028107"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
@ -99,12 +99,11 @@ checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bb8"
|
name = "bb8"
|
||||||
version = "0.8.1"
|
version = "0.8.5"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "98b4b0f25f18bcdc3ac72bdb486ed0acf7e185221fd4dc985bc15db5800b0ba2"
|
checksum = "b10cf871f3ff2ce56432fddc2615ac7acc3aa22ca321f8fea800846fbb32f188"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"futures-channel",
|
|
||||||
"futures-util",
|
"futures-util",
|
||||||
"parking_lot",
|
"parking_lot",
|
||||||
"tokio",
|
"tokio",
|
||||||
@ -340,12 +339,10 @@ version = "0.3.30"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48"
|
checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"futures-channel",
|
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"futures-task",
|
"futures-task",
|
||||||
"pin-project-lite",
|
"pin-project-lite",
|
||||||
"pin-utils",
|
"pin-utils",
|
||||||
"slab",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -616,9 +613,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "itoa"
|
name = "itoa"
|
||||||
version = "1.0.10"
|
version = "1.0.11"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b1a46d1a171d865aa5f83f92695765caa047a9b4cbae2cbf37dbd613a793fd4c"
|
checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "js-sys"
|
name = "js-sys"
|
||||||
@ -715,11 +712,10 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "native-tls"
|
name = "native-tls"
|
||||||
version = "0.2.11"
|
version = "0.2.12"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "07226173c32f2926027b63cce4bcd8076c3552846cbe7925f3aaffeac0a3b92e"
|
checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"lazy_static",
|
|
||||||
"libc",
|
"libc",
|
||||||
"log",
|
"log",
|
||||||
"openssl",
|
"openssl",
|
||||||
@ -1226,9 +1222,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "sky-derive"
|
name = "sky-derive"
|
||||||
version = "0.2.2"
|
version = "0.2.3"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "8a5d926a1f01fa0f21cf9ba651777b78e0a8a236be400d94cbb03396f5e22287"
|
checksum = "653a697e7fcd1ecf5f9af1d3277d6d48290f29f076cb0190011eb09cff2238ea"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
@ -1237,9 +1233,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "skytable"
|
name = "skytable"
|
||||||
version = "0.8.6"
|
version = "0.8.10"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "03e8d2a2164bdf8d5612caf70c31baf3ae905bc7bc4292dd631cfbe67eb097a9"
|
checksum = "6ad7801f368596253646e42e1a11360431d115ab576fffa26e5da08e6ddb9d8d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"bb8",
|
"bb8",
|
||||||
@ -1390,9 +1386,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio"
|
name = "tokio"
|
||||||
version = "1.35.1"
|
version = "1.38.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c89b4efa943be685f629b149f53829423f8f5531ea21249408e8e2f8671ec104"
|
checksum = "ba4f4a02a7a80d6f274636f0aa95c7e383b912d41fe721a31f29e29698585a4a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"backtrace",
|
"backtrace",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -1409,9 +1405,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio-macros"
|
name = "tokio-macros"
|
||||||
version = "2.2.0"
|
version = "2.3.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b"
|
checksum = "5f5ae998a069d4b5aba8ee9dad856af7d520c3699e6159b185c2acd48155d39a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
|
@ -16,7 +16,7 @@ jsonwebtoken = "9.2.0"
|
|||||||
rand = "0.8.5"
|
rand = "0.8.5"
|
||||||
rsa = "0.9.6"
|
rsa = "0.9.6"
|
||||||
serde_json = "1.0.111"
|
serde_json = "1.0.111"
|
||||||
skytable = "0.8.6"
|
skytable = "0.8.10"
|
||||||
tokio = { version = "1.35.1", features = ["full"] }
|
tokio = { version = "1.35.1", features = ["full"] }
|
||||||
urlencoding = "2.1.3"
|
urlencoding = "2.1.3"
|
||||||
uuid = { version = "1.6.1", features = ["v4", "v5"] }
|
uuid = { version = "1.6.1", features = ["v4", "v5"] }
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
use {
|
use {
|
||||||
std::{
|
std::{
|
||||||
sync::Arc,
|
|
||||||
collections::HashMap,
|
collections::HashMap,
|
||||||
any::type_name,
|
any::type_name,
|
||||||
time::{
|
time::{
|
||||||
@ -14,6 +13,7 @@ use {
|
|||||||
chrono::DateTime,
|
chrono::DateTime,
|
||||||
serde_json::{
|
serde_json::{
|
||||||
Value as Json,
|
Value as Json,
|
||||||
|
Map as JsonMap,
|
||||||
json,
|
json,
|
||||||
},
|
},
|
||||||
rsa::{
|
rsa::{
|
||||||
@ -37,10 +37,8 @@ use {
|
|||||||
},
|
},
|
||||||
skytable::{
|
skytable::{
|
||||||
query,
|
query,
|
||||||
pool::ConnectionMgrTcp,
|
|
||||||
error::Error as SkyError,
|
error::Error as SkyError,
|
||||||
},
|
},
|
||||||
bb8::Pool,
|
|
||||||
http_body_util::BodyExt,
|
http_body_util::BodyExt,
|
||||||
hyper::{
|
hyper::{
|
||||||
Request,
|
Request,
|
||||||
@ -59,6 +57,7 @@ use {
|
|||||||
html::*,
|
html::*,
|
||||||
Users,
|
Users,
|
||||||
Sites,
|
Sites,
|
||||||
|
APIV0_LIFETIME,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -379,7 +378,7 @@ pub async fn get_user(pool: DBPool, login: String) -> Res<Users, SkyError> {
|
|||||||
Ok(q?)
|
Ok(q?)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_cookies(headers: HeaderMap) -> HashMap<String, String> {
|
pub fn get_cookies(headers: HeaderMap) -> HashMap<String, String> {
|
||||||
let header = headers.get(hyper::header::COOKIE);
|
let header = headers.get(hyper::header::COOKIE);
|
||||||
let cookies = match header.is_none() {
|
let cookies = match header.is_none() {
|
||||||
false => header.unwrap().to_str().unwrap(),
|
false => header.unwrap().to_str().unwrap(),
|
||||||
@ -389,7 +388,7 @@ fn get_cookies(headers: HeaderMap) -> HashMap<String, String> {
|
|||||||
double_split(cookies.to_owned(), ";", "=")
|
double_split(cookies.to_owned(), ";", "=")
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn authorize_user(pool: DBPool, token: String, session: String) {
|
pub async fn authorize_user(pool: DBPool, token: String, session: String) {
|
||||||
let mut con = pool.get().await.unwrap();
|
let mut con = pool.get().await.unwrap();
|
||||||
|
|
||||||
let data: JsonMap<String, Json> = jwt_verify(pool.clone(), &token)
|
let data: JsonMap<String, Json> = jwt_verify(pool.clone(), &token)
|
||||||
|
31
src/main.rs
31
src/main.rs
@ -10,18 +10,13 @@ use {
|
|||||||
collections::HashMap,
|
collections::HashMap,
|
||||||
process::exit,
|
process::exit,
|
||||||
},
|
},
|
||||||
chrono::{
|
|
||||||
DateTime,
|
|
||||||
},
|
|
||||||
http_body_util::{
|
http_body_util::{
|
||||||
Full,
|
Full,
|
||||||
BodyExt,
|
|
||||||
},
|
},
|
||||||
hyper::{
|
hyper::{
|
||||||
StatusCode,
|
StatusCode,
|
||||||
Request,
|
Request,
|
||||||
Response,
|
Response,
|
||||||
Method,
|
|
||||||
HeaderMap,
|
HeaderMap,
|
||||||
header::HeaderValue,
|
header::HeaderValue,
|
||||||
body::{
|
body::{
|
||||||
@ -37,28 +32,8 @@ use {
|
|||||||
tokio::{
|
tokio::{
|
||||||
net::TcpListener,
|
net::TcpListener,
|
||||||
},
|
},
|
||||||
rsa::{
|
|
||||||
pkcs1::{
|
|
||||||
EncodeRsaPublicKey,
|
|
||||||
EncodeRsaPrivateKey,
|
|
||||||
},
|
|
||||||
RsaPrivateKey,
|
|
||||||
RsaPublicKey,
|
|
||||||
},
|
|
||||||
jsonwebtoken as jwt,
|
|
||||||
jwt::{
|
|
||||||
Header,
|
|
||||||
Algorithm,
|
|
||||||
TokenData,
|
|
||||||
Validation,
|
|
||||||
EncodingKey,
|
|
||||||
DecodingKey,
|
|
||||||
encode as jwt_encode,
|
|
||||||
decode as jwt_decode,
|
|
||||||
},
|
|
||||||
serde_json::{
|
serde_json::{
|
||||||
Value as Json,
|
Value as Json,
|
||||||
Map as JsonMap,
|
|
||||||
json,
|
json,
|
||||||
},
|
},
|
||||||
skytable::{
|
skytable::{
|
||||||
@ -75,7 +50,6 @@ use {
|
|||||||
},
|
},
|
||||||
urlencoding::{
|
urlencoding::{
|
||||||
encode as url_encode,
|
encode as url_encode,
|
||||||
decode as url_decode,
|
|
||||||
},
|
},
|
||||||
crate::{
|
crate::{
|
||||||
types::{
|
types::{
|
||||||
@ -84,7 +58,6 @@ use {
|
|||||||
},
|
},
|
||||||
html::*,
|
html::*,
|
||||||
funcs::*,
|
funcs::*,
|
||||||
url,
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -97,10 +70,10 @@ type FullBytes = Result<Response<Full<Bytes>>>;
|
|||||||
const PORT: u16 = 8083;
|
const PORT: u16 = 8083;
|
||||||
|
|
||||||
const DB_POOL: u32 = 32;
|
const DB_POOL: u32 = 32;
|
||||||
const DB_ADDR: &str = "192.168.1.49";
|
const DB_ADDR: &str = "127.0.0.1";
|
||||||
const DB_PORT: u16 = 2003;
|
const DB_PORT: u16 = 2003;
|
||||||
const DB_USER: &str = "root";
|
const DB_USER: &str = "root";
|
||||||
const DB_PASS: &str = "rootpass12345678";
|
const DB_PASS: &str = "5a14775a-a490-4212345678";
|
||||||
|
|
||||||
const TOKEN_LIFETIME: u32 = 300;
|
const TOKEN_LIFETIME: u32 = 300;
|
||||||
const REFRESH_LIFETIME: u32 = 2_678_400;
|
const REFRESH_LIFETIME: u32 = 2_678_400;
|
||||||
|
@ -1,3 +1,22 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
Request,
|
||||||
|
body::Incoming,
|
||||||
|
Method,
|
||||||
|
StatusCode,
|
||||||
|
header::HeaderValue,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
AUTHORIZE_HTML,
|
||||||
|
DBPool,
|
||||||
|
Result,
|
||||||
|
build_html,
|
||||||
|
double_split,
|
||||||
|
authorize_user,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub async fn authorize(req: Request<Incoming>, pool: DBPool, token: String) -> Result<(String, StatusCode, HeaderValue)> {
|
pub async fn authorize(req: Request<Incoming>, pool: DBPool, token: String) -> Result<(String, StatusCode, HeaderValue)> {
|
||||||
// TODO: Forward for versions.
|
// TODO: Forward for versions.
|
||||||
if *req.method() == Method::POST {
|
if *req.method() == Method::POST {
|
||||||
|
@ -1,3 +1,15 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
StatusCode,
|
||||||
|
header::HeaderValue,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
INDEX_HTML,
|
||||||
|
build_html,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub fn index() -> (String, StatusCode, HeaderValue) {
|
pub fn index() -> (String, StatusCode, HeaderValue) {
|
||||||
let restype: HeaderValue = "text/html".parse().unwrap();
|
let restype: HeaderValue = "text/html".parse().unwrap();
|
||||||
(build_html(INDEX_HTML), StatusCode::OK, restype)
|
(build_html(INDEX_HTML), StatusCode::OK, restype)
|
||||||
|
@ -1,96 +1,25 @@
|
|||||||
use {
|
use {
|
||||||
std::{
|
|
||||||
sync::Arc,
|
|
||||||
net::SocketAddr,
|
|
||||||
collections::HashMap,
|
|
||||||
process::exit,
|
|
||||||
},
|
|
||||||
chrono::{
|
|
||||||
DateTime,
|
|
||||||
},
|
|
||||||
http_body_util::{
|
|
||||||
Full,
|
|
||||||
BodyExt,
|
|
||||||
},
|
|
||||||
hyper::{
|
hyper::{
|
||||||
StatusCode,
|
StatusCode,
|
||||||
Request,
|
Request,
|
||||||
Response,
|
|
||||||
Method,
|
Method,
|
||||||
HeaderMap,
|
HeaderMap,
|
||||||
header::HeaderValue,
|
header::HeaderValue,
|
||||||
body::{
|
body::{
|
||||||
Bytes,
|
|
||||||
Incoming,
|
Incoming,
|
||||||
},
|
},
|
||||||
server::conn::http1 as Server,
|
|
||||||
service::service_fn,
|
|
||||||
},
|
|
||||||
hyper_util::{
|
|
||||||
rt::TokioIo,
|
|
||||||
},
|
|
||||||
tokio::{
|
|
||||||
net::TcpListener,
|
|
||||||
},
|
|
||||||
rsa::{
|
|
||||||
pkcs1::{
|
|
||||||
EncodeRsaPublicKey,
|
|
||||||
EncodeRsaPrivateKey,
|
|
||||||
},
|
|
||||||
RsaPrivateKey,
|
|
||||||
RsaPublicKey,
|
|
||||||
},
|
|
||||||
jsonwebtoken as jwt,
|
|
||||||
jwt::{
|
|
||||||
Header,
|
|
||||||
Algorithm,
|
|
||||||
TokenData,
|
|
||||||
Validation,
|
|
||||||
EncodingKey,
|
|
||||||
DecodingKey,
|
|
||||||
encode as jwt_encode,
|
|
||||||
decode as jwt_decode,
|
|
||||||
},
|
|
||||||
serde_json::{
|
|
||||||
Value as Json,
|
|
||||||
Map as JsonMap,
|
|
||||||
json,
|
|
||||||
},
|
|
||||||
skytable::{
|
|
||||||
query,
|
|
||||||
Config,
|
|
||||||
pool::{
|
|
||||||
self,
|
|
||||||
ConnectionMgrTcp
|
|
||||||
},
|
|
||||||
error::Error as SkyError,
|
|
||||||
},
|
|
||||||
bb8::{
|
|
||||||
Pool,
|
|
||||||
},
|
},
|
||||||
urlencoding::{
|
urlencoding::{
|
||||||
encode as url_encode,
|
|
||||||
decode as url_decode,
|
decode as url_decode,
|
||||||
},
|
},
|
||||||
crate::{
|
crate::{
|
||||||
types::{
|
Result,
|
||||||
users::Users,
|
DBPool,
|
||||||
sites::Sites,
|
|
||||||
},
|
|
||||||
html::*,
|
html::*,
|
||||||
funcs::*,
|
funcs::*,
|
||||||
url::{
|
|
||||||
api,
|
|
||||||
login,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
type Res<T, E> = std::result::Result<T, E>;
|
|
||||||
type Result<T> = std::result::Result<T, Box<dyn std::error::Error + Send + Sync>>;
|
|
||||||
type DBPool = Arc<Pool<ConnectionMgrTcp>>;
|
|
||||||
type FullBytes = Result<Response<Full<Bytes>>>;
|
|
||||||
|
|
||||||
|
|
||||||
pub async fn login(req: Request<Incoming>, pool: DBPool, headers: &mut HeaderMap) -> Result<(String, StatusCode, HeaderValue)> {
|
pub async fn login(req: Request<Incoming>, pool: DBPool, headers: &mut HeaderMap) -> Result<(String, StatusCode, HeaderValue)> {
|
||||||
let mut body = build_html(LOGIN_HTML);
|
let mut body = build_html(LOGIN_HTML);
|
||||||
|
@ -1,3 +1,15 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
StatusCode,
|
||||||
|
header::HeaderValue,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
NF_HTML,
|
||||||
|
build_html,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub fn nf() -> (String, StatusCode, HeaderValue) {
|
pub fn nf() -> (String, StatusCode, HeaderValue) {
|
||||||
let restype: HeaderValue = "text/html".parse().unwrap();
|
let restype: HeaderValue = "text/html".parse().unwrap();
|
||||||
(build_html(NF_HTML), StatusCode::NOT_FOUND, restype)
|
(build_html(NF_HTML), StatusCode::NOT_FOUND, restype)
|
||||||
|
@ -1,3 +1,15 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
StatusCode,
|
||||||
|
header::HeaderValue,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
build_html,
|
||||||
|
RECOVER_HTML,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub fn recover() -> (String, StatusCode, HeaderValue) {
|
pub fn recover() -> (String, StatusCode, HeaderValue) {
|
||||||
let restype: HeaderValue = "text/html".parse().unwrap();
|
let restype: HeaderValue = "text/html".parse().unwrap();
|
||||||
(build_html(RECOVER_HTML), StatusCode::OK, restype)
|
(build_html(RECOVER_HTML), StatusCode::OK, restype)
|
||||||
|
@ -1,3 +1,25 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
body::Incoming,
|
||||||
|
HeaderMap,
|
||||||
|
Method,
|
||||||
|
Request,
|
||||||
|
header::HeaderValue,
|
||||||
|
StatusCode,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
Result,
|
||||||
|
DBPool,
|
||||||
|
REG_HTML,
|
||||||
|
build_html,
|
||||||
|
set_location,
|
||||||
|
create_user,
|
||||||
|
double_split,
|
||||||
|
get_body_from_request,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub async fn register(req: Request<Incoming>, pool: DBPool, headers: &mut HeaderMap) -> Result<(String, StatusCode, HeaderValue)> {
|
pub async fn register(req: Request<Incoming>, pool: DBPool, headers: &mut HeaderMap) -> Result<(String, StatusCode, HeaderValue)> {
|
||||||
let mut body = "".to_owned();
|
let mut body = "".to_owned();
|
||||||
let mut status = StatusCode::OK;
|
let mut status = StatusCode::OK;
|
||||||
|
@ -1,3 +1,20 @@
|
|||||||
|
use {
|
||||||
|
hyper::{
|
||||||
|
Request,
|
||||||
|
StatusCode,
|
||||||
|
body::Incoming,
|
||||||
|
header::HeaderValue,
|
||||||
|
},
|
||||||
|
crate::{
|
||||||
|
Res,
|
||||||
|
DBPool,
|
||||||
|
SkyError,
|
||||||
|
get_user,
|
||||||
|
build_html,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
pub async fn user(req: Request<Incoming>, pool: DBPool) -> Res<(String, StatusCode, HeaderValue), SkyError> {
|
pub async fn user(req: Request<Incoming>, pool: DBPool) -> Res<(String, StatusCode, HeaderValue), SkyError> {
|
||||||
let uri: &str = req.uri().path().as_ref();
|
let uri: &str = req.uri().path().as_ref();
|
||||||
let login = &uri[2..uri.len()];
|
let login = &uri[2..uri.len()];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user