]> git.apps.os.sepia.ceph.com Git - ceph.git/commit
Fix the handling of HEAD requests that do not comply with RFC standards 59122/head
authorliubingrun <liubr1@chinatelecom.cn>
Tue, 16 Jul 2024 13:47:16 +0000 (09:47 -0400)
committerKonstantin Shalygin <k0ste@k0ste.ru>
Sat, 26 Oct 2024 08:51:01 +0000 (15:51 +0700)
commita799bf7c5fb01a194f77ff229a0609f5979671ca
treec4beef3d040104313bf35f17603e08fa27e6df1e
parent41aa834c147e833a2665e32c1824a6ec3cca8791
Fix the handling of HEAD requests that do not comply with RFC standards

    According to RFC 9110, The HEAD method is identical to GET except
    that the server MUST NOT send content in the response.

    And RFC 9112 indicates that Transfer-Encoding can be omitted in HEAD
    Response.

    The following HEAD OP is using chunked encoding and send the final chunk

    HEAD /bucket?uploads            RGWListBucketMultiparts_ObjStore_S3
    HEAD /bucket/abc?uploadId       RGWListMultipart_ObjStore_S3
    HEAD /                          RGWListBuckets_ObjStore_S3

    Clients using persistent connections, such as nginx, will be unable to handle
    subsequent requests after processing such requests because the final chunk
    remains in the TCP byte stream, preventing the next HTTP response from
    being correctly parsed.

    Ref: https://www.rfc-editor.org/rfc/rfc9110.html#section-9.3.2
         https://www.rfc-editor.org/rfc/rfc9112#section-6.1-9

Signed-off-by: liubingrun <liubr1@chinatelecom.cn>
(cherry picked from commit e63101650d43a60ae21e6c682f77175690542869)
src/rgw/rgw_rest.cc