@vknext/shared 1.6.15 → 1.6.17
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.
|
@@ -3,12 +3,13 @@ interface MitmConfig {
|
|
|
3
3
|
scope?: string;
|
|
4
4
|
}
|
|
5
5
|
export declare class StreamSaverMitm {
|
|
6
|
-
private
|
|
6
|
+
private _cachedWorker;
|
|
7
7
|
private scope?;
|
|
8
8
|
private swUrl;
|
|
9
9
|
private messages;
|
|
10
10
|
private keepAliveInterval;
|
|
11
11
|
constructor(config: MitmConfig);
|
|
12
|
+
private get controller();
|
|
12
13
|
private init;
|
|
13
14
|
private keepAlive;
|
|
14
15
|
private registerWorker;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
class e{
|
|
1
|
+
class e{_cachedWorker=null;scope;swUrl;messages=[];keepAliveInterval;constructor(e){this.swUrl=e.swUrl,this.scope=e.scope,this.init()}get controller(){return navigator.serviceWorker&&navigator.serviceWorker.controller?navigator.serviceWorker.controller:this._cachedWorker}init(){window.onmessage=e=>this.messages.push(e),window.opener&&window.opener.postMessage("VKNext/StreamSaver::loadedPopup","*"),navigator.serviceWorker&&(navigator.serviceWorker.addEventListener("controllerchange",(()=>{this._cachedWorker=navigator.serviceWorker.controller})),this.registerWorker().then((()=>{window.onmessage=e=>this.onMessage(e),this.messages.forEach((e=>this.onMessage(e))),this.messages=[]}))),this.keepAlive()}keepAlive(){if(this.keepAliveInterval)return;const e=location.href.substring(0,location.href.lastIndexOf("/"))+"/ping";this.keepAliveInterval=window.setInterval((()=>{const r=this.controller;r?r.postMessage("ping"):fetch(e).then((e=>(!e.ok&&this.keepAliveInterval&&clearInterval(this.keepAliveInterval),e.text())))}),1e4)}async registerWorker(){if(navigator.serviceWorker.controller)return void(this._cachedWorker=navigator.serviceWorker.controller);let e=await navigator.serviceWorker.getRegistration(this.swUrl);e&&e.active?.scriptURL===this.swUrl||(e=await navigator.serviceWorker.register(this.swUrl,{scope:this.scope})),this.scope=e.scope;const r=e.active||e.waiting||e.installing;if(this._cachedWorker=r,e.active)return;const t=e.installing||e.waiting;return t?new Promise((r=>{const a=()=>{"activated"===t.state&&(t.removeEventListener("statechange",a),this._cachedWorker=e.active,r())};t.addEventListener("statechange",a)})):void 0}onMessage(e){let{data:r,ports:t,origin:a}=e;if(!t||!t.length)throw new TypeError("[VK Next/StreamSaver] You didn't send a messageChannel");if("object"!=typeof r)throw new TypeError("[VK Next/StreamSaver] You didn't send a object");const s=r;s.origin=a,s.referrer=s.referrer||document.referrer||a,s.headers?new Headers(s.headers):console.warn("[VK Next/StreamSaver] pass `data.headers`..."),"string"==typeof s.filename&&(console.warn("[VK Next/StreamSaver] You shouldn't send `data.filename` anymore..."),s.filename=s.filename.replace(/\//g,":")),s.size&&console.warn("[VK Next/StreamSaver] You shouldn't send `data.size` anymore..."),s.readableStream&&console.warn("[VK Next/StreamSaver] You should send the readableStream in the messageChannel..."),s.pathname||(console.warn("[VK Next/StreamSaver] Please send `data.pathname`"),s.pathname=Math.random().toString().slice(-6)+"/"+s.filename),s.pathname=s.pathname.replace(/^\/+/g,"");let n=a.replace(/(^\w+:|^)\/\//,"");if(s.url=new URL(`${this.scope+n}/${s.pathname}`).toString(),!s.url.startsWith(`${this.scope+n}/`))throw new TypeError("[StreamSaver] bad `data.pathname`");const o=s.readableStream?[t[0],s.readableStream]:[t[0]];s.readableStream||s.transferringReadable||this.keepAlive();const i=this.controller;i?i.postMessage(s,o):console.warn("[VK Next/StreamSaver] No active service worker to handle message")}}export{e as StreamSaverMitm};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
class e{mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;constructor(e){this.options=e,globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread");const t=globalThis,
|
|
1
|
+
class e{mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;constructor(e){this.options=e,globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread");const t=globalThis,r=t.isSecureContext;this.useBlobFallback=/constructor/i.test(String(t.HTMLElement))||!!t.safari||!!t.WebKitPoint;try{new Response(new ReadableStream),r&&!("serviceWorker"in navigator)&&(this.useBlobFallback=!0)}catch(e){this.useBlobFallback=!0}this.downloadStrategy=r||"MozAppearance"in document.documentElement.style?"iframe":"navigate",this.test((()=>{const{readable:e}=new TransformStream,t=new MessageChannel;t.port1.postMessage(e,[e]),t.port1.close(),t.port2.close(),this.supportsTransferable=!0})),this.resolveMitmUrl()}test(e){try{e()}catch(e){}}resolveMitmUrl(){this.options.getMitmUrl().then((e=>{this.mitm=e,this.mitmTransporter&&this.mitmTransporter.loadUrl&&this.mitmTransporter.loadUrl(e)}))}makeIframe(e,t){const r=document.createElement("iframe");r.hidden=!0,r.name=`VK Next Saver | ${t||Math.random()}`,e&&(r.src=e);const a={isPopup:!1,isIframe:!0,loaded:!1,postMessage:(e,t,a)=>{r.contentWindow&&r.contentWindow.postMessage(e,t,a||[])},loadUrl:e=>{r.src=e},addEventListener:(...e)=>r.addEventListener(...e),removeEventListener:(...e)=>r.removeEventListener(...e),dispatchEvent:(...e)=>r.dispatchEvent(...e),remove:()=>r.remove()};return r.addEventListener("load",(()=>{r.src&&"about:blank"!==r.src&&(a.loaded=!0)}),{once:!0}),(document.body||document.documentElement).appendChild(r),a}makePopup(e){const t=document.createDocumentFragment(),r={frame:window.open(e||"","popup","width=200,height=100"),loaded:!1,isIframe:!1,isPopup:!0,remove(){r.frame&&r.frame.close()},addEventListener(...e){t.addEventListener(...e)},dispatchEvent:(...e)=>t.dispatchEvent(...e),removeEventListener(...e){t.removeEventListener(...e)},postMessage(e,t,a){r.frame&&r.frame.postMessage(e,t,a||[])},loadUrl(e){r.frame&&(r.frame.location.href=e)}},a=e=>{e.source===r.frame&&(r.loaded=!0,window.removeEventListener("message",a),r.dispatchEvent(new Event("load")))};return window.addEventListener("message",a),r}loadTransporter(){this.mitmTransporter||(this.mitmTransporter=window.isSecureContext?this.makeIframe(this.mitm,"transporter"):this.makePopup(this.mitm))}createWriteStream(e,t,r){let a={size:void 0,pathname:void 0,writableStrategy:void 0,readableStrategy:void 0},s=0,o=null,n=null,i=null,l=null,m=!1;const p=()=>{l&&(l.remove(),l=null)};if(t&&("highWaterMark"in t||"function"==typeof t.size)?(console.warn("[VK Next/StreamSaver] Deprecated pass an object as 2nd argument when creating a write stream"),a.size=r,a.writableStrategy=t):a=t||{},!this.useBlobFallback){this.loadTransporter(),n=new MessageChannel,e=encodeURIComponent(e.replace(/\//g,":")).replace(/['()]/g,escape).replace(/\*/g,"%2A");const t={transferringReadable:this.supportsTransferable,pathname:a.pathname||Math.random().toString().slice(-6)+"/"+e,headers:{"Content-Type":"application/octet-stream; charset=utf-8","Content-Disposition":"attachment; filename*=UTF-8''"+e}};a.size&&(t.headers["Content-Length"]=a.size);const r=[t,"*",[n.port2]];if(this.supportsTransferable){const e="iframe"===this.downloadStrategy?void 0:{transform(e,t){if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");s+=e.length,t.enqueue(e),o&&(location.href=o,o=null)},flush(){o&&(location.href=o)}};i=new TransformStream(e,a.writableStrategy,a.readableStrategy);const t=i.readable;n.port1.postMessage({readableStream:t},[t])}n.port1.onmessage=e=>{e.data.download?"navigate"===this.downloadStrategy?(this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null),s?location.href=e.data.download:o=e.data.download):(this.mitmTransporter&&this.mitmTransporter.isPopup&&(this.mitmTransporter.remove(),this.mitmTransporter=null,"iframe"===this.downloadStrategy&&this.makeIframe(this.mitm,"transporter")),m||(l=this.makeIframe(e.data.download,e.data.filename))):e.data.abort&&(d=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null))},this.mitmTransporter.loaded?this.mitmTransporter.postMessage(...r):this.mitmTransporter.addEventListener("load",(()=>{this.mitmTransporter.postMessage(...r)}),{once:!0})}let d=[];if(!this.useBlobFallback&&i&&i.writable){const e=i.writable.getWriter();return new WritableStream({write:t=>e.write(t),close:async()=>{m=!0,p(),await e.close()},abort:async t=>{m=!0,p(),await e.abort(t)}})}return new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");this.useBlobFallback?d.push(e):(n&&n.port1.postMessage(e),s+=e.length,o&&(location.href=o,o=null))},close:()=>{if(m=!0,this.useBlobFallback){const t=new Blob(d,{type:"application/octet-stream; charset=utf-8"}),r=document.createElement("a");r.href=URL.createObjectURL(t),r.download=e,r.click()}else n&&n.port1.postMessage("end");p()},abort:()=>{m=!0,d=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null),p()}},a.writableStrategy)}}export{e as StreamSaver};
|