From 07662d9403eb85b39e1ffcf91014bbf36efd1c5a Mon Sep 17 00:00:00 2001 From: s Date: Thu, 13 Nov 2025 22:25:02 -0500 Subject: refactor: break down large osint.go file into separate command modules and add helper functions --- cmd/bssid.go | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 cmd/bssid.go (limited to 'cmd/bssid.go') diff --git a/cmd/bssid.go b/cmd/bssid.go new file mode 100644 index 0000000..7a9e4c0 --- /dev/null +++ b/cmd/bssid.go @@ -0,0 +1,43 @@ +package cmd + +import ( + "git.db.org.ai/dborg/internal/formatter" + "git.db.org.ai/dborg/internal/models" + "github.com/spf13/cobra" +) + +var bssidCmd = &cobra.Command{ + Use: "bssid [bssid]", + Short: "Lookup WiFi access point location by BSSID", + Long: `Lookup geographic location of a WiFi access point by its BSSID (MAC address) using Apple's location services`, + Args: cobra.ExactArgs(1), + RunE: runBSSIDLookup, +} + +func init() { + rootCmd.AddCommand(bssidCmd) + bssidCmd.Flags().BoolP("all", "a", false, "Show all related results instead of exact match only") + bssidCmd.Flags().BoolP("google", "g", false, "Include Google Maps URL for the location") + bssidCmd.Flags().BoolP("osm", "o", false, "Include OpenStreetMap URL for the location") +} + +func runBSSIDLookup(cmd *cobra.Command, args []string) error { + c, err := newUnauthenticatedClient() + if err != nil { + return err + } + + params := &models.BSSIDParams{ + BSSID: args[0], + } + params.All, _ = cmd.Flags().GetBool("all") + params.Google, _ = cmd.Flags().GetBool("google") + params.OSM, _ = cmd.Flags().GetBool("osm") + + response, err := c.LookupBSSID(params) + if err != nil { + return err + } + + return formatter.FormatBSSIDResults(*response, IsJSONOutput()) +} -- cgit v1.2.3