mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2025-03-01 10:33:28 +00:00
Refactor/Create APT/DNF Repository (#1648)
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
#!/bin/bash -e
|
||||
#!/bin/bash
|
||||
|
||||
DOCKER="docker"
|
||||
# Git repo url of Hyperion
|
||||
@@ -7,20 +7,21 @@ GIT_REPO_URL="https://github.com/hyperion-project/hyperion.ng.git"
|
||||
REGISTRY_URL="ghcr.io/hyperion-project"
|
||||
# cmake build type
|
||||
BUILD_TYPE="Release"
|
||||
# the docker image at GitHub Container Registry
|
||||
BUILD_IMAGE="x86_64"
|
||||
# the docker tag at GitHub Container Registry
|
||||
BUILD_TAG="bullseye"
|
||||
DISTRIBUTION="debian"
|
||||
CODENAME="bullseye"
|
||||
ARCHITECTURE="amd64"
|
||||
# build packages (.deb .zip ...)
|
||||
BUILD_PACKAGES=true
|
||||
# packages string inserted to cmake cmd
|
||||
PACKAGES=""
|
||||
# platform string inserted to cmake cmd
|
||||
BUILD_PLATFORM=""
|
||||
#Run build with Qt6 or Qt5
|
||||
BUILD_WITH_QT5=false
|
||||
#Run build using GitHub code files
|
||||
BUILD_LOCAL=0
|
||||
BUILD_LOCAL=false
|
||||
#Build from scratch
|
||||
BUILD_INCREMENTAL=0
|
||||
BUILD_INCREMENTAL=false
|
||||
#Verbose output
|
||||
_VERBOSE=0
|
||||
#Additional args
|
||||
@@ -37,11 +38,7 @@ cd `dirname ${BASE_PATH}` > /dev/null
|
||||
BASE_PATH=`pwd`;
|
||||
popd > /dev/null
|
||||
|
||||
BASE_PATH=`pwd`;function log () {
|
||||
if [[ $_V -eq 1 ]]; then
|
||||
echo "$@"
|
||||
fi
|
||||
}
|
||||
BASE_PATH=`pwd`;
|
||||
|
||||
set +e
|
||||
${DOCKER} ps >/dev/null 2>&1
|
||||
@@ -62,7 +59,7 @@ function printHelp {
|
||||
echo "########################################################
|
||||
## A script to compile Hyperion inside a docker container
|
||||
## Requires installed Docker: https://www.docker.com/
|
||||
## Without arguments it will compile Hyperion for Debian Bullseye (x86_64) and uses Hyperion code from GitHub repository.
|
||||
## Without arguments it will compile Hyperion for ${DISTRIBUTION}:${CODENAME}, ${ARCHITECTURE} architecture and uses Hyperion code from GitHub repository.
|
||||
## For all images and tags currently available, see https://github.com/orgs/hyperion-project/packages
|
||||
##
|
||||
## Homepage: https://www.hyperion-project.org
|
||||
@@ -71,16 +68,17 @@ echo "########################################################
|
||||
# These are possible arguments to modify the script behaviour with their default values
|
||||
#
|
||||
# docker-compile.sh -h, --help # Show this help message
|
||||
# docker-compile.sh -i, --image # The docker image, e.g., x86_64, armv6l, armv7l, aarch64
|
||||
# docker-compile.sh -t, --tag # The docker tag, e.g., buster, bullseye, bookworm
|
||||
# docker-compile.sh -n, --name # The distribution's codename, e.g., buster, bullseye, bookworm, jammy, trixie, lunar, mantic; Note: for Fedora it is the version number
|
||||
# docker-compile.sh -a, --architecture # The output architecture, e.g., amd64, arm64, arm/v7
|
||||
# docker-compile.sh -b, --type # Release or Debug build
|
||||
# docker-compile.sh -p, --packages # If true, build packages with CPack
|
||||
# docker-compile.sh --qt5 # Build with Qt5, otherwise build with Qt6
|
||||
# docker-compile.sh -f, --platform # cmake PLATFORM parameter, e.g. x11, amlogic-dev
|
||||
# docker-compile.sh -l, --local # Run build using local code files
|
||||
# docker-compile.sh -c, --incremental # Run incremental build, i.e. do not delete files created during previous build
|
||||
# docker-compile.sh -f, --platform # cmake PLATFORM parameter, e.g. x11, amlogic-dev
|
||||
# docker-compile.sh -v, --verbose # Run the script in verbose mode
|
||||
# docker-compile.sh -- args # Additonal cmake arguments, e.g., -DHYPERION_LIGHT=ON
|
||||
# More informations to docker tags at: https://github.com/Hyperion-Project/hyperion.docker-ci"
|
||||
# More informations to docker containers available at: https://github.com/Hyperion-Project/hyperion.docker-ci"
|
||||
}
|
||||
|
||||
function log () {
|
||||
@@ -89,48 +87,63 @@ function log () {
|
||||
fi
|
||||
}
|
||||
|
||||
function check_distribution () {
|
||||
url=${REGISTRY_URL}/$1:${CODENAME}
|
||||
|
||||
log "Check for distribution at: $url"
|
||||
if $($DOCKER buildx imagetools inspect "$url" 2>&1 | grep -q $2) ; then
|
||||
rc=0
|
||||
else
|
||||
rc=1
|
||||
fi
|
||||
return $rc
|
||||
}
|
||||
|
||||
echo "Compile Hyperion using a Docker container"
|
||||
options=$(getopt -l "image:,tag:,type:,packages:,platform:,local,incremental,verbose,help" -o "i:t:b:p:f:lcvh" -a -- "$@")
|
||||
options=$(getopt -l "architecture:,name:,type:,packages:,platform:,qt5,local,incremental,verbose,help" -o "a:n:b:p:f:lcvh" -a -- "$@")
|
||||
|
||||
eval set -- "$options"
|
||||
while true
|
||||
do
|
||||
case $1 in
|
||||
-i|--image)
|
||||
-a|--architecture)
|
||||
shift
|
||||
BUILD_IMAGE=$1
|
||||
ARCHITECTURE=`echo $1 | tr '[:upper:]' '[:lower:]'`
|
||||
;;
|
||||
-t|--tag)
|
||||
-n|--name)
|
||||
shift
|
||||
BUILD_TAG=$1
|
||||
CODENAME=`echo $1 | tr '[:upper:]' '[:lower:]'`
|
||||
;;
|
||||
-b|--type)
|
||||
-b|--type)
|
||||
shift
|
||||
BUILD_TYPE=$1
|
||||
;;
|
||||
-p|--packages)
|
||||
-p|--packages)
|
||||
shift
|
||||
BUILD_PACKAGES=$1
|
||||
;;
|
||||
-f|--platform)
|
||||
-f|--platform)
|
||||
shift
|
||||
BUILD_PLATFORM=$1
|
||||
;;
|
||||
-l|--local)
|
||||
BUILD_LOCAL=1
|
||||
--qt5)
|
||||
BUILD_WITH_QT5=true
|
||||
;;
|
||||
-c|--incremental)
|
||||
BUILD_INCREMENTAL=1
|
||||
-l|--local)
|
||||
BUILD_LOCAL=true
|
||||
;;
|
||||
-v|--verbose)
|
||||
-i|--incremental)
|
||||
BUILD_INCREMENTAL=true
|
||||
;;
|
||||
-v|--verbose)
|
||||
_VERBOSE=1
|
||||
;;
|
||||
-h|--help)
|
||||
-h|--help)
|
||||
printHelp
|
||||
exit 0
|
||||
;;
|
||||
--)
|
||||
shift
|
||||
shift
|
||||
break;;
|
||||
esac
|
||||
shift
|
||||
@@ -148,7 +161,66 @@ if [[ ! -z ${BUILD_PLATFORM} ]]; then
|
||||
PLATFORM="-DPLATFORM=${BUILD_PLATFORM}"
|
||||
fi
|
||||
|
||||
echo "---> Initialize with IMAGE:TAG=${BUILD_IMAGE}:${BUILD_TAG}, BUILD_TYPE=${BUILD_TYPE}, BUILD_PACKAGES=${BUILD_PACKAGES}, PLATFORM=${BUILD_PLATFORM}, BUILD_LOCAL=${BUILD_LOCAL}, BUILD_INCREMENTAL=${BUILD_INCREMENTAL}"
|
||||
PLATFORM_ARCHITECTURE="linux/"${ARCHITECTURE}
|
||||
|
||||
QTVERSION="5"
|
||||
if [ ${BUILD_WITH_QT5} == false ]; then
|
||||
QTVERSION="6"
|
||||
CODENAME="${CODENAME}-qt6"
|
||||
fi
|
||||
|
||||
echo "---> Evaluate distribution for codename:${CODENAME} on platform architecture ${PLATFORM_ARCHITECTURE}"
|
||||
DISTRIBUTION="debian"
|
||||
if ! check_distribution ${DISTRIBUTION} ${PLATFORM_ARCHITECTURE} ; then
|
||||
DISTRIBUTION="ubuntu"
|
||||
if ! check_distribution ${DISTRIBUTION} ${PLATFORM_ARCHITECTURE} ; then
|
||||
DISTRIBUTION="fedora"
|
||||
if ! check_distribution ${DISTRIBUTION} ${PLATFORM_ARCHITECTURE} ; then
|
||||
echo "No docker image found for a distribution with codename: ${CODENAME} to be build on platform architecture ${PLATFORM_ARCHITECTURE}"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
echo "---> Build with -> Distribution: ${DISTRIBUTION}, Codename: ${CODENAME}, Architecture: ${ARCHITECTURE}, Type: ${BUILD_TYPE}, Platform: ${BUILD_PLATFORM}, QT Version: ${QTVERSION}, Build Packages: ${BUILD_PACKAGES}, Build local: ${BUILD_LOCAL}, Build incremental: ${BUILD_INCREMENTAL}"
|
||||
|
||||
# Determine the current architecture
|
||||
CURRENT_ARCHITECTURE=`uname -m`
|
||||
|
||||
#Test if multiarchitecture setup, i.e. user-space is 32bit
|
||||
if [ ${CURRENT_ARCHITECTURE} == "aarch64" ]; then
|
||||
CURRENT_ARCHITECTURE="arm64"
|
||||
USER_ARCHITECTURE=$CURRENT_ARCHITECTURE
|
||||
IS_V7L=`cat /proc/$$/maps |grep -m1 -c v7l`
|
||||
if [ $IS_V7L -ne 0 ]; then
|
||||
USER_ARCHITECTURE="arm/v7"
|
||||
else
|
||||
IS_V6L=`cat /proc/$$/maps |grep -m1 -c v6l`
|
||||
if [ $IS_V6L -ne 0 ]; then
|
||||
USER_ARCHITECTURE="arm/v6"
|
||||
fi
|
||||
fi
|
||||
if [ $ARCHITECTURE != $USER_ARCHITECTURE ]; then
|
||||
log "Identified user space current architecture: $USER_ARCHITECTURE"
|
||||
CURRENT_ARCHITECTURE=$USER_ARCHITECTURE
|
||||
fi
|
||||
else
|
||||
CURRENT_ARCHITECTURE=${CURRENT_ARCHITECTURE//x86_/amd}
|
||||
fi
|
||||
|
||||
log "Identified kernel current architecture: $CURRENT_ARCHITECTURE"
|
||||
if [ $ARCHITECTURE != $CURRENT_ARCHITECTURE ]; then
|
||||
echo "---> Build is not for the same architecturem, enable emulation for ${PLATFORM_ARCHITECTURE}"
|
||||
ENTRYPOINT_OPTION=
|
||||
|
||||
if [ $CURRENT_ARCHITECTURE != "amd64" ]; then
|
||||
echo "---> Emulation builds can only be executed on linux/amd64, linux/x86_64 platforms, current architecture is ${CURRENT_ARCHITECTURE}"
|
||||
exit 1
|
||||
fi
|
||||
else
|
||||
log "Build natively for platform architecture: ${PLATFORM_ARCHITECTURE}"
|
||||
ENTRYPOINT_OPTION="--entrypoint="""
|
||||
fi
|
||||
|
||||
log "---> BASE_PATH = ${BASE_PATH}"
|
||||
CODE_PATH=${BASE_PATH};
|
||||
@@ -163,9 +235,11 @@ git clone --recursive --depth 1 -q ${GIT_REPO_URL} ${CODE_PATH} || { echo "--->
|
||||
fi
|
||||
log "---> CODE_PATH = ${CODE_PATH}"
|
||||
|
||||
BUILD_DIR="build-${BUILD_IMAGE}-${BUILD_TAG}"
|
||||
ARCHITECTURE_PATH=${ARCHITECTURE//\//_}
|
||||
|
||||
BUILD_DIR="build-${CODENAME}-${ARCHITECTURE_PATH}"
|
||||
BUILD_PATH="${CODE_PATH}/${BUILD_DIR}"
|
||||
DEPLOY_DIR="deploy/${BUILD_IMAGE}/${BUILD_TAG}"
|
||||
DEPLOY_DIR="deploy/${CODENAME}/${ARCHITECTURE}"
|
||||
DEPLOY_PATH="${CODE_PATH}/${DEPLOY_DIR}"
|
||||
|
||||
log "---> BUILD_DIR = ${BUILD_DIR}"
|
||||
@@ -178,7 +252,7 @@ sudo rm -fr "${DEPLOY_PATH}" >/dev/null 2>&1
|
||||
mkdir -p "${DEPLOY_PATH}" >/dev/null 2>&1
|
||||
|
||||
#Remove previous build area, if no incremental build
|
||||
if [ ${BUILD_INCREMENTAL} != 1 ]; then
|
||||
if [ ${BUILD_INCREMENTAL} != true ]; then
|
||||
sudo rm -fr "${BUILD_PATH}" >/dev/null 2>&1
|
||||
fi
|
||||
mkdir -p "${BUILD_PATH}" >/dev/null 2>&1
|
||||
@@ -194,10 +268,11 @@ echo "---> Compiling Hyperion from source code at ${CODE_PATH}"
|
||||
# execute inside container all commands on bash
|
||||
|
||||
echo "---> Startup docker..."
|
||||
$DOCKER run --rm \
|
||||
$DOCKER run --rm --platform=${PLATFORM_ARCHITECTURE} \
|
||||
${ENTRYPOINT_OPTION} \
|
||||
-v "${DEPLOY_PATH}:/deploy" \
|
||||
-v "${CODE_PATH}/:/source:rw" \
|
||||
${REGISTRY_URL}/${BUILD_IMAGE}:${BUILD_TAG} \
|
||||
${REGISTRY_URL}/${DISTRIBUTION}:${CODENAME} \
|
||||
/bin/bash -c "mkdir -p /source/${BUILD_DIR} && cd /source/${BUILD_DIR} &&
|
||||
cmake -DCMAKE_BUILD_TYPE=${BUILD_TYPE} ${PLATFORM} ${BUILD_ARGS} .. || exit 2 &&
|
||||
make -j $(nproc) ${PACKAGES} || exit 3 || : &&
|
||||
@@ -210,7 +285,7 @@ DOCKERRC=${?}
|
||||
sudo chown -fR $(stat -c "%U:%G" ${BASE_PATH}) ${BUILD_PATH}
|
||||
|
||||
if [ ${DOCKERRC} == 0 ]; then
|
||||
if [ ${BUILD_LOCAL} == 1 ]; then
|
||||
if [ ${BUILD_LOCAL} == true ]; then
|
||||
echo "---> Find compiled binaries in: ${BUILD_PATH}/bin"
|
||||
fi
|
||||
|
||||
|
@@ -73,13 +73,13 @@ if [ ${ARCHITECTURE} == "aarch64" ]; then
|
||||
IS_V7L=`cat /proc/$$/maps |grep -m1 -c v7l`
|
||||
if [ $IS_V7L -ne 0 ]; then
|
||||
USER_ARCHITECTURE="armv7l"
|
||||
else
|
||||
else
|
||||
IS_V6L=`cat /proc/$$/maps |grep -m1 -c v6l`
|
||||
if [ $IS_V6L -ne 0 ]; then
|
||||
USER_ARCHITECTURE="armv6l"
|
||||
fi
|
||||
fi
|
||||
if [ $ARCHITECTURE != $USER_ARCHITECTURE ]; then
|
||||
if [ $ARCHITECTURE != $USER_ARCHITECTURE ]; then
|
||||
echo "---> Identified kernel target architecture: $ARCHITECTURE"
|
||||
echo "---> Identified user space target architecture: $USER_ARCHITECTURE"
|
||||
ARCHITECTURE=$USER_ARCHITECTURE
|
||||
@@ -134,11 +134,11 @@ if [ -z "$run_id" ]; then
|
||||
# Determine run_id from head_sha
|
||||
runs=$(request_call "$api_url/actions/runs?head_sha=$head_sha")
|
||||
run_id=$(echo "$runs" | tr '\r\n' ' ' | ${pythonCmd} -c """
|
||||
import json,sys
|
||||
import json,sys,os
|
||||
data = json.load(sys.stdin)
|
||||
|
||||
for i in data['workflow_runs']:
|
||||
if i['name'] == 'Hyperion PR Build':
|
||||
if os.path.basename(i['path']) == 'push_pull.yml':
|
||||
print(i['id'])
|
||||
break
|
||||
""" 2>/dev/null)
|
||||
@@ -198,11 +198,11 @@ if [[ ! -z ${CURRENT_SERVICE} ]]; then
|
||||
echo "---> Stop current service: ${CURRENT_SERVICE}"
|
||||
|
||||
STOPCMD="systemctl stop --quiet ${CURRENT_SERVICE} --now"
|
||||
USERNAME=${SUDO_USER:-$(whoami)}
|
||||
USERNAME=${SUDO_USER:-$(whoami)}
|
||||
if [ ${USERNAME} != "root" ]; then
|
||||
STOPCMD="sudo ${STOPCMD}"
|
||||
fi
|
||||
|
||||
|
||||
${STOPCMD} >/dev/null 2>&1
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "---> Critical Error: Failed to stop service: ${CURRENT_SERVICE}, Hyperion may not be started. Stop Hyperion manually."
|
||||
|
@@ -1,5 +1,5 @@
|
||||
[Unit]
|
||||
Description=Hyperion ambient light systemd service for user %i
|
||||
Description=Hyperion ambient light systemd service for user %i
|
||||
Documentation=https://docs.hyperion-project.org
|
||||
Requisite=network.target
|
||||
Wants=network-online.target
|
||||
|
22
bin/service/hyperion.xml
Normal file
22
bin/service/hyperion.xml
Normal file
@@ -0,0 +1,22 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<service>
|
||||
<short>Hyperion</short>
|
||||
<description>Hyperion.NG firewall rules</description>
|
||||
|
||||
<!-- HTTP -->
|
||||
<port protocol="tcp" port="8090"/>
|
||||
<!-- HTTPS -->
|
||||
<port protocol="tcp" port="8892"/>
|
||||
<!-- JSON Server -->
|
||||
<port protocol="tcp" port="19444"/>
|
||||
<!-- Flatbuffers Server -->
|
||||
<port protocol="tcp" port="19400"/>
|
||||
<!-- Protocol Buffers Server -->
|
||||
<port protocol="tcp" port="19445"/>
|
||||
<!-- Boblight Server -->
|
||||
<port protocol="tcp" port="19333"/>
|
||||
|
||||
<include service="ssdp"/>
|
||||
<include service="mdns"/>
|
||||
|
||||
</service>
|
Reference in New Issue
Block a user