-
Notifications
You must be signed in to change notification settings - Fork 100
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow to disable interception of XMLHttpRequest #981
Comments
Hi, @ddeath! Thanks for reporting this issue and providing this detailed description. This is a pretty good point and I can see why this behavior occurs. The current implementation of the network interceptor grabs the original I think a proper fix for this would be to get the original I will proceed with the fix described and get back to you once ready. |
Yeah, your solution will definitely help, however, I would also include that option to init object. Including that option to init object will cause more visibility for NetworkLogger and help identify these kinds of collisions between libraries sooner. Thank you for working on this bug! |
@ddeath I think introducing the change to get the |
Since #984 has been merged with the fix, we can close this one. |
I would like to have an option to completely prevent XMLHttpRequest to be intercepted. Current implementation of library will always enable it and then we have option to disable it with
NetworkLogger.setEnabled(false)
However this is not ideal because if there are some other modifications to the same object, kind of undefined behaviour can happen. See example bellow.
In order to keep interception enabled by default I would suggest that you could add new option to
InstabugConfig
which would be true by default and if it would be false, XMLHttpRequest would be kept untouched.In practice, this line: https://github.com/Instabug/Instabug-React-Native/blob/master/src/modules/Instabug.ts#L90 would be wrapped in IF based on that option.
Steps to Reproduce the Problem
NetworkLogger.setEnabled(false)
After these steps your own customization from step #2 is lost.
Expected Behavior
XMLHttpRequest is not proxied at all
Actual Behavior
XMLHttpRequest is first proxied and then original version is restored if it is disabled
SDK Version
11.9.1
React Native, iOS and Android Versions
0.71.8
Device Model
IOS Simulator
The text was updated successfully, but these errors were encountered: