mirror of
				https://github.com/mochi-mqtt/server.git
				synced 2025-10-31 03:26:28 +08:00 
			
		
		
		
	 26418c6fd8
			
		
	
	26418c6fd8
	
	
	
		
			
			* Implement file-based configuration * Implement file-based configuration * Replace DefaultServerCapabilities with NewDefaultServerCapabilities() to avoid data race (#360) Co-authored-by: JB <28275108+mochi-co@users.noreply.github.com> * Only pass a copy of system.Info to hooks (#365) * Only pass a copy of system.Info to hooks * Rename Itoa to Int64toa --------- Co-authored-by: JB <28275108+mochi-co@users.noreply.github.com> * Allow configurable max stored qos > 0 messages (#359) * Allow configurable max stored qos > 0 messages * Only rollback Inflight if QoS > 0 * Only rollback Inflight if QoS > 0 * Minor refactor * Update server version * Implement file-based configuration * Implement file-based configuration * update configs with maximum_inflight value * update docker configuration * fix tests --------- Co-authored-by: mochi-co <moumochi@icloud.com> Co-authored-by: thedevop <60499013+thedevop@users.noreply.github.com>
		
			
				
	
	
		
			87 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // SPDX-License-Identifier: MIT
 | |
| // SPDX-FileCopyrightText: 2022 mochi-mqtt, mochi-co
 | |
| // SPDX-FileContributor: mochi-co
 | |
| 
 | |
| package main
 | |
| 
 | |
| import (
 | |
| 	"log"
 | |
| 	"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/listeners"
 | |
| )
 | |
| 
 | |
| 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
 | |
| 	}()
 | |
| 
 | |
| 	authRules := &auth.Ledger{
 | |
| 		Auth: auth.AuthRules{ // Auth disallows all by default
 | |
| 			{Username: "peach", Password: "password1", Allow: true},
 | |
| 			{Username: "melon", Password: "password2", Allow: true},
 | |
| 			{Remote: "127.0.0.1:*", Allow: true},
 | |
| 			{Remote: "localhost:*", Allow: true},
 | |
| 		},
 | |
| 		ACL: auth.ACLRules{ // ACL allows all by default
 | |
| 			{Remote: "127.0.0.1:*"}, // local superuser allow all
 | |
| 			{
 | |
| 				// user melon can read and write to their own topic
 | |
| 				Username: "melon", Filters: auth.Filters{
 | |
| 					"melon/#":   auth.ReadWrite,
 | |
| 					"updates/#": auth.WriteOnly, // can write to updates, but can't read updates from others
 | |
| 				},
 | |
| 			},
 | |
| 			{
 | |
| 				// Otherwise, no clients have publishing permissions
 | |
| 				Filters: auth.Filters{
 | |
| 					"#":         auth.ReadOnly,
 | |
| 					"updates/#": auth.Deny,
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	// you may also find this useful...
 | |
| 	// d, _ := authRules.ToYAML()
 | |
| 	// d, _ := authRules.ToJSON()
 | |
| 	// fmt.Println(string(d))
 | |
| 
 | |
| 	server := mqtt.New(nil)
 | |
| 	err := server.AddHook(new(auth.Hook), &auth.Options{
 | |
| 		Ledger: authRules,
 | |
| 	})
 | |
| 	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")
 | |
| }
 |