A serverless solution to calculate and manage deliveries by a driver to customers in realtime. This is a work-in-progress/prototype built on ArcGIS Online and Pubnub.
- Serverless architecture using ArcGIS Online and PubNub cloud solutions.
- Use ArcGIS Online to generate optimal delivery routes with drive-time geofences.
- PubNub Function for realtime geofence-based triggering of imminent delivery alerts.
- Secure communication between PubNub Function and ArcGIS Online.
- ArcGIS JS API Delivery Tracking App.
- Simulator app.
- Local clone of this repo.
- Local web server pointing to the clone of this repo.
- Free ArcGIS Developer account.
- PubNub account.
The demo consists of a JavaScript Delivery Tracking app, ArcGIS Online hosted layers to store and analyze spatial data, and a PubNub function that uses those hosted layers in real-time to monitor driver location updates from the field and notify customers as their deliveries get close.
The Delivery Tracking app uses ArcGIS Online to generate the optimal route from the driver to the randomly selected customers. ArcGIS Online will then also generate DriveTime areas. These are polygons that represent an area <= 5 minutes' drive from the customer. PubNub monitors the driver location in relation to these DriveTime areas and alerts the customer when the driver is 5 minutes away.
This demo uses one driver (although it can handle any number) and picks randomly from a set of 30 fictional customers around Manhattan. The demo also includes a Driver Simulator that mimmicks the driver following the generated delivery route.
There are 3 high-level steps to getting this demo working in your own environment.
- ArcGIS Online: Create geographic hosted layers and an Application (for authentication token generation). These layers are geospatially-enabled services.
- PubNub: Configure a new Function to use the above layers and application token configuration.
- Locally: Configure the Delivery Tracking App (index.html) and Driver Simulator to use the above PubNub and ArcGIS Online components.
- Sign in at developers.arcgis.com.
- Create an application. You can call it whatever you like and give it any tags. Once created, take note of the
Client ID
andClient Secret
. You'll use these when you configure the PubNub Function below. - Create the DeliveryTracking layers. These are REST-enabled spatial database tables hosted in the ArcGIS Online cloud. They will store points, lines and polygons that are used by the app:
- Log in at arcgis.com with your Developer Account
- Browse to the
Content
section. - Select
Add Item
->From my computer
. - Browse to the DeliveryTracking.sd file. Ensure the
Publish this file as a hosted layer
checkbox is checked. Upload the file. - Once ArcGIS Online has finished creating the layer, make a note of the service URL found at the bottom-right of the newly created item's page.
- Create the DeliveryDriverSim hosted layers. These are used by the demo's Driver Simulator. Repeat step 3, but use the DeliveryDriverSim.sd file.
- Sign in at pubnub.com.
- Make a note of the Demo Project's Demo Keyset's
Publish
andSubscribe
keys from the Admin panel. - Create a Module named
Delivery Tracking Module
and a Function within it namedDelivery Tracking Function
(those are just suggestions you can pick whatever names you want). When prompted choose the following (these must be as specified):- Event type:
Before Publish or Fire
- Channel:
all_driver_updates
- Event type:
- Copy the contents of the driver-location-update.js file into the PubNub Function and Save it.
-
Configure the PubNub Function:
- Update
clientID
andclientSecret
with the Client ID and Client Secret from step 1.2. - Update
baseURL
with the DeliveryTracking URL from step 1.3.v. - Set (and save) the Test Payload with:
{ "driverId": "220C9781-DEB7-40F8-8452-2B6E238D9C33", "lat": 40.778215274460635, "lng": -73.97792446022514 }
- Save and start (or restart) the module.
- Publish the test payload and ensure the output shows no errors.
- Update
-
Configure the Delivery Tracking app. Edit index.html and locate the
initConfig()
function:- Set the PubNub keys from step 2.2.
- Set the URLs to the Feature Service URLs from steps 1.3 (
serviceURL
) and 1.4 (simServiceURL
).
-
Configure the Driver Simulator. Edit simulate-driver.html and locate the
initConfig()
function:- Set the PubNub keys from step 2.2.
- Set the URLs to the Feature Service URLs from steps 1.3 (
serviceURL
) and 1.4 (simServiceURL
).
- ArcGIS for Developers
- PubNub Functions
- ArcGIS Blog
- @esri on twitter
Find a bug or want to request a new feature? Please let us know by submitting an issue.
Esri welcomes contributions from anyone and everyone. Please see our guidelines for contributing.
Copyright 2017 Esri
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
A copy of the license is available in the repository's license.txt file