104 lines
2.8 KiB
Go
104 lines
2.8 KiB
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"log"
|
||
|
"os"
|
||
|
"os/signal"
|
||
|
"syscall"
|
||
|
"time"
|
||
|
|
||
|
"github.com/logrusorgru/aurora"
|
||
|
|
||
|
mqtt "github.com/mochi-co/mqtt/server"
|
||
|
"github.com/mochi-co/mqtt/server/events"
|
||
|
"github.com/mochi-co/mqtt/server/listeners"
|
||
|
"github.com/mochi-co/mqtt/server/listeners/auth"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
sigs := make(chan os.Signal, 1)
|
||
|
done := make(chan bool, 1)
|
||
|
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
|
||
|
go func() {
|
||
|
<-sigs
|
||
|
done <- true
|
||
|
}()
|
||
|
|
||
|
fmt.Println(aurora.Magenta("Mochi MQTT Server initializing..."), aurora.Cyan("TCP"))
|
||
|
|
||
|
server := mqtt.NewServer(nil)
|
||
|
tcp := listeners.NewTCP("t1", ":1883")
|
||
|
err := server.AddListener(tcp, &listeners.Config{
|
||
|
Auth: new(auth.Allow),
|
||
|
})
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
|
||
|
// Start the server
|
||
|
go func() {
|
||
|
err := server.Serve()
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
}()
|
||
|
|
||
|
// Add OnConnect Event Hook
|
||
|
server.Events.OnConnect = func(cl events.Client, pk events.Packet) {
|
||
|
fmt.Printf("<< OnConnect client connected %s: %+v\n", cl.ID, pk)
|
||
|
}
|
||
|
|
||
|
// Add OnDisconnect Event Hook
|
||
|
server.Events.OnDisconnect = func(cl events.Client, err error) {
|
||
|
fmt.Printf("<< OnDisconnect client disconnected %s: %v\n", cl.ID, err)
|
||
|
}
|
||
|
|
||
|
// Add OnSubscribe Event Hook
|
||
|
server.Events.OnSubscribe = func(filter string, cl events.Client, qos byte) {
|
||
|
fmt.Printf("<< OnSubscribe client subscribed %s: %s %v\n", cl.ID, filter, qos)
|
||
|
}
|
||
|
|
||
|
// Add OnUnsubscribe Event Hook
|
||
|
server.Events.OnUnsubscribe = func(filter string, cl events.Client) {
|
||
|
fmt.Printf("<< OnUnsubscribe client unsubscribed %s: %s\n", cl.ID, filter)
|
||
|
}
|
||
|
|
||
|
// Add OnMessage Event Hook
|
||
|
server.Events.OnMessage = func(cl events.Client, pk events.Packet) (pkx events.Packet, err error) {
|
||
|
pkx = pk
|
||
|
if string(pk.Payload) == "hello" {
|
||
|
pkx.Payload = []byte("hello world")
|
||
|
fmt.Printf("< OnMessage modified message from client %s: %s\n", cl.ID, string(pkx.Payload))
|
||
|
} else {
|
||
|
fmt.Printf("< OnMessage received message from client %s: %s\n", cl.ID, string(pkx.Payload))
|
||
|
}
|
||
|
|
||
|
// Example of using AllowClients to selectively deliver/drop messages.
|
||
|
// Only a client with the id of `allowed-client` will received messages on the topic.
|
||
|
if pkx.TopicName == "a/b/restricted" {
|
||
|
pkx.AllowClients = []string{"allowed-client"} // slice of known client ids
|
||
|
}
|
||
|
|
||
|
return pkx, nil
|
||
|
}
|
||
|
|
||
|
// Demonstration of directly publishing messages to a topic via the
|
||
|
// `server.Publish` method. Subscribe to `direct/publish` using your
|
||
|
// MQTT client to see the messages.
|
||
|
go func() {
|
||
|
for range time.Tick(time.Second * 10) {
|
||
|
server.Publish("direct/publish", []byte("scheduled message"), false)
|
||
|
fmt.Println("> issued direct message to direct/publish")
|
||
|
}
|
||
|
}()
|
||
|
|
||
|
fmt.Println(aurora.BgMagenta(" Started! "))
|
||
|
|
||
|
<-done
|
||
|
fmt.Println(aurora.BgRed(" Caught Signal "))
|
||
|
|
||
|
server.Close()
|
||
|
fmt.Println(aurora.BgGreen(" Finished "))
|
||
|
}
|