smcv@{collabora.com,debian.org}
A sandboxed app framework for Linux (formerly xdg-app)
/usr/share/applications
~/.gnupg
Fig.1. A stable flat-pack-based platform
ISVs can't target “generic Linux” like they can target Windows, or OS X, or iOS, or Android
-rpath
or LD_LIBRARY_PATH
)-backports
works, to a point, but…
/usr
(with the /usr
merge)
/usr
Reference runtimes: org.freedesktop.Platform
, org.gnome.Platform
KDE and Fedora also produce runtimes
/usr
, with developer tools
com.example.Sdk
conventionally goes with com.example.Platform
Each runtime has branches
org.gnome.gedit//stable
depends on org.gnome.Platform//3.24
org.gnome.Platform//3.24
org.fedoraproject.Platform//26
net.debian.flatpak.Games.Platform//stretch
/app
Canonically, you recompile with --prefix=/app
Do the same for bundled libraries
/app
in binaries is completely fine/home/jsmith/local
or similar/app
is the same length as /usr
libostree
: like git, but for /usr
./config
./refs/heads/master
./refs/heads/stable
./refs/remotes/origin/master
./objects/3b/6f018809252480b740a48ea3cb746a434dd688
./objects/c0/837b81795498042a3570b792cb2f41da0a0551
libostree
: like git, but for /usr
./config
./refs/heads/app/org.debian.packages.openarena/x86_64/master
./refs/remotes/flatdeb/runtime/net.debian.flatpak.Games.Platform/x86_64/stretch
./objects/a1/443a265b155be7d190c5a0a5e99427716a0a1432f6994fbde40aafb23fb11e.file
./objects/e9/67eda76106efa124b736af20c14b3fea2a254b71927534bd869217e105c532.file
${runtime}/files
on /usr
/usr
merge here${app}/files
on /app
Fig.2. Protecting an important subject with bubble wrap
bwrap
)xdg-app-helper
linux-user-chroot
PR_SET_NO_NEW_PRIVS
first~/Downloads
”Example
[Context]
shared=network;ipc;
sockets=x11;wayland;pulseaudio;
devices=dri;
Fig.3. Portals have safety implications if used carelessly
[yes]
[no]
[yes]
[no]
Looks like a normal dialog box
Implicitly gets permission
Selected file magically appears in a FUSE filesystem in the sandbox
dbus-daemon
to do this itselforg.freedesktop.portal.*
xdg-desktop-portal
xdg-desktop-portal
talks to a per-desktop implementation
Fig.4. IKEA would put the entire world in their warehouse if they could
… and that's OK
Every package has a maintainer who is often an expert in the field of the package
— Raphaël Hertzog, State of the Debian-Ubuntu relationship
At our best, we're domain experts on leaf packages (apps)
Debian is a ready-made source of things that ought to be ready to be high-quality Flatpak apps
We fix their bugs even if upstreams don't
Distributions are good at providing libraries
Debian takes libraries very seriously
Debian takes stability very seriously
Debian takes security very seriously
These are just what you want in a runtime
gnome-mines
?
xonotic
?
Apps with good upstream maintenance can come from upstream
Apps where we are genuinely helping can come from Debian
We get some of the advantages either way
Fig.5. A flat-pack stack ready for compilation
A prototype of building Flatpak runtimes with apt
/dpkg
Also a prototype of building Flatpak apps with apt
/dpkg
Fig.6. Flat-pack technology is not suitable for all use cases
apt
System-wide, root-privileged, non-atomic
No sandboxing unless you specifically add it
Good for: system services, the platform layer of desktop environments
Bad for: third-party software
libostree
-based deploymentSame packages as apt
, but different trade-offs
Good for: appliance-style systems with known functionality
Bad for: third-party software
Docker, systemd-nspawn and friends
Good for: development and debugging
Bad for: stopping container-root becoming real root
Bad for: desktop integration
An entire other OS, including the kernel
Good for: servers, “appliances”
Good for: code you want to keep at arm's length
Bad for: maximal efficiency
Bad for: desktop integration
Application code needs to be relocatable
Sandboxed (sometimes)
Good for: Ubuntu kernels
Bad for: mainstream kernels
App is a wrapped filesystem image that can be made executable and run
Dependencies must be either bundled or assumed
Good for: Windows- and Mac-like UX - just download and run
Bad for: getting updates
Bad for: avoiding the moving target problem
Bad for: deduplication
Setuid program to set up sandboxes, like bubblewrap
Uses the same technologies as bubblewrap
Good for: AppImage integration
Good for: users who are already root-equivalent anyway
Bad for: users who should not become root-equivalent
Slides, source code and flatdeb: https://flatpak.debian.net/
All content except images © 2017 Collabora Ltd. CC-BY-4.0
Image credits: