2017-12-20 21:46:01 +00:00
|
|
|
/*
|
|
|
|
Copyright 2016-2017 Resin.io
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import errors = require('resin-cli-errors');
|
|
|
|
import patterns = require('./utils/patterns');
|
|
|
|
import Raven = require('raven');
|
|
|
|
import Promise = require('bluebird');
|
|
|
|
|
2018-01-09 15:05:24 +00:00
|
|
|
const captureException = Promise.promisify<string, Error>(
|
|
|
|
Raven.captureException,
|
|
|
|
{ context: Raven },
|
|
|
|
);
|
2017-12-20 21:46:01 +00:00
|
|
|
|
|
|
|
exports.handle = function(error: any) {
|
|
|
|
let message = errors.interpret(error);
|
2018-01-09 15:05:24 +00:00
|
|
|
if (message == null) {
|
|
|
|
return;
|
|
|
|
}
|
2017-12-20 21:46:01 +00:00
|
|
|
|
|
|
|
if (process.env.DEBUG) {
|
|
|
|
message = error.stack;
|
|
|
|
}
|
|
|
|
|
|
|
|
patterns.printErrorMessage(message);
|
|
|
|
|
|
|
|
return captureException(error)
|
2018-01-09 15:05:24 +00:00
|
|
|
.timeout(1000)
|
|
|
|
.catch(function() {
|
|
|
|
// Ignore any errors (from error logging, or timeouts)
|
|
|
|
})
|
|
|
|
.finally(() => process.exit(error.exitCode || 1));
|
2017-12-20 21:46:01 +00:00
|
|
|
};
|