3 # verify.py - part of the FDroid server tools
4 # Copyright (C) 2013, Ciaran Gultnieks, ciaran@ciarang.com
6 # This program is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU Affero General Public License as published by
8 # the Free Software Foundation, either version 3 of the License, or
9 # (at your option) any later version.
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU Affero General Public License for more details.
16 # You should have received a copy of the GNU Affero General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
23 from argparse import ArgumentParser
29 from .exception import FDroidException
37 global options, config
39 # Parse command line...
40 parser = ArgumentParser(usage="%(prog)s [options] [APPID[:VERCODE] [APPID[:VERCODE] ...]]")
41 common.setup_global_opts(parser)
42 parser.add_argument("appid", nargs='*', help=_("applicationId with optional versionCode in the form APPID[:VERCODE]"))
43 options = parser.parse_args()
45 config = common.read_config(options)
48 if not os.path.isdir(tmp_dir):
49 logging.info(_("Creating temporary directory"))
52 unsigned_dir = 'unsigned'
53 if not os.path.isdir(unsigned_dir):
54 logging.error(_("No unsigned directory - nothing to do"))
60 vercodes = common.read_pkg_args(options.appid, True)
62 for apkfile in sorted(glob.glob(os.path.join(unsigned_dir, '*.apk'))):
64 apkfilename = os.path.basename(apkfile)
65 appid, vercode = common.publishednameinfo(apkfile)
67 if vercodes and appid not in vercodes:
69 if vercodes[appid] and vercode not in vercodes[appid]:
74 logging.info("Processing {apkfilename}".format(apkfilename=apkfilename))
76 remoteapk = os.path.join(tmp_dir, apkfilename)
77 if os.path.exists(remoteapk):
79 url = 'https://f-droid.org/repo/' + apkfilename
80 logging.info("...retrieving " + url)
82 net.download_file(url, dldir=tmp_dir)
83 except requests.exceptions.HTTPError as e:
85 net.download_file(url.replace('/repo', '/archive'), dldir=tmp_dir)
86 except requests.exceptions.HTTPError as e:
87 raise FDroidException(_('Downloading {url} failed. {error}')
88 .format(url=url, error=e))
90 compare_result = common.verify_apks(
92 os.path.join(unsigned_dir, apkfilename),
95 raise FDroidException(compare_result)
97 logging.info("...successfully verified")
100 except FDroidException as e:
101 logging.info("...NOT verified - {0}".format(e))
104 logging.info(_("Finished"))
105 logging.info("{0} successfully verified".format(verified))
106 logging.info("{0} NOT verified".format(notverified))
109 if __name__ == "__main__":