Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
fcwu
GitHub Repository: fcwu/docker-ubuntu-vnc-desktop
Path: blob/develop/rootfs/startup.sh
387 views
1
#!/bin/bash
2
3
if [ -n "$VNC_PASSWORD" ]; then
4
echo -n "$VNC_PASSWORD" > /.password1
5
x11vnc -storepasswd $(cat /.password1) /.password2
6
chmod 400 /.password*
7
sed -i 's/^command=x11vnc.*/& -rfbauth \/.password2/' /etc/supervisor/conf.d/supervisord.conf
8
export VNC_PASSWORD=
9
fi
10
11
if [ -n "$X11VNC_ARGS" ]; then
12
sed -i "s/^command=x11vnc.*/& ${X11VNC_ARGS}/" /etc/supervisor/conf.d/supervisord.conf
13
fi
14
15
if [ -n "$OPENBOX_ARGS" ]; then
16
sed -i "s#^command=/usr/bin/openbox\$#& ${OPENBOX_ARGS}#" /etc/supervisor/conf.d/supervisord.conf
17
fi
18
19
if [ -n "$RESOLUTION" ]; then
20
sed -i "s/1024x768/$RESOLUTION/" /usr/local/bin/xvfb.sh
21
fi
22
23
USER=${USER:-root}
24
HOME=/root
25
if [ "$USER" != "root" ]; then
26
echo "* enable custom user: $USER"
27
useradd --create-home --shell /bin/bash --user-group --groups adm,sudo $USER
28
if [ -z "$PASSWORD" ]; then
29
echo " set default password to \"ubuntu\""
30
PASSWORD=ubuntu
31
fi
32
HOME=/home/$USER
33
echo "$USER:$PASSWORD" | chpasswd
34
cp -r /root/{.config,.gtkrc-2.0,.asoundrc} ${HOME}
35
chown -R $USER:$USER ${HOME}
36
[ -d "/dev/snd" ] && chgrp -R adm /dev/snd
37
fi
38
sed -i -e "s|%USER%|$USER|" -e "s|%HOME%|$HOME|" /etc/supervisor/conf.d/supervisord.conf
39
40
# home folder
41
if [ ! -x "$HOME/.config/pcmanfm/LXDE/" ]; then
42
mkdir -p $HOME/.config/pcmanfm/LXDE/
43
ln -sf /usr/local/share/doro-lxde-wallpapers/desktop-items-0.conf $HOME/.config/pcmanfm/LXDE/
44
chown -R $USER:$USER $HOME
45
fi
46
47
# nginx workers
48
sed -i 's|worker_processes .*|worker_processes 1;|' /etc/nginx/nginx.conf
49
50
# nginx ssl
51
if [ -n "$SSL_PORT" ] && [ -e "/etc/nginx/ssl/nginx.key" ]; then
52
echo "* enable SSL"
53
sed -i 's|#_SSL_PORT_#\(.*\)443\(.*\)|\1'$SSL_PORT'\2|' /etc/nginx/sites-enabled/default
54
sed -i 's|#_SSL_PORT_#||' /etc/nginx/sites-enabled/default
55
fi
56
57
# nginx http base authentication
58
if [ -n "$HTTP_PASSWORD" ]; then
59
echo "* enable HTTP base authentication"
60
htpasswd -bc /etc/nginx/.htpasswd $USER $HTTP_PASSWORD
61
sed -i 's|#_HTTP_PASSWORD_#||' /etc/nginx/sites-enabled/default
62
fi
63
64
# dynamic prefix path renaming
65
if [ -n "$RELATIVE_URL_ROOT" ]; then
66
echo "* enable RELATIVE_URL_ROOT: $RELATIVE_URL_ROOT"
67
sed -i 's|#_RELATIVE_URL_ROOT_||' /etc/nginx/sites-enabled/default
68
sed -i 's|_RELATIVE_URL_ROOT_|'$RELATIVE_URL_ROOT'|' /etc/nginx/sites-enabled/default
69
fi
70
71
# clearup
72
PASSWORD=
73
HTTP_PASSWORD=
74
75
exec /bin/tini -- supervisord -n -c /etc/supervisor/supervisord.conf
76
77