diff options
Diffstat (limited to 'bin/mainlite.ml')
-rw-r--r-- | bin/mainlite.ml | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/bin/mainlite.ml b/bin/mainlite.ml new file mode 100644 index 0000000..3fd7e0f --- /dev/null +++ b/bin/mainlite.ml @@ -0,0 +1,40 @@ +open Eio +open Piaf + +let setup_log ?style_renderer level = + Logs_threaded.enable (); + Fmt_tty.setup_std_outputs ?style_renderer (); + Logs.set_level ~all:true level; + Logs.set_reporter (Logs_fmt.reporter ()) +;; + +let request_handler ~db_pool Server.{ request; _ } = + match Combattant.Router.match_route request.meth request.target with + | Some handler -> Result.get_ok @@ handler db_pool request + | None -> + Logs.info (fun d -> d "Não encontrei %S\n" request.target); + Response.create `Not_found +;; + +let () = + setup_log (Some Logs.Info); + Eio_main.run + @@ fun env -> + Switch.run + @@ fun sw -> + let config = + let interface = Net.Ipaddr.V4.any in + let port = 4455 in + `Tcp (interface, port) + in + let config = Server.Config.create config in + let db_uri = + Uri.make ~scheme:"sqlite3" ~path:"/home/y/code/ocaml/combattant/bulkdata/blog.db" () + in + match Caqti_eio_unix.connect_pool ~sw ~stdenv:(env :> Caqti_eio.stdenv) db_uri with + | Ok pool -> + let server = Server.create ~config (request_handler ~db_pool:pool) in + ignore @@ Server.Command.start ~sw env server + | Error err -> + Logs.err (fun m -> m "Error connecting to database: %a" Caqti_error.pp err) +;; |