2015-06-29 18:00:40 -07:00
|
|
|
package gpio
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"gobot.io/x/gobot/v2"
|
|
|
|
)
|
2015-06-29 18:00:40 -07:00
|
|
|
|
|
|
|
// RelayDriver represents a digital relay
|
|
|
|
type RelayDriver struct {
|
|
|
|
pin string
|
|
|
|
name string
|
|
|
|
connection DigitalWriter
|
|
|
|
high bool
|
2019-06-25 06:13:17 +01:00
|
|
|
Inverted bool
|
2015-06-29 18:00:40 -07:00
|
|
|
gobot.Commander
|
|
|
|
}
|
|
|
|
|
2016-09-25 13:36:18 +02:00
|
|
|
// NewRelayDriver return a new RelayDriver given a DigitalWriter and pin.
|
2015-06-29 18:00:40 -07:00
|
|
|
//
|
|
|
|
// Adds the following API Commands:
|
2023-05-20 14:25:21 +02:00
|
|
|
//
|
2015-06-29 18:00:40 -07:00
|
|
|
// "Toggle" - See RelayDriver.Toggle
|
|
|
|
// "On" - See RelayDriver.On
|
|
|
|
// "Off" - See RelayDriver.Off
|
2016-09-25 13:36:18 +02:00
|
|
|
func NewRelayDriver(a DigitalWriter, pin string) *RelayDriver {
|
2023-11-15 20:51:52 +01:00
|
|
|
d := &RelayDriver{
|
2017-02-02 15:37:09 +01:00
|
|
|
name: gobot.DefaultName("Relay"),
|
2015-06-29 18:00:40 -07:00
|
|
|
pin: pin,
|
|
|
|
connection: a,
|
|
|
|
high: false,
|
2019-06-25 06:13:17 +01:00
|
|
|
Inverted: false,
|
2015-06-29 18:00:40 -07:00
|
|
|
Commander: gobot.NewCommander(),
|
|
|
|
}
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.AddCommand("Toggle", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.Toggle()
|
2015-06-29 18:00:40 -07:00
|
|
|
})
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.AddCommand("On", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.On()
|
2015-06-29 18:00:40 -07:00
|
|
|
})
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.AddCommand("Off", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.Off()
|
2015-06-29 18:00:40 -07:00
|
|
|
})
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
return d
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Start implements the Driver interface
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Start() error { return nil }
|
2015-06-29 18:00:40 -07:00
|
|
|
|
|
|
|
// Halt implements the Driver interface
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Halt() error { return nil }
|
2015-06-29 18:00:40 -07:00
|
|
|
|
|
|
|
// Name returns the RelayDrivers name
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Name() string { return d.name }
|
2015-06-29 18:00:40 -07:00
|
|
|
|
2016-09-25 13:36:18 +02:00
|
|
|
// SetName sets the RelayDrivers name
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) SetName(n string) { d.name = n }
|
2016-09-25 13:36:18 +02:00
|
|
|
|
2015-06-29 18:00:40 -07:00
|
|
|
// Pin returns the RelayDrivers name
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Pin() string { return d.pin }
|
2015-06-29 18:00:40 -07:00
|
|
|
|
|
|
|
// Connection returns the RelayDrivers Connection
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Connection() gobot.Connection {
|
|
|
|
if conn, ok := d.connection.(gobot.Connection); ok {
|
|
|
|
return conn
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("%s has no gobot connection\n", d.name)
|
|
|
|
return nil
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// State return true if the relay is On and false if the relay is Off
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) State() bool {
|
|
|
|
if d.Inverted {
|
|
|
|
return !d.high
|
2019-06-25 06:13:17 +01:00
|
|
|
}
|
2023-11-15 20:51:52 +01:00
|
|
|
return d.high
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// On sets the relay to a high state.
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) On() error {
|
2020-03-31 06:43:00 +01:00
|
|
|
newValue := byte(1)
|
2023-11-15 20:51:52 +01:00
|
|
|
if d.Inverted {
|
2020-03-31 06:43:00 +01:00
|
|
|
newValue = 0
|
|
|
|
}
|
2023-11-15 20:51:52 +01:00
|
|
|
if err := d.connection.DigitalWrite(d.Pin(), newValue); err != nil {
|
|
|
|
return err
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
2019-06-25 06:13:17 +01:00
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.high = !d.Inverted
|
2019-06-25 06:13:17 +01:00
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
return nil
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Off sets the relay to a low state.
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Off() error {
|
2020-03-31 06:43:00 +01:00
|
|
|
newValue := byte(0)
|
2023-11-15 20:51:52 +01:00
|
|
|
if d.Inverted {
|
2020-03-31 06:43:00 +01:00
|
|
|
newValue = 1
|
|
|
|
}
|
2023-11-15 20:51:52 +01:00
|
|
|
if err := d.connection.DigitalWrite(d.Pin(), newValue); err != nil {
|
|
|
|
return err
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
2019-06-25 06:13:17 +01:00
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.high = d.Inverted
|
2019-06-25 06:13:17 +01:00
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
return nil
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Toggle sets the relay to the opposite of it's current state
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *RelayDriver) Toggle() error {
|
|
|
|
if d.State() {
|
|
|
|
return d.Off()
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|
2023-11-15 20:51:52 +01:00
|
|
|
|
|
|
|
return d.On()
|
2015-06-29 18:00:40 -07:00
|
|
|
}
|