forked from guoguo12/global-entry-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
91 lines (75 loc) · 2.99 KB
/
main.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
from datetime import datetime, timedelta
import logging
import sys
import os
import requests
import json
from tweepy import Client, Forbidden
# from keys import twitter_credentials # Only enable for local testing
LOGGING_FORMAT = '%(asctime)s %(name)-12s %(levelname)-8s %(message)s'
# Configure the logging to use AWS Lambda's logging handler
logging.basicConfig(
level=logging.INFO,
format='%(asctime)s.%(msecs)03d %(levelname)s [%(filename)s:%(lineno)d] - %(message)s',
datefmt='%Y-%m-%d %H:%M:%S',
handlers=[
logging.StreamHandler(sys.stdout)
]
)
# LAX is good for testing
LOCATIONS = [
('BNA', 10260),
# ('MEM', 13621),
# ('LAX', 5180)
]
DELTA = 12 # Weeks
SCHEDULER_API_URL = 'https://ttp.cbp.dhs.gov/schedulerapi/locations/{location}/slots?startTimestamp={start}&endTimestamp={end}'
TTP_TIME_FORMAT = '%Y-%m-%dT%H:%M'
NOTIF_MESSAGE = 'New appointment slot open at {location}: {date}'
MESSAGE_TIME_FORMAT = '%A, %B %d, %Y at %I:%M %p'
def tweet(message):
logging.info('Trying Tweet')
try:
t.create_tweet(text=message)
except Forbidden as e:
logging.error(str(e))
if "duplicate content" in str(e):
logging.error("This tweet was not posted because it contains duplicate content.")
else:
logging.error("You do not have permission to perform this action.")
def check_for_openings(location_name, location_code):
start = datetime.now()
end = start + timedelta(weeks=DELTA)
url = SCHEDULER_API_URL.format(location=location_code,
start=start.strftime(TTP_TIME_FORMAT),
end=end.strftime(TTP_TIME_FORMAT))
try:
results = requests.get(url).json() # List of flat appointment objects
except requests.ConnectionError:
logging.exception('Could not connect to scheduler API')
sys.exit(1)
for result in results:
if result['active'] > 0:
logging.info('Opening found for {}'.format(location_name))
timestamp = datetime.strptime(result['timestamp'], TTP_TIME_FORMAT)
message = NOTIF_MESSAGE.format(location=location_name,
date=timestamp.strftime(MESSAGE_TIME_FORMAT))
logging.info('Tweeting: ' + message)
tweet(message)
return # Halt on first match
logging.info('No openings for {}'.format(location_name))
def main():
logging.info('Starting checks (locations: {})'.format(len(LOCATIONS)))
for location_name, location_code in LOCATIONS:
check_for_openings(location_name, location_code)
def lambda_handler(event, context):
logging.info('## ENVIRONMENT VARIABLES')
logging.info(os.environ['AWS_LAMBDA_LOG_GROUP_NAME'])
logging.info(os.environ['AWS_LAMBDA_LOG_STREAM_NAME'])
logging.info('## EVENT')
logging.info(event)
twitter_credentials = json.loads(os.environ.get("TWTR"))
main()
if __name__ == "__main__":
t = Client(**twitter_credentials)
main()