summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2023-06-03 21:14:51 +0200
committerxengineering <me@xengineering.eu>2023-06-03 21:14:51 +0200
commit3d2bd84e683e414fc6c8ac2634165fccba641b72 (patch)
treee972f819485b4e188bcb71c6f76b1556b29709e5
parente313bce92afea09b2da657b5a4f7de2c958c0100 (diff)
downloadlimox-3d2bd84e683e414fc6c8ac2634165fccba641b72.tar
limox-3d2bd84e683e414fc6c8ac2634165fccba641b72.tar.zst
limox-3d2bd84e683e414fc6c8ac2634165fccba641b72.zip
Re-implement transport setup in session
-rw-r--r--xmpp/session.go43
1 files changed, 33 insertions, 10 deletions
diff --git a/xmpp/session.go b/xmpp/session.go
index 2e7bade..d8e4973 100644
--- a/xmpp/session.go
+++ b/xmpp/session.go
@@ -1,44 +1,67 @@
package xmpp
import (
+ "crypto/tls"
+ "crypto/x509"
"log"
- "time"
)
type SessionConnect struct{}
type SessionDisconnect struct{}
type SessionShouldDisconnect struct{}
-type Session struct {
- in, out chan any
+type session struct {
+ in, out chan any
+ jid string
+ transport *tls.Conn
}
func StartSession(out chan any, jid string, pwd string) chan any {
- s := Session{}
+ s := session{}
s.in = make(chan any)
s.out = out
+ s.jid = jid
go s.run()
return s.in
}
-func (s *Session) run() {
+func (s *session) run() {
defer func() { s.out <- SessionDisconnect{} }()
- time.Sleep(time.Second) // faked connect time
+ err := s.startTransport()
+ if err != nil { return }
+ defer s.transport.Close()
+
s.out <- SessionConnect{}
for {
select {
case data := <-s.in:
switch data.(type) {
- case SessionShouldDisconnect:
- return
- default:
- log.Printf("Unknown data '%d'!\n", data)
+ case SessionShouldDisconnect: return
+ default: log.Printf("Unknown data '%d'!\n", data)
}
}
}
}
+
+func (s *session) startTransport() error {
+ domain := domainpart(s.jid)
+
+ roots, err := x509.SystemCertPool()
+ if err != nil {
+ log.Println(err)
+ return err
+ }
+
+ s.transport, err = tls.Dial("tcp", domain+":"+"5223", &tls.Config{RootCAs: roots})
+ if err != nil {
+ log.Println(err)
+ return err
+ }
+
+ return nil
+}