2017-11-23 17:29:40 +00:00
|
|
|
/**
|
|
|
|
* @flow
|
|
|
|
* Crash Reporting representation wrapper
|
|
|
|
*/
|
|
|
|
import ModuleBase from '../../utils/ModuleBase';
|
|
|
|
|
2017-12-04 12:07:41 +00:00
|
|
|
import type FirebaseApp from '../core/firebase-app';
|
2017-11-23 17:29:40 +00:00
|
|
|
import type { FirebaseError } from '../../types';
|
2017-03-10 14:17:37 +00:00
|
|
|
|
2018-01-03 20:00:38 +00:00
|
|
|
export const MODULE_NAME = 'RNFirebaseCrash';
|
|
|
|
export const NAMESPACE = 'crash';
|
2017-08-17 17:58:28 +01:00
|
|
|
|
2018-01-03 20:00:38 +00:00
|
|
|
export default class Crash extends ModuleBase {
|
2017-12-04 12:07:41 +00:00
|
|
|
constructor(firebaseApp: FirebaseApp, options: Object = {}) {
|
2018-01-03 20:00:38 +00:00
|
|
|
super(firebaseApp, options, {
|
|
|
|
moduleName: MODULE_NAME,
|
|
|
|
namespace: NAMESPACE,
|
|
|
|
});
|
2017-05-25 23:39:06 +01:00
|
|
|
}
|
|
|
|
|
2017-06-12 14:26:56 +01:00
|
|
|
/**
|
|
|
|
* Enables/Disables crash reporting
|
|
|
|
* @param enabled
|
|
|
|
*/
|
|
|
|
setCrashCollectionEnabled(enabled: boolean): void {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.setCrashCollectionEnabled(enabled);
|
2017-06-12 14:26:56 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether or not crash reporting is currently enabled
|
|
|
|
* @returns {Promise.<boolean>}
|
|
|
|
*/
|
|
|
|
isCrashCollectionEnabled(): Promise<boolean> {
|
2017-06-30 17:23:32 +01:00
|
|
|
return this._native.isCrashCollectionEnabled();
|
2017-06-12 14:26:56 +01:00
|
|
|
}
|
|
|
|
|
2017-03-10 14:17:37 +00:00
|
|
|
/**
|
|
|
|
* Logs a message that will appear in a subsequent crash report.
|
|
|
|
* @param {string} message
|
|
|
|
*/
|
|
|
|
log(message: string): void {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.log(message);
|
2017-03-10 14:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs a message that will appear in a subsequent crash report as well as in logcat.
|
|
|
|
* NOTE: Android only functionality. iOS will just log the message.
|
|
|
|
* @param {string} message
|
|
|
|
* @param {number} level
|
|
|
|
* @param {string} tag
|
|
|
|
*/
|
|
|
|
logcat(level: number, tag: string, message: string): void {
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.logcat(level, tag, message);
|
2017-03-10 14:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates a crash report for the given message. This method should be used for unexpected
|
|
|
|
* exceptions where recovery is not possible.
|
|
|
|
* NOTE: on iOS, this will cause the app to crash as it's the only way to ensure the exception
|
|
|
|
* gets sent to Firebase. Otherwise it just gets lost as a log message.
|
2017-03-17 15:41:25 +00:00
|
|
|
* @param {Error} error
|
|
|
|
* @param maxStackSize
|
2017-03-10 14:17:37 +00:00
|
|
|
*/
|
2017-04-04 17:58:20 +01:00
|
|
|
report(error: FirebaseError, maxStackSize: number = 10): void {
|
2017-06-26 14:30:17 +09:00
|
|
|
if (!error || !error.message) return;
|
2017-03-17 15:41:25 +00:00
|
|
|
|
|
|
|
let errorMessage = `Message: ${error.message}\r\n`;
|
|
|
|
|
|
|
|
if (error.code) {
|
|
|
|
errorMessage = `${errorMessage}Code: ${error.code}\r\n`;
|
|
|
|
}
|
|
|
|
|
|
|
|
const stackRows = error.stack.split('\n');
|
|
|
|
errorMessage = `${errorMessage}\r\nStack: \r\n`;
|
|
|
|
for (let i = 0, len = stackRows.length; i < len; i++) {
|
|
|
|
if (i === maxStackSize) break;
|
|
|
|
errorMessage = `${errorMessage} - ${stackRows[i]}\r\n`;
|
|
|
|
}
|
|
|
|
|
2017-06-30 17:23:32 +01:00
|
|
|
this._native.report(errorMessage);
|
2017-03-10 14:17:37 +00:00
|
|
|
}
|
|
|
|
}
|
2017-11-23 17:29:40 +00:00
|
|
|
|
|
|
|
export const statics = {};
|