DEBUGNOTE[09:46:09,346]: check_host(): Command tty failed. Guess if running on console: yes DEBUGNOTE[09:46:09,399]: check_host(): ps can watch root processes: yes x11docker[09:46:09,412]: Image name: pccastor_ayabzo_wallet:latest Container command: DEBUGNOTE[09:46:09,442]: host user: debian 1000:1000 /home/debian x11docker WARNING: User debian is member of group docker. That allows unprivileged processes on host to gain root privileges. DEBUGNOTE[09:46:09,668]: storeinfo(): cache=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268 DEBUGNOTE[09:46:09,677]: storeinfo(): stdout=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/stdout DEBUGNOTE[09:46:09,685]: storeinfo(): stderr=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/stderr DEBUGNOTE[09:46:09,708]: storeinfo(): x11dockerpid=24421 DEBUGNOTE[09:46:09,754]: x11docker version: 6.10.1-beta-4 Backend version: Docker version 20.10.12, build e91ed57 Host system: "Debian GNU/Linux 10 (buster)" Host architecture: amd64 (x86_64) Command: '/usr/bin/x11docker' '-q' '--cap-default' '--showenv' '--backend=docker' '--xvfb' '--size=1980x1200' '--lang=fr' '--keymap=fr-latin9' '--home=pccastor_ayabzo_home' 'pccastor_ayabzo_wallet:latest' Parsed options: -q --cap-default --showenv --backend 'docker' --xvfb --size '1980x1200' --lang 'fr' --keymap 'fr-latin9' --home 'pccastor_ayabzo_home' -- 'pccastor_ayabzo_wallet:latest' DEBUGNOTE[09:46:09,759]: Dependency check for --xvfb: 0 DEBUGNOTE[09:46:09,764]: Dependencies of --xvfb already checked: 0 DEBUGNOTE[09:46:09,767]: Dependencies of --xvfb already checked: 0 DEBUGNOTE[09:46:09,772]: storeinfo(): xserver=--xvfb x11docker WARNING: Option --cap-default disables security hardening for containers done by x11docker. Default docker capabilities are allowed. This is considered to be less secure. x11docker note: Option --cap-default: Enabling option --newprivileges. You can avoid this with --newprivileges=no DEBUGNOTE[09:46:09,796]: container user: debian 1000:1000 /home/debian DEBUGNOTE[09:46:09,806]: Option --home: Using docker volume pccastor_ayabzo_home DEBUGNOTE[09:46:09,847]: waitforlogentry(): tailstdout: Waiting for logentry "x11docker=ready" in store.info DEBUGNOTE[09:46:09,848]: waitforlogentry(): tailstderr: Waiting for logentry "x11docker=ready" in store.info DEBUGNOTE[09:46:09,880]: storepid(): Stored pid '25202' of 'watchpidlist': 25202 ? 00:00:00 bash DEBUGNOTE[09:46:09,911]: storepid(): Stored pid '25221' of 'watchmessagefifo': 25221 ? 00:00:00 bash x11docker[09:46:09,924]: Virtual screen size: 1980x1200 x11docker[09:46:09,931]: Physical screen size: DEBUGNOTE[09:46:10,015]: storeinfo(): DISPLAY=:119 DEBUGNOTE[09:46:10,023]: storeinfo(): XAUTHORITY=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client DEBUGNOTE[09:46:10,031]: storeinfo(): XSOCKET=/tmp/.X11-unix/X119 DEBUGNOTE[09:46:10,039]: storeinfo(): XDG_RUNTIME_DIR=/run/user/1000 DEBUGNOTE[09:46:10,048]: storeinfo(): Xenv= DISPLAY=:119 XAUTHORITY=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client XSOCKET=/tmp/.X11-unix/X119 XDG_RUNTIME_DIR=/run/user/1000 DEBUGNOTE[09:46:10,073]: X server command: /usr/bin/Xvfb :119 \ -retro \ +extension RANDR \ +extension RENDER \ +extension GLX \ +extension XVideo \ +extension DOUBLE-BUFFER \ +extension SECURITY \ +extension DAMAGE \ +extension X-Resource \ -extension XINERAMA -xinerama \ -extension MIT-SHM \ +extension Composite +extension COMPOSITE \ +extension XTEST \ -dpms \ -s off \ -auth /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/Xauthority.server \ -nolisten tcp \ -screen 0 1980x1200x24 \ x11docker[09:46:10,192]: --init: Found tini binary: /usr/bin/docker-init DEBUGNOTE[09:46:10,196]: storeinfo(): tini=/usr/bin/docker-init DEBUGNOTE[09:46:10,206]: Users and terminal: x11docker was started by: debian As host user serves (running X, storing cache): debian Container user will be: debian Container user password: x11docker Getting permission to run backend with: eval Terminal for password frontend: bash -c Running in a terminal: no Running on console: yes Running over SSH: no Running sourced: no bash $-: hB x11docker WARNING: Option --newprivileges=yes: x11docker does not set docker run option --security-opt=no-new-privileges. That degrades container security. However, this is still within a default docker setup. DEBUGNOTE[09:46:10,210]: storeinfo(): containername=x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 DEBUGNOTE[09:46:10,506]: docker command: docker run --detach --tty \ --name x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 \ --user 1000:1000 \ --userns=host \ --security-opt label=type:container_runtime_t \ --volume '/usr/bin/docker-init':'/usr/local/bin/init':ro \ --tmpfs /run:exec --tmpfs /run/lock \ --volume '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share':'/x11docker':rw \ --volume 'pccastor_ayabzo_home':'/home.volume/pccastor_ayabzo_home':rw \ --volume '/tmp/.X11-unix/X119':'/X119':rw \ --workdir '/tmp' \ --entrypoint env \ --env 'container=docker' \ --env 'XAUTHORITY=/x11docker/Xauthority.client' \ --env 'DISPLAY=:119' \ --env 'HOME=/home.volume/pccastor_ayabzo_home/debian' \ --env 'USER=debian' \ -- pccastor_ayabzo_wallet:latest /usr/local/bin/init -- /bin/sh - /x11docker/containerrc x11docker[09:46:10,688]: Generated dockerrc: 1 #! /usr/bin/env bash 2 3 # dockerrc: 4 # This script runs as root (or member of group docker) on host. 5 # - inspect image 6 # - pull image if needed 7 # - create containerrc 8 # - set up systemd/elogind cgroup if needed 9 # - run window manager in container or from host if needed 10 11 trap '' SIGINT 12 13 askyesno () 14 { 15 local Choice; 16 read -t60 -n1 -p "(timeout after 60s assuming no) [Y|n]" Choice; 17 [ "$?" = '0' ] && { 18 [[ "$Choice" == [YyJj]* ]] || [ -z "$Choice" ] && return 0 19 }; 20 return 1 21 } 22 checkpid () 23 { 24 [ -e "/proc/${1:-NONSENSE}" ] 25 } 26 escapestring () 27 { 28 echo "${1:-}" | LC_ALL=C sed -e 's/[^a-zA-Z0-9,._+@=:/-]/\\&/g; ' 29 } 30 mysleep () 31 { 32 sleep "${1:-1}" 2> /dev/null || sleep 1 33 } 34 parse_inspect () 35 { 36 local Parserscript; 37 Parserscript="$Cachefolder/parse_inspect.py"; 38 Parserscript="#! $Pythonbin 39 $(cat << EOF 40 import json,sys 41 42 def parse_inspect(*args): 43 """ 44 parse output of docker|podman|nerdctl inspect 45 args: 46 0: ignored 47 1: string containing inspect output 48 2..n: json keys. For second level keys provide e.g. "Config","Cmd" 49 Prints key value as a string. 50 Prints empty string if key not found. 51 A list is printed as a string with '' around each element. 52 """ 53 54 output="" 55 inspect=args[1] 56 inspect=inspect.strip() 57 if inspect[0] == "[" : 58 inspect=inspect[1:-2] # remove enclosing [ ] 59 60 obj=json.loads(inspect) 61 62 for arg in args[2:]: # recursively find the desired object. Command.Cmd is found with args "Command" , "Cmd" 63 try: 64 obj=obj[arg] 65 except: 66 obj="" 67 68 objtype=str(type(obj)) 69 if "'list'" in objtype: 70 for i in obj: 71 output=output+"'"+str(i)+"' " 72 else: 73 output=str(obj) 74 75 if output == "None": 76 output="" 77 78 print(output) 79 80 parse_inspect(*sys.argv) 81 EOF 82 )"; 83 echo "$Parserscript" | $Pythonbin - "$@" 84 } 85 pspid () 86 { 87 LC_ALL=C ps -p "${1:-}" 2> /dev/null | grep -v 'TIME' 88 } 89 rmcr () 90 { 91 case "${1:-}" in 92 "") 93 sed "s/$(printf "\r")//g" 94 ;; 95 *) 96 sed -i "s/$(printf "\r")//g" "${1:-}" 97 ;; 98 esac 99 } 100 rocknroll () 101 { 102 [ -s "$Timetosaygoodbyefile" ] && return 1; 103 [ -e "$Timetosaygoodbyefile" ] || return 1; 104 return 0 105 } 106 saygoodbye () 107 { 108 debugnote "time to say goodbye ($*)"; 109 [ -e "$Timetosaygoodbyefile" ] && echo timetosaygoodbye >> $Timetosaygoodbyefile; 110 [ -e "$Timetosaygoodbyefifo" ] && echo timetosaygoodbye >> $Timetosaygoodbyefifo 111 } 112 storeinfo () 113 { 114 [ -e "$Storeinfofile" ] || return 1; 115 case "${1:-}" in 116 dump) 117 grep "^${2:-}=" $Storeinfofile | sed "s/^${2:-}=//" 118 ;; 119 drop) 120 sed -i "/^${2:-}=/d" $Storeinfofile 121 ;; 122 test) 123 grep -q "^${2:-}=" $Storeinfofile 124 ;; 125 *) 126 debugnote "storeinfo(): ${1:-}"; 127 grep -q "^$(echo "${1:-}" | cut -d= -f1)=" $Storeinfofile && { 128 sed -i "/^$(echo "${1:-}" | cut -d= -f1)=/d" $Storeinfofile 129 }; 130 echo "${1:-}" >> $Storeinfofile 131 ;; 132 esac 133 } 134 storepid () 135 { 136 case "${1:-}" in 137 dump) 138 grep -w "${2:-}" "$Storepidfile" | cut -d' ' -f1 139 ;; 140 test) 141 grep -q -w "${2:-}" "$Storepidfile" 142 ;; 143 *) 144 echo "${1:-NOPID}" "${2:-NONAME}" >> "$Storepidfile"; 145 debugnote "storepid(): Stored pid '${1:-}' of '${2:-}': $(pspid ${1:-} ||:)" 146 ;; 147 esac 148 } 149 waitforlogentry () 150 { 151 local Startzeit Uhrzeit Dauer Count=0 Schlaf; 152 local Errorkeys="${4:-}"; 153 local Warten="${5:-60}"; 154 local Error=; 155 Startzeit="$(date +%s ||:)"; 156 Startzeit="${Startzeit:-0}"; 157 [ "$Warten" = "infinity" ] && Warten=32000; 158 debugnote "waitforlogentry(): ${1:-}: Waiting for logentry \"${3:-}\" in $(basename ${2:-})"; 159 while ! grep -q "${3:-}" < "${2:-}"; do 160 Count="$(( $Count + 1 ))"; 161 Uhrzeit="$(date +%s ||:)"; 162 Uhrzeit="${Uhrzeit:-0}"; 163 Dauer="$(( $Uhrzeit - $Startzeit ))"; 164 Schlaf="$(( $Count / 10 ))"; 165 [ "$Schlaf" = "0" ] && Schlaf="0.5"; 166 mysleep "$Schlaf"; 167 [ "$Dauer" -gt "10" ] && debugnote "waitforlogentry(): ${1:-}: Waiting since ${Dauer}s for log entry \"${3:-}\" in $(basename ${2:-})"; 168 [ "$Dauer" -gt "$Warten" ] && error "waitforlogentry(): ${1:-}: Timeout waiting for entry \"${3:-}\" in $(basename ${2:-}) 169 Last lines of $(basename ${2:-}): 170 $(tail "${2:-}")"; 171 [ "$Errorkeys" ] && grep -i -q -E "$Errorkeys" < "${2:-}" && error "waitforlogentry(): ${1:-}: Found error message in logfile. 172 Last lines of logfile $(basename ${2:-}): 173 $(tail "${2:-}")"; 174 rocknroll || { 175 debugnote "waitforlogentry(): ${1:-}: Stopped waiting for ${3:-} in $(basename ${2:-}) due to terminating signal."; 176 Error=1; 177 break 178 }; 179 done; 180 [ "$Error" ] && return 1; 181 debugnote "waitforlogentry(): ${1:-}: Found log entry \"${3:-}\" in $(basename ${2:-})."; 182 return 0 183 } 184 185 warning() { 186 echo "$*:WARNING" | sed "s/\$/ /" >>$Messagefile 187 } 188 note() { 189 echo "$*:NOTE" | sed "s/\$/ /" >>$Messagefile 190 } 191 verbose() { 192 echo "$*:VERBOSE" | sed "s/\$/ /" >>$Messagefile 193 } 194 debugnote() { 195 echo "$*:DEBUGNOTE" | sed "s/\$/ /" >>$Messagefile 196 } 197 error() { 198 echo "$*:ERROR" | sed "s/\$/ /" >>$Messagefile 199 exit 64 200 } 201 stdout() { 202 echo "$*:STDOUT" | sed "s/\$/ /" >>$Messagefile 203 } 204 205 Cachefolder='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268' 206 Containercommand="" 207 Imagename="pccastor_ayabzo_wallet:latest" 208 Messagefile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/message.fifo' 209 Newxenv=' DISPLAY=:119 XAUTHORITY=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client XSOCKET=/tmp/.X11-unix/X119 XDG_RUNTIME_DIR=/run/user/1000' 210 export PATH='/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/local/games:/usr/games' 211 Pythonbin='/usr/bin/python' 212 Storeinfofile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/store.info' 213 Storepidfile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/store.pids' 214 Timetosaygoodbyefile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/timetosaygoodbye' 215 Timetosaygoodbyefifo='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/timetosaygoodbye.fifo' 216 Xserver='--xvfb' 217 Workdir='' 218 219 Containerarchitecture= 220 Containerid= 221 Containerip= 222 Dockerlogspid='' 223 Exec= 224 Entrypoint= 225 Failure= 226 Imagepull= 227 Imageuser= 228 Inspect= 229 Line= 230 Pid1pid= 231 Runtime= 232 Signal= 233 debugnote 'Running dockerrc: Setup as root or as user docker on host.' 234 235 236 # Check whether docker daemon is running, get docker info 237 docker info >>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/docker.info 2>>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log || { 238 error "'docker info' failed. 239 If using docker: Is docker daemon running at all? 240 Try to start docker daemon with 'systemctl start docker'. 241 Last lines of log: 242 $(rmcr < '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log' | tail)" 243 } 244 245 # Check default runtime 246 Runtime="$( { grep 'Default Runtime' < '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/docker.info' ||: ;} | awk '{print $3}' )" 247 [ -n "$Runtime" ] && { 248 debugnote "dockerrc: Found default container Runtime: $Runtime" 249 debugnote "dockerrc: All $(grep 'Runtimes' < '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/docker.info' ||: )" 250 [ "$Runtime" != '' ] && { 251 case $Runtime in 252 kata-runtime) warning 'Found default container runtime kata-runtime. 253 Please run x11docker with --runtime=kata-runtime to avoid issues.' ;; 254 nvidia) [ 'no' = 'yes' ] && warning 'Option --gpu: Found default container runtime nvidia. 255 Please run x11docker with --runtime=nvidia to avoid issues.' ;; 256 runc|crun|oci) ;; 257 *) note "Found unknown container runtime: $Runtime 258 Please report at: https://github.com/mviereck/x11docker" ;; 259 esac 260 } 261 } 262 Runtime='UNDECLARED_RUNTIME' 263 debugnote "dockerrc: Container Runtime: $Runtime" 264 storeinfo "runtime=$Runtime" 265 266 # Refresh images.list for x11docker-gui 267 docker images 2>>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | grep -v REPOSITORY | awk '{print $1 ":" $2}' >>/home/debian/.cache/x11docker/docker.imagelist.sort 268 rmcr /home/debian/.cache/x11docker/docker.imagelist.sort 269 while read -r Line ; do 270 grep -q "" <<<$Line || echo $Line >> /home/debian/.cache/x11docker/docker.imagelist 271 done < <(sort < /home/debian/.cache/x11docker/docker.imagelist.sort) 272 rm /home/debian/.cache/x11docker/docker.imagelist.sort 273 274 # Check if image pccastor_ayabzo_wallet:latest is available locally 275 Imagepull=no 276 277 rocknroll || exit 64 278 279 [ "$Imagepull" = 'yes' ] && { 280 note "Pulling image 'pccastor_ayabzo_wallet:latest' from docker hub" 281 env DISPLAY='' DBUS_SESSION_BUS_ADDRESS='unix:path=/run/user/1000/bus' bash -c "notify-send 'x11docker: Pulling image pccastor_ayabzo_wallet:latest'" 2>/dev/null & 282 docker pull pccastor_ayabzo_wallet:latest 1>&2 || error "Pulling image 'pccastor_ayabzo_wallet:latest' seems to have failed!" 283 } 284 285 rocknroll || exit 64 286 287 Inspect="$(docker inspect pccastor_ayabzo_wallet:latest)" 288 # Check architecture 289 Containerarchitecture=$(parse_inspect "$Inspect" "Architecture") 290 debugnote "dockerrc: Image architecture: $Containerarchitecture" 291 # Check CMD 292 [ -z "$Containercommand" ] && { 293 # extract image command from image if not given on cli 294 Containercommand="$(parse_inspect "$Inspect" "Config" "Cmd")" 295 debugnote "dockerrc: Image CMD: $Containercommand" 296 echo "$Containercommand" | grep -q /x11docker/containerrc && error 'Recursion error: Found CMD /x11docker/containerrc in image. 297 Did you use 'docker commit' with an x11docker container? 298 Please build new images with a Dockerfile instead of using docker commit, 299 or provide a different container command.' 300 } 301 302 # Check USER 303 Imageuser="$(parse_inspect "$Inspect" "Config" "User")" 304 debugnote "dockerrc: Image USER: $Imageuser" 305 [ "$Imageuser" ] && note "Found 'USER $Imageuser' in image. 306 If you want to run with user $Imageuser instead of host user debian, 307 than run with --user=RETAIN." 308 storeinfo containeruser="debian" 309 310 # Check ENTRYPOINT 311 Entrypoint="$(parse_inspect "$Inspect" "Config" "Entrypoint")" 312 debugnote "dockerrc: Image ENTRYPOINT: $Entrypoint" 313 echo "$Entrypoint" | grep -qE 'tini|init|systemd' && { 314 note "There seems to be an init system in ENTRYPOINT of image: 315 $Entrypoint 316 Will disable it as x11docker already runs an init with option --tini. 317 To allow this ENTRYPOINT, run x11docker with option --init=none." 318 Entrypoint= 319 } 320 321 # Check WORKDIR 322 Workdir="$(parse_inspect "$Inspect" "Config" "Workdir")" 323 debugnote "dockerrc: Image WORKDIR: $Workdir" 324 [ "$Workdir" ] && note "Found 'WORKDIR $Workdir' in image. 325 You can change it with option --workdir=DIR." 326 327 [ -z "$Containercommand$Entrypoint" ] && error 'No container command specified and no CMD or ENTRYPOINT found in image.' 328 329 ######## Create containerrc ######## 330 331 { echo '#! /bin/sh' 332 echo '' 333 echo '# containerrc' 334 echo '# Created startscript for docker run used as container command.' 335 echo '# Runs as unprivileged user in container.' 336 echo '' 337 echo 'exec >>/x11docker/container.log 2>&1' 338 echo '' 339 echo 'mysleep () 340 { 341 sleep "${1:-1}" 2> /dev/null || sleep 1 342 }' 343 echo 'rocknroll () 344 { 345 [ -s "$Timetosaygoodbyefile" ] && return 1; 346 [ -e "$Timetosaygoodbyefile" ] || return 1; 347 return 0 348 }' 349 echo 'saygoodbye () 350 { 351 debugnote "time to say goodbye ($*)"; 352 [ -e "$Timetosaygoodbyefile" ] && echo timetosaygoodbye >> $Timetosaygoodbyefile; 353 [ -e "$Timetosaygoodbyefifo" ] && echo timetosaygoodbye >> $Timetosaygoodbyefifo 354 }' 355 echo 'storeinfo () 356 { 357 [ -e "$Storeinfofile" ] || return 1; 358 case "${1:-}" in 359 dump) 360 grep "^${2:-}=" $Storeinfofile | sed "s/^${2:-}=//" 361 ;; 362 drop) 363 sed -i "/^${2:-}=/d" $Storeinfofile 364 ;; 365 test) 366 grep -q "^${2:-}=" $Storeinfofile 367 ;; 368 *) 369 debugnote "storeinfo(): ${1:-}"; 370 grep -q "^$(echo "${1:-}" | cut -d= -f1)=" $Storeinfofile && { 371 sed -i "/^$(echo "${1:-}" | cut -d= -f1)=/d" $Storeinfofile 372 }; 373 echo "${1:-}" >> $Storeinfofile 374 ;; 375 esac 376 }' 377 echo 'waitforlogentry () 378 { 379 local Startzeit Uhrzeit Dauer Count=0 Schlaf; 380 local Errorkeys="${4:-}"; 381 local Warten="${5:-60}"; 382 local Error=; 383 Startzeit="$(date +%s ||:)"; 384 Startzeit="${Startzeit:-0}"; 385 [ "$Warten" = "infinity" ] && Warten=32000; 386 debugnote "waitforlogentry(): ${1:-}: Waiting for logentry \"${3:-}\" in $(basename ${2:-})"; 387 while ! grep -q "${3:-}" < "${2:-}"; do 388 Count="$(( $Count + 1 ))"; 389 Uhrzeit="$(date +%s ||:)"; 390 Uhrzeit="${Uhrzeit:-0}"; 391 Dauer="$(( $Uhrzeit - $Startzeit ))"; 392 Schlaf="$(( $Count / 10 ))"; 393 [ "$Schlaf" = "0" ] && Schlaf="0.5"; 394 mysleep "$Schlaf"; 395 [ "$Dauer" -gt "10" ] && debugnote "waitforlogentry(): ${1:-}: Waiting since ${Dauer}s for log entry \"${3:-}\" in $(basename ${2:-})"; 396 [ "$Dauer" -gt "$Warten" ] && error "waitforlogentry(): ${1:-}: Timeout waiting for entry \"${3:-}\" in $(basename ${2:-}) 397 Last lines of $(basename ${2:-}): 398 $(tail "${2:-}")"; 399 [ "$Errorkeys" ] && grep -i -q -E "$Errorkeys" < "${2:-}" && error "waitforlogentry(): ${1:-}: Found error message in logfile. 400 Last lines of logfile $(basename ${2:-}): 401 $(tail "${2:-}")"; 402 rocknroll || { 403 debugnote "waitforlogentry(): ${1:-}: Stopped waiting for ${3:-} in $(basename ${2:-}) due to terminating signal."; 404 Error=1; 405 break 406 }; 407 done; 408 [ "$Error" ] && return 1; 409 debugnote "waitforlogentry(): ${1:-}: Found log entry \"${3:-}\" in $(basename ${2:-})."; 410 return 0 411 }' 412 echo ' 413 warning() { 414 echo "$*:WARNING" | sed "s/\$/ /" >>$Messagefile 415 } 416 note() { 417 echo "$*:NOTE" | sed "s/\$/ /" >>$Messagefile 418 } 419 verbose() { 420 echo "$*:VERBOSE" | sed "s/\$/ /" >>$Messagefile 421 } 422 debugnote() { 423 echo "$*:DEBUGNOTE" | sed "s/\$/ /" >>$Messagefile 424 } 425 error() { 426 echo "$*:ERROR" | sed "s/\$/ /" >>$Messagefile 427 exit 64 428 } 429 stdout() { 430 echo "$*:STDOUT" | sed "s/\$/ /" >>$Messagefile 431 }' 432 echo 'Messagefile=/x11docker/message.fifo' 433 echo 'Storeinfofile=/x11docker/store.info' 434 echo 'Timetosaygoodbyefile=/x11docker/timetosaygoodbye' 435 echo '' 436 echo 'waitforlogentry containerrc $Storeinfofile containerrootrc=ready infinity' 437 echo 'debugnote "Running containerrc: Unprivileged user commands in container"' 438 echo '' 439 echo "Containercommand=\"$Containercommand\"" 440 echo "Entrypoint=\"$Entrypoint\"" 441 echo '' 442 echo 'verbose "containerrc: Container system:' 443 echo '$(cat /etc/os-release 2>&1 ||:)"' 444 echo '' 445 } >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/containerrc 446 { 447 echo '' 448 echo '# USER and HOME' 449 echo 'Containeruser="$(storeinfo dump containeruser)"' 450 echo 'Containeruserhome="/home.volume/pccastor_ayabzo_home/debian"' 451 echo 'export USER="$Containeruser"' 452 echo '[ "$Containeruserhome" ] && {' 453 echo ' export HOME="$Containeruserhome"' 454 echo '}' 455 echo '' 456 echo '# XDG_RUNTIME_DIR' 457 echo 'Containeruseruid=$(id -u $Containeruser)' 458 echo 'export XDG_RUNTIME_DIR=/tmp/XDG_RUNTIME_DIR' 459 echo '[ -e /run/user/$Containeruseruid ] && ln -s /run/user/$Containeruseruid $XDG_RUNTIME_DIR || mkdir -p -m700 $XDG_RUNTIME_DIR' 460 echo '' 461 echo '# Copy files from /etc/skel into empty HOME' 462 echo '[ -d "$HOME" ] && {' 463 echo ' [ -d /etc/skel ] && [ -z "$(ls -A "$Containeruserhome" 2>/dev/null | grep -v -E "gnupg")" ] && {' 464 echo ' debugnote "containerrc: HOME is empty. Copying from /etc/skel"' 465 echo ' cp -n -R /etc/skel/. $Containeruserhome' 466 echo ' :' 467 echo ' } || {' 468 echo ' debugnote "containerrc: HOME is not empty. Not copying from /etc/skel"' 469 echo ' }' 470 echo '}' 471 echo '' 472 echo '# Create softlink to X unix socket' 473 echo '[ -e /tmp/.X11-unix/X119 ] || ln -s /X119 /tmp/.X11-unix' 474 echo '' 475 echo 'unset WAYLAND_DISPLAY' 476 echo '' 477 echo 'export XDG_SESSION_TYPE=x11' 478 echo '' 479 echo '' 480 echo 'export TERM=xterm' 481 echo 'storeinfo test locale && export LANG="$(storeinfo dump locale)"' 482 echo '[ -e "/usr/share/zoneinfo/UCT" ] || export TZ=UTC-00' 483 echo '[ "$(date -Ihours)" != "2022-04-22T09+00:00" ] && export TZ=UTC-00' 484 echo '[ "$DEBIAN_FRONTEND" = noninteractive ] && unset DEBIAN_FRONTEND && export DEBIAN_FRONTEND' 485 echo '[ "$DEBIAN_FRONTEND" = newt ] && unset DEBIAN_FRONTEND && export DEBIAN_FRONTEND' 486 echo '# container environment (--env)' 487 echo "export 'container=docker'" 488 echo "export 'XAUTHORITY=/x11docker/Xauthority.client'" 489 echo "export 'DISPLAY=:119'" 490 echo "export 'HOME=/home.volume/pccastor_ayabzo_home/debian'" 491 echo "export 'USER=debian'" 492 echo '' 493 echo '[ -d "$HOME" ] && cd "$HOME"' 494 [ "$Workdir" ] && echo "[ -d \"$Workdir\" ] && cd \"$Workdir\" # WORKDIR in image" 495 echo '' 496 echo '' 497 echo 'env >> /x11docker/container.environment' 498 echo 'verbose "Container environment:' 499 echo '$(env | sort)"' 500 echo '' 501 echo 'tail -f /x11docker/stdout 2>/dev/null &' 502 echo 'tail -f /x11docker/stderr >&2 2>/dev/null &' 503 echo "exec \$Dbus sh /x11docker/cmdrc >>/x11docker/stdout 2>>/x11docker/stderr" 504 } >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/containerrc 505 ######## End of containerrc ######## 506 507 # Write containerrc into x11docker.log 508 nl -ba >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/x11docker.log < /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/containerrc 509 510 ######## Create cmdrc ######## 511 { echo '#! /bin/sh' 512 echo '# Created startscript for cmdrc containing final container command' 513 echo '' 514 echo 'storeinfo () 515 { 516 [ -e "$Storeinfofile" ] || return 1; 517 case "${1:-}" in 518 dump) 519 grep "^${2:-}=" $Storeinfofile | sed "s/^${2:-}=//" 520 ;; 521 drop) 522 sed -i "/^${2:-}=/d" $Storeinfofile 523 ;; 524 test) 525 grep -q "^${2:-}=" $Storeinfofile 526 ;; 527 *) 528 debugnote "storeinfo(): ${1:-}"; 529 grep -q "^$(echo "${1:-}" | cut -d= -f1)=" $Storeinfofile && { 530 sed -i "/^$(echo "${1:-}" | cut -d= -f1)=/d" $Storeinfofile 531 }; 532 echo "${1:-}" >> $Storeinfofile 533 ;; 534 esac 535 }' 536 echo ' 537 warning() { 538 echo "$*:WARNING" | sed "s/\$/ /" >>$Messagefile 539 } 540 note() { 541 echo "$*:NOTE" | sed "s/\$/ /" >>$Messagefile 542 } 543 verbose() { 544 echo "$*:VERBOSE" | sed "s/\$/ /" >>$Messagefile 545 } 546 debugnote() { 547 echo "$*:DEBUGNOTE" | sed "s/\$/ /" >>$Messagefile 548 } 549 error() { 550 echo "$*:ERROR" | sed "s/\$/ /" >>$Messagefile 551 exit 64 552 } 553 stdout() { 554 echo "$*:STDOUT" | sed "s/\$/ /" >>$Messagefile 555 }' 556 echo 'Messagefile=/x11docker/message.fifo' 557 echo 'Storeinfofile="/x11docker/store.info"' 558 echo '' 559 echo "debugnote \"cmdrc: Running container command: 560 $Entrypoint $Containercommand 561 \"" 562 echo '' 563 echo "$Entrypoint $Containercommand " 564 echo "storeinfo cmdexitcode=\$?" 565 echo '' 566 echo '[ -h "$Homesoftlink" ] && rm $Homesoftlink' 567 } >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/cmdrc 568 ######## End of cmdrc ######## 569 570 # Write cmdrc into x11docker.log 571 nl -ba >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/x11docker.log < /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/cmdrc 572 573 # Send signal to run X and wait for X to be ready 574 storeinfo readyforX=ready 575 waitforlogentry 'dockerrc' /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/xinit.log 'xinitrc is ready' 'xinit: giving up|unable to connect to X server|Connection refused|server error|Only console users are allowed' 576 577 rocknroll || exit 64 578 579 #### run docker image #### 580 read Containerid < <(docker run --detach --tty \ 581 --name x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 \ 582 --user 1000:1000 \ 583 --userns=host \ 584 --security-opt label=type:container_runtime_t \ 585 --volume '/usr/bin/docker-init':'/usr/local/bin/init':ro \ 586 --tmpfs /run:exec --tmpfs /run/lock \ 587 --volume '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share':'/x11docker':rw \ 588 --volume 'pccastor_ayabzo_home':'/home.volume/pccastor_ayabzo_home':rw \ 589 --volume '/tmp/.X11-unix/X119':'/X119':rw \ 590 --workdir '/tmp' \ 591 --entrypoint env \ 592 --env 'container=docker' \ 593 --env 'XAUTHORITY=/x11docker/Xauthority.client' \ 594 --env 'DISPLAY=:119' \ 595 --env 'HOME=/home.volume/pccastor_ayabzo_home/debian' \ 596 --env 'USER=debian' \ 597 -- pccastor_ayabzo_wallet:latest /usr/local/bin/init -- /bin/sh - /x11docker/containerrc 2>>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | rmcr) 598 ########################## 599 600 601 [ "$Containerid" ] || { 602 error "Startup of docker failed. Did not receive a container ID. 603 604 Last lines of container log: 605 $(rmcr < /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | tail)" 606 } 607 storeinfo containerid="$Containerid" 608 # Wait for container to be ready 609 for ((Count=1 ; Count<=40 ; Count++)); do 610 docker exec x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 sh -c : 2>&1 | rmcr >>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log && { debugnote 'dockerrc: Container is up and running.' ; break ; } || debugnote "dockerrc: Container not ready on $Count. attempt, trying again." 611 rocknroll || exit 64 612 mysleep 0.1 613 done 614 615 # Wait for pid 1 in container 616 for ((Count=1 ; Count<=40 ; Count++)); do 617 Inspect="$(docker inspect x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 2>>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | rmcr)" 618 [ "$Inspect" != "[]" ] && Pid1pid="$(parse_inspect "$Inspect" "State" "Pid")" 619 debugnote "dockerrc: $Count. check for PID 1: $Pid1pid" 620 checkpid "$Pid1pid" && break 621 rocknroll || exit 64 622 mysleep 0.1 623 done 624 [ "$Pid1pid" = "0" ] && Pid1pid="" 625 [ -z "$Pid1pid" ] && error "dockerrc(): Did not receive PID of PID1 in container. 626 Maybe the container immediately stopped for unknown reasons. 627 Just in case, check if host and image architecture are compatible: 628 Host architecture: amd64 (x86_64), image architecture: $Containerarchitecture. 629 Output of \"docker ps | grep x11docker\": 630 $(docker ps | grep x11docker) 631 632 Content of container log: 633 $(rmcr < /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | uniq )" 634 storeinfo pid1pid="$Pid1pid" 635 636 # Get IP of container 637 Containerip="$(parse_inspect "$Inspect" "NetworkSettings" "IPAddress")" 638 storeinfo containerip=$Containerip 639 640 # Check log for startup failure 641 Failure="$(rmcr < /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log | grep -v grep | grep -E 'Error response from daemon|OCI runtime exec' ||:)" 642 [ "$Failure" ] && { 643 echo "$Failure" >>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log 644 error "Got error message from docker: 645 $Failure 646 647 Last lines of logfile: 648 $(tail /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log)" 649 } 650 651 debugnote 'dockerrc(): Starting containerrootrc with docker exec' 652 # copy containerrootrc inside of container to avoid possible noexec of host home. 653 docker exec x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 sh -c 'cp /x11docker/containerrootrc /tmp/containerrootrc ; chmod 644 /tmp/containerrootrc' 2>&1 | rmcr >>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log 654 # run container root setup. containerrc will wait until setup script is ready. 655 docker exec -u root x11docker_X119_pccastor_ayabzo_wallet-latest_20768838268 /bin/sh /tmp/containerrootrc 2>&1 | rmcr >>/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log 656 657 storeinfo dockerrc=ready 658 659 [ "$Containerid" ] && { 660 # wait for signal of finish() 661 read Signal > /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log 2>&1 & 664 [ "$Dockerlogspid" ] && kill $Dockerlogspid >> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/container.log 2>&1 & 665 } 666 } & storepid $! dockerstopshell 667 exit 0 x11docker[09:46:10,756]: Generated containerrootrc: 1 #! /bin/sh 2 3 # containerrootrc 4 # This Script is executed as root in container. 5 # - Create container user 6 # - Time zone 7 # - Install NVIDIA driver if requested 8 # - Set up init system services and DBus for --init=systemd|openrc|runit|sysvinit 9 10 # redirect output to have it available before 'docker logs' starts. --init=runit (void) would eat up the output at all for unknown reasons. 11 exec 1>>/x11docker/container.log 2>&1 12 13 storeinfo () 14 { 15 [ -e "$Storeinfofile" ] || return 1; 16 case "${1:-}" in 17 dump) 18 grep "^${2:-}=" $Storeinfofile | sed "s/^${2:-}=//" 19 ;; 20 drop) 21 sed -i "/^${2:-}=/d" $Storeinfofile 22 ;; 23 test) 24 grep -q "^${2:-}=" $Storeinfofile 25 ;; 26 *) 27 debugnote "storeinfo(): ${1:-}"; 28 grep -q "^$(echo "${1:-}" | cut -d= -f1)=" $Storeinfofile && { 29 sed -i "/^$(echo "${1:-}" | cut -d= -f1)=/d" $Storeinfofile 30 }; 31 echo "${1:-}" >> $Storeinfofile 32 ;; 33 esac 34 } 35 rocknroll () 36 { 37 [ -s "$Timetosaygoodbyefile" ] && return 1; 38 [ -e "$Timetosaygoodbyefile" ] || return 1; 39 return 0 40 } 41 42 warning() { 43 echo "$*:WARNING" | sed "s/\$/ /" >>$Messagefile 44 } 45 note() { 46 echo "$*:NOTE" | sed "s/\$/ /" >>$Messagefile 47 } 48 verbose() { 49 echo "$*:VERBOSE" | sed "s/\$/ /" >>$Messagefile 50 } 51 debugnote() { 52 echo "$*:DEBUGNOTE" | sed "s/\$/ /" >>$Messagefile 53 } 54 error() { 55 echo "$*:ERROR" | sed "s/\$/ /" >>$Messagefile 56 exit 64 57 } 58 stdout() { 59 echo "$*:STDOUT" | sed "s/\$/ /" >>$Messagefile 60 } 61 Messagefile=/x11docker/message.fifo 62 Storeinfofile='/x11docker/store.info' 63 Timetosaygoodbyefile=/x11docker/timetosaygoodbye 64 65 debugnote 'Running containerrootrc: Setup as root in container' 66 67 Error='' 68 for Line in cat chmod chown cut cd cp date echo env export grep id ln ls mkdir mv printf rm sed sh sleep tail touch; do 69 command -v "$Line" || { 70 warning "ERROR: Command not found in image: $Line" 71 Error=1 72 } 73 done 74 [ "$Error" ] && error 'Commands for container setup missing in image. 75 You can try with option --no-setup to avoid this error.' 76 77 # Check type of libc 78 ldd --version 2>&1 | grep -q 'musl libc' && Containerlibc='musl' 79 ldd --version 2>&1 | grep -q -E 'GLIBC|GNU libc' && Containerlibc='glibc' 80 debugnote "containerrootrc: Container libc: $Containerlibc" 81 82 # Prepare X environment 83 # Create some system dirs with needed permissions 84 mkdir -v -p /var/lib/dbus /var/run/dbus 85 mkdir -v -p -m 1777 /tmp/.ICE-unix /tmp/.X11-unix /tmp/.font-unix 86 chmod -c 1777 /tmp/.ICE-unix /tmp/.X11-unix /tmp/.font-unix 87 export DISPLAY=:119 XAUTHORITY=/x11docker/Xauthority.client 88 89 # workaround: autostart of xrandr for some desktops like deepin, cinnamon and gnome to fix wrong autoresize 90 echo '#! /bin/sh 91 Output=$(xrandr | grep ' connected' | cut -d" " -f1) 92 Mode=1980x1200 93 xrandr --output $Output --mode $Mode\n' > /usr/local/bin/x11docker-xrandr 94 chmod +x /usr/local/bin/x11docker-xrandr 95 mkdir -p /etc/xdg/autostart 96 echo '[Desktop Entry] 97 Encoding=UTF-8 98 Version=0.9.4 99 Type=Application 100 Name=x11docker-xrandr 101 Comment= 102 Exec=/usr/local/bin/x11docker-xrandr 103 ' > /etc/xdg/autostart/x11docker-xrandr.desktop 104 105 # Time zone 106 [ ! -d /usr/share/zoneinfo ] && [ "$Containerlibc" = "glibc" ] && { 107 mkdir -p /usr/share/zoneinfo 108 cp '/x11docker/libc.localtime' '/usr/share/zoneinfo/UCT' 109 } 110 [ -e '/usr/share/zoneinfo/UCT' ] && ln -f -s '/usr/share/zoneinfo/UCT' /etc/localtime 111 112 # Container system 113 Containersystem="$(grep '^ID=' /etc/os-release 2>/dev/null | cut -d= -f2 || echo 'unknown')" 114 verbose "Container system ID: $Containersystem" 115 116 # Environment variables 117 export 'container=docker' 118 export 'XAUTHORITY=/x11docker/Xauthority.client' 119 export 'DISPLAY=:119' 120 export 'HOME=/home.volume/pccastor_ayabzo_home/debian' 121 export 'USER=debian' 122 123 # Check container user 124 Containeruser="$(storeinfo dump containeruser)" 125 Containeruser="${Containeruser:-debian}" 126 127 Containeruserhome='/home.volume/pccastor_ayabzo_home/debian' 128 # Create user entry in /etc/passwd (and delete possibly existing same uid) 129 cat /etc/passwd | grep -v ':1000:' > /tmp/passwd 130 131 # Disable possible /etc/shadow passwords for other users 132 sed -i 's%:x:%:-:%' /tmp/passwd 133 bash --version >/dev/null 2>&1 && Containerusershell=/bin/bash || Containerusershell=/bin/sh 134 Containeruserentry="debian:x:1000:1000:debian,,,:/home.volume/pccastor_ayabzo_home/debian:$Containerusershell" 135 debugnote "containerrootrc: $Containeruserentry" 136 echo "$Containeruserentry" >> /tmp/passwd 137 138 rm /etc/passwd 139 mv /tmp/passwd /etc/passwd || warning 'Unable to change /etc/passwd. That may be a security risk.' 140 141 # Create password entry for container user in /etc/shadow 142 rm -v /etc/shadow || warning 'Cannot change /etc/shadow. That may be a security risk.' 143 echo "debian:sac19FwGGTx/A:17293:0:99999:7:::" > /etc/shadow 144 echo 'root:*:17219:0:99999:7:::' >> /etc/shadow 145 chmod 640 /etc/shadow # can fail depending on available capabilities 146 147 # Create user group entry (and delete possibly existing same gid) 148 cat /etc/group | grep -v ':1000:' > /tmp/group 149 echo "debian:x:1000:" >> /tmp/group 150 mv /tmp/group /etc/group 151 152 # Create /etc/sudoers, delete /etc/sudoers.d. Overwrite possible sudo setups in image. 153 [ -e /etc/sudoers.d ] && rm -v -R /etc/sudoers.d 154 [ -e /etc/sudoers ] && rm -v /etc/sudoers 155 echo '# /etc/sudoers created by x11docker' > /etc/sudoers 156 echo 'Defaults env_reset' >> /etc/sudoers 157 echo 'root ALL=(ALL) ALL' >> /etc/sudoers 158 159 # Restrict PAM configuration of su and sudo 160 mkdir -p /etc/pam.d 161 [ -e /etc/pam.d/sudo ] && rm -v /etc/pam.d/sudo 162 case "$Containersystem" in 163 fedora) 164 echo '#%PAM-1.0' > /etc/pam.d/su 165 echo 'auth sufficient pam_rootok.so' >> /etc/pam.d/su 166 echo 'account sufficient pam_succeed_if.so uid = 0 use_uid quiet' >> /etc/pam.d/su 167 echo 'session include system-auth' >> /etc/pam.d/su 168 ;; 169 *) 170 echo '#%PAM-1.0' > /etc/pam.d/su 171 echo 'auth sufficient pam_rootok.so' >> /etc/pam.d/su # allow root to switch user without a password 172 echo '@include common-auth' >> /etc/pam.d/su 173 echo '@include common-account' >> /etc/pam.d/su 174 echo '@include common-session' >> /etc/pam.d/su 175 ;; 176 esac 177 178 # Set up container user groups 179 # Create HOME 180 [ -e "$Containeruserhome" ] || { 181 mkdir -v -p "$(dirname "$Containeruserhome")" 182 mkdir -v -m 777 "$Containeruserhome" 183 chown -v "$Containeruser":"$Containerusergroup" "$Containeruserhome" && chmod -v 755 "$Containeruserhome" # can fail depending on capabilities 184 } 185 ls -la $Containeruserhome 186 187 rocknroll || exit 64 188 189 190 # disable getty in inittab 191 [ -e /etc/inittab ] && sed -i 's/.*getty/##getty disabled by x11docker## \0/' /etc/inittab 192 193 194 rocknroll || exit 64 195 196 # --lang: Language locale 197 verbose "Searching for language locale matching fr" 198 Locales="$(locale -a)" 199 Langall="$(cat /usr/share/i18n/SUPPORTED | grep -E 'UTF-8|utf8' | cut -d' ' -f1 | cut -d. -f1 | cut -d@ -f1 | sort | uniq)" 200 Langland="$(echo fr | cut -d. -f1)" 201 Langcontainer='' 202 203 echo "$Langland" | grep -q '_' || { 204 Langland="$(echo $Langland | tr '[:upper:]' '[:lower:]')_$(echo $Langland | tr '[:lower:]' '[:upper:]')" 205 echo "$Langall" | grep -q "$Langland" || { 206 echo "$Langall" | grep -i -q "fr" && { 207 Langland="$(echo "$Langall" | grep -i -m1 "fr")" 208 } 209 } 210 } 211 212 Langland="$(echo "$Langland" | cut -d_ -f1 | tr '[:upper:]' '[:lower:]')_$(echo "$Langland" | cut -d_ -f2 | tr '[:lower:]' '[:upper:]')" 213 214 echo "$Locales" | grep -q "$Langland.UTF-8" && Langcontainer="$Langland.UTF-8" 215 echo "$Locales" | grep -q "$Langland.utf8" && Langcontainer="$Langland.utf8" 216 217 [ -z "$Langcontainer" ] && { 218 [ -e /usr/share/i18n/SUPPORTED ] || note "Option --lang: /usr/share/i18n/SUPPORTED not found. 219 Please install package 'locales' in image (belongs to glibc). 220 Look here to find a package for your image system: 221 https://github.com/mviereck/x11docker/wiki/dependencies#dependencies-in-image" 222 223 Langcontainer="$Langland.utf8" 224 note "Option --lang: Generating language locale $Langcontainer". 225 226 command -v localedef >/dev/null || note 'Option --lang: Command localedef not found in image. 227 Need it for language locale creation. 228 Look here to find a package for your image system: 229 https://github.com/mviereck/x11docker/wiki/dependencies#dependencies-in-image' 230 localedef --verbose --force -i "$Langland" -f UTF-8 $Langcontainer || verbose "localedef exit code: $?" 231 232 locale -a | grep -q "$Langcontainer" || { 233 note "Option --lang: Generation of locale $Langcontainer failed." 234 Langcontainer='' 235 } 236 } || { 237 debugnote "Option --lang: Found locale in image: $Langcontainer" 238 } 239 240 [ "$Langcontainer" ] && { 241 storeinfo locale="$Langcontainer" 242 echo "LANG=$Langcontainer" > /etc/default/locale 243 } || note 'Option --lang: Desired locale for 'fr' not found and not generated.' 244 245 debugnote "Option --lang: Output of locale -a: 246 $(locale -a)" 247 248 rocknroll || exit 64 249 250 storeinfo containerrootrc=ready 251 x11docker[09:46:10,772]: Generated xinitrc: 1 #! /bin/sh 2 disable_xhost () 3 { 4 local Line=; 5 command -v xhost > /dev/null || { 6 warning "Command 'xhost' not found. 7 Can not check for possibly allowed network access to X. 8 Please install 'xhost'."; 9 return 1 10 }; 11 xhost 2>&1 | tail -n +2 /dev/stdin | while read -r Line; do 12 debugnote "xhost: Removing entry $Line"; 13 xhost -$Line; 14 done; 15 xhost -; 16 [ "$(xhost 2>&1 | wc -l)" -gt "1" ] && { 17 warning "Remaining xhost permissions found on display ${DISPLAY:-} 18 $(xhost 2>&1 )"; 19 return 1 20 }; 21 xhost 2>&1 | grep "access control disabled" && { 22 warning "Failed to restrict xhost permissions. 23 Access to display ${DISPLAY:-} is allowed for everyone."; 24 return 1 25 }; 26 return 0 27 } 28 pspid () 29 { 30 LC_ALL=C ps -p "${1:-}" 2> /dev/null | grep -v 'TIME' 31 } 32 rocknroll () 33 { 34 [ -s "$Timetosaygoodbyefile" ] && return 1; 35 [ -e "$Timetosaygoodbyefile" ] || return 1; 36 return 0 37 } 38 storeinfo () 39 { 40 [ -e "$Storeinfofile" ] || return 1; 41 case "${1:-}" in 42 dump) 43 grep "^${2:-}=" $Storeinfofile | sed "s/^${2:-}=//" 44 ;; 45 drop) 46 sed -i "/^${2:-}=/d" $Storeinfofile 47 ;; 48 test) 49 grep -q "^${2:-}=" $Storeinfofile 50 ;; 51 *) 52 debugnote "storeinfo(): ${1:-}"; 53 grep -q "^$(echo "${1:-}" | cut -d= -f1)=" $Storeinfofile && { 54 sed -i "/^$(echo "${1:-}" | cut -d= -f1)=/d" $Storeinfofile 55 }; 56 echo "${1:-}" >> $Storeinfofile 57 ;; 58 esac 59 } 60 storepid () 61 { 62 case "${1:-}" in 63 dump) 64 grep -w "${2:-}" "$Storepidfile" | cut -d' ' -f1 65 ;; 66 test) 67 grep -q -w "${2:-}" "$Storepidfile" 68 ;; 69 *) 70 echo "${1:-NOPID}" "${2:-NONAME}" >> "$Storepidfile"; 71 debugnote "storepid(): Stored pid '${1:-}' of '${2:-}': $(pspid ${1:-} ||:)" 72 ;; 73 esac 74 } 75 76 warning() { 77 echo "$*:WARNING" | sed "s/\$/ /" >>$Messagefile 78 } 79 note() { 80 echo "$*:NOTE" | sed "s/\$/ /" >>$Messagefile 81 } 82 verbose() { 83 echo "$*:VERBOSE" | sed "s/\$/ /" >>$Messagefile 84 } 85 debugnote() { 86 echo "$*:DEBUGNOTE" | sed "s/\$/ /" >>$Messagefile 87 } 88 error() { 89 echo "$*:ERROR" | sed "s/\$/ /" >>$Messagefile 90 exit 64 91 } 92 stdout() { 93 echo "$*:STDOUT" | sed "s/\$/ /" >>$Messagefile 94 } 95 getscreensize() { 96 CurrentXaxis="$(xrandr | grep primary | cut -d' ' -f4 | cut -dx -f1 )" 97 CurrentYaxis="$(xrandr | grep primary | cut -d' ' -f4 | cut -dx -f2 | cut -d+ -f1)" 98 } 99 checkscreensize() { 100 getscreensize 101 [ "$Xaxis" = "$CurrentXaxis" ] || return 1 102 [ "$Yaxis" = "$CurrentYaxis" ] || return 1 103 return 0 104 } 105 getprimary() { 106 xrandr | grep -q primary || xrandr --output $(xrandr | grep ' connected' | head -n1 | cut -d' ' -f1) --primary 107 echo $(xrandr | grep primary | cut -d' ' -f1) 108 } 109 110 Messagefile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/message.fifo' 111 Output="$(getprimary)" 112 Storeinfofile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/store.info' 113 Storepidfile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/store.pids' 114 Timetosaygoodbyefile='/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/timetosaygoodbye' 115 116 export PATH='/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/local/games:/usr/games' 117 118 Cookie='' 119 Line='' 120 Var='' 121 122 debugnote 'Running xinitrc' 123 124 export DISPLAY=:119 XAUTHORITY=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client XSOCKET=/tmp/.X11-unix/X119 XDG_RUNTIME_DIR=/run/user/1000 125 # background color 126 xsetroot -solid '#7F7F7F' 2>/dev/null 127 128 # create new XAUTHORITY cookies 129 :> /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client 130 131 echo 'Requesting trusted cookie from X server' 132 xauth -v -i -f /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client generate :119 . trusted timeout 3600 133 134 [ -s '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client' ] || { 135 [ 'trusted' = 'untrusted' ] && note 'Could not create untrusted cookie. 136 Maybe your X server misses extension SECURITY.' 137 } 138 [ -s '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client' ] || { 139 # still no cookie? try to create one without extension security 140 debugnote 'xinitrc: Failed to retrieve trusted cookie from X server. Will bake one myself.' 141 echo 'Failed to retrieve trusted cookie from X server. Will bake one myself.' 142 xauth -v -i -f /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client add :119 . d3e6a98ea5c03e18291acbbc49ed1d29 143 ls -l /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client 144 } 145 146 # Prepare cookie with localhost identification disabled by ffff, needed if X socket is shared. ffff means 'familiy wild' 147 Cookie="$(xauth -i -f /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client nlist | sed -e 's/^..../ffff/')" 148 echo "$Cookie" | xauth -v -i -f /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client nmerge - 149 150 debugnote "xinitrc: Created cookie: $(xauth -f /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client list 2>&1)" 151 ls -l /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client 152 cp /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/Xauthority.server 153 chmod 644 /home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client 154 155 [ -s '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client' ] || warning 'Cookie creation failed!' 156 export XAUTHORITY=/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client 157 [ 'yes' = 'no' ] || [ ! -s '/home/debian/.cache/x11docker/pccastor_ayabzo_wallet-latest-20768838268/share/Xauthority.client' ] && unset XAUTHORITY && warning '--xvfb: X server :119 runs without cookie authentication.' 158 159 # clean xhost 160 verbose 'Disabling any possible access to new X server possibly granted by xhost' 161 disable_xhost 162 163 # Keyboard layout 164 165 # create set of different screen resolutions 166 xrandr --newmode "1984x1200" 199.25 1984 2120 2328 2672 1200 1203 1213 1245 -hsync +vsync 167 xrandr --addmode $Output "1984x1200" 168 while read Line; do 169 Line="$(echo "$Line" | sed 's/Modeline//g')" 170 Line="$(echo "$Line" | sed 's/"//g')" 171 xrandr --newmode $Line 2>/dev/null 172 xrandr --addmode "$Output" $(echo $Line | cut -d' ' -f1) 2>/dev/null 173 done < "/home/debian/.cache/x11docker/modelines.1980x1200" 174 175 176 verbose "Output of xrandr on :119 177 $(xrandr)" 178 179 echo 'xinitrc: xinitrc is ready' 180 storeinfo xinitrc=ready 181 182 # wait for the end 183 read Var