Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
de4758c563 | ||
![]() |
a85c9ccd66 | ||
![]() |
da78a00446 | ||
![]() |
ba3c55dc34 | ||
![]() |
e0950b44ee | ||
![]() |
76a036707f | ||
![]() |
258323f5b7 | ||
![]() |
473eb22b97 |
4
.github/workflows/build.yml
vendored
4
.github/workflows/build.yml
vendored
@@ -36,9 +36,9 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
mkdir -p build
|
mkdir -p build
|
||||||
if [ "${{ matrix.goos }}" == "windows" ]; then
|
if [ "${{ matrix.goos }}" == "windows" ]; then
|
||||||
GOOS=${{ matrix.goos }} GOARCH=${{ matrix.goarch }} go build -o build/tecamino-driver-artNet-${{ matrix.goos }}-${{ matrix.goarch }}.exe main.go
|
GOOS=${{ matrix.goos }} GOARCH=${{ matrix.goarch }} go build -ldflags="-s -w" -trimpath -o build/tecamino-driver-artNet-${{ matrix.goos }}-${{ matrix.goarch }}.exe main.go
|
||||||
else
|
else
|
||||||
GOOS=${{ matrix.goos }} GOARCH=${{ matrix.goarch }} go build -o build/tecamino-driver-artNet-${{ matrix.goos }}-${{ matrix.goarch }} main.go
|
GOOS=${{ matrix.goos }} GOARCH=${{ matrix.goarch }} go build -ldflags="-s -w" -trimpath -o build/tecamino-driver-artNet-${{ matrix.goos }}-${{ matrix.goarch }} main.go
|
||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Upload artifacts
|
- name: Upload artifacts
|
||||||
|
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,3 +1,5 @@
|
|||||||
|
.DS_Store
|
||||||
*.cfg
|
*.cfg
|
||||||
*.log
|
*.log
|
||||||
artNetDriver-arm64
|
artNetDriver-arm64
|
||||||
|
tecamino-driver-artNet-linux-arm64
|
||||||
|
@@ -4,6 +4,7 @@ import (
|
|||||||
"artNet/cfg"
|
"artNet/cfg"
|
||||||
"artNet/models"
|
"artNet/models"
|
||||||
ws "artNet/websocket"
|
ws "artNet/websocket"
|
||||||
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"path"
|
"path"
|
||||||
|
|
||||||
@@ -81,7 +82,7 @@ func (d *ArtNetDriver) SetValue(bus string, address uint, value uint8) error {
|
|||||||
return fmt.Errorf("no dmx data on bus '%s' found", bus)
|
return fmt.Errorf("no dmx data on bus '%s' found", bus)
|
||||||
}
|
}
|
||||||
d.Buses[bus].Data.SetValue(address, value)
|
d.Buses[bus].Data.SetValue(address, value)
|
||||||
return d.Buses[bus].SendData()
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// connect to websocket server and listen to subscriptions
|
// connect to websocket server and listen to subscriptions
|
||||||
@@ -101,7 +102,23 @@ func (d *ArtNetDriver) Connect(ip, id string, port uint) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
client.OnMessage = func(data []byte) {
|
client.OnMessage = func(data []byte) {
|
||||||
fmt.Println(100, string(data))
|
|
||||||
|
request := json_data.NewResponse()
|
||||||
|
err = json.Unmarshal(data, &request)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if request.Subscribe != nil {
|
||||||
|
d.Subscribe(request.Subscribe...)
|
||||||
|
}
|
||||||
|
if request.Publish != nil {
|
||||||
|
d.Publish(request.Publish...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
d.Log.Error("artNet.Connect", err)
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
req := json_data.NewRequest()
|
req := json_data.NewRequest()
|
||||||
@@ -112,10 +129,15 @@ func (d *ArtNetDriver) Connect(ip, id string, port uint) error {
|
|||||||
d.Log.Error("websocket send data", err)
|
d.Log.Error("websocket send data", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
for {
|
for err := range errChan {
|
||||||
select {
|
|
||||||
case err := <-errChan:
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// send data to all buses that the send flage is true
|
||||||
|
func (d *ArtNetDriver) SendData() {
|
||||||
|
for _, bus := range d.Buses {
|
||||||
|
bus.Send <- bus.Data
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
19
driver/publish.go
Normal file
19
driver/publish.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package driver
|
||||||
|
|
||||||
|
import (
|
||||||
|
json_dataModels "github.com/tecamino/tecamino-json_data/models"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (d *ArtNetDriver) Publish(pubs ...json_dataModels.Publish) error {
|
||||||
|
if d.Subscriptions == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, pub := range pubs {
|
||||||
|
if drv, ok := (d.Subscriptions)[pub.Uuid]; ok {
|
||||||
|
d.SetValue(drv.Bus, drv.Address, uint8(pub.Value.(float64)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
d.SendData()
|
||||||
|
return nil
|
||||||
|
}
|
@@ -17,4 +17,5 @@ func (d *ArtNetDriver) Subscribe(subs ...json_dataModels.Subscription) {
|
|||||||
d.SetValue(drv.Bus, drv.Address, uint8(sub.Value.(float64)))
|
d.SetValue(drv.Bus, drv.Address, uint8(sub.Value.(float64)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
d.SendData()
|
||||||
}
|
}
|
||||||
|
@@ -29,6 +29,7 @@ type Bus struct {
|
|||||||
Resubscribe *[]json_dataModels.Subscription `yaml:"-" json:"resubscribe"`
|
Resubscribe *[]json_dataModels.Subscription `yaml:"-" json:"resubscribe"`
|
||||||
Watchdog context.CancelFunc `yaml:"-" json:"-"`
|
Watchdog context.CancelFunc `yaml:"-" json:"-"`
|
||||||
Reachable bool `yaml:"-" json:"-"`
|
Reachable bool `yaml:"-" json:"-"`
|
||||||
|
Send chan *DMX `yaml:"-" json:"-"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// adds new Art-Net interface to driver port 0 = 6454 (default art-net)
|
// adds new Art-Net interface to driver port 0 = 6454 (default art-net)
|
||||||
@@ -102,13 +103,15 @@ func (b *Bus) Poll(interval time.Duration) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// start bus
|
// start bus
|
||||||
func (b *Bus) Start(log *logging.Logger) {
|
func (b *Bus) Start(log *logging.Logger) error {
|
||||||
var ctx context.Context
|
var ctx context.Context
|
||||||
ctx, b.Watchdog = context.WithCancel(context.Background())
|
ctx, b.Watchdog = context.WithCancel(context.Background())
|
||||||
|
|
||||||
|
b.Send = make(chan *DMX, 1024)
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
var interval time.Duration = 10 * time.Second
|
var interval time.Duration = 10 * time.Second
|
||||||
log.Info("bus.Start", fmt.Sprintf("device:%s ip:%s watchdog stopped", b.Name, b.Ip))
|
log.Info("bus.Start", fmt.Sprintf("device:%s ip:%s watchdog starting", b.Name, b.Ip))
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
@@ -125,6 +128,8 @@ func (b *Bus) Start(log *logging.Logger) {
|
|||||||
interval = 5 * time.Second
|
interval = 5 * time.Second
|
||||||
} else {
|
} else {
|
||||||
b.Reachable = true
|
b.Reachable = true
|
||||||
|
// send data as a heartbeat for she ArtNet Protocol
|
||||||
|
b.Send <- b.Data
|
||||||
log.Info("bus.Start", fmt.Sprintf("device:%s ip:%s watchdog running", b.Name, b.Ip))
|
log.Info("bus.Start", fmt.Sprintf("device:%s ip:%s watchdog running", b.Name, b.Ip))
|
||||||
interval = 30 * time.Second
|
interval = 30 * time.Second
|
||||||
}
|
}
|
||||||
@@ -132,26 +137,7 @@ func (b *Bus) Start(log *logging.Logger) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
}
|
|
||||||
|
|
||||||
// stop bus
|
|
||||||
func (b *Bus) Stop() {
|
|
||||||
if b.Watchdog != nil {
|
|
||||||
b.Watchdog()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// status bus
|
|
||||||
func (b *Bus) Status() bool {
|
|
||||||
return b.Watchdog != nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// send dmx data
|
|
||||||
func (b *Bus) SendData() error {
|
|
||||||
if !b.Reachable {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
// Send packet over UDP
|
|
||||||
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
|
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
|
||||||
IP: net.ParseIP(b.Ip),
|
IP: net.ParseIP(b.Ip),
|
||||||
Port: *b.Port,
|
Port: *b.Port,
|
||||||
@@ -160,11 +146,37 @@ func (b *Bus) SendData() error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
go func() {
|
||||||
defer conn.Close()
|
defer conn.Close()
|
||||||
|
//close send channel
|
||||||
|
defer close(b.Send)
|
||||||
|
|
||||||
_, err = conn.Write(NewArtNetPackage(b.Data))
|
for send := range b.Send {
|
||||||
|
_, err = conn.Write(NewArtNetPackage(send))
|
||||||
|
if err != nil {
|
||||||
|
log.Error("bus.Start", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
time.Sleep(23 * time.Millisecond)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
return err
|
// stop bus
|
||||||
|
func (b *Bus) Stop() {
|
||||||
|
if b.Watchdog != nil {
|
||||||
|
//cancels context
|
||||||
|
b.Watchdog()
|
||||||
|
//close send channel
|
||||||
|
close(b.Send)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// status bus
|
||||||
|
func (b *Bus) Status() bool {
|
||||||
|
return b.Watchdog != nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *Bus) ParsePayload(c *gin.Context) error {
|
func (b *Bus) ParsePayload(c *gin.Context) error {
|
||||||
|
Reference in New Issue
Block a user