diff --git a/CHANGELOG.md b/CHANGELOG.md index 9bc89d7e..d7117f2b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ ## Changelog +### [13.6.1](https://kaos.sh/ek/13.6.1) + +- `[req]` Guess the value of the `Content-Type` header based on the request body type + ### [13.6.0](https://kaos.sh/ek/13.6.0) - `[setup]` Added package to install/uninstall application as a service diff --git a/req/req.go b/req/req.go index 0a8aa775..8624e7c6 100644 --- a/req/req.go +++ b/req/req.go @@ -590,12 +590,16 @@ func (e *Engine) doRequest(r Request, method string) (*Response, error) { r.URL += "?" + r.Query.Encode() } - bodyReader, err := getBodyReader(r.Body) + bodyReader, contentType, err := getBodyReader(r.Body) if err != nil { return nil, RequestError{ERROR_BODY_ENCODE, err.Error()} } + if r.ContentType == "" { + r.ContentType = contentType + } + req, err := createRequest(e, r, bodyReader) if err != nil { @@ -736,25 +740,25 @@ func createFormFile(w *multipart.Writer, fieldName, file string) (io.Writer, err return w.CreateFormFile(fieldName, filepath.Base(file)) } -func getBodyReader(body any) (io.Reader, error) { +func getBodyReader(body any) (io.Reader, string, error) { switch u := body.(type) { case nil: - return nil, nil + return nil, "", nil case string: - return strings.NewReader(u), nil + return strings.NewReader(u), CONTENT_TYPE_PLAIN, nil case io.Reader: - return u, nil + return u, CONTENT_TYPE_OCTET_STREAM, nil case []byte: - return bytes.NewReader(u), nil - default: - jsonBody, err := json.MarshalIndent(body, "", " ") + return bytes.NewReader(u), CONTENT_TYPE_OCTET_STREAM, nil + } - if err == nil { - return bytes.NewReader(jsonBody), nil - } + jsonBody, err := json.MarshalIndent(body, "", " ") - return nil, err + if err == nil { + return bytes.NewReader(jsonBody), CONTENT_TYPE_JSON, nil } + + return nil, "", err } func isURL(url string) bool { diff --git a/version.go b/version.go index 14137bf4..17d1a6be 100644 --- a/version.go +++ b/version.go @@ -8,4 +8,4 @@ package ek // ////////////////////////////////////////////////////////////////////////////////// // // VERSION is current ek package version -const VERSION = "13.6.0" +const VERSION = "13.6.1"