// SPDX-License-Identifier: MIT // SPDX-FileCopyrightText: 2022 mochi-mqtt, mochi-co // SPDX-FileContributor: mochi-co package main import ( "log" "log/slog" "os" "os/signal" "syscall" mqtt "github.com/mochi-mqtt/server/v2" "github.com/mochi-mqtt/server/v2/hooks/auth" "github.com/mochi-mqtt/server/v2/hooks/storage/redis" "github.com/mochi-mqtt/server/v2/listeners" rv8 "github.com/go-redis/redis/v8" ) 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 }() server := mqtt.New(nil) _ = server.AddHook(new(auth.AllowHook), nil) level := new(slog.LevelVar) server.Log = slog.New(slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{ Level: level, })) level.Set(slog.LevelDebug) err := server.AddHook(new(redis.Hook), &redis.Options{ Options: &rv8.Options{ Addr: "localhost:6379", // default redis address Password: "", // your password DB: 0, // your redis db }, }) if err != nil { log.Fatal(err) } tcp := listeners.NewTCP(listeners.Config{ ID: "t1", Address: ":1883", }) err = server.AddListener(tcp) if err != nil { log.Fatal(err) } go func() { err := server.Serve() if err != nil { log.Fatal(err) } }() <-done server.Log.Warn("caught signal, stopping...") _ = server.Close() server.Log.Info("main.go finished") }