-
Notifications
You must be signed in to change notification settings - Fork 3
/
post_flashz.py
105 lines (84 loc) · 3.32 KB
/
post_flashz.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#!/usr/bin/python
# this script is from esp32-flashz library
# https://github.com/vortigont/esp32-flashz
#https://docs.platformio.org/en/latest/scripting/actions.html
#https://trass3r.github.io/coding/2018/12/20/advanced-platformio.html
#https://github.com/platformio/bintray-secure-ota/blob/master/publish_firmware.py
from os.path import basename
from os.path import isfile
from os.path import getsize
import subprocess
import requests
import sys,zlib
import re
Import("env", "projenv")
# access to global build environment
#print(env)
# access to project build environment (is used source files in "src" folder)
#print(projenv.Dump())
#
# Dump build environment (for debug purpose)
# print(env.Dump())
#
def pigz_compress(source, target, env):
firmware_path = str(target[0]) #.replace(".elf", ".bin")
#firmware_name = basename(firmware_path)
print("Compressing %s file..." % basename(firmware_path))
subprocess.run(["pigz", "-fzk11", firmware_path])
#def zlib_compress(source, target, env):
def zlib_compress(source):
imgfile = source
print("Compressing %s file..." % basename(imgfile))
with open(imgfile, 'rb') as img:
with open(imgfile + '.zz', 'wb') as deflated:
data = zlib.compress(img.read(), zlib.Z_BEST_COMPRESSION)
deflated.write(data)
compress_ratio = (float(getsize(imgfile)) - float(getsize(imgfile + '.zz'))) / float(getsize(imgfile)) * 100
print("Compress ratio %d%%" % compress_ratio)
def ota_upload(source, target, env):
file_path = str(source[0])
print ("Found OTA_url option, will attempt over-the-air HTTP upload")
try:
flags = env.GetProjectOption('upload_flags')
for f in flags:
if f in ("mode_z", "compress"):
print("will use zlib compression")
zlib_compress(file_path)
if (isfile(file_path + ".zz")):
file_path += ".zz"
except:
print ("No 'upload_flags', NOT using compression")
try:
url = env.GetProjectOption('upload_port')
except:
print ("Pls, specify OTA URL via 'upload_port' project option")
env.Exit(1)
# check if we upload a firmware or FS image
imgtype = None
if (bool(re.search('firmware', file_path))):
imgtype = 'fw'
else:
imgtype = 'fs'
payload = {'img' : imgtype }
f = {'file': open(file_path, 'rb')}
req = None
try:
print("Uploading file %s to %s " % (file_path, url))
req = requests.post(url, data = payload, files=f)
req.raise_for_status()
except requests.exceptions.RequestException as e:
sys.stderr.write("Failed to upload file: %s\n" %
("%s\n%s" % (req.status_code, req.text) if req else str(e)))
env.Exit(1)
print("The firmware has been successfuly uploaded!")
# available targets, i.e. buildprog, size, upload, program, buildfs, uploadfs, uploadfsota
#buildprog is a target when ALL files are compiled and PROGRAM is ready.
# autocompress all bin images (fw and fs)
#env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", pigz_compress)
# Custom upload handler
try:
proto = env.GetProjectOption('upload_protocol')
if proto in ("custom"):
env.Replace(UPLOADCMD=ota_upload)
except:
print ("No custom upload proto, fallback to serial flasher")