Replaced pycurl by request, cleanup and comments

This commit is contained in:
Barbudor 2020-11-20 21:49:52 +01:00
parent dea0ae1d7b
commit c064ee1531
1 changed files with 47 additions and 33 deletions

View File

@ -30,22 +30,29 @@ Usage:
""" """
import sys
import io import io
import pycurl import requests
import certifi
from io import BytesIO from io import BytesIO
from io import StringIO from io import StringIO
from datetime import datetime from datetime import datetime
import json import json
column = 27 # Start position of {"NAME":... in line
LIST_URL = "https://templates.blakadder.com/list.json"
TEMPLATES = "../../TEMPLATES.md"
COLUMN = 27 # Start position of {"NAME":... in line
# Some values from support.ino and tasmota_templates.h
AGPIO = lambda x : x << 5 AGPIO = lambda x : x << 5
GPIO_NONE = 0 GPIO_NONE = 0
GPIO_USER = AGPIO(GPIO_NONE)+1
GPIO_ADC_INPUT = 147 GPIO_ADC_INPUT = 147
GPIO_USER = 2047 # User configurable needs to be 2047 GPIO_ADC_JOY = 104
kGpioConvert = [ # Conversion table extracted from Tasmota code
GPIO_CONVERT = [
0x0000, 0x0000,
0x04A0, 0x04A0,
0x04C0, 0x04C0,
@ -265,28 +272,34 @@ kGpioConvert = [
0x14E0 0x14E0
] ]
def is_old_template(template): def is_old_template(template):
"""find out it the template is old format"""
# Old format <=> 13 gpios AND all gpios <= 255
if "GPIO" in template and len(template["GPIO"]) == 13: if "GPIO" in template and len(template["GPIO"]) == 13:
gpio = 0
for g in template["GPIO"]: for g in template["GPIO"]:
if g < 256: if g > 255:
return False
return True return True
return False return False
def gpio_convert(gpio): def gpio_convert(gpio):
if gpio >= len(kGpioConvert): """Conversion as per https://tasmota.github.io/docs/Components/#gpio-conversion"""
return AGPIO(GPIO_NONE) +1 # USER if gpio >= len(GPIO_CONVERT):
return kGpioConvert[gpio] return GPIO_USER
return GPIO_CONVERT[gpio]
def adc0_convert(adc0): def adc0_convert(adc0):
"""Conversion as per https://tasmota.github.io/docs/Components/#adc-conversion"""
adc0 = adc0 & 0x0F adc0 = adc0 & 0x0F
if adc0 > 7: if 0 == adc0:
return AGPIO(GPIO_NONE) +1 # USER
elif 0 == adc0:
return GPIO_NONE return GPIO_NONE
elif 8 == adc0:
return AGPIO(GPIO_ADC_JOY); # Joystick
elif adc0 > 7:
return GPIO_USER
return AGPIO(GPIO_ADC_INPUT + adc0 -1) return AGPIO(GPIO_ADC_INPUT + adc0 -1)
def convert_gpios(gpios, flag): def convert_gpios(gpios, flag):
new_gpios = [] new_gpios = []
for g in gpios: for g in gpios:
@ -302,28 +315,31 @@ def convert_template(template):
"FLAG":0, "FLAG":0,
"BASE": template["BASE"] } "BASE": template["BASE"] }
def get_templates_list():
"""Download templates list from template website"""
response = requests.get(LIST_URL)
if response.status_code != 200:
printf(f"Error GET({URL}) returned code {response.status_code}\n")
exit()
return response.text.split('\n')
def main(): def main():
print ("\n*** templates.py v20200514 by Theo Arends ***") print ("\n*** templates.py v20200514 by Theo Arends ***")
# Download from template website
buffer = BytesIO()
url = "https://templates.blakadder.com/list.json"
c = pycurl.Curl()
c.setopt(c.URL, url)
c.setopt(c.WRITEDATA, buffer)
c.setopt(c.CAINFO, certifi.where())
c.perform()
c.close()
body = buffer.getvalue()
fin = StringIO(body.decode('UTF-8'))
now = datetime.now() now = datetime.now()
month = now.strftime('%B') month = now.strftime('%B')
year = now.strftime('%Y') year = now.strftime('%Y')
# if stdin is a file, read the file instead of downloading (usefull for testing)
if sys.__stdin__.isatty():
print(f"Get template list from {LIST_URL}\n")
template_list = get_templates_list()
else:
print("Get template list from stdin\n")
template_list = sys.__stdin__.readlines()
# Write to root/TEMPLATES.md # Write to root/TEMPLATES.md
fout = open("../../TEMPLATES.md","w+") fout = open(TEMPLATES,"w+")
fout.write("<img src=\"/tools/logo/TASMOTA_FullLogo_Vector.svg\" alt=\"Logo\" align=\"right\" height=\"76\"/>\n") fout.write("<img src=\"/tools/logo/TASMOTA_FullLogo_Vector.svg\" alt=\"Logo\" align=\"right\" height=\"76\"/>\n")
fout.write("\n") fout.write("\n")
@ -332,14 +348,13 @@ def main():
fout.write("Find below the available templates as of " + month + " " + year + ". More template information can be found in the [Tasmota Device Templates Repository](http://blakadder.github.io/templates)\n") fout.write("Find below the available templates as of " + month + " " + year + ". More template information can be found in the [Tasmota Device Templates Repository](http://blakadder.github.io/templates)\n")
first = True first = True
fline = fin.readlines() for line in template_list:
for line in fline:
if line.strip(): if line.strip():
if line.startswith("##"): if line.startswith("##"):
if not first: if not first:
fout.write('```\n') fout.write('```\n')
fout.write('\n') fout.write('\n')
fout.write(line) fout.write(line+'\n')
fout.write('```\n') fout.write('```\n')
first = False first = False
elif line.startswith("#"): elif line.startswith("#"):
@ -353,12 +368,11 @@ def main():
except json.decoder.JSONDecodeError as ex: except json.decoder.JSONDecodeError as ex:
template = "Not available" template = "Not available"
fout.write(f"{name:<{column}} {json.dumps(template)}\n") fout.write(f"{name:<{COLUMN}} {json.dumps(template)}\n")
fout.write('```\n') fout.write('```\n')
fout.close() fout.close()
fin.close()
if __name__ == "__main__": if __name__ == "__main__":
main() main()