mirror of https://github.com/pelias/api.git
Diana Shkolnikov
9 years ago
4 changed files with 125 additions and 57 deletions
@ -0,0 +1,29 @@
|
||||
var proxy = require('express-http-proxy'); |
||||
|
||||
function addRoutes(app, peliasConfig) { |
||||
if (!peliasConfig.hasOwnProperty('legacyUrl')) { |
||||
return; |
||||
} |
||||
|
||||
var sendToLegacy = proxy(peliasConfig.legacyUrl); |
||||
|
||||
// api root
|
||||
app.get( '/', sendToLegacy ); |
||||
|
||||
// place API
|
||||
app.get( '/place', sendToLegacy); |
||||
|
||||
// suggest APIs
|
||||
app.get( '/suggest', sendToLegacy ); |
||||
app.get( '/suggest/nearby', sendToLegacy ); |
||||
app.get( '/suggest/coarse',sendToLegacy ); |
||||
|
||||
// search APIs
|
||||
app.get( '/search', sendToLegacy); |
||||
app.get( '/search/coarse', sendToLegacy); |
||||
|
||||
// reverse API
|
||||
app.get( '/reverse', sendToLegacy ); |
||||
} |
||||
|
||||
module.exports.addRoutes = addRoutes; |
@ -0,0 +1,90 @@
|
||||
var reverseQuery = require('./query/reverse'); |
||||
|
||||
/** ----------------------- sanitisers ----------------------- **/ |
||||
var sanitisers = { |
||||
place: require('../sanitiser/place'), |
||||
search: require('../sanitiser/search'), |
||||
reverse: require('../sanitiser/reverse') |
||||
}; |
||||
|
||||
/** ----------------------- controllers ----------------------- **/ |
||||
|
||||
var controllers = { |
||||
index: require('../controller/index'), |
||||
place: require('../controller/place'), |
||||
search: require('../controller/search') |
||||
}; |
||||
|
||||
/** ----------------------- controllers ----------------------- **/ |
||||
|
||||
var postProc = { |
||||
renamePlacenames: require('./middleware/renamePlacenames'), |
||||
geocodeJSON: require('./middleware/geocodeJSON'), |
||||
sendJSON: require('./middleware/sendJSON') |
||||
}; |
||||
|
||||
/** |
||||
* Append routes to app |
||||
* |
||||
* @param {object} app |
||||
* @param {object} peliasConfig |
||||
*/ |
||||
function addRoutes(app, peliasConfig) { |
||||
|
||||
/** ------------------------- routers ------------------------- **/ |
||||
|
||||
var routers = { |
||||
index: createRouter([ |
||||
controllers.index() |
||||
]), |
||||
search: createRouter([ |
||||
sanitisers.search.middleware, |
||||
controllers.search(), |
||||
postProc.renamePlacenames(), |
||||
postProc.geocodeJSON(peliasConfig), |
||||
postProc.sendJSON |
||||
]), |
||||
reverse: createRouter([ |
||||
sanitisers.reverse.middleware, |
||||
controllers.search(undefined, reverseQuery), |
||||
postProc.renamePlacenames(), |
||||
postProc.geocodeJSON(peliasConfig), |
||||
postProc.sendJSON |
||||
]), |
||||
place: createRouter([ |
||||
sanitisers.place.middleware, |
||||
controllers.place(), |
||||
postProc.renamePlacenames(), |
||||
postProc.geocodeJSON(peliasConfig), |
||||
postProc.sendJSON |
||||
]) |
||||
}; |
||||
|
||||
|
||||
var base = '/v1/'; |
||||
|
||||
// api root
|
||||
app.get ( base, routers.index ); |
||||
app.get ( base + 'place', routers.place ); |
||||
app.get ( base + 'autocomplete', routers.search ); |
||||
app.get ( base + 'search', routers.search ); |
||||
app.post( base + 'search', routers.search ); |
||||
app.get ( base + 'reverse', routers.reverse ); |
||||
} |
||||
|
||||
/** |
||||
* Helper function for creating routers |
||||
* |
||||
* @param {[{function}]} functions |
||||
* @returns {express.Router} |
||||
*/ |
||||
function createRouter(functions) { |
||||
var router = Router(); // jshint ignore:line
|
||||
functions.forEach(function (f) { |
||||
router.use(f); |
||||
}); |
||||
return router; |
||||
} |
||||
|
||||
|
||||
module.exports.addRoutes = addRoutes; |
Loading…
Reference in new issue