8 Commits

Author SHA1 Message Date
5e0127b571 add car feedback 2
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-06 14:17:25 +01:00
311d4cf555 add car feedback
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-06 14:15:03 +01:00
ad043b5921 add raw output 3
Some checks failed
ci/woodpecker/tag/woodpecker Pipeline failed
2025-12-05 15:00:22 +01:00
7c90962de1 add raw output 2
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-05 14:58:46 +01:00
3a4cd499a5 add raw output
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-05 14:44:24 +01:00
6e50654d00 lower case
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-05 13:45:00 +01:00
e820aa2000 fix in ci 2025-12-05 13:36:19 +01:00
8e60802a7a fix configuration
All checks were successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2025-12-05 13:33:55 +01:00
5 changed files with 31 additions and 27 deletions

View File

@@ -23,7 +23,6 @@ steps:
exclude: exclude:
- refs/tags/*-configchange - 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
environment: environment:
@@ -34,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

View File

@@ -3,29 +3,12 @@ global:
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

View File

@@ -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.client.publish(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))

View File

@@ -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)}")

View File

@@ -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]