@vknext/shared 1.6.3 → 1.6.5

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.
@@ -1 +1 @@
1
- const e=self;e.addEventListener("install",(()=>{e.skipWaiting()})),e.addEventListener("activate",(t=>{t.waitUntil(e.clients.claim())}));const t=new Map;e.addEventListener("message",(n=>{const s=n.data;if("ping"===s)return;const o=s,a=o.url||e.registration.scope+Math.random()+"/"+("string"==typeof o?o:o.filename),r=n.ports[0],i=[null,o,r];o.readableStream?i[0]=o.readableStream:o.transferringReadable?r.onmessage=e=>{r.onmessage=null,i[0]=e.data.readableStream}:i[0]=function(e){return new ReadableStream({start(t){e.onmessage=({data:e})=>{if("end"===e)return t.close();"abort"!==e?t.enqueue(e):t.error("Aborted the download")}},cancel(t){console.log("user aborted",t),e.postMessage({abort:!0})}})}(r),t.set(a,i),r.postMessage({download:a})})),e.addEventListener("fetch",(e=>{const n=e.request.url;if(n.endsWith("/ping"))return e.respondWith(new Response("pong"));const s=t.get(n);if(!s)return null;const[o,a,r]=s;t.delete(n);const i=new Headers({"Content-Type":"application/octet-stream; charset=utf-8","Content-Security-Policy":"default-src 'none'","X-Content-Security-Policy":"default-src 'none'","X-WebKit-CSP":"default-src 'none'","X-XSS-Protection":"1; mode=block","Cross-Origin-Embedder-Policy":"require-corp"}),d=new Headers(a.headers||{});d.has("Content-Length")&&i.set("Content-Length",d.get("Content-Length")),d.has("Content-Disposition")&&i.set("Content-Disposition",d.get("Content-Disposition")),a.size&&(console.warn("Depricated"),i.set("Content-Length",String(a.size)));let l="string"==typeof a?a:a.filename;l&&(console.warn("Depricated"),l=encodeURIComponent(l).replace(/['()]/g,escape).replace(/\*/g,"%2A"),i.set("Content-Disposition","attachment; filename*=UTF-8''"+l)),e.respondWith(new Response(o,{headers:i})),r.postMessage({debug:"Download started"})}));
1
+ const e=self;e.addEventListener("install",(()=>{e.skipWaiting()})),e.addEventListener("activate",(t=>{t.waitUntil(e.clients.claim())}));const t=new Map;e.addEventListener("message",(n=>{const s=n.data;if("ping"===s)return;const o=s,a=o.url||e.registration.scope+Math.random()+"/"+("string"==typeof o?o:o.filename),r=n.ports[0],i=[null,o,r];o.readableStream?i[0]=o.readableStream:o.transferringReadable?r.onmessage=e=>{r.onmessage=null,i[0]=e.data.readableStream}:i[0]=function(e){return new ReadableStream({start(t){e.onmessage=({data:e})=>{if("end"===e)return t.close();"abort"!==e?t.enqueue(e):t.error("Aborted the download")}},cancel(t){console.log("user aborted",t),e.postMessage({abort:!0})}})}(r),t.set(a,i),r.postMessage({download:a,filename:"string"==typeof o?o:o.filename})})),e.addEventListener("fetch",(e=>{const n=e.request.url;if(n.endsWith("/ping"))return e.respondWith(new Response("pong"));const s=t.get(n);if(!s)return null;const[o,a,r]=s;t.delete(n);const i=new Headers({"Content-Type":"application/octet-stream; charset=utf-8","Content-Security-Policy":"default-src 'none'","X-Content-Security-Policy":"default-src 'none'","X-WebKit-CSP":"default-src 'none'","X-XSS-Protection":"1; mode=block","Cross-Origin-Embedder-Policy":"require-corp"}),l=new Headers(a.headers||{});l.has("Content-Length")&&i.set("Content-Length",l.get("Content-Length")),l.has("Content-Disposition")&&i.set("Content-Disposition",l.get("Content-Disposition")),a.size&&(console.warn("Depricated"),i.set("Content-Length",String(a.size)));let d="string"==typeof a?a:a.filename;d&&(console.warn("Depricated"),d=encodeURIComponent(d).replace(/['()]/g,escape).replace(/\*/g,"%2A"),i.set("Content-Disposition","attachment; filename*=UTF-8''"+d)),e.respondWith(new Response(o,{headers:i})),r.postMessage({debug:"Download started"})}));
@@ -1 +1 @@
1
- import"../../utils/parseSvg.js";import{waitHTMLBody as e}from"../../utils/waitHTMLBody.js";class t{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(t){const r=document.createElement("iframe");r.hidden=!0,r.name="vknext-streamSaver-iframe",t&&(r.src=t);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}),e().then((e=>e.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):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;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)),this.makeIframe(e.data.download)):e.data.abort&&(l=[],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 l=[];return!this.useBlobFallback&&i&&i.writable?i.writable:new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");this.useBlobFallback?l.push(e):(n&&n.port1.postMessage(e),s+=e.length,o&&(location.href=o,o=null))},close:()=>{if(this.useBlobFallback){const t=new Blob(l,{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")},abort:()=>{l=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null)}},a.writableStrategy)}}export{t as StreamSaver};
1
+ import"../../utils/parseSvg.js";import{waitHTMLBody as e}from"../../utils/waitHTMLBody.js";class t{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(t,r){const a=document.createElement("iframe");a.hidden=!0,a.name=`VK Next Saver | ${r||Math.random()}`,t&&(a.src=t);const s={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&&(s.loaded=!0)}),{once:!0}),e().then((e=>e.appendChild(a))),s}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;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")),l=this.makeIframe(e.data.download,e.data.filename)):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(...r):this.mitmTransporter.addEventListener("load",(()=>{this.mitmTransporter.postMessage(...r)}),{once:!0})}let m=[];return!this.useBlobFallback&&i&&i.writable?i.writable:new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");this.useBlobFallback?m.push(e):(n&&n.port1.postMessage(e),s+=e.length,o&&(location.href=o,o=null))},close:()=>{if(this.useBlobFallback){const t=new Blob(m,{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");l&&(l.remove(),l=null)},abort:()=>{m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null),l&&(l.remove(),l=null)}},a.writableStrategy)}}export{t as StreamSaver};
@@ -8,4 +8,7 @@ export interface ConvertTrackToBlobOptions {
8
8
  onProgress?: (progress: number) => void;
9
9
  forceHls?: boolean;
10
10
  }
11
- export declare const convertTrackToBlob: ({ url, filename, onProgress, forceHls }: ConvertTrackToBlobOptions) => Promise<Blob>;
11
+ /**
12
+ * @deprecated use convertTrackToStream
13
+ */
14
+ export declare const convertTrackToBlob: ({ url, filename, onProgress, forceHls, }: ConvertTrackToBlobOptions) => Promise<Blob>;
@@ -0,0 +1,10 @@
1
+ export interface ConvertTrackToStreamOptions {
2
+ url: string;
3
+ filename?: string;
4
+ /**
5
+ * @param progress значение от 0 до 1
6
+ */
7
+ onProgress?: (progress: number) => void;
8
+ forceHls?: boolean;
9
+ }
10
+ export declare const convertTrackToStream: ({ url, filename, onProgress, forceHls, }: ConvertTrackToStreamOptions) => Promise<ReadableStream<Uint8Array>>;
@@ -0,0 +1 @@
1
+ import{getHlsInstance as e}from"./utils/getHlsInstance.js";import{sendMessage as r}from"./utils/sendMessage.js";const o=async({url:o,filename:a,onProgress:t,forceHls:n})=>{if(!n)try{const e=await r({url:o,filename:a,type:"convertHlsToMp3",onProgress:t});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 s=await e();let l=null,i=null;const c=()=>{l&&(l.stopLoad(),l.destroy())};return new ReadableStream({start(e){l=new s({maxBufferHole:.5,maxBufferLength:600,maxBufferSize:6e7,fragLoadingRetryDelay:500,fragLoadingMaxRetry:6,maxFragLookUpTolerance:.25,enableWorker:!1}),i=new Audio;let r,a=null,n=0,u=0,d=0;const f=r=>{e.error(new Error(r||"HLS Error")),c()};l.on(s.Events.MANIFEST_PARSED,((e,r)=>{const o=r.levels[0]?.details;o&&(n=o.fragments.length)})),l.on(s.Events.BUFFER_CODECS,((e,o)=>{o.audio&&"audio/mp4"!==o.audio.container||(r=o.audio)})),l.on(s.Events.BUFFER_APPENDING,((e,r)=>{a=r.data})),l.on(s.Events.ERROR,((e,r)=>{if(!["bufferFullError","fragLoadError"].includes(r.details))return r.type==s.ErrorTypes.MEDIA_ERROR&&d<2?(++d>1&&l.swapAudioCodec(),void l.recoverMediaError()):void f(r.details);f(r.details)})),l.on(s.Events.FRAG_BUFFERED,(async(o,s)=>{if(a){const o=r?a.slice(8,a.length):a;e.enqueue(o),u++,a=null}i.currentTime=Math.max(0,s.frag.start+s.frag.duration-.25);try{t&&n>0&&t(u/n)}catch(e){console.error(e)}u>=n&&(c(),e.close())})),l.loadSource(o),l.attachMedia(i)},cancel(){c(),i&&(i.pause(),i.remove())}})};export{o as convertTrackToStream};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vknext/shared",
3
- "version": "1.6.3",
3
+ "version": "1.6.5",
4
4
  "description": "vk next shared",
5
5
  "type": "module",
6
6
  "files": [