The snapd-control interface

The snapd-control interface enables snap management, such as snap installation, removal and refresh-control by communicating with the snapd daemon.

Due to its ability to permit the installation any snap at potentially any confinement level, snapd-control is primarily intended to be used by brand store owners as they will typically already have full access to their devices.

Consequently, consumers of this interface require approval for distribution via the Snap Store, and this approval is only likely to be given under strict and specific circumstances.

Interface documentation:

See Interface management and Supported interfaces for further details on how interfaces are used.


Developer details

Auto-connect: no
Super-privileged: yes

Attributes :

  • refresh-schedule (plug): can be set to managed to signal an intention to permit only manual refreshes for the snap:

    plugs:
        snapd:
            interface: snapd-control
            refresh-schedule: managed
    

    Permitting only manual refreshes is a 3 stage process with the above being the first stage. The second stage is to connect the interface, effectively granting permission for refresh management while the third is to set the following core system setting:

    sudo snap set system refresh.timer=managed 
    

    The last step activates the manual-only refresh option, skipping upcoming refresh attempts. These values are rechecked and reconfirmed before every future refresh attempt. If any of the steps stop being true, the snap refresh proceeds.

Code examples

The source code can be found in the snapd repository: snapd/interfaces/builtin/snapd_control.go at master · canonical/snapd · GitHub

The test code for the interface is in the snapd repository: snapd/interfaces/builtin/snapd_control_test.go at master · canonical/snapd · GitHub


Last updated 3 months ago.