Metadata-Version: 2.1
Name: fdroid-dl
Version: 0.1.0
Summary: fdroid-dl is a f-droid (offline) mirror generation and update utility
Home-page: https://github.com/t4skforce/fdroid-dl
Author: t4skforce
Author-email: 7422037+t4skforce@users.noreply.github.com
License: UNKNOWN
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Environment :: Console
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, <4
Description-Content-Type: text/markdown
Requires-Dist: requests-futures (>=0.9.7)
Requires-Dist: PyYAML (>=3.13)
Requires-Dist: click (>=6.7)

# fdroid-dl

[![Build Status](https://api.travis-ci.org/t4skforce/fdroid-dl.svg)](https://travis-ci.org/t4skforce/fdroid-dl)
[![Documentation Status](https://readthedocs.org/projects/fdroid-dl/badge/?version=latest)](https://fdroid-dl.readthedocs.io/en/latest/?badge=latest)


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](https://pypi.org/project/fdroid-dl/)

# Documentation
Can be found at [fdroid-dl.readthedocs.io](https://fdroid-dl.readthedocs.io/en/latest/)

# 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
- [x] Create backend to crawl existing repos
- [x] Fetch info directly index.jar and index-v1.jar
- [x] Compatibility with old and new repo styles
- [x] Download multi threaded
- [x] Verify apk checksum
- [x] 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?)
- [x] Create a CLI [python click](http://click.pocoo.org/5/)
- [x] pip package [packaging.python.org](https://packaging.python.org/tutorials/packaging-projects/)
- [x] CI builds for pip package
- [ ] Documentation ;-)
- [ ] Writing tests [pytest](https://docs.pytest.org/en/latest/)

# 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](https://f-droid.org/en/docs/Setup_an_F-Droid_App_Repo/)
* Build Metadata Reference [f-droid.org](https://f-droid.org/en/docs/Build_Metadata_Reference/)
* All About Descriptions, Graphics, and Screenshots [f-droid.org](https://f-droid.org/en/docs/All_About_Descriptions_Graphics_and_Screenshots/)
* How to Add a Repo to F-Droid [f-droid.org](https://f-droid.org/en/tutorials/add-repo/)
* How to Send and Receive Apps Offline [f-droid.org](https://f-droid.org/en/tutorials/swap/)

#### Python
* Python Documentation [python.org](https://docs.python.org/3/)
* PyYAML Documentation [pyyaml.org](https://pyyaml.org/wiki/PyYAMLDocumentation)
* Requests: HTTP for Humans [python-requests.org](http://docs.python-requests.org/en/master/)
  * Suppress InsecureRequestWarning: Unverified HTTPS request is being made in Python2.6  [stackoverflow.com](https://stackoverflow.com/questions/27981545/suppress-insecurerequestwarning-unverified-https-request-is-being-made-in-pytho)
  * How to download large file in python with requests.py? [stackoverflow.com](https://stackoverflow.com/questions/16694907/how-to-download-large-file-in-python-with-requests-py)
* Asynchronous Python HTTP Requests for Humans using Futures [requests-futures](https://github.com/ross/requests-futures)
* Testing Your Code [python-guide.org](https://docs.python-guide.org/writing/tests/)


