-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandler.py
40 lines (30 loc) · 882 Bytes
/
handler.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
import logging
from etl import extract, transform, load
from db import connect
import notify as n
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
stream_handler = logging.StreamHandler()
stream_handler.setFormatter(formatter)
logger.addHandler(stream_handler)
def app(event, context):
response = None
try:
logger.info('Extract')
data = extract()
logger.info('Transform')
covid_df = transform(data)
conn = connect()
logger.info('Load')
load(conn, covid_df)
response = {
"statusCode": 200,
}
except (Exception) as err:
n.notify("Error in the handler")
logger.error(err)
response = {
"statusCode": 500,
}
return response