mirror of
https://github.com/YunoHost-Apps/homeassistant_ynh.git
synced 2024-09-03 19:26:16 +02:00
Merge pull request #304 from YunoHost-Apps/master-promotion
Upgrade master from testing
This commit is contained in:
commit
2935e055ce
8 changed files with 49 additions and 163 deletions
8
.github/workflows/package_linter.yml
vendored
8
.github/workflows/package_linter.yml
vendored
|
@ -5,19 +5,19 @@ on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- master-promotion
|
||||||
pull_request:
|
pull_request:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 8 * * *'
|
- cron: '0 8 * * *'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
packageLinter:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Set up Python
|
- name: Set up Python
|
||||||
uses: actions/setup-python@v4
|
uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
python-version: '3.9'
|
python-version: '3.9'
|
||||||
|
|
||||||
|
|
4
.github/workflows/update_master.yml
vendored
4
.github/workflows/update_master.yml
vendored
|
@ -10,7 +10,7 @@ jobs:
|
||||||
masterPromotion:
|
masterPromotion:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
ref: master
|
ref: master
|
||||||
- name: Reset promotion branch
|
- name: Reset promotion branch
|
||||||
|
@ -18,7 +18,7 @@ jobs:
|
||||||
git fetch origin testing:testing
|
git fetch origin testing:testing
|
||||||
git reset --hard testing
|
git reset --hard testing
|
||||||
- name: Create Pull Request
|
- name: Create Pull Request
|
||||||
uses: peter-evans/create-pull-request@v5
|
uses: peter-evans/create-pull-request@v6
|
||||||
with:
|
with:
|
||||||
branch: master-promotion
|
branch: master-promotion
|
||||||
title: 'Upgrade master from testing'
|
title: 'Upgrade master from testing'
|
||||||
|
|
78
.github/workflows/updater.sh
vendored
78
.github/workflows/updater.sh
vendored
|
@ -1,78 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# PACKAGE UPDATING HELPER
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# This script is meant to be run by GitHub Actions
|
|
||||||
# The YunoHost-Apps organisation offers a template Action to run this script periodically
|
|
||||||
# Since each app is different, maintainers can adapt its contents so as to perform
|
|
||||||
# automatic actions when a new upstream release is detected.
|
|
||||||
|
|
||||||
# Remove this exit command when you are ready to run this Action
|
|
||||||
#exit 1
|
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# FETCHING LATEST RELEASE AND ITS ASSETS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# Fetching information
|
|
||||||
app=$(cat manifest.toml | tomlq -j '.id')
|
|
||||||
current_version=$(cat manifest.toml | tomlq -j '.version|split("~")[0]')
|
|
||||||
upstream_version=$(curl -Ls https://pypi.org/pypi/$app/json | jq -r .info.version)
|
|
||||||
|
|
||||||
# Setting up the environment variables
|
|
||||||
echo "Current version: $current_version"
|
|
||||||
echo "Latest release from upstream: $upstream_version"
|
|
||||||
echo "VERSION=$upstream_version" >> $GITHUB_ENV
|
|
||||||
# For the time being, let's assume the script will fail
|
|
||||||
echo "PROCEED=false" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
# Proceed only if the retrieved version is greater than the current one
|
|
||||||
if ! dpkg --compare-versions "$current_version" "lt" "$upstream_version"
|
|
||||||
then
|
|
||||||
echo "::warning :: No new version available"
|
|
||||||
exit 0
|
|
||||||
# Proceed only if a PR for this new version does not already exist
|
|
||||||
elif git ls-remote -q --exit-code --heads https://github.com/$GITHUB_REPOSITORY.git ci-auto-update-v$upstream_version
|
|
||||||
then
|
|
||||||
echo "::warning ::A branch already exists for this update"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# SPECIFIC UPDATE STEPS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# Replace new version in _common.sh
|
|
||||||
sed -i "s/^app_version=.*/app_version=$upstream_version/" scripts/_common.sh
|
|
||||||
|
|
||||||
# Replace python required version
|
|
||||||
py_required_major=$(curl -Ls https://pypi.org/pypi/$app/json | jq -r .info.requires_python | cut -d '=' -f 2 | rev | cut -d"." -f2- | rev)
|
|
||||||
py_required_minor=$(curl -s "https://www.python.org/ftp/python/" | grep ">$py_required_major" | cut -d '/' -f 2 | cut -d '>' -f 2 | sort -rV | head -n 1)
|
|
||||||
current_py_required_minor=$(cat scripts/_common.sh | grep "py_required_version=" | cut -d '=' -f 2)
|
|
||||||
if ! dpkg --compare-versions "$current_py_required_minor" "lt" "$py_required_minor"
|
|
||||||
then
|
|
||||||
echo "::warning :: No need to update required python version"
|
|
||||||
else
|
|
||||||
echo "::warning :: Updating required python version to new upstream python version"
|
|
||||||
sed -i "s/^py_required_version=.*/py_required_version=$py_required_minor/" scripts/_common.sh
|
|
||||||
fi
|
|
||||||
# Replace pip required version
|
|
||||||
pip_required=$(curl -Ls https://pypi.org/pypi/$app/json | jq -r .info.requires_dist[] | grep "pip") #"pip (<23.1,>=21.0)"
|
|
||||||
sed -i "s/^pip_required=.*/pip_required=\"$pip_required\"/" scripts/_common.sh
|
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# GENERIC FINALIZATION
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# Replace new version in manifest
|
|
||||||
sed -i "s/^version = .*/version = \"$upstream_version~ynh1\"/" manifest.toml
|
|
||||||
#DOES NOT WORK BECAUSE IT REORDER ALL THE MANIFEST IN A STRANGE WAY
|
|
||||||
#echo "$(tomlq --toml-output --slurp --indent 4 ".[] | .version = \"$version~ynh1\"" manifest.toml)" > manifest.toml
|
|
||||||
|
|
||||||
# No need to update the README, yunohost-bot takes care of it
|
|
||||||
|
|
||||||
# The Action will proceed only if the PROCEED environment variable is set to true
|
|
||||||
echo "PROCEED=true" >> $GITHUB_ENV
|
|
||||||
exit 0
|
|
55
.github/workflows/updater.yml
vendored
55
.github/workflows/updater.yml
vendored
|
@ -1,55 +0,0 @@
|
||||||
# This workflow allows GitHub Actions to automagically update your app whenever a new upstream release is detected.
|
|
||||||
# You need to enable Actions in your repository settings, and fetch this Action from the YunoHost-Apps organization.
|
|
||||||
# This file should be enough by itself, but feel free to tune it to your needs.
|
|
||||||
# It calls updater.sh, which is where you should put the app-specific update steps.
|
|
||||||
name: Check for new upstream releases
|
|
||||||
on:
|
|
||||||
# Allow to manually trigger the workflow
|
|
||||||
workflow_dispatch:
|
|
||||||
# Run it every day at 6:00 UTC
|
|
||||||
schedule:
|
|
||||||
- cron: '0 6 */7 * *'
|
|
||||||
jobs:
|
|
||||||
updater:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Fetch the source code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
- name: Install python
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
- name: Install yq/tomlq
|
|
||||||
id: install_yq
|
|
||||||
run: pip install yq
|
|
||||||
- name: Run the updater script
|
|
||||||
id: run_updater
|
|
||||||
run: |
|
|
||||||
# Setting up Git user
|
|
||||||
git config --global user.name 'yunohost-bot'
|
|
||||||
git config --global user.email 'yunohost-bot@users.noreply.github.com'
|
|
||||||
# Run the updater script
|
|
||||||
/bin/bash .github/workflows/updater.sh
|
|
||||||
- name: Commit changes
|
|
||||||
id: commit
|
|
||||||
if: ${{ env.PROCEED == 'true' }}
|
|
||||||
run: |
|
|
||||||
git commit -am "Upgrade to v$VERSION"
|
|
||||||
- name: Create Pull Request
|
|
||||||
id: cpr
|
|
||||||
if: ${{ env.PROCEED == 'true' }}
|
|
||||||
uses: peter-evans/create-pull-request@v4
|
|
||||||
with:
|
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
commit-message: Update to version ${{ env.VERSION }}
|
|
||||||
committer: 'yunohost-bot <yunohost-bot@users.noreply.github.com>'
|
|
||||||
author: 'yunohost-bot <yunohost-bot@users.noreply.github.com>'
|
|
||||||
signoff: false
|
|
||||||
base: testing
|
|
||||||
branch: ci-auto-update-v${{ env.VERSION }}
|
|
||||||
delete-branch: true
|
|
||||||
title: 'Upgrade to version ${{ env.VERSION }}'
|
|
||||||
body: |
|
|
||||||
Upgrade to v${{ env.VERSION }}
|
|
||||||
[See upstream release page](https://github.com/home-assistant/core/releases/tag/${{ env.VERSION }})
|
|
||||||
draft: false
|
|
15
README.md
15
README.md
|
@ -27,10 +27,9 @@ Home Assistant is an open source home automation that puts local control and pri
|
||||||
- Companion Mobile Apps ;
|
- Companion Mobile Apps ;
|
||||||
- Home Energy Management."
|
- Home Energy Management."
|
||||||
|
|
||||||
|
**Shipped version:** 2024.2.5~ynh2
|
||||||
|
|
||||||
**Shipped version:** 2024.2.5~ynh1
|
**Demo:** <https://demo.home-assistant.io>
|
||||||
|
|
||||||
**Demo:** https://demo.home-assistant.io
|
|
||||||
|
|
||||||
## Screenshots
|
## Screenshots
|
||||||
|
|
||||||
|
@ -38,11 +37,11 @@ Home Assistant is an open source home automation that puts local control and pri
|
||||||
|
|
||||||
## Documentation and resources
|
## Documentation and resources
|
||||||
|
|
||||||
* Official app website: <https://www.home-assistant.io>
|
- Official app website: <https://www.home-assistant.io>
|
||||||
* Official admin documentation: <https://www.home-assistant.io/docs/>
|
- Official admin documentation: <https://www.home-assistant.io/docs/>
|
||||||
* Upstream app code repository: <https://github.com/home-assistant/core>
|
- Upstream app code repository: <https://github.com/home-assistant/core>
|
||||||
* YunoHost Store: <https://apps.yunohost.org/app/homeassistant>
|
- YunoHost Store: <https://apps.yunohost.org/app/homeassistant>
|
||||||
* Report a bug: <https://github.com/YunoHost-Apps/homeassistant_ynh/issues>
|
- Report a bug: <https://github.com/YunoHost-Apps/homeassistant_ynh/issues>
|
||||||
|
|
||||||
## Developer info
|
## Developer info
|
||||||
|
|
||||||
|
|
15
README_fr.md
15
README_fr.md
|
@ -26,10 +26,9 @@ Home Assistant zst une application domotique open source qui donne la priorité
|
||||||
- Toutes les données de votre maison intelligente restent locales ;
|
- Toutes les données de votre maison intelligente restent locales ;
|
||||||
- Applications mobiles compagnons ;
|
- Applications mobiles compagnons ;
|
||||||
- Gestion de l'énergie domestique.
|
- Gestion de l'énergie domestique.
|
||||||
|
**Version incluse :** 2024.2.5~ynh2
|
||||||
|
|
||||||
**Version incluse :** 2024.2.5~ynh1
|
**Démo :** <https://demo.home-assistant.io>
|
||||||
|
|
||||||
**Démo :** https://demo.home-assistant.io
|
|
||||||
|
|
||||||
## Captures d’écran
|
## Captures d’écran
|
||||||
|
|
||||||
|
@ -37,11 +36,11 @@ Home Assistant zst une application domotique open source qui donne la priorité
|
||||||
|
|
||||||
## Documentations et ressources
|
## Documentations et ressources
|
||||||
|
|
||||||
* Site officiel de l’app : <https://www.home-assistant.io>
|
- Site officiel de l’app : <https://www.home-assistant.io>
|
||||||
* Documentation officielle de l’admin : <https://www.home-assistant.io/docs/>
|
- Documentation officielle de l’admin : <https://www.home-assistant.io/docs/>
|
||||||
* Dépôt de code officiel de l’app : <https://github.com/home-assistant/core>
|
- Dépôt de code officiel de l’app : <https://github.com/home-assistant/core>
|
||||||
* YunoHost Store: <https://apps.yunohost.org/app/homeassistant>
|
- YunoHost Store : <https://apps.yunohost.org/app/homeassistant>
|
||||||
* Signaler un bug : <https://github.com/YunoHost-Apps/homeassistant_ynh/issues>
|
- Signaler un bug : <https://github.com/YunoHost-Apps/homeassistant_ynh/issues>
|
||||||
|
|
||||||
## Informations pour les développeurs
|
## Informations pour les développeurs
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ name = "Home Assistant"
|
||||||
description.en = "Home automation platform"
|
description.en = "Home automation platform"
|
||||||
description.fr = "Plateforme domotique"
|
description.fr = "Plateforme domotique"
|
||||||
|
|
||||||
version = "2024.2.5~ynh1"
|
version = "2024.2.5~ynh2"
|
||||||
|
|
||||||
maintainers = ["ewilly"]
|
maintainers = ["ewilly"]
|
||||||
|
|
||||||
|
@ -77,6 +77,14 @@ ram.runtime = "2G"
|
||||||
default = "America/Los_Angeles"
|
default = "America/Los_Angeles"
|
||||||
|
|
||||||
[resources]
|
[resources]
|
||||||
|
[resources.sources]
|
||||||
|
|
||||||
|
[resources.sources.main]
|
||||||
|
url = "https://github.com/home-assistant/core/archive/refs/tags/2024.2.5.tar.gz"
|
||||||
|
sha256 = "cb65a0c60621688eab43b646e545d2a991cd9eacc65e02d3a39d0ddbd5a645d4"
|
||||||
|
|
||||||
|
autoupdate.strategy = "latest_github_release"
|
||||||
|
|
||||||
[resources.system_user]
|
[resources.system_user]
|
||||||
|
|
||||||
[resources.install_dir]
|
[resources.install_dir]
|
||||||
|
|
|
@ -4,12 +4,22 @@
|
||||||
# COMMON VARIABLES
|
# COMMON VARIABLES
|
||||||
#=================================================
|
#=================================================
|
||||||
|
|
||||||
# Release to install
|
# App version
|
||||||
app_version=2024.2.5
|
## yq is not a dependencie of yunohost package so tomlq command is not available
|
||||||
|
## (see https://github.com/YunoHost/yunohost/blob/dev/debian/control)
|
||||||
|
app_version=$(cat ../manifest.toml 2>/dev/null \
|
||||||
|
| grep 'version = ' | cut -d '=' -f 2 \
|
||||||
|
| cut -d '~' -f 1 | tr -d ' "') #2024.2.5
|
||||||
|
|
||||||
# Requirements
|
# Python required version
|
||||||
py_required_version=3.11.8
|
## jq is a dependencie of yunohost package
|
||||||
pip_required="pip (>=21.3.1)"
|
## (see https://github.com/YunoHost/yunohost/blob/dev/debian/control)
|
||||||
|
py_required_major=$(curl -Ls https://pypi.org/pypi/$app/$app_version/json \
|
||||||
|
| jq -r '.info.requires_python' | cut -d '=' -f 2 \
|
||||||
|
| rev | cut -d '.' -f2- | rev) #3.11
|
||||||
|
py_required_version=$(curl -Ls https://www.python.org/ftp/python/ \
|
||||||
|
| grep '>'$py_required_major | cut -d '/' -f 2 \
|
||||||
|
| cut -d '>' -f 2 | sort -rV | head -n 1) #3.11.8
|
||||||
|
|
||||||
# Fail2ban
|
# Fail2ban
|
||||||
failregex="^%(__prefix_line)s.*\[homeassistant.components.http.ban\] Login attempt or request with invalid authentication from.* \(<HOST>\).* Requested URL: ./auth/.*"
|
failregex="^%(__prefix_line)s.*\[homeassistant.components.http.ban\] Login attempt or request with invalid authentication from.* \(<HOST>\).* Requested URL: ./auth/.*"
|
||||||
|
@ -113,6 +123,9 @@ myynh_install_python () {
|
||||||
|
|
||||||
# Install/Upgrade Homeassistant in virtual environement
|
# Install/Upgrade Homeassistant in virtual environement
|
||||||
myynh_install_homeassistant () {
|
myynh_install_homeassistant () {
|
||||||
|
# Requirements
|
||||||
|
pip_required=$(curl -Ls https://pypi.org/pypi/$app/$app_version/json | jq -r '.info.requires_dist[]' | grep 'pip') #pip (<23.1,>=21.0)
|
||||||
|
|
||||||
# Create the virtual environment
|
# Create the virtual environment
|
||||||
ynh_exec_as $app $py_app_version -m venv --without-pip "$install_dir"
|
ynh_exec_as $app $py_app_version -m venv --without-pip "$install_dir"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue