summaryrefslogtreecommitdiff
path: root/teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go
diff options
context:
space:
mode:
authorMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
committerMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
commite9c24f4af7ed56760f6db7941827d09f6db9020b (patch)
tree62128c43b883ce5e3148113350978755779bb5de /teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go
parent58d5e7cfda4781d8a57ec52aefd02983835c301a (diff)
add matterbridge
Diffstat (limited to 'teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go')
-rw-r--r--teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go78
1 files changed, 78 insertions, 0 deletions
diff --git a/teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go b/teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go
new file mode 100644
index 0000000..d5e4028
--- /dev/null
+++ b/teleirc/matterbridge/vendor/go.mau.fi/whatsmeow/keepalive.go
@@ -0,0 +1,78 @@
+// Copyright (c) 2021 Tulir Asokan
+//
+// This Source Code Form is subject to the terms of the Mozilla Public
+// License, v. 2.0. If a copy of the MPL was not distributed with this
+// file, You can obtain one at http://mozilla.org/MPL/2.0/.
+
+package whatsmeow
+
+import (
+ "context"
+ "math/rand"
+ "time"
+
+ waBinary "go.mau.fi/whatsmeow/binary"
+ "go.mau.fi/whatsmeow/types"
+ "go.mau.fi/whatsmeow/types/events"
+)
+
+var (
+ // KeepAliveResponseDeadline specifies the duration to wait for a response to websocket keepalive pings.
+ KeepAliveResponseDeadline = 10 * time.Second
+ // KeepAliveIntervalMin specifies the minimum interval for websocket keepalive pings.
+ KeepAliveIntervalMin = 20 * time.Second
+ // KeepAliveIntervalMax specifies the maximum interval for websocket keepalive pings.
+ KeepAliveIntervalMax = 30 * time.Second
+)
+
+func (cli *Client) keepAliveLoop(ctx context.Context) {
+ var lastSuccess time.Time
+ var errorCount int
+ for {
+ interval := rand.Int63n(KeepAliveIntervalMax.Milliseconds()-KeepAliveIntervalMin.Milliseconds()) + KeepAliveIntervalMin.Milliseconds()
+ select {
+ case <-time.After(time.Duration(interval) * time.Millisecond):
+ isSuccess, shouldContinue := cli.sendKeepAlive(ctx)
+ if !shouldContinue {
+ return
+ } else if !isSuccess {
+ errorCount++
+ go cli.dispatchEvent(&events.KeepAliveTimeout{
+ ErrorCount: errorCount,
+ LastSuccess: lastSuccess,
+ })
+ } else {
+ if errorCount > 0 {
+ errorCount = 0
+ go cli.dispatchEvent(&events.KeepAliveRestored{})
+ }
+ lastSuccess = time.Now()
+ }
+ case <-ctx.Done():
+ return
+ }
+ }
+}
+
+func (cli *Client) sendKeepAlive(ctx context.Context) (isSuccess, shouldContinue bool) {
+ respCh, err := cli.sendIQAsync(infoQuery{
+ Namespace: "w:p",
+ Type: "get",
+ To: types.ServerJID,
+ Content: []waBinary.Node{{Tag: "ping"}},
+ })
+ if err != nil {
+ cli.Log.Warnf("Failed to send keepalive: %v", err)
+ return false, true
+ }
+ select {
+ case <-respCh:
+ // All good
+ return true, true
+ case <-time.After(KeepAliveResponseDeadline):
+ cli.Log.Warnf("Keepalive timed out")
+ return false, true
+ case <-ctx.Done():
+ return false, false
+ }
+}