@openreplay/tracker 16.0.2-beta.1 → 16.0.3-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.
- package/dist/cjs/common/interaction.d.ts +2 -2
- package/dist/cjs/common/messages.gen.d.ts +1 -44
- package/dist/cjs/entry.js +9828 -0
- package/dist/cjs/entry.js.map +1 -0
- package/dist/cjs/index.js +88 -116
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/main/app/index.d.ts +0 -5
- package/dist/cjs/main/app/messages.gen.d.ts +0 -5
- package/dist/cjs/main/app/observer/observer.d.ts +5 -1
- package/dist/cjs/main/app/observer/top_observer.d.ts +1 -0
- package/dist/cjs/main/app/ticker.d.ts +0 -4
- package/dist/cjs/main/entry.d.ts +5 -0
- package/dist/cjs/main/index.d.ts +3 -3
- package/dist/cjs/main/singleton.d.ts +108 -0
- package/dist/lib/common/interaction.d.ts +2 -2
- package/dist/lib/common/messages.gen.d.ts +1 -44
- package/dist/lib/entry.js +9821 -0
- package/dist/lib/entry.js.map +1 -0
- package/dist/lib/index.js +88 -116
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/main/app/index.d.ts +0 -5
- package/dist/lib/main/app/messages.gen.d.ts +0 -5
- package/dist/lib/main/app/observer/observer.d.ts +5 -1
- package/dist/lib/main/app/observer/top_observer.d.ts +1 -0
- package/dist/lib/main/app/ticker.d.ts +0 -4
- package/dist/lib/main/entry.d.ts +5 -0
- package/dist/lib/main/index.d.ts +3 -3
- package/dist/lib/main/singleton.d.ts +108 -0
- package/dist/types/common/interaction.d.ts +2 -2
- package/dist/types/common/messages.gen.d.ts +1 -44
- package/dist/types/main/app/index.d.ts +0 -5
- package/dist/types/main/app/messages.gen.d.ts +0 -5
- package/dist/types/main/app/observer/observer.d.ts +5 -1
- package/dist/types/main/app/observer/top_observer.d.ts +1 -0
- package/dist/types/main/app/ticker.d.ts +0 -4
- package/dist/types/main/entry.d.ts +5 -0
- package/dist/types/main/index.d.ts +3 -3
- package/dist/types/main/singleton.d.ts +108 -0
- package/package.json +11 -6
package/dist/lib/index.js
CHANGED
|
@@ -721,7 +721,9 @@ class StringDictionary {
|
|
|
721
721
|
this.backDict = {};
|
|
722
722
|
this.getKey = (str) => {
|
|
723
723
|
let isNew = false;
|
|
724
|
-
|
|
724
|
+
// avoiding potential native object properties
|
|
725
|
+
const safeKey = `__${str}`;
|
|
726
|
+
if (!this.backDict[safeKey]) {
|
|
725
727
|
isNew = true;
|
|
726
728
|
// shaving the first 2 digits of the timestamp (since they are irrelevant for next millennia)
|
|
727
729
|
const shavedTs = Date.now() % 10 ** (13 - 2);
|
|
@@ -733,10 +735,10 @@ class StringDictionary {
|
|
|
733
735
|
else {
|
|
734
736
|
this.lastSuffix = 1;
|
|
735
737
|
}
|
|
736
|
-
this.backDict[
|
|
738
|
+
this.backDict[safeKey] = id;
|
|
737
739
|
this.lastTs = shavedTs;
|
|
738
740
|
}
|
|
739
|
-
return [this.backDict[
|
|
741
|
+
return [this.backDict[safeKey], isNew];
|
|
740
742
|
};
|
|
741
743
|
}
|
|
742
744
|
}
|
|
@@ -1673,33 +1675,6 @@ function SetNodeAttributeDictGlobal(id, name, value) {
|
|
|
1673
1675
|
value,
|
|
1674
1676
|
];
|
|
1675
1677
|
}
|
|
1676
|
-
function CSSInsertRule(id, rule, index) {
|
|
1677
|
-
return [
|
|
1678
|
-
37 /* Messages.Type.CSSInsertRule */,
|
|
1679
|
-
id,
|
|
1680
|
-
rule,
|
|
1681
|
-
index,
|
|
1682
|
-
];
|
|
1683
|
-
}
|
|
1684
|
-
function CSSDeleteRule(id, index) {
|
|
1685
|
-
return [
|
|
1686
|
-
38 /* Messages.Type.CSSDeleteRule */,
|
|
1687
|
-
id,
|
|
1688
|
-
index,
|
|
1689
|
-
];
|
|
1690
|
-
}
|
|
1691
|
-
function Fetch(method, url, request, response, status, timestamp, duration) {
|
|
1692
|
-
return [
|
|
1693
|
-
39 /* Messages.Type.Fetch */,
|
|
1694
|
-
method,
|
|
1695
|
-
url,
|
|
1696
|
-
request,
|
|
1697
|
-
response,
|
|
1698
|
-
status,
|
|
1699
|
-
timestamp,
|
|
1700
|
-
duration,
|
|
1701
|
-
];
|
|
1702
|
-
}
|
|
1703
1678
|
function Profiler(name, duration, args, result) {
|
|
1704
1679
|
return [
|
|
1705
1680
|
40 /* Messages.Type.Profiler */,
|
|
@@ -1842,18 +1817,6 @@ function SetNodeFocus(id) {
|
|
|
1842
1817
|
id,
|
|
1843
1818
|
];
|
|
1844
1819
|
}
|
|
1845
|
-
function LongTask(timestamp, duration, context, containerType, containerSrc, containerId, containerName) {
|
|
1846
|
-
return [
|
|
1847
|
-
59 /* Messages.Type.LongTask */,
|
|
1848
|
-
timestamp,
|
|
1849
|
-
duration,
|
|
1850
|
-
context,
|
|
1851
|
-
containerType,
|
|
1852
|
-
containerSrc,
|
|
1853
|
-
containerId,
|
|
1854
|
-
containerName,
|
|
1855
|
-
];
|
|
1856
|
-
}
|
|
1857
1820
|
function SetNodeAttributeURLBased(id, name, value, baseURL) {
|
|
1858
1821
|
return [
|
|
1859
1822
|
60 /* Messages.Type.SetNodeAttributeURLBased */,
|
|
@@ -1885,15 +1848,6 @@ function CustomIssue(name, payload) {
|
|
|
1885
1848
|
payload,
|
|
1886
1849
|
];
|
|
1887
1850
|
}
|
|
1888
|
-
function CSSInsertRuleURLBased(id, rule, index, baseURL) {
|
|
1889
|
-
return [
|
|
1890
|
-
67 /* Messages.Type.CSSInsertRuleURLBased */,
|
|
1891
|
-
id,
|
|
1892
|
-
rule,
|
|
1893
|
-
index,
|
|
1894
|
-
baseURL,
|
|
1895
|
-
];
|
|
1896
|
-
}
|
|
1897
1851
|
function MouseClick(id, hesitationTime, label, selector, normalizedX, normalizedY) {
|
|
1898
1852
|
return [
|
|
1899
1853
|
68 /* Messages.Type.MouseClick */,
|
|
@@ -2132,9 +2086,6 @@ var _Messages = /*#__PURE__*/Object.freeze({
|
|
|
2132
2086
|
AdoptedSSRemoveOwner: AdoptedSSRemoveOwner,
|
|
2133
2087
|
AdoptedSSReplaceURLBased: AdoptedSSReplaceURLBased,
|
|
2134
2088
|
BatchMetadata: BatchMetadata,
|
|
2135
|
-
CSSDeleteRule: CSSDeleteRule,
|
|
2136
|
-
CSSInsertRule: CSSInsertRule,
|
|
2137
|
-
CSSInsertRuleURLBased: CSSInsertRuleURLBased,
|
|
2138
2089
|
CanvasNode: CanvasNode,
|
|
2139
2090
|
ConnectionInformation: ConnectionInformation,
|
|
2140
2091
|
ConsoleLog: ConsoleLog,
|
|
@@ -2144,13 +2095,11 @@ var _Messages = /*#__PURE__*/Object.freeze({
|
|
|
2144
2095
|
CreateTextNode: CreateTextNode,
|
|
2145
2096
|
CustomEvent: CustomEvent,
|
|
2146
2097
|
CustomIssue: CustomIssue,
|
|
2147
|
-
Fetch: Fetch,
|
|
2148
2098
|
GraphQL: GraphQL,
|
|
2149
2099
|
GraphQLDeprecated: GraphQLDeprecated,
|
|
2150
2100
|
InputChange: InputChange,
|
|
2151
2101
|
JSException: JSException,
|
|
2152
2102
|
LoadFontFace: LoadFontFace,
|
|
2153
|
-
LongTask: LongTask,
|
|
2154
2103
|
Metadata: Metadata,
|
|
2155
2104
|
MobX: MobX,
|
|
2156
2105
|
MouseClick: MouseClick,
|
|
@@ -2588,9 +2537,7 @@ const spinnerStyles = {
|
|
|
2588
2537
|
};
|
|
2589
2538
|
|
|
2590
2539
|
const Quality = {
|
|
2591
|
-
Standard: { width: 1280, height: 720 }
|
|
2592
|
-
High: { width: 1920, height: 1080 },
|
|
2593
|
-
};
|
|
2540
|
+
Standard: { width: 1280, height: 720 }};
|
|
2594
2541
|
class Recorder {
|
|
2595
2542
|
constructor(app) {
|
|
2596
2543
|
this.app = app;
|
|
@@ -3752,29 +3699,76 @@ class Nodes {
|
|
|
3752
3699
|
}
|
|
3753
3700
|
|
|
3754
3701
|
const iconCache = {};
|
|
3755
|
-
const
|
|
3756
|
-
async function parseUseEl(useElement, mode) {
|
|
3702
|
+
const svgUrlCache = {};
|
|
3703
|
+
async function parseUseEl(useElement, mode, domParser) {
|
|
3757
3704
|
try {
|
|
3758
3705
|
const href = useElement.getAttribute('xlink:href') || useElement.getAttribute('href');
|
|
3759
3706
|
if (!href) {
|
|
3760
3707
|
console.debug('Openreplay: xlink:href or href not found on <use>.');
|
|
3761
3708
|
return;
|
|
3762
3709
|
}
|
|
3763
|
-
|
|
3764
|
-
if
|
|
3765
|
-
|
|
3710
|
+
let [url, symbolId] = href.split('#');
|
|
3711
|
+
// happens if svg spritemap is local, fastest case for us
|
|
3712
|
+
if (!url && symbolId) {
|
|
3713
|
+
const symbol = document.querySelector(href);
|
|
3714
|
+
if (symbol) {
|
|
3715
|
+
const inlineSvg = `
|
|
3716
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="${symbol.getAttribute('viewBox') || '0 0 24 24'}">
|
|
3717
|
+
${symbol.innerHTML}
|
|
3718
|
+
</svg>
|
|
3719
|
+
`.trim();
|
|
3720
|
+
iconCache[symbolId] = inlineSvg;
|
|
3721
|
+
return inlineSvg;
|
|
3722
|
+
}
|
|
3723
|
+
else {
|
|
3724
|
+
console.warn('Openreplay: Sprite symbol not found in the document.');
|
|
3725
|
+
return;
|
|
3726
|
+
}
|
|
3727
|
+
}
|
|
3728
|
+
if (!url && !symbolId) {
|
|
3729
|
+
console.warn('Openreplay: Invalid xlink:href or href found on <use>.');
|
|
3766
3730
|
return;
|
|
3767
3731
|
}
|
|
3768
3732
|
if (iconCache[symbolId]) {
|
|
3769
3733
|
return iconCache[symbolId];
|
|
3770
3734
|
}
|
|
3771
|
-
|
|
3772
|
-
|
|
3773
|
-
|
|
3735
|
+
let svgDoc;
|
|
3736
|
+
if (svgUrlCache[url]) {
|
|
3737
|
+
if (svgUrlCache[url] === 1) {
|
|
3738
|
+
await new Promise((resolve) => {
|
|
3739
|
+
let tries = 0;
|
|
3740
|
+
const interval = setInterval(() => {
|
|
3741
|
+
if (tries > 100) {
|
|
3742
|
+
clearInterval(interval);
|
|
3743
|
+
resolve(false);
|
|
3744
|
+
}
|
|
3745
|
+
if (svgUrlCache[url] !== 1) {
|
|
3746
|
+
svgDoc = svgUrlCache[url];
|
|
3747
|
+
clearInterval(interval);
|
|
3748
|
+
resolve(true);
|
|
3749
|
+
}
|
|
3750
|
+
else {
|
|
3751
|
+
tries++;
|
|
3752
|
+
}
|
|
3753
|
+
}, 100);
|
|
3754
|
+
});
|
|
3755
|
+
}
|
|
3756
|
+
else {
|
|
3757
|
+
svgDoc = svgUrlCache[url] ?? `<svg xmlns="http://www.w3.org/2000/svg"></svg>`;
|
|
3758
|
+
}
|
|
3759
|
+
}
|
|
3760
|
+
else {
|
|
3761
|
+
svgUrlCache[url] = 1;
|
|
3762
|
+
const response = await fetch(url);
|
|
3763
|
+
const svgText = await response.text();
|
|
3764
|
+
svgDoc = domParser.parseFromString(svgText, 'image/svg+xml');
|
|
3765
|
+
svgUrlCache[url] = svgDoc;
|
|
3766
|
+
}
|
|
3767
|
+
// @ts-ignore
|
|
3774
3768
|
const symbol = svgDoc.getElementById(symbolId);
|
|
3775
3769
|
if (!symbol) {
|
|
3776
3770
|
console.debug('Openreplay: Symbol not found in SVG.');
|
|
3777
|
-
return;
|
|
3771
|
+
return '';
|
|
3778
3772
|
}
|
|
3779
3773
|
if (mode === 'inline') ;
|
|
3780
3774
|
if (mode === 'svgtext') {
|
|
@@ -3829,7 +3823,7 @@ var RecentsType;
|
|
|
3829
3823
|
RecentsType[RecentsType["Changed"] = 2] = "Changed";
|
|
3830
3824
|
})(RecentsType || (RecentsType = {}));
|
|
3831
3825
|
class Observer {
|
|
3832
|
-
constructor(app, isTopContext = false) {
|
|
3826
|
+
constructor(app, isTopContext = false, options = { disableSprites: false }) {
|
|
3833
3827
|
this.app = app;
|
|
3834
3828
|
this.isTopContext = isTopContext;
|
|
3835
3829
|
this.commited = [];
|
|
@@ -3837,6 +3831,9 @@ class Observer {
|
|
|
3837
3831
|
this.indexes = [];
|
|
3838
3832
|
this.attributesMap = new Map();
|
|
3839
3833
|
this.textSet = new Set();
|
|
3834
|
+
this.disableSprites = false;
|
|
3835
|
+
this.domParser = new DOMParser();
|
|
3836
|
+
this.disableSprites = options.disableSprites;
|
|
3840
3837
|
this.observer = createMutationObserver(this.app.safe((mutations) => {
|
|
3841
3838
|
for (const mutation of mutations) {
|
|
3842
3839
|
// mutations order is sequential
|
|
@@ -3931,8 +3928,8 @@ class Observer {
|
|
|
3931
3928
|
if (value === null) {
|
|
3932
3929
|
this.app.send(RemoveNodeAttribute(id, name));
|
|
3933
3930
|
}
|
|
3934
|
-
if (isUseElement(node) && name === 'href') {
|
|
3935
|
-
parseUseEl(node, 'svgtext')
|
|
3931
|
+
if (isUseElement(node) && name === 'href' && !this.disableSprites) {
|
|
3932
|
+
parseUseEl(node, 'svgtext', this.domParser)
|
|
3936
3933
|
.then((svgData) => {
|
|
3937
3934
|
if (svgData) {
|
|
3938
3935
|
this.app.send(SetNodeAttribute(id, name, `_$OPENREPLAY_SPRITE$_${svgData}`));
|
|
@@ -4285,7 +4282,11 @@ class IFrameOffsets {
|
|
|
4285
4282
|
const attachShadowNativeFn = IN_BROWSER ? Element.prototype.attachShadow : () => new ShadowRoot();
|
|
4286
4283
|
class TopObserver extends Observer {
|
|
4287
4284
|
constructor(params) {
|
|
4288
|
-
|
|
4285
|
+
const opts = Object.assign({
|
|
4286
|
+
captureIFrames: true,
|
|
4287
|
+
disableSprites: false,
|
|
4288
|
+
}, params.options);
|
|
4289
|
+
super(params.app, true, opts);
|
|
4289
4290
|
this.iframeOffsets = new IFrameOffsets();
|
|
4290
4291
|
this.contextCallbacks = [];
|
|
4291
4292
|
// Attached once per Tracker instance
|
|
@@ -4295,9 +4296,7 @@ class TopObserver extends Observer {
|
|
|
4295
4296
|
this.docObservers = new WeakMap();
|
|
4296
4297
|
this.shadowRootObservers = new WeakMap();
|
|
4297
4298
|
this.app = params.app;
|
|
4298
|
-
this.options =
|
|
4299
|
-
captureIFrames: true,
|
|
4300
|
-
}, params.options);
|
|
4299
|
+
this.options = opts;
|
|
4301
4300
|
// IFrames
|
|
4302
4301
|
this.app.nodes.attachNodeCallback((node) => {
|
|
4303
4302
|
if (hasTag(node, 'iframe') &&
|
|
@@ -4631,10 +4630,6 @@ function wrap(callback, n) {
|
|
|
4631
4630
|
}
|
|
4632
4631
|
};
|
|
4633
4632
|
}
|
|
4634
|
-
/**
|
|
4635
|
-
* Takes a callback and n as number of turn skips
|
|
4636
|
-
* Every tick is 30ms, so attach(cb, 3) will call cb every 90ms
|
|
4637
|
-
* */
|
|
4638
4633
|
class Ticker {
|
|
4639
4634
|
constructor(app) {
|
|
4640
4635
|
this.app = app;
|
|
@@ -4676,7 +4671,7 @@ class Ticker {
|
|
|
4676
4671
|
* this value is injected during build time via rollup
|
|
4677
4672
|
* */
|
|
4678
4673
|
// @ts-ignore
|
|
4679
|
-
const workerBodyFn = "!function(){\"use strict\";class t{constructor(t,s,i,e=10,n=250,h,r){this.onUnauthorised=s,this.onFailure=i,this.MAX_ATTEMPTS_COUNT=e,this.ATTEMPT_TIMEOUT=n,this.onCompress=h,this.pageNo=r,this.attemptsCount=0,this.busy=!1,this.queue=[],this.token=null,this.lastBatchNum=0,this.ingestURL=t+\"/v1/web/i\",this.isCompressing=void 0!==h}getQueueStatus(){return 0===this.queue.length&&!this.busy}authorise(t){this.token=t,this.busy||this.sendNext()}push(t){if(this.busy||!this.token)this.queue.push(t);else if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}}sendNext(){const t=this.queue.shift();if(t)if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}else this.busy=!1}retry(t,s,i){this.attemptsCount>=this.MAX_ATTEMPTS_COUNT?this.onFailure(`Failed to send batch after ${this.attemptsCount} attempts.`):(this.attemptsCount++,setTimeout((()=>this.sendBatch(t,s,i)),this.ATTEMPT_TIMEOUT*this.attemptsCount))}sendBatch(t,s,i){var e;const n=null==i?void 0:i.toString().replace(/^([^_]+)_([^_]+).*/,\"$1_$2_$3\");this.busy=!0;const h={Authorization:`Bearer ${this.token}`};if(s&&(h[\"Content-Encoding\"]=\"gzip\"),null===this.token)return void setTimeout((()=>{this.sendBatch(t,s,`${null!=i?i:\"noBatchNum\"}_newToken`)}),500);const r=new AbortController,a=setTimeout((()=>{r.abort()}),3e4);fetch(`${this.ingestURL}?batch=${null!==(e=this.pageNo)&&void 0!==e?e:\"noPageNum\"}_${null!=n?n:\"noBatchNum\"}`,{body:t,method:\"POST\",headers:h,keepalive:t.length<65536,signal:r.signal}).then((e=>{if(clearTimeout(a),401===e.status)return this.busy=!1,void this.onUnauthorised();e.status>=400?this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_network:${e.status}`):(this.attemptsCount=0,this.sendNext())})).catch((e=>{clearTimeout(a),console.warn(\"OpenReplay:\",e),this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_reject:${e.message}`)}))}sendCompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!0,s)}sendUncompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}clean(){this.sendNext(),setTimeout((()=>{this.token=null,this.queue.length=0}),10)}}const s=\"function\"==typeof TextEncoder?new TextEncoder:{encode(t){const s=t.length,i=new Uint8Array(3*s);let e=-1;for(let n=0,h=0,r=0;r!==s;){if(n=t.charCodeAt(r),r+=1,n>=55296&&n<=56319){if(r===s){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;break}if(h=t.charCodeAt(r),!(h>=56320&&h<=57343)){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;continue}if(n=1024*(n-55296)+h-56320+65536,r+=1,n>65535){i[e+=1]=240|n>>>18,i[e+=1]=128|n>>>12&63,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n;continue}}n<=127?i[e+=1]=0|n:n<=2047?(i[e+=1]=192|n>>>6,i[e+=1]=128|63&n):(i[e+=1]=224|n>>>12,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n)}return i.subarray(0,e+1)}};class i{constructor(t){this.size=t,this.offset=0,this.checkpointOffset=0,this.data=new Uint8Array(t)}getCurrentOffset(){return this.offset}checkpoint(){this.checkpointOffset=this.offset}get isEmpty(){return 0===this.offset}skip(t){return this.offset+=t,this.offset<=this.size}set(t,s){this.data.set(t,s)}boolean(t){return this.data[this.offset++]=+t,this.offset<=this.size}uint(t){for((t<0||t>Number.MAX_SAFE_INTEGER)&&(t=0);t>=128;)this.data[this.offset++]=t%256|128,t=Math.floor(t/128);return this.data[this.offset++]=t,this.offset<=this.size}int(t){return t=Math.round(t),this.uint(t>=0?2*t:-2*t-1)}string(t){const i=s.encode(t),e=i.byteLength;return!(!this.uint(e)||this.offset+e>this.size)&&(this.data.set(i,this.offset),this.offset+=e,!0)}reset(){this.offset=0,this.checkpointOffset=0}flush(){const t=this.data.slice(0,this.checkpointOffset);return this.reset(),t}}class e extends i{encode(t){switch(t[0]){case 0:case 11:case 114:case 115:return this.uint(t[1]);case 4:case 44:case 47:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3]);case 5:case 20:case 38:case 70:case 75:case 76:case 77:case 82:return this.uint(t[1])&&this.uint(t[2]);case 6:return this.int(t[1])&&this.int(t[2]);case 7:return!0;case 8:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.string(t[4])&&this.boolean(t[5]);case 9:case 10:case 24:case 35:case 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 52:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17:case 34:case 50:case 54:return this.uint(t[1])&&this.string(t[2]);case 16:return this.uint(t[1])&&this.int(t[2])&&this.int(t[3]);case 18:return this.uint(t[1])&&this.string(t[2])&&this.int(t[3]);case 19:return this.uint(t[1])&&this.boolean(t[2]);case 21:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8]);case 22:case 27:case 30:case 41:case 45:case 46:case 43:case 63:case 64:case 79:case 124:return this.string(t[1])&&this.string(t[2]);case 23:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 28:case 29:case 42:case 117:case 118:return this.string(t[1]);case 37:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3]);case 39:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7]);case 40:return this.string(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 48:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.int(t[5]);case 49:return this.int(t[1])&&this.int(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 53:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8]);case 55:return this.boolean(t[1]);case 57:case 60:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 58:case 120:return this.int(t[1]);case 59:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6])&&this.string(t[7]);case 67:case 73:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 68:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6]);case 69:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 78:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 81:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.int(t[4])&&this.string(t[5]);case 83:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 84:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6]);case 112:return this.uint(t[1])&&this.string(t[2])&&this.boolean(t[3])&&this.string(t[4])&&this.int(t[5])&&this.int(t[6]);case 113:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3]);case 116:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8])&&this.uint(t[9])&&this.boolean(t[10]);case 119:return this.string(t[1])&&this.uint(t[2]);case 121:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 122:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 123:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])}}}class n{constructor(t,s,i,n,h,r){this.pageNo=t,this.timestamp=s,this.url=i,this.onBatch=n,this.tabId=h,this.onOfflineEnd=r,this.nextIndex=0,this.beaconSize=2e5,this.encoder=new e(this.beaconSize),this.sizeBuffer=new Uint8Array(3),this.isEmpty=!0,this.beaconSizeLimit=1e6,this.prepare()}writeType(t){return this.encoder.uint(t[0])}writeFields(t){return this.encoder.encode(t)}writeSizeAt(t,s){for(let s=0;s<3;s++)this.sizeBuffer[s]=t>>8*s;this.encoder.set(this.sizeBuffer,s)}prepare(){if(!this.encoder.isEmpty)return;const t=[81,1,this.pageNo,this.nextIndex,this.timestamp,this.url],s=[118,this.tabId];this.writeType(t),this.writeFields(t),this.writeWithSize(s),this.isEmpty=!0}writeWithSize(t){const s=this.encoder;if(!this.writeType(t)||!s.skip(3))return!1;const i=s.getCurrentOffset(),e=this.writeFields(t);if(e){const e=s.getCurrentOffset()-i;if(e>16777215)return console.warn(\"OpenReplay: max message size overflow.\"),!1;this.writeSizeAt(e,i-3),s.checkpoint(),this.isEmpty=this.isEmpty&&0===t[0],this.nextIndex++}return e}setBeaconSizeLimit(t){this.beaconSizeLimit=t}writeMessage(t){if(\"q_end\"===t[0])return this.finaliseBatch(),this.onOfflineEnd();0===t[0]&&(this.timestamp=t[1]),122===t[0]&&(this.url=t[1]),this.writeWithSize(t)||(this.finaliseBatch(),this.writeWithSize(t)||(this.encoder=new e(this.beaconSizeLimit),this.prepare(),this.writeWithSize(t)?this.finaliseBatch():console.warn(\"OpenReplay: beacon size overflow. Skipping large message.\",t,this),this.encoder=new e(this.beaconSize),this.prepare()))}finaliseBatch(){if(this.isEmpty)return;const t=this.encoder.flush();this.onBatch(t),this.prepare()}clean(){this.encoder.reset()}}var h;!function(t){t[t.NotActive=0]=\"NotActive\",t[t.Starting=1]=\"Starting\",t[t.Stopping=2]=\"Stopping\",t[t.Active=3]=\"Active\",t[t.Stopped=4]=\"Stopped\"}(h||(h={}));let r=null,a=null,u=h.NotActive;function o(){a&&a.finaliseBatch()}function c(){return new Promise((t=>{u=h.Stopping,null!==p&&(clearInterval(p),p=null),a&&(a.clean(),a=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{u=h.NotActive,t(null)}),100)}))}function l(){[h.Stopped,h.Stopping].includes(u)||(postMessage(\"a_stop\"),c().then((()=>{postMessage(\"a_start\")})))}let g,p=null;self.onmessage=({data:s})=>{if(null!=s)if(\"heartbeat_q\"!==s){if(\"stop\"===s)return o(),void c().then((()=>{u=h.Stopped}));if(\"forceFlushBatch\"!==s){if(!Array.isArray(s)){if(\"compressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Compressed batch.\"),void l();s.batch&&r.sendCompressed(s.batch)}if(\"uncompressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Uncompressed batch.\"),void l();s.batch&&r.sendUncompressed(s.batch)}return\"start\"===s.type?(u=h.Starting,r=new t(s.ingestPoint,(()=>{l()}),(t=>{!function(t){postMessage({type:\"failure\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\"compress\",batch:t},[t.buffer])}),s.pageNo),a=new n(s.pageNo,s.timestamp,s.url,(t=>{r&&r.push(t)}),s.tabId,(()=>postMessage({type:\"queue_empty\"}))),null===p&&(p=setInterval(o,1e4)),u=h.Active):\"auth\"===s.type?r?a?(r.authorise(s.token),void(s.beaconSizeLimit&&a.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\"OR WebWorker: writer not initialised. Received auth.\"),void l()):(console.debug(\"OR WebWorker: sender not initialised. Received auth.\"),void l()):void 0}if(a){const t=a;s.forEach((s=>{55===s[0]&&(s[1]?g=setTimeout((()=>l()),18e5):clearTimeout(g)),t.writeMessage(s)}))}else postMessage(\"not_init\"),l()}else o()}else setTimeout((()=>{postMessage(\"heartbeat_a\")}),50);else o()}}();\n";
|
|
4674
|
+
const workerBodyFn = "!function(){\"use strict\";class t{constructor(t,s,i,e=10,n=250,h,r){this.onUnauthorised=s,this.onFailure=i,this.MAX_ATTEMPTS_COUNT=e,this.ATTEMPT_TIMEOUT=n,this.onCompress=h,this.pageNo=r,this.attemptsCount=0,this.busy=!1,this.queue=[],this.token=null,this.lastBatchNum=0,this.ingestURL=t+\"/v1/web/i\",this.isCompressing=void 0!==h}getQueueStatus(){return 0===this.queue.length&&!this.busy}authorise(t){this.token=t,this.busy||this.sendNext()}push(t){if(this.busy||!this.token)this.queue.push(t);else if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}}sendNext(){const t=this.queue.shift();if(t)if(this.busy=!0,this.isCompressing&&this.onCompress)this.onCompress(t);else{const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}else this.busy=!1}retry(t,s,i){this.attemptsCount>=this.MAX_ATTEMPTS_COUNT?this.onFailure(`Failed to send batch after ${this.attemptsCount} attempts.`):(this.attemptsCount++,setTimeout((()=>this.sendBatch(t,s,i)),this.ATTEMPT_TIMEOUT*this.attemptsCount))}sendBatch(t,s,i){var e;const n=null==i?void 0:i.toString().replace(/^([^_]+)_([^_]+).*/,\"$1_$2_$3\");this.busy=!0;const h={Authorization:`Bearer ${this.token}`};s&&(h[\"Content-Encoding\"]=\"gzip\"),null!==this.token?fetch(`${this.ingestURL}?batch=${null!==(e=this.pageNo)&&void 0!==e?e:\"noPageNum\"}_${null!=n?n:\"noBatchNum\"}`,{body:t,method:\"POST\",headers:h,keepalive:t.length<65536}).then((e=>{if(401===e.status)return this.busy=!1,void this.onUnauthorised();e.status>=400?this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_network:${e.status}`):(this.attemptsCount=0,this.sendNext())})).catch((e=>{console.warn(\"OpenReplay:\",e),this.retry(t,s,`${null!=i?i:\"noBatchNum\"}_reject:${e.message}`)})):setTimeout((()=>{this.sendBatch(t,s,`${null!=i?i:\"noBatchNum\"}_newToken`)}),500)}sendCompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!0,s)}sendUncompressed(t){const s=++this.lastBatchNum;this.sendBatch(t,!1,s)}clean(){this.sendNext(),setTimeout((()=>{this.token=null,this.queue.length=0}),10)}}const s=\"function\"==typeof TextEncoder?new TextEncoder:{encode(t){const s=t.length,i=new Uint8Array(3*s);let e=-1;for(let n=0,h=0,r=0;r!==s;){if(n=t.charCodeAt(r),r+=1,n>=55296&&n<=56319){if(r===s){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;break}if(h=t.charCodeAt(r),!(h>=56320&&h<=57343)){i[e+=1]=239,i[e+=1]=191,i[e+=1]=189;continue}if(n=1024*(n-55296)+h-56320+65536,r+=1,n>65535){i[e+=1]=240|n>>>18,i[e+=1]=128|n>>>12&63,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n;continue}}n<=127?i[e+=1]=0|n:n<=2047?(i[e+=1]=192|n>>>6,i[e+=1]=128|63&n):(i[e+=1]=224|n>>>12,i[e+=1]=128|n>>>6&63,i[e+=1]=128|63&n)}return i.subarray(0,e+1)}};class i{constructor(t){this.size=t,this.offset=0,this.checkpointOffset=0,this.data=new Uint8Array(t)}getCurrentOffset(){return this.offset}checkpoint(){this.checkpointOffset=this.offset}get isEmpty(){return 0===this.offset}skip(t){return this.offset+=t,this.offset<=this.size}set(t,s){this.data.set(t,s)}boolean(t){return this.data[this.offset++]=+t,this.offset<=this.size}uint(t){for((t<0||t>Number.MAX_SAFE_INTEGER)&&(t=0);t>=128;)this.data[this.offset++]=t%256|128,t=Math.floor(t/128);return this.data[this.offset++]=t,this.offset<=this.size}int(t){return t=Math.round(t),this.uint(t>=0?2*t:-2*t-1)}string(t){const i=s.encode(t),e=i.byteLength;return!(!this.uint(e)||this.offset+e>this.size)&&(this.data.set(i,this.offset),this.offset+=e,!0)}reset(){this.offset=0,this.checkpointOffset=0}flush(){const t=this.data.slice(0,this.checkpointOffset);return this.reset(),t}}class e extends i{encode(t){switch(t[0]){case 0:case 11:case 114:case 115:return this.uint(t[1]);case 4:case 44:case 47:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3]);case 5:case 20:case 70:case 75:case 76:case 77:case 82:return this.uint(t[1])&&this.uint(t[2]);case 6:return this.int(t[1])&&this.int(t[2]);case 7:return!0;case 8:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.string(t[4])&&this.boolean(t[5]);case 9:case 10:case 24:case 35:case 51:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3]);case 12:case 52:case 61:case 71:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3]);case 13:case 14:case 17:case 34:case 50:case 54:return this.uint(t[1])&&this.string(t[2]);case 16:return this.uint(t[1])&&this.int(t[2])&&this.int(t[3]);case 18:return this.uint(t[1])&&this.string(t[2])&&this.int(t[3]);case 19:return this.uint(t[1])&&this.boolean(t[2]);case 21:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8]);case 22:case 27:case 30:case 41:case 45:case 46:case 43:case 63:case 64:case 79:case 124:return this.string(t[1])&&this.string(t[2]);case 23:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 28:case 29:case 42:case 117:case 118:return this.string(t[1]);case 40:return this.string(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 48:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.int(t[5]);case 49:return this.int(t[1])&&this.int(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 53:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8]);case 55:return this.boolean(t[1]);case 57:case 60:return this.uint(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 58:case 120:return this.int(t[1]);case 68:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])&&this.uint(t[6]);case 69:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3])&&this.string(t[4]);case 73:return this.uint(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 78:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4]);case 81:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.int(t[4])&&this.string(t[5]);case 83:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.string(t[5])&&this.uint(t[6])&&this.uint(t[7])&&this.uint(t[8])&&this.uint(t[9]);case 84:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.uint(t[4])&&this.string(t[5])&&this.string(t[6]);case 112:return this.uint(t[1])&&this.string(t[2])&&this.boolean(t[3])&&this.string(t[4])&&this.int(t[5])&&this.int(t[6]);case 113:return this.uint(t[1])&&this.uint(t[2])&&this.string(t[3]);case 116:return this.uint(t[1])&&this.uint(t[2])&&this.uint(t[3])&&this.uint(t[4])&&this.uint(t[5])&&this.uint(t[6])&&this.string(t[7])&&this.string(t[8])&&this.uint(t[9])&&this.boolean(t[10]);case 119:return this.string(t[1])&&this.uint(t[2]);case 121:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.uint(t[4]);case 122:return this.string(t[1])&&this.string(t[2])&&this.uint(t[3])&&this.string(t[4]);case 123:return this.string(t[1])&&this.string(t[2])&&this.string(t[3])&&this.string(t[4])&&this.uint(t[5])}}}class n{constructor(t,s,i,n,h,r){this.pageNo=t,this.timestamp=s,this.url=i,this.onBatch=n,this.tabId=h,this.onOfflineEnd=r,this.nextIndex=0,this.beaconSize=2e5,this.encoder=new e(this.beaconSize),this.sizeBuffer=new Uint8Array(3),this.isEmpty=!0,this.beaconSizeLimit=1e6,this.prepare()}writeType(t){return this.encoder.uint(t[0])}writeFields(t){return this.encoder.encode(t)}writeSizeAt(t,s){for(let s=0;s<3;s++)this.sizeBuffer[s]=t>>8*s;this.encoder.set(this.sizeBuffer,s)}prepare(){if(!this.encoder.isEmpty)return;const t=[81,1,this.pageNo,this.nextIndex,this.timestamp,this.url],s=[118,this.tabId];this.writeType(t),this.writeFields(t),this.writeWithSize(s),this.isEmpty=!0}writeWithSize(t){const s=this.encoder;if(!this.writeType(t)||!s.skip(3))return!1;const i=s.getCurrentOffset(),e=this.writeFields(t);if(e){const e=s.getCurrentOffset()-i;if(e>16777215)return console.warn(\"OpenReplay: max message size overflow.\"),!1;this.writeSizeAt(e,i-3),s.checkpoint(),this.isEmpty=this.isEmpty&&0===t[0],this.nextIndex++}return e}setBeaconSizeLimit(t){this.beaconSizeLimit=t}writeMessage(t){if(\"q_end\"===t[0])return this.finaliseBatch(),this.onOfflineEnd();0===t[0]&&(this.timestamp=t[1]),122===t[0]&&(this.url=t[1]),this.writeWithSize(t)||(this.finaliseBatch(),this.writeWithSize(t)||(this.encoder=new e(this.beaconSizeLimit),this.prepare(),this.writeWithSize(t)?this.finaliseBatch():console.warn(\"OpenReplay: beacon size overflow. Skipping large message.\",t,this),this.encoder=new e(this.beaconSize),this.prepare()))}finaliseBatch(){if(this.isEmpty)return;const t=this.encoder.flush();this.onBatch(t),this.prepare()}clean(){this.encoder.reset()}}var h;!function(t){t[t.NotActive=0]=\"NotActive\",t[t.Starting=1]=\"Starting\",t[t.Stopping=2]=\"Stopping\",t[t.Active=3]=\"Active\",t[t.Stopped=4]=\"Stopped\"}(h||(h={}));let r=null,a=null,u=h.NotActive;function o(){a&&a.finaliseBatch()}function c(){return new Promise((t=>{u=h.Stopping,null!==p&&(clearInterval(p),p=null),a&&(a.clean(),a=null),r&&(r.clean(),setTimeout((()=>{r=null}),20)),setTimeout((()=>{u=h.NotActive,t(null)}),100)}))}function l(){[h.Stopped,h.Stopping].includes(u)||(postMessage(\"a_stop\"),c().then((()=>{postMessage(\"a_start\")})))}let g,p=null;self.onmessage=({data:s})=>{if(null!=s){if(\"stop\"===s)return o(),void c().then((()=>{u=h.Stopped}));if(\"forceFlushBatch\"!==s){if(!Array.isArray(s)){if(\"compressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Compressed batch.\"),void l();s.batch&&r.sendCompressed(s.batch)}if(\"uncompressed\"===s.type){if(!r)return console.debug(\"OR WebWorker: sender not initialised. Uncompressed batch.\"),void l();s.batch&&r.sendUncompressed(s.batch)}return\"start\"===s.type?(u=h.Starting,r=new t(s.ingestPoint,(()=>{l()}),(t=>{!function(t){postMessage({type:\"failure\",reason:t}),c()}(t)}),s.connAttemptCount,s.connAttemptGap,(t=>{postMessage({type:\"compress\",batch:t},[t.buffer])}),s.pageNo),a=new n(s.pageNo,s.timestamp,s.url,(t=>{r&&r.push(t)}),s.tabId,(()=>postMessage({type:\"queue_empty\"}))),null===p&&(p=setInterval(o,1e4)),u=h.Active):\"auth\"===s.type?r?a?(r.authorise(s.token),void(s.beaconSizeLimit&&a.setBeaconSizeLimit(s.beaconSizeLimit))):(console.debug(\"OR WebWorker: writer not initialised. Received auth.\"),void l()):(console.debug(\"OR WebWorker: sender not initialised. Received auth.\"),void l()):void 0}if(a){const t=a;s.forEach((s=>{55===s[0]&&(s[1]?g=setTimeout((()=>l()),18e5):clearTimeout(g)),t.writeMessage(s)}))}else postMessage(\"not_init\"),l()}else o()}else o()}}();\n";
|
|
4680
4675
|
const CANCELED = 'canceled';
|
|
4681
4676
|
const uxtStorageKey = 'or_uxt_active';
|
|
4682
4677
|
const bufferStorageKey = 'or_buffer_1';
|
|
@@ -4730,7 +4725,7 @@ class App {
|
|
|
4730
4725
|
this.stopCallbacks = [];
|
|
4731
4726
|
this.commitCallbacks = [];
|
|
4732
4727
|
this.activityState = ActivityState.NotActive;
|
|
4733
|
-
this.version = '16.0.
|
|
4728
|
+
this.version = '16.0.3-beta-1'; // TODO: version compatability check inside each plugin.
|
|
4734
4729
|
this.socketMode = false;
|
|
4735
4730
|
this.compressionThreshold = 24 * 1000;
|
|
4736
4731
|
this.bc = null;
|
|
@@ -4962,8 +4957,6 @@ class App {
|
|
|
4962
4957
|
}
|
|
4963
4958
|
};
|
|
4964
4959
|
this.startTimeout = null;
|
|
4965
|
-
this.heartbeatInterval = null;
|
|
4966
|
-
this.restartTimeout = null;
|
|
4967
4960
|
this.coldStartCommitN = 0;
|
|
4968
4961
|
this.delay = 0;
|
|
4969
4962
|
this.attachStartCallback = (cb, useSafe = false) => {
|
|
@@ -5065,6 +5058,7 @@ class App {
|
|
|
5065
5058
|
fixedCanvasScaling: false,
|
|
5066
5059
|
disableCanvas: false,
|
|
5067
5060
|
captureIFrames: true,
|
|
5061
|
+
disableSprites: false,
|
|
5068
5062
|
obscureTextEmails: true,
|
|
5069
5063
|
obscureTextNumbers: false,
|
|
5070
5064
|
crossdomain: {
|
|
@@ -5243,17 +5237,6 @@ class App {
|
|
|
5243
5237
|
this.worker.postMessage(null);
|
|
5244
5238
|
}
|
|
5245
5239
|
};
|
|
5246
|
-
this.heartbeatInterval = setInterval(() => {
|
|
5247
|
-
if (this.worker) {
|
|
5248
|
-
this.restartTimeout = setTimeout(() => {
|
|
5249
|
-
this.stop();
|
|
5250
|
-
this.waitStatus(ActivityState.NotActive).then(() => {
|
|
5251
|
-
void this.start(this.prevOpts);
|
|
5252
|
-
});
|
|
5253
|
-
}, 10000);
|
|
5254
|
-
this.worker.postMessage('heartbeat_q');
|
|
5255
|
-
}
|
|
5256
|
-
}, 20000);
|
|
5257
5240
|
// keep better tactics, discard others?
|
|
5258
5241
|
this.attachEventListener(window, 'beforeunload', alertWorker, false);
|
|
5259
5242
|
this.attachEventListener(document.body, 'mouseleave', alertWorker, false, false);
|
|
@@ -5284,12 +5267,6 @@ class App {
|
|
|
5284
5267
|
else if (data === 'not_init') {
|
|
5285
5268
|
this.debug.warn('OR WebWorker: writer not initialised. Restarting tracker');
|
|
5286
5269
|
}
|
|
5287
|
-
else if (data === 'heartbeat_a') {
|
|
5288
|
-
if (this.restartTimeout) {
|
|
5289
|
-
clearTimeout(this.restartTimeout);
|
|
5290
|
-
this.restartTimeout = null;
|
|
5291
|
-
}
|
|
5292
|
-
}
|
|
5293
5270
|
else if (data.type === 'failure') {
|
|
5294
5271
|
this.stop(false);
|
|
5295
5272
|
this.debug.error('worker_failed', data.reason);
|
|
@@ -5361,8 +5338,7 @@ class App {
|
|
|
5361
5338
|
* */
|
|
5362
5339
|
_nCommit() {
|
|
5363
5340
|
if (this.socketMode) {
|
|
5364
|
-
this.messages.unshift(TabData(this.session.getTabId()));
|
|
5365
|
-
this.messages.unshift(Timestamp(this.timestamp()));
|
|
5341
|
+
this.messages.unshift(Timestamp(this.timestamp()), TabData(this.session.getTabId()));
|
|
5366
5342
|
this.commitCallbacks.forEach((cb) => cb(this.messages));
|
|
5367
5343
|
this.messages.length = 0;
|
|
5368
5344
|
return;
|
|
@@ -5381,8 +5357,7 @@ class App {
|
|
|
5381
5357
|
}
|
|
5382
5358
|
try {
|
|
5383
5359
|
requestIdleCb(() => {
|
|
5384
|
-
this.messages.unshift(TabData(this.session.getTabId()));
|
|
5385
|
-
this.messages.unshift(Timestamp(this.timestamp()));
|
|
5360
|
+
this.messages.unshift(Timestamp(this.timestamp()), TabData(this.session.getTabId()));
|
|
5386
5361
|
this.worker?.postMessage(this.messages);
|
|
5387
5362
|
this.commitCallbacks.forEach((cb) => cb(this.messages));
|
|
5388
5363
|
this.messages.length = 0;
|
|
@@ -5405,20 +5380,13 @@ class App {
|
|
|
5405
5380
|
_cStartCommit() {
|
|
5406
5381
|
this.coldStartCommitN += 1;
|
|
5407
5382
|
if (this.coldStartCommitN === 2) {
|
|
5408
|
-
this.
|
|
5409
|
-
this.bufferedMessages1.push(
|
|
5410
|
-
this.bufferedMessages2.push(
|
|
5411
|
-
this.bufferedMessages2.push(TabData(this.session.getTabId()));
|
|
5383
|
+
const payload = [Timestamp(this.timestamp()), TabData(this.session.getTabId())];
|
|
5384
|
+
this.bufferedMessages1.push(...payload);
|
|
5385
|
+
this.bufferedMessages2.push(...payload);
|
|
5412
5386
|
this.coldStartCommitN = 0;
|
|
5413
5387
|
}
|
|
5414
5388
|
}
|
|
5415
|
-
/**
|
|
5416
|
-
* called every 30ms via this.ticker
|
|
5417
|
-
* */
|
|
5418
5389
|
commit() {
|
|
5419
|
-
if (this.activityState === ActivityState.NotActive) {
|
|
5420
|
-
return;
|
|
5421
|
-
}
|
|
5422
5390
|
if (this.activityState === ActivityState.ColdStart) {
|
|
5423
5391
|
this._cStartCommit();
|
|
5424
5392
|
}
|
|
@@ -5441,6 +5409,10 @@ class App {
|
|
|
5441
5409
|
}
|
|
5442
5410
|
catch (e) {
|
|
5443
5411
|
app._debug('safe_fn_call', e);
|
|
5412
|
+
// time: this.timestamp(),
|
|
5413
|
+
// name: e.name,
|
|
5414
|
+
// message: e.message,
|
|
5415
|
+
// stack: e.stack
|
|
5444
5416
|
}
|
|
5445
5417
|
}; // TODO: correct typing
|
|
5446
5418
|
}
|
|
@@ -7269,7 +7241,7 @@ function roundNumber(num) {
|
|
|
7269
7241
|
return Math.round(num * 1e4);
|
|
7270
7242
|
}
|
|
7271
7243
|
|
|
7272
|
-
var e,o=-1,a=function(e){addEventListener("pageshow",(function(n){n.persisted&&(o=n.timeStamp,e(n));})
|
|
7244
|
+
var e,o=-1,a=function(e){addEventListener("pageshow",(function(n){n.persisted&&(o=n.timeStamp,e(n));}),true);},c=function(){var e=self.performance&&performance.getEntriesByType&&performance.getEntriesByType("navigation")[0];if(e&&e.responseStart>0&&e.responseStart<performance.now())return e},u=function(){var e=c();return e&&e.activationStart||0},f=function(e,n){var t=c(),r="navigate";o>=0?r="back-forward-cache":t&&(document.prerendering||u()>0?r="prerender":document.wasDiscarded?r="restore":t.type&&(r=t.type.replace(/_/g,"-")));return {name:e,value:void 0===n?-1:n,rating:"good",delta:0,entries:[],id:"v4-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12),navigationType:r}},s=function(e,n,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){var r=new PerformanceObserver((function(e){Promise.resolve().then((function(){n(e.getEntries());}));}));return r.observe(Object.assign({type:e,buffered:!0},t||{})),r}}catch(e){}},d=function(e,n,t,r){var i,o;return function(a){n.value>=0&&(a||r)&&((o=n.value-(i||0))||void 0===i)&&(i=n.value,n.delta=o,n.rating=function(e,n){return e>n[1]?"poor":e>n[0]?"needs-improvement":"good"}(n.value,t),e(n));}},l=function(e){requestAnimationFrame((function(){return requestAnimationFrame((function(){return e()}))}));},p=function(e){document.addEventListener("visibilitychange",(function(){"hidden"===document.visibilityState&&e();}));},v=function(e){var n=false;return function(){n||(e(),n=true);}},m=-1,h=function(){return "hidden"!==document.visibilityState||document.prerendering?1/0:0},g=function(e){"hidden"===document.visibilityState&&m>-1&&(m="visibilitychange"===e.type?e.timeStamp:0,T());},y=function(){addEventListener("visibilitychange",g,true),addEventListener("prerenderingchange",g,true);},T=function(){removeEventListener("visibilitychange",g,true),removeEventListener("prerenderingchange",g,true);},E=function(){return m<0&&(m=h(),y(),a((function(){setTimeout((function(){m=h(),y();}),0);}))),{get firstHiddenTime(){return m}}},C=function(e){document.prerendering?addEventListener("prerenderingchange",(function(){return e()}),true):e();},b=[1800,3e3],S=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("FCP"),o=s("paint",(function(e){e.forEach((function(e){"first-contentful-paint"===e.name&&(o.disconnect(),e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries.push(e),t(true)));}));}));o&&(t=d(e,i,b,n.reportAllChanges),a((function(r){i=f("FCP"),t=d(e,i,b,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,t(true);}));})));}));},L=[.1,.25],w=function(e,n){n=n||{},S(v((function(){var t,r=f("CLS",0),i=0,o=[],c=function(e){e.forEach((function(e){if(!e.hadRecentInput){var n=o[0],t=o[o.length-1];i&&e.startTime-t.startTime<1e3&&e.startTime-n.startTime<5e3?(i+=e.value,o.push(e)):(i=e.value,o=[e]);}})),i>r.value&&(r.value=i,r.entries=o,t());},u=s("layout-shift",c);u&&(t=d(e,r,L,n.reportAllChanges),p((function(){c(u.takeRecords()),t(true);})),a((function(){i=0,r=f("CLS",0),t=d(e,r,L,n.reportAllChanges),l((function(){return t()}));})),setTimeout(t,0));})));},A=0,I=1/0,P=0,M=function(e){e.forEach((function(e){e.interactionId&&(I=Math.min(I,e.interactionId),P=Math.max(P,e.interactionId),A=P?(P-I)/7+1:0);}));},k=function(){return e?A:performance.interactionCount||0},F=function(){"interactionCount"in performance||e||(e=s("event",M,{type:"event",buffered:true,durationThreshold:0}));},D=[],x=new Map,R=0,B=function(){var e=Math.min(D.length-1,Math.floor((k()-R)/50));return D[e]},H=[],q=function(e){if(H.forEach((function(n){return n(e)})),e.interactionId||"first-input"===e.entryType){var n=D[D.length-1],t=x.get(e.interactionId);if(t||D.length<10||e.duration>n.latency){if(t)e.duration>t.latency?(t.entries=[e],t.latency=e.duration):e.duration===t.latency&&e.startTime===t.entries[0].startTime&&t.entries.push(e);else {var r={id:e.interactionId,latency:e.duration,entries:[e]};x.set(r.id,r),D.push(r);}D.sort((function(e,n){return n.latency-e.latency})),D.length>10&&D.splice(10).forEach((function(e){return x.delete(e.id)}));}}},O=function(e){var n=self.requestIdleCallback||self.setTimeout,t=-1;return e=v(e),"hidden"===document.visibilityState?e():(t=n(e),p(e)),t},N=[200,500],j=function(e,n){"PerformanceEventTiming"in self&&"interactionId"in PerformanceEventTiming.prototype&&(n=n||{},C((function(){var t;F();var r,i=f("INP"),o=function(e){O((function(){e.forEach(q);var n=B();n&&n.latency!==i.value&&(i.value=n.latency,i.entries=n.entries,r());}));},c=s("event",o,{durationThreshold:null!==(t=n.durationThreshold)&&void 0!==t?t:40});r=d(e,i,N,n.reportAllChanges),c&&(c.observe({type:"first-input",buffered:true}),p((function(){o(c.takeRecords()),r(true);})),a((function(){R=k(),D.length=0,x.clear(),i=f("INP"),r=d(e,i,N,n.reportAllChanges);})));})));},_=[2500,4e3],z={},G=function(e,n){n=n||{},C((function(){var t,r=E(),i=f("LCP"),o=function(e){n.reportAllChanges||(e=e.slice(-1)),e.forEach((function(e){e.startTime<r.firstHiddenTime&&(i.value=Math.max(e.startTime-u(),0),i.entries=[e],t());}));},c=s("largest-contentful-paint",o);if(c){t=d(e,i,_,n.reportAllChanges);var m=v((function(){z[i.id]||(o(c.takeRecords()),c.disconnect(),z[i.id]=true,t(true));}));["keydown","click"].forEach((function(e){addEventListener(e,(function(){return O(m)}),{once:true,capture:true});})),p(m),a((function(r){i=f("LCP"),t=d(e,i,_,n.reportAllChanges),l((function(){i.value=performance.now()-r.timeStamp,z[i.id]=true,t(true);}));}));}}));},J=[800,1800],K=function e(n){document.prerendering?C((function(){return e(n)})):"complete"!==document.readyState?addEventListener("load",(function(){return e(n)}),true):setTimeout(n,0);},Q=function(e,n){n=n||{};var t=f("TTFB"),r=d(e,t,J,n.reportAllChanges);K((function(){var i=c();i&&(t.value=Math.max(i.responseStart-u(),0),t.entries=[i],r(true),a((function(){t=f("TTFB",0),(r=d(e,t,J,n.reportAllChanges))(true);})));}));};
|
|
7273
7245
|
|
|
7274
7246
|
function getPaintBlocks(resources) {
|
|
7275
7247
|
const paintBlocks = [];
|
|
@@ -9213,7 +9185,7 @@ class API {
|
|
|
9213
9185
|
this.signalStartIssue = (reason, missingApi) => {
|
|
9214
9186
|
const doNotTrack = this.checkDoNotTrack();
|
|
9215
9187
|
console.log("Tracker couldn't start due to:", JSON.stringify({
|
|
9216
|
-
trackerVersion: '16.0.
|
|
9188
|
+
trackerVersion: '16.0.3-beta-1',
|
|
9217
9189
|
projectKey: this.options.projectKey,
|
|
9218
9190
|
doNotTrack,
|
|
9219
9191
|
reason: missingApi.length ? `missing api: ${missingApi.join(',')}` : reason,
|