Python black format fixes

This commit is contained in:
2023-12-01 23:50:27 +09:00
parent 4f3d8d7800
commit 1e4b210670
5 changed files with 398 additions and 488 deletions
+65 -74
View File
@@ -2,11 +2,12 @@
reverse geolacte functions
"""
import requests
import re
import requests
from utils.long_lat import long_lat_reg
from utils.string_helpers import only_latin_chars
def reverse_geolocate(longitude, latitude, map_type, args):
"""
wrapper to call to either the google or openstreetmap
@@ -27,16 +28,13 @@ def reverse_geolocate(longitude, latitude, map_type, args):
# detect and convert
lat_long = long_lat_reg(longitude=longitude, latitude=latitude)
# which service to use
if map_type == 'google':
return reverse_geolocate_google(lat_long['longitude'], lat_long['latitude'], args)
elif map_type == 'openstreetmap':
return reverse_geolocate_open_street_map(lat_long['longitude'], lat_long['latitude'], args)
if map_type == "google":
return reverse_geolocate_google(lat_long["longitude"], lat_long["latitude"], args)
elif map_type == "openstreetmap":
return reverse_geolocate_open_street_map(lat_long["longitude"], lat_long["latitude"], args)
else:
return {
'Country': '',
'status': 'ERROR',
'error': 'Map type not valid'
}
return {"Country": "", "status": "ERROR", "error": "Map type not valid"}
def reverse_geolocate_init(longitude, latitude):
"""
@@ -52,22 +50,23 @@ def reverse_geolocate_init(longitude, latitude):
"""
# basic dict format
geolocation = {
'CountryCode': '',
'Country': '',
'State': '',
'City': '',
'Location': '',
"CountryCode": "",
"Country": "",
"State": "",
"City": "",
"Location": "",
# below for error reports
'status': '',
'error_message': ''
"status": "",
"error_message": "",
}
# error if long/lat is not valid
latlong_re = re.compile(r'^\d+\.\d+$')
latlong_re = re.compile(r"^\d+\.\d+$")
if not latlong_re.match(str(longitude)) or not latlong_re.match(str(latitude)):
geolocation['status'] = 'ERROR'
geolocation['error_message'] = f"Latitude {latitude} or Longitude {longitude} are not valid"
geolocation["status"] = "ERROR"
geolocation["error_message"] = f"Latitude {latitude} or Longitude {longitude} are not valid"
return geolocation
def reverse_geolocate_open_street_map(longitude, latitude, args):
"""
OpenStreetMap reverse lookcation lookup
@@ -87,24 +86,19 @@ def reverse_geolocate_open_street_map(longitude, latitude, args):
"""
# init
geolocation = reverse_geolocate_init(longitude, latitude)
if geolocation['status'] == 'ERROR':
if geolocation["status"] == "ERROR":
return geolocation
# query format
query_format = 'jsonv2'
query_format = "jsonv2"
# language to return (english)
language = 'en-US,en'
language = "en-US,en"
# build query
base = 'https://nominatim.openstreetmap.org/reverse.php?'
base = "https://nominatim.openstreetmap.org/reverse.php?"
# parameters
payload = {
'format': query_format,
'lat': latitude,
'lon': longitude,
'accept-language': language
}
payload = {"format": query_format, "lat": latitude, "lon": longitude, "accept-language": language}
# if we have an email, add it here
if args.email:
payload['email'] = args.email
payload["email"] = args.email
url = f"{base}"
# timeout in seconds
timeout = 60
@@ -117,16 +111,16 @@ def reverse_geolocate_open_street_map(longitude, latitude, args):
# type map
# Country to Location and for each in order of priority
type_map = {
'CountryCode': ['country_code'],
'Country': ['country'],
'State': ['state'],
'City': ['city', 'city_district', 'state_district'],
'Location': ['county', 'town', 'suburb', 'hamlet', 'neighbourhood', 'road']
"CountryCode": ["country_code"],
"Country": ["country"],
"State": ["state"],
"City": ["city", "city_district", "state_district"],
"Location": ["county", "town", "suburb", "hamlet", "neighbourhood", "road"],
}
# if not error
if 'error' not in response.json():
if "error" not in response.json():
# get address block
addr = response.json()['address']
addr = response.json()["address"]
# loop for locations
for loc_index, sub_index in type_map.items():
for index in sub_index:
@@ -137,12 +131,13 @@ def reverse_geolocate_open_street_map(longitude, latitude, args):
# if index in addr and not geolocation[loc_index]:
# geolocation[loc_index] = addr[index]
else:
geolocation['status'] = 'ERROR'
geolocation['error_message'] = response.json()['error']
geolocation["status"] = "ERROR"
geolocation["error_message"] = response.json()["error"]
print(f"Error in request: {geolocation['error']}")
# return
return geolocation
def reverse_geolocate_google(longitude, latitude, args):
"""
Google Maps reverse location lookup
@@ -163,25 +158,21 @@ def reverse_geolocate_google(longitude, latitude, args):
# init
geolocation = reverse_geolocate_init(longitude, latitude)
temp_geolocation = geolocation.copy()
if geolocation['status'] == 'ERROR':
if geolocation["status"] == "ERROR":
return geolocation
# sensor (why?)
sensor = 'false'
sensor = "false"
# language, so we get ascii en back
language = 'en'
language = "en"
# request to google
# if a google api key is used, the request has to be via https
protocol = 'https://' if args.google_api_key else 'http://'
protocol = "https://" if args.google_api_key else "http://"
base = "maps.googleapis.com/maps/api/geocode/json?"
# build the base params
payload = {
'latlng': f"{latitude},{longitude}",
'language': language,
'sensor': sensor
}
payload = {"latlng": f"{latitude},{longitude}", "language": language, "sensor": sensor}
# if we have a google api key, add it here
if args.google_api_key:
payload['key'] = args.google_api_key
payload["key"] = args.google_api_key
# build the full url and send it to google
url = f"{protocol}{base}"
# timeout in seconds
@@ -195,22 +186,22 @@ def reverse_geolocate_google(longitude, latitude, args):
# type map
# For automated return of correct data into set to return
type_map = {
'CountryCode': ['country'],
'Country': ['country'],
'State': ['administrative_area_level_1', 'administrative_area_level_2'],
'City': ['locality', 'administrative_area_level_3'],
'Location': ['sublocality_level_1', 'sublocality_level_2', 'route'],
"CountryCode": ["country"],
"Country": ["country"],
"State": ["administrative_area_level_1", "administrative_area_level_2"],
"City": ["locality", "administrative_area_level_3"],
"Location": ["sublocality_level_1", "sublocality_level_2", "route"],
}
# print("Error: {}".format(response.json()['status']))
if response.json()['status'] == 'OK':
if response.json()["status"] == "OK":
# first entry for type = premise
for entry in response.json()['results']:
for entry in response.json()["results"]:
for sub_entry in entry:
if sub_entry == 'types' and (
'premise' in entry[sub_entry] or
'route' in entry[sub_entry] or
'street_address' in entry[sub_entry] or
'sublocality' in entry[sub_entry]
if sub_entry == "types" and (
"premise" in entry[sub_entry]
or "route" in entry[sub_entry]
or "street_address" in entry[sub_entry]
or "sublocality" in entry[sub_entry]
):
# print("Entry {}: {}".format(sub_entry, entry[sub_entry]))
# print("Address {}".format(entry['address_components']))
@@ -225,33 +216,33 @@ def reverse_geolocate_google(longitude, latitude, args):
for loc_index, sub_index in type_map.items():
for index in sub_index:
# this is an array, so we need to loop through each
for addr in entry['address_components']:
for addr in entry["address_components"]:
# in types check that index is in there
# and the location is not yet set
# also check that entry is in LATIN based
# NOTE: fallback if all are non LATIN?
if index in addr['types'] and not geolocation[loc_index]:
if index in addr["types"] and not geolocation[loc_index]:
# for country code we need to use short name,
# else we use long name
if loc_index == 'CountryCode':
if only_latin_chars(addr['short_name']):
geolocation[loc_index] = addr['short_name']
if loc_index == "CountryCode":
if only_latin_chars(addr["short_name"]):
geolocation[loc_index] = addr["short_name"]
elif not temp_geolocation[loc_index]:
temp_geolocation[loc_index] = addr['short_name']
temp_geolocation[loc_index] = addr["short_name"]
else:
if only_latin_chars(addr['long_name']):
geolocation[loc_index] = addr['long_name']
if only_latin_chars(addr["long_name"]):
geolocation[loc_index] = addr["long_name"]
elif not temp_geolocation[loc_index]:
temp_geolocation[loc_index] = addr['long_name']
temp_geolocation[loc_index] = addr["long_name"]
# check that all in geoloaction are filled and if not fille from temp_geolocation dictionary
for loc_index in type_map:
if not geolocation[loc_index] and temp_geolocation[loc_index]:
geolocation[loc_index] = temp_geolocation[loc_index]
# write OK status
geolocation['status'] = response.json()['status']
geolocation["status"] = response.json()["status"]
else:
geolocation['error_message'] = response.json()['error_message']
geolocation['status'] = response.json()['status']
geolocation["error_message"] = response.json()["error_message"]
geolocation["status"] = response.json()["status"]
print(f"Error in request: {geolocation['status']} {geolocation['error_message']}")
# return
return geolocation