mirror of
https://github.com/yusing/godoxy.git
synced 2025-06-01 09:32:35 +02:00

Some checks are pending
Docker Image CI (socket-proxy) / build (push) Waiting to run
* refactor: simplify io code and make utils module independent * fix(docker): agent and socket-proxy docker event flushing with modified reverse proxy handler * refactor: remove unused code * refactor: remove the use of logging module in most code * refactor: streamline domain mismatch check in certState function * tweak: use ecdsa p-256 for autocert * fix(tests): update health check tests for invalid host and add case for port in host * feat(acme): custom acme directory * refactor: code refactor and improved context and error handling * tweak: optimize memory usage under load * fix(oidc): restore old user matching behavior * docs: add ChatGPT assistant to README --------- Co-authored-by: yusing <yusing@6uo.me>
48 lines
923 B
Go
48 lines
923 B
Go
package gphttp
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
func WriteBody(w http.ResponseWriter, body []byte) {
|
|
if _, err := w.Write(body); err != nil {
|
|
switch {
|
|
case errors.Is(err, http.ErrHandlerTimeout),
|
|
errors.Is(err, context.DeadlineExceeded):
|
|
log.Err(err).Msg("timeout writing body")
|
|
default:
|
|
log.Err(err).Msg("failed to write body")
|
|
}
|
|
}
|
|
}
|
|
|
|
func RespondJSON(w http.ResponseWriter, r *http.Request, data any, code ...int) (canProceed bool) {
|
|
if data == nil {
|
|
http.NotFound(w, r)
|
|
return false
|
|
}
|
|
|
|
if len(code) > 0 {
|
|
w.WriteHeader(code[0])
|
|
}
|
|
w.Header().Set("Content-Type", "application/json")
|
|
var err error
|
|
|
|
switch data := data.(type) {
|
|
case []byte:
|
|
panic("use WriteBody instead")
|
|
default:
|
|
err = json.NewEncoder(w).Encode(data)
|
|
}
|
|
|
|
if err != nil {
|
|
LogError(r).Err(err).Msg("failed to encode json")
|
|
return false
|
|
}
|
|
return true
|
|
}
|