mirror of
https://github.com/tulir/mautrix-whatsapp
synced 2024-11-12 04:52:40 +01:00
Add more logging in provisioning API
This commit is contained in:
parent
bcdc19d4f4
commit
4304472fc9
1 changed files with 32 additions and 2 deletions
|
@ -16,12 +16,15 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/gorilla/websocket"
|
"github.com/gorilla/websocket"
|
||||||
log "maunium.net/go/maulogger/v2"
|
log "maunium.net/go/maulogger/v2"
|
||||||
|
@ -51,6 +54,26 @@ func (prov *ProvisioningAPI) Init() {
|
||||||
r.HandleFunc("/reconnect", prov.Reconnect).Methods(http.MethodPost)
|
r.HandleFunc("/reconnect", prov.Reconnect).Methods(http.MethodPost)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type responseWrap struct {
|
||||||
|
http.ResponseWriter
|
||||||
|
statusCode int
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ http.Hijacker = (*responseWrap)(nil)
|
||||||
|
|
||||||
|
func (rw *responseWrap) WriteHeader(statusCode int) {
|
||||||
|
rw.ResponseWriter.WriteHeader(statusCode)
|
||||||
|
rw.statusCode = statusCode
|
||||||
|
}
|
||||||
|
|
||||||
|
func (rw *responseWrap) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
||||||
|
hijacker, ok := rw.ResponseWriter.(http.Hijacker)
|
||||||
|
if !ok {
|
||||||
|
return nil, nil, errors.New("response does not implement http.Hijacker")
|
||||||
|
}
|
||||||
|
return hijacker.Hijack()
|
||||||
|
}
|
||||||
|
|
||||||
func (prov *ProvisioningAPI) AuthMiddleware(h http.Handler) http.Handler {
|
func (prov *ProvisioningAPI) AuthMiddleware(h http.Handler) http.Handler {
|
||||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
auth := r.Header.Get("Authorization")
|
auth := r.Header.Get("Authorization")
|
||||||
|
@ -75,7 +98,11 @@ func (prov *ProvisioningAPI) AuthMiddleware(h http.Handler) http.Handler {
|
||||||
}
|
}
|
||||||
userID := r.URL.Query().Get("user_id")
|
userID := r.URL.Query().Get("user_id")
|
||||||
user := prov.bridge.GetUserByMXID(id.UserID(userID))
|
user := prov.bridge.GetUserByMXID(id.UserID(userID))
|
||||||
h.ServeHTTP(w, r.WithContext(context.WithValue(r.Context(), "user", user)))
|
start := time.Now()
|
||||||
|
wWrap := &responseWrap{w, 200}
|
||||||
|
h.ServeHTTP(wWrap, r.WithContext(context.WithValue(r.Context(), "user", user)))
|
||||||
|
duration := time.Now().Sub(start).Seconds()
|
||||||
|
prov.log.Infofln("%s %s from %s took %.2f seconds and returned status %d", r.Method, r.URL.Path, user.MXID, duration, wWrap.statusCode)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,6 +189,7 @@ func (prov *ProvisioningAPI) Reconnect(w http.ResponseWriter, r *http.Request) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
user.log.Debugln("Received /reconnect request, disconnecting")
|
||||||
wasConnected := true
|
wasConnected := true
|
||||||
sess, err := user.Conn.Disconnect()
|
sess, err := user.Conn.Disconnect()
|
||||||
if err == whatsapp.ErrNotConnected {
|
if err == whatsapp.ErrNotConnected {
|
||||||
|
@ -172,7 +200,9 @@ func (prov *ProvisioningAPI) Reconnect(w http.ResponseWriter, r *http.Request) {
|
||||||
user.SetSession(&sess)
|
user.SetSession(&sess)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
user.log.Debugln("Restoring session for /reconnect")
|
||||||
err = user.Conn.Restore()
|
err = user.Conn.Restore()
|
||||||
|
user.log.Debugfln("Restore session for /reconnect responded with %v", err)
|
||||||
if err == whatsapp.ErrInvalidSession {
|
if err == whatsapp.ErrInvalidSession {
|
||||||
if user.Session != nil {
|
if user.Session != nil {
|
||||||
user.log.Debugln("Got invalid session error when reconnecting, but user has session. Retrying using RestoreWithSession()...")
|
user.log.Debugln("Got invalid session error when reconnecting, but user has session. Retrying using RestoreWithSession()...")
|
||||||
|
@ -335,7 +365,7 @@ func (prov *ProvisioningAPI) Login(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
c, err := upgrader.Upgrade(w, r, nil)
|
c, err := upgrader.Upgrade(w, r, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
prov.log.Errorfln("Failed to upgrade connection to websocket:", err)
|
prov.log.Errorln("Failed to upgrade connection to websocket:", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer c.Close()
|
defer c.Close()
|
||||||
|
|
Loading…
Reference in a new issue