summaryrefslogtreecommitdiff
path: root/demos/xdg-app-run.sh
blob: e8f548a169fb9f3de973afd494d42ebabc554baf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#!/bin/sh
# For this to work you first have to run these commands:
#  curl -O http://sdk.gnome.org/nightly/keys/nightly.gpg
#  xdg-app --user remote-add --gpg-key=nightly.gpg gnome-nightly http://sdk.gnome.org/nightly/repo/
#  xdg-app --user install gnome-nightly org.gnome.Platform
#  xdg-app --user install gnome-nightly org.gnome.Weather

mkdir -p ~/.var/app/org.gnome.Weather/cache ~/.var/app/org.gnome.Weather/config ~/.var/app/org.gnome.Weather/data

APPINFO=`mktemp`
cat > ${APPINFO} <<EOF
[Application]
name=org.gnome.Weather
runtime=runtime/org.gnome.Platform/x86_64/master
EOF

PASSWD=`mktemp`
getent passwd `id -u` 65534 > ${PASSWD}

GROUP=`mktemp`
getent group `id -g` 65534 > ${GROUP}

(
    # Remove all temporary files before calling bwrap, they are open in the fds anyway
    rm $APPINFO
    rm $GROUP
    rm $PASSWD
    bwrap \
    --mount-ro-bind ~/.local/share/xdg-app/runtime/org.gnome.Platform/x86_64/master/active/files /usr \
    --lock-file /usr/.ref \
    --mount-ro-bind ~/.local/share/xdg-app/app/org.gnome.Weather/x86_64/master/active/files/ /app \
    --lock-file /app/.ref \
    --mount-dev /dev \
    --mount-proc /proc \
    --make-dir /tmp \
    --make-symlink /tmp /var/tmp \
    --make-symlink /run /var/run \
    --make-symlink usr/lib /lib \
    --make-symlink usr/lib64 /lib64 \
    --make-symlink usr/bin /bin \
    --make-symlink usr/sbin /sbin \
    --make-symlink usr/etc /etc \
    --make-dir /run/user/`id -u` \
    --make-bind-file 11 /usr/etc/passwd \
    --make-bind-file 12 /usr/etc/group \
    --mount-ro-bind /etc/machine-id /usr/etc/machine-id \
    --mount-ro-bind /etc/resolv.conf /run/host/monitor/resolv.conf \
    --make-file 10 /run/user/`id -u`/xdg-app-info \
    --mount-ro-bind /sys/block /sys/block \
    --mount-ro-bind /sys/bus /sys/bus \
    --mount-ro-bind /sys/class /sys/class \
    --mount-ro-bind /sys/dev /sys/dev \
    --mount-ro-bind /sys/devices /sys/devices \
    --mount-dev-bind /dev/dri /dev/dri \
    --mount-bind /tmp/.X11-unix/X0 /tmp/.X11-unix/X99 \
    --mount-bind ~/.var/app/org.gnome.Weather ~/.var/app/org.gnome.Weather \
    --mount-bind ~/.config/dconf ~/.config/dconf \
    --mount-bind /run/user/`id -u`/dconf /run/user/`id -u`/dconf  \
    --unshare-pid \
    --setenv XDG_RUNTIME_DIR "/run/user/`id -u`" \
    --setenv DISPLAY :99 \
    --setenv GI_TYPELIB_PATH /app/lib/girepository-1.0 \
    --setenv GST_PLUGIN_PATH /app/lib/gstreamer-1.0 \
    --setenv LD_LIBRARY_PATH /app/lib:/usr/lib/GL \
    --setenv DCONF_USER_CONFIG_DIR .config/dconf \
    --setenv PATH /app/bin:/usr/bin \
    --setenv XDG_CONFIG_DIRS /app/etc/xdg:/etc/xdg \
    --setenv XDG_DATA_DIRS /app/share:/usr/share \
    --setenv SHELL /bin/sh \
    --setenv XDG_CACHE_HOME ~/.var/app/org.gnome.Weather/cache \
    --setenv XDG_CONFIG_HOME ~/.var/app/org.gnome.Weather/config \
    --setenv XDG_DATA_HOME ~/.var/app/org.gnome.Weather/data \
    gnome-weather) 10< ${APPINFO} 11< ${PASSWD} 12< ${GROUP}


# TODO:
# clean commandlines (pass args via file/fd?)
# seccomp