Compare commits
6 Commits
x11-pulse-
...
x11-pulse-
| Author | SHA1 | Date | |
|---|---|---|---|
| 1935ad1b30 | |||
| 8fbec958ed | |||
| 3b58d3e99d | |||
| 5dfd1063e4 | |||
| 5ab68d4e8e | |||
| 15fedccb99 |
@@ -18,7 +18,8 @@ LABEL maintainer=${IMG_MAINTAINER}
|
|||||||
ENV DISPLAY=:0
|
ENV DISPLAY=:0
|
||||||
|
|
||||||
|
|
||||||
RUN urpmi --force xterm lib64jack0 lib64opencl1 pipewire-media-session lib64proxy-webkit hunspell-en lib64xcb-xkb1 lib64xcomposite1 lib64xcursor1 lib64xdamage1 lib64xft-gir2.0 lib64xi6 lib64xinerama1 lib64xkbcommon0 lib64vulkan-loader1 lib64xlib-gir2.0 lib64xrandr2 lib64xmlb2 lib64xslt1 libexif12-common libgxps-tools frozen-bubble
|
RUN urpmi.update -a \
|
||||||
|
&& urpmi --force xterm lib64jack0 lib64opencl1 pipewire-media-session lib64proxy-webkit hunspell-en lib64xcb-xkb1 lib64xcomposite1 lib64xcursor1 lib64xdamage1 lib64xft-gir2.0 lib64xi6 lib64xinerama1 lib64xkbcommon0 lib64vulkan-loader1 lib64xlib-gir2.0 lib64xrandr2 lib64xmlb2 lib64xslt1 libexif12-common libgxps-tools frozen-bubble glxinfo
|
||||||
|
|
||||||
#RUN passwd -d root
|
#RUN passwd -d root
|
||||||
|
|
||||||
|
|||||||
@@ -5,16 +5,16 @@ Welcome to RX3-Docker/X11-Pulse docker image!
|
|||||||
This is project aims to build a X11 + Pulse docker image able to run any graphic & audio application isolated.
|
This is project aims to build a X11 + Pulse docker image able to run any graphic & audio application isolated.
|
||||||
|
|
||||||
Features:
|
Features:
|
||||||
- Curtently based on rx3-docker/base:1.3.0-mga9 image,
|
- Curtently based on rx3-docker/base:1.3.5-mga9 image,
|
||||||
- X11 & Pulse base libraries installed,
|
- X11 & Pulse base libraries installed,
|
||||||
- Target user & group created on the run,
|
- Target user & group created on the run,
|
||||||
- Optional output internet routing.
|
- Optional output internet routing.
|
||||||
|
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
./bin/run.sh [-h] [-i] <Application Dir> <Application Exec> [Args...]
|
./bin/run.sh [-h] [-i] <Application Dir> <Application Exec> [Args...]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Enjoy it!
|
Enjoy it!
|
||||||
|
|
||||||
Your Rx3 Team.
|
Your Rx3 Team.
|
||||||
|
|||||||
@@ -1,3 +1,49 @@
|
|||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Rx3-Docker/X11-Pulse V 1.2.5 - A. GIBERT - 2025/09/19
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
- Use now rx3-docker/base:1.3.5-mga9 image,
|
||||||
|
- Rebuild for updates.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Rx3-Docker/X11-Pulse V 1.2.4 - A. GIBERT - 2025/04/21
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
- Fix Application Dir spaces support.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Rx3-Docker/X11-Pulse V 1.2.3 - A. GIBERT - 2025/04/14
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
- Add absolute & relative command path support,
|
||||||
|
- Add spaces support in Application Dir & Command,
|
||||||
|
- Add glinfo command.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Rx3-Docker/X11-Pulse V 1.2.2 - A. GIBERT - 2025/04/13
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
- Use now rx3-docker/base:1.3.2-mga9 image,
|
||||||
|
- Add "urpmi.update -a" to force mirror sync.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Rx3-Docker/X11-Pulse V 1.2.1 - A. GIBERT - 2025/03/08
|
||||||
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
- Use now rx3-docker/base:1.3.1-mga9 image,
|
||||||
|
- Fix some env.dist variables,
|
||||||
|
- Improve network naming.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------------------------------------------------------------
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
Rx3-Docker/X11-Pulse V 1.2.0 - A. GIBERT - 2024/11/18
|
Rx3-Docker/X11-Pulse V 1.2.0 - A. GIBERT - 2024/11/18
|
||||||
------------------------------------------------------------------------------------------------------------------------------------
|
------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -32,6 +32,8 @@ shift
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
APPL_DIR=$(realpath "${APPL_DIR}")
|
||||||
|
|
||||||
export USER_ID=$(id -u)
|
export USER_ID=$(id -u)
|
||||||
export GROUP_ID=$(id -g)
|
export GROUP_ID=$(id -g)
|
||||||
export GROUP_NAME=$(id -gn)
|
export GROUP_NAME=$(id -gn)
|
||||||
@@ -41,4 +43,6 @@ cd "${APPL_HOME_DIR}"
|
|||||||
|
|
||||||
sbin/docker_mk_env
|
sbin/docker_mk_env
|
||||||
|
|
||||||
docker compose run --rm x11-pulse /usr/local/sbin/user_add_exec ${USER_ID} ${USER} ${HOME} ${GROUP_ID} ${GROUP_NAME} ${APPL_DIR}/${APPL_NAME} $*
|
docker compose run --rm x11-pulse /usr/local/sbin/user_add_exec ${USER_ID} ${USER} ${HOME} ${GROUP_ID} ${GROUP_NAME} "${APPL_DIR}" "${APPL_NAME}" "$@"
|
||||||
|
|
||||||
|
docker compose down
|
||||||
|
|||||||
16
compose.yaml
16
compose.yaml
@@ -5,6 +5,8 @@ name: ${XP_IMG_NAME}
|
|||||||
|
|
||||||
services:
|
services:
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
x11-pulse:
|
x11-pulse:
|
||||||
container_name: ${XP_HOST_NAME}
|
container_name: ${XP_HOST_NAME}
|
||||||
hostname: ${XP_HOST_NAME}
|
hostname: ${XP_HOST_NAME}
|
||||||
@@ -23,10 +25,11 @@ services:
|
|||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
DISPLAY: ":0"
|
DISPLAY: "${DISPLAY}"
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
- home_dir:/home
|
# - home_dir:/home
|
||||||
|
- /opt/vm/home:/home
|
||||||
- type: bind
|
- type: bind
|
||||||
source: /tmp/.X11-unix/X0
|
source: /tmp/.X11-unix/X0
|
||||||
target: /tmp/.X11-unix/X0
|
target: /tmp/.X11-unix/X0
|
||||||
@@ -46,11 +49,20 @@ volumes:
|
|||||||
external: true
|
external: true
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
internet:
|
internet:
|
||||||
|
name: ${NETWORK_NAME}-internet
|
||||||
driver: bridge
|
driver: bridge
|
||||||
internal: false # Allow internet access
|
internal: false # Allow internet access
|
||||||
|
driver_opts:
|
||||||
|
com.docker.network.bridge.name: ${NETWORK_IF_NAME}
|
||||||
|
|
||||||
no-internet:
|
no-internet:
|
||||||
|
name: ${NETWORK_NAME}-no-internet
|
||||||
driver: bridge
|
driver: bridge
|
||||||
internal: true # Block internet access
|
internal: true # Block internet access
|
||||||
|
driver_opts:
|
||||||
|
com.docker.network.bridge.name: ${NETWORK_IF_NAME}
|
||||||
|
|||||||
29
env.dist
29
env.dist
@@ -17,19 +17,36 @@ ORG_URL_PREFIX="${ORG_REGISTRY}/${ORG_NAME}"
|
|||||||
# Image Settings
|
# Image Settings
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
APPL_NAME="x11-pulse"
|
||||||
|
APPL_NAME_FULL="X11-Pulse Docker Image"
|
||||||
|
APPL_NAME_SHORT="x11-pulse"
|
||||||
|
APPL_VERSION="1.2.5"
|
||||||
|
|
||||||
HOST_NAME_PREFIX=""
|
HOST_NAME_PREFIX=${APPL_NAME_SHORT}${APPL_SUFFIX}
|
||||||
|
|
||||||
PORT_ENV_OFFSET=0
|
PORT_ENV_OFFSET=0
|
||||||
|
|
||||||
|
PORT_SV_INT=9001
|
||||||
PORT_SV_OFFSET=1000
|
PORT_SV_OFFSET=1000
|
||||||
|
|
||||||
|
NETWORK_NAME=${HOST_NAME_PREFIX}
|
||||||
|
NETWORK_IF_NAME=br-${NETWORK_NAME}
|
||||||
|
|
||||||
#------------------+----------+--------------------+--------------------------+------------------------------------------+------------+--------------------+---------------+------------+--------------+------------+-------+-------+-------+-------+--------------+--------------+
|
DOCKER_TOOLS_DEBUG=FALSE
|
||||||
# | Variable | Target Image | From Image | Module | Main Port | Admin Port | User | Group |
|
|
||||||
# | Prefix | URL Prefix | Name | Name Full + Version | URL Prefix | Name + Version | Name | Version | Ext | Int | Ext | Int | Name / Id | Name / Id |
|
|
||||||
#------------------+----------+--------------------+--------------------------+------------------------------------------+------------+--------------------+---------------+------------+--------------+------------+-------+-------+-------+-------+--------------+--------------+
|
|
||||||
|
|
||||||
docker_service_add XP ${ORG_URL_PREFIX} x11-pulse "Rx3-Docker X11 Pulse Docker Image" 1.2.0-mga9 ${ORG_URL_PREFIX} base 1.3.0-mga9 - - - - - - - -
|
DOCKER_TOOLS_VOLUME=SINGLE
|
||||||
|
#DOCKER_TOOLS_VOLUME=MIXED
|
||||||
|
#DOCKER_TOOLS_VOLUME=MERGED
|
||||||
|
#DOCKER_TOOLS_VOLUME=SPLIT
|
||||||
|
|
||||||
|
#DOCKER_TOOLS_EXEPTION_LIBS="postgres:pgsql"
|
||||||
|
|
||||||
|
#------------------+----------+--------------------------+--------------------+------------------+-------------------------------+---------------------+--------------------+---------------+------------+--------------+------------+-------+-------+-------+-------+--------------+--------------+
|
||||||
|
# | Variable | Service | Target Image | From Image | Module | Main Port | Admin Port | User | Group |
|
||||||
|
# | Prefix | Name | URL Prefix | Name | Name Full | Version | URL Prefix | Name | Version | Name | Version | Ext | Int | Ext | Int | Name / Id | Name / Id |
|
||||||
|
#------------------+----------+--------------------------+--------------------+------------------+-------------------------------+---------------------+--------------------+---------------+------------+--------------+------------+-------+-------+-------+-------+--------------+--------------+
|
||||||
|
|
||||||
|
docker_service_add XP x11-pulse ${ORG_URL_PREFIX} - "Rx3-Docker/X11-Pulse" ${APPL_VERSION}-mga9 ${ORG_URL_PREFIX} base 1.3.5-mga9 - - - - - - - -
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,23 +1,24 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
for arg in User_Id User_Name Home_Dir Group_Id Group_Name
|
for arg in User_Id User_Name Home_Dir Group_Id Group_Name Appl_Dir
|
||||||
do
|
do
|
||||||
declare "$arg"=$1
|
declare "$arg"="$1"
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
|
Cmd=$( printf " %q" "$@" | sed -e 's/^ //' -e 's/\\;/;/g')
|
||||||
|
|
||||||
|
|
||||||
echo "User Add & Exec: User_Id: (${User_Id}) User_Name: [${User_Name}] Home_Dir: [${Home_Dir}] Group_Id: (${Group_Id}) Group_Name: [${Group_Name}]"
|
echo "User Add & Exec: User_Id: (${User_Id}) User_Name: [${User_Name}] Home_Dir: [${Home_Dir}] Group_Id: (${Group_Id}) Group_Name: [${Group_Name}] Appl_Dir: [${Appl_Dir}]"
|
||||||
echo -n " Display: [${DISPLAY}] Cmd: [$1]"
|
echo -n " Display: [${DISPLAY}] Cmd: [${Cmd}]"
|
||||||
|
|
||||||
i=2
|
#i=2
|
||||||
|
|
||||||
while [[ $i -le $# ]]
|
#while [[ $i -le $# ]]
|
||||||
do
|
#do
|
||||||
echo -n " [${!i}]"
|
# echo -n " [${!i}]"
|
||||||
i=$(($i + 1))
|
# i=$(($i + 1))
|
||||||
done
|
#done
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo ""
|
echo ""
|
||||||
@@ -46,8 +47,9 @@ chown ${User_Name}:${Group_Name} /run/user/${User_Id}
|
|||||||
|
|
||||||
|
|
||||||
echo "Exec Cmd..."
|
echo "Exec Cmd..."
|
||||||
|
|
||||||
#echo "su - -P ${User_Name} -c \"$*\""
|
#echo "su - -P ${User_Name} -c \"$*\""
|
||||||
|
|
||||||
su - -P ${User_Name} -c "$*"
|
su - -P ${User_Name} -c "cd \"${Appl_Dir}\"; ${Cmd}"
|
||||||
|
|
||||||
echo "Completed!"
|
echo "Completed!"
|
||||||
|
|||||||
Reference in New Issue
Block a user