Every application needs a unique application ID, based on a reversed domain name. For example
All resources exported by the application must be prefixed by this identifier. This includes the
desktop file, the appdata file for the
application, and any icons referenced by the desktop file.
The appdata file for a Flatpak is used for displaying information about the application prior to installation. See Fedora Packaging Guidelines for AppData Files.
Runtimes and bundled libraries
When a Flatpak is executed, the files that the application see come from two places:
The Flatpak runtime, mounted at
/usr. This contains libraries and data files shared by all Fedora Flatpaks. There is one runtime version for each Fedora release.
The Flatpak application, mounted at
/app. This contains the application code itself, but also contains any libraries that are bundled with the application. The application and libraries must be rebuilt with this prefix - this is done by including them in your module.
Packaging flatpaks in Fedora makes use of Modularity. The application and bundled libraries are built in a module - this gives a couple of advantages:
The module has a different buildroot configuration with macros that result in RPMs in the module being built with a prefix of
The application author is in control of the particular versions of libraries that are included. Even if your application is built on the
f37runtime, you can use libraries from a newer or older version of Fedora, if required by your application.
Note that Flatpak modules will not work outside the Flatpak context, since they contain RPMs rebuilt with a prefix of
/app with the same name as system ibraries - you cannot use
dnf module enable to install them.
For Fedora, Flatpak runtimes and applications are built as OCI Images and distributed via https://registry.fedoraproject.org. This allows Flatpaks to be handled in a very similar way to server side containers. (Flatpaks are also commonly distributed via ostree.)
Want to help? Learn how to contribute to Fedora Docs ›