package sihl

  1. Overview
  2. Docs
The modular functional web framework

Install

Dune Dependency

Authors

Maintainers

Sources

sihl-queue-0.1.5.tbz
sha256=bfa7bde9af02bb83d5ca39d54797b05b43317f033d93d24ca86ca42ff8ef83a1
sha512=6bb8727f65116e8042aa1fb77b3c14851ce5238f7b412adadf0f8e5b52d5310e8f06056c96bf76a82ffd7096753f49b2b0482f41e18ee1ca94310b874fe81bf9

doc/src/sihl.middleware/middleware_session.ml.html

Source file middleware_session.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
open Lwt.Syntax

module Make (SessionService : Session.Sig.SERVICE) = struct
  let m ?(cookie_key = "session_key") () =
    let filter handler ctx =
      match Http.Req.cookie_data ctx ~key:cookie_key with
      | Some session_key ->
        (* A session cookie was found *)
        let* session = SessionService.find_opt ctx ~key:session_key in
        (match session with
        | Some session ->
          let* session =
            if Session.is_expired (Ptime_clock.now ()) session
            then (
              Logs.debug (fun m -> m "SESSION: Session expired, creating new one");
              let* session = SessionService.create ctx [] in
              Lwt.return session)
            else Lwt.return session
          in
          let ctx = SessionService.add_to_ctx session ctx in
          handler ctx
        | None ->
          let* session = SessionService.create ctx [] in
          let ctx = SessionService.add_to_ctx session ctx in
          let* res = handler ctx in
          res |> Http.Res.set_cookie ~key:cookie_key ~data:session.key |> Lwt.return)
      | None ->
        (* No session cookie found *)
        let* session = SessionService.create ctx [] in
        let ctx = SessionService.add_to_ctx session ctx in
        let* res = handler ctx in
        res |> Http.Res.set_cookie ~key:cookie_key ~data:session.key |> Lwt.return
    in
    Middleware_core.create ~name:"session" filter
  ;;
end
OCaml

Innovation. Community. Security.