mirror of
https://github.com/onyx-and-iris/vbantxt.git
synced 2025-04-04 21:33:51 +01:00
Compare commits
No commits in common. "585b4d4c14accc32ee4e7dc31efd41da84478d1a" and "7d93ecb1c7036f5584ed9eb4108d2ca02039546b" have entirely different histories.
585b4d4c14
...
7d93ecb1c7
29
.github/workflows/golang-ci.yml
vendored
29
.github/workflows/golang-ci.yml
vendored
@ -1,29 +0,0 @@
|
|||||||
name: CI
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [ "main" ]
|
|
||||||
paths:
|
|
||||||
- '**.go'
|
|
||||||
pull_request:
|
|
||||||
branches: [ "main" ]
|
|
||||||
paths:
|
|
||||||
- '**.go'
|
|
||||||
jobs:
|
|
||||||
lint:
|
|
||||||
name: Lint
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: github.event_name == 'pull_request'
|
|
||||||
timeout-minutes: 3
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: Setup Go
|
|
||||||
uses: actions/setup-go@v5
|
|
||||||
with:
|
|
||||||
go-version: '1.24'
|
|
||||||
- name: Install golangci-lint
|
|
||||||
run: go install github.com/golangci/golangci-lint/cmd/golangci-lint@latest
|
|
||||||
- name: Run golangci-lint
|
|
||||||
run: golangci-lint run ./...
|
|
@ -1,54 +0,0 @@
|
|||||||
run:
|
|
||||||
# timeout for analysis, e.g. 30s, 3m, default is 1m
|
|
||||||
timeout: 3m
|
|
||||||
# exclude test files
|
|
||||||
tests: true
|
|
||||||
|
|
||||||
linters:
|
|
||||||
# Set to true runs only fast linters.
|
|
||||||
# Good option for 'lint on save', pre-commit hook or CI.
|
|
||||||
fast: true
|
|
||||||
|
|
||||||
disable-all: true
|
|
||||||
|
|
||||||
enable:
|
|
||||||
- gosimple
|
|
||||||
- govet
|
|
||||||
- ineffassign
|
|
||||||
- staticcheck
|
|
||||||
- unused
|
|
||||||
- gofmt
|
|
||||||
- gofumpt
|
|
||||||
- misspell
|
|
||||||
- unparam
|
|
||||||
- gosec
|
|
||||||
- asciicheck
|
|
||||||
- errname
|
|
||||||
- gci
|
|
||||||
- godot
|
|
||||||
- goimports
|
|
||||||
- revive
|
|
||||||
|
|
||||||
linters-settings:
|
|
||||||
gofmt:
|
|
||||||
rewrite-rules:
|
|
||||||
- pattern: 'interface{}'
|
|
||||||
replacement: 'any'
|
|
||||||
- pattern: 'a[b:len(a)]'
|
|
||||||
replacement: 'a[b:]'
|
|
||||||
|
|
||||||
misspell:
|
|
||||||
locale: UK
|
|
||||||
|
|
||||||
errcheck:
|
|
||||||
check-type-assertions: true
|
|
||||||
|
|
||||||
issues:
|
|
||||||
max-same-issues: 0
|
|
||||||
max-issues-per-linter: 0
|
|
||||||
exclude-use-default: false
|
|
||||||
exclude:
|
|
||||||
# gosec: Duplicated errcheck checks
|
|
||||||
- G104
|
|
||||||
# gosec: integer overflow conversion int -> uint32
|
|
||||||
- G115
|
|
@ -1,4 +1,3 @@
|
|||||||
// Package main provides the configuration loading functionality for the vbantxt application.
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
@ -35,4 +35,5 @@ func TestLoadConfig_Errors(t *testing.T) {
|
|||||||
assert.ErrorContains(t, err, tc.err)
|
assert.ErrorContains(t, err, tc.err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
// Package vbantxt provides utilities for handling VBAN text errors.
|
|
||||||
package vbantxt
|
package vbantxt
|
||||||
|
|
||||||
// Error is used to define sentinel errors.
|
// Error is used to define sentinel errors.
|
||||||
|
@ -9,14 +9,14 @@ import (
|
|||||||
// Option is a functional option type that allows us to configure the VbanTxt.
|
// Option is a functional option type that allows us to configure the VbanTxt.
|
||||||
type Option func(*VbanTxt)
|
type Option func(*VbanTxt)
|
||||||
|
|
||||||
// WithRateLimit is a functional option to set the ratelimit for requests.
|
// WithRateLimit is a functional option to set the ratelimit for requests
|
||||||
func WithRateLimit(ratelimit time.Duration) Option {
|
func WithRateLimit(ratelimit time.Duration) Option {
|
||||||
return func(vt *VbanTxt) {
|
return func(vt *VbanTxt) {
|
||||||
vt.ratelimit = ratelimit
|
vt.ratelimit = ratelimit
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// WithBPSOpt is a functional option to set the bps index for {VbanTxt}.packet.
|
// WithBPSOpt is a functional option to set the bps index for {VbanTxt}.packet
|
||||||
func WithBPSOpt(bps int) Option {
|
func WithBPSOpt(bps int) Option {
|
||||||
return func(vt *VbanTxt) {
|
return func(vt *VbanTxt) {
|
||||||
bpsIndex := indexOf(BpsOpts, bps)
|
bpsIndex := indexOf(BpsOpts, bps)
|
||||||
@ -28,7 +28,7 @@ func WithBPSOpt(bps int) Option {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// WithChannel is a functional option to set the channel for {VbanTxt}.packet.
|
// WithChannel is a functional option to set the channel for {VbanTxt}.packet
|
||||||
func WithChannel(channel int) Option {
|
func WithChannel(channel int) Option {
|
||||||
return func(vt *VbanTxt) {
|
return func(vt *VbanTxt) {
|
||||||
vt.packet.channel = channel
|
vt.packet.channel = channel
|
||||||
|
15
packet.go
15
packet.go
@ -13,12 +13,9 @@ const (
|
|||||||
headerSz = 4 + 1 + 1 + 1 + 1 + 16 + 4
|
headerSz = 4 + 1 + 1 + 1 + 1 + 16 + 4
|
||||||
)
|
)
|
||||||
|
|
||||||
// BpsOpts defines the available baud rate options.
|
var BpsOpts = []int{0, 110, 150, 300, 600, 1200, 2400, 4800, 9600, 14400, 19200, 31250,
|
||||||
var BpsOpts = []int{
|
|
||||||
0, 110, 150, 300, 600, 1200, 2400, 4800, 9600, 14400, 19200, 31250,
|
|
||||||
38400, 57600, 115200, 128000, 230400, 250000, 256000, 460800, 921600,
|
38400, 57600, 115200, 128000, 230400, 250000, 256000, 460800, 921600,
|
||||||
1000000, 1500000, 2000000, 3000000,
|
1000000, 1500000, 2000000, 3000000}
|
||||||
}
|
|
||||||
|
|
||||||
type packet struct {
|
type packet struct {
|
||||||
streamname []byte
|
streamname []byte
|
||||||
@ -42,17 +39,17 @@ func newPacket(streamname string) packet {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// sr defines the samplerate for the request.
|
// sr defines the samplerate for the request
|
||||||
func (p *packet) sr() byte {
|
func (p *packet) sr() byte {
|
||||||
return byte(vbanProtocolTxt + p.bpsIndex)
|
return byte(vbanProtocolTxt + p.bpsIndex)
|
||||||
}
|
}
|
||||||
|
|
||||||
// nbc defines the channel of the request.
|
// nbc defines the channel of the request
|
||||||
func (p *packet) nbc() byte {
|
func (p *packet) nbc() byte {
|
||||||
return byte(p.channel)
|
return byte(p.channel)
|
||||||
}
|
}
|
||||||
|
|
||||||
// header returns a fully formed packet header.
|
// header returns a fully formed packet header
|
||||||
func (p *packet) header() []byte {
|
func (p *packet) header() []byte {
|
||||||
p.hbuf.Reset()
|
p.hbuf.Reset()
|
||||||
p.hbuf.WriteString("VBAN")
|
p.hbuf.WriteString("VBAN")
|
||||||
@ -65,7 +62,7 @@ func (p *packet) header() []byte {
|
|||||||
return p.hbuf.Bytes()
|
return p.hbuf.Bytes()
|
||||||
}
|
}
|
||||||
|
|
||||||
// bumpFrameCounter increments the frame counter by 1.
|
// bumpFrameCounter increments the frame counter by 1
|
||||||
func (p *packet) bumpFrameCounter() {
|
func (p *packet) bumpFrameCounter() {
|
||||||
x := binary.LittleEndian.Uint32(p.framecounter)
|
x := binary.LittleEndian.Uint32(p.framecounter)
|
||||||
binary.LittleEndian.PutUint32(p.framecounter, x+1)
|
binary.LittleEndian.PutUint32(p.framecounter, x+1)
|
||||||
|
@ -7,12 +7,12 @@ import (
|
|||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
|
|
||||||
// udpConn represents the UDP client.
|
// udpConn represents the UDP client
|
||||||
type udpConn struct {
|
type udpConn struct {
|
||||||
conn *net.UDPConn
|
conn *net.UDPConn
|
||||||
}
|
}
|
||||||
|
|
||||||
// newUDPConn returns a UDP client.
|
// newUDPConn returns a UDP client
|
||||||
func newUDPConn(host string, port int) (udpConn, error) {
|
func newUDPConn(host string, port int) (udpConn, error) {
|
||||||
udpAddr, err := net.ResolveUDPAddr("udp4", fmt.Sprintf("%s:%d", host, port))
|
udpAddr, err := net.ResolveUDPAddr("udp4", fmt.Sprintf("%s:%d", host, port))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -27,7 +27,7 @@ func newUDPConn(host string, port int) (udpConn, error) {
|
|||||||
return udpConn{conn: conn}, nil
|
return udpConn{conn: conn}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write implements the io.WriteCloser interface.
|
// Write implements the io.WriteCloser interface
|
||||||
func (u udpConn) Write(buf []byte) (int, error) {
|
func (u udpConn) Write(buf []byte) (int, error) {
|
||||||
n, err := u.conn.Write(buf)
|
n, err := u.conn.Write(buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -38,7 +38,7 @@ func (u udpConn) Write(buf []byte) (int, error) {
|
|||||||
return n, nil
|
return n, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close implements the io.WriteCloser interface.
|
// Close implements the io.WriteCloser interface
|
||||||
func (u udpConn) Close() error {
|
func (u udpConn) Close() error {
|
||||||
err := u.conn.Close()
|
err := u.conn.Close()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -49,7 +49,7 @@ func (vt VbanTxt) Send(cmd string) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close is responsible for closing the UDP Client connection.
|
// Close is responsible for closing the UDP Client connection
|
||||||
func (vt VbanTxt) Close() error {
|
func (vt VbanTxt) Close() error {
|
||||||
err := vt.udpConn.Close()
|
err := vt.udpConn.Close()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user