react-native-gleapsdk 6.4.2 → 6.4.5-beta.1

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.
@@ -56,6 +56,5 @@ dependencies {
56
56
  //noinspection GradleDynamicVersion
57
57
  implementation "com.facebook.react:react-native:+" // From node_modules
58
58
  // https://mvnrepository.com/artifact/io.gleap/gleap-android-sdk
59
- implementation group: 'io.gleap', name: 'gleap-android-sdk', version: '6.4.8'
60
-
59
+ implementation group: 'io.gleap', name: 'gleap-android-sdk', version: '6.4.11-hotfix'
61
60
  }
@@ -1,6 +1,5 @@
1
1
  package com.reactnativegleapsdk;
2
2
 
3
-
4
3
  import android.app.Activity;
5
4
  import android.os.Build;
6
5
  import android.os.Handler;
@@ -34,7 +33,9 @@ import io.gleap.APPLICATIONTYPE;
34
33
  import io.gleap.ConfigLoadedCallback;
35
34
  import io.gleap.CustomActionCallback;
36
35
  import io.gleap.FeedbackSentCallback;
36
+ import io.gleap.FeedbackSentWithDataCallback;
37
37
  import io.gleap.FeedbackWillBeSentCallback;
38
+ import io.gleap.GetActivityCallback;
38
39
  import io.gleap.Gleap;
39
40
  import io.gleap.GleapActivationMethod;
40
41
  import io.gleap.GleapUserProperties;
@@ -48,6 +49,12 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
48
49
 
49
50
  public GleapsdkModule(ReactApplicationContext reactContext) {
50
51
  super(reactContext);
52
+ Gleap.getInstance().setGetActivityCallback(new GetActivityCallback() {
53
+ @Override
54
+ public Activity getActivity() {
55
+ return reactContext.getCurrentActivity();
56
+ }
57
+ });
51
58
  }
52
59
 
53
60
  @Override
@@ -64,69 +71,86 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
64
71
  @ReactMethod
65
72
  public void initialize(String sdkKey) {
66
73
  getCurrentActivity().runOnUiThread(
67
- new Runnable() {
68
- @Override
69
- public void run() {
70
- try {
71
- Activity activity = getReactApplicationContext()
72
- .getCurrentActivity();
73
- if (activity != null && !invalidated) {
74
- Gleap.getInstance().setApplicationType(APPLICATIONTYPE.REACTNATIVE);
75
- Gleap.getInstance().setFeedbackWillBeSentCallback(new FeedbackWillBeSentCallback() {
76
- @Override
77
- public void flowInvoced() {
78
- if (!invalidated) {
79
- getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class).emit("feedbackWillBeSent", null);
74
+ new Runnable() {
75
+ @Override
76
+ public void run() {
77
+ try {
78
+ Activity activity = getReactApplicationContext()
79
+ .getCurrentActivity();
80
+ if (activity != null && !invalidated) {
81
+ Gleap.getInstance().setApplicationType(APPLICATIONTYPE.REACTNATIVE);
82
+ Gleap.getInstance().setFeedbackWillBeSentCallback(new FeedbackWillBeSentCallback() {
83
+ @Override
84
+ public void flowInvoced() {
85
+ if (!invalidated) {
86
+ getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
87
+ .emit("feedbackWillBeSent", null);
88
+ }
80
89
  }
81
- }
82
- });
83
-
84
- Gleap.initialize(sdkKey, activity.getApplication());
85
- Gleap.getInstance().setConfigLoadedCallback(new ConfigLoadedCallback() {
86
- @Override
87
- public void configLoaded(JSONObject jsonObject) {
88
- if (!invalidated) {
89
- getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class).emit("configLoaded", jsonObject.toString());
90
+ });
91
+
92
+ Gleap.initialize(sdkKey, activity.getApplication());
93
+ Gleap.getInstance().setConfigLoadedCallback(new ConfigLoadedCallback() {
94
+ @Override
95
+ public void configLoaded(JSONObject jsonObject) {
96
+ if (!invalidated) {
97
+ getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
98
+ .emit("configLoaded", jsonObject.toString());
99
+ }
90
100
  }
91
- }
92
- });
93
-
94
- Gleap.getInstance().registerCustomAction(new CustomActionCallback() {
95
- @Override
96
- public void invoke(String message) {
97
- JSONObject obj = new JSONObject();
98
- try {
99
- obj.put("name", message);
100
- } catch (JSONException e) {
101
- e.printStackTrace();
101
+ });
102
+
103
+ Gleap.getInstance().registerCustomAction(new CustomActionCallback() {
104
+ @Override
105
+ public void invoke(String message) {
106
+ JSONObject obj = new JSONObject();
107
+ try {
108
+ obj.put("name", message);
109
+ } catch (JSONException e) {
110
+ e.printStackTrace();
111
+ }
112
+ if (!invalidated) {
113
+ getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
114
+ .emit("customActionTriggered", obj.toString());
115
+ }
102
116
  }
103
- if (!invalidated) {
104
- getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class).emit("customActionTriggered", obj.toString());
117
+ });
118
+
119
+ Gleap.getInstance().setFeedbackSentWithDataCallback(new FeedbackSentWithDataCallback() {
120
+ @Override
121
+ public void close(JSONObject jsonObject) {
122
+ getReactApplicationContext().getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
123
+ .emit("feedbackSent", jsonObject.toString());
124
+ new java.util.Timer().schedule(
125
+ new java.util.TimerTask() {
126
+ @Override
127
+ public void run() {
128
+ showDevMenu();
129
+ }
130
+ },
131
+ 500);
105
132
  }
106
- }
107
- });
108
-
109
- Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
110
- @Override
111
- public void close() {
112
- new java.util.Timer().schedule(
113
- new java.util.TimerTask() {
114
- @Override
115
- public void run() {
116
- showDevMenu();
117
- }
118
- },
119
- 500
120
- );
121
- }
122
- });
133
+ });
134
+
135
+ Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
136
+ @Override
137
+ public void close() {
138
+ new java.util.Timer().schedule(
139
+ new java.util.TimerTask() {
140
+ @Override
141
+ public void run() {
142
+ showDevMenu();
143
+ }
144
+ },
145
+ 500);
146
+ }
147
+ });
148
+ }
149
+ } catch (Exception ex) {
150
+ System.out.println(ex);
123
151
  }
124
- } catch (Exception ex) {
125
- System.out.println(ex);
126
152
  }
127
- }
128
- }
129
- );
153
+ });
130
154
  }
131
155
 
132
156
  @ReactMethod
@@ -145,34 +169,33 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
145
169
  @ReactMethod
146
170
  public void open() {
147
171
  getCurrentActivity().runOnUiThread(
148
- new Runnable() {
149
- @Override
150
- public void run() {
151
- try {
152
- Gleap.getInstance().startFeedbackFlow();
153
- Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
154
- @Override
155
- public void close() {
156
- new java.util.Timer().schedule(
157
- new java.util.TimerTask() {
158
- @Override
159
- public void run() {
160
- if (!isSilentBugReport) {
161
- showDevMenu();
162
- } else {
163
- isSilentBugReport = false;
164
- }
165
- }
166
- },
167
- 500
168
- );
169
- }
170
- });
171
- } catch (Exception e) {
172
- System.out.println(e);
172
+ new Runnable() {
173
+ @Override
174
+ public void run() {
175
+ try {
176
+ Gleap.getInstance().startFeedbackFlow();
177
+ Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
178
+ @Override
179
+ public void close() {
180
+ new java.util.Timer().schedule(
181
+ new java.util.TimerTask() {
182
+ @Override
183
+ public void run() {
184
+ if (!isSilentBugReport) {
185
+ showDevMenu();
186
+ } else {
187
+ isSilentBugReport = false;
188
+ }
189
+ }
190
+ },
191
+ 500);
192
+ }
193
+ });
194
+ } catch (Exception e) {
195
+ System.out.println(e);
196
+ }
173
197
  }
174
- }
175
- });
198
+ });
176
199
  }
177
200
 
178
201
  /**
@@ -181,34 +204,33 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
181
204
  @ReactMethod
182
205
  public void startFeedbackFlow(String feedbackFlow) {
183
206
  getCurrentActivity().runOnUiThread(
184
- new Runnable() {
185
- @Override
186
- public void run() {
187
- try {
188
- Gleap.getInstance().startFeedbackFlow(feedbackFlow);
189
- Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
190
- @Override
191
- public void close() {
192
- new java.util.Timer().schedule(
193
- new java.util.TimerTask() {
194
- @Override
195
- public void run() {
196
- if (!isSilentBugReport) {
197
- showDevMenu();
198
- } else {
199
- isSilentBugReport = false;
200
- }
201
- }
202
- },
203
- 500
204
- );
205
- }
206
- });
207
- } catch (Exception e) {
208
- System.out.println(e);
207
+ new Runnable() {
208
+ @Override
209
+ public void run() {
210
+ try {
211
+ Gleap.getInstance().startFeedbackFlow(feedbackFlow);
212
+ Gleap.getInstance().setFeedbackSentCallback(new FeedbackSentCallback() {
213
+ @Override
214
+ public void close() {
215
+ new java.util.Timer().schedule(
216
+ new java.util.TimerTask() {
217
+ @Override
218
+ public void run() {
219
+ if (!isSilentBugReport) {
220
+ showDevMenu();
221
+ } else {
222
+ isSilentBugReport = false;
223
+ }
224
+ }
225
+ },
226
+ 500);
227
+ }
228
+ });
229
+ } catch (Exception e) {
230
+ System.out.println(e);
231
+ }
209
232
  }
210
- }
211
- });
233
+ });
212
234
  }
213
235
 
214
236
  /**
@@ -216,24 +238,48 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
216
238
  */
217
239
  @ReactMethod
218
240
  public void sendSilentBugReport(
219
- String description,
220
- String priority
221
- ) {
241
+ String description,
242
+ String priority) {
222
243
  getCurrentActivity().runOnUiThread(
223
- new Runnable() {
224
- @Override
225
- public void run() {
226
- isSilentBugReport = true;
227
- Gleap.SEVERITY severity = Gleap.SEVERITY.LOW;
228
- if (priority == "MEDIUM") {
229
- severity = Gleap.SEVERITY.MEDIUM;
244
+ new Runnable() {
245
+ @Override
246
+ public void run() {
247
+ isSilentBugReport = true;
248
+ Gleap.SEVERITY severity = Gleap.SEVERITY.LOW;
249
+ if (priority == "MEDIUM") {
250
+ severity = Gleap.SEVERITY.MEDIUM;
251
+ }
252
+ if (priority == "HIGH") {
253
+ severity = Gleap.SEVERITY.HIGH;
254
+ }
255
+ Gleap.getInstance().sendSilentBugReport(description, severity);
230
256
  }
231
- if (priority == "HIGH") {
232
- severity = Gleap.SEVERITY.HIGH;
257
+ });
258
+ }
259
+
260
+ /**
261
+ * Manually start a silent bug reporting workflow.
262
+ */
263
+ @ReactMethod
264
+ public void sendSilentBugReportWithType(
265
+ String description,
266
+ String priority,
267
+ String type) {
268
+ getCurrentActivity().runOnUiThread(
269
+ new Runnable() {
270
+ @Override
271
+ public void run() {
272
+ isSilentBugReport = true;
273
+ Gleap.SEVERITY severity = Gleap.SEVERITY.LOW;
274
+ if (priority == "MEDIUM") {
275
+ severity = Gleap.SEVERITY.MEDIUM;
276
+ }
277
+ if (priority == "HIGH") {
278
+ severity = Gleap.SEVERITY.HIGH;
279
+ }
280
+ Gleap.getInstance().sendSilentBugReport(description, severity, type);
233
281
  }
234
- Gleap.getInstance().sendSilentBugReport(description, severity);
235
- }
236
- });
282
+ });
237
283
  }
238
284
 
239
285
  @ReactMethod
@@ -242,32 +288,33 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
242
288
  }
243
289
 
244
290
  @ReactMethod
245
- public void enableDebugConsoleLog() {}
291
+ public void enableDebugConsoleLog() {
292
+ }
246
293
 
247
294
  @ReactMethod
248
295
  public void identify(String userid, ReadableMap data) {
249
296
  getCurrentActivity().runOnUiThread(
250
- new Runnable() {
251
- @Override
252
- public void run() {
253
- JSONObject jsonObject = null;
254
- String name = "";
255
- String email = "";
256
- try {
257
- jsonObject = GleapUtil.convertMapToJson(data);
258
- if (jsonObject.has("name")) {
259
- name = jsonObject.getString("name");
260
- }
261
- if (jsonObject.has("email")) {
262
- email = jsonObject.getString("email");
297
+ new Runnable() {
298
+ @Override
299
+ public void run() {
300
+ JSONObject jsonObject = null;
301
+ String name = "";
302
+ String email = "";
303
+ try {
304
+ jsonObject = GleapUtil.convertMapToJson(data);
305
+ if (jsonObject.has("name")) {
306
+ name = jsonObject.getString("name");
307
+ }
308
+ if (jsonObject.has("email")) {
309
+ email = jsonObject.getString("email");
310
+ }
311
+ } catch (JSONException e) {
312
+ e.printStackTrace();
263
313
  }
264
- } catch (JSONException e) {
265
- e.printStackTrace();
314
+ GleapUserProperties gleapUserSession = new GleapUserProperties(name, email);
315
+ Gleap.getInstance().identifyUser(userid, gleapUserSession);
266
316
  }
267
- GleapUserProperties gleapUserSession = new GleapUserProperties(name, email);
268
- Gleap.getInstance().identifyUser(userid, gleapUserSession);
269
- }
270
- });
317
+ });
271
318
  }
272
319
 
273
320
  @ReactMethod
@@ -276,7 +323,8 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
276
323
  }
277
324
 
278
325
  /**
279
- * Attaches custom data, which can be viewed in the BugBattle dashboard. New data will be merged with existing custom data.
326
+ * Attaches custom data, which can be viewed in the BugBattle dashboard. New
327
+ * data will be merged with existing custom data.
280
328
  *
281
329
  * @param customData The data to attach to a bug report.
282
330
  * @author BugBattle
@@ -321,7 +369,8 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
321
369
  }
322
370
 
323
371
  /**
324
- * Attaches custom data, which can be viewed in the Gleap dashboard. New data will be merged with existing custom data.
372
+ * Attaches custom data, which can be viewed in the Gleap dashboard. New data
373
+ * will be merged with existing custom data.
325
374
  *
326
375
  * @param customData The data to attach to a bug report.
327
376
  * @author Gleap
@@ -348,7 +397,6 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
348
397
  Gleap.getInstance().setCustomData(key, value);
349
398
  }
350
399
 
351
-
352
400
  /**
353
401
  * Removes one key from existing custom data.
354
402
  *
@@ -360,7 +408,6 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
360
408
  Gleap.getInstance().removeCustomDataForKey(key);
361
409
  }
362
410
 
363
-
364
411
  /**
365
412
  * Sets an array of activation methods.
366
413
  *
@@ -378,10 +425,10 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
378
425
  internalActivationMethods.add(GleapActivationMethod.SCREENSHOT);
379
426
  }
380
427
  }
381
- Gleap.getInstance().setActivationMethods(internalActivationMethods.toArray(new GleapActivationMethod[internalActivationMethods.size()]));
428
+ Gleap.getInstance().setActivationMethods(
429
+ internalActivationMethods.toArray(new GleapActivationMethod[internalActivationMethods.size()]));
382
430
  }
383
431
 
384
-
385
432
  /**
386
433
  * Clears all custom data.
387
434
  */
@@ -406,7 +453,9 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
406
453
  if (currentRequest.has("request")) {
407
454
  request = (JSONObject) currentRequest.get("request");
408
455
  }
409
- Gleap.getInstance().logNetwork(currentRequest.getString("url"), RequestType.valueOf(currentRequest.getString("type")), response.getInt("status"), currentRequest.getInt("duration"), request, response);
456
+ Gleap.getInstance().logNetwork(currentRequest.getString("url"),
457
+ RequestType.valueOf(currentRequest.getString("type")), response.getInt("status"),
458
+ currentRequest.getInt("duration"), request, response);
410
459
  }
411
460
 
412
461
  } catch (Exception ex) {
@@ -443,7 +492,6 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
443
492
  }
444
493
  }
445
494
 
446
-
447
495
  @RequiresApi(api = Build.VERSION_CODES.O)
448
496
  @ReactMethod
449
497
  /**
@@ -518,14 +566,13 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
518
566
  @ReactMethod
519
567
  public void registerConfigLoadedAction(ConfigLoadedCallback configLoadedCallback) {
520
568
  Gleap.getInstance().setConfigLoadedCallback(configLoadedCallback);
521
-
522
569
  }
523
570
 
524
571
  ;
525
572
 
526
573
  private boolean checkAllowedEndings(String fileName) {
527
574
  String[] fileType = fileName.split("\\.");
528
- String[] allowedTypes = {"jpeg", "svg", "png", "mp4", "webp", "xml", "plain", "xml", "json"};
575
+ String[] allowedTypes = { "jpeg", "svg", "png", "mp4", "webp", "xml", "plain", "xml", "json" };
529
576
  if (fileType.length <= 1) {
530
577
  return false;
531
578
  }
@@ -544,40 +591,43 @@ public class GleapsdkModule extends ReactContextBaseJavaModule implements Lifecy
544
591
  */
545
592
  private void showDevMenu() {
546
593
  getCurrentActivity().runOnUiThread(
547
- new Runnable() {
548
- @Override
549
- public void run() {
550
- final ReactApplication application = (ReactApplication) getReactApplicationContext()
551
- .getCurrentActivity()
552
- .getApplication();
553
- Handler mainHandler = new Handler(GleapsdkModule.this.getReactApplicationContext().getMainLooper());
554
- Runnable myRunnable = new Runnable() {
555
- @Override
556
- public void run() {
557
- try {
558
- application
559
- .getReactNativeHost()
560
- .getReactInstanceManager()
561
- .getDevSupportManager()
562
- .showDevOptionsDialog();
563
- } catch (Exception e) {
564
- e.printStackTrace();
594
+ new Runnable() {
595
+ @Override
596
+ public void run() {
597
+ final ReactApplication application = (ReactApplication) getReactApplicationContext()
598
+ .getCurrentActivity()
599
+ .getApplication();
600
+ Handler mainHandler = new Handler(GleapsdkModule.this.getReactApplicationContext().getMainLooper());
601
+ Runnable myRunnable = new Runnable() {
602
+ @Override
603
+ public void run() {
604
+ try {
605
+ application
606
+ .getReactNativeHost()
607
+ .getReactInstanceManager()
608
+ .getDevSupportManager()
609
+ .showDevOptionsDialog();
610
+ } catch (Exception e) {
611
+ e.printStackTrace();
612
+ }
565
613
  }
566
- }
567
- };
568
- mainHandler.post(myRunnable);
569
- }
570
- });
614
+ };
615
+ mainHandler.post(myRunnable);
616
+ }
617
+ });
571
618
  }
572
619
 
573
620
  @Override
574
- public void onHostResume() {}
621
+ public void onHostResume() {
622
+ }
575
623
 
576
624
  @Override
577
- public void onHostPause() {}
625
+ public void onHostPause() {
626
+ }
578
627
 
579
628
  @Override
580
- public void onHostDestroy() {}
629
+ public void onHostDestroy() {
630
+ }
581
631
 
582
632
  @Override
583
633
  public void onCatalystInstanceDestroy() {
package/ios/Gleapsdk.m CHANGED
@@ -98,9 +98,9 @@ RCT_EXPORT_METHOD(initialize:(NSString *)token)
98
98
  }
99
99
  }
100
100
 
101
- - (void)feedbackSent {
101
+ - (void)feedbackSent:(NSDictionary *)data {
102
102
  if (_hasListeners) {
103
- [self sendEventWithName:@"feedbackSent" body:@{}];
103
+ [self sendEventWithName:@"feedbackSent" body: data];
104
104
  }
105
105
  }
106
106
 
@@ -140,6 +140,20 @@ RCT_EXPORT_METHOD(sendSilentBugReport:(NSString *)description andSeverity:(NSStr
140
140
  });
141
141
  }
142
142
 
143
+ RCT_EXPORT_METHOD(sendSilentBugReportWithType:(NSString *)description andSeverity:(NSString *)priority andType:(NSString *)type)
144
+ {
145
+ dispatch_async(dispatch_get_main_queue(), ^{
146
+ GleapBugSeverity prio = MEDIUM;
147
+ if ([priority isEqualToString: @"LOW"]) {
148
+ prio = LOW;
149
+ }
150
+ if ([priority isEqualToString: @"HIGH"]) {
151
+ prio = HIGH;
152
+ }
153
+ [Gleap sendSilentBugReportWith: description andSeverity: prio andType: type];
154
+ });
155
+ }
156
+
143
157
  RCT_EXPORT_METHOD(attachNetworkLog:(NSArray *)networkLogs)
144
158
  {
145
159
  dispatch_async(dispatch_get_main_queue(), ^{
@@ -33,13 +33,31 @@ if (GleapSdk && !GleapSdk.touched) {
33
33
  networkLogger.setStopped(true);
34
34
  };
35
35
 
36
- var callbacks = [];
36
+ var callbacks = {};
37
+
38
+ GleapSdk.registerListener = (eventType, callback) => {
39
+ if (!callbacks[eventType]) {
40
+ callbacks[eventType] = [];
41
+ }
42
+
43
+ callbacks[eventType].push(callback);
44
+ };
37
45
 
38
46
  GleapSdk.registerCustomAction = customActionCallback => {
39
- callbacks.push(customActionCallback);
47
+ GleapSdk.registerListener('customActionTriggered', customActionCallback);
48
+ };
49
+
50
+ const notifyCallback = function (eventType, data) {
51
+ if (callbacks && callbacks[eventType] && callbacks[eventType].length > 0) {
52
+ for (var i = 0; i < callbacks[eventType].length; i++) {
53
+ if (callbacks[eventType][i]) {
54
+ callbacks[eventType][i](data);
55
+ }
56
+ }
57
+ }
40
58
  };
41
59
 
42
- const gleapEmitter = new _reactNative.NativeEventEmitter(GleapSdk);
60
+ const gleapEmitter = new _reactNative.NativeEventEmitter(_reactNative.NativeModules.Gleapsdk);
43
61
  gleapEmitter.addListener('configLoaded', config => {
44
62
  try {
45
63
  const configJSON = config instanceof Object ? config : JSON.parse(config);
@@ -47,6 +65,8 @@ if (GleapSdk && !GleapSdk.touched) {
47
65
  if (configJSON.enableNetworkLogs) {
48
66
  GleapSdk.startNetworkLogging();
49
67
  }
68
+
69
+ notifyCallback('configLoaded', configJSON);
50
70
  } catch (exp) {}
51
71
  });
52
72
  gleapEmitter.addListener('feedbackWillBeSent', () => {
@@ -58,6 +78,17 @@ if (GleapSdk && !GleapSdk.touched) {
58
78
  } else {
59
79
  GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));
60
80
  }
81
+
82
+ notifyCallback('feedbackWillBeSent');
83
+ });
84
+ gleapEmitter.addListener('feedbackSent', data => {
85
+ try {
86
+ const dataJSON = data instanceof Object ? data : JSON.parse(data);
87
+ notifyCallback('feedbackSent', dataJSON);
88
+ } catch (exp) {}
89
+ });
90
+ gleapEmitter.addListener('feedbackSendingFailed', () => {
91
+ notifyCallback('feedbackSendingFailed');
61
92
  });
62
93
 
63
94
  function isJsonString(str) {
@@ -80,14 +111,10 @@ if (GleapSdk && !GleapSdk.touched) {
80
111
  name
81
112
  } = data;
82
113
 
83
- if (name && callbacks.length > 0) {
84
- for (var i = 0; i < callbacks.length; i++) {
85
- if (callbacks[i]) {
86
- callbacks[i]({
87
- name
88
- });
89
- }
90
- }
114
+ if (name) {
115
+ notifyCallback('customActionTriggered', {
116
+ name
117
+ });
91
118
  }
92
119
  } catch (exp) {}
93
120
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["index.tsx"],"names":["LINKING_ERROR","Platform","select","ios","default","GleapSdk","NativeModules","Gleapsdk","Proxy","get","Error","touched","networkLogger","GleapNetworkIntercepter","startNetworkLogging","start","stopNetworkLogging","setStopped","callbacks","registerCustomAction","customActionCallback","push","gleapEmitter","NativeEventEmitter","addListener","config","configJSON","Object","JSON","parse","enableNetworkLogs","exp","requests","getRequests","OS","attachNetworkLog","stringify","isJsonString","str","e","data","name","length","i","removeAllAttachments"],"mappings":"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","sourcesContent":["import { NativeModules, NativeEventEmitter, Platform } from 'react-native';\nimport GleapNetworkIntercepter from './networklogger';\n\nconst LINKING_ERROR =\n `The package 'react-native-gleapsdk' doesn't seem to be linked. Make sure: \\n\\n` +\n Platform.select({ ios: \"- You have run 'pod install'\\n\", default: '' }) +\n '- You rebuilt the app after installing the package\\n' +\n '- You are not using Expo managed workflow\\n';\n\nexport type GleapUserProperty = {\n email?: string;\n name?: string;\n};\n\ntype GleapActivationMethod = 'SHAKE' | 'SCREENSHOT';\n\ntype GleapSdkType = {\n initialize(token: string): void;\n open(): void;\n startFeedbackFlow(feedbackFlow: string): void;\n sendSilentBugReport(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH'\n ): void;\n identify(userId: string, userProperties: GleapUserProperty): void;\n clearIdentity(): void;\n setApiUrl(apiUrl: string): void;\n setWidgetUrl(widgetUrl: string): void;\n attachCustomData(customData: any): void;\n setCustomData(key: string, value: string): void;\n removeCustomDataForKey(key: string): void;\n clearCustomData(): void;\n registerCustomAction(\n customActionCallback: (data: { name: string }) => void\n ): void;\n setLanguage(language: string): void;\n logEvent(name: string, data: any): void;\n addAttachment(base64file: string, fileName: string): void;\n removeAllAttachments(): void;\n startNetworkLogging(): void;\n stopNetworkLogging(): void;\n enableDebugConsoleLog(): void;\n setActivationMethods(activationMethods: GleapActivationMethod[]): void;\n};\n\nconst GleapSdk = NativeModules.Gleapsdk\n ? NativeModules.Gleapsdk\n : new Proxy(\n {},\n {\n get() {\n throw new Error(LINKING_ERROR);\n },\n }\n );\n\nif (GleapSdk && !GleapSdk.touched) {\n const networkLogger = new GleapNetworkIntercepter();\n\n GleapSdk.startNetworkLogging = () => {\n networkLogger.start();\n };\n\n GleapSdk.stopNetworkLogging = () => {\n networkLogger.setStopped(true);\n };\n\n var callbacks: any[] = [];\n\n GleapSdk.registerCustomAction = (customActionCallback: any) => {\n callbacks.push(customActionCallback);\n };\n\n const gleapEmitter = new NativeEventEmitter(GleapSdk);\n\n gleapEmitter.addListener('configLoaded', (config: any) => {\n try {\n const configJSON = config instanceof Object ? config : JSON.parse(config);\n if (configJSON.enableNetworkLogs) {\n GleapSdk.startNetworkLogging();\n }\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackWillBeSent', () => {\n // Push the network log to the native SDK.\n const requests = networkLogger.getRequests();\n if (Platform.OS === 'android') {\n GleapSdk.attachNetworkLog(JSON.stringify(requests));\n } else {\n GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));\n }\n });\n\n function isJsonString(str: string) {\n try {\n JSON.parse(str);\n } catch (e) {\n return false;\n }\n return true;\n }\n\n gleapEmitter.addListener('customActionTriggered', (data: any) => {\n try {\n if (isJsonString(data)) {\n data = JSON.parse(data);\n }\n const { name } = data;\n if (name && callbacks.length > 0) {\n for (var i = 0; i < callbacks.length; i++) {\n if (callbacks[i]) {\n callbacks[i]({\n name,\n });\n }\n }\n }\n } catch (exp) {}\n });\n\n GleapSdk.removeAllAttachments();\n\n GleapSdk.touched = true;\n}\n\nexport default GleapSdk as GleapSdkType;\n"]}
1
+ {"version":3,"sources":["index.tsx"],"names":["LINKING_ERROR","Platform","select","ios","default","GleapSdk","NativeModules","Gleapsdk","Proxy","get","Error","touched","networkLogger","GleapNetworkIntercepter","startNetworkLogging","start","stopNetworkLogging","setStopped","callbacks","registerListener","eventType","callback","push","registerCustomAction","customActionCallback","notifyCallback","data","length","i","gleapEmitter","NativeEventEmitter","addListener","config","configJSON","Object","JSON","parse","enableNetworkLogs","exp","requests","getRequests","OS","attachNetworkLog","stringify","dataJSON","isJsonString","str","e","name","removeAllAttachments"],"mappings":"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","sourcesContent":["import { NativeModules, NativeEventEmitter, Platform } from 'react-native';\nimport GleapNetworkIntercepter from './networklogger';\n\nconst LINKING_ERROR =\n `The package 'react-native-gleapsdk' doesn't seem to be linked. Make sure: \\n\\n` +\n Platform.select({ ios: \"- You have run 'pod install'\\n\", default: '' }) +\n '- You rebuilt the app after installing the package\\n' +\n '- You are not using Expo managed workflow\\n';\n\nexport type GleapUserProperty = {\n email?: string;\n name?: string;\n};\n\ntype GleapActivationMethod = 'SHAKE' | 'SCREENSHOT';\n\ntype GleapSdkType = {\n initialize(token: string): void;\n open(): void;\n startFeedbackFlow(feedbackFlow: string): void;\n sendSilentBugReport(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH'\n ): void;\n sendSilentBugReportWithType(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH',\n type: string\n ): void;\n identify(userId: string, userProperties: GleapUserProperty): void;\n clearIdentity(): void;\n setApiUrl(apiUrl: string): void;\n setWidgetUrl(widgetUrl: string): void;\n attachCustomData(customData: any): void;\n setCustomData(key: string, value: string): void;\n removeCustomDataForKey(key: string): void;\n clearCustomData(): void;\n registerCustomAction(\n customActionCallback: (data: { name: string }) => void\n ): void;\n registerListener(eventType: string, callback: (data?: any) => void): void;\n setLanguage(language: string): void;\n logEvent(name: string, data: any): void;\n addAttachment(base64file: string, fileName: string): void;\n removeAllAttachments(): void;\n startNetworkLogging(): void;\n stopNetworkLogging(): void;\n enableDebugConsoleLog(): void;\n setActivationMethods(activationMethods: GleapActivationMethod[]): void;\n};\n\nconst GleapSdk = NativeModules.Gleapsdk\n ? NativeModules.Gleapsdk\n : new Proxy(\n {},\n {\n get() {\n throw new Error(LINKING_ERROR);\n },\n }\n );\n\nif (GleapSdk && !GleapSdk.touched) {\n const networkLogger = new GleapNetworkIntercepter();\n\n GleapSdk.startNetworkLogging = () => {\n networkLogger.start();\n };\n\n GleapSdk.stopNetworkLogging = () => {\n networkLogger.setStopped(true);\n };\n\n var callbacks: any = {};\n\n GleapSdk.registerListener = (eventType: string, callback: any) => {\n if (!callbacks[eventType]) {\n callbacks[eventType] = [];\n }\n callbacks[eventType].push(callback);\n };\n\n GleapSdk.registerCustomAction = (customActionCallback: any) => {\n GleapSdk.registerListener('customActionTriggered', customActionCallback);\n };\n\n const notifyCallback = function (eventType: string, data?: any) {\n if (callbacks && callbacks[eventType] && callbacks[eventType].length > 0) {\n for (var i = 0; i < callbacks[eventType].length; i++) {\n if (callbacks[eventType][i]) {\n callbacks[eventType][i](data);\n }\n }\n }\n };\n\n const gleapEmitter = new NativeEventEmitter(NativeModules.Gleapsdk);\n\n gleapEmitter.addListener('configLoaded', (config: any) => {\n try {\n const configJSON = config instanceof Object ? config : JSON.parse(config);\n if (configJSON.enableNetworkLogs) {\n GleapSdk.startNetworkLogging();\n }\n notifyCallback('configLoaded', configJSON);\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackWillBeSent', () => {\n // Push the network log to the native SDK.\n const requests = networkLogger.getRequests();\n if (Platform.OS === 'android') {\n GleapSdk.attachNetworkLog(JSON.stringify(requests));\n } else {\n GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));\n }\n\n notifyCallback('feedbackWillBeSent');\n });\n\n gleapEmitter.addListener('feedbackSent', (data) => {\n try {\n const dataJSON = data instanceof Object ? data : JSON.parse(data);\n notifyCallback('feedbackSent', dataJSON);\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackSendingFailed', () => {\n notifyCallback('feedbackSendingFailed');\n });\n\n function isJsonString(str: string) {\n try {\n JSON.parse(str);\n } catch (e) {\n return false;\n }\n return true;\n }\n\n gleapEmitter.addListener('customActionTriggered', (data: any) => {\n try {\n if (isJsonString(data)) {\n data = JSON.parse(data);\n }\n const { name } = data;\n if (name) {\n notifyCallback('customActionTriggered', {\n name,\n });\n }\n } catch (exp) {}\n });\n\n GleapSdk.removeAllAttachments();\n\n GleapSdk.touched = true;\n}\n\nexport default GleapSdk as GleapSdkType;\n"]}
@@ -126,9 +126,7 @@ class GleapNetworkIntercepter {
126
126
  this.calcRequestTime(gleapRequestId);
127
127
  this.cleanRequests();
128
128
  }
129
- }).catch(err => {
130
- console.log(err);
131
-
129
+ }).catch(_err => {
132
130
  if (this) {
133
131
  this.cleanRequests();
134
132
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["networklogger.ts"],"names":["GleapNetworkIntercepter","getRequests","Object","values","requests","setMaxRequests","maxRequests","setStopped","stopped","cleanRequests","keys","length","keysToRemove","slice","i","calcRequestTime","gleapRequestId","startDate","date","getTime","isFrozen","duration","Date","toString","contentSizeOk","text","size","kiloBytes","megaBytes","start","interceptNetworkRequests","onFetch","params","method","request","payload","body","headers","type","url","onFetchLoad","req","success","response","status","statusText","responseText","exp","then","catch","err","console","log","onFetchFailed","_err","onOpen","args","onSend","requestHeaders","onError","onLoad","contentType","getResponseHeader","isTextOrJSON","includes","responseType","_response","callback","self","XMLHttpRequest","prototype","open","send","wrappedSetRequestHeader","setRequestHeader","header","value","hasOwnProperty","push","requestId","arguments","addEventListener","apply","global","originalFetch","fetch","clone","data"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nclass GleapNetworkIntercepter {\n requestId = 0;\n requests: any = {};\n maxRequests = 10;\n stopped = false;\n\n getRequests() {\n return Object.values(this.requests);\n }\n\n setMaxRequests(maxRequests: number) {\n this.maxRequests = maxRequests;\n }\n\n setStopped(stopped: boolean) {\n this.stopped = stopped;\n }\n\n cleanRequests() {\n var keys = Object.keys(this.requests);\n if (keys.length > this.maxRequests) {\n var keysToRemove = keys.slice(0, keys.length - this.maxRequests);\n for (var i = 0; i < keysToRemove.length; i++) {\n delete this.requests[keysToRemove[i]];\n }\n }\n }\n\n calcRequestTime(gleapRequestId: string | number) {\n if (!this.requests[gleapRequestId]) {\n return;\n }\n\n var startDate = this.requests[gleapRequestId].date;\n if (\n startDate &&\n typeof startDate.getTime === 'function' &&\n !Object.isFrozen(this.requests[gleapRequestId])\n ) {\n this.requests[gleapRequestId].duration =\n new Date().getTime() - startDate.getTime();\n this.requests[gleapRequestId].date =\n this.requests[gleapRequestId].date.toString();\n }\n }\n\n contentSizeOk(text: string) {\n if (text && text.length) {\n const size = text.length * 16;\n const kiloBytes = size / 1024;\n const megaBytes = kiloBytes / 1024;\n if (megaBytes < 0.5) {\n return true;\n }\n }\n return false;\n }\n\n start() {\n this.setStopped(false);\n this.interceptNetworkRequests({\n onFetch: (params: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n if (params.length >= 2) {\n var method = params[1].method ? params[1].method : 'GET';\n this.requests[gleapRequestId] = {\n request: {\n payload: params[1].body,\n headers: params[1].headers,\n },\n type: method,\n url: params[0],\n date: new Date(),\n };\n } else {\n this.requests[gleapRequestId] = {\n request: {},\n url: params[0],\n type: 'GET',\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onFetchLoad: (req: any, gleapRequestId: any) => {\n if (\n this.stopped ||\n !gleapRequestId ||\n !this.requests ||\n !this.requests[gleapRequestId]\n ) {\n return;\n }\n\n try {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: '',\n responseText: '<request_still_open>',\n };\n this.calcRequestTime(gleapRequestId);\n } catch (exp) {}\n\n req\n .text()\n .then((responseText: any) => {\n if (this.requests && this.requests[gleapRequestId]) {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: req.statusText,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n }\n })\n .catch((err: any) => {\n console.log(err);\n if (this) {\n this.cleanRequests();\n }\n });\n },\n onFetchFailed: (_err: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n this.requests[gleapRequestId].success = false;\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n },\n onOpen: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n args.length >= 2 &&\n this.requests\n ) {\n this.requests[request.gleapRequestId] = {\n type: args[0],\n url: args[1],\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onSend: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].request = {\n payload: args.length > 0 ? args[0] : '',\n headers: request.requestHeaders,\n };\n }\n\n this.cleanRequests();\n },\n onError: (request: any) => {\n if (\n !this.stopped &&\n this.requests &&\n request &&\n request.gleapRequestId &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].success = false;\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n onLoad: (request: any) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n const contentType = request.getResponseHeader('content-type');\n const isTextOrJSON =\n contentType &&\n (contentType.includes('json') || contentType.includes('text'));\n\n var responseText = '<' + contentType + '>';\n if (request.responseType === '' || request.responseType === 'text') {\n responseText = request.responseText;\n }\n if (request._response && isTextOrJSON) {\n responseText = request._response;\n }\n\n this.requests[request.gleapRequestId].success = true;\n this.requests[request.gleapRequestId].response = {\n status: request.status,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n });\n }\n\n interceptNetworkRequests(callback: any) {\n // eslint-disable-next-line consistent-this\n var self = this;\n\n // @ts-ignore\n if (XMLHttpRequest.prototype['gleapTouched']) {\n return;\n }\n\n // @ts-ignore\n XMLHttpRequest.prototype['gleapTouched'] = true;\n\n // XMLHttpRequest\n const open = XMLHttpRequest.prototype.open;\n const send = XMLHttpRequest.prototype.send;\n\n // @ts-ignore\n XMLHttpRequest.prototype.wrappedSetRequestHeader =\n XMLHttpRequest.prototype.setRequestHeader;\n XMLHttpRequest.prototype.setRequestHeader = function (header, value) {\n // @ts-ignore\n if (!this.requestHeaders) {\n // @ts-ignore\n this.requestHeaders = {};\n }\n\n // @ts-ignore\n if (this.requestHeaders && this.requestHeaders.hasOwnProperty(header)) {\n return;\n }\n\n // @ts-ignore\n if (!this.requestHeaders[header]) {\n // @ts-ignore\n this.requestHeaders[header] = [];\n }\n\n // @ts-ignore\n this.requestHeaders[header].push(value);\n // @ts-ignore\n this.wrappedSetRequestHeader(header, value);\n };\n\n XMLHttpRequest.prototype.open = function () {\n (this as any).gleapRequestId = ++self.requestId;\n callback.onOpen && callback.onOpen(this, arguments);\n\n if (callback.onLoad) {\n this.addEventListener('load', function () {\n // @ts-ignore\n callback.onLoad(this);\n });\n }\n if (callback.onError) {\n this.addEventListener('error', function () {\n // @ts-ignore\n callback.onError(this);\n });\n }\n\n // @ts-ignore\n return open.apply(this, arguments);\n };\n\n XMLHttpRequest.prototype.send = function () {\n callback.onSend && callback.onSend(this, arguments);\n // @ts-ignore\n return send.apply(this, arguments);\n };\n\n // Fetch\n if (global) {\n (function () {\n var originalFetch = global.fetch;\n global.fetch = function () {\n var gleapRequestId = ++self.requestId;\n callback.onFetch(arguments, gleapRequestId);\n\n return (\n originalFetch\n // @ts-ignore\n .apply(this, arguments)\n .then(function (response) {\n if (response && typeof response.clone === 'function') {\n const data = response.clone();\n callback.onFetchLoad(data, gleapRequestId);\n }\n\n return response;\n })\n .catch((err) => {\n callback.onFetchFailed(err, gleapRequestId);\n throw err;\n })\n );\n };\n })();\n }\n\n return callback;\n }\n}\n\nexport default GleapNetworkIntercepter;\n"]}
1
+ {"version":3,"sources":["networklogger.ts"],"names":["GleapNetworkIntercepter","getRequests","Object","values","requests","setMaxRequests","maxRequests","setStopped","stopped","cleanRequests","keys","length","keysToRemove","slice","i","calcRequestTime","gleapRequestId","startDate","date","getTime","isFrozen","duration","Date","toString","contentSizeOk","text","size","kiloBytes","megaBytes","start","interceptNetworkRequests","onFetch","params","method","request","payload","body","headers","type","url","onFetchLoad","req","success","response","status","statusText","responseText","exp","then","catch","_err","onFetchFailed","onOpen","args","onSend","requestHeaders","onError","onLoad","contentType","getResponseHeader","isTextOrJSON","includes","responseType","_response","callback","self","XMLHttpRequest","prototype","open","send","wrappedSetRequestHeader","setRequestHeader","header","value","hasOwnProperty","push","requestId","arguments","addEventListener","apply","global","originalFetch","fetch","clone","data","err"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nclass GleapNetworkIntercepter {\n requestId = 0;\n requests: any = {};\n maxRequests = 10;\n stopped = false;\n\n getRequests() {\n return Object.values(this.requests);\n }\n\n setMaxRequests(maxRequests: number) {\n this.maxRequests = maxRequests;\n }\n\n setStopped(stopped: boolean) {\n this.stopped = stopped;\n }\n\n cleanRequests() {\n var keys = Object.keys(this.requests);\n if (keys.length > this.maxRequests) {\n var keysToRemove = keys.slice(0, keys.length - this.maxRequests);\n for (var i = 0; i < keysToRemove.length; i++) {\n delete this.requests[keysToRemove[i]];\n }\n }\n }\n\n calcRequestTime(gleapRequestId: string | number) {\n if (!this.requests[gleapRequestId]) {\n return;\n }\n\n var startDate = this.requests[gleapRequestId].date;\n if (\n startDate &&\n typeof startDate.getTime === 'function' &&\n !Object.isFrozen(this.requests[gleapRequestId])\n ) {\n this.requests[gleapRequestId].duration =\n new Date().getTime() - startDate.getTime();\n this.requests[gleapRequestId].date =\n this.requests[gleapRequestId].date.toString();\n }\n }\n\n contentSizeOk(text: string) {\n if (text && text.length) {\n const size = text.length * 16;\n const kiloBytes = size / 1024;\n const megaBytes = kiloBytes / 1024;\n if (megaBytes < 0.5) {\n return true;\n }\n }\n return false;\n }\n\n start() {\n this.setStopped(false);\n this.interceptNetworkRequests({\n onFetch: (params: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n if (params.length >= 2) {\n var method = params[1].method ? params[1].method : 'GET';\n this.requests[gleapRequestId] = {\n request: {\n payload: params[1].body,\n headers: params[1].headers,\n },\n type: method,\n url: params[0],\n date: new Date(),\n };\n } else {\n this.requests[gleapRequestId] = {\n request: {},\n url: params[0],\n type: 'GET',\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onFetchLoad: (req: any, gleapRequestId: any) => {\n if (\n this.stopped ||\n !gleapRequestId ||\n !this.requests ||\n !this.requests[gleapRequestId]\n ) {\n return;\n }\n\n try {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: '',\n responseText: '<request_still_open>',\n };\n this.calcRequestTime(gleapRequestId);\n } catch (exp) {}\n\n req\n .text()\n .then((responseText: any) => {\n if (this.requests && this.requests[gleapRequestId]) {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: req.statusText,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n }\n })\n .catch((_err: any) => {\n if (this) {\n this.cleanRequests();\n }\n });\n },\n onFetchFailed: (_err: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n this.requests[gleapRequestId].success = false;\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n },\n onOpen: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n args.length >= 2 &&\n this.requests\n ) {\n this.requests[request.gleapRequestId] = {\n type: args[0],\n url: args[1],\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onSend: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].request = {\n payload: args.length > 0 ? args[0] : '',\n headers: request.requestHeaders,\n };\n }\n\n this.cleanRequests();\n },\n onError: (request: any) => {\n if (\n !this.stopped &&\n this.requests &&\n request &&\n request.gleapRequestId &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].success = false;\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n onLoad: (request: any) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n const contentType = request.getResponseHeader('content-type');\n const isTextOrJSON =\n contentType &&\n (contentType.includes('json') || contentType.includes('text'));\n\n var responseText = '<' + contentType + '>';\n if (request.responseType === '' || request.responseType === 'text') {\n responseText = request.responseText;\n }\n if (request._response && isTextOrJSON) {\n responseText = request._response;\n }\n\n this.requests[request.gleapRequestId].success = true;\n this.requests[request.gleapRequestId].response = {\n status: request.status,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n });\n }\n\n interceptNetworkRequests(callback: any) {\n // eslint-disable-next-line consistent-this\n var self = this;\n\n // @ts-ignore\n if (XMLHttpRequest.prototype['gleapTouched']) {\n return;\n }\n\n // @ts-ignore\n XMLHttpRequest.prototype['gleapTouched'] = true;\n\n // XMLHttpRequest\n const open = XMLHttpRequest.prototype.open;\n const send = XMLHttpRequest.prototype.send;\n\n // @ts-ignore\n XMLHttpRequest.prototype.wrappedSetRequestHeader =\n XMLHttpRequest.prototype.setRequestHeader;\n XMLHttpRequest.prototype.setRequestHeader = function (header, value) {\n // @ts-ignore\n if (!this.requestHeaders) {\n // @ts-ignore\n this.requestHeaders = {};\n }\n\n // @ts-ignore\n if (this.requestHeaders && this.requestHeaders.hasOwnProperty(header)) {\n return;\n }\n\n // @ts-ignore\n if (!this.requestHeaders[header]) {\n // @ts-ignore\n this.requestHeaders[header] = [];\n }\n\n // @ts-ignore\n this.requestHeaders[header].push(value);\n // @ts-ignore\n this.wrappedSetRequestHeader(header, value);\n };\n\n XMLHttpRequest.prototype.open = function () {\n (this as any).gleapRequestId = ++self.requestId;\n callback.onOpen && callback.onOpen(this, arguments);\n\n if (callback.onLoad) {\n this.addEventListener('load', function () {\n // @ts-ignore\n callback.onLoad(this);\n });\n }\n if (callback.onError) {\n this.addEventListener('error', function () {\n // @ts-ignore\n callback.onError(this);\n });\n }\n\n // @ts-ignore\n return open.apply(this, arguments);\n };\n\n XMLHttpRequest.prototype.send = function () {\n callback.onSend && callback.onSend(this, arguments);\n // @ts-ignore\n return send.apply(this, arguments);\n };\n\n // Fetch\n if (global) {\n (function () {\n var originalFetch = global.fetch;\n global.fetch = function () {\n var gleapRequestId = ++self.requestId;\n callback.onFetch(arguments, gleapRequestId);\n\n return (\n originalFetch\n // @ts-ignore\n .apply(this, arguments)\n .then(function (response) {\n if (response && typeof response.clone === 'function') {\n const data = response.clone();\n callback.onFetchLoad(data, gleapRequestId);\n }\n\n return response;\n })\n .catch((err) => {\n callback.onFetchFailed(err, gleapRequestId);\n throw err;\n })\n );\n };\n })();\n }\n\n return callback;\n }\n}\n\nexport default GleapNetworkIntercepter;\n"]}
@@ -22,13 +22,31 @@ if (GleapSdk && !GleapSdk.touched) {
22
22
  networkLogger.setStopped(true);
23
23
  };
24
24
 
25
- var callbacks = [];
25
+ var callbacks = {};
26
+
27
+ GleapSdk.registerListener = (eventType, callback) => {
28
+ if (!callbacks[eventType]) {
29
+ callbacks[eventType] = [];
30
+ }
31
+
32
+ callbacks[eventType].push(callback);
33
+ };
26
34
 
27
35
  GleapSdk.registerCustomAction = customActionCallback => {
28
- callbacks.push(customActionCallback);
36
+ GleapSdk.registerListener('customActionTriggered', customActionCallback);
37
+ };
38
+
39
+ const notifyCallback = function (eventType, data) {
40
+ if (callbacks && callbacks[eventType] && callbacks[eventType].length > 0) {
41
+ for (var i = 0; i < callbacks[eventType].length; i++) {
42
+ if (callbacks[eventType][i]) {
43
+ callbacks[eventType][i](data);
44
+ }
45
+ }
46
+ }
29
47
  };
30
48
 
31
- const gleapEmitter = new NativeEventEmitter(GleapSdk);
49
+ const gleapEmitter = new NativeEventEmitter(NativeModules.Gleapsdk);
32
50
  gleapEmitter.addListener('configLoaded', config => {
33
51
  try {
34
52
  const configJSON = config instanceof Object ? config : JSON.parse(config);
@@ -36,6 +54,8 @@ if (GleapSdk && !GleapSdk.touched) {
36
54
  if (configJSON.enableNetworkLogs) {
37
55
  GleapSdk.startNetworkLogging();
38
56
  }
57
+
58
+ notifyCallback('configLoaded', configJSON);
39
59
  } catch (exp) {}
40
60
  });
41
61
  gleapEmitter.addListener('feedbackWillBeSent', () => {
@@ -47,6 +67,17 @@ if (GleapSdk && !GleapSdk.touched) {
47
67
  } else {
48
68
  GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));
49
69
  }
70
+
71
+ notifyCallback('feedbackWillBeSent');
72
+ });
73
+ gleapEmitter.addListener('feedbackSent', data => {
74
+ try {
75
+ const dataJSON = data instanceof Object ? data : JSON.parse(data);
76
+ notifyCallback('feedbackSent', dataJSON);
77
+ } catch (exp) {}
78
+ });
79
+ gleapEmitter.addListener('feedbackSendingFailed', () => {
80
+ notifyCallback('feedbackSendingFailed');
50
81
  });
51
82
 
52
83
  function isJsonString(str) {
@@ -69,14 +100,10 @@ if (GleapSdk && !GleapSdk.touched) {
69
100
  name
70
101
  } = data;
71
102
 
72
- if (name && callbacks.length > 0) {
73
- for (var i = 0; i < callbacks.length; i++) {
74
- if (callbacks[i]) {
75
- callbacks[i]({
76
- name
77
- });
78
- }
79
- }
103
+ if (name) {
104
+ notifyCallback('customActionTriggered', {
105
+ name
106
+ });
80
107
  }
81
108
  } catch (exp) {}
82
109
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["index.tsx"],"names":["NativeModules","NativeEventEmitter","Platform","GleapNetworkIntercepter","LINKING_ERROR","select","ios","default","GleapSdk","Gleapsdk","Proxy","get","Error","touched","networkLogger","startNetworkLogging","start","stopNetworkLogging","setStopped","callbacks","registerCustomAction","customActionCallback","push","gleapEmitter","addListener","config","configJSON","Object","JSON","parse","enableNetworkLogs","exp","requests","getRequests","OS","attachNetworkLog","stringify","isJsonString","str","e","data","name","length","i","removeAllAttachments"],"mappings":"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","sourcesContent":["import { NativeModules, NativeEventEmitter, Platform } from 'react-native';\nimport GleapNetworkIntercepter from './networklogger';\n\nconst LINKING_ERROR =\n `The package 'react-native-gleapsdk' doesn't seem to be linked. Make sure: \\n\\n` +\n Platform.select({ ios: \"- You have run 'pod install'\\n\", default: '' }) +\n '- You rebuilt the app after installing the package\\n' +\n '- You are not using Expo managed workflow\\n';\n\nexport type GleapUserProperty = {\n email?: string;\n name?: string;\n};\n\ntype GleapActivationMethod = 'SHAKE' | 'SCREENSHOT';\n\ntype GleapSdkType = {\n initialize(token: string): void;\n open(): void;\n startFeedbackFlow(feedbackFlow: string): void;\n sendSilentBugReport(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH'\n ): void;\n identify(userId: string, userProperties: GleapUserProperty): void;\n clearIdentity(): void;\n setApiUrl(apiUrl: string): void;\n setWidgetUrl(widgetUrl: string): void;\n attachCustomData(customData: any): void;\n setCustomData(key: string, value: string): void;\n removeCustomDataForKey(key: string): void;\n clearCustomData(): void;\n registerCustomAction(\n customActionCallback: (data: { name: string }) => void\n ): void;\n setLanguage(language: string): void;\n logEvent(name: string, data: any): void;\n addAttachment(base64file: string, fileName: string): void;\n removeAllAttachments(): void;\n startNetworkLogging(): void;\n stopNetworkLogging(): void;\n enableDebugConsoleLog(): void;\n setActivationMethods(activationMethods: GleapActivationMethod[]): void;\n};\n\nconst GleapSdk = NativeModules.Gleapsdk\n ? NativeModules.Gleapsdk\n : new Proxy(\n {},\n {\n get() {\n throw new Error(LINKING_ERROR);\n },\n }\n );\n\nif (GleapSdk && !GleapSdk.touched) {\n const networkLogger = new GleapNetworkIntercepter();\n\n GleapSdk.startNetworkLogging = () => {\n networkLogger.start();\n };\n\n GleapSdk.stopNetworkLogging = () => {\n networkLogger.setStopped(true);\n };\n\n var callbacks: any[] = [];\n\n GleapSdk.registerCustomAction = (customActionCallback: any) => {\n callbacks.push(customActionCallback);\n };\n\n const gleapEmitter = new NativeEventEmitter(GleapSdk);\n\n gleapEmitter.addListener('configLoaded', (config: any) => {\n try {\n const configJSON = config instanceof Object ? config : JSON.parse(config);\n if (configJSON.enableNetworkLogs) {\n GleapSdk.startNetworkLogging();\n }\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackWillBeSent', () => {\n // Push the network log to the native SDK.\n const requests = networkLogger.getRequests();\n if (Platform.OS === 'android') {\n GleapSdk.attachNetworkLog(JSON.stringify(requests));\n } else {\n GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));\n }\n });\n\n function isJsonString(str: string) {\n try {\n JSON.parse(str);\n } catch (e) {\n return false;\n }\n return true;\n }\n\n gleapEmitter.addListener('customActionTriggered', (data: any) => {\n try {\n if (isJsonString(data)) {\n data = JSON.parse(data);\n }\n const { name } = data;\n if (name && callbacks.length > 0) {\n for (var i = 0; i < callbacks.length; i++) {\n if (callbacks[i]) {\n callbacks[i]({\n name,\n });\n }\n }\n }\n } catch (exp) {}\n });\n\n GleapSdk.removeAllAttachments();\n\n GleapSdk.touched = true;\n}\n\nexport default GleapSdk as GleapSdkType;\n"]}
1
+ {"version":3,"sources":["index.tsx"],"names":["NativeModules","NativeEventEmitter","Platform","GleapNetworkIntercepter","LINKING_ERROR","select","ios","default","GleapSdk","Gleapsdk","Proxy","get","Error","touched","networkLogger","startNetworkLogging","start","stopNetworkLogging","setStopped","callbacks","registerListener","eventType","callback","push","registerCustomAction","customActionCallback","notifyCallback","data","length","i","gleapEmitter","addListener","config","configJSON","Object","JSON","parse","enableNetworkLogs","exp","requests","getRequests","OS","attachNetworkLog","stringify","dataJSON","isJsonString","str","e","name","removeAllAttachments"],"mappings":"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","sourcesContent":["import { NativeModules, NativeEventEmitter, Platform } from 'react-native';\nimport GleapNetworkIntercepter from './networklogger';\n\nconst LINKING_ERROR =\n `The package 'react-native-gleapsdk' doesn't seem to be linked. Make sure: \\n\\n` +\n Platform.select({ ios: \"- You have run 'pod install'\\n\", default: '' }) +\n '- You rebuilt the app after installing the package\\n' +\n '- You are not using Expo managed workflow\\n';\n\nexport type GleapUserProperty = {\n email?: string;\n name?: string;\n};\n\ntype GleapActivationMethod = 'SHAKE' | 'SCREENSHOT';\n\ntype GleapSdkType = {\n initialize(token: string): void;\n open(): void;\n startFeedbackFlow(feedbackFlow: string): void;\n sendSilentBugReport(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH'\n ): void;\n sendSilentBugReportWithType(\n description: string,\n severity: 'LOW' | 'MEDIUM' | 'HIGH',\n type: string\n ): void;\n identify(userId: string, userProperties: GleapUserProperty): void;\n clearIdentity(): void;\n setApiUrl(apiUrl: string): void;\n setWidgetUrl(widgetUrl: string): void;\n attachCustomData(customData: any): void;\n setCustomData(key: string, value: string): void;\n removeCustomDataForKey(key: string): void;\n clearCustomData(): void;\n registerCustomAction(\n customActionCallback: (data: { name: string }) => void\n ): void;\n registerListener(eventType: string, callback: (data?: any) => void): void;\n setLanguage(language: string): void;\n logEvent(name: string, data: any): void;\n addAttachment(base64file: string, fileName: string): void;\n removeAllAttachments(): void;\n startNetworkLogging(): void;\n stopNetworkLogging(): void;\n enableDebugConsoleLog(): void;\n setActivationMethods(activationMethods: GleapActivationMethod[]): void;\n};\n\nconst GleapSdk = NativeModules.Gleapsdk\n ? NativeModules.Gleapsdk\n : new Proxy(\n {},\n {\n get() {\n throw new Error(LINKING_ERROR);\n },\n }\n );\n\nif (GleapSdk && !GleapSdk.touched) {\n const networkLogger = new GleapNetworkIntercepter();\n\n GleapSdk.startNetworkLogging = () => {\n networkLogger.start();\n };\n\n GleapSdk.stopNetworkLogging = () => {\n networkLogger.setStopped(true);\n };\n\n var callbacks: any = {};\n\n GleapSdk.registerListener = (eventType: string, callback: any) => {\n if (!callbacks[eventType]) {\n callbacks[eventType] = [];\n }\n callbacks[eventType].push(callback);\n };\n\n GleapSdk.registerCustomAction = (customActionCallback: any) => {\n GleapSdk.registerListener('customActionTriggered', customActionCallback);\n };\n\n const notifyCallback = function (eventType: string, data?: any) {\n if (callbacks && callbacks[eventType] && callbacks[eventType].length > 0) {\n for (var i = 0; i < callbacks[eventType].length; i++) {\n if (callbacks[eventType][i]) {\n callbacks[eventType][i](data);\n }\n }\n }\n };\n\n const gleapEmitter = new NativeEventEmitter(NativeModules.Gleapsdk);\n\n gleapEmitter.addListener('configLoaded', (config: any) => {\n try {\n const configJSON = config instanceof Object ? config : JSON.parse(config);\n if (configJSON.enableNetworkLogs) {\n GleapSdk.startNetworkLogging();\n }\n notifyCallback('configLoaded', configJSON);\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackWillBeSent', () => {\n // Push the network log to the native SDK.\n const requests = networkLogger.getRequests();\n if (Platform.OS === 'android') {\n GleapSdk.attachNetworkLog(JSON.stringify(requests));\n } else {\n GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));\n }\n\n notifyCallback('feedbackWillBeSent');\n });\n\n gleapEmitter.addListener('feedbackSent', (data) => {\n try {\n const dataJSON = data instanceof Object ? data : JSON.parse(data);\n notifyCallback('feedbackSent', dataJSON);\n } catch (exp) {}\n });\n\n gleapEmitter.addListener('feedbackSendingFailed', () => {\n notifyCallback('feedbackSendingFailed');\n });\n\n function isJsonString(str: string) {\n try {\n JSON.parse(str);\n } catch (e) {\n return false;\n }\n return true;\n }\n\n gleapEmitter.addListener('customActionTriggered', (data: any) => {\n try {\n if (isJsonString(data)) {\n data = JSON.parse(data);\n }\n const { name } = data;\n if (name) {\n notifyCallback('customActionTriggered', {\n name,\n });\n }\n } catch (exp) {}\n });\n\n GleapSdk.removeAllAttachments();\n\n GleapSdk.touched = true;\n}\n\nexport default GleapSdk as GleapSdkType;\n"]}
@@ -119,9 +119,7 @@ class GleapNetworkIntercepter {
119
119
  this.calcRequestTime(gleapRequestId);
120
120
  this.cleanRequests();
121
121
  }
122
- }).catch(err => {
123
- console.log(err);
124
-
122
+ }).catch(_err => {
125
123
  if (this) {
126
124
  this.cleanRequests();
127
125
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["networklogger.ts"],"names":["GleapNetworkIntercepter","getRequests","Object","values","requests","setMaxRequests","maxRequests","setStopped","stopped","cleanRequests","keys","length","keysToRemove","slice","i","calcRequestTime","gleapRequestId","startDate","date","getTime","isFrozen","duration","Date","toString","contentSizeOk","text","size","kiloBytes","megaBytes","start","interceptNetworkRequests","onFetch","params","method","request","payload","body","headers","type","url","onFetchLoad","req","success","response","status","statusText","responseText","exp","then","catch","err","console","log","onFetchFailed","_err","onOpen","args","onSend","requestHeaders","onError","onLoad","contentType","getResponseHeader","isTextOrJSON","includes","responseType","_response","callback","self","XMLHttpRequest","prototype","open","send","wrappedSetRequestHeader","setRequestHeader","header","value","hasOwnProperty","push","requestId","arguments","addEventListener","apply","global","originalFetch","fetch","clone","data"],"mappings":";;AAAA;AACA,MAAMA,uBAAN,CAA8B;AAAA;AAAA,uCAChB,CADgB;;AAAA,sCAEZ,EAFY;;AAAA,yCAGd,EAHc;;AAAA,qCAIlB,KAJkB;AAAA;;AAM5BC,EAAAA,WAAW,GAAG;AACZ,WAAOC,MAAM,CAACC,MAAP,CAAc,KAAKC,QAAnB,CAAP;AACD;;AAEDC,EAAAA,cAAc,CAACC,WAAD,EAAsB;AAClC,SAAKA,WAAL,GAAmBA,WAAnB;AACD;;AAEDC,EAAAA,UAAU,CAACC,OAAD,EAAmB;AAC3B,SAAKA,OAAL,GAAeA,OAAf;AACD;;AAEDC,EAAAA,aAAa,GAAG;AACd,QAAIC,IAAI,GAAGR,MAAM,CAACQ,IAAP,CAAY,KAAKN,QAAjB,CAAX;;AACA,QAAIM,IAAI,CAACC,MAAL,GAAc,KAAKL,WAAvB,EAAoC;AAClC,UAAIM,YAAY,GAAGF,IAAI,CAACG,KAAL,CAAW,CAAX,EAAcH,IAAI,CAACC,MAAL,GAAc,KAAKL,WAAjC,CAAnB;;AACA,WAAK,IAAIQ,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,YAAY,CAACD,MAAjC,EAAyCG,CAAC,EAA1C,EAA8C;AAC5C,eAAO,KAAKV,QAAL,CAAcQ,YAAY,CAACE,CAAD,CAA1B,CAAP;AACD;AACF;AACF;;AAEDC,EAAAA,eAAe,CAACC,cAAD,EAAkC;AAC/C,QAAI,CAAC,KAAKZ,QAAL,CAAcY,cAAd,CAAL,EAAoC;AAClC;AACD;;AAED,QAAIC,SAAS,GAAG,KAAKb,QAAL,CAAcY,cAAd,EAA8BE,IAA9C;;AACA,QACED,SAAS,IACT,OAAOA,SAAS,CAACE,OAAjB,KAA6B,UAD7B,IAEA,CAACjB,MAAM,CAACkB,QAAP,CAAgB,KAAKhB,QAAL,CAAcY,cAAd,CAAhB,CAHH,EAIE;AACA,WAAKZ,QAAL,CAAcY,cAAd,EAA8BK,QAA9B,GACE,IAAIC,IAAJ,GAAWH,OAAX,KAAuBF,SAAS,CAACE,OAAV,EADzB;AAEA,WAAKf,QAAL,CAAcY,cAAd,EAA8BE,IAA9B,GACE,KAAKd,QAAL,CAAcY,cAAd,EAA8BE,IAA9B,CAAmCK,QAAnC,EADF;AAED;AACF;;AAEDC,EAAAA,aAAa,CAACC,IAAD,EAAe;AAC1B,QAAIA,IAAI,IAAIA,IAAI,CAACd,MAAjB,EAAyB;AACvB,YAAMe,IAAI,GAAGD,IAAI,CAACd,MAAL,GAAc,EAA3B;AACA,YAAMgB,SAAS,GAAGD,IAAI,GAAG,IAAzB;AACA,YAAME,SAAS,GAAGD,SAAS,GAAG,IAA9B;;AACA,UAAIC,SAAS,GAAG,GAAhB,EAAqB;AACnB,eAAO,IAAP;AACD;AACF;;AACD,WAAO,KAAP;AACD;;AAEDC,EAAAA,KAAK,GAAG;AACN,SAAKtB,UAAL,CAAgB,KAAhB;AACA,SAAKuB,wBAAL,CAA8B;AAC5BC,MAAAA,OAAO,EAAE,CAACC,MAAD,EAAchB,cAAd,KAAsC;AAC7C,YAAI,KAAKR,OAAT,EAAkB;AAChB;AACD;;AAED,YAAIwB,MAAM,CAACrB,MAAP,IAAiB,CAArB,EAAwB;AACtB,cAAIsB,MAAM,GAAGD,MAAM,CAAC,CAAD,CAAN,CAAUC,MAAV,GAAmBD,MAAM,CAAC,CAAD,CAAN,CAAUC,MAA7B,GAAsC,KAAnD;AACA,eAAK7B,QAAL,CAAcY,cAAd,IAAgC;AAC9BkB,YAAAA,OAAO,EAAE;AACPC,cAAAA,OAAO,EAAEH,MAAM,CAAC,CAAD,CAAN,CAAUI,IADZ;AAEPC,cAAAA,OAAO,EAAEL,MAAM,CAAC,CAAD,CAAN,CAAUK;AAFZ,aADqB;AAK9BC,YAAAA,IAAI,EAAEL,MALwB;AAM9BM,YAAAA,GAAG,EAAEP,MAAM,CAAC,CAAD,CANmB;AAO9Bd,YAAAA,IAAI,EAAE,IAAII,IAAJ;AAPwB,WAAhC;AASD,SAXD,MAWO;AACL,eAAKlB,QAAL,CAAcY,cAAd,IAAgC;AAC9BkB,YAAAA,OAAO,EAAE,EADqB;AAE9BK,YAAAA,GAAG,EAAEP,MAAM,CAAC,CAAD,CAFmB;AAG9BM,YAAAA,IAAI,EAAE,KAHwB;AAI9BpB,YAAAA,IAAI,EAAE,IAAII,IAAJ;AAJwB,WAAhC;AAMD;;AAED,aAAKb,aAAL;AACD,OA3B2B;AA4B5B+B,MAAAA,WAAW,EAAE,CAACC,GAAD,EAAWzB,cAAX,KAAmC;AAC9C,YACE,KAAKR,OAAL,IACA,CAACQ,cADD,IAEA,CAAC,KAAKZ,QAFN,IAGA,CAAC,KAAKA,QAAL,CAAcY,cAAd,CAJH,EAKE;AACA;AACD;;AAED,YAAI;AACF,eAAKZ,QAAL,CAAcY,cAAd,EAA8B0B,OAA9B,GAAwC,IAAxC;AACA,eAAKtC,QAAL,CAAcY,cAAd,EAA8B2B,QAA9B,GAAyC;AACvCC,YAAAA,MAAM,EAAEH,GAAG,CAACG,MAD2B;AAEvCC,YAAAA,UAAU,EAAE,EAF2B;AAGvCC,YAAAA,YAAY,EAAE;AAHyB,WAAzC;AAKA,eAAK/B,eAAL,CAAqBC,cAArB;AACD,SARD,CAQE,OAAO+B,GAAP,EAAY,CAAE;;AAEhBN,QAAAA,GAAG,CACAhB,IADH,GAEGuB,IAFH,CAESF,YAAD,IAAuB;AAC3B,cAAI,KAAK1C,QAAL,IAAiB,KAAKA,QAAL,CAAcY,cAAd,CAArB,EAAoD;AAClD,iBAAKZ,QAAL,CAAcY,cAAd,EAA8B0B,OAA9B,GAAwC,IAAxC;AACA,iBAAKtC,QAAL,CAAcY,cAAd,EAA8B2B,QAA9B,GAAyC;AACvCC,cAAAA,MAAM,EAAEH,GAAG,CAACG,MAD2B;AAEvCC,cAAAA,UAAU,EAAEJ,GAAG,CAACI,UAFuB;AAGvCC,cAAAA,YAAY,EAAE,KAAKtB,aAAL,CAAmBsB,YAAnB,IACVA,YADU,GAEV;AALmC,aAAzC;AAQA,iBAAK/B,eAAL,CAAqBC,cAArB;AACA,iBAAKP,aAAL;AACD;AACF,SAhBH,EAiBGwC,KAjBH,CAiBUC,GAAD,IAAc;AACnBC,UAAAA,OAAO,CAACC,GAAR,CAAYF,GAAZ;;AACA,cAAI,IAAJ,EAAU;AACR,iBAAKzC,aAAL;AACD;AACF,SAtBH;AAuBD,OAvE2B;AAwE5B4C,MAAAA,aAAa,EAAE,CAACC,IAAD,EAAYtC,cAAZ,KAAoC;AACjD,YAAI,KAAKR,OAAT,EAAkB;AAChB;AACD;;AAED,aAAKJ,QAAL,CAAcY,cAAd,EAA8B0B,OAA9B,GAAwC,KAAxC;AACA,aAAK3B,eAAL,CAAqBC,cAArB;AACA,aAAKP,aAAL;AACD,OAhF2B;AAiF5B8C,MAAAA,MAAM,EAAE,CAACrB,OAAD,EAAesB,IAAf,KAAwC;AAC9C,YAAI,KAAKhD,OAAT,EAAkB;AAChB;AACD;;AAED,YACE0B,OAAO,IACPA,OAAO,CAAClB,cADR,IAEAwC,IAAI,CAAC7C,MAAL,IAAe,CAFf,IAGA,KAAKP,QAJP,EAKE;AACA,eAAKA,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,IAAwC;AACtCsB,YAAAA,IAAI,EAAEkB,IAAI,CAAC,CAAD,CAD4B;AAEtCjB,YAAAA,GAAG,EAAEiB,IAAI,CAAC,CAAD,CAF6B;AAGtCtC,YAAAA,IAAI,EAAE,IAAII,IAAJ;AAHgC,WAAxC;AAKD;;AAED,aAAKb,aAAL;AACD,OApG2B;AAqG5BgD,MAAAA,MAAM,EAAE,CAACvB,OAAD,EAAesB,IAAf,KAAwC;AAC9C,YAAI,KAAKhD,OAAT,EAAkB;AAChB;AACD;;AAED,YACE0B,OAAO,IACPA,OAAO,CAAClB,cADR,IAEA,KAAKZ,QAFL,IAGA,KAAKA,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,CAJF,EAKE;AACA,eAAKZ,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,EAAsCkB,OAAtC,GAAgD;AAC9CC,YAAAA,OAAO,EAAEqB,IAAI,CAAC7C,MAAL,GAAc,CAAd,GAAkB6C,IAAI,CAAC,CAAD,CAAtB,GAA4B,EADS;AAE9CnB,YAAAA,OAAO,EAAEH,OAAO,CAACwB;AAF6B,WAAhD;AAID;;AAED,aAAKjD,aAAL;AACD,OAvH2B;AAwH5BkD,MAAAA,OAAO,EAAGzB,OAAD,IAAkB;AACzB,YACE,CAAC,KAAK1B,OAAN,IACA,KAAKJ,QADL,IAEA8B,OAFA,IAGAA,OAAO,CAAClB,cAHR,IAIA,KAAKZ,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,CALF,EAME;AACA,eAAKZ,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,EAAsC0B,OAAtC,GAAgD,KAAhD;AACA,eAAK3B,eAAL,CAAqBmB,OAAO,CAAClB,cAA7B;AACD;;AAED,aAAKP,aAAL;AACD,OArI2B;AAsI5BmD,MAAAA,MAAM,EAAG1B,OAAD,IAAkB;AACxB,YAAI,KAAK1B,OAAT,EAAkB;AAChB;AACD;;AAED,YACE0B,OAAO,IACPA,OAAO,CAAClB,cADR,IAEA,KAAKZ,QAFL,IAGA,KAAKA,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,CAJF,EAKE;AACA,gBAAM6C,WAAW,GAAG3B,OAAO,CAAC4B,iBAAR,CAA0B,cAA1B,CAApB;AACA,gBAAMC,YAAY,GAChBF,WAAW,KACVA,WAAW,CAACG,QAAZ,CAAqB,MAArB,KAAgCH,WAAW,CAACG,QAAZ,CAAqB,MAArB,CADtB,CADb;AAIA,cAAIlB,YAAY,GAAG,MAAMe,WAAN,GAAoB,GAAvC;;AACA,cAAI3B,OAAO,CAAC+B,YAAR,KAAyB,EAAzB,IAA+B/B,OAAO,CAAC+B,YAAR,KAAyB,MAA5D,EAAoE;AAClEnB,YAAAA,YAAY,GAAGZ,OAAO,CAACY,YAAvB;AACD;;AACD,cAAIZ,OAAO,CAACgC,SAAR,IAAqBH,YAAzB,EAAuC;AACrCjB,YAAAA,YAAY,GAAGZ,OAAO,CAACgC,SAAvB;AACD;;AAED,eAAK9D,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,EAAsC0B,OAAtC,GAAgD,IAAhD;AACA,eAAKtC,QAAL,CAAc8B,OAAO,CAAClB,cAAtB,EAAsC2B,QAAtC,GAAiD;AAC/CC,YAAAA,MAAM,EAAEV,OAAO,CAACU,MAD+B;AAE/CE,YAAAA,YAAY,EAAE,KAAKtB,aAAL,CAAmBsB,YAAnB,IACVA,YADU,GAEV;AAJ2C,WAAjD;AAOA,eAAK/B,eAAL,CAAqBmB,OAAO,CAAClB,cAA7B;AACD;;AAED,aAAKP,aAAL;AACD;AA1K2B,KAA9B;AA4KD;;AAEDqB,EAAAA,wBAAwB,CAACqC,QAAD,EAAgB;AACtC;AACA,QAAIC,IAAI,GAAG,IAAX,CAFsC,CAItC;;AACA,QAAIC,cAAc,CAACC,SAAf,CAAyB,cAAzB,CAAJ,EAA8C;AAC5C;AACD,KAPqC,CAStC;;;AACAD,IAAAA,cAAc,CAACC,SAAf,CAAyB,cAAzB,IAA2C,IAA3C,CAVsC,CAYtC;;AACA,UAAMC,IAAI,GAAGF,cAAc,CAACC,SAAf,CAAyBC,IAAtC;AACA,UAAMC,IAAI,GAAGH,cAAc,CAACC,SAAf,CAAyBE,IAAtC,CAdsC,CAgBtC;;AACAH,IAAAA,cAAc,CAACC,SAAf,CAAyBG,uBAAzB,GACEJ,cAAc,CAACC,SAAf,CAAyBI,gBAD3B;;AAEAL,IAAAA,cAAc,CAACC,SAAf,CAAyBI,gBAAzB,GAA4C,UAAUC,MAAV,EAAkBC,KAAlB,EAAyB;AACnE;AACA,UAAI,CAAC,KAAKlB,cAAV,EAA0B;AACxB;AACA,aAAKA,cAAL,GAAsB,EAAtB;AACD,OALkE,CAOnE;;;AACA,UAAI,KAAKA,cAAL,IAAuB,KAAKA,cAAL,CAAoBmB,cAApB,CAAmCF,MAAnC,CAA3B,EAAuE;AACrE;AACD,OAVkE,CAYnE;;;AACA,UAAI,CAAC,KAAKjB,cAAL,CAAoBiB,MAApB,CAAL,EAAkC;AAChC;AACA,aAAKjB,cAAL,CAAoBiB,MAApB,IAA8B,EAA9B;AACD,OAhBkE,CAkBnE;;;AACA,WAAKjB,cAAL,CAAoBiB,MAApB,EAA4BG,IAA5B,CAAiCF,KAAjC,EAnBmE,CAoBnE;;AACA,WAAKH,uBAAL,CAA6BE,MAA7B,EAAqCC,KAArC;AACD,KAtBD;;AAwBAP,IAAAA,cAAc,CAACC,SAAf,CAAyBC,IAAzB,GAAgC,YAAY;AACzC,UAAD,CAAcvD,cAAd,GAA+B,EAAEoD,IAAI,CAACW,SAAtC;AACAZ,MAAAA,QAAQ,CAACZ,MAAT,IAAmBY,QAAQ,CAACZ,MAAT,CAAgB,IAAhB,EAAsByB,SAAtB,CAAnB;;AAEA,UAAIb,QAAQ,CAACP,MAAb,EAAqB;AACnB,aAAKqB,gBAAL,CAAsB,MAAtB,EAA8B,YAAY;AACxC;AACAd,UAAAA,QAAQ,CAACP,MAAT,CAAgB,IAAhB;AACD,SAHD;AAID;;AACD,UAAIO,QAAQ,CAACR,OAAb,EAAsB;AACpB,aAAKsB,gBAAL,CAAsB,OAAtB,EAA+B,YAAY;AACzC;AACAd,UAAAA,QAAQ,CAACR,OAAT,CAAiB,IAAjB;AACD,SAHD;AAID,OAfyC,CAiB1C;;;AACA,aAAOY,IAAI,CAACW,KAAL,CAAW,IAAX,EAAiBF,SAAjB,CAAP;AACD,KAnBD;;AAqBAX,IAAAA,cAAc,CAACC,SAAf,CAAyBE,IAAzB,GAAgC,YAAY;AAC1CL,MAAAA,QAAQ,CAACV,MAAT,IAAmBU,QAAQ,CAACV,MAAT,CAAgB,IAAhB,EAAsBuB,SAAtB,CAAnB,CAD0C,CAE1C;;AACA,aAAOR,IAAI,CAACU,KAAL,CAAW,IAAX,EAAiBF,SAAjB,CAAP;AACD,KAJD,CAhEsC,CAsEtC;;;AACA,QAAIG,MAAJ,EAAY;AACV,OAAC,YAAY;AACX,YAAIC,aAAa,GAAGD,MAAM,CAACE,KAA3B;;AACAF,QAAAA,MAAM,CAACE,KAAP,GAAe,YAAY;AACzB,cAAIrE,cAAc,GAAG,EAAEoD,IAAI,CAACW,SAA5B;AACAZ,UAAAA,QAAQ,CAACpC,OAAT,CAAiBiD,SAAjB,EAA4BhE,cAA5B;AAEA,iBACEoE,aAAa,CACX;AADW,WAEVF,KAFH,CAES,IAFT,EAEeF,SAFf,EAGGhC,IAHH,CAGQ,UAAUL,QAAV,EAAoB;AACxB,gBAAIA,QAAQ,IAAI,OAAOA,QAAQ,CAAC2C,KAAhB,KAA0B,UAA1C,EAAsD;AACpD,oBAAMC,IAAI,GAAG5C,QAAQ,CAAC2C,KAAT,EAAb;AACAnB,cAAAA,QAAQ,CAAC3B,WAAT,CAAqB+C,IAArB,EAA2BvE,cAA3B;AACD;;AAED,mBAAO2B,QAAP;AACD,WAVH,EAWGM,KAXH,CAWUC,GAAD,IAAS;AACdiB,YAAAA,QAAQ,CAACd,aAAT,CAAuBH,GAAvB,EAA4BlC,cAA5B;AACA,kBAAMkC,GAAN;AACD,WAdH,CADF;AAiBD,SArBD;AAsBD,OAxBD;AAyBD;;AAED,WAAOiB,QAAP;AACD;;AA9U2B;;AAiV9B,eAAenE,uBAAf","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nclass GleapNetworkIntercepter {\n requestId = 0;\n requests: any = {};\n maxRequests = 10;\n stopped = false;\n\n getRequests() {\n return Object.values(this.requests);\n }\n\n setMaxRequests(maxRequests: number) {\n this.maxRequests = maxRequests;\n }\n\n setStopped(stopped: boolean) {\n this.stopped = stopped;\n }\n\n cleanRequests() {\n var keys = Object.keys(this.requests);\n if (keys.length > this.maxRequests) {\n var keysToRemove = keys.slice(0, keys.length - this.maxRequests);\n for (var i = 0; i < keysToRemove.length; i++) {\n delete this.requests[keysToRemove[i]];\n }\n }\n }\n\n calcRequestTime(gleapRequestId: string | number) {\n if (!this.requests[gleapRequestId]) {\n return;\n }\n\n var startDate = this.requests[gleapRequestId].date;\n if (\n startDate &&\n typeof startDate.getTime === 'function' &&\n !Object.isFrozen(this.requests[gleapRequestId])\n ) {\n this.requests[gleapRequestId].duration =\n new Date().getTime() - startDate.getTime();\n this.requests[gleapRequestId].date =\n this.requests[gleapRequestId].date.toString();\n }\n }\n\n contentSizeOk(text: string) {\n if (text && text.length) {\n const size = text.length * 16;\n const kiloBytes = size / 1024;\n const megaBytes = kiloBytes / 1024;\n if (megaBytes < 0.5) {\n return true;\n }\n }\n return false;\n }\n\n start() {\n this.setStopped(false);\n this.interceptNetworkRequests({\n onFetch: (params: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n if (params.length >= 2) {\n var method = params[1].method ? params[1].method : 'GET';\n this.requests[gleapRequestId] = {\n request: {\n payload: params[1].body,\n headers: params[1].headers,\n },\n type: method,\n url: params[0],\n date: new Date(),\n };\n } else {\n this.requests[gleapRequestId] = {\n request: {},\n url: params[0],\n type: 'GET',\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onFetchLoad: (req: any, gleapRequestId: any) => {\n if (\n this.stopped ||\n !gleapRequestId ||\n !this.requests ||\n !this.requests[gleapRequestId]\n ) {\n return;\n }\n\n try {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: '',\n responseText: '<request_still_open>',\n };\n this.calcRequestTime(gleapRequestId);\n } catch (exp) {}\n\n req\n .text()\n .then((responseText: any) => {\n if (this.requests && this.requests[gleapRequestId]) {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: req.statusText,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n }\n })\n .catch((err: any) => {\n console.log(err);\n if (this) {\n this.cleanRequests();\n }\n });\n },\n onFetchFailed: (_err: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n this.requests[gleapRequestId].success = false;\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n },\n onOpen: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n args.length >= 2 &&\n this.requests\n ) {\n this.requests[request.gleapRequestId] = {\n type: args[0],\n url: args[1],\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onSend: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].request = {\n payload: args.length > 0 ? args[0] : '',\n headers: request.requestHeaders,\n };\n }\n\n this.cleanRequests();\n },\n onError: (request: any) => {\n if (\n !this.stopped &&\n this.requests &&\n request &&\n request.gleapRequestId &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].success = false;\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n onLoad: (request: any) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n const contentType = request.getResponseHeader('content-type');\n const isTextOrJSON =\n contentType &&\n (contentType.includes('json') || contentType.includes('text'));\n\n var responseText = '<' + contentType + '>';\n if (request.responseType === '' || request.responseType === 'text') {\n responseText = request.responseText;\n }\n if (request._response && isTextOrJSON) {\n responseText = request._response;\n }\n\n this.requests[request.gleapRequestId].success = true;\n this.requests[request.gleapRequestId].response = {\n status: request.status,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n });\n }\n\n interceptNetworkRequests(callback: any) {\n // eslint-disable-next-line consistent-this\n var self = this;\n\n // @ts-ignore\n if (XMLHttpRequest.prototype['gleapTouched']) {\n return;\n }\n\n // @ts-ignore\n XMLHttpRequest.prototype['gleapTouched'] = true;\n\n // XMLHttpRequest\n const open = XMLHttpRequest.prototype.open;\n const send = XMLHttpRequest.prototype.send;\n\n // @ts-ignore\n XMLHttpRequest.prototype.wrappedSetRequestHeader =\n XMLHttpRequest.prototype.setRequestHeader;\n XMLHttpRequest.prototype.setRequestHeader = function (header, value) {\n // @ts-ignore\n if (!this.requestHeaders) {\n // @ts-ignore\n this.requestHeaders = {};\n }\n\n // @ts-ignore\n if (this.requestHeaders && this.requestHeaders.hasOwnProperty(header)) {\n return;\n }\n\n // @ts-ignore\n if (!this.requestHeaders[header]) {\n // @ts-ignore\n this.requestHeaders[header] = [];\n }\n\n // @ts-ignore\n this.requestHeaders[header].push(value);\n // @ts-ignore\n this.wrappedSetRequestHeader(header, value);\n };\n\n XMLHttpRequest.prototype.open = function () {\n (this as any).gleapRequestId = ++self.requestId;\n callback.onOpen && callback.onOpen(this, arguments);\n\n if (callback.onLoad) {\n this.addEventListener('load', function () {\n // @ts-ignore\n callback.onLoad(this);\n });\n }\n if (callback.onError) {\n this.addEventListener('error', function () {\n // @ts-ignore\n callback.onError(this);\n });\n }\n\n // @ts-ignore\n return open.apply(this, arguments);\n };\n\n XMLHttpRequest.prototype.send = function () {\n callback.onSend && callback.onSend(this, arguments);\n // @ts-ignore\n return send.apply(this, arguments);\n };\n\n // Fetch\n if (global) {\n (function () {\n var originalFetch = global.fetch;\n global.fetch = function () {\n var gleapRequestId = ++self.requestId;\n callback.onFetch(arguments, gleapRequestId);\n\n return (\n originalFetch\n // @ts-ignore\n .apply(this, arguments)\n .then(function (response) {\n if (response && typeof response.clone === 'function') {\n const data = response.clone();\n callback.onFetchLoad(data, gleapRequestId);\n }\n\n return response;\n })\n .catch((err) => {\n callback.onFetchFailed(err, gleapRequestId);\n throw err;\n })\n );\n };\n })();\n }\n\n return callback;\n }\n}\n\nexport default GleapNetworkIntercepter;\n"]}
1
+ {"version":3,"sources":["networklogger.ts"],"names":["GleapNetworkIntercepter","getRequests","Object","values","requests","setMaxRequests","maxRequests","setStopped","stopped","cleanRequests","keys","length","keysToRemove","slice","i","calcRequestTime","gleapRequestId","startDate","date","getTime","isFrozen","duration","Date","toString","contentSizeOk","text","size","kiloBytes","megaBytes","start","interceptNetworkRequests","onFetch","params","method","request","payload","body","headers","type","url","onFetchLoad","req","success","response","status","statusText","responseText","exp","then","catch","_err","onFetchFailed","onOpen","args","onSend","requestHeaders","onError","onLoad","contentType","getResponseHeader","isTextOrJSON","includes","responseType","_response","callback","self","XMLHttpRequest","prototype","open","send","wrappedSetRequestHeader","setRequestHeader","header","value","hasOwnProperty","push","requestId","arguments","addEventListener","apply","global","originalFetch","fetch","clone","data","err"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nclass GleapNetworkIntercepter {\n requestId = 0;\n requests: any = {};\n maxRequests = 10;\n stopped = false;\n\n getRequests() {\n return Object.values(this.requests);\n }\n\n setMaxRequests(maxRequests: number) {\n this.maxRequests = maxRequests;\n }\n\n setStopped(stopped: boolean) {\n this.stopped = stopped;\n }\n\n cleanRequests() {\n var keys = Object.keys(this.requests);\n if (keys.length > this.maxRequests) {\n var keysToRemove = keys.slice(0, keys.length - this.maxRequests);\n for (var i = 0; i < keysToRemove.length; i++) {\n delete this.requests[keysToRemove[i]];\n }\n }\n }\n\n calcRequestTime(gleapRequestId: string | number) {\n if (!this.requests[gleapRequestId]) {\n return;\n }\n\n var startDate = this.requests[gleapRequestId].date;\n if (\n startDate &&\n typeof startDate.getTime === 'function' &&\n !Object.isFrozen(this.requests[gleapRequestId])\n ) {\n this.requests[gleapRequestId].duration =\n new Date().getTime() - startDate.getTime();\n this.requests[gleapRequestId].date =\n this.requests[gleapRequestId].date.toString();\n }\n }\n\n contentSizeOk(text: string) {\n if (text && text.length) {\n const size = text.length * 16;\n const kiloBytes = size / 1024;\n const megaBytes = kiloBytes / 1024;\n if (megaBytes < 0.5) {\n return true;\n }\n }\n return false;\n }\n\n start() {\n this.setStopped(false);\n this.interceptNetworkRequests({\n onFetch: (params: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n if (params.length >= 2) {\n var method = params[1].method ? params[1].method : 'GET';\n this.requests[gleapRequestId] = {\n request: {\n payload: params[1].body,\n headers: params[1].headers,\n },\n type: method,\n url: params[0],\n date: new Date(),\n };\n } else {\n this.requests[gleapRequestId] = {\n request: {},\n url: params[0],\n type: 'GET',\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onFetchLoad: (req: any, gleapRequestId: any) => {\n if (\n this.stopped ||\n !gleapRequestId ||\n !this.requests ||\n !this.requests[gleapRequestId]\n ) {\n return;\n }\n\n try {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: '',\n responseText: '<request_still_open>',\n };\n this.calcRequestTime(gleapRequestId);\n } catch (exp) {}\n\n req\n .text()\n .then((responseText: any) => {\n if (this.requests && this.requests[gleapRequestId]) {\n this.requests[gleapRequestId].success = true;\n this.requests[gleapRequestId].response = {\n status: req.status,\n statusText: req.statusText,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n }\n })\n .catch((_err: any) => {\n if (this) {\n this.cleanRequests();\n }\n });\n },\n onFetchFailed: (_err: any, gleapRequestId: any) => {\n if (this.stopped) {\n return;\n }\n\n this.requests[gleapRequestId].success = false;\n this.calcRequestTime(gleapRequestId);\n this.cleanRequests();\n },\n onOpen: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n args.length >= 2 &&\n this.requests\n ) {\n this.requests[request.gleapRequestId] = {\n type: args[0],\n url: args[1],\n date: new Date(),\n };\n }\n\n this.cleanRequests();\n },\n onSend: (request: any, args: string | any[]) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].request = {\n payload: args.length > 0 ? args[0] : '',\n headers: request.requestHeaders,\n };\n }\n\n this.cleanRequests();\n },\n onError: (request: any) => {\n if (\n !this.stopped &&\n this.requests &&\n request &&\n request.gleapRequestId &&\n this.requests[request.gleapRequestId]\n ) {\n this.requests[request.gleapRequestId].success = false;\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n onLoad: (request: any) => {\n if (this.stopped) {\n return;\n }\n\n if (\n request &&\n request.gleapRequestId &&\n this.requests &&\n this.requests[request.gleapRequestId]\n ) {\n const contentType = request.getResponseHeader('content-type');\n const isTextOrJSON =\n contentType &&\n (contentType.includes('json') || contentType.includes('text'));\n\n var responseText = '<' + contentType + '>';\n if (request.responseType === '' || request.responseType === 'text') {\n responseText = request.responseText;\n }\n if (request._response && isTextOrJSON) {\n responseText = request._response;\n }\n\n this.requests[request.gleapRequestId].success = true;\n this.requests[request.gleapRequestId].response = {\n status: request.status,\n responseText: this.contentSizeOk(responseText)\n ? responseText\n : '<response_too_large>',\n };\n\n this.calcRequestTime(request.gleapRequestId);\n }\n\n this.cleanRequests();\n },\n });\n }\n\n interceptNetworkRequests(callback: any) {\n // eslint-disable-next-line consistent-this\n var self = this;\n\n // @ts-ignore\n if (XMLHttpRequest.prototype['gleapTouched']) {\n return;\n }\n\n // @ts-ignore\n XMLHttpRequest.prototype['gleapTouched'] = true;\n\n // XMLHttpRequest\n const open = XMLHttpRequest.prototype.open;\n const send = XMLHttpRequest.prototype.send;\n\n // @ts-ignore\n XMLHttpRequest.prototype.wrappedSetRequestHeader =\n XMLHttpRequest.prototype.setRequestHeader;\n XMLHttpRequest.prototype.setRequestHeader = function (header, value) {\n // @ts-ignore\n if (!this.requestHeaders) {\n // @ts-ignore\n this.requestHeaders = {};\n }\n\n // @ts-ignore\n if (this.requestHeaders && this.requestHeaders.hasOwnProperty(header)) {\n return;\n }\n\n // @ts-ignore\n if (!this.requestHeaders[header]) {\n // @ts-ignore\n this.requestHeaders[header] = [];\n }\n\n // @ts-ignore\n this.requestHeaders[header].push(value);\n // @ts-ignore\n this.wrappedSetRequestHeader(header, value);\n };\n\n XMLHttpRequest.prototype.open = function () {\n (this as any).gleapRequestId = ++self.requestId;\n callback.onOpen && callback.onOpen(this, arguments);\n\n if (callback.onLoad) {\n this.addEventListener('load', function () {\n // @ts-ignore\n callback.onLoad(this);\n });\n }\n if (callback.onError) {\n this.addEventListener('error', function () {\n // @ts-ignore\n callback.onError(this);\n });\n }\n\n // @ts-ignore\n return open.apply(this, arguments);\n };\n\n XMLHttpRequest.prototype.send = function () {\n callback.onSend && callback.onSend(this, arguments);\n // @ts-ignore\n return send.apply(this, arguments);\n };\n\n // Fetch\n if (global) {\n (function () {\n var originalFetch = global.fetch;\n global.fetch = function () {\n var gleapRequestId = ++self.requestId;\n callback.onFetch(arguments, gleapRequestId);\n\n return (\n originalFetch\n // @ts-ignore\n .apply(this, arguments)\n .then(function (response) {\n if (response && typeof response.clone === 'function') {\n const data = response.clone();\n callback.onFetchLoad(data, gleapRequestId);\n }\n\n return response;\n })\n .catch((err) => {\n callback.onFetchFailed(err, gleapRequestId);\n throw err;\n })\n );\n };\n })();\n }\n\n return callback;\n }\n}\n\nexport default GleapNetworkIntercepter;\n"]}
@@ -8,6 +8,7 @@ declare type GleapSdkType = {
8
8
  open(): void;
9
9
  startFeedbackFlow(feedbackFlow: string): void;
10
10
  sendSilentBugReport(description: string, severity: 'LOW' | 'MEDIUM' | 'HIGH'): void;
11
+ sendSilentBugReportWithType(description: string, severity: 'LOW' | 'MEDIUM' | 'HIGH', type: string): void;
11
12
  identify(userId: string, userProperties: GleapUserProperty): void;
12
13
  clearIdentity(): void;
13
14
  setApiUrl(apiUrl: string): void;
@@ -19,6 +20,7 @@ declare type GleapSdkType = {
19
20
  registerCustomAction(customActionCallback: (data: {
20
21
  name: string;
21
22
  }) => void): void;
23
+ registerListener(eventType: string, callback: (data?: any) => void): void;
22
24
  setLanguage(language: string): void;
23
25
  logEvent(name: string, data: any): void;
24
26
  addAttachment(base64file: string, fileName: string): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-native-gleapsdk",
3
- "version": "6.4.2",
3
+ "version": "6.4.5-beta.1",
4
4
  "description": "Know exactly why and how a bug happened. Get reports with screenshots, live action replays and all of the important metadata every time.",
5
5
  "main": "lib/commonjs/index",
6
6
  "module": "lib/module/index",
@@ -16,5 +16,5 @@ Pod::Spec.new do |s|
16
16
  s.source_files = "ios/**/*.{h,m,mm}"
17
17
 
18
18
  s.dependency "React-Core"
19
- s.dependency "Gleap", "6.4.2"
19
+ s.dependency "Gleap", "6.4.6"
20
20
  end
package/src/index.tsx CHANGED
@@ -22,6 +22,11 @@ type GleapSdkType = {
22
22
  description: string,
23
23
  severity: 'LOW' | 'MEDIUM' | 'HIGH'
24
24
  ): void;
25
+ sendSilentBugReportWithType(
26
+ description: string,
27
+ severity: 'LOW' | 'MEDIUM' | 'HIGH',
28
+ type: string
29
+ ): void;
25
30
  identify(userId: string, userProperties: GleapUserProperty): void;
26
31
  clearIdentity(): void;
27
32
  setApiUrl(apiUrl: string): void;
@@ -33,6 +38,7 @@ type GleapSdkType = {
33
38
  registerCustomAction(
34
39
  customActionCallback: (data: { name: string }) => void
35
40
  ): void;
41
+ registerListener(eventType: string, callback: (data?: any) => void): void;
36
42
  setLanguage(language: string): void;
37
43
  logEvent(name: string, data: any): void;
38
44
  addAttachment(base64file: string, fileName: string): void;
@@ -65,13 +71,30 @@ if (GleapSdk && !GleapSdk.touched) {
65
71
  networkLogger.setStopped(true);
66
72
  };
67
73
 
68
- var callbacks: any[] = [];
74
+ var callbacks: any = {};
75
+
76
+ GleapSdk.registerListener = (eventType: string, callback: any) => {
77
+ if (!callbacks[eventType]) {
78
+ callbacks[eventType] = [];
79
+ }
80
+ callbacks[eventType].push(callback);
81
+ };
69
82
 
70
83
  GleapSdk.registerCustomAction = (customActionCallback: any) => {
71
- callbacks.push(customActionCallback);
84
+ GleapSdk.registerListener('customActionTriggered', customActionCallback);
85
+ };
86
+
87
+ const notifyCallback = function (eventType: string, data?: any) {
88
+ if (callbacks && callbacks[eventType] && callbacks[eventType].length > 0) {
89
+ for (var i = 0; i < callbacks[eventType].length; i++) {
90
+ if (callbacks[eventType][i]) {
91
+ callbacks[eventType][i](data);
92
+ }
93
+ }
94
+ }
72
95
  };
73
96
 
74
- const gleapEmitter = new NativeEventEmitter(GleapSdk);
97
+ const gleapEmitter = new NativeEventEmitter(NativeModules.Gleapsdk);
75
98
 
76
99
  gleapEmitter.addListener('configLoaded', (config: any) => {
77
100
  try {
@@ -79,6 +102,7 @@ if (GleapSdk && !GleapSdk.touched) {
79
102
  if (configJSON.enableNetworkLogs) {
80
103
  GleapSdk.startNetworkLogging();
81
104
  }
105
+ notifyCallback('configLoaded', configJSON);
82
106
  } catch (exp) {}
83
107
  });
84
108
 
@@ -90,6 +114,19 @@ if (GleapSdk && !GleapSdk.touched) {
90
114
  } else {
91
115
  GleapSdk.attachNetworkLog(JSON.parse(JSON.stringify(requests)));
92
116
  }
117
+
118
+ notifyCallback('feedbackWillBeSent');
119
+ });
120
+
121
+ gleapEmitter.addListener('feedbackSent', (data) => {
122
+ try {
123
+ const dataJSON = data instanceof Object ? data : JSON.parse(data);
124
+ notifyCallback('feedbackSent', dataJSON);
125
+ } catch (exp) {}
126
+ });
127
+
128
+ gleapEmitter.addListener('feedbackSendingFailed', () => {
129
+ notifyCallback('feedbackSendingFailed');
93
130
  });
94
131
 
95
132
  function isJsonString(str: string) {
@@ -107,14 +144,10 @@ if (GleapSdk && !GleapSdk.touched) {
107
144
  data = JSON.parse(data);
108
145
  }
109
146
  const { name } = data;
110
- if (name && callbacks.length > 0) {
111
- for (var i = 0; i < callbacks.length; i++) {
112
- if (callbacks[i]) {
113
- callbacks[i]({
114
- name,
115
- });
116
- }
117
- }
147
+ if (name) {
148
+ notifyCallback('customActionTriggered', {
149
+ name,
150
+ });
118
151
  }
119
152
  } catch (exp) {}
120
153
  });
@@ -124,8 +124,7 @@ class GleapNetworkIntercepter {
124
124
  this.cleanRequests();
125
125
  }
126
126
  })
127
- .catch((err: any) => {
128
- console.log(err);
127
+ .catch((_err: any) => {
129
128
  if (this) {
130
129
  this.cleanRequests();
131
130
  }