#!/usr/bin/env python3

import os
import sys
import ssl
import zipfile
import hashlib
import urllib.request
import urllib.error

# Disable certificate checking because it always fails on Windows
# We verify the checksum anyway.
ctx = ssl.create_default_context()
ctx.check_hostname = False
ctx.verify_mode = ssl.CERT_NONE

BASENAME = 'pkg-config.zip'
GSTREAMER_URL = 'https://gstreamer.freedesktop.org/src/mirror/pkg-config.zip'

zip_sha256 = sys.argv[1]
source_dir = os.path.join(
    os.environ['MESON_SOURCE_ROOT'], os.environ['MESON_SUBDIR'])
dest = BASENAME
dest_path = os.path.join(source_dir, dest)


def get_sha256(zipf):
    hasher = hashlib.sha256()
    with open(zipf, 'rb') as f:
        hasher.update(f.read())
    return hasher.hexdigest()


if os.path.isfile(dest_path):
    found_sha256 = get_sha256(dest_path)
    if found_sha256 == zip_sha256:
        print('{} already downloaded'.format(dest))
        sys.exit(0)
    else:
        print('{} checksum mismatch, redownloading'.format(dest))

url = GSTREAMER_URL.format(dest)
print('Downloading {} to {}'.format(GSTREAMER_URL.format(dest), dest))
try:
    with open(dest_path, 'wb') as d:
        f = urllib.request.urlopen(url, context=ctx)
        d.write(f.read())
except urllib.error.URLError as ex:
    curdir = os.path.dirname(sys.argv[0])
    print('Couldn\'t download {!r}! Try downloading it manually and '
          'placing it into {!r}'.format(dest, curdir))

found_sha256 = get_sha256(dest_path)
if found_sha256 != zip_sha256:
    print('SHA256 of downloaded file {} was {} instead of {}'
          ''.format(dest, found_sha256, zip_sha256))
    sys.exit(1)

print('Extracting {}'.format(dest))
zf = zipfile.ZipFile(dest_path, "r")
zf.extractall(path=source_dir)