2021-05-20 09:28:02 +00:00
|
|
|
import sys
|
|
|
|
sys.path.append("vendor/lib/python3.9/site-packages")
|
2021-05-20 08:43:50 +00:00
|
|
|
import json
|
|
|
|
import boto3
|
|
|
|
import os
|
|
|
|
import uuid
|
|
|
|
import hashlib
|
2021-05-20 09:28:02 +00:00
|
|
|
import asyncio
|
|
|
|
import aioboto3
|
2021-05-20 08:43:50 +00:00
|
|
|
|
|
|
|
BUCKET = "sondehub-open-data"
|
|
|
|
|
|
|
|
def values_to_hash(payload):
|
|
|
|
fields = [
|
|
|
|
"type",
|
|
|
|
"serial",
|
|
|
|
"frame",
|
|
|
|
"datetime",
|
|
|
|
"lat",
|
|
|
|
"lon",
|
|
|
|
"alt",
|
|
|
|
"subtype",
|
|
|
|
"temp",
|
|
|
|
"humidity",
|
|
|
|
"pressure",
|
|
|
|
"vel_h",
|
|
|
|
"vel_v",
|
|
|
|
"heading",
|
|
|
|
"sats",
|
|
|
|
"batt",
|
|
|
|
"burst_timer",
|
|
|
|
"xdata"
|
|
|
|
]
|
|
|
|
output = ""
|
|
|
|
for field in fields:
|
|
|
|
if field in payload:
|
|
|
|
output += str(payload[field])
|
|
|
|
return output
|
|
|
|
|
2021-05-24 12:14:18 +00:00
|
|
|
def set_connection_header(request, operation_name, **kwargs):
|
|
|
|
request.headers['Connection'] = 'keep-alive'
|
2021-05-20 08:43:50 +00:00
|
|
|
|
2021-05-20 09:28:02 +00:00
|
|
|
async def upload(event, context):
|
|
|
|
async with aioboto3.client("s3") as s3:
|
2021-05-24 12:14:18 +00:00
|
|
|
s3.meta.events.register('request-created.s3', set_connection_header)
|
2021-05-20 09:28:02 +00:00
|
|
|
tasks = []
|
|
|
|
payloads = {}
|
|
|
|
for record in event['Records']:
|
|
|
|
sns_message = json.loads(record["body"])
|
2021-05-24 10:44:29 +00:00
|
|
|
if type(json.loads(sns_message["Message"])) == dict:
|
|
|
|
incoming_payloads = [json.loads(sns_message["Message"])]
|
|
|
|
else:
|
|
|
|
incoming_payloads = json.loads(sns_message["Message"])
|
|
|
|
for payload in incoming_payloads:
|
|
|
|
|
|
|
|
body = json.dumps(payload)
|
|
|
|
id = str(uuid.uuid4())
|
|
|
|
hash = hashlib.sha256(values_to_hash(payload).encode("utf-8")).hexdigest()
|
2021-05-20 08:43:50 +00:00
|
|
|
|
2021-05-24 10:44:29 +00:00
|
|
|
filenames = [
|
|
|
|
f"date/{payload['datetime']}-{payload['serial']}-{id}.json",
|
|
|
|
f"serial/{payload['serial']}/{payload['datetime']}-{id}.json",
|
|
|
|
f"serial-hashed/{payload['serial']}/{payload['datetime']}-{hash}.json"
|
|
|
|
]
|
|
|
|
|
|
|
|
for filename in filenames:
|
|
|
|
tasks.append(s3.put_object(
|
|
|
|
ACL="public-read",
|
|
|
|
Bucket=BUCKET,
|
|
|
|
Body=body,
|
|
|
|
Key=filename
|
|
|
|
))
|
2021-05-20 09:28:02 +00:00
|
|
|
await asyncio.gather(*tasks)
|
2021-05-20 08:43:50 +00:00
|
|
|
|
2021-05-20 09:28:02 +00:00
|
|
|
|
|
|
|
def lambda_handler(event, context):
|
|
|
|
asyncio.run(upload(event, context))
|
|
|
|
|
|
|
|
|
|
|
|
# test event
|
|
|
|
###########
|
2021-05-20 08:43:50 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
demo_event = {
|
|
|
|
"Records": [
|
|
|
|
{
|
|
|
|
"messageId": "262d4090-e23b-4907-b677-3c94334dc899",
|
|
|
|
"receiptHandle": "AQEBL1FXHS4m+Om59KZH9ayxC5VBqDEDh6DgXUZuBhV2uQJS312bhOTpLvptuCCIWaeLkfHU+7NajqV2kTVhnz5lehE/zfQ8OU1jqqm+cHxyul99MxA7K7+C+ww2Ri9KSbgaAgqvZzcLbwpW8rP0MNhrBcIQAE5Pz1urfTZKx1RVnv/XQHbR2ARPwocOzk2yEexa0y2f7FedS4F10gju8Ypp0Zr4DSRb1zUkES3QJGiSJakaO1QJT5npRySjAd0CUSPXw7IDTejolfGkItQG5eMRx0enELTUDv8LPsHJkr7ha3DHNfbvxTtdk406nWFn8U8DW515emp7+Y+AD469OnceIMdVC62GHwrpMkedXzLEH0C8TOXHQ+WuRkhR1dauwKqO",
|
2021-05-24 12:14:18 +00:00
|
|
|
"body": "{\n \"Type\" : \"Notification\",\n \"MessageId\" : \"65147554-e06d-5324-a87d-2da107fea807\",\n \"TopicArn\" : \"arn:aws:sns:us-east-1:143841941773:sonde-telem\",\n \"Message\" : \"{\\\"software_name\\\":\\\"radiosonde_auto_rx\\\",\\\"software_version\\\":\\\"1.5.1\\\",\\\"uploader_callsign\\\":\\\"BIOWL1\\\",\\\"uploader_position\\\":\\\"52.014417,8.47351\\\",\\\"uploader_antenna\\\":\\\"SirioCX395\\\",\\\"time_received\\\":\\\"2021-04-18T07:52:37.196266Z\\\",\\\"datetime\\\":\\\"2021-04-18T07:52:53.001000Z\\\",\\\"manufacturer\\\":\\\"Vaisala\\\",\\\"type\\\":\\\"RS41\\\",\\\"serial\\\":\\\"meowmeowtest\\\",\\\"subtype\\\":\\\"RS41-SGP\\\",\\\"frame\\\":12781,\\\"lat\\\":50.65064,\\\"lon\\\":6.60805,\\\"alt\\\":2954.44289,\\\"temp\\\":-9.3,\\\"humidity\\\":75.4,\\\"pressure\\\":709.79,\\\"vel_v\\\":-2.85326,\\\"vel_h\\\":8.53055,\\\"heading\\\":236.0122,\\\"sats\\\":9,\\\"batt\\\":2.7,\\\"frequency\\\":405.3,\\\"burst_timer\\\":25423,\\\"snr\\\":12.5,\\\"user-agent\\\":\\\"Amazon CloudFront\\\",\\\"position\\\":\\\"50.65064,6.60805\\\",\\\"upload_time_delta\\\":-0.713689,\\\"uploader_alt\\\":340}\",\n \"Timestamp\" : \"2021-04-18T07:52:51.776Z\",\n \"SignatureVersion\" : \"1\",\n \"Signature\" : \"qXuYwDAGPYYLjKXfDtF69AWKDEhhz9MXlqxO2nBwJ/dgOqNSUZtDPqOYSuge3jVCoTSRY5qGw38gg2G+JnEbJd8SVvp9GRsFre8MKWu8T0obq3rj8S0YAh7dTqi4EILIMmi2KziasCDQlrVuZvCSgPnC+hYF3GByI626QW6m3a4E2igclvbE+O6x6qvVDKwmf/eh+8LRiH1PCrEckiXthnr+qOCiTcstyZoOqMOShJBun9k0DK07+Yf1tYDPSHnqZSIaOvAMSjIKKXfGCkel3SWieO7Zgk7xQuo9Z1bcV8Miu4uEvge4G9HKU3S41zaVcQjYvEhQLxxgd1x3HxXImA==\",\n \"SigningCertURL\" : \"https://sns.us-east-1.amazonaws.com/SimpleNotificationService-010a507c1833636cd94bdb98bd93083a.pem\",\n \"UnsubscribeURL\" : \"https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:us-east-1:143841941773:sonde-telem:1a52ac41-6e17-43da-bfb6-114577c94ca6\"\n}",
|
2021-05-20 08:43:50 +00:00
|
|
|
"attributes": {
|
|
|
|
"ApproximateReceiveCount": "2",
|
|
|
|
"SentTimestamp": "1618732371814",
|
|
|
|
"SenderId": "AIDAIT2UOQQY3AUEKVGXU",
|
|
|
|
"ApproximateFirstReceiveTimestamp": "1618732640317"
|
|
|
|
},
|
|
|
|
"messageAttributes": {},
|
|
|
|
"md5OfMessageAttributes": None,
|
|
|
|
"md5OfBody": "a0191fc5ea3705340c088e457c31095b",
|
|
|
|
"eventSource": "aws:sqs",
|
|
|
|
"eventSourceARN": "arn:aws:sqs:us-east-1:143841941773:to-elk",
|
|
|
|
"awsRegion": "us-east-1"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2021-05-20 09:28:02 +00:00
|
|
|
lambda_handler(demo_event, {})
|
|
|
|
|
|
|
|
|