Error Analysis
Error Analysis is automatically included in the Contentsquare Bridge and is available for both Android and iOS.
Prerequisites
Section titled PrerequisitesScreen tracking implemented
Section titled Screen tracking implementedTracking will start at the 1st screenview event, it is required to have screen tracking implemented. Make sure to follow the React Native Track screens sections.
Reminder about User consent
Section titled Reminder about User consentIf you are in the process of implementing the SDK for the 1st time (or choose to take this update as an opportunity to review your Privacy related implementation), make sure to follow the React Native Privacy section and use the Opt-in API to get the user consent, otherwise no data will be collected.
Get Started
Section titled Get StartedAdd Contentsquare Error Analysis to your app
Section titled Add Contentsquare Error Analysis to your appIf you have already integrated the Contentsquare Bridge and enabled Error Analysis on Experience Analytics Mobile, the Error Analysis SDK should seamlessly function. However, note that additional configuration is required specifically for Android apps.
Add Gradle plugin on Android
Section titled Add Gradle plugin on AndroidWith the use of a Gradle plugin, an instrumentation of your code will be performed to collect the data about network errors.
Add the Contentsquare Network Gradle plugin to the plugins block in both your root-level and app-level Gradle files:
plugins {  id "com.contentsquare.error.analysis.network" version "1.6.0"}plugins {  id("com.contentsquare.error.analysis.network") version "1.6.0"}Start the SDK
Section titled Start the SDKYou do not need to do anything to start the Error Analysis SDK, it will start itself with Contentsquare SDK.
Validate SDK integration
Section titled Validate SDK integrationLook at the native SDK docs for validation on each platform.
📚 Validate Android SDK integration
📚 Validate iOS SDK integration
Sample App
Section titled Sample AppFor best implementation practices of our library, explore the Contentsquare for React Native sample app ↗.
API Errors
Section titled API ErrorsAutomatic network inspection
Section titled Automatic network inspectionAPI Errors automatically collects failed network requests.
Removing Personal Data in request URL path
Section titled Removing Personal Data in request URL pathBy default, the API Errors feature collects the URL path of the failed API requests. To prevent the collection of Personal Data in the URL path, you can rewrite the request URL path with the ErrorAnalysis.setUrlMaskingPatterns SDK API.
Replace a step of the path - meaning between two slashes (/) - containing Personal Data with a variable:
- becomes CS_ANONYMIZED_USER_ID
- becomes CS_ANONYMIZED_ADDRESS
Example
Section titled Exampleimport { ErrorAnalysis } from "@contentsquare/react-native-bridge";
ErrorAnalysis.setURLMaskingPatterns([  "https://www.contentsquare.com/users/:user_id/address/:address",]);Result
Section titled Result| URL before masking | URL after masking | 
|---|---|
| https://www.contentsquare.com/users/123/address/castle+black | https://www.contentsquare.com/users/CS_ANONYMIZED_USER_ID/address/CS_ANONYMIZED_ADDRESS | 
Debugging and Logging
Section titled Debugging and LoggingIf in-app features are enabled, a info log should appear with the details of the event (see React Native Debugging and Logging section):
I/CSLIB: API Error - GET 401 https://api.client.comCSLIB ℹ️ Info: API Error - GET 401 https://api.client.comHow API Errors works
Section titled How API Errors worksInitialization
Section titled InitializationThe way our SDK works is by auto-starting with the application launch and automatically collects failed network requests.
Configuration
Section titled ConfigurationOnce started, our SDK fetches its config from our servers. It will start collecting data from network events if the API Errors setting is enabled in the config (this is handled by the Contentsquare team).
Tracking
Section titled TrackingThe SDK monitors only the API Errors with response code above 400, and generates analytics data. These events are then locally stored, and eventually sent to our servers in batches.
Sending data
Section titled Sending dataFor each network error, a new event will be sent in analytics and Session Replay data. Check the following sections to learn more about how data is processed and sent:
API Troubleshooting Details
Section titled API Troubleshooting DetailsAPI Errors troubleshooting details enables you to collect more information about API errors so you can troubleshoot errors faster.
With this feature you will be able to see three types of additional API error details in the Event Stream of Session Replay.
- The HTTP headers of the request and the response.
- The body (the data sent by the request or received in the response).
- The query parameters of the request endpoint (of the URL of the information you request for).
See API Troubleshooting Details ↗ for more details.
Mask API Error By Template URL
Section titled Mask API Error By Template URLThis method will mask URLs of failing API calls to URLs that match the template URL.
Use colon (:) to indicate a dynamic parameter.
import { ErrorAnalysis } from "@contentsquare/react-native-bridge";
ErrorAnalysis.setURLMaskingPatterns([  "https://<domain>/:status_code/person/:person_id/store/:store_id",]);Collected data points
Section titled Collected data pointsOnly network calls in error (response code above 400) will be collected. Here the exhaustive list of data collected:
- URL (without query strings)
- HTTP method
- Response code
- Timestamp of the request
- Timestamp of the response
- HTTP headers of the request
- HTTP headers of the response
- HTTP body of the request
- HTTP body of the response
- Query parameters of the request endpoint
Known limitations and recommendations
Section titled Known limitations and recommendationsConflict with Firebase Performance Monitoring
Section titled Conflict with Firebase Performance MonitoringAndroid
Section titled AndroidContentsquare Error Analysis is not compatible with Firebase Performance Monitoring auto-collection. Only one of the two will log events, and usually, the events will be automatically logged by the Contentsquare Error Analysis. To log events to Firebase Performance Monitoring, we suggest logging it manually ↗.
Contentsquare Error Analysis is compatible with Firebase Performance auto-collection, but the HTTP body from the response won’t be collected by the Error Analysis SDK.
Workaround: Disable Firebase automatic monitoring:
// <project-root>/firebase.json{  "react-native": {    "perf_auto_collection_enabled": false  }}Contentsquare Error Analysis may not be compatible with other network auto-collection tools.
Crash Reporter
Section titled Crash ReporterThe Crash Reporter feature automatically captures and reports application crashes to help you identify and debug critical issues in your React Native app. It supports both native crashes (Android/iOS) and JavaScript crashes.
Overview
Section titled OverviewThe Crash Reporter provides:
- Native crash collection: Captures crashes occurring in the native Android and iOS layers
- JavaScript crash collection: Captures unhandled JavaScript errors and exceptions
- Automatic symbolication: Provides readable stack traces for easier debugging
- Session context: Links crashes to user sessions for better context
Native crashes
Section titled Native crashesNative crashes occur in the platform-specific code (Android or iOS) and require additional setup for proper symbolication.
Requirements
Section titled RequirementsAndroid
Section titled AndroidTo enable crash collection and symbolication for Android native crashes, you need to add the Contentsquare Crash Gradle plugin.
Add the plugin to both your root-level and app-level Gradle files:
plugins {   id "com.contentsquare.error.analysis.crash" version "1.7.0" apply false}plugins {   id "com.contentsquare.error.analysis.crash"}plugins {   id("com.contentsquare.error.analysis.crash") version "1.7.0" apply false}plugins {   id("com.contentsquare.error.analysis.crash")}For iOS applications, crash collection is automatically enabled when you integrate the Contentsquare Bridge. No additional dependencies or configuration are required.
JavaScript crashes
Section titled JavaScript crashesValidate JavaScript crashes integration
Section titled Validate JavaScript crashes integrationValidate JavaScript error handler is activated
Section titled Validate JavaScript error handler is activatedIf the JavaScript Crash reporter has been successfully initialized an info log should appear in React Native logs:
CSLIB ℹ️ Info: CSErrorHandler is set as javascript global error handler.Validate JavaScript crash reporting
Section titled Validate JavaScript crash reportingTo test that the JavaScript Crash Reporter is working properly, you can throw unhandled JavaScript error. The next time you start your application, the JavaScript crash will be sent to our servers. If you have logging enabled, you will see the upload reflected in the logs for iOS or Android.
I/CSLIB: React Native Crash event detected and sent for userID: <user-id>, session: <session-number> on screen: <screen-number> crashID: <crash-id>CSLIB ℹ️ Info: React Native Crash event detected and sent for userID: <user-id>, session: <session-number> on screen: <screen-number> crashID: <crash-id>Source Maps
Section titled Source MapsCheck the React Native documentation ↗ on how to enable source maps generation for JavaScript, and make sure to adjust the following settings in your project for automatic source map upload:
...apply plugin: "com.contentsquare.error.analysis.crash"apply from: "../../node_modules/@contentsquare/cli/scripts/contentsquare.gradle"...
react {  // Ensure the following hermesFlags are present  (hermesFlags = ['-O', '-output-source-map'])}
ext {  contentsquareConfigPath = "../contentsquare-cli.json" // default}Use the index.android.bundle.map path in the sourcemapPath configuration for android. Example for default path:
./android/app/build/generated/sourcemaps/react/release/index.android.bundle.map  ...  export SOURCEMAP_FILE="$SRCROOT/main.jsbundle.map"  WITH_ENVIRONMENT="$REACT_NATIVE_PATH/scripts/xcode/with-environment.sh"  REACT_NATIVE_XCODE="$REACT_NATIVE_PATH/scripts/react-native-xcode.sh";  export CONTENTSQUARE_CONFIG_PATH="$SRCROOT/../contentsquare-cli.json"  CONTENTSQUARE_XCODE="$SRCROOT/../node_modules/@contentsquare/cli/scripts/contentsquare-xcode.sh"
  /bin/sh -c "$WITH_ENVIRONMENT $REACT_NATIVE_XCODE"  /bin/sh -c "$WITH_ENVIRONMENT $CONTENTSQUARE_XCODE"  ...Use the main.jsbundle.map path in the sourcemapPath configuration for ios. Example for default path:
./ios/main.jsbundle.mapCLI configuration
Section titled CLI configurationDownload the contentsquare-cli-v0.1.2.tgz package and install it as a dev dependency to your project.
yarn add <path-to-contentsquare-cli-v0.1.2.tgz> --devReplace <path-to-contentsquare-cli-v0.1.2.tgz> with the actual path to the tarball file on your system.
The following information is required for the CLI to successfully upload the source maps:
- 
The targeted platform iosorandroid
- 
The project ID 
- Log on the Contentsquare platform on https://app.contentsquare.com ↗
- Make sure to be on the right project
- The project ID can be found in the URL query parameter project:https://app.contentsquare.com/#/{MODULE_NAME}?project={PROJECT_ID}&hash={HASH}
- 
Valid API credentials Follow the dedicated documentation from the Help Center to get the client ID and client Secret: How to create API credentials ↗. 
- 
The source map path The path to the source map file in the project. The path should be relative to the project root. 
To provide this information to the CLI script, either use a JSON configuration file or pass the required information as command line arguments. For automatic source map upload, the preferred way is to use the JSON configuration file.
Using JSON configuration file
Section titled Using JSON configuration fileProvide the required information by adding a contentsquare-cli.json file at the root of your project.
{  "android": {    "clientId": "ANDROID_CLIENT_ID",    "clientSecret": "ANDROID_CLIENT_SECRET",    "projectId": "ANDROID_PROJECT_ID",    "sourcemapPath": "ANDROID_PROJECT_SOURCEMAP_PATH"  },  "ios": {    "clientId": "IOS_CLIENT_ID",    "clientSecret": "IOS_CLIENT_SECRET",    "projectId": "IOS_PROJECT_ID",    "sourcemapPath": "IOS_PROJECT_SOURCEMAP_PATH"  }}Using command line arguments
Section titled Using command line argumentsAlternatively, the required information can be added as arguments directly on the command line.
| Option | Description | 
|---|---|
| --client-id | The client ID of API credentials ↗ | 
| --client-secret | The client secret of API credentials ↗ | 
| --config | The path to the configuration file relative to project root. Default value: contentsquare-cli.json | 
| --help | Display the help message | 
| --platform | The platform to target: iosorandroid | 
| --project-id | The project ID | 
| --sourcemap-path | The path to the source map file | 
| --uploadUrl | The URL of the Contentsquare platform. Default value: https://api.csq.io ↗ | 
| --verbose | Display verbose output | 
How to use @contentsquare/cli to manually upload source maps
Following exact steps is crucial to ensure the correct deobfuscation of the stack traces:
- 
Invoke the Contentsquare CLI with the update-sourcemap-idcommand from the root of your project to create/updatecontentsquare-sourcemap-info.json, that contains the source map ID for both platforms.Terminal window npx contentsquare-cli update-sourcemap-id
- 
Build a release version of your app. 
- 
Upload the source maps to the Contentsquare platform by invoking the upload-sourcemapscommand from the root of your project.Terminal window npx contentsquare-cli upload-sourcemaps