From 6f874c2bfd0cfc8ba1f9d59cf594c445216edaee Mon Sep 17 00:00:00 2001 From: Shon Feder Date: Thu, 28 Nov 2024 20:59:08 -0500 Subject: [PATCH] Update for cohttp 6 Response API Cohttp 6 introduced a breaking change to the `Response` API dropping `flush` in https://github.com/mirage/ocaml-cohttp/pull/1052 This updates our usage to be compatible. --- Dockerfile.web | 2 +- opam-repo-ci-web.opam | 2 +- web-ui/github.ml | 5 ++--- 3 files changed, 4 insertions(+), 5 deletions(-) diff --git a/Dockerfile.web b/Dockerfile.web index f3e4154c..18884731 100644 --- a/Dockerfile.web +++ b/Dockerfile.web @@ -1,7 +1,7 @@ FROM ocaml/opam:debian-12-ocaml-4.14 AS build RUN sudo ln -f /usr/bin/opam-2.1 /usr/bin/opam && opam init --reinit -ni RUN sudo apt-get update && sudo apt-get install libev-dev capnproto m4 pkg-config libgmp-dev libffi-dev -y --no-install-recommends -RUN cd ~/opam-repository && git fetch origin master && git reset --hard 2dff29abd6cda0706f80503db11dd4af4e7db559 && opam update +RUN cd ~/opam-repository && git fetch origin master && git reset --hard 65a1519b6d82a358204a1a33b6d84821d56da6bd && opam update COPY --chown=opam opam-repo-ci-api.opam opam-repo-ci-web.opam opam-repo-ci-service.opam opam-ci-check.opam /src/ WORKDIR /src RUN opam install -y --deps-only . diff --git a/opam-repo-ci-web.opam b/opam-repo-ci-web.opam index b06a771b..0268fcc5 100644 --- a/opam-repo-ci-web.opam +++ b/opam-repo-ci-web.opam @@ -29,7 +29,7 @@ depends: [ "prometheus-app" "cmdliner" {>= "1.1.0"} "lwt" - "cohttp-lwt-unix" {>= "2.2.0"} + "cohttp-lwt-unix" {>= "6.0.0"} "mirage-crypto-rng" {>= "0.11.0"} "tyxml" "capnp-rpc-unix" diff --git a/web-ui/github.ml b/web-ui/github.ml index 03ee51fe..609d3dc5 100644 --- a/web-ui/github.ml +++ b/web-ui/github.ml @@ -283,10 +283,9 @@ module Repo_handle = struct (* Otherwise, an nginx reverse proxy will wait for the whole log before sending anything. *) Cohttp.Header.init_with "X-Accel-Buffering" "no" in - let res = Cohttp.Response.make ~status:`OK ~flush:true ~encoding:Cohttp.Transfer.Chunked ~headers () in + let res = Cohttp.Response.make ~status:`OK ~encoding:Cohttp.Transfer.Chunked ~headers () in let write _ic oc = - let flush = Cohttp.Response.flush res in - let writer = Transfer_IO.make_writer ~flush Cohttp.Transfer.Chunked oc in + let writer = Transfer_IO.make_writer ~flush:true Cohttp.Transfer.Chunked oc in Lwt.finalize (fun () -> stream_logs job ~owner ~name ~refs ~hash ~variant ~status chunk writer >>= fun () ->