diff options
| author | xengineering <me@xengineering.eu> | 2023-05-21 13:12:23 +0200 | 
|---|---|---|
| committer | xengineering <me@xengineering.eu> | 2023-05-21 13:12:23 +0200 | 
| commit | 1d46cedcbb92edf69f080bf3dca07509a14159e2 (patch) | |
| tree | 499fe796a6450f23e44fb82db1baf166fa1cf34d | |
| parent | 37753409dc55da1a1cc3feed139f287a2d6215bb (diff) | |
| download | limox-1d46cedcbb92edf69f080bf3dca07509a14159e2.tar limox-1d46cedcbb92edf69f080bf3dca07509a14159e2.tar.zst limox-1d46cedcbb92edf69f080bf3dca07509a14159e2.zip | |
Introduce xengineering.eu/xmpp.Conn
| -rw-r--r-- | limox.go | 3 | ||||
| -rw-r--r-- | xmpp/xmpp.go | 23 | 
2 files changed, 19 insertions, 7 deletions
| @@ -86,7 +86,8 @@ func (l *Limox) buttonCallback() {  		pwd := l.PwdEditor.Text()  		setLastJid(jid)  		setLastPwd(pwd) -		go xmpp.Run(l.XmppConn, jid, pwd) +		c := xmpp.NewConn(l.XmppConn, jid, pwd) +		go c.Run()  		l.State = Connecting  	case Connecting:  		log.Println("Aborted connection establishment") diff --git a/xmpp/xmpp.go b/xmpp/xmpp.go index 5193f02..1d00739 100644 --- a/xmpp/xmpp.go +++ b/xmpp/xmpp.go @@ -15,8 +15,19 @@ const (  	ShouldDisconnectEvent  ) -func Run(ch chan Event, jid string, pwd string) { -	conn, err := setupConn(jid) +type Conn struct { +	ch chan Event +	jid, pwd string +} + +func NewConn(ch chan Event, jid string, pwd string) *Conn { +	c := Conn{ch, jid, pwd} + +	return &c +} + +func (c *Conn) Run() { +	conn, err := setupConn(c.jid)  	if err != nil {  		log.Print(err)  		return @@ -32,15 +43,15 @@ func Run(ch chan Event, jid string, pwd string) {  	tr := newTokenRouter(&enc) -	end := sendStreamStart(&enc, jid) +	end := sendStreamStart(&enc, c.jid)  	defer sendStreamEnd(&enc, end) -	ch <- ConnectEvent -	defer func() { ch <- DisconnectEvent }() +	c.ch <- ConnectEvent +	defer func() { c.ch <- DisconnectEvent }()  	for {  		select { -		case ev := <-ch: +		case ev := <-c.ch:  			switch ev {  			case ShouldDisconnectEvent:  				return | 
