Last active
January 7, 2018 13:59
-
-
Save jorgerance/18c282dbc340ef86a9cd061d5f5ae9d8 to your computer and use it in GitHub Desktop.
get.py - esp32 (SSL: CERTIFICATE_VERIFY_FAILED solved)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env python | |
# This script will download and extract required tools into the current directory. | |
# Tools list is obtained from package/package_esp8266com_index.template.json file. | |
# Written by Ivan Grokhotkov, 2015. | |
# | |
from __future__ import print_function | |
import os | |
import shutil | |
import errno | |
import os.path | |
import hashlib | |
import json | |
import platform | |
import sys | |
import tarfile | |
import zipfile | |
import re | |
import wget | |
import ssl | |
ssl._create_default_https_context = ssl._create_unverified_context | |
if sys.version_info[0] == 3: | |
from urllib.request import urlretrieve | |
else: | |
# Not Python 3 - today, it is most likely to be Python 2 | |
from urllib import urlretrieve | |
if 'Windows' in platform.system(): | |
import requests | |
current_dir = os.path.dirname(os.path.realpath(unicode(__file__))) | |
dist_dir = current_dir + '/dist/' | |
def sha256sum(filename, blocksize=65536): | |
hash = hashlib.sha256() | |
with open(filename, "rb") as f: | |
for block in iter(lambda: f.read(blocksize), b""): | |
hash.update(block) | |
return hash.hexdigest() | |
def mkdir_p(path): | |
try: | |
os.makedirs(path) | |
except OSError as exc: | |
if exc.errno != errno.EEXIST or not os.path.isdir(path): | |
raise | |
def report_progress(count, blockSize, totalSize): | |
percent = int(count*blockSize*100/totalSize) | |
percent = min(100, percent) | |
sys.stdout.write("\r%d%%" % percent) | |
sys.stdout.flush() | |
def unpack(filename, destination): | |
dirname = '' | |
print('Extracting {0}'.format(os.path.basename(filename))) | |
sys.stdout.flush() | |
if filename.endswith('tar.gz'): | |
tfile = tarfile.open(filename, 'r:gz') | |
tfile.extractall(destination) | |
dirname= tfile.getnames()[0] | |
elif filename.endswith('zip'): | |
zfile = zipfile.ZipFile(filename) | |
zfile.extractall(destination) | |
dirname = zfile.namelist()[0] | |
else: | |
raise NotImplementedError('Unsupported archive type') | |
# a little trick to rename tool directories so they don't contain version number | |
rename_to = re.match(r'^([a-z][^\-]*\-*)+', dirname).group(0).strip('-') | |
if rename_to != dirname: | |
print('Renaming {0} to {1}'.format(dirname, rename_to)) | |
if os.path.isdir(rename_to): | |
shutil.rmtree(rename_to) | |
shutil.move(dirname, rename_to) | |
def get_tool(tool): | |
sys_name = platform.system() | |
archive_name = tool['archiveFileName'] | |
local_path = dist_dir + archive_name | |
url = tool['url'] | |
#real_hash = tool['checksum'].split(':')[1] | |
if not os.path.isfile(local_path): | |
print('Downloading ' + archive_name); | |
sys.stdout.flush() | |
if 'CYGWIN_NT' in sys_name: | |
import ssl | |
ctx = ssl.create_default_context() | |
ctx.check_hostname = False | |
ctx.verify_mode = ssl.CERT_NONE | |
urlretrieve(url, local_path, report_progress, context=ctx) | |
elif 'Windows' in sys_name: | |
r = requests.get(url) | |
f = open(local_path, 'wb') | |
f.write(r.content) | |
f.close() | |
else: | |
#urlretrieve(url, local_path, report_progress) | |
wget.download(url, local_path) | |
sys.stdout.write("\rDone\n") | |
sys.stdout.flush() | |
else: | |
print('Tool {0} already downloaded'.format(archive_name)) | |
sys.stdout.flush() | |
#local_hash = sha256sum(local_path) | |
#if local_hash != real_hash: | |
# print('Hash mismatch for {0}, delete the file and try again'.format(local_path)) | |
# raise RuntimeError() | |
unpack(local_path, '.') | |
def load_tools_list(filename, platform): | |
tools_info = json.load(open(filename))['packages'][0]['tools'] | |
tools_to_download = [] | |
for t in tools_info: | |
tool_platform = [p for p in t['systems'] if p['host'] == platform] | |
if len(tool_platform) == 0: | |
continue | |
tools_to_download.append(tool_platform[0]) | |
return tools_to_download | |
def identify_platform(): | |
arduino_platform_names = {'Darwin' : {32 : 'i386-apple-darwin', 64 : 'x86_64-apple-darwin'}, | |
'Linux' : {32 : 'i686-pc-linux-gnu', 64 : 'x86_64-pc-linux-gnu'}, | |
'LinuxARM': {32 : 'arm-linux-gnueabihf', 64 : 'aarch64-linux-gnu'}, | |
'Windows' : {32 : 'i686-mingw32', 64 : 'i686-mingw32'}} | |
bits = 32 | |
if sys.maxsize > 2**32: | |
bits = 64 | |
sys_name = platform.system() | |
sys_platform = platform.platform() | |
print('System: %s, Info: %s' % (sys_name, sys_platform)) | |
if 'Linux' in sys_name and sys_platform.find('arm') > 0: | |
sys_name = 'LinuxARM' | |
if 'CYGWIN_NT' in sys_name: | |
sys_name = 'Windows' | |
return arduino_platform_names[sys_name][bits] | |
if __name__ == '__main__': | |
identified_platform = identify_platform() | |
print('Platform: {0}'.format(identified_platform)) | |
tools_to_download = load_tools_list(current_dir + '/../package/package_esp32_index.template.json', identified_platform) | |
mkdir_p(dist_dir) | |
for tool in tools_to_download: | |
get_tool(tool) | |
print('Done') |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment