fxa/packages/fxa-geodb
dschom d96797ae6a
task(CI): Improve nx caching for CI pipelines
Because:
- Not all CI operations where taking advantage of NX caches

This Commit:
- Adjusts nx.json config to ensure correct caching behavior
- Adjusts nx.json config to ensure proper target chains. ie build is dependent on pre-build
- Uses nx to directly run integration tests
- Uses nx to directly run unit tests
- Phases out dependency on generated .list files
- Ensures 'start up' for services for functional tests is done with nx and uses nx caches.
- Creates nx tags to facilitate test commands
- Fixes linter errors encountered
- Updates docker images to nx for builds
- Updates nx ignore files
2023-08-29 11:19:54 -07:00
..
.vscode
db refactor(packages): use workspace references 2020-05-21 10:57:21 -07:00
examples
lib fix(auth): Use maxmind for Stripe tax 2023-02-14 13:32:42 -08:00
scripts/mmdb refactor(packages): use workspace references 2020-05-21 10:57:21 -07:00
test task(many): Remove #unit tags on tests 2023-03-25 13:43:00 -07:00
.eslintrc task(CI): build, unit test, and integration test jobs 2023-01-10 12:52:01 -08:00
.nsprc chore(deps): Updates to address nsp advisory 1179 2020-03-19 10:42:24 -07:00
.prettierignore
README.md task(CI): Improve nx caching for CI pipelines 2023-08-29 11:19:54 -07:00
package.json task(CI): Improve nx caching for CI pipelines 2023-08-29 11:19:54 -07:00
sources.json

README.md

Firefox Accounts GeoDB Repo for Geolocation based services

Provides a wrapper around node-maxmind for getting the location data in an easy-to-read format.

Getting started

Install the module by running yarn add fxa-geodb --dev. Then, include the module in your source file, like so:

var geoDb = require('fxa-geodb')();

You can also pass other options like the path to the database to the require statement, like so:

var geoDb = require('fxa-geodb')({
  dbPath: 'cities-db.mmdb' // Defaults to fxa-geodb/db/cities-db.mmdb
});

--

API

The function returns a location object or throws if the ip was invalid or location data could not be found. Call the function like so:

try {
  const location = geoDb(ip);
  // Use location...
} catch (err) {
  // Handle err
}

The location object has the following properties:

  • accuracy: Accuracy radius in km (number)
  • city: Human readable city name (string)
  • state: Human readable state name (string)
  • stateCode: ISO 3166-2 state code (string)
  • country: Human readable country name (string)
  • countryCode: ISO 3166-1 alpha-2 country code (string)
  • continent: Human readable continent name (string)
  • timeZone: IANA tz database timezone (string)
  • latLong: An object containing two properties:
    • latitude: Latitude (number)
    • longitude: Longitude (number)

For example:

{
  accuracy: 5,
  city: 'Mountain View',
  state: 'California',
  stateCode: 'CA',
  country: 'United States',
  countryCode: 'US',
  continent: 'North America',
  timeZone: 'America/Los_Angeles'
  latLong: {
    latitude: 37.3885,
    longitude: -122.0741
  }
}

A working example is provided in the examples directory.

--

Testing

This package uses Mocha to test its code. By default npm test will test all files under test/.

Test specific tests with the following commands:

# Test only src/test/lib/sentry.spec.ts
npx mocha test/fxa-geodb.js

# Grep for "setupDownloadList"
npx mocha /test/** -g "setupDownloadList"

Refer to Mocha's CLI documentation for more advanced test configuration.

--

Code Coverage

Code coverage is provided with nyc, to run coverage, call yarn cover

--

Updating

A Cron job is provided in lib/maxmind-db-downloader, that can be configured and run like so:

  var maxmindDbDownloader = new MaxmindDbDownloader();
  var targetDirPath = maxmindDbDownloader.createTargetDir('db-name');
  var downloadPromiseFunctions = maxmindDbDownloader.setupDownloadList(
    path.join(__dirname, '..','path-to-sources-file'),
    targetDirPath
  );
  maxmindDbDownloader.setupAutoUpdate('30 30 1 * * 3', downloadPromiseFunctions);

By default, the cron job runs every week on Wednesday at 01:30:30 (UTC -7) and updates the Geodata-DB from Maxmind.

--

Getting involved

Interested in contributing to the development of Firefox Accounts GeoDB repo? Great! Head over to the #fxa:mozilla.org room on Matrix with questions, or jump ahead and fix any of the issues we have.

Please review and understand the Mozilla Community Participation Guidelines before contributing to this project. Also, following the commit guidelines is greatly appreciated.

UPDATE: On March 2020, Mozilla moved from IRC to Matrix. For more information on Matrix, check out the following wiki article: https://wiki.mozilla.org/Matrix.

--

Submitting bugs

You can file issues here on GitHub. Please try to include as much information as you can and under what conditions you saw the issue.

--

Attribution

This product includes GeoLite2 data created by MaxMind, available from http://www.maxmind.com.

--

License

MPL 2.0