-
Notifications
You must be signed in to change notification settings - Fork 10
/
client.ml
55 lines (51 loc) · 1.84 KB
/
client.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
48
49
50
51
52
53
54
55
(* $MDX part-begin=client-imports *)
open Grpc_lwt
open Lwt.Syntax
(* $MDX part-end *)
(* $MDX part-begin=client-hello *)
let call_server address port req =
(* Setup Http/2 connection *)
let* addresses =
Lwt_unix.getaddrinfo address (string_of_int port)
[ Unix.(AI_FAMILY PF_INET) ]
in
let socket = Lwt_unix.socket Unix.PF_INET Unix.SOCK_STREAM 0 in
let* () = Lwt_unix.connect socket (List.hd addresses).Unix.ai_addr in
let error_handler _ = print_endline "error" in
let* connection =
H2_lwt_unix.Client.create_connection ~error_handler socket
in
(* code generation *)
let open Ocaml_protoc_plugin in
let open Greeter.Mypackage in
let encode, decode = Service.make_client_functions Greeter.sayHello in
let enc = encode req |> Writer.contents in
Client.call ~service:"mypackage.Greeter" ~rpc:"SayHello"
~do_request:(H2_lwt_unix.Client.request connection ~error_handler:ignore)
~handler:
(Client.Rpc.unary enc ~f:(fun decoder ->
let+ decoder = decoder in
match decoder with
| Some decoder -> (
Reader.create decoder |> decode |> function
| Ok v -> v
| Error e ->
failwith
(Printf.sprintf "Could not decode request: %s"
(Result.show_error e)))
| None -> Greeter.SayHello.Response.make ()))
()
(* $MDX part-end *)
(* $MDX part-begin=client-main *)
let () =
let open Lwt.Syntax in
let port = 8080 in
let address = "localhost" in
let name = if Array.length Sys.argv > 1 then Sys.argv.(1) else "anonymous" in
let req = Greeter.Mypackage.HelloRequest.make ~name () in
Lwt_main.run
(let+ res = call_server address port req in
match res with
| Ok (res, _) -> print_endline res
| Error _ -> print_endline "an error occurred")
(* $MDX part-end *)