config

package
v0.2024.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 5, 2024 License: GPL-3.0 Imports: 4 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	DefaultModeSource           = SwitchMode{Key: "hvac.mode", On: "auto", Off: "manual"}
	DefaultOccupancyModeTarget  = SwitchMode{Key: "occupancy", On: "occupied", Off: "unoccupied"}
	DefaultDeadbandModeTarget   = SwitchMode{Key: "deadband", On: "comfort", Off: "eco"}
	DefaultWriteCacheExpiry     = 0 * time.Second
	DefaultWriteRetryDelay      = time.Minute
	DefaultWriteEvery           = 0 * time.Second
	DefaultWriteReadPropagation = 5 * time.Second
	DefaultUnoccupiedDelay      = 15 * time.Minute
	DefaultResetModeSourceDelay = 4 * time.Hour
	DefaultAutoModeSetPoint     = float32(21.0)
)

Functions

func PtrOr

func PtrOr[T any](p *T, or T) T

Types

type Range

type Range struct {
	Start jsontypes.Schedule `json:"start,omitempty"`
	End   jsontypes.Schedule `json:"end,omitempty"`
}

type Root

type Root struct {
	auto.Config

	DryRun              bool `json:"dryRun,omitempty"`              // Don't actually write to devices
	LogDeviceWrites     bool `json:"logDeviceWrites,omitempty"`     // Log each write to a device as they happen
	LogDuplicateChanges bool `json:"logDuplicateChanges,omitempty"` // Log even if all writes were blocked by caching
	LogTTLDelays        bool `json:"logTTLDelays,omitempty"`        // Log the TTL when no writes were performed
	LogReads            bool `json:"logReads,omitempty"`            // Log each read from a device as they happen. Warning this is noisy

	// How long should a past write affect future writes.
	WriteCacheExpiry *jsontypes.Duration `json:"writeCacheExpiry,omitempty"` // Defaults to no expiry.
	// If processing fails, how long to wait before trying again.
	WriteRetryDelay *jsontypes.Duration `json:"WriteRetryDelay,omitempty"` // Defaults to 1m.
	// Reprocess state at least this often.
	WriteEvery *jsontypes.Duration `json:"writeEvery,omitempty"` // Defaults to never.
	// How long do we allow for writes to be picked up as reads.
	// For devices that we both read from and write to, we cache the read state in the write state to avoid writing the same value back to the device.
	// We only cache the read value if it is newer than the write, this property configures what "newer" means.
	// The read must be at least WriteReadPropagation newer than the write to be cached.
	WriteReadPropagation *jsontypes.Duration `json:"writeReadPropagation,omitempty"` // Defaults to 5s.

	// The device that we read the automation mode from.
	// See DefaultModeSource for the default values.
	ModeSource SwitchMode `json:"modeSource,omitempty"`
	// How long after ModeSource changes away from "auto" do we change it back to "auto".
	// Defaults to 4h.
	ResetModeSourceDelay *jsontypes.Duration `json:"resetModeSourceDelay,omitempty"`
	AutoModeSetPoint     *float32            `json:"autoModeSetPoint,omitempty"` // Defaults to 21.0 unless AutoModeOATemp is specified.
	AutoThermostats      []string            `json:"autoThermostats,omitempty"`  // Thermostats that we control in auto mode.
	// AutoModeOATemp is the device that we read the outdoor air temperature from.
	// If specified, AutoModeOATemp is read and used as a basis for auto mode set point values.
	// Typically the indoor set point is proportional to the weighted average of recent outdoor temperatures.
	// If this device supports AirTemperatureHistory then it will be used to seed the weighted average.
	AutoModeOATemp string `json:"oaTemp,omitempty"`

	OccupancySensors     []string            `json:"occupancySensors,omitempty"`     // Sensors whose occupancy is linked with OccupancyModeTargets On mode.
	OccupancyModeTargets []SwitchMode        `json:"occupancyModeTargets,omitempty"` // Defaults: on=occupied, off=unoccupied
	UnoccupiedDelay      *jsontypes.Duration `json:"unoccupiedDelay,omitempty"`      // Defaults to 15m.

	DeadbandSchedule    []Range      `json:"deadbandSchedule,omitempty"`    // Periods of time when DeadbandModeTargets should be On
	DeadbandModeTargets []SwitchMode `json:"deadbandModeTargets,omitempty"` // Defaults: on=comfort, off=eco
}

func ReadBytes

func ReadBytes(data []byte) (cfg Root, err error)

type SwitchMode

type SwitchMode struct {
	Name string `json:"name,omitempty"` // name of the device that implements Mode
	Key  string `json:"key,omitempty"`  // mode key to set
	On   string `json:"on,omitempty"`   // value when on
	Off  string `json:"off,omitempty"`  // value when off
}

SwitchMode represents a mode option that we switch between two values.

func (*SwitchMode) ApplyDefaults

func (s *SwitchMode) ApplyDefaults(d SwitchMode)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL