fix xss issue

This commit is contained in:
Michaela 2021-04-28 08:30:28 +10:00
parent 3fd74d61a7
commit ccf84fe48a

View File

@ -10,6 +10,7 @@ import os
from datetime import datetime, timedelta, timezone
import sys, traceback
import re
import html
HOST = os.getenv("ES")
# get current sondes, filter by date, location
@ -314,7 +315,7 @@ def datanew(event, context):
try:
frame_data = frame["1"]["hits"]["hits"][0]["_source"]
uploaders = {
x["_source"]['uploader_callsign'] : {
html.escape(x["_source"]['uploader_callsign']) : {
"snr" : x["_source"]["snr"] if "snr" in x["_source"] else None,
"rssi" : x["_source"]["rssi"] if "rssi" in x["_source"] else None
}
@ -323,13 +324,13 @@ def datanew(event, context):
# Use subtype if it exists, else just use the basic type.
if "subtype" in frame_data:
_type = frame_data["subtype"]
_type = html.escape(frame_data["subtype"])
else:
_type = frame_data["type"]
_type = html.escape(frame_data["type"])
data = {
"manufacturer": frame_data['manufacturer'],
"type": _type
"manufacturer": html.escape(frame_data['manufacturer']),
"type": html.escape(_type)
}
if "temp" in frame_data:
@ -355,15 +356,15 @@ def datanew(event, context):
# May need to revisit this, if the resultant strings are too long.
if "xdata" in frame_data:
data["xdata"] = frame_data["xdata"]
data["xdata"] = html.escape(frame_data["xdata"])
output["positions"]["position"].append(
{
"position_id": f'{frame_data["serial"]}-{frame_data["datetime"]}',
"position_id": html.escape(f'{frame_data["serial"]}-{frame_data["datetime"]}'),
"mission_id": "0",
"vehicle": frame_data["serial"],
"server_time": frame_data["datetime"],
"gps_time": frame_data["datetime"],
"vehicle": html.escape(frame_data["serial"]),
"server_time": html.escape(frame_data["datetime"]),
"gps_time": html.escape(frame_data["datetime"]),
"gps_lat": frame_data["lat"],
"gps_lon": frame_data["lon"],
"gps_alt": frame_data["alt"],
@ -371,7 +372,7 @@ def datanew(event, context):
if "heading" in frame_data
else "",
"gps_speed": frame_data["vel_h"] if "vel_h" in frame_data else "",
"type": _type,
"type": html.escape(_type),
"picture": "",
"temp_inside": "",
"data": data,
@ -450,11 +451,11 @@ def datanew(event, context):
#
output["positions"]["position"].append(
{
"position_id": f'{frame_data["uploader_callsign"]}-{frame_data["ts"]}',
"position_id": html.escape(f'{frame_data["uploader_callsign"]}-{frame_data["ts"]}'),
"mission_id": "0",
"vehicle": f'{frame_data["uploader_callsign"]}_chase',
"server_time": datetime.fromtimestamp(frame_data["ts"]/1000).isoformat(),
"gps_time": datetime.fromtimestamp(frame_data["ts"]/1000).isoformat(),
"vehicle": html.escape(f'{frame_data["uploader_callsign"]}_chase'),
"server_time": html.escape(datetime.fromtimestamp(frame_data["ts"]/1000).isoformat()),
"gps_time": html.escape(datetime.fromtimestamp(frame_data["ts"]/1000).isoformat()),
"gps_lat": frame_data["uploader_position"][0],
"gps_lon": frame_data["uploader_position"][1],
"gps_alt": frame_data["uploader_position"][2],
@ -463,7 +464,7 @@ def datanew(event, context):
"picture": "",
"temp_inside": "",
"data": data,
"callsign": frame_data["uploader_callsign"],
"callsign": html.escape(frame_data["uploader_callsign"]),
"sequence": "",
}
)
@ -541,7 +542,7 @@ def get_listeners(event, context):
output = [
{
"name": listener["key"],
"name": html.escape(listener["key"]),
"tdiff_hours": (
datetime.now(timezone.utc)
- datetime.fromisoformat(
@ -565,9 +566,9 @@ def get_listeners(event, context):
"alt": float(listener["1"]["hits"]["hits"][0]["fields"]["uploader_alt"][0]),
"description": f"""\n
<font size=\"-2\"><BR>\n
<B>Radio: {listener["1"]["hits"]["hits"][0]["fields"]["software_name.keyword"][0]}-{listener["1"]["hits"]["hits"][0]["fields"]["software_version.keyword"][0]}</B><BR>\n
<B>Antenna: </B>{listener["1"]["hits"]["hits"][0]["fields"]["uploader_antenna.keyword"][0]}<BR>\n
<B>Last Contact: </B>{listener["1"]["hits"]["hits"][0]["fields"]["ts"][0]} <BR>\n
<B>Radio: {html.escape(listener["1"]["hits"]["hits"][0]["fields"]["software_name.keyword"][0])}-{html.escape(listener["1"]["hits"]["hits"][0]["fields"]["software_version.keyword"][0])}</B><BR>\n
<B>Antenna: </B>{html.escape(listener["1"]["hits"]["hits"][0]["fields"]["uploader_antenna.keyword"][0])}<BR>\n
<B>Last Contact: </B>{html.escape(listener["1"]["hits"]["hits"][0]["fields"]["ts"][0])} <BR>\n
</font>\n
""",
}
@ -604,7 +605,6 @@ if __name__ == "__main__":
datanew(
{
"queryStringParameters": {
"vehicles": "55067220",
"type": "positions",
"mode": "1day",
"position_id": "0"
@ -613,3 +613,8 @@ if __name__ == "__main__":
{},
)
)
print(
get_listeners(
{},{}
)
)