-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapi_server.ml
49 lines (42 loc) · 1.4 KB
/
api_server.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
37
38
39
40
41
42
43
44
45
46
47
open Core
open Async
open Cohttp_async
open Merkle
(* given filename: api_server.ml compile with:
* $ dune build api_server.exe
*)
let handler ~body:_ _sock req =
let uri = Cohttp.Request.uri req in
match Uri.path uri with
| "/test" ->
Uri.get_query_param uri "hello"
|> Option.map ~f:(fun v -> "hello: " ^ v)
|> Option.value ~default:"No param hello supplied"
|> Server.respond_string
| "/merkle" ->
Uri.get_query_param' uri "txs"
|> Option.value ~default:[]
|> ( let debug_param = Uri.get_query_param uri "debug" in
let debug_str = Option.value ~default:"false" debug_param in
let debug = match bool_of_string_opt debug_str with
| None -> false
| Some x -> x
in Tree.of_txs ~debug:debug )
|> Tree.to_json
|> Server.respond_string
| _ ->
Server.respond_string ~status:`Not_found "Route not found"
let start_server port () =
eprintf "Listening for HTTP on port %d\n" port;
eprintf "Try 'curl http://localhost:%d/merkle?txs=x,y,z'\n%!" port;
Cohttp_async.Server.create ~on_handler_error:`Raise
(Tcp.Where_to_listen.of_port port) handler
>>= fun _ -> Deferred.never ()
let () =
Command.async_spec
~summary:"Start a hello world Async server"
Command.Spec.(empty +>
flag "-p" (optional_with_default 8080 int)
~doc:"int Source port to listen on"
) start_server
|> Command.run