Skip to content

yasuoza/switchbot-ble-go

Repository files navigation

SwitchBot Client for Go
test CodeQL Go Report Card Coverage Status PkgGoDev

Unofficial SwitchBot client for Go.

Commandline

$ go install github.com/yasuoza/switchbot-ble-go/v2/cmd/switchbot@latest
Usage: switchbot [--version] [--help] <command> [<args>]

Available commands are:
    info     Show current SwitchBot information
    press    Trigger press command
    scan     Search for SwitchBots

Scan SwitchBots.

$ switchbot scan
11:11:11:11:11:11

Press.

switchbot press -max-retry '11:11:11:11:11:11'

API Example

import (
  "github.com/yasuoza/switchbot-ble-go/v2/pkg/switchbot"
)

func main() {
	ctx := context.Background()
	timeout := 5 * time.Second

	// Scan SwitchBots.
	var addrs []string
	err := switchbot.Scan(ctx, timeout, func(addr string) {
		addrs = append(addrs, addr)
	})
	if err != nil {
		log.Fatal(err)
	}

	// If there is no SwitchBot, err is nil and length of addresses is 0.
	if len(addrs) == 0 {
		log.Println("SwitchBot not found")
		os.Exit(0)
	}

	// First, connect to SwitchBot.
	addr := addrs[0]
	log.Printf("Connecting to SwitchBot %s\n", addr)
	bot, err := switchbot.Connect(ctx, addr, timeout)
	if err != nil {
		log.Fatal(err)
	}

	// Trigger Press.
	log.Printf("Connected to SwitchBot %s. Trigger Press\n", addr)
	bot.Press(false)
}