Skip to content

Docker compose discussion #451

@pablomendezroyo

Description

@pablomendezroyo

The docker-compose volumes, networks and service keys/volumes/networks are critical in dappnode since all dappnode packages are distributed through docker-compose.yml files.

service keys
The compose keys may be critical and allow a container to gain privileges on the host and perform almost any type of attack.

In dappnode there is a compose keys "whitelist" to restrict the use of these keys. However this list has been growing due to necessities and it must be reviewed in deep.

To discuss:

networks
There are currently two docker networks for simplicity in dappnode: dncore_network (for all containers) and dnpublic_network (for HTTPS portal mappings). The current setup is that no one owns any docker network, both of them are declared as external. The dncore_network is created on dappnode installation with docker network create. The dnpublic_network is created by the dappmanager when installing the HTTPS package.

To discuss:

  • As Fredik security report, having all containers in the same docker network is a security vulnerability since containers can communicate with each other without restrictions, which is not ideal. Implementing a docker network system to have a dedicated docker network for each group of containers looks complicated. What other solutions do we have?
  • Should the dnpublic_network be owned by the HTTPS package? see reasoning Define dnpublic_network in the docker-compose.yml DNP_HTTPS#66

volumes
There are two types of docker volumes used in dappnode: named and bind-mounted volumes. Bind mounted volumes are dangerous and should be only used in a reasoned case of necessity (especially the docker socket volume)

To discuss:

  • Restrict bind mounted volumes to exporter, wifi, wireguard, vpn core and dappmanager:
    • dappmanager:
      • /run/dbus/system_bus_socket used by avahi and upnp
      • /usr/src/dappnode/DNCORE/ used to have on host the core compose files, and hostScripts
      • /var/run/docker.sock to allow dappmanager to perform docker actions
      • /etc/hostname to render the hostname in the UI. Would be a better solution to run a script to get the hostname on startup instead of bind-mounting the volume? tropicar
    • exporter: as Fredik security report, the exporter is mounting the whole host file system. There should be a way to make the exporter work without this mount.
    • wifi
      • /var/run/docker.sock used to execute container with host network privileges
    • vpn:
      • /var/run/docker.sock ?
      • /etc/hostname ?
      • /usr/src/dappnode/config ?
      • /lib/modules ?
    • wireguard
      • /lib/modules ? 3alpha
    • core:
      • /etc/ to get access to /etc/os-release and /etc/motd files from host. Consider only mounting those files instead of the entire /etc folder
      • /usr/src/dappnode/ to modify scripts and profile
      • /var/run/docker.sock to startup dappmanager container

┆Issue is synchronized with this Basecamp todo by Unito

Metadata

Metadata

Labels

DiscussionOpen to discussion from different team membersresearchIssues that can't be developed immediately and require research

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions