Forge Home


Module for installing and managing Flatpak packages


1,691 latest version

Version information

  • 0.2.6 (latest)
  • 0.2.5
  • 0.2.4
  • 0.2.3
  • 0.2.2
  • 0.2.1
  • 0.2.0
  • 0.1.1
  • 0.1.0
released Oct 17th 2020
This version is compatible with:
  • Puppet Enterprise 2018.1.x, 2017.3.x, 2017.2.x, 2017.1.x, 2016.5.x, 2016.4.x
  • Puppet >= 4.7.0 < 6.0.0
  • , ,

Start using this module

  • r10k or Code Manager
  • Bolt
  • Manual installation
  • Direct download

Add this module to your Puppetfile:

mod 'brwyatt-flatpak', '0.2.6'
Learn more about managing modules with a Puppetfile

Add this module to your Bolt project:

bolt module add brwyatt-flatpak
Learn more about using this module with an existing project

Manually install this module globally with Puppet module tool:

puppet module install brwyatt-flatpak --version 0.2.6

Direct download is not typically how you would use a Puppet module to manage your infrastructure, but you may want to download the module in order to inspect the code.



brwyatt/flatpak — version 0.2.6 Oct 17th 2020


Build Status

GitHub license GitHub issues GitHub forks GitHub stars

Puppet Forge Puppet Forge - downloads Puppet Forge - scores

Table of Contents

  1. Description
  2. Setup - The basics of getting started with flatpak
  3. Usage - Configuration options and additional functionality
  4. Reference - An under-the-hood peek at what the module is doing and how
  5. Limitations - OS compatibility, etc.
  6. Development - Guide for contributing to the module
  7. Contributors - List of those who've helped to make the module better


This module (optionally) installs Flatpak from the developer's PPA on Launchpad and offers two defined types, one for adding/removing Remotes and another for installing/removing Flatpak applications.

This module was created to allow for managing/installing Flatpak-based application distributions, as some developers have started to move away from more traditional system packages such as apt/deb and rpm/yum, instead leveraging Flatpak's ability to be one-size-fits all.


What flatpak affects

This module (optionally) adds the Flatpak PPA on Launchpad to the system's repository (if manage_repo is true - default for Debian family) and installs Flatpak.

Setup Requirements

Currently, this module only supports Ubuntu and RedHat, but may work with other Debian- based or RedHat-based distributions.

This module requires the puppetlabs-apt module in order to manage Apt repos (if manage_repo is true).

Beginning with flatpak

To install this module, call:

puppet module install brwyatt-flatpak


To install Flatpak for use in your Puppet manifests, simply include it into your manifests.

include ::flatpak




Installs the Flatpak PPA and installs Flatpak


  • package_ensure: Ensure value for the Flatpak package. Default: 'installed'
  • repo_file_name: Optional name for the repo source file. Defaults to the PPA naming scheme to avoid duplicate repository files.


Adds the Gnome SDK remote to Flatpak. Includes the flatpak class to ensure Flatpak is installed first.

This class has no parameters.

Defined Types


This type installs (or uninstalls) Flatpak apps.


  • ensure: If the package should be present (or installed) or absent (or uninstalled)
  • arch: The package architecture to be installed. Cannot be used if ref is defined.
  • branch: The package branch to be installed. Cannot be used if ref is defined.
  • name: (namevar) The name of the package to be installed (or removed)
  • ref: The package ref to install. This can be any valid pakcage ref, from simply the package name up to a full Identifier Triple ("name/arch/branch"). Cannot be used if branch or arch are defined.
  • remote: The name of the remote repo to install the package from. Required if ensure is "installed" or "present".

If defined, this type will install the package identified in the ref parameter. Otherwise, it will attempt to generate an Identifier Triple from the values of name/arch/branch. If no parameters are explicitly defined, this will result in attempting to install the package with the resource's name and the remote's default architecture and branch.


This type adds and removes Flatpak remotes.


  • ensure: If the remote should be present or absent
  • name: (namevar) The name of the remote
  • location: The location for the remote
  • from: if true, it specifies that location is a repo config file.



Implements the flatpak type. Default provider.


Implements the flatpak_remote type. Default provider.


Currently, this module can only install on Debian-based systems and has not been tested on distributions other than Ubuntu 16.04. It may or may not work on other Debian-based distributions, but makes no claims regarding such. This will not currently work at all on RHEL-based systems.


Feel free to file issues in the GitHub issue tracker for the repository, or submit Pull Requests.

I may not have much time to work on (or test) this myself, so help to expand current functionality (especially to make it work for more people) is greatly appreciated and encouraged.


The list of contributors can be found at: