Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
4ea8a3688b
|
|||
0eace0be7c
|
|||
88c442697f
|
|||
c2053acee3
|
|||
827ebdadad
|
|||
3d28188833
|
|||
52d690c382
|
|||
44d5118411
|
13
Dockerfile
13
Dockerfile
@ -2,11 +2,17 @@ FROM python:latest
|
||||
|
||||
LABEL Maintainer="Wolfgang Hottgenroth wolfgang.hottgenroth@icloud.com"
|
||||
LABEL ImageName="registry.hottis.de/dockerized/pv-controller"
|
||||
LABEL HubImageName="wollud1969/pv-controller"
|
||||
|
||||
ARG APP_DIR="/opt/app"
|
||||
ARG CONF_DIR="${APP_DIR}/config"
|
||||
|
||||
|
||||
ENV MQTT__BROKER ""
|
||||
ENV MQTT__PORT "1883"
|
||||
ENV MQTT__METERPUBLISHTOPIC "IoT/PV/Values"
|
||||
ENV MQTT__METERPUBLISHPERIOD "15"
|
||||
ENV MQTT__RELAISSUBSCRIBETOPIC "IoT/PV/Cmd"
|
||||
ENV MODBUS__GATEWAY ""
|
||||
|
||||
RUN \
|
||||
apt update && \
|
||||
@ -16,18 +22,15 @@ RUN \
|
||||
|
||||
RUN \
|
||||
mkdir -p ${APP_DIR} && \
|
||||
mkdir -p ${CONF_DIR} && \
|
||||
useradd -d ${APP_DIR} -u 1000 user
|
||||
|
||||
COPY ./src/pv_controller/*.py ${APP_DIR}/
|
||||
COPY config.ini ${CONF_DIR}/
|
||||
|
||||
USER 1000:1000
|
||||
WORKDIR ${APP_DIR}
|
||||
VOLUME ${CONF_DIR}
|
||||
|
||||
|
||||
CMD [ "python", "pvc.py", "-f", "/opt/app/config/config.ini" ]
|
||||
CMD [ "python", "pvc.py" ]
|
||||
|
||||
|
||||
|
||||
|
14
config.ini
14
config.ini
@ -1,14 +0,0 @@
|
||||
[mqtt]
|
||||
broker = 172.16.2.16
|
||||
port = 1883
|
||||
# login =
|
||||
# password =
|
||||
# ca =
|
||||
# cert =
|
||||
# key =
|
||||
relaisSubscribeTopic = IoT/PV/Cmd
|
||||
meterPublishTopic = IoT/PV/Values
|
||||
meterPublishPeriod = 15
|
||||
|
||||
[modbus]
|
||||
gateway = 172.16.2.42
|
@ -1,5 +1,5 @@
|
||||
apiVersion: v1
|
||||
kind: namespace
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: pv-controller
|
||||
---
|
||||
@ -35,7 +35,7 @@ spec:
|
||||
spec:
|
||||
containers:
|
||||
- name: pv-controller
|
||||
image: wollud1969/sinkserver:e5f9d3e3
|
||||
image: wollud1969/pv-controller:1.0.7
|
||||
envFrom:
|
||||
- configMapRef:
|
||||
name: pv-controller
|
||||
|
@ -37,7 +37,7 @@ class ModbusHandler:
|
||||
def readInputRegister(self, slave, addr):
|
||||
res = self.client.read_input_registers(addr, 2, slave=slave)
|
||||
if (isinstance(res, ReadInputRegistersResponse)):
|
||||
v = BinaryPayloadDecoder.fromRegisters(res.registers, byteorder=Endian.Big, wordorder=Endian.Big).decode_32bit_float()
|
||||
v = BinaryPayloadDecoder.fromRegisters(res.registers, byteorder=Endian.BIG, wordorder=Endian.BIG).decode_32bit_float()
|
||||
return v
|
||||
elif (isinstance(res, LocalModbusException)):
|
||||
msg = f"Error: {type(res)}, Content: {res}"
|
||||
|
@ -1,4 +1,5 @@
|
||||
import os
|
||||
from loguru import logger
|
||||
|
||||
class Config:
|
||||
OPTIONS = {
|
||||
@ -17,15 +18,16 @@ class Config:
|
||||
|
||||
def __init__(self):
|
||||
self.values = {}
|
||||
for section, keys in OPTIONS:
|
||||
for section, keys in Config.OPTIONS.items():
|
||||
self.values[section] = {}
|
||||
for key in keys:
|
||||
varname = f"{section}__{key}".upper()
|
||||
try:
|
||||
self.values[section][key] = os.environ[varname]
|
||||
logger.info(f"Config: {section} {key} -> {self.values[section][key]}")
|
||||
except KeyError:
|
||||
pass
|
||||
|
||||
def __getitem__(self, section):
|
||||
return self.values[index]
|
||||
return self.values[section]
|
||||
|
||||
|
Reference in New Issue
Block a user