This guide will show you how to set up an F-Droid repo with this tool. It makes some assumptions you need to know about:
- You use GitHub to host the repositories of your app(s)
- You create GitHub releases for your app(s) that contain exactly one artifact with an
.apk
suffix- My recommendation is to create a GitHub Actions workflow in your app repo that builds & signs your APK, then publishes it as a release (maybe as a draft release so you have more control). If you want to see how I did it with a Flutter app, go here.
- Your release tag names are something like
v1.2.3
(recommended, but should work anyways regardless)
This tool does not build your apps from source. It assumes that the build process runs in the application's repository.
When building/releasing a new version of your app, you need to make sure that you update not only the versionName
, but also the versionCode
. It seems like the latter is preferred by F-Droid for comparing versions.
- In Flutter, you have something like
version: 1.2.3+4
in yourpubspec.yaml
file. The1.2.3
is theversionName
, theversionCode
is after the+
, so4
in this case. You should update both for F-Droid to recognize an update.
-
First of all, clone this repository and delete everything from the
fdroid
directory. This deletes my repo files; you can now use it for your own apps. If you want to reduce the size of the repository, you can also delete the.git
directory, thengit init
again (you need to force-push/create a new repo after that). -
Now you can install the F-Droid server tools by running the following:
sudo add-apt-repository ppa:fdroid/fdroidserver sudo apt-get update sudo apt-get install fdroidserver
Make sure that you install version
2.x
of thefdroidserver
package. In the previous step we added the repository because thefdroidserver
package I found at first (in the default repo) was outdated; so just make sure it's version 2 (you can also check withapt-get -s install fdroidserver
).We only need these tools once to set up the repository. After these steps you can delete them, as now GitHub Actions will manage everything.
-
Then run
fdroid init
in thefdroid
subdirectory:cd fdroid && fdroid init
This creates two files:
fdroid/config.yml
andfdroid/keystore.p12
. The first one is the configuration file for your repository, the second one is a keystore file (these are used for signing apps when building, but this tool doesn't build apps).Edit the generated
fdroid/config.yml
. The comments will tell you a lot, but make sure therepo_url
looks something like this (it should include your username instead ofxarantolus
):repo_url: https://raw.githubusercontent.com/xarantolus/fdroid/main/fdroid/repo
You should also set
archive_older
to0
to disable the archive:archive_older: 0
-
Open your GitHub repository, go to Settings and then to Secrets. We will create a few "Repository secrets" now (do not mix them up with the "Environment secrets", we don't want those!)
-
After finishing your edits to the two files, you can run the following command:
base64 config.yml > out.txt
Now copy the contents of
out.txt
and set up a new repository secred calledCONFIG_YML
. Just paste the content ofout.txt
into the value field.Then do the same with the keystore file:
base64 keystore.p12 > out.txt
And now create another secret with the name
KEYSTORE_P12
, and again paste the content ofout.txt
. -
Then open this page and generate a new GitHub personal access token without any scopes. Set the expiration date to "No expiration" (or really any timeframe on how often you want to manually update this secret). Copy the token and set it as the
GH_ACCESS_TOKEN
repository secret.
That should be it. You can now also generate a new QR code for your repo using online tools, then replace the file in .github/qrcode.png
. And of course, you should now add your apps!
Now you can edit the apps.yaml
file to include a new app. Usually you just need to input the GitHub link and everything should work:
notality:
git: https://github.com/xarantolus/notality
name: "Notality"
description: |
Notality is a very simple note taking app. I mostly built it to learn how Flutter works, but it's functional and you can use it.
<b>Features</b>
- Create, edit, delete and reorder notes
- Automatic dark/light mode depending on the system-wide setting
- Localization for English and German
# As described on https://f-droid.org/en/docs/Build_Metadata_Reference/#Categories,
# you can use any name here, but you should look at the existing categories first
categories:
- Writing
another_app:
git: https://github.com/xarantolus/myotherapp
If the repository has APK releases, they should be imported into this repo the next time GitHub Actions run.
Metadata can be added in two places: the apps.yaml
file and the app repositories.
Description: As described in Add a new app, you can set a git URL and a description in the apps.yaml
file
Categories: A list of categories, preferably one of the categories already listed in the official repo
Screenshots: This tool will make any file from the git repository for which the path contains screenshot
available as screenshot. Basically, if you run find . -type f | grep -i screenshot
in your app repo you should find all files that will be used.
Changelog: To display a "what's new" changelog in F-Droid, you just need to fill out the body/text of the GitHub release.
License: The License spdx_id
given by GitHub. Make sure GitHub recognizes the license type of your app.
Tag line: The tag line of the app shown in F-Droid is the same text as the repository description on GitHub.
When you link to your repository, you can also add the fingerprint to the URL.
To get the fingerprint, you need to look at the fdroid
command output (or search for the following lines in GitHub Actions):
2021-10-11 06:01:21,726 INFO: Creating signed index with this key (SHA256):
2021-10-11 06:01:21,726 INFO: 08 08 98 AE 43 09 AE CE B5 89 15 E4 3A 4B 7C 4A 3E 2C DA 40 C9 17 38 E2 C0 2F 58 33 9A B2 FB D7
Just remove all spaces from after "INFO" in the second line and you'll end up with your fingerprint:
080898AE4309AECEB58915E43A4B7C4A3E2CDA40C91738E2C02F58339AB2FBD7
Now add it to your repo URL (add a ?fingerprint=
, then your key):
https://raw.githubusercontent.com/xarantolus/fdroid/main/fdroid/repo?fingerprint=080898AE4309AECEB58915E43A4B7C4A3E2CDA40C91738E2C02F58339AB2FBD7
You should of course replace the username in the URL. This is the URL your users should add to the F-Droid client. You can also generate a QR code for this URL.
For the repository store icon (if you would like it to not be the auto generated QR), make sure to add the icon.png
(assuming this has not been changed to a custom filename in the config.yml) file to the root of the fdroid
folder as well as to the fdroid/repo/icons
folder. It must be in both places to bypass a bug in the fdroid-server code.
For app icons, metascoop will not automatically get app icons from your repository. App icons must be manually added (both icon.png
and featureGraphic.png
) to the following folder /fdroid/repo/<your_app_package_name>/en-US