Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: document cohttp-server-lwt-unix #1049

Merged
merged 1 commit into from
Jun 30, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ libraries:
* `Cohttp_curl` uses `libcurl`, via `ocurl`, as backend. It also comes
with lwt (`Cohttp_curl_lwt`) and async backends (`Cohttp_curl_async`).
* `Cohttp_eio` uses `eio` to leverage new features from multicore ocaml 5.0.
* `Cohttp_server_lwt_unix` uses lwt to implement a more efficient web server
with a minimal interface.

You can implement other targets using the parser very easily. Look at the `IO`
signature in `lib/s.mli` and implement that in the desired backend.
Expand Down
68 changes: 68 additions & 0 deletions cohttp-server-lwt-unix/src/cohttp_server_lwt_unix.mli
Original file line number Diff line number Diff line change
@@ -1,34 +1,102 @@
(** High performance lwt server

This module is an alternative to the server offered in
[Cohttp_lwt_unix.Server]. It's a simplified implementation that has less
functionality but offers more control and better performance. The
differences are as follows:

- Vastly improved performance due to optimized buffer handling
- No dependency on conduit
- No builtin logging

An example server: {[
open Lwt.Syntax

let server_callback ctx =
Lwt.join
[
Cohttp_server_lwt_unix.ontext.discard_body ctx;
Cohttp_server_lwt_unix.ontext.respond ctx
(Http.Response.make ())
(Cohttp_server_lwt_unix.Body.string "hello world");
]

let main () =
let* _server =
let listen_address = Unix.(ADDR_INET (inet_addr_loopback, 8080)) in
let server = Cohttp_server_lwt_unix.create server_callback in
Lwt_io.establish_server_with_client_address ~backlog:10_000 listen_address
(fun _addr ch -> Cohttp_server_lwt_unix.handle_connection server ch)
in
let forever, _ = Lwt.wait () in
forever

let () = ignore (Lwt_main.run (main ()))
]}
*)

module Body : sig
module Encoding : sig
type t
(** HTTP body encoding *)

val fixed : int64 -> t
val chunked : t
end

type t
(** A response body *)

val string : ?encoding:Encoding.t -> string -> t
(** [string ?encoding s] respond with body [s].

[?encoding] the encoding to use. by default this is [Encoding.fixed] *)

module Substring : sig
type t = { base : string; pos : int; len : int }
end

val stream : ?encoding:Encoding.t -> (unit -> Substring.t option Lwt.t) -> t
(** [stream ?encoding f] respond with body generated by repeatedly applying
[f]. When [f] returns [None], it will be considered terminated.

[?encoding] is the encoding to use. By deafult this is [Encoding.chunked]. *)
end

module Context : sig
type t
(** A request context *)

val request : t -> Http.Request.t
(** [request t] returns the HTTP request *)

val read_body : t -> string Lwt.t
(** [read_body t] read the request body as a string *)

val discard_body : t -> unit Lwt.t
(** [discard_body t] discard the request body *)

val respond : t -> Http.Response.t -> Body.t -> unit Lwt.t
(** [respond t response body] respond to the request with [response] and
[body] *)
end

type t
(** The type of an HTTP server able to handle requests. *)

val create : ?on_exn:(exn -> unit) -> (Context.t -> unit Lwt.t) -> t
(** [create ?on_exn f] creates an HTTP server that will handle every incoming
request with [f] concurrently.

[on_exn] will be called on exceptions not caught in [f] or raisedd by the
server itself. If [on_exn] isn't provided [Lwt.async_exception_hook] will be
used. *)

val handle_connection :
t -> Lwt_io.input_channel * Lwt_io.output_channel -> unit Lwt.t
(** [handle_connection t (i, o)] will handle all HTTP requests incoming from [i]
and write them to [o].

This function should be used with
[Lwt_io.establish_server_with_client_address] to setup a running HTTP
server. *)
Loading