You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

92 lines
2.2 KiB

11 years ago
{
"name": "pelias-api",
"version": "0.0.0-development",
"author": "pelias",
11 years ago
"description": "Pelias API",
"homepage": "https://github.com/pelias/api",
"license": "MIT",
"main": "index.js",
"bin": "./bin/start",
11 years ago
"scripts": {
"ciao": "node node_modules/ciao/bin/ciao -c test/ciao.json test/ciao",
"coverage": "node_modules/.bin/istanbul cover test/unit/run.js",
"docs": "./bin/generate-docs",
"lint": "jshint .",
"start": "./bin/start",
"test": "npm run unit",
7 years ago
"travis": "npm test",
"unit": "./bin/units",
"validate": "npm ls",
"config": "node -e \"console.log(JSON.stringify(require( 'pelias-config' ).generate(require('./schema')), null, 2))\"",
"prune": "npm prune"
11 years ago
},
"repository": {
"type": "git",
"url": "https://github.com/pelias/api.git"
11 years ago
},
"keywords": [
"pelias",
"elasticsearch",
"webview"
],
"bugs": {
"url": "https://github.com/pelias/api/issues"
},
"engines": {
"node": ">=6.0.0"
11 years ago
},
"dependencies": {
"@mapbox/geojson-extent": "^0.3.1",
"addressit": "1.5.0",
"async": "^2.0.0",
"check-types": "^7.0.0",
"elasticsearch": "^15.0.0",
"elasticsearch-exceptions": "0.0.4",
"express": "^4.8.8",
"geojson": "^0.5.0",
"geolib": "^2.0.18",
"iso-639-3": "^1.0.0",
"joi": "^14.0.0",
"locale": "^0.1.0",
"lodash": "^4.17.4",
"markdown": "^0.5.0",
"morgan": "^1.8.2",
"pelias-categories": "^1.2.0",
feat(autocomplete) add hard distance filter to short focus.point queries Short autocomplete inputs are very difficult to serve in a performant and low-latency way. With shorter inputs, many more documents match for just about any input string. In our testing, one to three character input texts generally match up to 100 million documents out of a 560 million document full planet build. There's really no way to make scoring 100 million documents fast, so in order to achieve acceptable performance (ideally, <100ms P99 latency), it's worth looking at ways to either avoid querying Elasticsearch or reducing the scope of autocomplete queries. Short autocomplete queries without a focus.point parameter can be cached. There are only 47,000 possible 1-3 character alphanumerical inputs. At this time, caching is outside the scope of Pelias itself but can easily be implemented with Varnish, Nginx, Fastly, Cloudfront, and lots of other tools and services. Queries with a `focus.point` are effectively uncachable however, since the coordinate chosen will often be unique. This PR uses the `focus.point` coordinate to build a hard filter limiting the search to documents only within a certain radius of the coordinate. This can reduce the number of documents searched and improve performance, while still returning results that are useful. It takes two parameters, driven by `pelias-config`: - `api.autocomplete.focusHardLimitTextLength': the maximum length of text for which a hard distance filter will be constructed - `api.autocomplete.focusHardLimitMultiplier`: the length of the input text will be multiplied by this number to get the total hard filter radius in kilometers. For example, with `focusHardLimitTextLength` 4, and `focusHardLimitMultiplier` 50, the following hard filters would be constructed: | text length | max distance | | ---- | ----| | 1 | 50 | | 2 | 100 | | 3 | 150 | | 4+ | unlimited |
6 years ago
"pelias-config": "^3.6.0",
"pelias-labels": "^1.8.0",
"pelias-logger": "^1.2.0",
"pelias-microservice-wrapper": "^1.7.0",
"pelias-model": "^5.5.2",
"pelias-query": "^9.1.1",
"pelias-sorting": "^1.2.0",
"predicates": "^2.0.0",
"retry": "^0.12.0",
"stable": "^0.1.8",
"stats-lite": "^2.0.4",
"through2": "^2.0.3"
},
"devDependencies": {
"ciao": "^1.0.0",
"difflet": "^1.0.1",
"istanbul": "^0.4.2",
"jshint": "^2.5.6",
"pelias-mock-logger": "^1.3.0",
"precommit-hook": "^3.0.0",
"proxyquire": "^2.0.0",
"source-map": "^0.7.0",
"tap-dot": "^2.0.0",
"tape": "^4.5.1",
"tmp": "^0.0.33"
},
"pre-commit": [
"lint",
"prune",
"validate",
7 years ago
"test"
],
"release": {
"branch": "production",
"success": []
}
}