Browse Source

Merge branch '1stvamp-fix-offline-500'

pull/4/head
Harish.K 9 years ago
parent
commit
ba5eeb8286
  1. 28
      app.js

28
app.js

@ -1,4 +1,5 @@
var express = require('express'); var express = require('express');
var Promise = require('bluebird');
var config = require( __dirname + '/./config' ); var config = require( __dirname + '/./config' );
var utils = require( __dirname + '/./utils'); var utils = require( __dirname + '/./utils');
@ -37,22 +38,21 @@ app.get( '/:package', function( req, res, next ){
return fileExists( cacheFile ) return fileExists( cacheFile )
.tap( function( isExists ){ .tap( function( isExists ){
if( !isExists ){ if( !isExists ){
if ( ENABLE_NPM_FAILOVER ) {
if ( !ENABLE_NPM_FAILOVER ) {
return Promise.reject( { status:404, message: 'Package not found' });
}
res._log.cacheHit = '---'; res._log.cacheHit = '---';
return fetchAndCacheMetadata( packageName, cacheFile ); return fetchAndCacheMetadata( packageName, cacheFile );
} else {
return res.status( 404 ).json( {} );
}
} }
}) })
.then( function( ){ .then( function( ){
res._log.cacheFile = cacheFile; res._log.cacheFile = cacheFile;
return readFile( cacheFile, 'utf-8' ); return readFile( cacheFile, 'utf-8' );
}) })
.then( function( cacheData ){
cacheData = JSON.parse( cacheData );
patchData( cacheData );
return res.send( cacheData );
.then( function( cachedData ){
cachedData = JSON.parse( cachedData );
patchData( cachedData );
return res.send( cachedData );
}) })
.catch( next ); .catch( next );
}); });
@ -65,12 +65,11 @@ app.get( '/:package/-/:tarball', function( req, res, next ){
fileExists( packagePath ) fileExists( packagePath )
.tap( function( isExists ){ .tap( function( isExists ){
if( !isExists ){ if( !isExists ){
if ( ENABLE_NPM_FAILOVER ) {
if ( !ENABLE_NPM_FAILOVER ) {
return Promise.reject( { status: 404, message: '' });
}
res._log.cacheHit = '---'; res._log.cacheHit = '---';
return fetchAndCacheTarball( packageName, version, packagePath ); return fetchAndCacheTarball( packageName, version, packagePath );
} else {
return res.status( 404 ).json( {} );
}
} }
}) })
.then( function( ){ .then( function( ){
@ -93,10 +92,7 @@ app.use(function(req, res, next) {
app.use(function(err, req, res, next) { app.use(function(err, req, res, next) {
console.log( err.stack ); console.log( err.stack );
res.status(err.status || 500); res.status(err.status || 500);
res.send({
message: err.message,
error: err
});
res.send( err.message || err );
if( next ) { next(); } if( next ) { next(); }
}); });

Loading…
Cancel
Save