1.0.9 • Published 5 years ago

geofence v1.0.9

Weekly downloads
5
License
ISC
Repository
github
Last release
5 years ago

Geofence

Simple geofencing using Google or other geolocation providers's API

NPM NPM Downloads

  • Check the current location's distance/duration againts the destination
  • Caches the distances to reduce geolocation API calls
  • Accepts callbacks for finding current location
  • Accepts callbacks for when inside the fence

Screenshot

examples/cli.js

node cli.js --apiKey=$apiKey --destination="San Francisco, CA" --mode=driving --updateInterval=1 --fenceDurationValue=25

Output example

Installation

Install with npm:

npm install geofence --save

Usage

The current location and destination can be address or lat/long. See Google's Distance Matrix API

let options = {
  // You can get it from here: https://cloud.google.com/maps-platform/
  apiKey: "ENTER YOUR API HERE", // Enter your own api key
  updateInterval: 5,  // Update current location (in seconds)

  // API function to get the current location.
  // It should return a string that is an address or lat/long
  // See Google's Distance Matrix API:
  // https://developers.google.com/maps/documentation/distance-matrix/intro
  getCurrentLocation: getCurrentLocation,

  // Callback for when we are inside the fence (optional)
  insideGeofenceCallBack: insideGeofenceCallBack,

  // Callback function to be called whenever the 
  // current location and distance is updated (optional)
  updateDistanceCallBack: updateDistanceCallBack,

  loopForever: false,  // Stop/continue once we are inside the fence

  activateFenceOn: "duration", // 'duration' OR 'distance' OR 'either'
  fenceDurationValue: 25 * 60, // range of the fence in seconds
  fenceDistanceValue: 1000, // range of the fence in meters
};

let locationSepc = {
  destination: "Oakland, CA", // Can be address or lat/long
  mode: "driving" //
};
//-----------------------------------------------------------------------------
var geofence = require("geofence")(options, locationSepc);

geofence.start(options);

Examples

  • examples/example.js: Simple example
  • examples/cli.js: demonstrates running with command line arguments:
    • node cli.js --apiKey=YOUR_API_KEY --destination="San Francisco, CA"
  • examples/termux.js: demonstrates running inside Termux and Termux-API on Android using device GPS and system notifications. Run with:
    • node termux.js --apiKey=YOUR_API_KEY --destination="320 Main St, Venice, CA" --fenceDurationValue=300 --updateInterval=10
    • examples/termux_prompt.js: demonstrates running inside Termux and Termux-API on Android using device GPS and system notifications. It receives the inputs from command prompt:
    • node termux_prompt.js
1.0.9

5 years ago

1.0.8

5 years ago

1.0.7

5 years ago

1.0.6

5 years ago

1.0.5

5 years ago

1.0.4

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago