Skip to content

Request string reprenetations prints non-existing field #193

Open
@DifferentialOrange

Description

@DifferentialOrange

tostring(req) invokes request_tostring function, which does the following step:

return sprintf("%s\r\n%s", res, self.body)

But request does not have a body attribute. response does. String representation of a request always ends with empty lines since .body == nil.

local log = require('log')

local http_server = require('http.server')

box.cfg{}

local httpd = http_server.new('127.0.0.1', 8081)
httpd:route(
    { path = '/hello', method = 'POST' }, function(req)
        local _ = req:json() -- If removed, result is the same.
        log.info(req.body)
        log.info(tostring(req))
        return req:render{text = 'OK'}
    end)
httpd:start()
curl -X POST localhost:8081/hello?a=a -d '{"sdfs":"dfdfsfs"}'
2023-09-18 10:31:12.506 [1212600] main/114/http/127.0.0.1:60846/http.server I> POST /hello?a=a
2023-09-18 10:31:12.506 [1212600] main/114/http/127.0.0.1:60846/. I> 
2023-09-18 10:31:12.506 [1212600] main/114/http/127.0.0.1:60846/. I> POST /hello?a=a HTTP/1.1
Host: localhost:8081
Content-type: application/x-www-form-urlencoded
Content-length: 18
Accept: */*
User-agent: curl/7.81.0


Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't workingquestionFurther information is requested

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions