aboutsummaryrefslogtreecommitdiff
path: root/telegram/connect.go
diff options
context:
space:
mode:
authorbodqhrohro <bodqhrohro@gmail.com>2019-12-17 04:56:11 +0300
committerbodqhrohro <bodqhrohro@gmail.com>2019-12-17 04:56:11 +0300
commit05a9aca537a9420244860374da6b56731f483637 (patch)
treef64596f268223406810eebbd74d0789c9c1d4b3c /telegram/connect.go
parent10aae376f7dae843a5472cfc5c7083b4c032021d (diff)
Reconnect fix
Diffstat (limited to 'telegram/connect.go')
-rw-r--r--telegram/connect.go10
1 files changed, 7 insertions, 3 deletions
diff --git a/telegram/connect.go b/telegram/connect.go
index 3827bcc..3a711c2 100644
--- a/telegram/connect.go
+++ b/telegram/connect.go
@@ -146,6 +146,7 @@ func (c *Client) Disconnect() {
_, err := c.client.Close()
if err != nil {
log.Errorf("Couldn't close the Telegram instance: %v; %#v", err, c)
+ c.forceClose()
}
}
@@ -198,13 +199,16 @@ func (c *Client) interactor() {
}
gateway.SendPresence(c.xmpp, c.jid, gateway.SPStatus("Logged in "+c.Session.Login))
- case client.TypeAuthorizationStateClosed:
- log.Warn("Closing the updates listener")
- c.listener.Close()
+
+ return
}
}
}
+func (c *Client) forceClose() {
+ c.listener.Close()
+}
+
// Online checks if the updates listener is alive
func (c *Client) Online() bool {
return c.listener != nil && c.listener.IsActive()