2018-11-20 21:55:06 +00:00
|
|
|
package sensor
|
|
|
|
|
2019-02-24 21:46:36 +00:00
|
|
|
import (
|
2019-06-17 21:37:48 +00:00
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"math"
|
2019-02-24 21:46:36 +00:00
|
|
|
"sync"
|
|
|
|
|
2019-06-15 13:58:41 +00:00
|
|
|
"github.com/go-flucky/flucky/pkg/internal/collect"
|
|
|
|
"github.com/go-flucky/flucky/pkg/internal/prittyprint"
|
|
|
|
"github.com/go-flucky/flucky/pkg/types"
|
2019-02-24 21:46:36 +00:00
|
|
|
)
|
|
|
|
|
2019-06-13 19:25:32 +00:00
|
|
|
// ReadHumidities returns a list of measured humidities by humidity sensors
|
2019-06-17 21:37:48 +00:00
|
|
|
func ReadHumidities(humiditySensors []HumiditySensor, round float64) ([]*types.Humidity, error) {
|
2019-06-13 19:25:32 +00:00
|
|
|
humidityChannel := make(chan *types.Humidity, len(humiditySensors))
|
2019-06-17 21:37:48 +00:00
|
|
|
errorChannel := make(chan error, len(humiditySensors))
|
|
|
|
|
|
|
|
wg := new(sync.WaitGroup)
|
|
|
|
wg.Add(len(humiditySensors))
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
for _, humiditySensor := range humiditySensors {
|
|
|
|
go humiditySensor.ReadHumidityWriteIntoChannel(humidityChannel, errorChannel, wg)
|
2019-06-13 19:25:32 +00:00
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
errors := collect.Errors(errorChannel)
|
|
|
|
if len(errors) > 0 {
|
|
|
|
return nil, prittyprint.FormatErrors(errors)
|
|
|
|
}
|
|
|
|
|
|
|
|
humidities := collect.Humidities(humidityChannel)
|
|
|
|
|
|
|
|
if round != 0 {
|
|
|
|
for _, humidity := range humidities {
|
|
|
|
humidity.HumidityValue = math.Round(humidity.HumidityValue/round) * round
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return humidities, nil
|
2019-06-13 19:25:32 +00:00
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
// ReadHumiditiesWriteIntoChannel reads the humidity values of humidity sensors and writes them into a channel
|
|
|
|
func ReadHumiditiesWriteIntoChannel(ctx context.Context, humiditySensors []HumiditySensor, humidityChannel chan<- *types.Humidity, errorChannel chan<- error, wg *sync.WaitGroup) {
|
2019-02-24 21:46:36 +00:00
|
|
|
for _, humiditySensor := range humiditySensors {
|
2019-06-17 21:37:48 +00:00
|
|
|
humiditySensor.ReadHumidityWriteIntoChannel(humidityChannel, errorChannel, wg)
|
2019-02-24 21:46:36 +00:00
|
|
|
}
|
2019-06-13 19:25:32 +00:00
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-13 19:25:32 +00:00
|
|
|
// ReadHumiditiesContinuously reads the humidity values of humidity sensors continuously and writes them into a channel
|
2019-06-17 21:37:48 +00:00
|
|
|
func ReadHumiditiesContinuously(ctx context.Context, humiditySensors []HumiditySensor, humidityChannel chan<- *types.Humidity, errorChannel chan<- error) {
|
2019-06-13 19:25:32 +00:00
|
|
|
for {
|
2019-06-17 21:37:48 +00:00
|
|
|
select {
|
|
|
|
case <-ctx.Done():
|
|
|
|
errorChannel <- fmt.Errorf("Context closed: %v", ctx.Err())
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
ReadHumiditiesWriteIntoChannel(ctx, humiditySensors, humidityChannel, errorChannel, nil)
|
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
}
|
2019-06-13 19:25:32 +00:00
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-13 19:25:32 +00:00
|
|
|
// ReadTemperatures returns a list of measured temperatures by temperature sensors
|
2019-06-17 21:37:48 +00:00
|
|
|
func ReadTemperatures(temperatureSensors []TemperatureSensor, round float64) ([]*types.Temperature, error) {
|
2019-06-13 19:25:32 +00:00
|
|
|
temperatureChannel := make(chan *types.Temperature, len(temperatureSensors))
|
2019-06-17 21:37:48 +00:00
|
|
|
errorChannel := make(chan error, len(temperatureSensors))
|
|
|
|
|
|
|
|
wg := new(sync.WaitGroup)
|
|
|
|
wg.Add(len(temperatureSensors))
|
|
|
|
|
|
|
|
for _, temperatureSensor := range temperatureSensors {
|
|
|
|
go temperatureSensor.ReadTemperatureWriteIntoChannel(temperatureChannel, errorChannel, wg)
|
|
|
|
}
|
|
|
|
|
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
errors := collect.Errors(errorChannel)
|
|
|
|
if len(errors) > 0 {
|
|
|
|
return nil, prittyprint.FormatErrors(errors)
|
|
|
|
}
|
|
|
|
|
|
|
|
temperatures := collect.Temperatures(temperatureChannel)
|
2019-02-24 21:46:36 +00:00
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
if round != 0 {
|
|
|
|
for _, temperature := range temperatures {
|
|
|
|
temperature.TemperatureValue = math.Round(temperature.TemperatureValue/round) * round
|
|
|
|
}
|
2019-06-13 19:25:32 +00:00
|
|
|
}
|
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
return temperatures, nil
|
2018-11-28 17:07:20 +00:00
|
|
|
}
|
|
|
|
|
2019-06-17 21:37:48 +00:00
|
|
|
// ReadTemperaturesWriteIntoChannel reads the temperature values of temperature sensors and writes them into a channel
|
|
|
|
func ReadTemperaturesWriteIntoChannel(ctx context.Context, temperatureSensors []TemperatureSensor, temperatureChannel chan<- *types.Temperature, errorChannel chan<- error, wg *sync.WaitGroup) {
|
2019-02-24 21:46:36 +00:00
|
|
|
for _, temperatureSensor := range temperatureSensors {
|
2019-06-17 21:37:48 +00:00
|
|
|
temperatureSensor.ReadTemperatureWriteIntoChannel(temperatureChannel, errorChannel, wg)
|
2019-02-24 21:46:36 +00:00
|
|
|
}
|
2019-06-17 21:37:48 +00:00
|
|
|
|
2019-02-24 21:46:36 +00:00
|
|
|
}
|
|
|
|
|
2019-06-13 19:25:32 +00:00
|
|
|
// ReadTemperaturesContinuously reads the temperature values of temperature sensors continuously and writes them into a chann
|
2019-06-17 21:37:48 +00:00
|
|
|
func ReadTemperaturesContinuously(ctx context.Context, temperatureSensors []TemperatureSensor, temperatureChannel chan<- *types.Temperature, errorChannel chan<- error) {
|
2019-02-24 21:46:36 +00:00
|
|
|
for {
|
2019-06-17 21:37:48 +00:00
|
|
|
select {
|
|
|
|
case <-ctx.Done():
|
|
|
|
errorChannel <- fmt.Errorf("Context closed: %v", ctx.Err())
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
ReadTemperaturesWriteIntoChannel(ctx, temperatureSensors, temperatureChannel, errorChannel, nil)
|
|
|
|
}
|
2019-02-24 21:46:36 +00:00
|
|
|
}
|
|
|
|
}
|