mdns query
This commit is contained in:
		
							parent
							
								
									89ebd5ca41
								
							
						
					
					
						commit
						669a5c7d57
					
				
							
								
								
									
										38
									
								
								huego.go
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								huego.go
									
									
									
									
									
								
							| @ -3,34 +3,30 @@ package main | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"log" | ||||
| 	"os" | ||||
| 	"net" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/grandcat/zeroconf" | ||||
| 	"golang.org/x/net/context" | ||||
| ) | ||||
| 
 | ||||
| func main() { | ||||
| 	// Create or open a log file | ||||
| 	logFile, err := os.OpenFile("program.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666) | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Failed to open log file: %v", err) | ||||
| 	} | ||||
| 	defer logFile.Close() | ||||
| type Device struct { | ||||
| 	IP   net.IP | ||||
| 	Name string | ||||
| } | ||||
| 
 | ||||
| 	// Set log output to the file | ||||
| 	log.SetOutput(logFile) | ||||
| 
 | ||||
| 	// Log a startup message | ||||
| 	log.Println("Starting mDNS query for 'hue-bridge'") | ||||
| func discoverHueBridge() ([]Device, error) { | ||||
| 	// Create a new resolver | ||||
| 	resolver, err := zeroconf.NewResolver(nil) | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Failed to initialize resolver: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	// Instantiate a new devices slice | ||||
| 	devices := make([]Device, 0) | ||||
| 
 | ||||
| 	// Set up a context with a timeout | ||||
| 	ctx, cancel := context.WithTimeout(context.Background(), time.Second*10) | ||||
| 	ctx, cancel := context.WithTimeout(context.Background(), time.Second*3) | ||||
| 	defer cancel() | ||||
| 
 | ||||
| 	// Channel to recive the results | ||||
| @ -47,13 +43,21 @@ func main() { | ||||
| 	// Process the results | ||||
| 	go func() { | ||||
| 		for entry := range entries { | ||||
| 			fmt.Printf("Found Device: %s\n", entry.HostName) | ||||
| 			fmt.Printf("IP Addresses: %v\n", entry.AddrIPv4) | ||||
| 			devices = append(devices, Device{IP: entry.AddrIPv4[0], Name: entry.HostName}) | ||||
| 		} | ||||
| 		fmt.Printf("Number of devices found: %d\n", len(entries)) | ||||
| 	}() | ||||
| 
 | ||||
| 	// Wait for the context to expire | ||||
| 	<-ctx.Done() | ||||
| 	fmt.Println("mDNS query finished") | ||||
| 	fmt.Printf("Number of devices found: %d\n", len(devices)) | ||||
| 	for _, device := range devices { | ||||
| 		fmt.Printf("Device: %s\n", device.Name) | ||||
| 		fmt.Printf("IP Address: %s\n", device.IP) | ||||
| 	} | ||||
| 	return devices, nil | ||||
| } | ||||
| 
 | ||||
| func main() { | ||||
| 	discoverHueBridge() | ||||
| } | ||||
|  | ||||
| @ -1 +1,2 @@ | ||||
| 2024/07/16 23:58:30 Starting mDNS query for 'hue-bridge' | ||||
| 2024/07/17 07:00:24 Starting mDNS query for 'hue-bridge' | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user