const request = require('request'); const bl = require('bl'); const _ = require('lodash'); const logger = require( 'pelias-logger' ).get( 'placeholder' ); module.exports = function setup(url) { if (_.isEmpty(url)) { logger.warn('placeholder service disabled'); return { search: (text, lang, callback) => { callback(`placeholder service disabled`); } }; } logger.info(`using placeholder service at ${url}`); return { search: (text, lang, callback) => { const requestUrl = `${url}/search?text=${text}&lang=${lang}`; request .get(requestUrl) .on('response', (response) => { // pipe the response thru bl which will accumulate the entire body response.pipe(bl((err, data) => { if (response.statusCode === 200) { // parse and return w/o error unless response wasn't JSON try { const parsed = JSON.parse(data); return callback(null, parsed); } catch (err) { logger.error(`${encodeURI(requestUrl)} could not parse response: ${data}`); return callback(`${encodeURI(requestUrl)} could not parse response: ${data}`); } } else { // otherwise there was a non-200 status so handle generically logger.error(`${encodeURI(requestUrl)} returned status ${response.statusCode}: ${data}`); return callback(`${encodeURI(requestUrl)} returned status ${response.statusCode}: ${data}`); } })); }) .on('error', (err) => { logger.error(JSON.stringify(err)); callback(err); }); } }; };