Added CT: ESPHome

This commit is contained in:
2022-12-18 16:42:40 +01:00
parent 6d0aafe7ea
commit 57c6e041fb
7 changed files with 66 additions and 1 deletions

View File

@@ -7,7 +7,7 @@ pipeline {
string defaultValue: '192.168.200.11', description: 'Proxy server for packages, when enabled', name: 'ProxyServer' string defaultValue: '192.168.200.11', description: 'Proxy server for packages, when enabled', name: 'ProxyServer'
booleanParam description: 'will disable use of proxy server', name: 'DisProxy' booleanParam description: 'will disable use of proxy server', name: 'DisProxy'
checkboxParameter(name: 'ImgVariantList', format: 'JSON', displayNodePath: "//Variants/Variant", valueNodePath: "//Variants/Variant", description: 'Select the variant(s) that should be build', checkboxParameter(name: 'ImgVariantList', format: 'JSON', displayNodePath: "//Variants/Variant", valueNodePath: "//Variants/Variant", description: 'Select the variant(s) that should be build',
pipelineSubmitContent: '{"Variants": [{"Variant": "minimal"},{"Variant": "default"},{"Variant": "jenkinsbuilder"},{"Variant": "imgbuilder"},{"Variant": "jenkins"},{"Variant": "mysql"},{"Variant": "pihole"},{"Variant": "collabora"},{"Variant": "jellyfin"},{"Variant": "domoticz"},{"Variant": "omadaV3"},{"Variant": "docker"},{"Variant": "smb"},{"Variant": "tvheadend"},{"Variant": "x2go"},{"Variant": "aptcacherng"},{"Variant": "elkarbackupDEB"},{"Variant": "nfs"},{"Variant": "duplicati"},{"Variant": "fileshelter"}]}') pipelineSubmitContent: '{"Variants": [{"Variant": "minimal"},{"Variant": "default"},{"Variant": "jenkinsbuilder"},{"Variant": "imgbuilder"},{"Variant": "jenkins"},{"Variant": "mysql"},{"Variant": "pihole"},{"Variant": "collabora"},{"Variant": "jellyfin"},{"Variant": "domoticz"},{"Variant": "omadaV3"},{"Variant": "docker"},{"Variant": "smb"},{"Variant": "tvheadend"},{"Variant": "x2go"},{"Variant": "aptcacherng"},{"Variant": "elkarbackupDEB"},{"Variant": "nfs"},{"Variant": "duplicati"},{"Variant": "fileshelter"},{"Variant": "esphome"}]}')
} }
options { options {
skipDefaultCheckout() skipDefaultCheckout()

View File

@@ -1005,6 +1005,13 @@ files:
variants: variants:
- fileshelter - fileshelter
#FileForESPHome
- path: /opt/Setup
generator: copy
source: CT-Files/epshome
variants:
- esphome
packages: packages:
manager: apt manager: apt
update: true update: true
@@ -1053,6 +1060,7 @@ packages:
- nfs - nfs
- duplicati - duplicati
- fileshelter - fileshelter
- esphome
#Minimal pkgs #Minimal pkgs
- packages: - packages:
@@ -1346,6 +1354,19 @@ packages:
variants: variants:
- fileshelter - fileshelter
#esphome pkgs
- packages:
- python3
- python3-venv
- python3-pip
- git
- sudo
- g++
- nano
action: install
variants:
- esphome
repositories: repositories:
- name: sources.list - name: sources.list
url: |- url: |-
@@ -1493,6 +1514,7 @@ actions:
- nfs - nfs
- duplicati - duplicati
- fileshelter - fileshelter
- esphome
#Move App update script for ProxmoxHelper/ProxMoxToolKit, if CT has this script #Move App update script for ProxmoxHelper/ProxMoxToolKit, if CT has this script
- trigger: post-files - trigger: post-files

View File

@@ -0,0 +1,13 @@
[Unit]
Description= ESPHome Dashboard
After=network.target
[Service]
User=esphome
ExecStart=/opt/ESPHome/srv/bin/esphome -q dashboard /opt/ESPHome/data/
Restart=on-failure
RestartSec=5s
Environment="PATH=$PATH:/opt/ESPHome/srv/bin"
[Install]
WantedBy=multi-user.target

View File

@@ -0,0 +1,19 @@
#!/bin/bash
#Install ESPHome
mkdir -p /opt/ESPHome/srv
mkdir -p /opt/ESPHome/data
adduser --group --system --no-create-home --home /opt/ESPHome/data --shell /bin/sh esphome
chown -R esphome:esphome /opt/ESPHome
sudo -u esphome python3 -m venv /opt/ESPHome/srv
sudo -u esphome sh -c '. /opt/ESPHome/srv/bin/activate && pip install --upgrade pip && pip3 install tornado esptool esphome'
#Update script
mv /opt/Setup/Scripts/UpdateESPHome.sh /opt/UpdateESPHome.sh
#CleanUp
rm -rf /build/TMP/usr/lib/python3.9/__pycache__/*
#Setup ESPHome service
mv /opt/Setup/Configs/esphome.service /lib/systemd/system/esphome.service
chmod +x /lib/systemd/system/esphome.service
ln -s /lib/systemd/system/esphome.service /etc/systemd/system/multi-user.target.wants/esphome.service

View File

@@ -0,0 +1,3 @@
#!/bin/sh
# Update script for updating apps with ProxmoxHelper/ProxMoxToolKit
bash /opt/UpdateESPHome.sh

View File

@@ -0,0 +1,4 @@
#!/bin/bash
service esphome stop
sudo -u esphome sh -c '. /opt/ESPHome/srv/activate && pip install --upgrade pip && pip3 install --upgrade tornado esptool esphome'
service esphome start

View File

@@ -36,6 +36,7 @@ This can be done on a privileged Debian CT (make sure to enable the Fuse, Nestin
| nfs | Debian | NFS server | | nfs | Debian | NFS server |
| duplicati | Debian | Duplicati backup software | | duplicati | Debian | Duplicati backup software |
| fileshelter | Debian | FileShelter file shareing software | | fileshelter | Debian | FileShelter file shareing software |
| esphome | Debian | ESPHome software to manage wifi-MCUs|
| gitea | Alpine | Gitea server | | gitea | Alpine | Gitea server |
| nginx | Alpine | Nginx server for reverse-proxy use | | nginx | Alpine | Nginx server for reverse-proxy use |
| ddns | Alpine | DDNS client configured for OVH/OVH-Cloud | | ddns | Alpine | DDNS client configured for OVH/OVH-Cloud |
@@ -265,6 +266,9 @@ lxc.mount.entry: /dev/ttyACM-Zwave dev/ttyACM-Zwave none bind,optional,create=fi
## fileshelter ## fileshelter
* Available on http://`<ip>`:5091 * Available on http://`<ip>`:5091
## esphome
* Available on http://`<ip>`:6052
# Further CT documentation # Further CT documentation
## iscsi ## iscsi