@vknext/shared 1.6.40 → 1.6.42

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.
@@ -17,6 +17,7 @@ export declare class StreamSaver {
17
17
  private options;
18
18
  private swState;
19
19
  constructor(options: StreamSaverOptions);
20
+ private init;
20
21
  private test;
21
22
  private resolveMitmUrl;
22
23
  private makeIframe;
@@ -24,4 +25,7 @@ export declare class StreamSaver {
24
25
  private makePopup;
25
26
  private loadTransporter;
26
27
  createWriteStream(filename: string, options?: CreateWriteStreamOptions | QueuingStrategy<Uint8Array>, size?: number): WritableStream<Uint8Array>;
28
+ private createBlobStream;
29
+ private createSwStream;
30
+ private setupSwConnection;
27
31
  }
@@ -1 +1 @@
1
- class e{downloadIframe=null;mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;swState="pending";constructor(e){this.options=e,globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread"),"undefined"!=typeof window&&window.addEventListener("message",(e=>{"VKNext/StreamSaver::sw-ready"===e.data?.type&&(this.swState="ready"),"VKNext/StreamSaver::sw-error"===e.data?.type&&(console.warn("[VK Next/StreamSaver] Switching to blob fallback due to SW error"),this.swState="error",this.useBlobFallback=!0,this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null))}));const t=globalThis,a=t.isSecureContext;this.useBlobFallback=/constructor/i.test(String(t.HTMLElement))||!!t.safari||!!t.WebKitPoint;try{new Response(new ReadableStream),(a&&!("serviceWorker"in navigator)||!navigator.serviceWorker)&&(this.useBlobFallback=!0)}catch(e){this.useBlobFallback=!0}this.downloadStrategy=a||"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 a=document.createElement("iframe");a.hidden=!0,a.name=`VK Next Saver | ${t||Math.random()}`,e&&(a.src=e);const r={isPopup:!1,isIframe:!0,loaded:!1,postMessage:(e,t,r)=>{a.contentWindow&&a.contentWindow.postMessage(e,t,r||[])},loadUrl:e=>{a.src=e},addEventListener:(...e)=>a.addEventListener(...e),removeEventListener:(...e)=>a.removeEventListener(...e),dispatchEvent:(...e)=>a.dispatchEvent(...e),remove:()=>a.remove()};return a.addEventListener("load",(()=>{a.src&&"about:blank"!==a.src&&(r.loaded=!0)}),{once:!0}),(document.body||document.documentElement).appendChild(a),r}getDownloadIframe(){if(!this.downloadIframe){const e=document.createElement("iframe");e.hidden=!0,e.style.display="none",e.name="VK Next Saver | downloader",document.body.appendChild(e),this.downloadIframe=e}return this.downloadIframe}makePopup(e){const t=document.createDocumentFragment(),a={frame:window.open(e||"","popup","width=200,height=100"),loaded:!1,isIframe:!1,isPopup:!0,remove(){a.frame&&a.frame.close()},addEventListener(...e){t.addEventListener(...e)},dispatchEvent:(...e)=>t.dispatchEvent(...e),removeEventListener(...e){t.removeEventListener(...e)},postMessage(e,t,r){a.frame&&a.frame.postMessage(e,t,r||[])},loadUrl(e){a.frame&&(a.frame.location.href=e)}},r=e=>{e.source===a.frame&&(a.loaded=!0,window.removeEventListener("message",r),a.dispatchEvent(new Event("load")))};return window.addEventListener("message",r),a}loadTransporter(){this.mitmTransporter||(this.mitmTransporter=window.isSecureContext?this.makeIframe(this.mitm,"transporter"):this.makePopup(this.mitm))}createWriteStream(e,t,a){let r={size:void 0,pathname:void 0,writableStrategy:void 0,readableStrategy:void 0},s=0,o=null,n=null,i=null,l=!1,m=[],d=[],p=!this.useBlobFallback&&"pending"===this.swState;const c=()=>{window.removeEventListener("message",h)},h=e=>{"VKNext/StreamSaver::sw-ready"===e.data?.type?(p=!1,n&&d.forEach((e=>n.port1.postMessage(e))),d=[],c()):"VKNext/StreamSaver::sw-error"===e.data?.type&&(p=!1,d.forEach((e=>m.push(e))),d=[],c())};if(p&&window.addEventListener("message",h),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"),r.size=a,r.writableStrategy=t):r=t||{},!this.useBlobFallback){this.loadTransporter(),n=new MessageChannel;const t=encodeURIComponent(e.replace(/\//g,":")).replace(/['()]/g,escape).replace(/\*/g,"%2A"),a={transferringReadable:this.supportsTransferable,pathname:r.pathname||Math.random().toString().slice(-6)+"/"+t,headers:{"Content-Type":"application/octet-stream; charset=utf-8","Content-Disposition":"attachment; filename*=UTF-8''"+t}};r.size&&(a.headers["Content-Length"]=r.size);const d=[a,"*",[n.port2]];if(this.supportsTransferable&&!p){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,r.writableStrategy,r.readableStrategy);const t=i.readable;n.port1.postMessage({readableStream:t},[t])}n.port1.onmessage=e=>{if(e.data.download){if("navigate"===this.downloadStrategy)this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null),s?location.href=e.data.download:o=e.data.download;else if(this.mitmTransporter&&this.mitmTransporter.isPopup&&(this.mitmTransporter.remove(),this.mitmTransporter=null,"iframe"===this.downloadStrategy&&this.makeIframe(this.mitm,"transporter")),!l){this.getDownloadIframe().src=e.data.download}}else e.data.abort&&(m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null))},this.mitmTransporter.loaded?this.mitmTransporter.postMessage(...d):this.mitmTransporter.addEventListener("load",(()=>{this.mitmTransporter.postMessage(...d)}),{once:!0})}if(!this.useBlobFallback&&i&&i.writable){const e=i.writable.getWriter();return new WritableStream({write:t=>e.write(t),close:async()=>{l=!0,await e.close()},abort:async t=>{l=!0,await e.abort(t)}})}return new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");p?d.push(e):this.useBlobFallback?m.push(e):(n&&n.port1.postMessage(e),s+=e.length,o&&(location.href=o,o=null))},close:()=>{if(l=!0,this.useBlobFallback){const t=new Blob(m,{type:"application/octet-stream; charset=utf-8"}),a=document.createElement("a");a.href=URL.createObjectURL(t),a.download=e,a.click()}else n&&n.port1.postMessage("end")},abort:async()=>{l=!0,p&&await new Promise((e=>{const t=setInterval((()=>{p||(clearInterval(t),e())}),100)})),m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null)}},r.writableStrategy)}}export{e as StreamSaver};
1
+ class e{downloadIframe=null;mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;swState="pending";constructor(e){this.options=e,this.init()}init(){globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread");const e=globalThis,t=e.isSecureContext;this.useBlobFallback=/constructor/i.test(String(e.HTMLElement))||!!e.safari||!!e.WebKitPoint;try{new Response(new ReadableStream),(t&&!("serviceWorker"in navigator)||!navigator.serviceWorker)&&(this.useBlobFallback=!0)}catch(e){this.useBlobFallback=!0}"undefined"!=typeof window&&window.addEventListener("message",(e=>{"VKNext/StreamSaver::sw-ready"===e.data?.type&&(this.swState="ready"),"VKNext/StreamSaver::sw-error"===e.data?.type&&(console.warn("[VK Next/StreamSaver] Switching to blob fallback due to SW error"),this.swState="error",this.useBlobFallback=!0,this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null))})),this.downloadStrategy=t||"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}getDownloadIframe(){if(!this.downloadIframe){const e=document.createElement("iframe");e.hidden=!0,e.style.display="none",e.name="VK Next Saver | downloader",document.body.appendChild(e),this.downloadIframe=e}return this.downloadIframe}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={};return t&&("highWaterMark"in t||"function"==typeof t.size)?(console.warn("[VK Next/StreamSaver] Deprecated pass an object as 2nd argument"),a.size=r,a.writableStrategy=t):a=t||{},this.useBlobFallback?this.createBlobStream(e,a):this.createSwStream(e,a)}createBlobStream(e,t,r=[]){const a=[...r];return new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");a.push(e)},close:()=>{const t=new Blob(a,{type:"application/octet-stream; charset=utf-8"}),r=document.createElement("a");r.href=URL.createObjectURL(t),r.download=e,r.click()},abort:()=>{a.length=0}},t.writableStrategy)}createSwStream(e,t){let r=[],a=!this.useBlobFallback&&"pending"===this.swState,n=null,s={value:!1};const o=async i=>{if("VKNext/StreamSaver::sw-ready"===i.data?.type){if(a=!1,window.removeEventListener("message",o),n=this.setupSwConnection(e,t,s),n.writer)for(const e of r)await n.writer.write(e).catch((()=>{}));else n.channel&&r.forEach((e=>n.channel.port1.postMessage(e)));r=[]}else"VKNext/StreamSaver::sw-error"===i.data?.type&&(a=!1,window.removeEventListener("message",o))};return a&&window.addEventListener("message",o),this.useBlobFallback||"error"===this.swState||(this.loadTransporter(),a||(n=this.setupSwConnection(e,t,s))),new WritableStream({write:async e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");n?.writer?await n.writer.write(e):a||this.useBlobFallback||"error"===this.swState?r.push(e):n?.channel&&n.channel.port1.postMessage(e)},close:async()=>{if(a&&await new Promise((e=>{const t=setInterval((()=>{a||(clearInterval(t),e())}),100)})),s.value=!0,n?.writer)await n.writer.close();else if(this.useBlobFallback||"error"===this.swState){const t=new Blob(r,{type:"application/octet-stream; charset=utf-8"}),a=document.createElement("a");a.href=URL.createObjectURL(t),a.download=e,a.click(),r=[]}else n?.channel&&n.channel.port1.postMessage("end")},abort:async e=>{s.value=!0,r=[],n?.writer?await n.writer.abort(e):n?.channel&&(n.channel.port1.postMessage("abort"),n.channel.port1.onmessage=null,n.channel.port1.close(),n.channel.port2.close())}},t.writableStrategy)}setupSwConnection(e,t,r){const a=new MessageChannel;let n=null,s=0,o=null;const i=encodeURIComponent(e.replace(/\//g,":")).replace(/['()]/g,escape).replace(/\*/g,"%2A"),l={transferringReadable:this.supportsTransferable,pathname:t.pathname||Math.random().toString().slice(-6)+"/"+i,headers:{"Content-Type":"application/octet-stream; charset=utf-8","Content-Disposition":"attachment; filename*=UTF-8''"+i}};t.size&&(l.headers["Content-Length"]=t.size);const m=[l,"*",[a.port2]],c=()=>{this.mitmTransporter&&this.mitmTransporter.postMessage(...m)};if(this.mitmTransporter?.loaded?c():this.mitmTransporter?.addEventListener("load",c,{once:!0}),this.supportsTransferable){const e="iframe"===this.downloadStrategy?void 0:{transform(e,t){s+=e.length,t.enqueue(e),o&&(location.href=o,o=null)},flush(){o&&(location.href=o)}},r=new TransformStream(e,t.writableStrategy,t.readableStrategy),i=r.readable;a.port1.postMessage({readableStream:i},[i]),n=r.writable.getWriter()}return a.port1.onmessage=e=>{if(e.data.download){if("navigate"===this.downloadStrategy)this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null),s?location.href=e.data.download:o=e.data.download;else if(this.mitmTransporter&&this.mitmTransporter.isPopup&&(this.mitmTransporter.remove(),this.mitmTransporter=null,"iframe"===this.downloadStrategy&&this.makeIframe(this.mitm,"transporter")),!r.value){this.getDownloadIframe().src=e.data.download}}else e.data.abort&&(r.value=!0,a&&(a.port1.postMessage("abort"),a.port1.onmessage=null,a.port1.close(),a.port2.close()),n&&n.abort(e.data.reason||"Aborted by Service Worker").catch((()=>{})))},{channel:a,writer:n,streamEnded:r}}}export{e as StreamSaver};
@@ -1 +1 @@
1
- import{attachHlsErrorHandlers as e}from"./utils/attachHlsErrorHandlers.js";import{extractAudioFromMp4 as r}from"./utils/extractAudioFromMp4.js";import{getHlsInstance as o}from"./utils/getHlsInstance.js";import{sendMessage as t}from"./utils/sendMessage.js";const a=async({url:a,filename:n,onProgress:s,forceHls:l})=>{if(!l)try{const e=await t({url:a,filename:n,type:"convertHlsToMp3",onProgress:s});if(e instanceof ReadableStream)return e;if(e instanceof Blob)return e.stream();if("stream"in e)return e.stream();throw new Error("Invalid response")}catch(e){console.error(e)}const i=await o();let c=null,u=null;const f=()=>{c&&(c.stopLoad(),c.destroy())};return new ReadableStream({start(o){c=new i({maxBufferHole:.5,maxBufferLength:600,maxBufferSize:6e7,fragLoadingRetryDelay:500,fragLoadingMaxRetry:20,maxFragLookUpTolerance:.25,enableWorker:!1}),u=new Audio;let t,n=null,l=0,m=0;c.on(i.Events.MANIFEST_PARSED,((e,r)=>{const o=r.levels[0]?.details;o&&(l=o.fragments.length)})),c.on(i.Events.BUFFER_CODECS,((e,r)=>{r.audio&&"audio/mp4"!==r.audio.container||(t=r.audio)})),c.on(i.Events.BUFFER_APPENDING,((e,r)=>{n=r.data})),c.on(i.Events.FRAG_BUFFERED,(async(e,a)=>{if(n){const e=t?r(n):n;o.enqueue(e),m++,n=null}u.currentTime=Math.max(0,a.frag.start+a.frag.duration-.25);try{s&&l>0&&s(m/l)}catch(e){console.error(e)}m>=l&&(f(),o.close())})),e({Hls:i,hlsInstance:c,onError:e=>{o.error(new Error(e||"HLS Error")),f()}}),c.loadSource(a),c.attachMedia(u)},cancel(){f(),u&&(u.pause(),u.remove())}})};export{a as convertTrackToStream};
1
+ import{attachHlsErrorHandlers as e}from"./utils/attachHlsErrorHandlers.js";import{extractAudioFromMp4 as r}from"./utils/extractAudioFromMp4.js";import{getHlsInstance as a}from"./utils/getHlsInstance.js";import{sendMessage as t}from"./utils/sendMessage.js";const o=async({url:o,filename:n,onProgress:s,forceHls:l})=>{if(!l)try{const e=await t({url:o,filename:n,type:"convertHlsToMp3",onProgress:s});if(e instanceof ReadableStream)return e;if(e instanceof Blob)return e.stream();if("stream"in e)return e.stream();throw new Error("Invalid response")}catch(e){console.error(e)}const i=await a();let c=null,u=null;const f=()=>{c&&(c.stopLoad(),c.destroy())};return new ReadableStream({start(a){c=new i({maxBufferHole:.5,maxBufferLength:600,maxBufferSize:6e7,fragLoadingRetryDelay:500,fragLoadingMaxRetry:20,maxFragLookUpTolerance:.25,manifestLoadingRetryDelay:700,manifestLoadingMaxRetry:10,enableWorker:!1}),u=new Audio;let t,n=null,l=0,m=0;c.on(i.Events.MANIFEST_PARSED,((e,r)=>{const a=r.levels[0]?.details;a&&(l=a.fragments.length)})),c.on(i.Events.BUFFER_CODECS,((e,r)=>{r.audio&&"audio/mp4"!==r.audio.container||(t=r.audio)})),c.on(i.Events.BUFFER_APPENDING,((e,r)=>{n=r.data})),c.on(i.Events.FRAG_BUFFERED,(async(e,o)=>{if(n){const e=t?r(n):n;a.enqueue(e),m++,n=null}u.currentTime=Math.max(0,o.frag.start+o.frag.duration-.25);try{s&&l>0&&s(m/l)}catch(e){console.error(e)}m>=l&&(f(),a.close())})),e({Hls:i,hlsInstance:c,onError:e=>{a.error(new Error(e||"HLS Error")),f()}}),c.loadSource(o),c.attachMedia(u)},cancel(){f(),u&&(u.pause(),u.remove())}})};export{o as convertTrackToStream};
@@ -1 +1 @@
1
- const r=({Hls:r,hlsInstance:e,onError:o})=>{let i=!1,n=0;e.on(r.Events.FRAG_BUFFERED,(()=>{n=0})),e.on(r.Events.ERROR,((t,s)=>{if(["bufferFullError"].includes(s.details))o(s.details);else{if(s.type===r.ErrorTypes.NETWORK_ERROR){if(s.response&&(403===s.response.code||404===s.response.code))return void o(`HTTP Error ${s.response.code} (Link expired or invalid)`);if(!navigator.onLine){if(!i){i=!0,e?.stopLoad();const r=()=>{window.removeEventListener("online",r),i=!1,e?.startLoad()};window.addEventListener("online",r)}return}return s.fatal?void e?.startLoad():void 0}if(s.type===r.ErrorTypes.MEDIA_ERROR){if("bufferStalledError"===s.details)return void e?.startLoad();if("fragParsingError"===s.details)return void e?.recoverMediaError();if(n<6)return n++,n>1&&e?.swapAudioCodec(),void e?.recoverMediaError()}s.fatal&&o(s.details)}}))};export{r as attachHlsErrorHandlers};
1
+ const r=({Hls:r,hlsInstance:e,onError:o})=>{let i=!1,t=0;e.on(r.Events.FRAG_BUFFERED,(()=>{t=0})),e.on(r.Events.ERROR,((s,n)=>{if(["bufferFullError"].includes(n.details))o(n.details);else{if(n.type===r.ErrorTypes.NETWORK_ERROR){if(n.response&&(403===n.response.code||404===n.response.code))return void o(`HTTP Error ${n.response.code} (Link expired or invalid)`);if(!navigator.onLine){if(!i){i=!0,e?.stopLoad();const r=()=>{window.removeEventListener("online",r),i=!1,e?.startLoad()};window.addEventListener("online",r)}return}return n.fatal?n.details===r.ErrorDetails.MANIFEST_LOAD_ERROR||n.details===r.ErrorDetails.MANIFEST_LOAD_TIMEOUT?void o(`Manifest Load Error: HTTP ${n.response?.code||"Timeout"}`):void e?.startLoad():void 0}if(n.type===r.ErrorTypes.MEDIA_ERROR){if("bufferStalledError"===n.details)return void e?.startLoad();if("fragParsingError"===n.details)return void e?.recoverMediaError();if(t<6)return t++,t>1&&e?.swapAudioCodec(),void e?.recoverMediaError()}n.fatal&&o(n.details)}}))};export{r as attachHlsErrorHandlers};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vknext/shared",
3
- "version": "1.6.40",
3
+ "version": "1.6.42",
4
4
  "description": "vk next shared",
5
5
  "type": "module",
6
6
  "files": [