|
|
|
const Raven = require('raven-js')
|
|
|
|
const METAMASK_DEBUG = process.env.METAMASK_DEBUG
|
|
|
|
const extractEthjsErrorMessage = require('./extractEthjsErrorMessage')
|
|
|
|
const PROD = 'https://3567c198f8a8412082d32655da2961d0@sentry.io/273505'
|
|
|
|
const DEV = 'https://f59f3dd640d2429d9d0e2445a87ea8e1@sentry.io/273496'
|
|
|
|
|
|
|
|
module.exports = setupRaven
|
|
|
|
|
|
|
|
// Setup raven / sentry remote error reporting
|
|
|
|
function setupRaven(opts) {
|
|
|
|
const { release } = opts
|
|
|
|
let ravenTarget
|
|
|
|
|
|
|
|
if (METAMASK_DEBUG) {
|
|
|
|
console.log('Setting up Sentry Remote Error Reporting: DEV')
|
|
|
|
ravenTarget = DEV
|
|
|
|
} else {
|
|
|
|
console.log('Setting up Sentry Remote Error Reporting: PROD')
|
|
|
|
ravenTarget = PROD
|
|
|
|
}
|
|
|
|
|
|
|
|
const client = Raven.config(ravenTarget, {
|
|
|
|
release,
|
|
|
|
transport: function(opts) {
|
|
|
|
const report = opts.data
|
|
|
|
// simplify certain complex error messages
|
|
|
|
report.exception.values.forEach(item => {
|
|
|
|
let errorMessage = item.value
|
|
|
|
// simplify ethjs error messages
|
|
|
|
errorMessage = extractEthjsErrorMessage(errorMessage)
|
|
|
|
// simplify 'Transaction Failed: known transaction'
|
|
|
|
if (errorMessage.indexOf('Transaction Failed: known transaction') === 0) {
|
|
|
|
// cut the hash from the error message
|
|
|
|
errorMessage = 'Transaction Failed: known transaction'
|
|
|
|
}
|
|
|
|
// finalize
|
|
|
|
item.value = errorMessage
|
|
|
|
})
|
|
|
|
|
|
|
|
// modify report urls
|
|
|
|
rewriteReportUrls(report)
|
|
|
|
// make request normally
|
|
|
|
client._makeRequest(opts)
|
|
|
|
},
|
|
|
|
})
|
|
|
|
client.install()
|
|
|
|
|
|
|
|
return Raven
|
|
|
|
}
|
|
|
|
|
|
|
|
function rewriteReportUrls(report) {
|
|
|
|
// update request url
|
|
|
|
report.request.url = toMetamaskUrl(report.request.url)
|
|
|
|
// update exception stack trace
|
|
|
|
report.exception.values.forEach(item => {
|
|
|
|
item.stacktrace.frames.forEach(frame => {
|
|
|
|
frame.filename = toMetamaskUrl(frame.filename)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
function toMetamaskUrl(origUrl) {
|
|
|
|
const filePath = origUrl.split(location.origin)[1]
|
|
|
|
if (!filePath) return origUrl
|
|
|
|
const metamaskUrl = `metamask${filePath}`
|
|
|
|
return metamaskUrl
|
|
|
|
}
|