partially correct cors, cookies works

This commit is contained in:
L-Nafaryus 2024-03-15 19:21:13 +05:00
parent fb83b42393
commit 721b1963a1
Signed by: L-Nafaryus
GPG Key ID: 582F8B0866B294A1
5 changed files with 27 additions and 11 deletions

View File

@ -1,8 +1,21 @@
use npm_rs::*; use npm_rs::*;
use std::{fs, io};
fn main() { fn main() {
// TODO: add cargo:rerun-if-changed for important files // TODO: add cargo:rerun-if-changed for important files
let paths = fs::read_dir(".")
.unwrap()
.filter(|entry| entry.is_ok())
.map(|file| file.map(|e| e.path()))
.collect::<Result<Vec<_>, io::Error>>()
.unwrap();
/*for path in paths {
println!("cargo:rerun-if-changed={}", path.to_str().unwrap());
}*/
//println!("cargo:rerun-if-changed=src/main.ts");
NpmEnv::default() NpmEnv::default()
.with_node_env(&NodeEnv::from_cargo_profile().unwrap_or_default()) .with_node_env(&NodeEnv::from_cargo_profile().unwrap_or_default())
.with_env("FOO", "bar") .with_env("FOO", "bar")

View File

@ -4,22 +4,22 @@ const password = defineModel("password")
async function login() { async function login() {
const response = await fetch( const response = await fetch(
"http://localhost:54600/api/v1/login_user", "http://0.0.0.0:54600/api/v1/login_user",
{ {
method: "POST", method: "POST",
headers: { headers: {
//Accept: 'application/json', //Accept: 'application/json',
"Content-Type": "application/json", "Content-Type": "application/json",
//"Access-Control-Allow-Origin": "http://0.0.0.0"
}, },
credentials: "same-origin", credentials: "include",
mode: "cors", mode: "cors",
body: JSON.stringify({ email: email.value, password: password.value }) body: JSON.stringify({ email: email.value, password: password.value })
} }
); );
console.log(response.headers.getSetCookie()); let { status, token } = await response.json();
const data = await response.json(); console.log(status);
console.log(data);
} }
</script> </script>

View File

@ -2,5 +2,6 @@ import { createApp } from 'vue'
import App from './App.vue' import App from './App.vue'
import './assets/style.css' import './assets/style.css'
const app = createApp(App) const app = createApp(App)
app.mount('#app') app.mount('#app')

View File

@ -173,7 +173,8 @@ pub async fn login_user(
let cookie = Cookie::build(("token", token.to_owned())) let cookie = Cookie::build(("token", token.to_owned()))
.path("/") .path("/")
.max_age(time::Duration::hours(1)) .max_age(time::Duration::hours(1))
.same_site(SameSite::Lax) .same_site(SameSite::None)
.secure(true)
.http_only(true); .http_only(true);
let mut response = let mut response =
@ -189,7 +190,8 @@ pub async fn logout_user() -> Result<impl IntoResponse, (StatusCode, Json<serde_
let cookie = Cookie::build(("token", "")) let cookie = Cookie::build(("token", ""))
.path("/") .path("/")
.max_age(time::Duration::hours(-1)) .max_age(time::Duration::hours(-1))
.same_site(SameSite::Lax) .same_site(SameSite::None)
.secure(true)
.http_only(true); .http_only(true);
let mut response = Response::new(serde_json::json!({"status": "success"}).to_string()); let mut response = Response::new(serde_json::json!({"status": "success"}).to_string());

View File

@ -64,10 +64,10 @@ async fn main() {
let lister = tokio::net::TcpListener::bind(&address).await.unwrap(); let lister = tokio::net::TcpListener::bind(&address).await.unwrap();
let cors = CorsLayer::new() let cors = CorsLayer::new()
.allow_methods([Method::GET, Method::POST]) .allow_methods([Method::GET, Method::POST, Method::OPTIONS])
.allow_headers(Any) //vec![ORIGIN, AUTHORIZATION, ACCEPT]) .allow_headers(vec![ORIGIN, AUTHORIZATION, ACCEPT, CONTENT_TYPE])
.allow_origin(Any); .allow_origin("http://0.0.0.0:54600".parse::<HeaderValue>().unwrap()) //Any)
//.allow_credentials(true); //"http://localhost:5173".parse::<HeaderValue>().unwrap()); .allow_credentials(true); //"http://localhost:5173".parse::<HeaderValue>().unwrap());
let app = Router::new() let app = Router::new()
.route("/", get(home)) .route("/", get(home))