-
Notifications
You must be signed in to change notification settings - Fork 5
Home
pinpoint is a script that is able to find the location of your Mac using Google's GeoCoding APIs. It works based off of the same idea as Prey, Find My iPhone, or LoJack. However, pinpoint is different in a few ways:
- Continuously checks for location updates in the background
- Stores location locally on disk in a plist for easy parsing
- Has no server backend
- Free
pinpoint requires a wireless adapter to obtain location data. On older Macs that did not ship with a wireless adapter this script will exit. Your Mac does not need to be connected to an active SSID for location data to be found, just enabled. If you normally keep your wireless adapter disabled pinpoint can enable it for the run and disable it post run.
First some terminology.
-
Geocoding - is the process of converting a postal address into geographical coordinates.
-
Reverse Geocoding - is the process of converting geographical coordinates into a human readable address (frequently a street address).
For pinpoint we are sending information on wireless networks; MAC addresses, signal strength, SSID names, and other network details to APIs. When the API call returns data we get Latitude and Longitude. After we have gotten the Latitude and Longitude and make a secondary API call to Reverse Geocode the data into an address. So that the terminology doesn't overlap, pinpoint uses the word 'lookup' for geocoding and 'address' lookup for reverse geocoding.
This script only has the option of using Google's Geocoding API for lookup and address (reverse) lookup requests. It also uses Google's Elevation API to find your altitude.
This works by scanning for wireless networks using Apple's airport
command located:
/System/Library/PrivateFrameworks/Apple80211.framework/Versions/A/Resources/airport
After a XML list of near wireless networks is returned we process that data to find the 5 wireless access point's (WAP) that are closest to your Mac. We do this by sorting based on the wireless signal strength. Then we send those networks to Google's Geocoding API in a http GET request in order to find our Latitude and Longitude. Followed by a secondary API call to do the address lookup.
This API used to have the following limits:
- 2,500 free requests per day
- 10 requests per second
Sadly as of July 18th 2018 it now requires you to enable billing on your API account. You are supposed to get a $200 credit to your account per month and as far as I can see this means you could therefore call their APIs a total of 40,000 times per month so 10,000 for Geolocation + 10,000 for Geocoding plus 10,000 for Elevation should be safe. You are also supposed to be able to set billing/usage limits for your API account so if you exceed these figures it should simply reject requests and prevent you incurring (additional) costs.
It is your responsibility to set your API account up appropriately and to be aware of the potential cost consequences.
To use the service you will need an API key. Please refer to the Google APIs for using the Google location service api. Get your key here.
Additional information can be found: https://developers.google.com/maps/documentation/geocoding/usage-limits