aboutsummaryrefslogtreecommitdiff
path: root/ptv_client.py
diff options
context:
space:
mode:
Diffstat (limited to 'ptv_client.py')
-rw-r--r--ptv_client.py48
1 files changed, 31 insertions, 17 deletions
diff --git a/ptv_client.py b/ptv_client.py
index 652d87b..ec89134 100644
--- a/ptv_client.py
+++ b/ptv_client.py
@@ -18,56 +18,70 @@ from hashlib import sha1
from urllib import request, error, parse
import hmac
import json
-import pprint
import itertools
import os
_ROUTE_TYPE = ["Train", "Tram", "Bus", "Vline", "Night Bus"]
-def get_url(request):
+
+def get_url(req):
key = str.encode(os.environ.get('PTVKEY'))
dev_id = os.environ.get('PTVID')
- request = parse.quote(request) + ('&' if ('?' in request) else '?')
- raw = request + f'devid={dev_id}'
+ req = parse.quote(req) + ('&' if ('?' in req) else '?')
+ raw = req + f'devid={dev_id}'
hashed = hmac.new(key, raw.encode('utf-8'), sha1)
signature = hashed.hexdigest().upper()
return f'http://timetableapi.ptv.vic.gov.au{raw}&signature={signature}'
+
def get_json(url):
try:
- document = request.urlopen(url).read().decode()
+ with request.urlopen(url) as opened:
+ document = opened.read().decode()
+ return json.loads(document)
except error.HTTPError:
print("http error!")
- return
- return json.loads(document)
+
def get_stops(search_result):
- return [{'routes': stop['routes'],
- 'stop_name': stop['stop_name'],
- 'stop_id': stop['stop_id']} for stop in search_result(stops)]
+ return [{
+ 'routes': stop['routes'],
+ 'stop_name': stop['stop_name'],
+ 'stop_id': stop['stop_id']
+ } for stop in search_result['stops']]
+
def get_stop_and_routes(search_result):
- return itertools.chain.from_iterable(
- [[(stop, route) for route in stop['routes']]
- for stop in search_result['stops']])
+ return itertools.chain.from_iterable([[(stop, route)
+ for route in stop['routes']]
+ for stop in search_result['stops']])
+
def search(keyword):
return get_json(get_url(f'/v3/search/{keyword}'))
+
def get_departures(route_type, stop_id, route_id):
- return get_json(get_url(
- f'/v3/departures/route_type/{route_type}/stop/{stop_id}/route/{route_id}'))
+ return get_json(
+ get_url(f'/v3/departures/route_type/{route_type}/stop/{stop_id}'
+ f'/route/{route_id}'))
+
def get_departures_from_stop_and_route(stop, route):
return get_departures(route['route_type'], stop['stop_id'],
route['route_id'])
+
def get_directions(route_id):
return get_json(get_url(f'/v3/directions/route/{route_id}'))
+
def get_direction_names(route_id):
- return {dir['direction_id']: dir['direction_name'] for dir in
- get_directions(route_id)['directions']}
+ return {
+ dir['direction_id']: dir['direction_name']
+ for dir in get_directions(route_id)['directions']
+ }
+
def get_route_type(idx):
return _ROUTE_TYPE[idx]