mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-01-13 09:45:27 +00:00
Log Web Push server error messages
This commit is contained in:
parent
79559933e0
commit
dcac7f2035
1 changed files with 19 additions and 3 deletions
|
@ -21,6 +21,7 @@ import (
|
|||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"io"
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
|
@ -57,6 +58,9 @@ func NewRealSender(httpClient *http.Client, state *state.State) Sender {
|
|||
// while waiting for the client to retrieve them.
|
||||
const TTL = 48 * time.Hour
|
||||
|
||||
// responseBodyMaxLen limits how much of the Web Push server response we use for error messages.
|
||||
const responseBodyMaxLen = 1024
|
||||
|
||||
func (r *realSender) Send(
|
||||
ctx context.Context,
|
||||
notification *gtsmodel.Notification,
|
||||
|
@ -229,10 +233,22 @@ func (r *realSender) sendToSubscription(
|
|||
if err != nil {
|
||||
return gtserror.Newf("error sending Web Push notification: %w", err)
|
||||
}
|
||||
// We're not going to use the response body, but we need to close it so we don't leak the connection.
|
||||
_ = resp.Body.Close()
|
||||
defer func() {
|
||||
_ = resp.Body.Close()
|
||||
}()
|
||||
|
||||
// If there's an error, log the response.
|
||||
if resp.StatusCode != http.StatusOK {
|
||||
return gtserror.Newf("unexpected HTTP status received when sending Web Push notification: %s", resp.Status)
|
||||
bodyBytes, err := io.ReadAll(io.LimitReader(resp.Body, responseBodyMaxLen))
|
||||
if err != nil {
|
||||
return gtserror.Newf("error reading Web Push server response: %w", err)
|
||||
}
|
||||
|
||||
return gtserror.Newf(
|
||||
"unexpected HTTP status %s received when sending Web Push notification: %s",
|
||||
resp.Status,
|
||||
string(bodyBytes),
|
||||
)
|
||||
}
|
||||
|
||||
return nil
|
||||
|
|
Loading…
Reference in a new issue