UNPKG

@dynatrace/react-native-plugin

Version:

This plugin gives you the ability to use the Dynatrace Mobile agent in your react native application.

98 lines (97 loc) 5.16 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Dynatrace = void 0; const DynatraceBridge_1 = require("../core/DynatraceBridge"); const ConsoleLogger_1 = require("../core/logging/ConsoleLogger"); const EventCreator_1 = require("./events/EventCreator"); const EventPipeline_1 = require("./events/EventPipeline"); const EventTimestamp_1 = require("./events/EventTimestamp"); const EventModifierUtil_1 = require("./events/modifier/EventModifierUtil"); const SendEventValidation_1 = require("./events/modifier/SendEventValidation"); const TimestampProvider_1 = require("./provider/TimestampProvider"); class DynatraceImpl { constructor(timestampProvider) { this.timestampProvider = timestampProvider; this.logger = new ConsoleLogger_1.ConsoleLogger('Dynatrace'); } addEventModifier(eventModifier) { this.logger.debug('addEventModifier()'); return EventPipeline_1.EventPipeline.addEventModifier(eventModifier); } removeEventModifier(eventModifier) { this.logger.debug('removeEventModifier()'); return EventPipeline_1.EventPipeline.removeEventModifier(eventModifier); } startView(name) { this.logger.debug(`startView(${name})`); EventPipeline_1.EventPipeline.generateViewData(name); if (name != null && name.length > 0) { DynatraceBridge_1.DynatraceNative.startView(name); } else { this.logger.debug(`startView(${name}): Name can't be used. Either empty or null!`); } } stopView() { this.logger.debug('stopView()'); EventPipeline_1.EventPipeline.releaseViewData(); DynatraceBridge_1.DynatraceNative.stopView(); } reportCrash(crash, isApiReported, isFatal = true) { this.logger.debug(`reportCrash(${JSON.stringify(crash)}, ${isFatal})`); const eventTimestamp = new EventTimestamp_1.EventTimestamp(this.timestampProvider); const event = Object.assign(Object.assign({}, (0, EventCreator_1.createCrashEvent)(crash.name, crash.message, crash.stack, isFatal)), eventTimestamp.getEventTimeInfo()); if (isApiReported) { event["characteristics.is_api_reported"] = true; } EventPipeline_1.EventPipeline.insertEvent(event); } reportErrorCode(errorName, errorCode, isApiReported) { this.logger.debug(`reportErrorCode(${errorName}, ${errorCode})`); const eventTimestamp = new EventTimestamp_1.EventTimestamp(this.timestampProvider); const event = Object.assign(Object.assign({}, (0, EventCreator_1.createErrorCodeEvent)(errorName, errorCode)), eventTimestamp.getEventTimeInfo()); if (isApiReported) { event["characteristics.is_api_reported"] = true; } EventPipeline_1.EventPipeline.insertEvent(event); } reportError(error, isApiReported) { this.logger.debug(`reportError(${JSON.stringify(error)})`); const eventTimestamp = new EventTimestamp_1.EventTimestamp(this.timestampProvider); const event = Object.assign(Object.assign({}, (0, EventCreator_1.createErrorEvent)(error.name, error.message, error.stack)), eventTimestamp.getEventTimeInfo()); if (isApiReported) { event["characteristics.is_api_reported"] = true; } EventPipeline_1.EventPipeline.insertEvent(event); } sendExceptionEvent(error, fields) { const fieldsCheck = !fields ? null : fields; this.logger.debug(`sendExceptionEvent(${JSON.stringify(error)}, ${JSON.stringify(fieldsCheck)})`); const event = Object.assign({}, (0, EventCreator_1.createErrorEvent)(error.name, error.message, error.stack)); let eventValidated = SendEventValidation_1.SendEventValidation.modifyEvent(fieldsCheck); eventValidated = Object.assign(Object.assign({}, event), eventValidated); eventValidated["characteristics.is_api_reported"] = true; EventPipeline_1.EventPipeline.insertEvent(eventValidated); } sendEvent(properties, context) { this.logger.debug(`sendEvent(${JSON.stringify(properties, context)})`); const eventValidated = SendEventValidation_1.SendEventValidation.modifyEvent(properties); if (eventValidated != null && (0, EventModifierUtil_1.containEventProperties)(eventValidated)) { eventValidated["characteristics.has_event_properties"] = true; } EventPipeline_1.EventPipeline.insertEvent(eventValidated, context); } sendSessionPropertyEvent(properties) { this.logger.debug(`sendSessionPropertyEvent(${JSON.stringify(properties)})`); const eventValidated = SendEventValidation_1.SendSessionPropertyEventValidation.modifyEvent(properties); if (eventValidated != null && (0, EventModifierUtil_1.containSessionProperties)(eventValidated)) { eventValidated["characteristics.has_session_properties"] = true; } EventPipeline_1.EventPipeline.insertEvent(eventValidated); } } exports.Dynatrace = new DynatraceImpl(TimestampProvider_1.defaultTimestampProvider);