fdroid-dl is a f-droid (offline) mirror generation and update utility
Project description
fdroid-dl
Is a python based f-droid mirror generation and update utility. Point at one or more existing f-droid repositories and the utility will download the metadata (pictures, descriptions,..) for you and place it in your local system. Simply run fdroid-dl && fdroid update
and you are set.
Motivation
The idea is to have an no internet local copy of one or more repositories, without the need to compile the thousands of apps on your own build server but rather download them like the android client does. So this tool came into existence to simply download a whole repository and import the apps into your own locally installed one. At the time of writing a full offline copy including assets is ~7.5GB of the official repository of f-droid.org.
Installation
fdroid-dl is available via pip, simply run pip install fdroid-dl
and you can use fdroid-dl
on your command line. pypi.org - fdroid-dl
Documentation
Can be found at fdroid-dl.readthedocs.io
Command Line Options
Usage: fdroid-dl [OPTIONS] COMMAND [ARGS]...
Is a python based f-droid mirror generation and update utility. Point at
one or more existing f-droid repositories and the utility will download
the metadata (pictures, descriptions,..) for you and place it in your
local system.
Simply run "fdroid-dl update && fdroid update" in your folder with repo
and you are set.
Options:
-d, --debug enable debug level logging
-c, --config FILE location of your fdroid-dl.json configuration file
[default: fdroid-dl.json]
-r, --repo DIRECTORY location of your fdroid repository to store the
apk files [default: ./repo]
-m, --metadata DIRECTORY location of your fdroid metadata to store the
asset files [default: ./metadata]
--cache DIRECTORY location for fdroid-dl to store cached data
[default: ./.cache]
--help Show this message and exit.
Commands:
update starts updating process
Usage: fdroid-dl update [OPTIONS] COMMAND [ARGS]...
Options:
--index / --no-index download repository index files [default: True]
--metadata / --no-metadata download metadata assset files [default: True]
--apk / --no-apk download apk files [default: True]
--apk-versions INTEGER how many versions of apk to download [default:
1]
--src / --no-src download src files [default: True]
--threads INTEGER configure number of parallel threads used for
download [default: 10]
--head-timeout INTEGER maximum time in seconds a HEAD request is
allowed to take [default: 10]
--index-timeout INTEGER maximum time in seconds index file download is
allowed to take [default: 60]
--download-timeout INTEGER maximum time in seconds file download is allowed
to take [default: 60]
--help Show this message and exit.
Configuration File
TODO
- Create backend to crawl existing repos
- Fetch info directly index.jar and index-v1.jar
- Compatibility with old and new repo styles
- Download multi threaded
- Verify apk checksum
- Local cache for index files
- Source code download not implemented yet
- Metadata update to do delta not full download all the time
- Cleanup strategy for old apk files (maybe
fdroid update
does this already?) - Create a CLI python click
- pip package packaging.python.org
- CI builds for pip package
- Documentation ;-)
- Writing tests pytest
CHANGELOG
- WIP: Documentation added
- WIP: Test added
- requests-mock ?
Ideas
- requests-cache ?
Development
Requirements
- python 2.7.* or 3.5.*
- pip 3.x
- virtualenv 3.x
install locally
# git clone https://github.com/t4skforce/fdroid-dl.git
# cd fdroid-dl
# virtualenv .env
# source .env/bin/activate
# python setup.py install
# fdroid-dl --help
# python3 -m fdroid_dl --help
References
While this project was developed the following references where used
F-Droid
- Setup an F-Droid App Repo f-droid.org
- Build Metadata Reference f-droid.org
- All About Descriptions, Graphics, and Screenshots f-droid.org
- How to Add a Repo to F-Droid f-droid.org
- How to Send and Receive Apps Offline f-droid.org
Python
- Python Documentation python.org
- PyYAML Documentation pyyaml.org
- Requests: HTTP for Humans python-requests.org
- Suppress InsecureRequestWarning: Unverified HTTPS request is being made in Python2.6 stackoverflow.com
- How to download large file in python with requests.py? stackoverflow.com
- Asynchronous Python HTTP Requests for Humans using Futures requests-futures
- Testing Your Code python-guide.org
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fdroid-dl-0.1.0.tar.gz
.
File metadata
- Download URL: fdroid-dl-0.1.0.tar.gz
- Upload date:
- Size: 21.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.44.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8fb3ae5969c34d4ecc8314489fadcd7473f968f4857154c0e3b22643568ebdbc |
|
MD5 | 2b2ab08517eb34327f0e3b3d20f19728 |
|
BLAKE2b-256 | 41f7d840aab8ea3bb5468b54abecf5b457b10d28d20b68e8d69d063ebf0705cb |
File details
Details for the file fdroid_dl-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: fdroid_dl-0.1.0-py3-none-any.whl
- Upload date:
- Size: 29.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.44.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 878e8d43e40b338ca6467b47a7e77d5843aa677b27337b39d486dc745e978329 |
|
MD5 | 322a715ab0571a73c499a6ec72e9d84b |
|
BLAKE2b-256 | a637ad0bdfe6662d7cce0f110a2a868fa01eb6c3b92c68df2077e5c08815a37e |