-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathavailability.py
126 lines (99 loc) · 4.3 KB
/
availability.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import datetime
import json
import os
import smtplib
import ssl
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from typing import List
import cachetools.func
import pandas as pd
import requests
from retry import retry
headers = {'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36'}
def get_all_district_ids():
district_df_all = None
for state_code in range(1, 40):
response = requests.get("https://cdn-api.co-vin.in/api/v2/admin/location/districts/{}".format(state_code), timeout=3, headers=headers)
district_df = pd.DataFrame(json.loads(response.text))
district_df = pd.json_normalize(district_df['districts'])
if district_df_all is None:
district_df_all = district_df
else:
district_df_all = pd.concat([district_df_all, district_df])
district_df_all.district_id = district_df_all.district_id.astype(int)
district_df_all = district_df_all[["district_name", "district_id"]].sort_values("district_name")
return district_df_all
@cachetools.func.ttl_cache(maxsize=100, ttl=30 * 60)
@retry(KeyError, tries=5, delay=2)
def get_data(URL):
response = requests.get(URL, timeout=3, headers=headers)
data = json.loads(response.text)['centers']
return data
def get_availability(district_ids: List[int], min_age_limit: int):
INP_DATE = datetime.datetime.today().strftime("%d-%m-%Y")
all_date_df = None
for district_id in district_ids:
print(f"checking for INP_DATE:{INP_DATE} & DIST_ID:{district_id}")
URL = "https://cdn-api.co-vin.in/api/v2/appointment/sessions/public/calendarByDistrict?district_id={}&date={}".format(district_id, INP_DATE)
data = get_data(URL)
df = pd.DataFrame(data)
if len(df):
df = df.explode("sessions")
df['min_age_limit'] = df.sessions.apply(lambda x: x['min_age_limit'])
df['available_capacity'] = df.sessions.apply(lambda x: x['available_capacity'])
df['date'] = df.sessions.apply(lambda x: x['date'])
df = df[["date", "min_age_limit", "available_capacity", "pincode", "name", "state_name", "district_name", "block_name", "fee_type"]]
if all_date_df is not None:
all_date_df = pd.concat([all_date_df, df])
else:
all_date_df = df
if all_date_df is not None:
all_date_df = all_date_df.drop(["block_name"], axis=1).sort_values(["min_age_limit", "available_capacity", "date", "district_name"], ascending=[True, False, True, True])
all_date_df = all_date_df[all_date_df.min_age_limit >= min_age_limit]
all_date_df = all_date_df[all_date_df.available_capacity>0]
all_date_df.set_index('date', inplace=True)
return all_date_df
return pd.DataFrame()
def send_email(data_frame, age):
# Used most of code from https://realpython.com/python-send-email/ and modified
if data_frame is None or len(data_frame.index) == 0:
print("Empty Data")
return
sender_email = os.environ['SENDER_EMAIL']
receiver_email = os.environ['RECEIVER_EMAIL']
message = MIMEMultipart("alternative")
message["Subject"] = "Availability for Max Age {} Count {}".format(age, len(data_frame.index))
message["From"] = sender_email
message["To"] = receiver_email
text = """\
Hi,
Please refer vaccine availability"""
html_header = """\
<html>
<body>
<p>
"""
html_footer = """\
</p>
</body>
</html>
"""
html = "{}{}{}".format(html_header, data_frame.to_html(), html_footer)
part1 = MIMEText(text, "plain")
part2 = MIMEText(html, "html")
message.attach(part1)
message.attach(part2)
context = ssl.create_default_context()
with smtplib.SMTP_SSL("smtp.gmail.com", 465, context=context) as server:
server.login(sender_email, os.environ['SENDER_PASSWORD'])
server.sendmail(
sender_email, receiver_email, message.as_string()
)
if __name__ == "__main__":
Ahmedabad = 154
Ahmedabad_Corporation = 770
dist_ids = [Ahmedabad, Ahmedabad_Corporation]
min_age_limit = 18
availability_data = get_availability(dist_ids, min_age_limit)
send_email(availability_data, min_age_limit)