Skip to content

Helper scripts for using podman for running less trusted desktop software in containers

Notifications You must be signed in to change notification settings

httk/desktop-containers

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Compose-Desktop-Containers (CDC)

Note: for anyone finding this: this software is currently in an early work-in-progress state. Once the design reaches a bit more maturity, we will track proper releases.

Scripts and tools for running containerized desktop applications using the industry standard podman (originally docker) compose files on yaml format. The usual benefits of containerized applications apply, where podman non-root containers provide a security layer to reduce the risks of running less trusted software. The tools help install applications with symlinks to run them, .desktop files, etc., and sets up xdg-dbus-proxy, compose lists of video devices, etc., when launching them.

Overview

Applications are defined using a single yaml file on compose.yaml format with a few format-compatible extensions. In particular:

  • A top-level x-application key defines a README.md, and default contents for an override.yaml and a .env to help create configurable containers.
  • The x-application section allows definition of an app-global .desktop file, icons, and dependencies on packages that are needed in the container image.
  • Under specific services one can define an x-launcher key to mark them as launchable as application entry points, with their own .desktop files, icons, etc.
  • The x-launcher key may furthermore list services, e.g., video that are set up when launching to give access to the video devices on the host system, etc.
  • Standardized service names: download, install, update-check, and update are used to allow the tools to manage the application.
  • Application definitions (the yaml files) are distributed separately from the actual content; they define how to download content via the download service (which is run inside the container) and then install it.

When an application is installed from a definition yaml file, a directory is created for the application containing compose.yaml, override.yaml, .env, symlinks for the launchable application entry points, and a home directory to isolate filesystem access for the application when run.

Installed applications are made available in the host desktop system (via .desktop files in ~/.local/share/applications), but can also be started from the command line via a launch symlink in the application direcotry, e.g. ./blender.

Design: benefits and drawbacks

The usual design model of containerized applications in, e.g., flatpack, snap, etc., is that applications are delivered as separate self-contained containers that can be installed and run independently. In CDC, the model is rather that there is a single "parallel" container system (i.e., ideally one image) that lives inside your host system. This parallel system can be independently upgraded, be extended with new dependency libraries, etc. We then run a range of installed applications inside this parallel containerized system. This shift in design model has both benefits and drawbacks.

Benefits:

  • Allows keeping the container system software up to date independently from application software updates, so that, e.g., apps don't rely on outdated, possibly vulnerable, version of security-sensitive system software (e.g., libssl, gnutls).

  • Existing application definition files will (try to) install new versions directly as they get released, instead of waiting for a new release of an updated container.

  • Arguably, the model allows better scaling of storage use to many installed applications since they are meant to share a single image (or in the worst case, a few).

Drawbacks:

  • Future changes of applications may unexpectedly break the update process (which shouldn't happen in other container formats where updates are done via tested new definition files).

  • All apps must be made to run on the image(s) provided. Right now, the standard is: Ubuntu LTS 24.04; going forward the idea will likely be to handle images for all maintained LTS releases.

  • Apps will be able to access to system software (e.g., libraries) installed in the image for use by other apps, which arguably reduces the security barrier somewhat. (On the other hand, malicious software could just embedd (or download) the same functionality.)

  • Changes (e.g., updates) to the master container image may affect all containerized software (e.g., in the worst case, a library update could break previous working software; this should, however, be rare).

Design notes

The top level directory contains the subdirectories:

  • images: used to build the system podman image used for the containers.
  • apps: a hierarchy of subdirectories for yaml files defining a number of applications.
  • tools: scripts used to install, configure, and launch applications.

The apps contains one subdirectory for each catogory in the XDG desktop specification meant to be the primary categorization of the app, below which there are app.yaml files for the provided applications.

Quickstart: build the system image

Clone the repository and initialize submodule dependecies; a suggested location is ~/Containers:

git clone --recurse-submodules 'https://github.com/httk/compose-desktop-containers.git' ~/Containers 

Install dependencies (replace <your host system> with the name of the OS you are installing the containers on):

cd dependencies/installers
ls
cd <your host system>
./install.sh
cd ../../..

Build the image:

cd images/image-u24
./build-gamescope.sh
./build-proton.sh
./build.sh
cd ../..

This first builds some dependencies, which is helper software we need for the image, and then builds the desktop-container-default image.

Install and run an app

cd ~/Containers
../tools/cdc-install apps/Networking/discord.yaml discord

Now try to start discord from your system launcher, or run ./discord in the application directory.

Exchanging files between the container, host system, and other containers

All application directories have a subdirectory home which is mounted inside containers at the location of /home/<username>/. This stores the internal installation and state of the application.

You can use the host system file browser or command line to copy/move files between locations inside these container-specific home directories and the host system.

To give the container access to other places in the host system, edit the override.yaml file. For example, to give blender access to ~/Documents/blender in the host system, edit it to contain:

version: "3.8"

services:
  blender:
    volumes: 
      - "${CDC_APP_DIR}/home:/home/${USER}:rw"
      - "/home/${USER}/Documents/blender:/home/${USER}/Documents/blender:rw"

Update an app

cd <app directory>
~/Containers/tools/cdc-update

Now try to start discord from your system launcher.

Update the application definition files to the latest ones in this repository

cd ~/Containers
git pull

(Installed compose.yaml files are symbolic links to the ones under apps, so they get updated automatically. If you do not want this feature, you can remove the symbolic link and copy the file istead.)

Troubleshooting

All the application state information resides in the application subdirectories. Hence, if you seem to have trouble with podman in general, you can always purge and re-create the system image. The deepest reset you can do is to run podman system reset, which completely purges all internal podman configuration (including any other podman images you may have, outside of CDC...) After that, you can re-do the "Build the image" step above.

You can also try to reinstall the application:

cd <app directory>
~/Containers/tools/reinstall

A reinstall keeps your home subdirectory intact. However, sometimes it can help to remove also this subdirectory (IMPORTANT: make sure to move out any files you want to keep from there first), and then reinstall. This will ensure that all hidden home directory files are recreated from scratch.

Uninstalling applications

Before removing an application you likely want to look into the application home subdirectory and copy any files you want to preserve.

After that, the installed application and its state can be purged by simply removing the directory where the application was installed.

There is currently no script for removing the .desktop files and icons from the host system, but they are unlikely to cause any issues if just left. If you anyway want to make sure to clean out an installation as much as possible, check out the following directories in your home directory on the host system:

  • ~/.local/share/applications: remove the relevant <application>_cdc.desktop files.
  • ~/.local/share/<application name>_cdc: this directory is in rare occasions created to store application icons that have to be in the same location on the host system and inside the container. (I'd consider that a bug, but sometimes seems unavoidable.)
  • ~/.local/share/icons/hicolor: in the subdirectories below here, application icons are installed. Icons are installed using the normal name of the application (e.g., blender.png) to allow for themeing to work as expected. (But it is also difficult to imagine that leaving application icons here would cause any trouble.)

About

Helper scripts for using podman for running less trusted desktop software in containers

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published