From 0dd1fb9f2158dec48c8dc55a078b3d79d475c9d9 Mon Sep 17 00:00:00 2001 From: xengineering Date: Thu, 11 May 2023 20:22:31 +0200 Subject: Restructure xmpp() --- xmpp.go | 22 ++++++++-------------- 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/xmpp.go b/xmpp.go index d7c8790..90a0355 100644 --- a/xmpp.go +++ b/xmpp.go @@ -1,11 +1,11 @@ package main import ( - "os" "crypto/tls" "crypto/x509" "encoding/xml" "log" + "os" ) type XmppEvent uint8 @@ -16,32 +16,34 @@ const ( ) func (l *Limox) xmpp(jid string, pwd string) { + defer func() { l.XmppEvents <- XmppDisconnect }() conn, err := setupConn(jid) if err != nil { l.XmppEvents <- err return } - - enc := xml.NewEncoder(conn) + defer conn.Close() receiver := make(chan xml.Token) termination := make(chan bool) go rxRoutine(conn, receiver, termination) + enc := xml.NewEncoder(conn) dbg := xml.NewEncoder(os.Stdout) end := sendStreamStart(enc, jid) + defer sendStreamEnd(enc, end) + l.XmppEvents <- XmppConnect - var closing bool = false for { select { case ev := <-l.GuiEvents: switch ev { case Disconnect: termination <- true - closing = true + return default: log.Fatalf("Unknown GuiEvent '%d'!\n", ev) } @@ -50,15 +52,7 @@ func (l *Limox) xmpp(jid string, pwd string) { dbg.EncodeToken(rx) dbg.Flush() } - - if closing { - break - } } - - sendStreamEnd(enc, end) - conn.Close() - l.XmppEvents <- XmppDisconnect } func setupConn(jid string) (*tls.Conn, error) { @@ -91,7 +85,7 @@ func rxRoutine(conn *tls.Conn, tokens chan xml.Token, terminator chan bool) { } } -func sendStreamStart(enc *xml.Encoder, jid string) (xml.EndElement) { +func sendStreamStart(enc *xml.Encoder, jid string) xml.EndElement { start := xml.StartElement{ xml.Name{"jabber:client", "stream:stream"}, []xml.Attr{ -- cgit v1.2.3-70-g09d2