Compare commits
17 Commits
1.1.7
...
2.1.2-conf
| Author | SHA1 | Date | |
|---|---|---|---|
|
7794fabaf3
|
|||
|
6e6ff4c229
|
|||
|
dc2175c298
|
|||
|
6d8c5c25db
|
|||
|
ca08059e13
|
|||
|
6796bdd905
|
|||
|
6c208e32bf
|
|||
|
d2ee8a80c2
|
|||
|
5e0127b571
|
|||
|
311d4cf555
|
|||
|
ad043b5921
|
|||
|
7c90962de1
|
|||
|
3a4cd499a5
|
|||
|
6e50654d00
|
|||
|
e820aa2000
|
|||
|
8e60802a7a
|
|||
|
2f87ec6d37
|
@@ -18,6 +18,10 @@ steps:
|
|||||||
repo: ${FORGE_NAME}/${CI_REPO}
|
repo: ${FORGE_NAME}/${CI_REPO}
|
||||||
auto_tag: true
|
auto_tag: true
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
exclude:
|
||||||
|
- refs/tags/*-configchange
|
||||||
|
|
||||||
namespace:
|
namespace:
|
||||||
image: quay.io/wollud1969/k8s-admin-helper:0.3.4
|
image: quay.io/wollud1969/k8s-admin-helper:0.3.4
|
||||||
@@ -29,6 +33,10 @@ steps:
|
|||||||
- printf "$KUBE_CONFIG_CONTENT" > /tmp/kubeconfig
|
- printf "$KUBE_CONFIG_CONTENT" > /tmp/kubeconfig
|
||||||
- export KUBECONFIG=/tmp/kubeconfig
|
- export KUBECONFIG=/tmp/kubeconfig
|
||||||
- kubectl create namespace $NAMESPACE || echo "Namespace $NAMESPACE already exists"
|
- kubectl create namespace $NAMESPACE || echo "Namespace $NAMESPACE already exists"
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
exclude:
|
||||||
|
- refs/tags/*-configchange
|
||||||
|
|
||||||
configuration:
|
configuration:
|
||||||
image: quay.io/wollud1969/k8s-admin-helper:0.3.4
|
image: quay.io/wollud1969/k8s-admin-helper:0.3.4
|
||||||
@@ -55,3 +63,7 @@ steps:
|
|||||||
- printf "$KUBE_CONFIG_CONTENT" > /tmp/kubeconfig
|
- printf "$KUBE_CONFIG_CONTENT" > /tmp/kubeconfig
|
||||||
- export KUBECONFIG=/tmp/kubeconfig
|
- export KUBECONFIG=/tmp/kubeconfig
|
||||||
- cat deployment/install-yml.tmpl | sed "s,%IMAGE%,$IMAGE,g" | kubectl apply -n $NAMESPACE -f -
|
- cat deployment/install-yml.tmpl | sed "s,%IMAGE%,$IMAGE,g" | kubectl apply -n $NAMESPACE -f -
|
||||||
|
when:
|
||||||
|
ref:
|
||||||
|
exclude:
|
||||||
|
- refs/tags/*-configchange
|
||||||
|
|||||||
@@ -1,31 +1,14 @@
|
|||||||
global:
|
global:
|
||||||
scan_interval: 1
|
scan_interval: 0.25
|
||||||
log_level: INFO
|
log_level: INFO
|
||||||
|
|
||||||
mqtt:
|
mqtt:
|
||||||
broker: 172.16.2.16
|
broker: emqx01-anonymous-cluster-internal.broker.svc.cluster.local
|
||||||
port: 1883
|
port: 1883
|
||||||
|
|
||||||
modbus:
|
modbus:
|
||||||
gateway: 172.16.2.42
|
gateway: 172.16.2.42
|
||||||
|
|
||||||
# REGISTERS = [
|
|
||||||
# { "slave":2, "addr":0x0048, "type":"input", "attr": "importEnergyActive", "name":"Import active energy", "unit":"kWh", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x004c, "type":"input", "attr": "importEnergyReactive", "name":"Import reactive energy", "unit":"kVAh", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x004a, "type":"input", "attr": "exportEnergyActive", "name":"Export active energy", "unit":"kWh", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x004e, "type":"input", "attr": "exportEnergyReactive", "name":"Export reactive energy", "unit":"kVAh", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0012, "type":"input", "attr": "powerApparent", "name":"Apparent Power", "unit":"W", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x000c, "type":"input", "attr": "powerActive", "name":"Active Power", "unit":"W", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0018, "type":"input", "attr": "powerReactive", "name":"Reactive Power", "unit":"W", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0058, "type":"input", "attr": "powerDemandPositive", "name":"PositivePowerDemand", "unit":"W", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x005c, "type":"input", "attr": "powerDemandReverse", "name":"ReversePowerDemand", "unit":"W", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x001e, "type":"input", "attr": "factor", "name":"Factor", "unit":"-", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0024, "type":"input", "attr": "angle", "name":"Angle", "unit":"degree", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0000, "type":"input", "attr": "voltage", "name":"Voltage", "unit":"V", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":2, "addr":0x0006, "type":"input", "attr": "current", "name":"Current", "unit":"A", "adaptor": floatAdaptor },
|
|
||||||
# { "slave":1, "addr":0x0001, "type":"holding", "attr": "state", "name":"State", "unit":"-", "adaptor": onOffAdaptor },
|
|
||||||
# ]
|
|
||||||
|
|
||||||
|
|
||||||
input:
|
input:
|
||||||
- name: pv_control
|
- name: pv_control
|
||||||
@@ -140,10 +123,11 @@ output:
|
|||||||
- name: pv_control
|
- name: pv_control
|
||||||
publish_topic: IoT/PV/Control/State
|
publish_topic: IoT/PV/Control/State
|
||||||
scan_rate: 1
|
scan_rate: 1
|
||||||
|
raw_output: true # use only for output device with only one register, name this register 'output'
|
||||||
slave_id: 1
|
slave_id: 1
|
||||||
registers:
|
registers:
|
||||||
- address: 0x0001
|
- address: 0x0001
|
||||||
attribute: state
|
attribute: output
|
||||||
name: State
|
name: State
|
||||||
unit: "-"
|
unit: "-"
|
||||||
register_type: holding
|
register_type: holding
|
||||||
@@ -153,10 +137,11 @@ output:
|
|||||||
enabled: true
|
enabled: true
|
||||||
publish_topic: IoT/Car/Control/State
|
publish_topic: IoT/Car/Control/State
|
||||||
scan_rate: 1
|
scan_rate: 1
|
||||||
|
raw_output: true # use only for output device with only one register, name this register 'output'
|
||||||
slave_id: 5
|
slave_id: 5
|
||||||
registers:
|
registers:
|
||||||
- address: 0x0001
|
- address: 0x0001
|
||||||
attribute: state
|
attribute: output
|
||||||
name: State
|
name: State
|
||||||
unit: "-"
|
unit: "-"
|
||||||
register_type: holding
|
register_type: holding
|
||||||
@@ -245,3 +230,17 @@ output:
|
|||||||
register_type: input
|
register_type: input
|
||||||
data_type: float32
|
data_type: float32
|
||||||
adaptor: floatAdaptor
|
adaptor: floatAdaptor
|
||||||
|
- name: car_feedback
|
||||||
|
enabled: true
|
||||||
|
publish_topic: IoT/Car/Feedback/State
|
||||||
|
scan_rate: 1
|
||||||
|
raw_output: true # use only for output device with only one register, name this register 'output'
|
||||||
|
slave_id: 7
|
||||||
|
registers:
|
||||||
|
- address: 0x0010
|
||||||
|
attribute: output
|
||||||
|
name: State
|
||||||
|
unit: "-"
|
||||||
|
register_type: holding
|
||||||
|
data_type: int32
|
||||||
|
adaptor: onOffAdaptor
|
||||||
|
|||||||
@@ -2,9 +2,11 @@ apiVersion: apps/v1
|
|||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
name: pv-controller
|
name: pv-controller
|
||||||
namespace: homea
|
|
||||||
labels:
|
labels:
|
||||||
app: pv-controller
|
app: pv-controller
|
||||||
|
annotations:
|
||||||
|
reloader.stakater.com/auto: "true"
|
||||||
|
reloader.stakater.com/configmap: "pv-controller-config"
|
||||||
spec:
|
spec:
|
||||||
replicas: 1
|
replicas: 1
|
||||||
selector:
|
selector:
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ def floatAdaptor(i):
|
|||||||
return float(f"{i:0.2f}") if i else 0.0
|
return float(f"{i:0.2f}") if i else 0.0
|
||||||
|
|
||||||
def onOffAdaptor(i):
|
def onOffAdaptor(i):
|
||||||
return bool(i)
|
return 'on' if bool(i) else 'off'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -49,12 +49,13 @@ class FromDevices(AbstractMqttPublisher):
|
|||||||
payload[registers.attribute] = value
|
payload[registers.attribute] = value
|
||||||
|
|
||||||
payload['status'] = "Ok"
|
payload['status'] = "Ok"
|
||||||
|
payload['cnt'] = cnt
|
||||||
|
|
||||||
|
payloadStr = json.dumps(payload) if not device.raw_output else str(payload['output'])
|
||||||
|
self.publish_with_cache(device.publish_topic, payloadStr)
|
||||||
|
logger.debug(f"mqtt message sent: {device.publish_topic} -> {payloadStr}")
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.error(f"Caught exception: {str(e)}")
|
logger.error(f"Caught exception: {str(e)}")
|
||||||
|
|
||||||
payload['cnt'] = cnt
|
|
||||||
payloadStr = json.dumps(payload)
|
|
||||||
self.client.publish(device.publish_topic, payloadStr)
|
|
||||||
logger.debug(f"mqtt message sent: {device.publish_topic} -> {payloadStr}")
|
|
||||||
|
|
||||||
self.killEvent.wait(timeout=float(self.config.global_.scan_interval))
|
self.killEvent.wait(timeout=float(self.config.global_.scan_interval))
|
||||||
|
|||||||
@@ -25,6 +25,8 @@ class AbstractMqttPublisher(threading.Thread):
|
|||||||
logger.info(f"mqtt client id: {client_id}")
|
logger.info(f"mqtt client id: {client_id}")
|
||||||
self.client = mqtt.Client(client_id=client_id, userdata=self)
|
self.client = mqtt.Client(client_id=client_id, userdata=self)
|
||||||
|
|
||||||
|
self.cache = {}
|
||||||
|
|
||||||
# consider this flag in the localLoop
|
# consider this flag in the localLoop
|
||||||
self.killBill = False
|
self.killBill = False
|
||||||
self.killEvent = threading.Event()
|
self.killEvent = threading.Event()
|
||||||
@@ -62,3 +64,10 @@ class AbstractMqttPublisher(threading.Thread):
|
|||||||
def onMessage(self, topic, payload):
|
def onMessage(self, topic, payload):
|
||||||
logger.warning("mqtt unexpected message received: {} -> {}".format(topic, str(payload)))
|
logger.warning("mqtt unexpected message received: {} -> {}".format(topic, str(payload)))
|
||||||
|
|
||||||
|
def publish_with_cache(self, topic, payload):
|
||||||
|
if topic in self.cache and self.cache[topic] == payload:
|
||||||
|
logger.debug(f"mqtt message unchanged, not publishing: {topic} -> {payload}")
|
||||||
|
return
|
||||||
|
self.cache[topic] = payload
|
||||||
|
self.client.publish(topic, payload)
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ class ToDevices(AbstractMqttPublisher):
|
|||||||
continue
|
continue
|
||||||
if device.register_type != 'coil':
|
if device.register_type != 'coil':
|
||||||
raise Exception(f"Unsupported register type {device.register_type} for input device {device.name}")
|
raise Exception(f"Unsupported register type {device.register_type} for input device {device.name}")
|
||||||
value = payload == b'On'
|
value = payload == b'on'
|
||||||
self.modbusHandler.writeCoil(device.slave_id, device.address, value)
|
self.modbusHandler.writeCoil(device.slave_id, device.address, value)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.error(f"Caught exception in onMessage: {str(e)}")
|
logger.error(f"Caught exception in onMessage: {str(e)}")
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ class OutputConfig(BaseModel):
|
|||||||
enabled: bool = Field(default=True)
|
enabled: bool = Field(default=True)
|
||||||
scan_rate: Optional[int] = Field(default=60)
|
scan_rate: Optional[int] = Field(default=60)
|
||||||
publish_topic: str
|
publish_topic: str
|
||||||
|
raw_output: Optional[bool] = Field(default=False)
|
||||||
slave_id: int
|
slave_id: int
|
||||||
registers: List[RegisterConfig]
|
registers: List[RegisterConfig]
|
||||||
|
|
||||||
@@ -50,7 +51,7 @@ class ModbusConfig(BaseModel):
|
|||||||
|
|
||||||
class GlobalConfig(BaseModel):
|
class GlobalConfig(BaseModel):
|
||||||
"""Global settings"""
|
"""Global settings"""
|
||||||
scan_interval: int
|
scan_interval: float
|
||||||
log_level: str
|
log_level: str
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user