From d8b3e15bec60f58defad13e961f80354d250235d Mon Sep 17 00:00:00 2001 From: polwex Date: Sat, 14 Jun 2025 23:30:34 +0700 Subject: aaaaaa --- bs5/server/api/dune | 5 +++++ bs5/server/api/json.ml | 13 +++++++++++++ bs5/server/api/stream.ml | 18 ++++++++++++++++++ bs5/server/api/upload.ml | 37 +++++++++++++++++++++++++++++++++++++ 4 files changed, 73 insertions(+) create mode 100644 bs5/server/api/dune create mode 100644 bs5/server/api/json.ml create mode 100644 bs5/server/api/stream.ml create mode 100644 bs5/server/api/upload.ml (limited to 'bs5/server/api') diff --git a/bs5/server/api/dune b/bs5/server/api/dune new file mode 100644 index 0000000..9dc8d84 --- /dev/null +++ b/bs5/server/api/dune @@ -0,0 +1,5 @@ +(library + (name api) + (libraries dream lwt yojson) + (preprocess + (pps lwt_ppx ppx_yojson_conv))) diff --git a/bs5/server/api/json.ml b/bs5/server/api/json.ml new file mode 100644 index 0000000..3e4c68c --- /dev/null +++ b/bs5/server/api/json.ml @@ -0,0 +1,13 @@ +open Ppx_yojson_conv_lib.Yojson_conv.Primitives + +type message_object = { message : string } [@@deriving yojson] + +let routes = + [ + Dream.post "/json" (fun req -> + let%lwt body = Dream.body req in + let message_object = + body |> Yojson.Safe.from_string |> message_object_of_yojson + in + `String message_object.message |> Yojson.Safe.to_string |> Dream.json); + ] diff --git a/bs5/server/api/stream.ml b/bs5/server/api/stream.ml new file mode 100644 index 0000000..8bfaa86 --- /dev/null +++ b/bs5/server/api/stream.ml @@ -0,0 +1,18 @@ +let streams = + [ + Dream.post "/stream" (fun request -> + let request_stream = Dream.body_stream request in + + Dream.stream + ~headers:[ ("Content-Type", "application/octet-stream") ] + (fun response_stream -> + let rec loop () = + match%lwt Dream.read request_stream with + | None -> Dream.close response_stream + | Some chunk -> + let%lwt () = Dream.write response_stream chunk in + let%lwt () = Dream.flush response_stream in + loop () + in + loop ())); + ] diff --git a/bs5/server/api/upload.ml b/bs5/server/api/upload.ml new file mode 100644 index 0000000..4ba5fb7 --- /dev/null +++ b/bs5/server/api/upload.ml @@ -0,0 +1,37 @@ +(* let home request = *) +(* *) +(* *) +(*
*) +(* <%s! Dream.csrf_tag request %> *) +(* *) +(* *) +(*
*) +(* *) +(* *) + +(* let report files = *) +(* *) +(* *) +(* % files |> List.iter begin fun (name, content) -> *) +(* % let name = *) +(* % match name with *) +(* % | None -> "None" *) +(* % | Some name -> name *) +(* % in *) +(*

<%s name %>, <%i String.length content %> bytes

*) +(* % end; *) +(* *) +(* *) + +(* let uploads = *) +(* [ *) + +(* Dream.get "/" (fun request -> *) +(* Dream.html (home request)); *) + +(* Dream.post "/" (fun request -> *) +(* match%lwt Dream.multipart request with *) +(* | `Ok ["files", files] -> Dream.html (report files) *) +(* | _ -> Dream.empty `Bad_Request); *) + +(* ] *) -- cgit v1.2.3