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
Description: # 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/)
        
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
