diff options
author | Colin Reeder <vpzomtrrfrt@gmail.com> | 2020-09-27 12:21:37 -0600 |
---|---|---|
committer | Colin Reeder <vpzomtrrfrt@gmail.com> | 2020-09-27 12:21:37 -0600 |
commit | ccae2cb90ac79f1c138d1a5e5da6cb0f20b50607 (patch) | |
tree | 96cd9d2d52ab61351412becddcb72253ad7b6a6c /src | |
parent | af6366c336ee4ded8200362adb3f9e7156601ec1 (diff) |
Add logout button in header
Diffstat (limited to 'src')
-rw-r--r-- | src/components/mod.rs | 5 | ||||
-rw-r--r-- | src/routes/mod.rs | 36 |
2 files changed, 41 insertions, 0 deletions
diff --git a/src/components/mod.rs b/src/components/mod.rs index 255f38a..9f7db1f 100644 --- a/src/components/mod.rs +++ b/src/components/mod.rs @@ -248,6 +248,11 @@ pub fn HTPage<'a, Children: render::Render>( <a href={format!("/users/{}", login.user.id)}> {hitide_icons::PERSON.img()} </a> + <form method={"POST"} action={"/logout"} class={"inline"}> + <button type={"submit"} class={"iconbutton"}> + {hitide_icons::LOGOUT.img()} + </button> + </form> </> }) } else { diff --git a/src/routes/mod.rs b/src/routes/mod.rs index 5fde279..d2718e9 100644 --- a/src/routes/mod.rs +++ b/src/routes/mod.rs @@ -719,6 +719,38 @@ async fn handler_login_submit( } } +async fn handler_logout( + _: (), + ctx: Arc<crate::RouteContext>, + req: hyper::Request<hyper::Body>, +) -> Result<hyper::Response<hyper::Body>, crate::Error> { + let cookies = get_cookie_map_for_req(&req)?; + + res_to_error( + ctx.http_client + .request(for_client( + hyper::Request::delete(format!( + "{}/api/unstable/logins/~current", + ctx.backend_host, + )) + .body(Default::default())?, + req.headers(), + &cookies, + )?) + .await?, + ) + .await?; + + Ok(hyper::Response::builder() + .status(hyper::StatusCode::SEE_OTHER) + .header(hyper::header::LOCATION, "/") + .header( + hyper::header::SET_COOKIE, + format!("hitideToken=\"\"; Path=/; Expires=Thu, 01 Jan 1970 00:00:00 GMT"), + ) + .body("Successfully logged out.".into())?) +} + async fn page_lookup( _: (), ctx: Arc<crate::RouteContext>, @@ -1589,6 +1621,10 @@ pub fn route_root() -> crate::RouteNode<()> { ), ) .with_child( + "logout", + crate::RouteNode::new().with_handler_async("POST", handler_logout), + ) + .with_child( "lookup", crate::RouteNode::new().with_handler_async("GET", page_lookup), ) |