All notable changes to this project are documented in this file.
- Updated RUM XHR events to include
requestDetails
for theonBeforeSendRUM
handler. Request details includeurl
(including query parameters),method
,body
andresponseBody
. These details are stripped from the payload before it's sent to Raygun's servers.
- Updated when ping happens so it only happens once, and when successful, it will store in sessionStorage and not ping again. This is to prevent multiple pings from happening on every page load.
- Resolved jQuery
isFunction
deprecation warnings. As of jQuery 3.3,jQuery.isFunction()
is deprecated. It is replaced bytypeof x === "function"
- source.
- Added a ping to tell Raygun that raygun4js has been set up correctly. The ping is enabled by default but can be disabled using the new
sendPing
option e.g.,rg4js('sendPing', false)
. The ping contains the version of Raygun4js and which products have been enabled (CrashReporting and/or Real User Monitoring). This information will be used to help users when setting up a new application. - Moved the typescript types into the main raygun4js repo
- Added a new option for enabling Real User Monitoring.
rg4js('enableRealUserMonitoring', true);
- Fixed an typo raised by issue #508 that caused breadcrumb messages to be undefined
- Adds Browserify support to build pipeline
- Added new browser mocks for unit tests
- Added new popstate event listener, to trigger
- unloadHandler replacement: Added popstate event listener network logic to better support mobile devices
- unloadHandler replacement: Added hidden visibilityState change network logic to better support mobile devices
- Changed the way the web-vitals library is imported into the project
- Moved to using the official web vital callback triggers
- Updated the sendCoreWebVitalTimings method to fire web vital payloads using beacon if available
- Upgrade chromedriver dependency to 119.0.1
- unloadHandler replacement: Removed the unload event listener network logic in favour of other approaches
- Adds client provider (version) information
- Adds defaults for timing information payload information
- Fixes a rare condition with UMD where we assume rg4js is initialised but it is not, causing an infinite loop.
- Rolls back the previous change
- Fixes a rare condition where 'Custom timings' are showing on pages that aren't related
[2nd phase of deprecations] NPM and nuget packages (2.26.4 and older) were marked deprecated on NPM and Nuget with message:
This package is deprecated. It may not perform completely in browsers newer than Chromium 114
NPM and nuget packages (2.25.4 and older) were marked deprecated on NPM and Nuget with message:
This package is deprecated. It may not perform completely in browsers newer than Chromium 114
- Page timings are now gathered by default from PerformanceNavigationTiming instead of PerformanceTiming when available. This was done because the PerformanceTiming API has been deprecated.
- Now defaults to using the
PerformanceObserver
object to trigger RUM. This ensures it occurs after the page is fully loaded and all timing objects are populated
- Fixed bug that could stop
captureMissingRequests
from being set. - Fixed potential access to PerformanceTiming API in browsers where it has been deprecated
- Bug fix for structuredClone causing errors when used, together, with
rg4js('withTags', function() {});
- Use api.raygun.io endpoint, if URL is not overridden, to send stored events
- Reverted the default endpoint url from api.raygun.com back to api.raygun.io (From release v2.26.2 which is causing disruptions for some users)
- The 'OnBeforeSend' and 'OnBeforeSendRUM' callbacks now pass a clone of the payload, to prevent accidental pollution of global objects
- Updated the Github Action (Pre commit unit tests) Node to version 20
- Replaced old company name in metadata
- Documentation points to 'new' .com url
- Updated the Raygun url to send events to preferred ingestion endpoint
- Fixed timing bug, where some xhr requests may rarely be mis-attributed to a different page from which they were started on.
- Updated unit test libraries and re-enabled running on PR creation
- Removed some dead code related to http support in IE8. As IE8 and http is no longer supported due to security reasons
- Improve README documentation to be more clear on the protocol relative URL and how to use the CDN implementation without running a server .
- Improve README documentation to be more clear on our highly recommended installation steps.
- Minor grammar changes within README
- Add a note about rich user data within README
- Update the Github Workflow to use a support chrome-version for the chromedriver
- Improved support for including High Entropy user agent data
- Adds support for including High Entropy user agent data
- Adds support for the Ionic Capacitor cross-platform app runtime
- Allows passing a callback with 'getRaygunInstance' to allow for easier access to checking if a raygun instance exists when raygun4js may not have finished loading
- Fixes an issue where the rg4js proxy in the umd loader was throwing away the return value of the executor, preventing the use of commands like 'getRaygunInstance'
- Fixes an issue where errors on promises, which have been caught, were still being reported to raygun. Thanks @codex- for identifying and fixing the problem.
- Attach a parent resource to non-page load events to assist with resource parenting.
- Send the browser's viewport width and height with each RUM session payload.
- If
ignore3rdPartyErrors
option is true, discard errors that match the pattern of errors from browser extensions, bots and crawlers.
- Fixes an issue with Core Web Vital tracking not being able to be disabled.
- Fixes an issue where
navigator.sendBeacon
errors were not being handled gracefully.
- Upgrade the web-vitals vendor library to v2.1.0.
- Fixes an issue where Core Web Vital timings were being queued behind virtual page timings.
- Fixes an issue where the heartbeat was not clearing the
xhrStatusMap
array due tothis
referring to the window object
- Fixes an issue where raygun4js attempts to access the document on non-browser environments. Also ensures that the Core Web Vitals scripts are not initialized for these environments.
- Fixes a compatibility issue with the
web-vitals
vendor script and RequireJS.
- Adds the ability to track Core Web Vitals when the
trackCoreWebVitals
option is enabled. The option is enabled by default.
- Fixes an issue where errors generated on Cordova iOS 6.0+ applications would not contain a stack trace due to the scheme changing from
file
and toapp
- Fixes a memory leak issue by clearing the
xhrStatusMap
array on every heart beat - Replace the "Script error" message on an unhandled rejection to be "Unhandled promise rejection" to better distinguish between the two
- Adds a fallback for calculating the duration for timing entries which have a
.duration
value of zero. This fixes a issue where Safari reportsfetch
calls as having a duration of zero.
- Fixes an issue with ionic-cordova errors not reporting due to the stack-trace being null. Thanks @nirajrajbhandari for identifying and fixing the problem
- Fixes an issue where some browsers (most notably Mobile Safari) won't send data when the page is being transitioned away from
- Adds new custom timings support which enables Custom Timings to work with SPA's and regardless of page loads
- Adds an option
automaticPerformanceCustomTimings
for tracking performance.measure calls as custom timings
- Fix accidental removal of node.value
- Add manual end session functionality to public API
- Fixes an issue where we record the "navigation" entryTypes as cached child assets
- Fixes an issue with
setAutoBreadcrumbsXHRIgnoredHosts
not being applied when requests are opened
- Use navigator.sendBeacon when available to send the last request as XHR requests can be cancelled
- Fixes an issue with first-paint being calculated incorrectly for Edge/IE browsers
- Fixes an issue with how the network tracking util integrates with the fetch snippet
- Missing XHR timings are no longer tracked by default. Instead a configuration option exists to enable these via 'captureMissingRequests'
- Set the maximum duration of missing XHR calls to 5 minutes
- Add offset timings to missing XHR calls
- Support for tracking fetch methods which might be referenced locally
- Fixes an issue where the XHR data type was not attached to statusCode calls
- Fix regression and use localStorage to persist RUM sessions instead of sessionStorage
- Add initial support for users to set the client IP address
- Fix promise rejection errors when trying to retrieve fetch response text in network-tracking module
- Add paint timings to RUM page load metrics using the performance api & msFirstPaint
- Wrap response code get 'text' in a try catch
- Change the key for the status code which gets sent to RUM to statusCode to match the API
- Prepend the protocol to the URL in the resolveFullUrl function to accommodate URLs without protocols
- Include all dist files in npm package instead of just main file
- Don't run RUM in React Native to prevent a crash, RUM does not support React Native
- Fix error in Raygun4JS UMD build with raygunNetworkTrackingFactory being undefined
- Use localStorage to persist user id for Crash Reporting instead of a cookie
- Use sessionStorage to persist session id for RUM instead of a cookie
- Start tracking XHR status codes with performance information
- Improve support for EmberJS
- Add fetch support to automatic XHR breadcrumbs
- Fix offline errors not being sent with new API key format
- Guard call to XMLHttpRequest.setRequestHeader as it is not present on IE8,9,10,11
- Typescript definitions removed, they are now maintained in @types/raygun4js
- Set
content-type
header on XHR calls - Fix issue #302 with the promiseRejectionHandler throwing rejection errors
- Unhandled promise exceptions will now use the look for a
reason.error
error instance ifevent.reason
isn't already an Error instance.
- Bug where stacktraces/messages in older browsers wouldn't be calculated
- Add
UnhandledPromiseRejection
tag to errors caught by the unhandled promise callback - Fixes a bug where the
UnhandledException
tag would be added unnecessarily to subsequent errors - Manually sending a error which is a string and not a Error object no longer results in a
Script error
being sent. Instead it uses the string as the error message
- Fixes bug with
ignore3rdPartyErrors
that could result in first party errors being ignored - Fixes Typescript definitions for V2 API
- Adds 'setCookieAsSecure' option which will set the '; secure' flag on cookies. Off by default
- Fetch calls are now tracked like XHR calls for RUM
- Add support for unhandled promise exceptions
- Fix crash with stack traces containing undefined urls
- Fix potential error attaching breadcrumbs to error payload
- Fixes crash in third party error detection code when stacktraces have undefined urls
- If logging of XHR contents in Breadcrumbs is enabled requests/responses before the onload event will now be recorded
- Errors that happen before onload event when using Raygun4JS via the NPM module will now be captured
- Add a request ID for each page and virtual page to associate it with its child assets
- Add failed posted payload event items to a queue, attempt to send queued items on heartbeat
- Navigating to virtual pages before sending custom timings will no longer prevent the page load timings from being sent
- Stop multiple heartbeat timers from being created
- Prevent 'page' and 'virtual page' timings from being included in the same event data item, fixing 'virtual pages' being counted as 'page views'
- Fix child assets being associated with incorrect views
- Fix virtual page duration timings
- Correct error in Typescript definition requiring isAnonymous to be a string when setting user information
- Fix crash on unhandled exceptions when withTags option is set to a string instead of an array or function returning an array
- Fix JSON parsing issue when attempting to use RUM custom timings
- Strip query string out of RUM virtual page urls
- New onBeforeSendRUM callback to modify and cancel sending of RUM payloads
- Disabling automatic breadcrumb functionality will correctly un-enhance the enhanced objects
- Don't read response text in breadcrumb XHR logging if logXhrContents is false
- Improve breadcrumb disabling to handle network calls that match xhrIgnoredHosts but were triggered before the xhrIgnoredHosts configuration option was set
- Update TraceKit regexes to handle stacktraces in RN android release builds
- Fix a rare initialization issue with RUM and recording events before the provider has finished loading
- Small bugfixes to some of the Breadcrumbs operations
- Fixes a runtime bug on init when using the UMD module (installed via NPM) introduced in 2.6.2
- React Native: bugfix for 'window is not defined' error upon import
- Fix a bug in vanilla and UMD builds introduced when using breadcrumbs
- Adds support for tracking custom timings in Real User Monitoring
- Fixes corner case bugs with XHRs as recorded by breadcrumbs
- Adds breadcrumbs feature
- Initial beta support for React Native in Release (production) mode
- Fixed indexOf bug for IE8 compatibility
- Fixed offline errors failing to send to Raygun when back online.
- Fix for duplicate UnhandledException tags as added in v2.5.0
- Loader option setters and errors/trackEvent calls are now executed once onLoad, fixing edge cases and race conditions with
rg4js
calls during various stages of the page lifecycle
- Unhandled errors now have a tag added, UnhandledException, for filtering by handled error vs. crash in the Raygun web app
- Update regexes to support stacktraces from Electron, Chrome with Webpack, and many other scenarios/edge cases
- Locally cached errors for offline saving are now keyed off the API key, allowing apps running on different subdomains to use offline caching
- Adds UMD module support for React Native and other non-web bundled app scenarios
- Max length of RUM URLs is clamped to 800 chars (aligned with existing backend behavior)
- Guard against an undefined options object causing undefined messages for thrown non-Error objects (strings)
- Fix synchronous XHR warnings in Chrome
- Fix a bug in v2.4.0 when the library loads first and consumer code sets
rg4js
options which then aren't picked up and used
- Allow send/trackEvent calls to be proxied through
rg4js()
to avoid async loading race condition when global Raygun object not available before static load is finished - Add onAfterSend callback function
- Fix non-RG onerror handlers from being removed if Crash Reporting not enabled
- The most recent pending virtual page is now sent when the tab/window is closed from unload (where available)
- RUM URLs lowercase by default
- Add ability to ignore RUM URL casing
- Guard against undefined fetchStart bug in Mobile Safari 8.0 which passed the existing Browser Timing checks
- Add new onBeforeXHR function for mutating the XHR object immediately before an error payload is sent to the API
- If invalid non-function handler passed in to jQuery Ajax add function, call the old event handler & return early
- CustomData keys with a value of
null
are now included and not filtered out automatically when filtering is enabled - Guard against non-string type in message being sub-stringed
- Fix bug when passing callback to
withTags()
and subsequently callingRaygun.send()
with tags parameter also - ignoreAjaxAbort now checks for statusCode of
0
in addition to checking if the response headers are null when deciding to ignore a potential aborted Ajax request
- Further guards for unsupported
now()
in Safari 7/8
- Hotfix for unsupported calls in IE8
- Release version of v2.2.0-beta with bug fixes and improvements; trackEvent officially added to API
-
Adds experimental support for SPA sites to RUM
-
noConflict mode improved for V2
-
Fixed a bug when attaching onBeforeUnload handler when RUM enabled
-
v2.1.1
- Fix issue where when filterScope set to 'all' resulted in payload 400 errors
- Guard against null message substring error
- Add custom grouping key function
- Add ability to ignore host-names and user agents for RUM
- Calls to
rg4js()
for config setters made after the script has been downloaded by the snippet are now proxied through to the Raygun object, making the V2 API experience like V1 - Guard against data set with V2 API being null for certain out-of-order declaration scenarios
- Fix API rejection issue for large heartbeat payloads
- Fix a bug where the session cookie was not present or invalid
-
Fixes a snippet loader race condition
-
v2.0.2
- Fixes an issue with isAnonymous from setUser
-
v2.0.1
- Guard against NaNs in RUM timing data
- Adds support for Real User Monitoring
- Create copy of customData object when filtering
- Slice function check for older browsers
- Limit active data on JQuery AJAX errors
- Error payloads are no longer persisted in localStorage if sending failed due to RG plan hitting its monthly cap
- Guard against invalid JSON being persisted in localStorage on send failure
- Guard against incorrect (non-function) types being passed in as callback handler to wrapped $.event
- Guard against null stacktraces in JS Windows Store apps
- Published to npm
- Ajax errors: custom data now includes the markup of the tag which caused the error
- Various improvements to the internal Tracekit fork for Firefox and Chrome
- Added generation of source maps
- Safer implementations of excludedHostnames and excludedUserAgents when there are prototype functions on the arrays passed to these keys
- filterSensitiveData now also accepts RegExp objects in its param array
- Add new
setFilterScope()
function for supporting applying the filterSensitiveData keys across the entire payload (supported scopes are 'all' and 'customData')
- Add location.hash to Request.Url before payload is sent
- setUser now accepts empty strings/falsey values for logout scenarios
- Max message size of 512 in payload
- Guard against a runtime error when no options are specified
- Add new ignoreAjaxError option to stop auto sending of Ajax 400/500 errors when attached
- excludedHostnames now takes regexes for partial matching
- Add new excludedUserAgents to prevent sends from certain clients (supports regexes as above)
- Support multiple Raygun objects on one page
- jQuery Ajax errors now have better method names (the function signature) for anonymous functions
- Added init option to exclude host-names to prevent sending from certain environments
- wrapAsynchronousCallbacks now defaults to false
- Split the changelog out into this file
- Add wrapAsynchronousCallbacks option for disabling wrapping of setTimeout/setInterval callbacks
- Provide query-strings from AngularJS too (hash in URL broke previous logic)
- Fix stacktrace bug from Firefox that caused source maps to not be processed correctly
- Added anonymous user tracking, enabled by default
- Errors in third-party scripts (not hosted on origin domain) are now stopped from being sent correctly (flag still must be set true)
- Added new
onBeforeSend()
callback function withTags()
can now take a callback function- Custom data is now filtered by filterSensitiveData (recursively) too
- Guard against 'settings' in ajax errors being undefined, leading to failed sends
- Add support for unique stack trace format in iOS 7 UIWebView for anonymous functions
- Guard against another possible undefined string in Tracekit causing an 'indexOf' error
- Ajax errors now transmit response text
- Filtered keys are now transmitted with the value sanitized instead of having the whole object removed
- Add ignoring 3rd party scripts
- Fix bug with filtering keys on some browsers
- Support chrome extension stack parsing
- Added enhanced affected user data to setUser
- Ported latest Tracekit improvements
- Fix bug in filter query
- Added function to filter sensitive query string
- Add ignoreAjaxAbort option
- Provide vanilla build without jQuery hooks
- Guard against circular reference in custom data
- Allow withCustomData to accept a function to provide a
customdata
object - Fix undefined URL issue from Ajax
- Rm duplicated Tracekit ajax hook
- Fixed bug in Tracekit which caused 'Cannot call method indexOf' of undefined error
- Added meaningful message for Ajax errors
- Fixed debugmode logging bug
- Add Offline Saving feature; add support for WinJS
- Fixed tags not being included when error caught from global window.onerror handler
- Fixed broken withTags when no other custom data provided on Send
- Added source maps support by transmitting column numbers (from supported browsers)
- Fixed an issue with not supplying options to processUnhandledException
- Added support for attaching Tags
- Added NuGet package
- Added Bower package; minor bugfix for Ajax functionality
- Capture data submitted by jQuery AJAX calls
- Allow IE8 to submit errors over HTTP
- Updated TraceKit to the latest revision
- Fix bug with using jQuery AJAX calls with >= v1.5 of jQuery
- AJAX errors will display status code instead of script error
- Fixed regression where
send()
would no longer attach a custom data object parameter
- Fixed the need to call
attach()
(if only using manual sending)
- Added user tracking/Customers and version tracking functionality
- Updated to latest TraceKit
- Included removed jQuery support from TraceKit
- Added jQuery AJAX error support
- Changed from QueryString approach to sending data to using an ajax post with CORS
- Initial Release