image: repository: tccr.io/truecharts/zigbee2mqtt tag: 1.29.1@sha256:4be6bf787a2d82406a303a830777c3acade12c0d184be9b1b43fb42857032dfa pullPolicy: IfNotPresent secretEnv: ZIGBEE2MQTT_CONFIG_MQTT_USER: "" ZIGBEE2MQTT_CONFIG_MQTT_PASSWORD: "" env: ZIGBEE2MQTT_DATA: "/data" ZIGBEE2MQTT_CONFIG_FRONTEND_PORT: "{{ .Values.service.main.ports.main.port }}" # User defined USE_CUSTOM_CONFIG_FILE: false # This values are required for the autogenerated file to work. # ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API: true # ZIGBEE2MQTT_CONFIG_PERMIT_JOIN: true # ZIGBEE2MQTT_CONFIG_MQTT_SERVER: "mqtt://localhost" # ZIGBEE2MQTT_CONFIG_MQTT_BASE_TOPIC: "zigbee2mqtt" # ZIGBEE2MQTT_CONFIG_SERIAL_PORT: "/dev/ttyUSB0" # ZIGBEE2MQTT_CONFIG_SERIAL_ADAPTER: "auto" securityContext: runAsNonRoot: false readOnlyRootFilesystem: false podSecurityContext: runAsUser: 0 runAsGroup: 0 service: main: ports: main: port: 10103 persistence: data: enabled: true mountPath: "/data" initContainers: init-config: image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}" volumeMounts: - name: data mountPath: "/data" env: - name: ZIGBEE2MQTT_CONFIG_FRONTEND_PORT value: "{{ .Values.service.main.ports.main.port }}" - name: ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API }}" - name: ZIGBEE2MQTT_CONFIG_PERMIT_JOIN value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_PERMIT_JOIN }}" - name: ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API }}" - name: ZIGBEE2MQTT_CONFIG_MQTT_SERVER value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_MQTT_SERVER }}" - name: ZIGBEE2MQTT_CONFIG_MQTT_USER value: "{{ .Values.secret.ZIGBEE2MQTT_CONFIG_MQTT_USER }}" - name: ZIGBEE2MQTT_CONFIG_MQTT_PASSWORD value: "{{ .Values.secret.ZIGBEE2MQTT_CONFIG_MQTT_PASSWORD }}" - name: ZIGBEE2MQTT_CONFIG_MQTT_BASE_TOPIC value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_MQTT_BASE_TOPIC }}" - name: ZIGBEE2MQTT_CONFIG_SERIAL_PORT value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_SERIAL_PORT }}" - name: ZIGBEE2MQTT_CONFIG_SERIAL_ADAPTER value: "{{ .Values.env.ZIGBEE2MQTT_CONFIG_SERIAL_ADAPTER }}" - name: USE_CUSTOM_CONFIG_FILE value: "{{ .Values.env.USE_CUSTOM_CONFIG_FILE }}" command: ["/bin/sh", "-c"] args: - > if [ -f /data/configuration.yaml ] || [ ${USE_CUSTOM_CONFIG_FILE} == true ]; then echo "Initial configuration exists or User selected to use custom configuration file. Skipping..."; else echo "Creating initial configuration"; touch /data/configuration.yaml; echo "# Configuration bellow will be always be overridden" >> /data/configuration.yaml; echo "# from environment settings on the Scale Apps UI." >> /data/configuration.yaml; echo "# You however will not see this values change in the file." >> /data/configuration.yaml; echo "# It's a generated file based on the values provided on initial install." >> /data/configuration.yaml; echo "##########################################################" >> /data/configuration.yaml; echo "experimental:" >> /data/configuration.yaml; echo " new_api: $ZIGBEE2MQTT_CONFIG_EXPIRIMENTAL_NEW_API" >> /data/configuration.yaml; echo "frontend:" >> /data/configuration.yaml; echo " port: $ZIGBEE2MQTT_CONFIG_FRONTEND_PORT" >> /data/configuration.yaml; echo "permit_join: $ZIGBEE2MQTT_CONFIG_PERMIT_JOIN" >> /data/configuration.yaml; echo "mqtt:" >> /data/configuration.yaml; echo " server: $ZIGBEE2MQTT_CONFIG_MQTT_SERVER" >> /data/configuration.yaml; echo " base_topic: $ZIGBEE2MQTT_CONFIG_MQTT_BASE_TOPIC" >> /data/configuration.yaml; if [ ! -z "$ZIGBEE2MQTT_CONFIG_MQTT_USER" ]; then echo " user: $ZIGBEE2MQTT_CONFIG_MQTT_USER" >> /data/configuration.yaml; fi; if [ ! -z "$ZIGBEE2MQTT_CONFIG_MQTT_PASSWORD" ]; then echo " password: $ZIGBEE2MQTT_CONFIG_MQTT_PASSWORD" >> /data/configuration.yaml; fi; echo "serial:" >> /data/configuration.yaml; echo " port: $ZIGBEE2MQTT_CONFIG_SERIAL_PORT" >> /data/configuration.yaml; echo " adapter: $ZIGBEE2MQTT_CONFIG_SERIAL_ADAPTER" >> /data/configuration.yaml; echo "##########################################################" >> /data/configuration.yaml; echo 'Initial configuration file created at "/data/configuration.yaml"'; fi; portal: enabled: true