mirror of
https://github.com/FluuxIO/go-xmpp.git
synced 2025-01-18 20:29:02 -08:00
7fa4b06705
This makes it possible to use a factory function to create a transport of the right type and not having to repeat the address when calling Transport.Connect()
53 lines
1.2 KiB
Go
53 lines
1.2 KiB
Go
/*
|
|
xmpp_echo is a demo client that connect on an XMPP server and echo message received back to original sender.
|
|
*/
|
|
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
"os"
|
|
|
|
"gosrc.io/xmpp"
|
|
"gosrc.io/xmpp/stanza"
|
|
)
|
|
|
|
func main() {
|
|
config := xmpp.Config{
|
|
TransportConfiguration: xmpp.TransportConfiguration{
|
|
Address: "localhost:5222",
|
|
},
|
|
Jid: "test@localhost",
|
|
Credential: xmpp.Password("test"),
|
|
StreamLogger: os.Stdout,
|
|
Insecure: true,
|
|
// TLSConfig: tls.Config{InsecureSkipVerify: true},
|
|
}
|
|
|
|
router := xmpp.NewRouter()
|
|
router.HandleFunc("message", handleMessage)
|
|
|
|
client, err := xmpp.NewClient(config, router)
|
|
if err != nil {
|
|
log.Fatalf("%+v", err)
|
|
}
|
|
|
|
// If you pass the client to a connection manager, it will handle the reconnect policy
|
|
// for you automatically.
|
|
cm := xmpp.NewStreamManager(client, nil)
|
|
log.Fatal(cm.Run())
|
|
}
|
|
|
|
func handleMessage(s xmpp.Sender, p stanza.Packet) {
|
|
msg, ok := p.(stanza.Message)
|
|
if !ok {
|
|
_, _ = fmt.Fprintf(os.Stdout, "Ignoring packet: %T\n", p)
|
|
return
|
|
}
|
|
|
|
_, _ = fmt.Fprintf(os.Stdout, "Body = %s - from = %s\n", msg.Body, msg.From)
|
|
reply := stanza.Message{Attrs: stanza.Attrs{To: msg.From}, Body: msg.Body}
|
|
_ = s.Send(reply)
|
|
}
|