some alpine to test
This commit is contained in:
		
							parent
							
								
									3db4479cd0
								
							
						
					
					
						commit
						a9fabb9442
					
				
							
								
								
									
										58
									
								
								ct/alpine-komodo.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								ct/alpine-komodo.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,58 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) | ||||||
|  | # Copyright (c) 2021-2025 community-scripts ORG | ||||||
|  | # Author: MickLesk (CanbiZ) | ||||||
|  | # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE | ||||||
|  | # Source: https://komo.do | ||||||
|  | 
 | ||||||
|  | APP="Alpine-Komodo" | ||||||
|  | var_tags="${var_tags:-docker,alpine}" | ||||||
|  | var_cpu="${var_cpu:-1}" | ||||||
|  | var_ram="${var_ram:-1024}" | ||||||
|  | var_disk="${var_disk:-10}" | ||||||
|  | var_os="${var_os:-alpine}" | ||||||
|  | var_version="${var_version:-3.22}" | ||||||
|  | var_unprivileged="${var_unprivileged:-1}" | ||||||
|  | 
 | ||||||
|  | header_info "$APP" | ||||||
|  | variables | ||||||
|  | color | ||||||
|  | catch_errors | ||||||
|  | 
 | ||||||
|  | function update_script() { | ||||||
|  |   [[ -d /opt/komodo ]] || { | ||||||
|  |     msg_error "No ${APP} Installation Found!" | ||||||
|  |     exit 1 | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   msg_info "Updating ${APP}" | ||||||
|  |   COMPOSE_FILE=$(find /opt/komodo -maxdepth 1 -type f -name '*.compose.yaml' ! -name 'compose.env' | head -n1) | ||||||
|  |   if [[ -z "$COMPOSE_FILE" ]]; then | ||||||
|  |     msg_error "No valid compose file found in /opt/komodo!" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  |   COMPOSE_BASENAME=$(basename "$COMPOSE_FILE") | ||||||
|  |   BACKUP_FILE="/opt/komodo/${COMPOSE_BASENAME}.bak_$(date +%Y%m%d_%H%M%S)" | ||||||
|  |   cp "$COMPOSE_FILE" "$BACKUP_FILE" || { | ||||||
|  |     msg_error "Failed to create backup of ${COMPOSE_BASENAME}!" | ||||||
|  |     exit 1 | ||||||
|  |   } | ||||||
|  |   GITHUB_URL="https://raw.githubusercontent.com/moghtech/komodo/main/compose/${COMPOSE_BASENAME}" | ||||||
|  |   if ! curl -fsSL "$GITHUB_URL" -o "$COMPOSE_FILE"; then | ||||||
|  |     msg_error "Failed to download ${COMPOSE_BASENAME} from GitHub!" | ||||||
|  |     mv "$BACKUP_FILE" "$COMPOSE_FILE" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  |   $STD docker compose -p komodo -f "$COMPOSE_FILE" --env-file /opt/komodo/compose.env up -d | ||||||
|  |   msg_ok "Updated ${APP}" | ||||||
|  |   exit | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | start | ||||||
|  | build_container | ||||||
|  | description | ||||||
|  | 
 | ||||||
|  | msg_ok "Completed Successfully!\n" | ||||||
|  | echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" | ||||||
|  | echo -e "${INFO}${YW} Access it using the following URL:${CL}" | ||||||
|  | echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:9120${CL}" | ||||||
							
								
								
									
										58
									
								
								ct/alpine-tinyauth.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								ct/alpine-tinyauth.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,58 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) | ||||||
|  | # Copyright (c) 2021-2025 community-scripts ORG | ||||||
|  | # Author: Slaviša Arežina (tremor021) | Co-Author: Stavros (steveiliop56) | ||||||
|  | # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE | ||||||
|  | # Source: https://github.com/steveiliop56/tinyauth | ||||||
|  | 
 | ||||||
|  | APP="Alpine-Tinyauth" | ||||||
|  | var_tags="${var_tags:-alpine;auth}" | ||||||
|  | var_cpu="${var_cpu:-1}" | ||||||
|  | var_ram="${var_ram:-256}" | ||||||
|  | var_disk="${var_disk:-2}" | ||||||
|  | var_os="${var_os:-alpine}" | ||||||
|  | var_version="${var_version:-3.22}" | ||||||
|  | var_unprivileged="${var_unprivileged:-1}" | ||||||
|  | 
 | ||||||
|  | header_info "$APP" | ||||||
|  | variables | ||||||
|  | color | ||||||
|  | catch_errors | ||||||
|  | 
 | ||||||
|  | function update_script() { | ||||||
|  |   if [[ ! -d /opt/tinyauth ]]; then | ||||||
|  |     msg_error "No ${APP} Installation Found!" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | 
 | ||||||
|  |   msg_info "Updating packages" | ||||||
|  |   $STD apk -U upgrade | ||||||
|  |   msg_ok "Updated packages" | ||||||
|  | 
 | ||||||
|  |   msg_info "Updating Tinyauth" | ||||||
|  |   RELEASE=$(curl -s https://api.github.com/repos/steveiliop56/tinyauth/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }') | ||||||
|  | 
 | ||||||
|  |   if [ "${RELEASE}" != "$(cat /opt/tinyauth_version.txt)" ] || [ ! -f /opt/tinyauth_version.txt ]; then | ||||||
|  |     $STD service tinyauth stop | ||||||
|  |     rm -f /opt/tinyauth/tinyauth | ||||||
|  |     curl -fsSL "https://github.com/steveiliop56/tinyauth/releases/download/v${RELEASE}/tinyauth-amd64" -o /opt/tinyauth/tinyauth | ||||||
|  |     chmod +x /opt/tinyauth/tinyauth | ||||||
|  |     echo "${RELEASE}" >/opt/tinyauth_version.txt | ||||||
|  |     msg_info "Restarting Tinyauth" | ||||||
|  |     $STD service tinyauth start | ||||||
|  |     msg_ok "Restarted Tinyauth" | ||||||
|  |     msg_ok "Updated Tinyauth" | ||||||
|  |   else | ||||||
|  |     msg_ok "No update required. ${APP} is already at ${RELEASE}" | ||||||
|  |   fi | ||||||
|  |   exit 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | start | ||||||
|  | build_container | ||||||
|  | description | ||||||
|  | 
 | ||||||
|  | msg_ok "Completed Successfully!\n" | ||||||
|  | echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" | ||||||
|  | echo -e "${INFO}${YW} Access it using the following URL:${CL}" | ||||||
|  | echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:3000${CL}" | ||||||
							
								
								
									
										79
									
								
								install/alpine-komodo-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								install/alpine-komodo-install.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,79 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | 
 | ||||||
|  | # Copyright (c) 2021-2025 community-scripts ORG | ||||||
|  | # Author: MickLesk (CanbiZ) | ||||||
|  | # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE | ||||||
|  | # Source: https://komo.do/ | ||||||
|  | 
 | ||||||
|  | source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" | ||||||
|  | color | ||||||
|  | verb_ip6 | ||||||
|  | catch_errors | ||||||
|  | setting_up_container | ||||||
|  | network_check | ||||||
|  | update_os | ||||||
|  | 
 | ||||||
|  | msg_info "Installing Dependencies" | ||||||
|  | $STD apk add --no-cache ca-certificates openssl | ||||||
|  | msg_ok "Installed Dependencies" | ||||||
|  | 
 | ||||||
|  | msg_info "Setup Docker Repository" | ||||||
|  | $STD apk add --no-cache docker docker-cli docker-compose openrc | ||||||
|  | msg_ok "Setup Docker Repository" | ||||||
|  | 
 | ||||||
|  | msg_info "Enabling Docker Service" | ||||||
|  | $STD rc-update add docker boot | ||||||
|  | $STD service docker start | ||||||
|  | msg_ok "Enabled Docker Service" | ||||||
|  | 
 | ||||||
|  | echo "${TAB3}Choose the database for Komodo installation:" | ||||||
|  | echo "${TAB3}1) MongoDB (recommended)" | ||||||
|  | echo "${TAB3}2) SQLite" | ||||||
|  | echo "${TAB3}3) PostgreSQL" | ||||||
|  | read -rp "${TAB3}Enter your choice (default: 1): " DB_CHOICE | ||||||
|  | DB_CHOICE=${DB_CHOICE:-1} | ||||||
|  | 
 | ||||||
|  | case $DB_CHOICE in | ||||||
|  | 1) | ||||||
|  |   DB_COMPOSE_FILE="mongo.compose.yaml" | ||||||
|  |   ;; | ||||||
|  | 2) | ||||||
|  |   DB_COMPOSE_FILE="sqlite.compose.yaml" | ||||||
|  |   ;; | ||||||
|  | 3) | ||||||
|  |   DB_COMPOSE_FILE="postgres.compose.yaml" | ||||||
|  |   ;; | ||||||
|  | *) | ||||||
|  |   echo "Invalid choice. Defaulting to MongoDB." | ||||||
|  |   DB_COMPOSE_FILE="mongo.compose.yaml" | ||||||
|  |   ;; | ||||||
|  | esac | ||||||
|  | 
 | ||||||
|  | mkdir -p /opt/komodo | ||||||
|  | cd /opt/komodo | ||||||
|  | curl -fsSL "https://raw.githubusercontent.com/moghtech/komodo/main/compose/$DB_COMPOSE_FILE" -o "$(basename "$DB_COMPOSE_FILE")" | ||||||
|  | 
 | ||||||
|  | msg_info "Setup Komodo Environment" | ||||||
|  | curl -fsSL "https://raw.githubusercontent.com/moghtech/komodo/main/compose/compose.env" -o "/opt/komodo/compose.env" | ||||||
|  | DB_PASSWORD=$(openssl rand -base64 16 | tr -d '/+=') | ||||||
|  | PASSKEY=$(openssl rand -base64 24 | tr -d '/+=') | ||||||
|  | WEBHOOK_SECRET=$(openssl rand -base64 24 | tr -d '/+=') | ||||||
|  | JWT_SECRET=$(openssl rand -base64 24 | tr -d '/+=') | ||||||
|  | 
 | ||||||
|  | sed -i "s/^KOMODO_DB_USERNAME=.*/KOMODO_DB_USERNAME=komodo_admin/" /opt/komodo/compose.env | ||||||
|  | sed -i "s/^KOMODO_DB_PASSWORD=.*/KOMODO_DB_PASSWORD=${DB_PASSWORD}/" /opt/komodo/compose.env | ||||||
|  | sed -i "s/^KOMODO_PASSKEY=.*/KOMODO_PASSKEY=${PASSKEY}/" /opt/komodo/compose.env | ||||||
|  | sed -i "s/^KOMODO_WEBHOOK_SECRET=.*/KOMODO_WEBHOOK_SECRET=${WEBHOOK_SECRET}/" /opt/komodo/compose.env | ||||||
|  | sed -i "s/^KOMODO_JWT_SECRET=.*/KOMODO_JWT_SECRET=${JWT_SECRET}/" /opt/komodo/compose.env | ||||||
|  | msg_ok "Setup Komodo Environment" | ||||||
|  | 
 | ||||||
|  | msg_info "Initialize Komodo" | ||||||
|  | $STD docker compose -p komodo -f "/opt/komodo/$DB_COMPOSE_FILE" --env-file /opt/komodo/compose.env up -d | ||||||
|  | msg_ok "Initialized Komodo" | ||||||
|  | 
 | ||||||
|  | motd_ssh | ||||||
|  | customize | ||||||
|  | 
 | ||||||
|  | msg_info "Cleaning up" | ||||||
|  | $STD apk cache clean | ||||||
|  | msg_ok "Cleaned" | ||||||
							
								
								
									
										90
									
								
								install/alpine-tinyauth-install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								install/alpine-tinyauth-install.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,90 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | 
 | ||||||
|  | # Copyright (c) 2021-2025 community-scripts ORG | ||||||
|  | # Author: Slaviša Arežina (tremor021) | Co-Author: Stavros (steveiliop56) | ||||||
|  | # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE | ||||||
|  | # Source: https://github.com/steveiliop56/tinyauth | ||||||
|  | 
 | ||||||
|  | source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" | ||||||
|  | color | ||||||
|  | verb_ip6 | ||||||
|  | catch_errors | ||||||
|  | setting_up_container | ||||||
|  | network_check | ||||||
|  | update_os | ||||||
|  | 
 | ||||||
|  | msg_info "Installing Dependencies" | ||||||
|  | $STD apk add --no-cache curl openssl apache2-utils | ||||||
|  | msg_ok "Installed Dependencies" | ||||||
|  | 
 | ||||||
|  | msg_info "Installing Tinyauth" | ||||||
|  | mkdir -p /opt/tinyauth | ||||||
|  | 
 | ||||||
|  | RELEASE=$(curl -s https://api.github.com/repos/steveiliop56/tinyauth/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }') | ||||||
|  | curl -fsSL "https://github.com/steveiliop56/tinyauth/releases/download/v${RELEASE}/tinyauth-amd64" -o /opt/tinyauth/tinyauth | ||||||
|  | chmod +x /opt/tinyauth/tinyauth | ||||||
|  | 
 | ||||||
|  | PASSWORD=$(openssl rand -base64 8 | tr -dc 'a-zA-Z0-9' | head -c 8) | ||||||
|  | USER=$(htpasswd -Bbn "tinyauth" "${PASSWORD}") | ||||||
|  | 
 | ||||||
|  | cat <<EOF > /opt/tinyauth/credentials.txt | ||||||
|  | Tinyauth Credentials | ||||||
|  | Username: tinyauth | ||||||
|  | Password: ${PASSWORD} | ||||||
|  | EOF | ||||||
|  | 
 | ||||||
|  | echo "${RELEASE}" >/opt/tinyauth_version.txt | ||||||
|  | msg_ok "Installed Tinyauth" | ||||||
|  | 
 | ||||||
|  | read -p "${TAB3}Enter your Tinyauth subdomain (e.g. https://tinyauth.example.com): " app_url | ||||||
|  | 
 | ||||||
|  | msg_info "Creating Tinyauth Service" | ||||||
|  | SECRET=$(openssl rand -base64 32 | tr -dc 'a-zA-Z0-9' | head -c 32) | ||||||
|  | 
 | ||||||
|  | cat <<EOF >/opt/tinyauth/.env | ||||||
|  | SECRET=${SECRET} | ||||||
|  | USERS=${USER} | ||||||
|  | APP_URL=${app_url} | ||||||
|  | EOF | ||||||
|  | 
 | ||||||
|  | sed -i -e 's/\$/\$\$/g' /opt/tinyauth/.env | ||||||
|  | 
 | ||||||
|  | cat <<'EOF' >/etc/init.d/tinyauth | ||||||
|  | #!/sbin/openrc-run | ||||||
|  | description="Tinyauth Service" | ||||||
|  | 
 | ||||||
|  | command="/opt/tinyauth/tinyauth" | ||||||
|  | directory="/opt/tinyauth" | ||||||
|  | command_user="root" | ||||||
|  | command_background="true" | ||||||
|  | pidfile="/var/run/tinyauth.pid" | ||||||
|  | 
 | ||||||
|  | start_pre() { | ||||||
|  |     if [ -f "/opt/tinyauth/.env" ]; then | ||||||
|  |         while IFS= read -r line || [ -n "$line" ]; do | ||||||
|  |             [ -z "$line" ] && continue | ||||||
|  |             case "$line" in | ||||||
|  |                 '#'*) | ||||||
|  |                     continue | ||||||
|  |                     ;; | ||||||
|  |             esac | ||||||
|  |             export "$line" | ||||||
|  |         done < "/opt/tinyauth/.env" | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | depend() { | ||||||
|  |     use net | ||||||
|  | } | ||||||
|  | EOF | ||||||
|  | 
 | ||||||
|  | chmod +x /etc/init.d/tinyauth | ||||||
|  | $STD rc-update add tinyauth default | ||||||
|  | msg_ok "Enabled Tinyauth Service" | ||||||
|  | 
 | ||||||
|  | msg_info "Starting Tinyauth" | ||||||
|  | $STD service tinyauth start | ||||||
|  | msg_ok "Started Tinyauth" | ||||||
|  | 
 | ||||||
|  | motd_ssh | ||||||
|  | customize | ||||||
| @ -1248,45 +1248,64 @@ EOF | |||||||
|   if ([ "$CT_TYPE" == "0" ] || [ "$is_vaapi_app" == "true" ]) && |   if ([ "$CT_TYPE" == "0" ] || [ "$is_vaapi_app" == "true" ]) && | ||||||
|     ([[ -e /dev/dri/renderD128 ]] || [[ -e /dev/dri/card0 ]] || [[ -e /dev/fb0 ]]); then |     ([[ -e /dev/dri/renderD128 ]] || [[ -e /dev/dri/card0 ]] || [[ -e /dev/fb0 ]]); then | ||||||
| 
 | 
 | ||||||
|     msg_custom "⚙️" "\e[36m" "Configuring VAAPI passthrough for LXC container" |     echo "" | ||||||
|  |     msg_custom "⚙️ " "\e[96m" "Configuring VAAPI passthrough for LXC container" | ||||||
| 
 | 
 | ||||||
|     if [ "$CT_TYPE" != "0" ]; then |     if [ "$CT_TYPE" != "0" ]; then | ||||||
|       msg_custom "⚠️" "\e[33m" "Container is unprivileged – VAAPI passthrough may not work without additional host configuration (e.g., idmap)." |       msg_custom "⚠️ " "\e[33m" "Container is unprivileged – VAAPI passthrough may not work without additional host configuration (e.g., idmap)." | ||||||
|     fi |     fi | ||||||
| 
 | 
 | ||||||
|     msg_custom "ℹ️" "\e[36m" "VAAPI enables GPU hardware acceleration (e.g., for video transcoding in Jellyfin or Plex)." |     msg_custom "ℹ️ " "\e[96m" "VAAPI enables GPU hardware acceleration (e.g., for video transcoding in Jellyfin or Plex)." | ||||||
|     msg_custom "📦" "\e[36m" "The following GPU-related devices were detected on the host and can be mounted into the container." |  | ||||||
| 
 | 
 | ||||||
|     VAAPI_ALL=no |     echo "" | ||||||
|     read -rp "  ➤ Automatically mount all VAAPI devices? [Y/n]: " VAAPI_ALL |     read -rp "➤ Automatically mount all available VAAPI devices? [Y/n]: " VAAPI_ALL | ||||||
| 
 | 
 | ||||||
|     if [[ ! "$VAAPI_ALL" =~ ^[Nn]$ ]]; then |     if [[ "$VAAPI_ALL" =~ ^[Yy]$|^$ ]]; then | ||||||
|       VAAPI_ALL=yes |       # Mount all devices automatically | ||||||
|     fi |       if [[ -e /dev/dri/renderD128 ]]; then | ||||||
| 
 |  | ||||||
|     if [[ -e /dev/dri/renderD128 ]]; then |  | ||||||
|       if [[ "$VAAPI_ALL" == "yes" ]] || read -rp "  ➤ /dev/dri/renderD128 (GPU rendering) – mount? [Y/n]: " yn && [[ "$yn" =~ ^[Yy]$|^$ ]]; then |  | ||||||
|         echo "lxc.cgroup2.devices.allow: c 226:128 rwm" >>"$LXC_CONFIG" |         echo "lxc.cgroup2.devices.allow: c 226:128 rwm" >>"$LXC_CONFIG" | ||||||
|         echo "lxc.mount.entry: /dev/dri/renderD128 dev/dri/renderD128 none bind,optional,create=file" >>"$LXC_CONFIG" |         echo "lxc.mount.entry: /dev/dri/renderD128 dev/dri/renderD128 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|       fi |       fi | ||||||
|     fi |       if [[ -e /dev/dri/card0 ]]; then | ||||||
| 
 |  | ||||||
|     if [[ -e /dev/dri/card0 ]]; then |  | ||||||
|       if [[ "$VAAPI_ALL" == "yes" ]] || read -rp "  ➤ /dev/dri/card0 (GPU interface) – mount? [Y/n]: " yn && [[ "$yn" =~ ^[Yy]$|^$ ]]; then |  | ||||||
|         echo "lxc.cgroup2.devices.allow: c 226:0 rwm" >>"$LXC_CONFIG" |         echo "lxc.cgroup2.devices.allow: c 226:0 rwm" >>"$LXC_CONFIG" | ||||||
|         echo "lxc.mount.entry: /dev/dri/card0 dev/dri/card0 none bind,optional,create=file" >>"$LXC_CONFIG" |         echo "lxc.mount.entry: /dev/dri/card0 dev/dri/card0 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|       fi |       fi | ||||||
|     fi |       if [[ -e /dev/fb0 ]]; then | ||||||
| 
 |  | ||||||
|     if [[ -e /dev/fb0 ]]; then |  | ||||||
|       if [[ "$VAAPI_ALL" == "yes" ]] || read -rp "  ➤ /dev/fb0 (framebuffer) – mount as well? [Y/n]: " yn && [[ "$yn" =~ ^[Yy]$|^$ ]]; then |  | ||||||
|         echo "lxc.cgroup2.devices.allow: c 29:0 rwm" >>"$LXC_CONFIG" |         echo "lxc.cgroup2.devices.allow: c 29:0 rwm" >>"$LXC_CONFIG" | ||||||
|         echo "lxc.mount.entry: /dev/fb0 dev/fb0 none bind,optional,create=file" >>"$LXC_CONFIG" |         echo "lxc.mount.entry: /dev/fb0 dev/fb0 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|       fi |       fi | ||||||
|     fi |       if [[ -d /dev/dri ]]; then | ||||||
|  |         echo "lxc.mount.entry: /dev/dri dev/dri none bind,optional,create=dir" >>"$LXC_CONFIG" | ||||||
|  |       fi | ||||||
|  |     else | ||||||
|  |       # Manual selection per device | ||||||
|  |       if [[ -e /dev/dri/renderD128 ]]; then | ||||||
|  |         read -rp "➤ Mount /dev/dri/renderD128 (GPU rendering)? [y/N]: " MOUNT_D128 | ||||||
|  |         if [[ "$MOUNT_D128" =~ ^[Yy]$ ]]; then | ||||||
|  |           echo "lxc.cgroup2.devices.allow: c 226:128 rwm" >>"$LXC_CONFIG" | ||||||
|  |           echo "lxc.mount.entry: /dev/dri/renderD128 dev/dri/renderD128 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
| 
 | 
 | ||||||
|     if [[ -d /dev/dri ]]; then |       if [[ -e /dev/dri/card0 ]]; then | ||||||
|       echo "lxc.mount.entry: /dev/dri dev/dri none bind,optional,create=dir" >>"$LXC_CONFIG" |         read -rp "➤ Mount /dev/dri/card0 (GPU hardware interface)? [y/N]: " MOUNT_CARD0 | ||||||
|  |         if [[ "$MOUNT_CARD0" =~ ^[Yy]$ ]]; then | ||||||
|  |           echo "lxc.cgroup2.devices.allow: c 226:0 rwm" >>"$LXC_CONFIG" | ||||||
|  |           echo "lxc.mount.entry: /dev/dri/card0 dev/dri/card0 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  | 
 | ||||||
|  |       if [[ -e /dev/fb0 ]]; then | ||||||
|  |         read -rp "➤ Mount /dev/fb0 (Framebuffer, GUI)? [y/N]: " MOUNT_FB0 | ||||||
|  |         if [[ "$MOUNT_FB0" =~ ^[Yy]$ ]]; then | ||||||
|  |           echo "lxc.cgroup2.devices.allow: c 29:0 rwm" >>"$LXC_CONFIG" | ||||||
|  |           echo "lxc.mount.entry: /dev/fb0 dev/fb0 none bind,optional,create=file" >>"$LXC_CONFIG" | ||||||
|  |         fi | ||||||
|  |       fi | ||||||
|  | 
 | ||||||
|  |       if [[ -d /dev/dri ]]; then | ||||||
|  |         echo "lxc.mount.entry: /dev/dri dev/dri none bind,optional,create=dir" >>"$LXC_CONFIG" | ||||||
|  |       fi | ||||||
|     fi |     fi | ||||||
|   fi |   fi | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 CanbiZ
						CanbiZ