@truewatchtech/react-native-mobile 0.4.0-alpha.4 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (155) hide show
  1. package/FTMobileReactNativeSDK.podspec +31 -2
  2. package/android/build.gradle +7 -19
  3. package/android/src/main/java/com/ft/sdk/reactnative/FTMobileImpl.java +472 -5
  4. package/android/src/main/java/com/ft/sdk/reactnative/FTRUMImpl.java +12 -0
  5. package/android/src/newarch/java/com/ft/sdk/reactnative/FTLogModule.java +7 -14
  6. package/android/src/newarch/java/com/ft/sdk/reactnative/FTMobileModule.java +46 -12
  7. package/android/src/newarch/java/com/ft/sdk/reactnative/FTRUMModule.java +12 -13
  8. package/android/src/newarch/java/com/ft/sdk/reactnative/FTTraceModule.java +6 -8
  9. package/android/src/oldarch/java/com/ft/sdk/reactnative/FTMobileModule.java +34 -2
  10. package/android/src/oldarch/java/com/ft/sdk/reactnative/FTRUMModule.java +5 -0
  11. package/android/src/rnpost74/java/com/ft/sdk/reactnative/FTMobilePackage.java +14 -3
  12. package/android/src/rnpre74/java/com/ft/sdk/reactnative/FTMobilePackage.java +0 -3
  13. package/ios/FTMobileReactNative.h +9 -5
  14. package/ios/FTMobileReactNative.mm +625 -0
  15. package/ios/FTReactNativeLog.h +8 -3
  16. package/ios/FTReactNativeLog.mm +79 -0
  17. package/ios/FTReactNativeRUM.h +8 -3
  18. package/ios/{FTReactNativeRUM.m → FTReactNativeRUM.mm} +143 -84
  19. package/ios/FTReactNativeTrace.h +8 -2
  20. package/ios/FTReactNativeTrace.mm +74 -0
  21. package/ios/FtMobileAgent.xcodeproj/project.pbxproj +17 -1
  22. package/lib/commonjs/ft_logger.js +14 -13
  23. package/lib/commonjs/ft_logger.js.map +1 -1
  24. package/lib/commonjs/ft_mobile_agent.js +155 -6
  25. package/lib/commonjs/ft_mobile_agent.js.map +1 -1
  26. package/lib/commonjs/ft_rum.js +55 -21
  27. package/lib/commonjs/ft_rum.js.map +1 -1
  28. package/lib/commonjs/ft_tracing.js +29 -10
  29. package/lib/commonjs/ft_tracing.js.map +1 -1
  30. package/lib/commonjs/index.js +24 -13
  31. package/lib/commonjs/index.js.map +1 -1
  32. package/lib/commonjs/rum/FTRumActionTracking.js +10 -4
  33. package/lib/commonjs/rum/FTRumActionTracking.js.map +1 -1
  34. package/lib/commonjs/rum/FTRumErrorTracking.js +4 -4
  35. package/lib/commonjs/rum/FTRumErrorTracking.js.map +1 -1
  36. package/lib/commonjs/specs/NativeFTMobileReactNative.js +10 -0
  37. package/lib/commonjs/specs/NativeFTMobileReactNative.js.map +1 -0
  38. package/lib/commonjs/specs/NativeFTReactNativeLog.js +10 -0
  39. package/lib/commonjs/specs/NativeFTReactNativeLog.js.map +1 -0
  40. package/lib/commonjs/specs/NativeFTReactNativeRUM.js +10 -0
  41. package/lib/commonjs/specs/NativeFTReactNativeRUM.js.map +1 -0
  42. package/lib/commonjs/specs/NativeFTReactNativeTrace.js +10 -0
  43. package/lib/commonjs/specs/NativeFTReactNativeTrace.js.map +1 -0
  44. package/lib/commonjs/version.js +1 -1
  45. package/lib/commonjs/version.js.map +1 -1
  46. package/lib/module/ft_logger.js +14 -12
  47. package/lib/module/ft_logger.js.map +1 -1
  48. package/lib/module/ft_mobile_agent.js +161 -5
  49. package/lib/module/ft_mobile_agent.js.map +1 -1
  50. package/lib/module/ft_rum.js +54 -16
  51. package/lib/module/ft_rum.js.map +1 -1
  52. package/lib/module/ft_tracing.js +29 -9
  53. package/lib/module/ft_tracing.js.map +1 -1
  54. package/lib/module/index.js +3 -4
  55. package/lib/module/index.js.map +1 -1
  56. package/lib/module/rum/FTRumActionTracking.js +10 -4
  57. package/lib/module/rum/FTRumActionTracking.js.map +1 -1
  58. package/lib/module/rum/FTRumErrorTracking.js +4 -4
  59. package/lib/module/rum/FTRumErrorTracking.js.map +1 -1
  60. package/lib/module/specs/NativeFTMobileReactNative.js +5 -0
  61. package/lib/module/specs/NativeFTMobileReactNative.js.map +1 -0
  62. package/lib/module/specs/NativeFTReactNativeLog.js +5 -0
  63. package/lib/module/specs/NativeFTReactNativeLog.js.map +1 -0
  64. package/lib/module/specs/NativeFTReactNativeRUM.js +5 -0
  65. package/lib/module/specs/NativeFTReactNativeRUM.js.map +1 -0
  66. package/lib/module/specs/NativeFTReactNativeTrace.js +5 -0
  67. package/lib/module/specs/NativeFTReactNativeTrace.js.map +1 -0
  68. package/lib/module/version.js +1 -1
  69. package/lib/module/version.js.map +1 -1
  70. package/lib/typescript/ft_logger.d.ts +6 -6
  71. package/lib/typescript/ft_mobile_agent.d.ts +169 -14
  72. package/lib/typescript/ft_rum.d.ts +32 -8
  73. package/lib/typescript/ft_tracing.d.ts +6 -6
  74. package/lib/typescript/index.d.ts +3 -4
  75. package/lib/typescript/specs/NativeFTMobileReactNative.d.ts +75 -0
  76. package/lib/typescript/specs/NativeFTReactNativeLog.d.ts +23 -0
  77. package/lib/typescript/specs/NativeFTReactNativeRUM.d.ts +89 -0
  78. package/lib/typescript/specs/NativeFTReactNativeTrace.d.ts +24 -0
  79. package/lib/typescript/version.d.ts +1 -1
  80. package/package.json +26 -93
  81. package/scripts/replace-react-require.js +37 -38
  82. package/src/ft_logger.tsx +72 -40
  83. package/src/ft_mobile_agent.tsx +378 -91
  84. package/src/ft_rum.tsx +227 -121
  85. package/src/ft_tracing.tsx +58 -37
  86. package/src/index.tsx +58 -18
  87. package/src/rum/FTRumActionTracking.tsx +212 -204
  88. package/src/rum/FTRumErrorTracking.tsx +70 -71
  89. package/src/specs/NativeFTMobileReactNative.ts +83 -0
  90. package/src/specs/NativeFTReactNativeLog.ts +29 -0
  91. package/src/specs/NativeFTReactNativeRUM.ts +104 -0
  92. package/src/specs/NativeFTReactNativeTrace.ts +26 -0
  93. package/src/version.ts +1 -1
  94. package/LICENSE +0 -201
  95. package/android/.project +0 -17
  96. package/android/.settings/org.eclipse.buildship.core.prefs +0 -13
  97. package/android/gradlew +0 -185
  98. package/android/local.properties +0 -8
  99. package/android/src/main/java/com/ft/sdk/InnerClassProxy.java +0 -8
  100. package/android/src/main/java/com/ft/sdk/reactnative/FTSessionReplayImpl.java +0 -60
  101. package/android/src/main/java/com/ft/sdk/reactnative/extensions/ReactDrawablesExt.java +0 -155
  102. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/NoopTextPropertiesResolver.java +0 -23
  103. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/ReactNativeSessionReplayExtensionSupport.java +0 -57
  104. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/ShadowNodeWrapper.java +0 -84
  105. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/TextPropertiesResolver.java +0 -20
  106. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/DefaultMapper.java +0 -78
  107. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/Pair.java +0 -11
  108. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/ReactEditTextMapper.java +0 -136
  109. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/ReactNativeImageViewMapper.java +0 -117
  110. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/ReactTextMapper.java +0 -57
  111. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/ReactViewGroupMapper.java +0 -22
  112. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/mappers/ReactViewModalMapper.java +0 -21
  113. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/resources/ReactDrawableCopier.java +0 -35
  114. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/utils/DrawableUtils.java +0 -34
  115. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/utils/ReflectionUtils.java +0 -43
  116. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/utils/text/FabricTextViewUtils.java +0 -69
  117. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/utils/text/LegacyTextViewUtils.java +0 -97
  118. package/android/src/main/java/com/ft/sdk/reactnative/sessionreplay/utils/text/TextViewUtils.java +0 -184
  119. package/android/src/main/java/com/ft/sdk/reactnative/utils/ColorUtils.java +0 -24
  120. package/android/src/newarch/java/com/ft/sdk/reactnative/FTSessionReplayModule.java +0 -30
  121. package/android/src/oldarch/java/com/ft/sdk/reactnative/FTSessionReplayModule.java +0 -25
  122. package/android/src/rn69/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -100
  123. package/android/src/rn75/java/com/ft/sdk/reactnative/sessionreplay/extensions/LengthPercentageExt.java +0 -27
  124. package/android/src/rn75/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -116
  125. package/android/src/rn76/java/com/ft/sdk/reactnative/sessionreplay/extensions/LengthPercentageExt.java +0 -38
  126. package/android/src/rn76/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -117
  127. package/android/src/rn79/java/com/ft/sdk/reactnative/sessionreplay/extensions/LengthPercentageExt.java +0 -38
  128. package/android/src/rn79/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -132
  129. package/android/src/rn80/java/com/ft/sdk/reactnative/sessionreplay/extensions/ComputedBorderRadiusExt.java +0 -58
  130. package/android/src/rn80/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -190
  131. package/android/src/rnlegacy/java/com/ft/sdk/reactnative/sessionreplay/utils/ReactViewBackgroundDrawableUtils.java +0 -120
  132. package/ios/.idea/.name +0 -1
  133. package/ios/.idea/ios.iml +0 -2
  134. package/ios/.idea/modules.xml +0 -8
  135. package/ios/.idea/vcs.xml +0 -6
  136. package/ios/.idea/xcode.xml +0 -4
  137. package/ios/FTMobileReactNative.m +0 -184
  138. package/ios/FTRCTTextViewRecorder.h +0 -33
  139. package/ios/FTRCTTextViewRecorder.m +0 -120
  140. package/ios/FTReactNativeLog.m +0 -60
  141. package/ios/FTReactNativeSessionReplay.h +0 -6
  142. package/ios/FTReactNativeSessionReplay.mm +0 -44
  143. package/ios/FTReactNativeTrace.m +0 -56
  144. package/ios/FtMobileAgent.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -4
  145. package/ios/FtMobileAgent.xcodeproj/project.xcworkspace/xcuserdata/Brandon.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
  146. package/ios/FtMobileAgent.xcodeproj/project.xcworkspace/xcuserdata/Brandon.xcuserdatad/xcschemes/xcschememanagement.plist +0 -5
  147. package/ios/FtMobileAgent.xcodeproj/xcuserdata/Brandon.xcuserdatad/xcschemes/FtMobileAgent.xcscheme +0 -56
  148. package/ios/FtMobileAgent.xcodeproj/xcuserdata/Brandon.xcuserdatad/xcschemes/xcschememanagement.plist +0 -14
  149. package/ios/RCTVersion.h +0 -8
  150. package/lib/commonjs/ft_session_replay.js +0 -34
  151. package/lib/commonjs/ft_session_replay.js.map +0 -1
  152. package/lib/module/ft_session_replay.js +0 -29
  153. package/lib/module/ft_session_replay.js.map +0 -1
  154. package/lib/typescript/ft_session_replay.d.ts +0 -27
  155. package/src/ft_session_replay.tsx +0 -34
@@ -1,9 +1,98 @@
1
+ var _BridgeContextManager;
1
2
  function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
2
3
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
3
4
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
- import { NativeModules } from 'react-native';
5
+ import { NativeEventEmitter, NativeModules } from 'react-native';
5
6
  import { version as sdkVersion } from './version';
6
7
 
8
+ /**
9
+ * Bridge context manager for managing shared properties across RUM and Logger modules
10
+ * This class provides a centralized way to store and retrieve global properties that will be
11
+ * automatically merged with local properties when making calls to RUM and Logger functions
12
+ */
13
+ class BridgeContextManager {
14
+ constructor() {
15
+ _defineProperty(this, "properties", new Map());
16
+ // Initialize with SDK version information
17
+ this.initializeSDKInfo();
18
+ }
19
+
20
+ /**
21
+ * Initialize SDK information properties
22
+ * @private
23
+ */
24
+ initializeSDKInfo() {
25
+ // Create sdk_bridge_info with version information
26
+ const sdkBridgeInfo = {
27
+ react_native: sdkVersion
28
+ };
29
+
30
+ // Set the sdk_bridge_info property
31
+ this.properties.set('sdk_bridge_info', JSON.stringify(sdkBridgeInfo));
32
+ }
33
+
34
+ /**
35
+ * Get singleton instance of BridgeContextManager
36
+ * @returns BridgeContextManager instance
37
+ */
38
+ static getInstance() {
39
+ if (!BridgeContextManager.instance) {
40
+ BridgeContextManager.instance = new BridgeContextManager();
41
+ }
42
+ return BridgeContextManager.instance;
43
+ }
44
+
45
+ /**
46
+ * Add bridge context properties that will be automatically merged with local properties
47
+ * @param properties Object containing key-value pairs
48
+ */
49
+ appendBridgeContext(properties) {
50
+ // Store properties locally in JavaScript
51
+ try {
52
+ // Store properties locally in JavaScript
53
+ Object.entries(properties).forEach(([key, value]) => {
54
+ this.properties.set(key, value);
55
+ });
56
+ } catch (error) {
57
+ console.warn('Failed to append bridge context:', error);
58
+ }
59
+ }
60
+
61
+ /**
62
+ * Merge bridge context properties with local properties
63
+ * Bridge context properties take precedence over local properties
64
+ * @param localProperties Local properties to merge with bridge context properties
65
+ * @returns Merged properties object
66
+ */
67
+ mergeWithLocalPropertiesSync(localProperties) {
68
+ try {
69
+ const merged = {};
70
+
71
+ // First add local properties (if any)
72
+ if (localProperties) {
73
+ Object.assign(merged, localProperties);
74
+ }
75
+
76
+ // Then add bridge context properties (these will override local properties with same keys)
77
+ this.properties.forEach((value, key) => {
78
+ merged[key] = value;
79
+ });
80
+ return merged;
81
+ } catch (error) {
82
+ console.warn('Failed to merge bridge context with local properties:', error);
83
+ // Return empty object or only local properties on error
84
+ return localProperties ? {
85
+ ...localProperties
86
+ } : {};
87
+ }
88
+ }
89
+ }
90
+
91
+ // Internal bridge context manager - not exported
92
+ _BridgeContextManager = BridgeContextManager;
93
+ _defineProperty(BridgeContextManager, "instance", void 0);
94
+ export const bridgeContextManager = BridgeContextManager.getInstance();
95
+
7
96
  /**
8
97
  * Environment.
9
98
  */
@@ -15,13 +104,45 @@ export let EnvType = /*#__PURE__*/function (EnvType) {
15
104
  EnvType[EnvType["local"] = 4] = "local";
16
105
  return EnvType;
17
106
  }({});
18
- ;
19
107
  export let FTDBCacheDiscard = /*#__PURE__*/function (FTDBCacheDiscard) {
20
108
  FTDBCacheDiscard[FTDBCacheDiscard["discard"] = 0] = "discard";
21
109
  FTDBCacheDiscard[FTDBCacheDiscard["discardOldest"] = 1] = "discardOldest";
22
110
  return FTDBCacheDiscard;
23
111
  }({});
24
- ;
112
+
113
+ /**
114
+ * Remote config override rule matching condition for custom keys. Supports exact match and contains match.
115
+ * For exact match, set the value directly, for example: "userid": "test_user", which means the rule will be applied when the custom key "userid" is exactly "test_user".
116
+ * For contains match, set the value as an object with a "contains" field, for example: "userid": { "contains": "test_user" }, which means the rule will be applied when the custom key "userid" contains the object "test_user".
117
+ */
118
+
119
+ /**
120
+ * Matching rules for remote config override
121
+ * Defines matching conditions using customKeys
122
+ */
123
+
124
+ /**
125
+ * Values that can be modified by remote config override rules.
126
+ * These values will adjust the fetched remote configuration before it is applied.
127
+ */
128
+
129
+ /**
130
+ * Remote config override rules .
131
+ * Adjust the fetched remote configuration before application.
132
+ */
133
+
134
+ /**
135
+ * Final result of the remote config update
136
+ * @param triggerType the type of remote config update trigger, auto or manual
137
+ * @param success whether the remote config update was successful
138
+ * @param platform the platform of the device, ios or android
139
+ * @param timestamp the timestamp when the remote config update was triggered
140
+ * @param rawJson the final remote config update result, in JSON string format
141
+ * @param errorCode the error code if the remote config update failed, may be null if the update was successful
142
+ * @param errorMessage the error message if the remote config update failed, may be null if the update was successful
143
+ * @param appliedOverrideRuleIds the list of override rule IDs applied in this remote config update, may be null if no rules were applied
144
+ */
145
+
25
146
  /**
26
147
  * Configure SDK startup parameters.
27
148
  * @param serverUrl data reporting address, deprecated, use [datakitUrl] instead
@@ -36,6 +157,8 @@ export let FTDBCacheDiscard = /*#__PURE__*/function (FTDBCacheDiscard) {
36
157
  * @param syncSleepTime interval time between each request during data synchronization, unit milliseconds, 0 < syncSleepTime < 100
37
158
  * @param enableDataIntegerCompatible whether to enable data integer compatibility during data synchronization, enabled by default
38
159
  * @param compressIntakeRequests whether to compress synchronized data
160
+ * @param enableDataFilter whether to enable SDK-side local data filters, enabled by default
161
+ * @param dataFilters local blocklist filter rules. Supported categories include `logging` and `rum`. Any data that matches a rule will be discarded.
39
162
  * @param globalContext custom global parameters
40
163
  * @param groupIdentifiers iOS side sets the AppGroups Identifier array corresponding to the collected Widget Extension
41
164
  * @param enableLimitWithDbSize set whether to enable using db to limit data size, after enabling, `FTLogConfig.logCacheLimitCount` and `FTRUMConfig.rumCacheLimitCount` will no longer take effect
@@ -43,19 +166,39 @@ export let FTDBCacheDiscard = /*#__PURE__*/function (FTDBCacheDiscard) {
43
166
  * @param dbDiscardStrategy db data discard strategy
44
167
  * @param dataModifier data modifier, modify individual fields {key:value}, after setting, the SDK will replace the original value with the set value according to the key
45
168
  * @param lineDataModifier data modifier, modify single data {"measurement":measurement,"data":{key:value}}, after setting, the SDK will replace the original value with the set value according to the key
169
+ * @param remoteConfiguration Set whether to enable remote dynamic configuration
170
+ * @param remoteConfigMiniUpdateInterval Set remote dynamic configuration minimum update interval, unit seconds, default 12*60*60
171
+ * @param remoteConfigOverrideRules Remote config override rules .Adjust the fetched remote configuration before application.
46
172
  */
47
173
 
48
174
  class FTMobileReactNativeWrapper {
49
175
  constructor() {
50
- _defineProperty(this, "sdk", NativeModules.FTMobileReactNative);
176
+ /* eslint-disable @typescript-eslint/no-var-requires */
177
+ _defineProperty(this, "sdk", require('./specs/NativeFTMobileReactNative').default);
178
+ /* eslint-enable @typescript-eslint/no-var-requires */
179
+ _defineProperty(this, "emitter", null);
180
+ }
181
+ getEmitter() {
182
+ var _NativeModules$FTMobi;
183
+ if (this.emitter) {
184
+ return this.emitter;
185
+ }
186
+ const nativeEventModule = (_NativeModules$FTMobi = NativeModules.FTMobileReactNative) !== null && _NativeModules$FTMobi !== void 0 ? _NativeModules$FTMobi : this.sdk;
187
+ this.emitter = new NativeEventEmitter(nativeEventModule);
188
+ return this.emitter;
51
189
  }
52
190
  sdkConfig(config) {
53
191
  if (config.serverUrl != null && config.serverUrl.length > 0 && config.datakitUrl == null) {
54
192
  config.datakitUrl = config.serverUrl;
55
193
  }
56
- config.pkgInfo = sdkVersion;
57
194
  return this.sdk.sdkConfig(config);
58
195
  }
196
+ setDatakitURL(datakitUrl) {
197
+ return this.sdk.setDatakitURL(datakitUrl);
198
+ }
199
+ setDatawayURL(datawayUrl, clientToken) {
200
+ return this.sdk.setDatawayURL(datawayUrl, clientToken);
201
+ }
59
202
  bindRUMUserData(userId, userName, userEmail, extra) {
60
203
  return this.sdk.bindRUMUserData(userId, userName, userEmail, extra);
61
204
  }
@@ -83,6 +226,19 @@ class FTMobileReactNativeWrapper {
83
226
  clearAllData() {
84
227
  return this.sdk.clearAllData();
85
228
  }
229
+ appendBridgeContext(properties) {
230
+ // Use bridgeContextManager to store properties in JavaScript and send to native SDK
231
+ bridgeContextManager.appendBridgeContext(properties);
232
+ }
233
+ updateRemoteConfig() {
234
+ return this.sdk.updateRemoteConfig();
235
+ }
236
+ updateRemoteConfigWithMiniUpdateInterval(interval, rules) {
237
+ return this.sdk.updateRemoteConfigWithMiniUpdateInterval(interval, rules);
238
+ }
239
+ addRemoteConfigListener(listener) {
240
+ return this.getEmitter().addListener('ft_remote_config_callback', listener);
241
+ }
86
242
  }
87
243
  export const FTMobileReactNative = new FTMobileReactNativeWrapper();
88
244
  //# sourceMappingURL=ft_mobile_agent.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["NativeModules","version","sdkVersion","EnvType","FTDBCacheDiscard","FTMobileReactNativeWrapper","constructor","_defineProperty","FTMobileReactNative","sdkConfig","config","serverUrl","length","datakitUrl","pkgInfo","sdk","bindRUMUserData","userId","userName","userEmail","extra","unbindRUMUserData","appendGlobalContext","context","appendLogGlobalContext","appendRUMGlobalContext","trackEventFromExtension","identifier","flushSyncData","shutDown","clearAllData"],"sources":["ft_mobile_agent.tsx"],"sourcesContent":["import { NativeModules } from 'react-native';\nimport { version as sdkVersion } from './version'\n\n/**\n * Environment.\n */\nexport enum EnvType {\n prod, gray, pre, common, local\n};\nexport enum FTDBCacheDiscard { discard, discardOldest };\n/**\n * Configure SDK startup parameters.\n * @param serverUrl data reporting address, deprecated, use [datakitUrl] instead\n * @param datakitUrl datakit access URL address, example: http://10.0.0.1:9529, default port 9529. Choose one between datakit and dataway configuration\n * @param datawayUrl dataway access URL address, example: http://10.0.0.1:9528, default port 9528, note: the device installing the SDK needs to be able to access this address. Note: choose one between datakit and dataway configuration\n * @param clientToken dataway authentication token, needs to be configured together with [datawayUrl]\n * @param debug set whether to allow log printing, default false\n * @param env environment, default prod\n * @param service set the name of the business or service it belongs to, default: `df_rum_ios`, `df_rum_android`\n * @param autoSync whether data is automatically synchronized and uploaded, default: true\n * @param syncPageSize number of synchronized items per request during data synchronization, minimum value 5, default: 10\n * @param syncSleepTime interval time between each request during data synchronization, unit milliseconds, 0 < syncSleepTime < 100\n * @param enableDataIntegerCompatible whether to enable data integer compatibility during data synchronization, enabled by default\n * @param compressIntakeRequests whether to compress synchronized data\n * @param globalContext custom global parameters\n * @param groupIdentifiers iOS side sets the AppGroups Identifier array corresponding to the collected Widget Extension\n * @param enableLimitWithDbSize set whether to enable using db to limit data size, after enabling, `FTLogConfig.logCacheLimitCount` and `FTRUMConfig.rumCacheLimitCount` will no longer take effect\n * @param dbCacheLimit db cache limit size, minimum value 30MB, default 100MB, unit byte\n * @param dbDiscardStrategy db data discard strategy\n * @param dataModifier data modifier, modify individual fields {key:value}, after setting, the SDK will replace the original value with the set value according to the key\n * @param lineDataModifier data modifier, modify single data {\"measurement\":measurement,\"data\":{key:value}}, after setting, the SDK will replace the original value with the set value according to the key\n */\n export interface FTMobileConfig {\n /**\n * @deprecated \"serverUrl\" parameter renamed to \"datakitUrl\"\n */\n serverUrl?: string,\n datakitUrl?: string,\n datawayUrl?: string,\n clientToken?: string,\n debug?:boolean,\n envType?:EnvType,\n env?:string,\n service?:string,\n autoSync?:boolean,\n syncPageSize?:number,\n syncSleepTime?:number,\n enableDataIntegerCompatible?:boolean,\n compressIntakeRequests?:boolean,\n globalContext?:object,\n groupIdentifiers?:Array<string>,\n enableLimitWithDbSize?:boolean,\n dbCacheLimit?:number,\n dbDiscardStrategy?:FTDBCacheDiscard,\n pkgInfo?: string,\n dataModifier?:object,\n lineDataModifier?:object\n }\n\n\ntype FTMobileReactNativeType = {\n\n /**\n * SDK initialization method.\n * @param config SDK initialization configuration items.\n * @returns a Promise.\n */\n sdkConfig(config:FTMobileConfig): Promise<void>;\n /**\n * Bind user.\n * @param userId user ID.\n * @param userName user name.\n * @param userEmail user email\n * @param extra additional user information\n * @returns a Promise.\n */\n bindRUMUserData(userId: string,userName?:string,userEmail?:string,extra?:object): Promise<void>;\n /**\n * Unbind user.\n * @returns a Promise.\n */\n unbindRUMUserData(): Promise<void>;\n /**\n * Add custom global parameters. Applies to RUM and Log data\n * @param context custom global parameters.\n * @returns a Promise.\n */\n appendGlobalContext(context:object):Promise<void>;\n /**\n * Add custom RUM global parameters. Applies to RUM data\n * @param context custom RUM global parameters.\n * @returns a Promise.\n */\n appendRUMGlobalContext(context:object):Promise<void>;\n /**\n * Add custom RUM and Log global parameters. Applies to Log data\n * @param context custom Log global parameters.\n * @returns a Promise.\n */\n appendLogGlobalContext(context:object):Promise<void>;\n /**\n * Actively synchronize data. When `FTMobileConfig.autoSync=false` is configured, you need to actively trigger this method to synchronize data.\n * @returns a Promise.\n */\n flushSyncData():Promise<void>;\n\n /**\n * Synchronize events in iOS Widget Extension, iOS only\n * @param groupIdentifier app groupId\n * @returns {groupIdentifier:string,datas:Array<object>} can be used to view data collected in Extension.\n */\n trackEventFromExtension(identifier:string): Promise<object>\n /**\n * Shut down objects currently running in the SDK\n */\n shutDown():Promise<void>\n /**\n * Clear all data that has not yet been uploaded to the server.\n */\n clearAllData():Promise<void>\n };\n\n class FTMobileReactNativeWrapper implements FTMobileReactNativeType {\n private sdk:FTMobileReactNativeType = NativeModules.FTMobileReactNative;\n sdkConfig(config:FTMobileConfig): Promise<void> {\n if(config.serverUrl != null && config.serverUrl.length>0 && config.datakitUrl == null){\n config.datakitUrl = config.serverUrl;\n }\n config.pkgInfo = sdkVersion;\n return this.sdk.sdkConfig(config);\n }\n bindRUMUserData(userId: string,userName?:string,userEmail?:string,extra?:object): Promise<void> {\n return this.sdk.bindRUMUserData(userId,userName,userEmail,extra);\n }\n unbindRUMUserData(): Promise<void> {\n return this.sdk.unbindRUMUserData();\n }\n appendGlobalContext(context: object): Promise<void> {\n return this.sdk.appendGlobalContext(context);\n }\n appendLogGlobalContext(context: object): Promise<void> {\n return this.sdk.appendLogGlobalContext(context);\n }\n appendRUMGlobalContext(context: object): Promise<void> {\n return this.sdk.appendRUMGlobalContext(context);\n }\n trackEventFromExtension(identifier:string) :Promise<object>{\n return this.sdk.trackEventFromExtension(identifier);\n }\n flushSyncData():Promise<void>{\n return this.sdk.flushSyncData();\n }\n shutDown():Promise<void>{\n return this.sdk.shutDown();\n }\n clearAllData():Promise<void>{\n return this.sdk.clearAllData();\n }\n }\nexport const FTMobileReactNative: FTMobileReactNativeType = new FTMobileReactNativeWrapper();\n\n"],"mappings":";;;AAAA,SAASA,aAAa,QAAQ,cAAc;AAC5C,SAASC,OAAO,IAAIC,UAAU,QAAQ,WAAW;;AAEjD;AACA;AACA;AACA,WAAYC,OAAO,0BAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAPA,OAAO,CAAPA,OAAO;EAAA,OAAPA,OAAO;AAAA;AAElB;AACD,WAAYC,gBAAgB,0BAAhBA,gBAAgB;EAAhBA,gBAAgB,CAAhBA,gBAAgB;EAAhBA,gBAAgB,CAAhBA,gBAAgB;EAAA,OAAhBA,gBAAgB;AAAA;AAA2B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA2FC,MAAMC,0BAA0B,CAAoC;EAAAC,YAAA;IAAAC,eAAA,cAC5BP,aAAa,CAACQ,mBAAmB;EAAA;EACvEC,SAASA,CAACC,MAAqB,EAAiB;IAC9C,IAAGA,MAAM,CAACC,SAAS,IAAI,IAAI,IAAID,MAAM,CAACC,SAAS,CAACC,MAAM,GAAC,CAAC,IAAIF,MAAM,CAACG,UAAU,IAAI,IAAI,EAAC;MACpFH,MAAM,CAACG,UAAU,GAAGH,MAAM,CAACC,SAAS;IACtC;IACAD,MAAM,CAACI,OAAO,GAAGZ,UAAU;IAC3B,OAAO,IAAI,CAACa,GAAG,CAACN,SAAS,CAACC,MAAM,CAAC;EACnC;EACAM,eAAeA,CAACC,MAAc,EAACC,QAAgB,EAACC,SAAiB,EAACC,KAAa,EAAiB;IAC9F,OAAO,IAAI,CAACL,GAAG,CAACC,eAAe,CAACC,MAAM,EAACC,QAAQ,EAACC,SAAS,EAACC,KAAK,CAAC;EAClE;EACAC,iBAAiBA,CAAA,EAAkB;IACjC,OAAO,IAAI,CAACN,GAAG,CAACM,iBAAiB,CAAC,CAAC;EACrC;EACAC,mBAAmBA,CAACC,OAAe,EAAiB;IACnD,OAAO,IAAI,CAACR,GAAG,CAACO,mBAAmB,CAACC,OAAO,CAAC;EAC7C;EACAC,sBAAsBA,CAACD,OAAe,EAAiB;IACnD,OAAO,IAAI,CAACR,GAAG,CAACS,sBAAsB,CAACD,OAAO,CAAC;EACnD;EACAE,sBAAsBA,CAACF,OAAe,EAAiB;IACnD,OAAO,IAAI,CAACR,GAAG,CAACU,sBAAsB,CAACF,OAAO,CAAC;EACnD;EACAG,uBAAuBA,CAACC,UAAiB,EAAkB;IACzD,OAAO,IAAI,CAACZ,GAAG,CAACW,uBAAuB,CAACC,UAAU,CAAC;EACrD;EACAC,aAAaA,CAAA,EAAgB;IAC5B,OAAO,IAAI,CAACb,GAAG,CAACa,aAAa,CAAC,CAAC;EAChC;EACAC,QAAQA,CAAA,EAAgB;IACvB,OAAO,IAAI,CAACd,GAAG,CAACc,QAAQ,CAAC,CAAC;EAC3B;EACAC,YAAYA,CAAA,EAAgB;IAC3B,OAAO,IAAI,CAACf,GAAG,CAACe,YAAY,CAAC,CAAC;EAC/B;AACF;AACD,OAAO,MAAMtB,mBAA4C,GAAG,IAAIH,0BAA0B,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["NativeEventEmitter","NativeModules","version","sdkVersion","BridgeContextManager","constructor","_defineProperty","Map","initializeSDKInfo","sdkBridgeInfo","react_native","properties","set","JSON","stringify","getInstance","instance","appendBridgeContext","Object","entries","forEach","key","value","error","console","warn","mergeWithLocalPropertiesSync","localProperties","merged","assign","_BridgeContextManager","bridgeContextManager","EnvType","FTDBCacheDiscard","FTMobileReactNativeWrapper","require","default","getEmitter","_NativeModules$FTMobi","emitter","nativeEventModule","FTMobileReactNative","sdk","sdkConfig","config","serverUrl","length","datakitUrl","setDatakitURL","setDatawayURL","datawayUrl","clientToken","bindRUMUserData","userId","userName","userEmail","extra","unbindRUMUserData","appendGlobalContext","context","appendLogGlobalContext","appendRUMGlobalContext","trackEventFromExtension","identifier","flushSyncData","shutDown","clearAllData","updateRemoteConfig","updateRemoteConfigWithMiniUpdateInterval","interval","rules","addRemoteConfigListener","listener","addListener"],"sources":["ft_mobile_agent.tsx"],"sourcesContent":["import {\n EmitterSubscription,\n NativeEventEmitter,\n NativeModules,\n} from 'react-native';\nimport { version as sdkVersion } from './version';\n\n/**\n * Bridge context manager for managing shared properties across RUM and Logger modules\n * This class provides a centralized way to store and retrieve global properties that will be\n * automatically merged with local properties when making calls to RUM and Logger functions\n */\nclass BridgeContextManager {\n private static instance: BridgeContextManager;\n private properties: Map<string, any> = new Map();\n\n private constructor() {\n // Initialize with SDK version information\n this.initializeSDKInfo();\n }\n\n /**\n * Initialize SDK information properties\n * @private\n */\n private initializeSDKInfo(): void {\n // Create sdk_bridge_info with version information\n const sdkBridgeInfo = {\n react_native: sdkVersion,\n };\n\n // Set the sdk_bridge_info property\n this.properties.set('sdk_bridge_info', JSON.stringify(sdkBridgeInfo));\n }\n\n /**\n * Get singleton instance of BridgeContextManager\n * @returns BridgeContextManager instance\n */\n public static getInstance(): BridgeContextManager {\n if (!BridgeContextManager.instance) {\n BridgeContextManager.instance = new BridgeContextManager();\n }\n return BridgeContextManager.instance;\n }\n\n /**\n * Add bridge context properties that will be automatically merged with local properties\n * @param properties Object containing key-value pairs\n */\n public appendBridgeContext(properties: Record<string, any>): void {\n // Store properties locally in JavaScript\n try {\n // Store properties locally in JavaScript\n Object.entries(properties).forEach(([key, value]) => {\n this.properties.set(key, value);\n });\n } catch (error) {\n console.warn('Failed to append bridge context:', error);\n }\n }\n\n /**\n * Merge bridge context properties with local properties\n * Bridge context properties take precedence over local properties\n * @param localProperties Local properties to merge with bridge context properties\n * @returns Merged properties object\n */\n public mergeWithLocalPropertiesSync(\n localProperties?: object\n ): Record<string, any> {\n try {\n const merged: Record<string, any> = {};\n\n // First add local properties (if any)\n if (localProperties) {\n Object.assign(merged, localProperties);\n }\n\n // Then add bridge context properties (these will override local properties with same keys)\n this.properties.forEach((value, key) => {\n merged[key] = value;\n });\n\n return merged;\n } catch (error) {\n console.warn(\n 'Failed to merge bridge context with local properties:',\n error\n );\n // Return empty object or only local properties on error\n return localProperties ? { ...localProperties } : {};\n }\n }\n}\n\n// Internal bridge context manager - not exported\nexport const bridgeContextManager = BridgeContextManager.getInstance();\n\n/**\n * Environment.\n */\nexport enum EnvType {\n prod,\n gray,\n pre,\n common,\n local,\n}\nexport enum FTDBCacheDiscard {\n discard,\n discardOldest,\n}\n\n/**\n * Remote config override rule matching condition for custom keys. Supports exact match and contains match.\n * For exact match, set the value directly, for example: \"userid\": \"test_user\", which means the rule will be applied when the custom key \"userid\" is exactly \"test_user\".\n * For contains match, set the value as an object with a \"contains\" field, for example: \"userid\": { \"contains\": \"test_user\" }, which means the rule will be applied when the custom key \"userid\" contains the object \"test_user\".\n */\nexport type FTRemoteConfigCustomKeyContainsMatch = {\n contains: string | number | boolean;\n};\n\n/**\n * Matching rules for remote config override\n * Defines matching conditions using customKeys\n */\nexport type FTRemoteConfigOverrideMatch = {\n customKeys?: Record<\n string,\n string | number | boolean | FTRemoteConfigCustomKeyContainsMatch\n >;\n};\n\n/**\n * Values that can be modified by remote config override rules.\n * These values will adjust the fetched remote configuration before it is applied.\n */\nexport type FTRemoteConfigOverrideValues = {\n env?: string;\n serviceName?: string;\n autoSync?: boolean;\n compressIntakeRequests?: boolean;\n syncPageSize?: number;\n syncSleepTime?: number;\n rumSampleRate?: number;\n rumSessionOnErrorSampleRate?: number;\n rumEnableTraceUserAction?: boolean;\n rumEnableTraceUserView?: boolean;\n rumEnableTraceUserResource?: boolean;\n rumEnableResourceHostIP?: boolean;\n rumEnableTrackAppUIBlock?: boolean;\n rumBlockDurationMs?: number;\n rumEnableTrackAppCrash?: boolean;\n rumEnableTrackAppANR?: boolean;\n rumEnableTraceWebView?: boolean;\n rumAllowWebViewHost?: Array<string>;\n traceSampleRate?: number;\n traceEnableAutoTrace?: boolean;\n traceType?: string;\n logSampleRate?: number;\n logLevelFilters?: Array<string>;\n logEnableCustomLog?: boolean;\n logEnableConsoleLog?: boolean;\n};\n\n/**\n * Remote config override rules .\n * Adjust the fetched remote configuration before application.\n */\nexport type FTRemoteConfigOverrideRule = {\n id?: string;\n enabled?: boolean;\n match: FTRemoteConfigOverrideMatch;\n override: FTRemoteConfigOverrideValues;\n};\n/**\n * Final result of the remote config update\n * @param triggerType the type of remote config update trigger, auto or manual\n * @param success whether the remote config update was successful\n * @param platform the platform of the device, ios or android\n * @param timestamp the timestamp when the remote config update was triggered\n * @param rawJson the final remote config update result, in JSON string format\n * @param errorCode the error code if the remote config update failed, may be null if the update was successful\n * @param errorMessage the error message if the remote config update failed, may be null if the update was successful\n * @param appliedOverrideRuleIds the list of override rule IDs applied in this remote config update, may be null if no rules were applied\n */\nexport type FTRemoteConfigResult = {\n triggerType: 'auto' | 'manual';\n success: boolean;\n platform: 'ios' | 'android';\n timestamp: number;\n rawJson?: string;\n errorCode?: string | number;\n errorMessage?: string;\n appliedOverrideRuleIds?: string[];\n};\n/**\n * Configure SDK startup parameters.\n * @param serverUrl data reporting address, deprecated, use [datakitUrl] instead\n * @param datakitUrl datakit access URL address, example: http://10.0.0.1:9529, default port 9529. Choose one between datakit and dataway configuration\n * @param datawayUrl dataway access URL address, example: http://10.0.0.1:9528, default port 9528, note: the device installing the SDK needs to be able to access this address. Note: choose one between datakit and dataway configuration\n * @param clientToken dataway authentication token, needs to be configured together with [datawayUrl]\n * @param debug set whether to allow log printing, default false\n * @param env environment, default prod\n * @param service set the name of the business or service it belongs to, default: `df_rum_ios`, `df_rum_android`\n * @param autoSync whether data is automatically synchronized and uploaded, default: true\n * @param syncPageSize number of synchronized items per request during data synchronization, minimum value 5, default: 10\n * @param syncSleepTime interval time between each request during data synchronization, unit milliseconds, 0 < syncSleepTime < 100\n * @param enableDataIntegerCompatible whether to enable data integer compatibility during data synchronization, enabled by default\n * @param compressIntakeRequests whether to compress synchronized data\n * @param enableDataFilter whether to enable SDK-side local data filters, enabled by default\n * @param dataFilters local blocklist filter rules. Supported categories include `logging` and `rum`. Any data that matches a rule will be discarded.\n * @param globalContext custom global parameters\n * @param groupIdentifiers iOS side sets the AppGroups Identifier array corresponding to the collected Widget Extension\n * @param enableLimitWithDbSize set whether to enable using db to limit data size, after enabling, `FTLogConfig.logCacheLimitCount` and `FTRUMConfig.rumCacheLimitCount` will no longer take effect\n * @param dbCacheLimit db cache limit size, minimum value 30MB, default 100MB, unit byte\n * @param dbDiscardStrategy db data discard strategy\n * @param dataModifier data modifier, modify individual fields {key:value}, after setting, the SDK will replace the original value with the set value according to the key\n * @param lineDataModifier data modifier, modify single data {\"measurement\":measurement,\"data\":{key:value}}, after setting, the SDK will replace the original value with the set value according to the key\n * @param remoteConfiguration Set whether to enable remote dynamic configuration\n * @param remoteConfigMiniUpdateInterval Set remote dynamic configuration minimum update interval, unit seconds, default 12*60*60\n * @param remoteConfigOverrideRules Remote config override rules .Adjust the fetched remote configuration before application.\n */\nexport interface FTMobileConfig {\n /**\n * @deprecated \"serverUrl\" parameter renamed to \"datakitUrl\"\n */\n serverUrl?: string;\n datakitUrl?: string;\n datawayUrl?: string;\n clientToken?: string;\n debug?: boolean;\n envType?: EnvType;\n env?: string;\n service?: string;\n autoSync?: boolean;\n syncPageSize?: number;\n syncSleepTime?: number;\n enableDataIntegerCompatible?: boolean;\n compressIntakeRequests?: boolean;\n enableDataFilter?: boolean;\n dataFilters?: Record<string, Array<string>>;\n globalContext?: object;\n groupIdentifiers?: Array<string>;\n enableLimitWithDbSize?: boolean;\n dbCacheLimit?: number;\n dbDiscardStrategy?: FTDBCacheDiscard;\n dataModifier?: object;\n lineDataModifier?: object;\n remoteConfiguration?: boolean;\n remoteConfigMiniUpdateInterval?: number;\n remoteConfigOverrideRules?: Array<FTRemoteConfigOverrideRule>;\n}\n\ntype FTMobileReactNativeType = {\n /**\n * SDK initialization method.\n * @param config SDK initialization configuration items.\n * @returns a Promise.\n */\n sdkConfig(config: FTMobileConfig): Promise<void>;\n /**\n * Dynamically set the Datakit upload URL after SDK initialization.\n * @param datakitUrl Datakit upload URL.\n * @returns a Promise.\n */\n setDatakitURL(datakitUrl: string): Promise<void>;\n /**\n * Dynamically set the Dataway upload URL and client token after SDK initialization.\n * @param datawayUrl Dataway upload URL.\n * @param clientToken Dataway authentication token.\n * @returns a Promise.\n */\n setDatawayURL(datawayUrl: string, clientToken: string): Promise<void>;\n /**\n * Bind user.\n * @param userId user ID.\n * @param userName user name.\n * @param userEmail user email\n * @param extra additional user information\n * @returns a Promise.\n */\n bindRUMUserData(\n userId: string,\n userName?: string,\n userEmail?: string,\n extra?: object\n ): Promise<void>;\n /**\n * Unbind user.\n * @returns a Promise.\n */\n unbindRUMUserData(): Promise<void>;\n /**\n * Add custom global parameters. Applies to RUM and Log data\n * @param context custom global parameters.\n * @returns a Promise.\n */\n appendGlobalContext(context: object): Promise<void>;\n /**\n * Add custom RUM global parameters. Applies to RUM data\n * @param context custom RUM global parameters.\n * @returns a Promise.\n */\n appendRUMGlobalContext(context: object): Promise<void>;\n /**\n * Add custom RUM and Log global parameters. Applies to Log data\n * @param context custom Log global parameters.\n * @returns a Promise.\n */\n appendLogGlobalContext(context: object): Promise<void>;\n /**\n * Actively synchronize data. When `FTMobileConfig.autoSync=false` is configured, you need to actively trigger this method to synchronize data.\n * @returns a Promise.\n */\n flushSyncData(): Promise<void>;\n\n /**\n * Synchronize events in iOS Widget Extension, iOS only\n * @param groupIdentifier app groupId\n * @returns {groupIdentifier:string,datas:Array<object>} can be used to view data collected in Extension.\n */\n trackEventFromExtension(identifier: string): Promise<object>;\n /**\n * Shut down objects currently running in the SDK\n */\n shutDown(): Promise<void>;\n /**\n * Clear all data that has not yet been uploaded to the server.\n */\n clearAllData(): Promise<void>;\n /**\n * Add bridge context properties that will be automatically merged with local properties\n * @param properties Object containing key-value pairs\n */\n appendBridgeContext(properties: Record<string, any>): void;\n /**\n * Update remote configuration, after enabling remote configuration, you can call this method to update the configuration in real time.\n */\n updateRemoteConfig(): Promise<FTRemoteConfigResult>;\n /**\n * Update remote configuration with minimum update interval, after enabling remote configuration, you can call this method to update the configuration in real time.\n * This method is used to set the minimum update interval for remote configuration updates. If the time since the last update is less than the specified interval, the update will not be performed.\n * @param interval minimum update interval, unit seconds\n * @param rules Remote config override rules .Adjust the fetched remote configuration before application.\n * @returns the result of the remote config update\n */\n updateRemoteConfigWithMiniUpdateInterval(\n interval: number,\n rules?: Array<FTRemoteConfigOverrideRule>\n ): Promise<FTRemoteConfigResult>;\n /**\n * Listen for auto remote configuration updates triggered by the native SDK.\n * Manual updates are returned through the update Promise instead of this event.\n */\n addRemoteConfigListener(\n listener: (result: FTRemoteConfigResult) => void\n ): EmitterSubscription;\n};\n\nclass FTMobileReactNativeWrapper implements FTMobileReactNativeType {\n /* eslint-disable @typescript-eslint/no-var-requires */\n private sdk: FTMobileReactNativeType =\n require('./specs/NativeFTMobileReactNative').default;\n /* eslint-enable @typescript-eslint/no-var-requires */\n\n private emitter: NativeEventEmitter | null = null;\n\n private getEmitter(): NativeEventEmitter {\n if (this.emitter) {\n return this.emitter;\n }\n\n const nativeEventModule = NativeModules.FTMobileReactNative ?? this.sdk;\n this.emitter = new NativeEventEmitter(nativeEventModule as never);\n return this.emitter;\n }\n\n sdkConfig(config: FTMobileConfig): Promise<void> {\n if (\n config.serverUrl != null &&\n config.serverUrl.length > 0 &&\n config.datakitUrl == null\n ) {\n config.datakitUrl = config.serverUrl;\n }\n return this.sdk.sdkConfig(config);\n }\n setDatakitURL(datakitUrl: string): Promise<void> {\n return this.sdk.setDatakitURL(datakitUrl);\n }\n setDatawayURL(datawayUrl: string, clientToken: string): Promise<void> {\n return this.sdk.setDatawayURL(datawayUrl, clientToken);\n }\n bindRUMUserData(\n userId: string,\n userName?: string,\n userEmail?: string,\n extra?: object\n ): Promise<void> {\n return this.sdk.bindRUMUserData(userId, userName, userEmail, extra);\n }\n unbindRUMUserData(): Promise<void> {\n return this.sdk.unbindRUMUserData();\n }\n appendGlobalContext(context: object): Promise<void> {\n return this.sdk.appendGlobalContext(context);\n }\n appendLogGlobalContext(context: object): Promise<void> {\n return this.sdk.appendLogGlobalContext(context);\n }\n appendRUMGlobalContext(context: object): Promise<void> {\n return this.sdk.appendRUMGlobalContext(context);\n }\n trackEventFromExtension(identifier: string): Promise<object> {\n return this.sdk.trackEventFromExtension(identifier);\n }\n flushSyncData(): Promise<void> {\n return this.sdk.flushSyncData();\n }\n shutDown(): Promise<void> {\n return this.sdk.shutDown();\n }\n clearAllData(): Promise<void> {\n return this.sdk.clearAllData();\n }\n appendBridgeContext(properties: Record<string, any>): void {\n // Use bridgeContextManager to store properties in JavaScript and send to native SDK\n bridgeContextManager.appendBridgeContext(properties);\n }\n updateRemoteConfig(): Promise<FTRemoteConfigResult> {\n return this.sdk.updateRemoteConfig();\n }\n updateRemoteConfigWithMiniUpdateInterval(\n interval: number,\n rules?: Array<FTRemoteConfigOverrideRule>\n ): Promise<FTRemoteConfigResult> {\n return this.sdk.updateRemoteConfigWithMiniUpdateInterval(interval, rules);\n }\n addRemoteConfigListener(\n listener: (result: FTRemoteConfigResult) => void\n ): EmitterSubscription {\n return this.getEmitter().addListener('ft_remote_config_callback', listener);\n }\n}\nexport const FTMobileReactNative: FTMobileReactNativeType =\n new FTMobileReactNativeWrapper();\n"],"mappings":"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","ignoreList":[]}
@@ -1,13 +1,15 @@
1
1
  function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
2
2
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
3
3
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
- import { NativeModules } from 'react-native';
4
+ // import { NativeModules } from 'react-native';
5
5
  import { FTRumErrorTracking } from './rum/FTRumErrorTracking';
6
6
  import { FTRumActionTracking } from './rum/FTRumActionTracking';
7
+ import { bridgeContextManager } from './ft_mobile_agent';
7
8
 
8
9
  /**
9
10
  * Error monitoring type.
10
11
  */
12
+ /* eslint-disable no-bitwise */
11
13
  export let ErrorMonitorType = /*#__PURE__*/function (ErrorMonitorType) {
12
14
  ErrorMonitorType[ErrorMonitorType["all"] = 4294967295] = "all";
13
15
  ErrorMonitorType[ErrorMonitorType["battery"] = 2] = "battery";
@@ -16,8 +18,8 @@ export let ErrorMonitorType = /*#__PURE__*/function (ErrorMonitorType) {
16
18
  return ErrorMonitorType;
17
19
  }({});
18
20
  /**
19
- * Page monitoring supplement type
20
- */
21
+ * Page monitoring supplement type
22
+ */
21
23
  export let DeviceMetricsMonitorType = /*#__PURE__*/function (DeviceMetricsMonitorType) {
22
24
  DeviceMetricsMonitorType[DeviceMetricsMonitorType["all"] = 4294967295] = "all";
23
25
  DeviceMetricsMonitorType[DeviceMetricsMonitorType["battery"] = 2] = "battery";
@@ -40,8 +42,26 @@ export let FTRUMCacheDiscard = /*#__PURE__*/function (FTRUMCacheDiscard) {
40
42
  FTRUMCacheDiscard[FTRUMCacheDiscard["discardOldest"] = 1] = "discardOldest";
41
43
  return FTRUMCacheDiscard;
42
44
  }({});
43
- ;
44
-
45
+ export let IOSCrashMonitoringType = /*#__PURE__*/function (IOSCrashMonitoringType) {
46
+ /** Monitor Mach kernel exceptions. */
47
+ IOSCrashMonitoringType[IOSCrashMonitoringType["machException"] = 1] = "machException";
48
+ /** Monitor fatal signals. */
49
+ IOSCrashMonitoringType[IOSCrashMonitoringType["signal"] = 2] = "signal";
50
+ /** Monitor uncaught C++ exceptions. */
51
+ IOSCrashMonitoringType[IOSCrashMonitoringType["cppException"] = 4] = "cppException";
52
+ /** Monitor uncaught Objective-C NSExceptions. */
53
+ IOSCrashMonitoringType[IOSCrashMonitoringType["nsException"] = 8] = "nsException";
54
+ /** Track and inject system information. */
55
+ IOSCrashMonitoringType[IOSCrashMonitoringType["system"] = 64] = "system";
56
+ /** Track and inject application state information. */
57
+ IOSCrashMonitoringType[IOSCrashMonitoringType["applicationState"] = 128] = "applicationState";
58
+ /** All crash monitor types. */
59
+ IOSCrashMonitoringType[IOSCrashMonitoringType["all"] = 207] = "all";
60
+ /** High compatibility crash monitor types (excludes Mach exceptions). */
61
+ IOSCrashMonitoringType[IOSCrashMonitoringType["highCompatibility"] = 206] = "highCompatibility";
62
+ return IOSCrashMonitoringType;
63
+ }({});
64
+ /* eslint-enable no-bitwise */
45
65
  /**
46
66
  * Set RUM tracking conditions.
47
67
  * @param androidAppId appId, apply during monitoring
@@ -64,6 +84,9 @@ export let FTRUMCacheDiscard = /*#__PURE__*/function (FTRUMCacheDiscard) {
64
84
  * @param globalContext custom global parameters
65
85
  * @param rumCacheLimitCount RUM max cache size, default 100_000
66
86
  * @param rumDiscardStrategy RUM data discard strategy
87
+ * @param enableTraceWebView Set whether to enable WebView data collection, default true
88
+ * @param allowWebViewHost Set specific hosts or domains allowed to collect WebView data, nil means collect all
89
+ * @param iosCrashMonitoringType iOS crash monitoring type , default is highCompatibility, which does not include Mach exceptions for better compatibility. you must enable system crash monitoring to get crash stack traces and crash information.
67
90
  */
68
91
 
69
92
  /**
@@ -76,7 +99,6 @@ export let FTRUMCacheDiscard = /*#__PURE__*/function (FTRUMCacheDiscard) {
76
99
  * @param resourceStatus response status code
77
100
  */
78
101
 
79
- ;
80
102
  /**
81
103
  * RUM Resource performance metrics.
82
104
  * @param duration resource load time
@@ -88,10 +110,10 @@ export let FTRUMCacheDiscard = /*#__PURE__*/function (FTRUMCacheDiscard) {
88
110
  * @param resource_first_byte resource first byte time
89
111
  */
90
112
 
91
- ;
92
113
  class FTReactNativeRUMWrapper {
93
114
  constructor() {
94
- _defineProperty(this, "rum", NativeModules.FTReactNativeRUM);
115
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
116
+ _defineProperty(this, "rum", require('./specs/NativeFTReactNativeRUM').default);
95
117
  }
96
118
  setConfig(config) {
97
119
  console.log('FTRUMConfig');
@@ -104,31 +126,47 @@ class FTReactNativeRUMWrapper {
104
126
  return this.rum.setConfig(config);
105
127
  }
106
128
  startAction(actionName, actionType, property) {
107
- return this.rum.startAction(actionName, actionType, property);
129
+ // Automatically merge bridge context properties with local properties
130
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
131
+ return this.rum.startAction(actionName, actionType, mergedProperties);
108
132
  }
109
133
  addAction(actionName, actionType, property) {
110
- return this.rum.addAction(actionName, actionType, property);
134
+ // Automatically merge bridge context properties with local properties
135
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
136
+ return this.rum.addAction(actionName, actionType, mergedProperties);
111
137
  }
112
138
  onCreateView(viewName, loadTime) {
113
139
  return this.rum.onCreateView(viewName, loadTime);
114
140
  }
115
141
  startView(viewName, property) {
116
- return this.rum.startView(viewName, property);
142
+ // Automatically merge bridge context properties with local properties
143
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
144
+ return this.rum.startView(viewName, mergedProperties);
117
145
  }
118
146
  stopView(property) {
119
- return this.rum.stopView(property);
147
+ // Automatically merge bridge context properties with local properties
148
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
149
+ return this.rum.stopView(mergedProperties);
120
150
  }
121
151
  addError(stack, message, property) {
122
- return this.rum.addError(stack, message, property);
152
+ // Automatically merge bridge context properties with local properties
153
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
154
+ return this.rum.addError(stack, message, mergedProperties);
123
155
  }
124
156
  addErrorWithType(type, stack, message, property) {
125
- return this.rum.addErrorWithType(type, stack, message, property);
157
+ // Automatically merge bridge context properties with local properties
158
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
159
+ return this.rum.addErrorWithType(type, stack, message, mergedProperties);
126
160
  }
127
161
  startResource(key, property) {
128
- return this.rum.startResource(key, property);
162
+ // Automatically merge bridge context properties with local properties
163
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
164
+ return this.rum.startResource(key, mergedProperties);
129
165
  }
130
166
  stopResource(key, property) {
131
- return this.rum.stopResource(key, property);
167
+ // Automatically merge bridge context properties with local properties
168
+ const mergedProperties = bridgeContextManager.mergeWithLocalPropertiesSync(property);
169
+ return this.rum.stopResource(key, mergedProperties);
132
170
  }
133
171
  addResource(key, resource, metrics = {}) {
134
172
  return this.rum.addResource(key, resource, metrics);
@@ -1 +1 @@
1
- {"version":3,"names":["NativeModules","FTRumErrorTracking","FTRumActionTracking","ErrorMonitorType","DeviceMetricsMonitorType","DetectFrequency","FTRUMCacheDiscard","FTReactNativeRUMWrapper","constructor","_defineProperty","FTReactNativeRUM","setConfig","config","console","log","enableAutoTrackError","startTracking","enableAutoTrackUserAction","rum","startAction","actionName","actionType","property","addAction","onCreateView","viewName","loadTime","startView","stopView","addError","stack","message","addErrorWithType","type","startResource","key","stopResource","addResource","resource","metrics"],"sources":["ft_rum.tsx"],"sourcesContent":["import { NativeModules } from 'react-native';\nimport { FTRumErrorTracking} from './rum/FTRumErrorTracking';\nimport { FTRumActionTracking} from './rum/FTRumActionTracking';\n\n/**\n * Error monitoring type.\n */\n export enum ErrorMonitorType {\n all=0xFFFFFFFF,\n battery=1 << 1,\n memory=1 << 2,\n cpu=1 << 3,\n }\n /**\n * Page monitoring supplement type\n */\n export enum DeviceMetricsMonitorType {\n all=0xFFFFFFFF,\n battery=1 << 1,\n memory=1 << 2,\n cpu=1 << 3,\n fps=1 << 4\n }\n /**\n * Device information monitoring cycle.\n */\n export enum DetectFrequency { normal, frequent, rare }\n\n export enum FTRUMCacheDiscard { discard, discardOldest };\n\n/**\n * Set RUM tracking conditions.\n * @param androidAppId appId, apply during monitoring\n * @param iOSAppId appId, apply during monitoring\n * @param sampleRate sampling rate\n * @param sessionOnErrorSampleRate error session sampling rate. For sessions not sampled, if ERROR is hit, collect data 1 minute before the error occurs\n * @param enableAutoTrackUserAction whether to automatically collect react-native control click events, can set actionName with accessibilityLabel when enabled\n * @param enableTrackError whether to automatically collect react-native Error\n * @param enableTrackNativeCrash whether to collect Native Error\n * @param enableTrackNativeAppANR whether to collect Native ANR\n * @param enableTrackNativeFreeze whether to collect Native Freeze\n * @param nativeFreezeDurationMs set the threshold for collecting Native Freeze, value range [100,), unit ms. iOS default 250ms, Android default 1000ms\n * @param enableNativeUserAction whether to start Native Action tracking, Button click events, recommended to disable for pure react-native apps\n * @param enableNativeUserView whether to start Native View auto tracking, recommended to disable for pure react-native apps\n * @param enableNativeUserResource whether to automatically collect react-native Resource\n * @param enableResourceHostIP whether to collect network request Host IP (only for native http, iOS 13 and above)\n * @param errorMonitorType error monitoring supplement type\n * @param deviceMonitorType page monitoring supplement type\n * @param detectFrequency monitoring frequency\n * @param globalContext custom global parameters\n * @param rumCacheLimitCount RUM max cache size, default 100_000\n * @param rumDiscardStrategy RUM data discard strategy\n */\n export interface FTRUMConfig{\n androidAppId:string,\n iOSAppId:string,\n sampleRate?:number,\n sessionOnErrorSampleRate?:number,\n enableAutoTrackUserAction?:boolean,\n enableAutoTrackError?:boolean,\n enableTrackNativeCrash?:boolean,\n enableTrackNativeAppANR?:boolean,\n enableTrackNativeFreeze?:boolean,\n nativeFreezeDurationMs?:number,\n enableNativeUserAction?:boolean,\n enableNativeUserView?:boolean,\n enableNativeUserResource?:boolean,\n enableResourceHostIP?:boolean,\n errorMonitorType?:ErrorMonitorType,\n deviceMonitorType?:DeviceMetricsMonitorType,\n detectFrequency?:DetectFrequency\n globalContext?:object,\n rumCacheLimitCount?:number,\n rumDiscardStrategy?:FTRUMCacheDiscard,\n }\n/**\n * RUM Resource data.\n * @param url request URL\n * @param httpMethod request method\n * @param requestHeader request header parameters\n * @param responseHeader response header parameters\n * @param responseBody response content\n * @param resourceStatus response status code\n */\n export interface FTRUMResource{\n url:string,\n httpMethod:string,\n requestHeader:object,\n responseHeader?:object,\n responseBody?:string,\n resourceStatus?:number\n };\n/**\n * RUM Resource performance metrics.\n * @param duration resource load time\n * @param resource_dns resource DNS resolution time\n * @param resource_tcp resource TCP connection time\n * @param resource_ssl resource SSL connection time\n * @param resource_ttfb resource request response time\n * @param resource_trans resource content transfer time\n * @param resource_first_byte resource first byte time\n */\n export interface FTRUMResourceMetrics{\n duration?:number,\n resource_dns?:number,\n resource_tcp?:number,\n resource_ssl?:number,\n resource_ttfb?:number,\n resource_trans?:number,\n resource_first_byte?:number,\n };\n type FTReactNativeRUMType = {\n /**\n * Set RUM tracking conditions and enable RUM collection.\n * @param config rum configuration parameters.\n * @returns a Promise.\n */\n setConfig(config:FTRUMConfig): Promise<void>;\n /**\n * Start RUM Action.\n * RUM will bind Resource, Error, LongTask events that may be triggered by this Action.\n * Avoid adding multiple times within 0.1s, only one Action will be associated with the same View at the same time, and new Actions will be discarded if the previous one has not ended.\n * Adding Action with `addAction` method does not affect each other.\n * @param actionName action name\n * @param actionType action type\n * @param property event context (optional)\n * @returns a Promise.\n */\n startAction(actionName:string,actionType:string,property?:object): Promise<void>;\n /**\n * Add Action event. This type of data cannot be associated with Error, Resource, LongTask data, and has no discard logic.\n * @param actionName action name\n * @param actionType action type\n * @param property event context (optional)\n * @returns a Promise.\n */\n addAction(actionName:string,actionType:string,property?:object): Promise<void>;\n /**\n * view load duration.\n * @param viewName view name\n * @param loadTime view load duration\n * @returns a Promise.\n */\n onCreateView(viewName:string,loadTime:number): Promise<void>;\n /**\n * view start.\n * @param viewName page name\n * @param property event context (optional)\n * @returns a Promise.\n */\n startView(viewName: string, property?: object): Promise<void>;\n /**\n * view end.\n * @param property event context (optional)\n * @returns a Promise.\n */\n stopView(property?:object): Promise<void>;\n /**\n * Exception capture and log collection.\n * @param stack stack log\n * @param message error message\n * @param property event context (optional)\n * @returns a Promise.\n */\n addError(stack: string, message: string,property?:object): Promise<void>;\n /**\n * Exception capture and log collection.\n * @param type error type\n * @param stack stack log\n * @param message error message\n * @param property event context (optional)\n * @returns a Promise.\n */\n addErrorWithType(type:string,stack: string, message: string,property?:object): Promise<void>;\n /**\n * Start resource request.\n * @param key unique id\n * @param property event context (optional)\n * @returns a Promise.\n */\n startResource(key: string,property?:object): Promise<void>;\n /**\n * End resource request.\n * @param key unique id\n * @param property event context (optional)\n * @returns a Promise.\n */\n stopResource(key: string,property?:object): Promise<void>;\n /**\n * Send resource data metrics.\n * @param key unique id\n * @param resource resource data\n * @param metrics resource performance data\n * @returns a Promise.\n */\n addResource(key:string, resource:FTRUMResource,metrics?:FTRUMResourceMetrics):Promise<void>;\n }\n\n class FTReactNativeRUMWrapper implements FTReactNativeRUMType {\n private rum: FTReactNativeRUMType = NativeModules.FTReactNativeRUM;\n\n setConfig(config:FTRUMConfig): Promise<void>{\n console.log('FTRUMConfig');\n if(config.enableAutoTrackError){\n FTRumErrorTracking.startTracking();\n }\n if(config.enableAutoTrackUserAction){\n FTRumActionTracking.startTracking();\n }\n return this.rum.setConfig(config);\n }\n startAction(actionName:string,actionType:string,property?:object): Promise<void>{\n return this.rum.startAction(actionName,actionType,property);\n }\n addAction(actionName: string, actionType: string, property?: object): Promise<void> {\n return this.rum.addAction(actionName,actionType,property);\n }\n onCreateView(viewName:string,loadTime:number): Promise<void>{\n return this.rum.onCreateView(viewName,loadTime);\n }\n startView(viewName: string, property?:object): Promise<void>{\n return this.rum.startView(viewName,property);\n }\n stopView(property?:object): Promise<void>{\n return this.rum.stopView(property);\n }\n addError(stack: string, message: string,property?:object): Promise<void>{\n return this.rum.addError(stack,message,property);\n }\n addErrorWithType(type:string,stack: string, message: string,property?:object): Promise<void>{\n return this.rum.addErrorWithType(type,stack,message,property);\n }\n startResource(key: string,property?:object): Promise<void>{\n return this.rum.startResource(key,property);\n }\n stopResource(key: string,property?:object): Promise<void>{\n return this.rum.stopResource(key,property);\n }\n addResource(key:string, resource:FTRUMResource,metrics:FTRUMResourceMetrics={}):Promise<void>{\n return this.rum.addResource(key,resource,metrics);\n }\n }\n\n export const FTReactNativeRUM: FTReactNativeRUMType = new FTReactNativeRUMWrapper();\n\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["FTRumErrorTracking","FTRumActionTracking","bridgeContextManager","ErrorMonitorType","DeviceMetricsMonitorType","DetectFrequency","FTRUMCacheDiscard","IOSCrashMonitoringType","FTReactNativeRUMWrapper","constructor","_defineProperty","require","default","setConfig","config","console","log","enableAutoTrackError","startTracking","enableAutoTrackUserAction","rum","startAction","actionName","actionType","property","mergedProperties","mergeWithLocalPropertiesSync","addAction","onCreateView","viewName","loadTime","startView","stopView","addError","stack","message","addErrorWithType","type","startResource","key","stopResource","addResource","resource","metrics","FTReactNativeRUM"],"sources":["ft_rum.tsx"],"sourcesContent":["// import { NativeModules } from 'react-native';\nimport { FTRumErrorTracking } from './rum/FTRumErrorTracking';\nimport { FTRumActionTracking } from './rum/FTRumActionTracking';\nimport { bridgeContextManager } from './ft_mobile_agent';\n\n/**\n * Error monitoring type.\n */\n/* eslint-disable no-bitwise */\nexport enum ErrorMonitorType {\n all = 0xffffffff,\n battery = 1 << 1,\n memory = 1 << 2,\n cpu = 1 << 3,\n}\n/**\n * Page monitoring supplement type\n */\nexport enum DeviceMetricsMonitorType {\n all = 0xffffffff,\n battery = 1 << 1,\n memory = 1 << 2,\n cpu = 1 << 3,\n fps = 1 << 4,\n}\n/**\n * Device information monitoring cycle.\n */\nexport enum DetectFrequency {\n normal,\n frequent,\n rare,\n}\n\nexport enum FTRUMCacheDiscard {\n discard,\n discardOldest,\n}\n\nexport enum IOSCrashMonitoringType {\n /** Monitor Mach kernel exceptions. */\n machException = 0x01,\n\n /** Monitor fatal signals. */\n signal = 0x02,\n\n /** Monitor uncaught C++ exceptions. */\n cppException = 0x04,\n\n /** Monitor uncaught Objective-C NSExceptions. */\n nsException = 0x08,\n\n /** Track and inject system information. */\n system = 0x40,\n\n /** Track and inject application state information. */\n applicationState = 0x80,\n\n /** All crash monitor types. */\n all = machException |\n signal |\n cppException |\n nsException |\n applicationState |\n system,\n\n /** High compatibility crash monitor types (excludes Mach exceptions). */\n highCompatibility = all & ~machException,\n}\n/* eslint-enable no-bitwise */\n/**\n * Set RUM tracking conditions.\n * @param androidAppId appId, apply during monitoring\n * @param iOSAppId appId, apply during monitoring\n * @param sampleRate sampling rate\n * @param sessionOnErrorSampleRate error session sampling rate. For sessions not sampled, if ERROR is hit, collect data 1 minute before the error occurs\n * @param enableAutoTrackUserAction whether to automatically collect react-native control click events, can set actionName with accessibilityLabel when enabled\n * @param enableTrackError whether to automatically collect react-native Error\n * @param enableTrackNativeCrash whether to collect Native Error\n * @param enableTrackNativeAppANR whether to collect Native ANR\n * @param enableTrackNativeFreeze whether to collect Native Freeze\n * @param nativeFreezeDurationMs set the threshold for collecting Native Freeze, value range [100,), unit ms. iOS default 250ms, Android default 1000ms\n * @param enableNativeUserAction whether to start Native Action tracking, Button click events, recommended to disable for pure react-native apps\n * @param enableNativeUserView whether to start Native View auto tracking, recommended to disable for pure react-native apps\n * @param enableNativeUserResource whether to automatically collect react-native Resource\n * @param enableResourceHostIP whether to collect network request Host IP (only for native http, iOS 13 and above)\n * @param errorMonitorType error monitoring supplement type\n * @param deviceMonitorType page monitoring supplement type\n * @param detectFrequency monitoring frequency\n * @param globalContext custom global parameters\n * @param rumCacheLimitCount RUM max cache size, default 100_000\n * @param rumDiscardStrategy RUM data discard strategy\n * @param enableTraceWebView Set whether to enable WebView data collection, default true\n * @param allowWebViewHost Set specific hosts or domains allowed to collect WebView data, nil means collect all\n * @param iosCrashMonitoringType iOS crash monitoring type , default is highCompatibility, which does not include Mach exceptions for better compatibility. you must enable system crash monitoring to get crash stack traces and crash information.\n */\nexport interface FTRUMConfig {\n androidAppId: string;\n iOSAppId: string;\n sampleRate?: number;\n sessionOnErrorSampleRate?: number;\n enableAutoTrackUserAction?: boolean;\n enableAutoTrackError?: boolean;\n enableTrackNativeCrash?: boolean;\n enableTrackNativeAppANR?: boolean;\n enableTrackNativeFreeze?: boolean;\n nativeFreezeDurationMs?: number;\n enableNativeUserAction?: boolean;\n enableNativeUserView?: boolean;\n enableNativeUserResource?: boolean;\n enableResourceHostIP?: boolean;\n errorMonitorType?: ErrorMonitorType;\n deviceMonitorType?: DeviceMetricsMonitorType;\n detectFrequency?: DetectFrequency;\n globalContext?: object;\n rumCacheLimitCount?: number;\n rumDiscardStrategy?: FTRUMCacheDiscard;\n enableTraceWebView?: boolean;\n allowWebViewHost?: Array<string>;\n iosCrashMonitoringType?: IOSCrashMonitoringType;\n}\n/**\n * RUM Resource data.\n * @param url request URL\n * @param httpMethod request method\n * @param requestHeader request header parameters\n * @param responseHeader response header parameters\n * @param responseBody response content\n * @param resourceStatus response status code\n */\nexport interface FTRUMResource {\n url: string;\n httpMethod: string;\n requestHeader: object;\n responseHeader?: object;\n responseBody?: string;\n resourceStatus?: number;\n}\n/**\n * RUM Resource performance metrics.\n * @param duration resource load time\n * @param resource_dns resource DNS resolution time\n * @param resource_tcp resource TCP connection time\n * @param resource_ssl resource SSL connection time\n * @param resource_ttfb resource request response time\n * @param resource_trans resource content transfer time\n * @param resource_first_byte resource first byte time\n */\nexport interface FTRUMResourceMetrics {\n duration?: number;\n resource_dns?: number;\n resource_tcp?: number;\n resource_ssl?: number;\n resource_ttfb?: number;\n resource_trans?: number;\n resource_first_byte?: number;\n}\ntype FTReactNativeRUMType = {\n /**\n * Set RUM tracking conditions and enable RUM collection.\n * @param config rum configuration parameters.\n * @returns a Promise.\n */\n setConfig(config: FTRUMConfig): Promise<void>;\n /**\n * Start RUM Action.\n * RUM will bind Resource, Error, LongTask events that may be triggered by this Action.\n * Avoid adding multiple times within 0.1s, only one Action will be associated with the same View at the same time, and new Actions will be discarded if the previous one has not ended.\n * Adding Action with `addAction` method does not affect each other.\n * @param actionName action name\n * @param actionType action type\n * @param property event context (optional)\n * @returns a Promise.\n */\n startAction(\n actionName: string,\n actionType: string,\n property?: object\n ): Promise<void>;\n /**\n * Add Action event. This type of data cannot be associated with Error, Resource, LongTask data, and has no discard logic.\n * @param actionName action name\n * @param actionType action type\n * @param property event context (optional)\n * @returns a Promise.\n */\n addAction(\n actionName: string,\n actionType: string,\n property?: object\n ): Promise<void>;\n /**\n * view load duration.\n * @param viewName view name\n * @param loadTime view load duration\n * @returns a Promise.\n */\n onCreateView(viewName: string, loadTime: number): Promise<void>;\n /**\n * view start.\n * @param viewName page name\n * @param property event context (optional)\n * @returns a Promise.\n */\n startView(viewName: string, property?: object): Promise<void>;\n /**\n * view end.\n * @param property event context (optional)\n * @returns a Promise.\n */\n stopView(property?: object): Promise<void>;\n /**\n * Exception capture and log collection.\n * @param stack stack log\n * @param message error message\n * @param property event context (optional)\n * @returns a Promise.\n */\n addError(stack: string, message: string, property?: object): Promise<void>;\n /**\n * Exception capture and log collection.\n * @param type error type\n * @param stack stack log\n * @param message error message\n * @param property event context (optional)\n * @returns a Promise.\n */\n addErrorWithType(\n type: string,\n stack: string,\n message: string,\n property?: object\n ): Promise<void>;\n /**\n * Start resource request.\n * @param key unique id\n * @param property event context (optional)\n * @returns a Promise.\n */\n startResource(key: string, property?: object): Promise<void>;\n /**\n * End resource request.\n * @param key unique id\n * @param property event context (optional)\n * @returns a Promise.\n */\n stopResource(key: string, property?: object): Promise<void>;\n /**\n * Send resource data metrics.\n * @param key unique id\n * @param resource resource data\n * @param metrics resource performance data\n * @returns a Promise.\n */\n addResource(\n key: string,\n resource: FTRUMResource,\n metrics?: FTRUMResourceMetrics\n ): Promise<void>;\n};\n\nclass FTReactNativeRUMWrapper implements FTReactNativeRUMType {\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n private rum: FTReactNativeRUMType = require('./specs/NativeFTReactNativeRUM')\n .default;\n\n setConfig(config: FTRUMConfig): Promise<void> {\n console.log('FTRUMConfig');\n if (config.enableAutoTrackError) {\n FTRumErrorTracking.startTracking();\n }\n if (config.enableAutoTrackUserAction) {\n FTRumActionTracking.startTracking();\n }\n return this.rum.setConfig(config);\n }\n startAction(\n actionName: string,\n actionType: string,\n property?: object\n ): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.startAction(actionName, actionType, mergedProperties);\n }\n addAction(\n actionName: string,\n actionType: string,\n property?: object\n ): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.addAction(actionName, actionType, mergedProperties);\n }\n onCreateView(viewName: string, loadTime: number): Promise<void> {\n return this.rum.onCreateView(viewName, loadTime);\n }\n startView(viewName: string, property?: object): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.startView(viewName, mergedProperties);\n }\n stopView(property?: object): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.stopView(mergedProperties);\n }\n addError(stack: string, message: string, property?: object): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.addError(stack, message, mergedProperties);\n }\n addErrorWithType(\n type: string,\n stack: string,\n message: string,\n property?: object\n ): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.addErrorWithType(type, stack, message, mergedProperties);\n }\n startResource(key: string, property?: object): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.startResource(key, mergedProperties);\n }\n stopResource(key: string, property?: object): Promise<void> {\n // Automatically merge bridge context properties with local properties\n const mergedProperties =\n bridgeContextManager.mergeWithLocalPropertiesSync(property);\n return this.rum.stopResource(key, mergedProperties);\n }\n addResource(\n key: string,\n resource: FTRUMResource,\n metrics: FTRUMResourceMetrics = {}\n ): Promise<void> {\n return this.rum.addResource(key, resource, metrics);\n }\n}\n\nexport const FTReactNativeRUM: FTReactNativeRUMType =\n new FTReactNativeRUMWrapper();\n"],"mappings":"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","ignoreList":[]}
@@ -1,22 +1,40 @@
1
1
  function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
2
2
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
3
3
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
- import { NativeModules } from 'react-native';
4
+ // import { NativeModules } from 'react-native';
5
5
  //FTReactNativeTrace
6
6
 
7
7
  /**
8
8
  * Trace types for use.
9
9
  */
10
10
  export let TraceType = /*#__PURE__*/function (TraceType) {
11
+ //
12
+ // datadog trace
13
+ //
14
+ // x-datadog-trace-id
15
+ // x-datadog-parent-id
16
+ // x-datadog-sampling-priority
17
+ // x-datadog-origin
18
+ //
11
19
  TraceType[TraceType["ddTrace"] = 0] = "ddTrace";
20
+ //
21
+ // zipkin multi header
22
+ //
23
+ // X-B3-TraceId
24
+ // X-B3-SpanId
25
+ // X-B3-Sampled
26
+ //
12
27
  TraceType[TraceType["zipkinMulti"] = 1] = "zipkinMulti";
28
+ /// zipkin single header,b3
13
29
  TraceType[TraceType["zipkinSingle"] = 2] = "zipkinSingle";
30
+ // w3c, traceparent
14
31
  TraceType[TraceType["traceparent"] = 3] = "traceparent";
32
+ // skywalking 8.0+, sw-8
15
33
  TraceType[TraceType["skywalking"] = 4] = "skywalking";
34
+ // jaeger, header uber-trace-id
16
35
  TraceType[TraceType["jaeger"] = 5] = "jaeger";
17
36
  return TraceType;
18
37
  }({});
19
- ;
20
38
  /**
21
39
  * Configure trace.
22
40
  * @param sampleRate sampling rate
@@ -25,11 +43,13 @@ export let TraceType = /*#__PURE__*/function (TraceType) {
25
43
  * @param enableNativeAutoTrace whether to enable automatic tracing
26
44
  */
27
45
 
28
- ;
29
46
  class FTReactNativeTraceWrapper {
30
47
  constructor() {
31
- _defineProperty(this, "trace", NativeModules.FTReactNativeTrace);
48
+ /* eslint-disable @typescript-eslint/no-var-requires */
49
+ _defineProperty(this, "trace", require('./specs/NativeFTReactNativeTrace').default);
32
50
  }
51
+ /* eslint-enable @typescript-eslint/no-var-requires */
52
+
33
53
  setConfig(config) {
34
54
  return this.trace.setConfig(config);
35
55
  }
@@ -43,11 +63,11 @@ class FTReactNativeTraceWrapper {
43
63
  return this.trace.getTraceHeaderFields(url, key);
44
64
  }
45
65
  /**
46
- * Get trace HTTP request header data.
47
- * @param url request URL
48
- * @param key unique id
49
- * @returns a Promise.
50
- */
66
+ * Get trace HTTP request header data.
67
+ * @param url request URL
68
+ * @param key unique id
69
+ * @returns a Promise.
70
+ */
51
71
  getTraceHeaderFields(url, key) {
52
72
  return this.trace.getTraceHeaderFields(url, key);
53
73
  }
@@ -1 +1 @@
1
- {"version":3,"names":["NativeModules","TraceType","FTReactNativeTraceWrapper","constructor","_defineProperty","FTReactNativeTrace","setConfig","config","trace","getTraceHeader","key","url","getTraceHeaderFields"],"sources":["ft_tracing.tsx"],"sourcesContent":["import { NativeModules } from 'react-native';\n//FTReactNativeTrace\n\n/**\n * Trace types for use.\n */\n export enum TraceType {\n ddTrace,\n zipkinMulti,\n zipkinSingle,\n traceparent,\n skywalking,\n jaeger,\n };\n/**\n * Configure trace.\n * @param sampleRate sampling rate\n * @param traceType trace type\n * @param enableLinkRUMData whether to link with RUM data\n * @param enableNativeAutoTrace whether to enable automatic tracing\n */\n export interface FTTraceConfig{\n sampleRate?:number,\n traceType?:TraceType,\n enableLinkRUMData?:boolean,\n enableNativeAutoTrace?:boolean,\n };\n\n type FTReactNativeTraceType = {\n /**\n * Configure trace to enable distributed tracing.\n * @param config trace configuration parameters.\n * @returns a Promise.\n */\n setConfig(config: FTTraceConfig): Promise<void>; \n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @returns trace request header parameters\n * @deprecated use getTraceHeaderFields() replace.\n */\n getTraceHeader(key:String, url: String): Promise<object>;\n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @returns trace request header parameters\n */\n getTraceHeaderFields(url: String,key?:String): Promise<object>;\n };\n\n class FTReactNativeTraceWrapper implements FTReactNativeTraceType {\n private trace: FTReactNativeTraceType = NativeModules.FTReactNativeTrace;\n\n setConfig(config:FTTraceConfig): Promise<void>{\n return this.trace.setConfig(config);\n }\n /**\n * Get trace HTTP request header data.\n * @param key unique id\n * @param url request URL\n * @returns a Promise.\n */\n getTraceHeader(key:String, url: String): Promise<object>{\n return this.trace.getTraceHeaderFields(url,key);\n }\n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @param key unique id\n * @returns a Promise.\n */\n getTraceHeaderFields(url: String,key?:String): Promise<object>{\n return this.trace.getTraceHeaderFields(url,key);\n }\n\n }\n export const FTReactNativeTrace:FTReactNativeTraceType = new FTReactNativeTraceWrapper(); \n\n"],"mappings":";;;AAAA,SAASA,aAAa,QAAQ,cAAc;AAC5C;;AAEA;AACA;AACA;AACC,WAAYC,SAAS,0BAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAATA,SAAS,CAATA,SAAS;EAAA,OAATA,SAAS;AAAA;AAOpB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;;AAME;AAwBD,MAAMC,yBAAyB,CAAmC;EAAAC,YAAA;IAAAC,eAAA,gBACxBJ,aAAa,CAACK,kBAAkB;EAAA;EAExEC,SAASA,CAACC,MAAoB,EAAgB;IAC5C,OAAO,IAAI,CAACC,KAAK,CAACF,SAAS,CAACC,MAAM,CAAC;EACrC;EACD;AACF;AACA;AACA;AACA;AACA;EACGE,cAAcA,CAACC,GAAU,EAAEC,GAAW,EAAkB;IACtD,OAAO,IAAI,CAACH,KAAK,CAACI,oBAAoB,CAACD,GAAG,EAACD,GAAG,CAAC;EACjD;EACC;AACJ;AACA;AACA;AACA;AACA;EACGE,oBAAoBA,CAACD,GAAW,EAACD,GAAW,EAAkB;IAC7D,OAAO,IAAI,CAACF,KAAK,CAACI,oBAAoB,CAACD,GAAG,EAACD,GAAG,CAAC;EAChD;AAEF;AACA,OAAO,MAAML,kBAAyC,GAAG,IAAIH,yBAAyB,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["TraceType","FTReactNativeTraceWrapper","constructor","_defineProperty","require","default","setConfig","config","trace","getTraceHeader","key","url","getTraceHeaderFields","FTReactNativeTrace"],"sources":["ft_tracing.tsx"],"sourcesContent":["// import { NativeModules } from 'react-native';\n//FTReactNativeTrace\n\n/**\n * Trace types for use.\n */\nexport enum TraceType {\n //\n // datadog trace\n //\n // x-datadog-trace-id\n // x-datadog-parent-id\n // x-datadog-sampling-priority\n // x-datadog-origin\n //\n ddTrace,\n //\n // zipkin multi header\n //\n // X-B3-TraceId\n // X-B3-SpanId\n // X-B3-Sampled\n //\n zipkinMulti,\n /// zipkin single header,b3\n zipkinSingle,\n // w3c, traceparent\n traceparent,\n // skywalking 8.0+, sw-8\n skywalking,\n // jaeger, header uber-trace-id\n jaeger,\n}\n/**\n * Configure trace.\n * @param sampleRate sampling rate\n * @param traceType trace type\n * @param enableLinkRUMData whether to link with RUM data\n * @param enableNativeAutoTrace whether to enable automatic tracing\n */\nexport interface FTTraceConfig {\n sampleRate?: number;\n traceType?: TraceType;\n enableLinkRUMData?: boolean;\n enableNativeAutoTrace?: boolean;\n}\n\ntype FTReactNativeTraceType = {\n /**\n * Configure trace to enable distributed tracing.\n * @param config trace configuration parameters.\n * @returns a Promise.\n */\n setConfig(config: FTTraceConfig): Promise<void>;\n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @returns trace request header parameters\n * @deprecated use getTraceHeaderFields() replace.\n */\n getTraceHeader(key: string, url: string): Promise<object>;\n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @returns trace request header parameters\n */\n getTraceHeaderFields(url: string, key?: string): Promise<object>;\n};\n\nclass FTReactNativeTraceWrapper implements FTReactNativeTraceType {\n /* eslint-disable @typescript-eslint/no-var-requires */\n private trace: FTReactNativeTraceType =\n require('./specs/NativeFTReactNativeTrace').default;\n /* eslint-enable @typescript-eslint/no-var-requires */\n\n setConfig(config: FTTraceConfig): Promise<void> {\n return this.trace.setConfig(config);\n }\n /**\n * Get trace HTTP request header data.\n * @param key unique id\n * @param url request URL\n * @returns a Promise.\n */\n getTraceHeader(key: string, url: string): Promise<object> {\n return this.trace.getTraceHeaderFields(url, key);\n }\n /**\n * Get trace HTTP request header data.\n * @param url request URL\n * @param key unique id\n * @returns a Promise.\n */\n getTraceHeaderFields(url: string, key?: string): Promise<object> {\n return this.trace.getTraceHeaderFields(url, key);\n }\n}\nexport const FTReactNativeTrace: FTReactNativeTraceType =\n new FTReactNativeTraceWrapper();\n"],"mappings":";;;AAAA;AACA;;AAEA;AACA;AACA;AACA,WAAYA,SAAS,0BAATA,SAAS;EACnB;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EARUA,SAAS,CAATA,SAAS;EAUnB;EACA;EACA;EACA;EACA;EACA;EACA;EAhBUA,SAAS,CAATA,SAAS;EAkBnB;EAlBUA,SAAS,CAATA,SAAS;EAoBnB;EApBUA,SAAS,CAATA,SAAS;EAsBnB;EAtBUA,SAAS,CAATA,SAAS;EAwBnB;EAxBUA,SAAS,CAATA,SAAS;EAAA,OAATA,SAAS;AAAA;AA2BrB;AACA;AACA;AACA;AACA;AACA;AACA;;AA8BA,MAAMC,yBAAyB,CAAmC;EAAAC,YAAA;IAChE;IAAAC,eAAA,gBAEEC,OAAO,CAAC,kCAAkC,CAAC,CAACC,OAAO;EAAA;EACrD;;EAEAC,SAASA,CAACC,MAAqB,EAAiB;IAC9C,OAAO,IAAI,CAACC,KAAK,CAACF,SAAS,CAACC,MAAM,CAAC;EACrC;EACA;AACF;AACA;AACA;AACA;AACA;EACEE,cAAcA,CAACC,GAAW,EAAEC,GAAW,EAAmB;IACxD,OAAO,IAAI,CAACH,KAAK,CAACI,oBAAoB,CAACD,GAAG,EAAED,GAAG,CAAC;EAClD;EACA;AACF;AACA;AACA;AACA;AACA;EACEE,oBAAoBA,CAACD,GAAW,EAAED,GAAY,EAAmB;IAC/D,OAAO,IAAI,CAACF,KAAK,CAACI,oBAAoB,CAACD,GAAG,EAAED,GAAG,CAAC;EAClD;AACF;AACA,OAAO,MAAMG,kBAA0C,GACrD,IAAIZ,yBAAyB,CAAC,CAAC","ignoreList":[]}
@@ -1,9 +1,8 @@
1
- import { FTMobileConfig, FTMobileReactNative, EnvType, FTDBCacheDiscard } from './ft_mobile_agent';
1
+ import { FTMobileConfig, FTMobileReactNative, EnvType, FTDBCacheDiscard, FTRemoteConfigResult, FTRemoteConfigOverrideRule, FTRemoteConfigOverrideMatch, FTRemoteConfigOverrideValues } from './ft_mobile_agent';
2
2
  import { FTLogConfig, FTReactNativeLog, FTLogStatus, FTLogCacheDiscard } from './ft_logger';
3
- import { FTRUMConfig, FTRUMResource, FTReactNativeRUM, ErrorMonitorType, DeviceMetricsMonitorType, DetectFrequency, FTRUMResourceMetrics, FTRUMCacheDiscard } from './ft_rum';
3
+ import { FTRUMConfig, FTRUMResource, FTReactNativeRUM, ErrorMonitorType, DeviceMetricsMonitorType, DetectFrequency, FTRUMResourceMetrics, FTRUMCacheDiscard, IOSCrashMonitoringType } from './ft_rum';
4
4
  import { FTTraceConfig, FTReactNativeTrace, TraceType } from './ft_tracing';
5
- import { FTSessionReplayConfig, SessionReplayPrivacy, FTReactNativeSessionReplay } from './ft_session_replay';
6
5
  import { FTRumActionTracking } from './rum/FTRumActionTracking';
7
6
  import { FTRumErrorTracking } from './rum/FTRumErrorTracking';
8
- export { FTMobileReactNative, FTMobileConfig, EnvType, FTDBCacheDiscard, FTLogConfig, FTReactNativeLog, FTLogStatus, FTLogCacheDiscard, FTRUMConfig, FTReactNativeRUM, FTRUMResource, ErrorMonitorType, DeviceMetricsMonitorType, DetectFrequency, FTRUMResourceMetrics, FTRUMCacheDiscard, FTTraceConfig, FTReactNativeTrace, TraceType, FTSessionReplayConfig, SessionReplayPrivacy, FTReactNativeSessionReplay, FTRumActionTracking, FTRumErrorTracking };
7
+ export { FTMobileReactNative, FTMobileConfig, EnvType, FTDBCacheDiscard, FTRemoteConfigResult, FTRemoteConfigOverrideRule, FTRemoteConfigOverrideMatch, FTRemoteConfigOverrideValues, FTLogConfig, FTReactNativeLog, FTLogStatus, FTLogCacheDiscard, FTRUMConfig, FTReactNativeRUM, FTRUMResource, ErrorMonitorType, DeviceMetricsMonitorType, DetectFrequency, FTRUMResourceMetrics, FTRUMCacheDiscard, IOSCrashMonitoringType, FTTraceConfig, FTReactNativeTrace, TraceType, FTRumActionTracking, FTRumErrorTracking };
9
8
  //# sourceMappingURL=index.js.map