Browse Source

Merge pull request #123 from pelias/add-logging#8

add logging
pull/131/head
Severyn Kozak 10 years ago
parent
commit
beb6dfb790
  1. 7
      README.md
  2. 5
      app.js
  3. 5
      middleware/500.js
  4. 20
      middleware/access_log.js
  5. 5
      package.json
  6. 4
      query/search.js
  7. 4
      query/suggest.js
  8. 3
      sanitiser/coarse.js
  9. 3
      sanitiser/doc.js
  10. 3
      sanitiser/search.js
  11. 3
      sanitiser/suggest.js
  12. 5
      service/mget.js
  13. 5
      service/search.js
  14. 5
      service/suggest.js
  15. 5
      src/logger.js

7
README.md

@ -33,6 +33,13 @@ The API ships with several convenience commands (runnable via `npm`):
* `npm run docs`: generate API documentation * `npm run docs`: generate API documentation
* `npm run coverage`: generate code coverage reports * `npm run coverage`: generate code coverage reports
## pelias-config
The API recognizes the following properties under the top-level `api` key in your `pelias.json` config file:
* `accessLog`: (*optional*) The name of the format to use for access logs; may be any one of the
[predefined values](https://github.com/expressjs/morgan#predefined-formats) in the `morgan` package. Defaults to
`"common"`; if set to `false`, or an otherwise falsy value, disables access-logging entirely.
## Contributing ## Contributing
Please fork and pull request against upstream master on a feature branch. Pretty please; provide unit tests and script Please fork and pull request against upstream master on a feature branch. Pretty please; provide unit tests and script

5
app.js

@ -1,5 +1,10 @@
var app = require('express')(); var app = require('express')();
var peliasConfig = require( 'pelias-config' ).generate().api;
if( peliasConfig.accessLog ){
app.use( require( './middleware/access_log' )( peliasConfig.accessLog ) );
}
/** ----------------------- middleware ----------------------- **/ /** ----------------------- middleware ----------------------- **/

5
middleware/500.js

@ -1,9 +1,8 @@
var logger = require( '../src/logger' ); var logger = require( 'pelias-logger' ).get( 'middleware-500' );
// handle application errors // handle application errors
function middleware(err, req, res, next) { function middleware(err, req, res, next) {
logger.error( 'Error:', err ); logger.error( 'Error: `%s`. Stack trace: `%s`.', err, err.stack );
logger.error( 'Stack trace:', err.trace );
res.header('Cache-Control','no-cache'); res.header('Cache-Control','no-cache');
if( res.statusCode < 400 ){ res.status(500); } if( res.statusCode < 400 ){ res.status(500); }
res.json({ error: typeof err === 'string' ? err : 'internal server error' }); res.json({ error: typeof err === 'string' ? err : 'internal server error' });

20
middleware/access_log.js

@ -0,0 +1,20 @@
/**
* Create a middleware that prints access logs via pelias-logger.
*/
'use strict';
var morgan = require( 'morgan' );
var through = require( 'through2' );
var peliasLogger = require( 'pelias-logger' ).get( 'api' );
function createAccessLogger( logFormat ){
return morgan( logFormat, {
stream: through( function write( ln, _, next ){
peliasLogger.info( ln.toString().trim() );
next();
})
});
}
module.exports = createAccessLogger;

5
package.json

@ -41,6 +41,11 @@
"is-object": "^1.0.1", "is-object": "^1.0.1",
"markdown": "0.5.0", "markdown": "0.5.0",
"pelias-esclient": "0.0.25", "pelias-esclient": "0.0.25",
"pelias-logger": "^0.0.8",
"through2": "0.6.5",
"morgan": "1.5.2",
"pelias-config": "^0.1.4",
"microtime": "1.4.0",
"pelias-suggester-pipeline": "2.0.2" "pelias-suggester-pipeline": "2.0.2"
}, },
"devDependencies": { "devDependencies": {

4
query/search.js

@ -1,10 +1,8 @@
var logger = require('../src/logger'), var queries = require('geopipes-elasticsearch-backend').queries,
queries = require('geopipes-elasticsearch-backend').queries,
sort = require('../query/sort'); sort = require('../query/sort');
function generate( params ){ function generate( params ){
var centroid = null; var centroid = null;
if ( params.lat && params.lon ){ if ( params.lat && params.lon ){

4
query/suggest.js

@ -1,6 +1,5 @@
var logger = require('../src/logger'), var get_layers = require('../helper/layers');
get_layers = require('../helper/layers');
// Build pelias suggest query // Build pelias suggest query
function generate( params, query_mixer, fuzziness ){ function generate( params, query_mixer, fuzziness ){
@ -69,7 +68,6 @@ function generate( params, query_mixer, fuzziness ){
} }
// logger.log( 'cmd', JSON.stringify( cmd.cmd, null, 2 ) );
return cmd.cmd; return cmd.cmd;
} }

3
sanitiser/coarse.js

@ -1,6 +1,5 @@
var logger = require('../src/logger'), var _sanitize = require('../sanitiser/_sanitize'),
_sanitize = require('../sanitiser/_sanitize'),
sanitizers = { sanitizers = {
input: require('../sanitiser/_input'), input: require('../sanitiser/_input'),
size: require('../sanitiser/_size'), size: require('../sanitiser/_size'),

3
sanitiser/doc.js

@ -1,6 +1,5 @@
var logger = require('../src/logger'), var _sanitize = require('../sanitiser/_sanitize'),
_sanitize = require('../sanitiser/_sanitize'),
sanitizers = { sanitizers = {
id: require('../sanitiser/_id'), id: require('../sanitiser/_id'),
details: require('../sanitiser/_details') details: require('../sanitiser/_details')

3
sanitiser/search.js

@ -1,6 +1,5 @@
var logger = require('../src/logger'), var _sanitize = require('../sanitiser/_sanitize'),
_sanitize = require('../sanitiser/_sanitize'),
sanitizers = { sanitizers = {
input: require('../sanitiser/_input'), input: require('../sanitiser/_input'),
size: require('../sanitiser/_size'), size: require('../sanitiser/_size'),

3
sanitiser/suggest.js

@ -1,6 +1,5 @@
var logger = require('../src/logger'), var _sanitize = require('../sanitiser/_sanitize'),
_sanitize = require('../sanitiser/_sanitize'),
sanitizers = { sanitizers = {
input: require('../sanitiser/_input'), input: require('../sanitiser/_input'),
size: require('../sanitiser/_size'), size: require('../sanitiser/_size'),

5
service/mget.js

@ -11,6 +11,9 @@
**/ **/
var peliasLogger = require( 'pelias-logger' ).get( 'service/mget' );
var microtime = require( 'microtime' );
function service( backend, query, cb ){ function service( backend, query, cb ){
// backend command // backend command
@ -20,8 +23,10 @@ function service( backend, query, cb ){
} }
}; };
var startTime = microtime.nowDouble();
// query new backend // query new backend
backend().client.mget( cmd, function( err, data ){ backend().client.mget( cmd, function( err, data ){
peliasLogger.verbose( 'time elasticsearch query took:', microtime.nowDouble() - startTime );
// handle backend errors // handle backend errors
if( err ){ return cb( err ); } if( err ){ return cb( err ); }

5
service/search.js

@ -5,10 +5,15 @@
**/ **/
var peliasLogger = require( 'pelias-logger' ).get( 'service/search' );
var microtime = require( 'microtime' );
function service( backend, cmd, cb ){ function service( backend, cmd, cb ){
var startTime = microtime.nowDouble();
// query new backend // query new backend
backend().client.search( cmd, function( err, data ){ backend().client.search( cmd, function( err, data ){
peliasLogger.verbose( 'time elasticsearch query took:', microtime.nowDouble() - startTime );
// handle backend errors // handle backend errors
if( err ){ return cb( err ); } if( err ){ return cb( err ); }

5
service/suggest.js

@ -4,10 +4,15 @@
cmd can be any valid ES suggest command cmd can be any valid ES suggest command
**/ **/
var peliasLogger = require( 'pelias-logger' ).get( 'service/suggest' );
var microtime = require( 'microtime' );
function service( backend, cmd, cb ){ function service( backend, cmd, cb ){
// query new backend // query new backend
var startTime = microtime.nowDouble();
backend().client.suggest( cmd, function( err, data ){ backend().client.suggest( cmd, function( err, data ){
peliasLogger.verbose( 'time elasticsearch query took:', microtime.nowDouble() - startTime );
// handle backend errors // handle backend errors
if( err ){ return cb( err ); } if( err ){ return cb( err ); }

5
src/logger.js

@ -1,5 +0,0 @@
module.exports = {
log: console.log.bind( console ),
warn: console.warn.bind( console ),
error: console.error.bind( console )
};
Loading…
Cancel
Save