partially correct cors, cookies works
This commit is contained in:
parent
fb83b42393
commit
721b1963a1
@ -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")
|
||||||
|
@ -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>
|
||||||
|
|
||||||
|
@ -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')
|
||||||
|
@ -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());
|
||||||
|
@ -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))
|
||||||
|
Loading…
Reference in New Issue
Block a user