From 73b44da6360a9674b761588e199c0f3b642aa197 Mon Sep 17 00:00:00 2001 From: himanshu8443 Date: Tue, 2 Sep 2025 14:00:22 +0530 Subject: [PATCH] fix: multistream --- dist/autoEmbed/meta.js | 2 +- dist/autoEmbed/stream.js | 2 +- providers/autoEmbed/meta.ts | 7 +- providers/autoEmbed/stream.ts | 322 +++++++++++++++++++--------------- 4 files changed, 187 insertions(+), 146 deletions(-) diff --git a/dist/autoEmbed/meta.js b/dist/autoEmbed/meta.js index 5cee539..0f41849 100644 --- a/dist/autoEmbed/meta.js +++ b/dist/autoEmbed/meta.js @@ -1 +1 @@ -"use strict";var __awaiter=this&&this.__awaiter||function(thisArg,_arguments,P,generator){return new(P||(P=Promise))(function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){var value;result.done?resolve(result.value):(value=result.value,value instanceof P?value:new P(function(resolve){resolve(value)})).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getMeta=void 0;const getMeta=function(_a){return __awaiter(this,arguments,void 0,function*({link:link,providerContext:providerContext}){var _b,_c,_d,_e,_f,_g,_h,_j,_k,_l,_m;const axios=providerContext.axios;try{const data=(yield axios.get(link)).data,meta={title:"",synopsis:"",image:"",imdbId:(null===(_b=null==data?void 0:data.meta)||void 0===_b?void 0:_b.imdb_id)||"",type:(null===(_c=null==data?void 0:data.meta)||void 0===_c?void 0:_c.type)||"movie"},links=[];let directLinks=[],season=new Map;if("series"===meta.type){null===(_e=null===(_d=null==data?void 0:data.meta)||void 0===_d?void 0:_d.videos)||void 0===_e||_e.map(video=>{var _a,_b,_c,_d,_e,_f,_g,_h;(null==video?void 0:video.season)<=0||(season.has(null==video?void 0:video.season)||season.set(null==video?void 0:video.season,[]),season.get(null==video?void 0:video.season).push({title:"Episode "+(null==video?void 0:video.episode),type:"series",link:JSON.stringify({title:null===(_a=null==data?void 0:data.meta)||void 0===_a?void 0:_a.name,imdbId:null===(_b=null==data?void 0:data.meta)||void 0===_b?void 0:_b.imdb_id,season:null===(_c=null==video?void 0:video.id)||void 0===_c?void 0:_c.split(":")[1],episode:null===(_d=null==video?void 0:video.id)||void 0===_d?void 0:_d.split(":")[2],type:null===(_e=null==data?void 0:data.meta)||void 0===_e?void 0:_e.type,tmdbId:(null===(_g=null===(_f=null==data?void 0:data.meta)||void 0===_f?void 0:_f.moviedb_id)||void 0===_g?void 0:_g.toString())||"",year:null===(_h=null==data?void 0:data.meta)||void 0===_h?void 0:_h.year})}))});const keys=Array.from(season.keys());keys.sort(),keys.map(key=>{directLinks=season.get(key),links.push({title:`Season ${key}`,directLinks:directLinks})})}else links.push({title:null===(_f=null==data?void 0:data.meta)||void 0===_f?void 0:_f.name,directLinks:[{title:"Movie",type:"movie",link:JSON.stringify({title:null===(_g=null==data?void 0:data.meta)||void 0===_g?void 0:_g.name,imdbId:null===(_h=null==data?void 0:data.meta)||void 0===_h?void 0:_h.imdb_id,season:"",episode:"",type:null===(_j=null==data?void 0:data.meta)||void 0===_j?void 0:_j.type,tmdbId:(null===(_l=null===(_k=null==data?void 0:data.meta)||void 0===_k?void 0:_k.moviedb_id)||void 0===_l?void 0:_l.toString())||"",year:null===(_m=null==data?void 0:data.meta)||void 0===_m?void 0:_m.year})}]});return Object.assign(Object.assign({},meta),{linkList:links})}catch(err){return{title:"",synopsis:"",image:"",imdbId:"",type:"movie",linkList:[]}}})};exports.getMeta=getMeta; \ No newline at end of file +"use strict";var __awaiter=this&&this.__awaiter||function(thisArg,_arguments,P,generator){return new(P||(P=Promise))(function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){var value;result.done?resolve(result.value):(value=result.value,value instanceof P?value:new P(function(resolve){resolve(value)})).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getMeta=void 0;const getMeta=function(_a){return __awaiter(this,arguments,void 0,function*({link:link,providerContext:providerContext}){var _b,_c,_d,_e,_f,_g,_h,_j,_k,_l,_m,_o,_p,_q;const axios=providerContext.axios;try{const data=(yield axios.get(link)).data,meta={title:(null===(_b=null==data?void 0:data.meta)||void 0===_b?void 0:_b.name)||"",synopsis:(null===(_c=null==data?void 0:data.meta)||void 0===_c?void 0:_c.description)||"",image:(null===(_d=null==data?void 0:data.meta)||void 0===_d?void 0:_d.background)||"",imdbId:(null===(_e=null==data?void 0:data.meta)||void 0===_e?void 0:_e.imdb_id)||"",type:(null===(_f=null==data?void 0:data.meta)||void 0===_f?void 0:_f.type)||"movie"},links=[];let directLinks=[],season=new Map;if("series"===meta.type){null===(_h=null===(_g=null==data?void 0:data.meta)||void 0===_g?void 0:_g.videos)||void 0===_h||_h.map(video=>{var _a,_b,_c,_d,_e,_f,_g,_h;(null==video?void 0:video.season)<=0||(season.has(null==video?void 0:video.season)||season.set(null==video?void 0:video.season,[]),season.get(null==video?void 0:video.season).push({title:"Episode "+(null==video?void 0:video.episode),type:"series",link:JSON.stringify({title:null===(_a=null==data?void 0:data.meta)||void 0===_a?void 0:_a.name,imdbId:null===(_b=null==data?void 0:data.meta)||void 0===_b?void 0:_b.imdb_id,season:null===(_c=null==video?void 0:video.id)||void 0===_c?void 0:_c.split(":")[1],episode:null===(_d=null==video?void 0:video.id)||void 0===_d?void 0:_d.split(":")[2],type:null===(_e=null==data?void 0:data.meta)||void 0===_e?void 0:_e.type,tmdbId:(null===(_g=null===(_f=null==data?void 0:data.meta)||void 0===_f?void 0:_f.moviedb_id)||void 0===_g?void 0:_g.toString())||"",year:null===(_h=null==data?void 0:data.meta)||void 0===_h?void 0:_h.year})}))});const keys=Array.from(season.keys());keys.sort(),keys.map(key=>{directLinks=season.get(key),links.push({title:`Season ${key}`,directLinks:directLinks})})}else links.push({title:null===(_j=null==data?void 0:data.meta)||void 0===_j?void 0:_j.name,directLinks:[{title:"Movie",type:"movie",link:JSON.stringify({title:null===(_k=null==data?void 0:data.meta)||void 0===_k?void 0:_k.name,imdbId:null===(_l=null==data?void 0:data.meta)||void 0===_l?void 0:_l.imdb_id,season:"",episode:"",type:null===(_m=null==data?void 0:data.meta)||void 0===_m?void 0:_m.type,tmdbId:(null===(_p=null===(_o=null==data?void 0:data.meta)||void 0===_o?void 0:_o.moviedb_id)||void 0===_p?void 0:_p.toString())||"",year:null===(_q=null==data?void 0:data.meta)||void 0===_q?void 0:_q.year})}]});return Object.assign(Object.assign({},meta),{linkList:links})}catch(err){return{title:"",synopsis:"",image:"",imdbId:"",type:"movie",linkList:[]}}})};exports.getMeta=getMeta; \ No newline at end of file diff --git a/dist/autoEmbed/stream.js b/dist/autoEmbed/stream.js index e6366c8..a5c7782 100644 --- a/dist/autoEmbed/stream.js +++ b/dist/autoEmbed/stream.js @@ -1 +1 @@ -"use strict";var __awaiter=this&&this.__awaiter||function(thisArg,_arguments,P,generator){return new(P||(P=Promise))(function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){var value;result.done?resolve(result.value):(value=result.value,value instanceof P?value:new P(function(resolve){resolve(value)})).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getStream=void 0,exports.getRiveStream=getRiveStream;const getStream=_a=>__awaiter(void 0,[_a],void 0,function*({link:id,type:type,providerContext:providerContext}){try{const streams=[],{imdbId:imdbId,season:season,episode:episode,title:title,tmdbId:tmdbId,year:year}=JSON.parse(id);return yield getRiveStream(tmdbId,episode,season,type,streams,providerContext),streams}catch(err){return[]}});function getRiveStream(tmdId,episode,season,type,Streams,providerContext){return __awaiter(this,void 0,void 0,function*(){const secret=generateSecretKey(Number(tmdId)),baseUrl=yield providerContext.getBaseUrl("rive"),cors=process.env.CORS_PRXY?process.env.CORS_PRXY+"?url=":"",route="series"===type?`/api/backendfetch?requestID=tvVideoProvider&id=${tmdId}&season=${season}&episode=${episode}&secretKey=${secret}&service=`:`/api/backendfetch?requestID=movieVideoProvider&id=${tmdId}&secretKey=${secret}&service=`,url=cors?cors+encodeURIComponent(baseUrl+route):baseUrl+route;yield Promise.all(["flowcast","shadow","asiacloud","hindicast","anime","animez","guard","curve","hq","ninja","alpha","kaze","zenesis","genesis","zenith","ghost","halo","kinoecho","ee3","volt","putafilme","ophim","kage"].map(server=>__awaiter(this,void 0,void 0,function*(){var _a,_b,_c,_d,_e,_f;try{const res=yield providerContext.axios.get(url+server,{timeout:4e3,headers:providerContext.commonHeaders}),subtitles=[];(null===(_b=null===(_a=res.data)||void 0===_a?void 0:_a.data)||void 0===_b?void 0:_b.captions)&&(null===(_d=null===(_c=res.data)||void 0===_c?void 0:_c.data)||void 0===_d||_d.captions.forEach(sub=>{var _a,_b;subtitles.push({language:(null===(_a=null==sub?void 0:sub.label)||void 0===_a?void 0:_a.slice(0,2))||"Und",uri:null==sub?void 0:sub.file,title:(null==sub?void 0:sub.label)||"Undefined",type:(null===(_b=null==sub?void 0:sub.file)||void 0===_b?void 0:_b.endsWith(".vtt"))?"text/vtt":"application/x-subrip"})})),null===(_f=null===(_e=res.data)||void 0===_e?void 0:_e.data)||void 0===_f||_f.sources.forEach(source=>{Streams.push({server:(null==source?void 0:source.source)+"-"+(null==source?void 0:source.quality),link:null==source?void 0:source.url,type:"hls"===(null==source?void 0:source.format)?"m3u8":"mp4",quality:null==source?void 0:source.quality,subtitles:subtitles})})}catch(e){}})))})}function generateSecretKey(id){const c=["Yhv40uKAZa","nn8YU4yBA","uNeH","ehK","jT0","n5G","99R","MvB1M","DQtPCh","GBRjk4k4I","CzIOoa95UT","BLE8s","GDZlc7","Fz45T","JW6lWn","DE3g4uw0i","18KxmYizv","8ji","JUDdNMnZ","oGpBippPgm","7De8Pg","Zv6","VHT9TVN","bYH6m","aK1","WcWH6jU","Q47YEMi4k","vRD3A","CGOsfJO","BLn8","RgK0drv7l","oPTfGCn3a","MkpMDkttW9","VNI1fPM","XNFi6","6cq","4LvTksXoEI","1rRa2KOZB0","zoOGRb8HT2","mhcXDtvz","NUmexFY2Ur","6BIMdvSZ","Tr0zU2vjRd","QPR","fhOqJR","R9VnFY","xkZ99D6S","umY7E","5Ds8qyDq","Cc6jy09y3","yvU3iR","Bg07zY","GccECglg","VYd","6vOiXqz","7xX","UdRrbEzF","fE6wc","BUd25Rb","lxq5Zum89o"];if(void 0===id)return"rive";try{let fragment,insertPos;const idStr=String(id),encodedHash=btoa(function(input){const str=String(input);let hash=3735928559^str.length;for(let i=0;i>>25)>>>0^char)>>>0}return hash^=hash>>>16,hash=2246822507*hash>>>0,hash^=hash>>>13,hash=3266489909*hash>>>0,(hash^=hash>>>16).toString(16).padStart(8,"0")}(function(input){input=String(input);let hash=0;for(let i=0;i>>0}return hash^=hash>>>13,hash=1540483477*hash>>>0,(hash^=hash>>>15).toString(16).padStart(8,"0")}(idStr)));if(isNaN(Number(id))){const charSum=idStr.split("").reduce((sum,char)=>sum+char.charCodeAt(0),0);fragment=c[charSum%c.length]||btoa(idStr),insertPos=Math.floor(charSum%encodedHash.length/2)}else{const numId=Number(id);fragment=c[numId%c.length]||btoa(idStr),insertPos=Math.floor(numId%encodedHash.length/2)}return encodedHash.slice(0,insertPos)+fragment+encodedHash.slice(insertPos)}catch(error){return"topSecret"}}exports.getStream=getStream; \ No newline at end of file +"use strict";var __awaiter=this&&this.__awaiter||function(thisArg,_arguments,P,generator){return new(P||(P=Promise))(function(resolve,reject){function fulfilled(value){try{step(generator.next(value))}catch(e){reject(e)}}function rejected(value){try{step(generator.throw(value))}catch(e){reject(e)}}function step(result){var value;result.done?resolve(result.value):(value=result.value,value instanceof P?value:new P(function(resolve){resolve(value)})).then(fulfilled,rejected)}step((generator=generator.apply(thisArg,_arguments||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getStream=void 0,exports.getRiveStream=getRiveStream;const getStream=_a=>__awaiter(void 0,[_a],void 0,function*({link:id,type:type,providerContext:providerContext}){var _b,_c,_d,_e,_f,_g,_h;try{const streams=[],payload=(()=>{try{return JSON.parse(id)}catch(_a){return{tmdbId:id}}})(),tmdbId=null!==(_d=null!==(_c=null!==(_b=payload.tmdbId)&&void 0!==_b?_b:payload.id)&&void 0!==_c?_c:payload.tmdId)&&void 0!==_d?_d:"",season=null!==(_e=payload.season)&&void 0!==_e?_e:"",episode=null!==(_f=payload.episode)&&void 0!==_f?_f:"",effectiveType=null!==(_h=null!==(_g=payload.type)&&void 0!==_g?_g:type)&&void 0!==_h?_h:"movie";return yield getRiveStream(String(tmdbId),episode,season,effectiveType,streams,providerContext),streams}catch(err){return[]}});function getRiveStream(tmdId,episode,season,type,Streams,providerContext){return __awaiter(this,void 0,void 0,function*(){if(!tmdId||"undefined"===tmdId)return;const secret=generateSecretKey(tmdId),baseUrl=yield providerContext.getBaseUrl("rive"),cors=process.env.CORS_PRXY?process.env.CORS_PRXY+"?url=":"",route="series"===type?`/api/backendfetch?requestID=tvVideoProvider&id=${tmdId}&season=${season}&episode=${episode}&secretKey=${secret}&service=`:`/api/backendfetch?requestID=movieVideoProvider&id=${tmdId}&secretKey=${secret}&service=`,url=cors?cors+encodeURIComponent(baseUrl+route):baseUrl+route;yield Promise.all(["flowcast","primevids","humpy","loki","asiacloud","shadow","hindicast","animez","aqua","voyager","yggdrasil","putafilme","ophim"].map(server=>__awaiter(this,void 0,void 0,function*(){var _a,_b,_c,_d,_e,_f;try{const res=yield providerContext.axios.get(url+server,{timeout:4e3,headers:providerContext.commonHeaders}),subtitles=[];(null===(_b=null===(_a=res.data)||void 0===_a?void 0:_a.data)||void 0===_b?void 0:_b.captions)&&(null===(_d=null===(_c=res.data)||void 0===_c?void 0:_c.data)||void 0===_d||_d.captions.forEach(sub=>{var _a,_b;subtitles.push({language:(null===(_a=null==sub?void 0:sub.label)||void 0===_a?void 0:_a.slice(0,2))||"Und",uri:null==sub?void 0:sub.file,title:(null==sub?void 0:sub.label)||"Undefined",type:(null===(_b=null==sub?void 0:sub.file)||void 0===_b?void 0:_b.endsWith(".vtt"))?"text/vtt":"application/x-subrip"})})),null===(_f=null===(_e=res.data)||void 0===_e?void 0:_e.data)||void 0===_f||_f.sources.forEach(source=>{Streams.push({server:(null==source?void 0:source.source)+"-"+(null==source?void 0:source.quality),link:null==source?void 0:source.url,type:"hls"===(null==source?void 0:source.format)?"m3u8":"mp4",quality:null==source?void 0:source.quality,subtitles:subtitles})})}catch(e){}})))})}function generateSecretKey(id){const c=["oYRu3JJ5g1C","TRlWJIJXT","RuoyGA0udvsFVXr","Y4s2LNM4y","wHzuSgl0fD","MGLTaSGs","rr0rSBIYfwutV7E","ABJXC9c","W2BuY0yDB9CcK","3yvZP1OJuTM","YDoqbu6zdN0zT","rnNQ2a5OBaMu","eSKa1Uy","QsIV8J472Xa","cPfTgu27","j4mzadQCou9","qHLZbLrZQfB","8U9YP6hrTz4cJNQ","xbAbu4pzFEXz","dhuA9zvdw","k3A1JGmb","eVC3z4COdUNvvzA","dwMmuXnrb","AqpWzY9I1ZmGPR","VGXWUm0JTetmXs","gD4sH3CISTanpTs","d6w8dntV","iL6dvSNqEab4kd","mIB8NFtmPjnX1kM","F4PXdP0Hx3","5Fijua4Z7C","wPGnHJrkYa1Tu4P","pjrfBfTf","vswQDEbM0y64io","LAnpQuk6hR2bEWs","kX8orxNnkK","mRsZ5fjHbC8YuT","JnBr1jr","2twFGU5PgvDmKdP","3wCg6zYtHFjy","gaQSJhixHiy1pa8","pE2cXTP0GPX","xr0ONW3sOnCRdt","QZu43flHFsebX","yrvtqRTOnHo","kvXEs16lgj","AGwT2zpQVHCMb09","M4BxOh3z2JgC","5hbV7briYC7","YfHMsm0","jC9PAPfz34Vgc","ExoJ1tgEXpK","eD8WPA4Lmsyf4W","h7WSlhT7iNOj","RRP61kk","QtY0f1aN","TlatGjcOQjup","MfpeEGbjouYSOa","Zz0Qh8B0pwUkdRT","Y4SkLSQNU","hOk01KFeEVbNRZx","fyf4H8MXazm3oY","Z116B9F2p","GdxNJOnvdz","kqVNNHfP","IO3hhNu","qDdC9Lcllce","Et7lLOg","6ZlQrvfgZu","YXHLeZBF","NH6nAd7y","ARsut59gfK6j0v","jPE2KXiJjnSsjn","qYcG5HOJc3TtxM","C2w06YGj5C","kHx1pT7","2enXfHXw","koFHBiR054aizN","Uj53XTQ92Ntbq7K","QjC5euFYi2AuxWb","njLwvdMejA","NWMzrwTAVZEb","s4sVqC0AyTM5h","pu01jeZ6AoH","SgiOfwx9qkR","grjsLtBNn9eTQg","XABTTaYgihZk2mq","2vlSCZQc3HT27F4","kQZ7VQfEL3TC7P","MEzqVne021W","BLYPZp2SIO","5zDMVoqw4nH","t14S9uLuGKX7Lb5","4McODHAYTyp","EAoxL5UKvMPqjH3","hJpAbqp","tcj63Wpz","hGqEu0LxKkMv46P","u2wNvb8ou19N3","wUKY6Opi1kH"];if(void 0===id)return"rive";try{let t,n;const r=String(id);if(isNaN(Number(id))){const sum=r.split("").reduce((e,ch)=>e+ch.charCodeAt(0),0);t=c[sum%c.length]||btoa(r),n=Math.floor(sum%r.length/2)}else{const num=Number(id);t=c[num%c.length]||btoa(r),n=Math.floor(num%r.length/2)}const i=r.slice(0,n)+t+r.slice(n),innerHash=e=>{e=String(e);let t=0;for(let n=0;n>>0)<>>32-n%5)>>>0;t=(t^i^(r<>>8-n%7)>>>0)>>>0,t=t+(t>>>11^t<<3)>>>0}return t^=t>>>15,t=49842*(65535&t)+((49842*(t>>>16)&65535)<<16)>>>0,t^=t>>>13,t=40503*(65535&t)+((40503*(t>>>16)&65535)<<16)>>>0,t^=t>>>16,t.toString(16).padStart(8,"0")},outerHash=e=>{const t=String(e);let n=(3735928559^t.length)>>>0;for(let idx=0;idx>>25)>>>0^r;n=(60205*(65535&n)>>>0)+(60205*(n>>>16)<<16>>>0)>>>0,n^=n>>>11}return n^=n>>>15,n=49842*(65535&n)+(49842*(n>>>16)<<16)>>>0>>>0,n^=n>>>13,n=40503*(65535&n)+(40503*(n>>>16)<<16)>>>0>>>0,n^=n>>>16,n=10196*(65535&n)+(10196*(n>>>16)<<16)>>>0>>>0,n^=n>>>15,n.toString(16).padStart(8,"0")},o=outerHash(innerHash(i));return btoa(o)}catch(e){return"topSecret"}}exports.getStream=getStream; \ No newline at end of file diff --git a/providers/autoEmbed/meta.ts b/providers/autoEmbed/meta.ts index 72a6032..a6ce16a 100644 --- a/providers/autoEmbed/meta.ts +++ b/providers/autoEmbed/meta.ts @@ -13,9 +13,9 @@ export const getMeta = async function ({ const res = await axios.get(link); const data = res.data; const meta = { - title: "", - synopsis: "", - image: "", + title: data?.meta?.name || "", + synopsis: data?.meta?.description || "", + image: data?.meta?.background || "", imdbId: data?.meta?.imdb_id || "", type: data?.meta?.type || "movie", }; @@ -53,7 +53,6 @@ export const getMeta = async function ({ }); }); } else { - console.log("all meta Mv🔥🔥", meta); links.push({ title: data?.meta?.name as string, directLinks: [ diff --git a/providers/autoEmbed/stream.ts b/providers/autoEmbed/stream.ts index 4e86c47..144bfdb 100644 --- a/providers/autoEmbed/stream.ts +++ b/providers/autoEmbed/stream.ts @@ -11,12 +11,25 @@ export const getStream = async ({ }): Promise => { try { const streams: Stream[] = []; - const { imdbId, season, episode, title, tmdbId, year } = JSON.parse(id); + const payload = (() => { + try { + return JSON.parse(id); + } catch { + return { tmdbId: id }; + } + })(); + + const tmdbId: string | number = + payload.tmdbId ?? payload.id ?? payload.tmdId ?? ""; + const season: string = payload.season ?? ""; + const episode: string = payload.episode ?? ""; + const effectiveType: string = payload.type ?? type ?? "movie"; + await getRiveStream( - tmdbId, + String(tmdbId), episode, season, - type, + effectiveType, streams, providerContext ); @@ -35,31 +48,25 @@ export async function getRiveStream( Streams: Stream[], providerContext: ProviderContext ) { - const secret = generateSecretKey(Number(tmdId)); + if (!tmdId || tmdId === "undefined") { + console.warn("autoEmbed/rive: missing tmdbId in link payload"); + return; + } + const secret = generateSecretKey(tmdId); const servers = [ "flowcast", - "shadow", + "primevids", + "humpy", + "loki", "asiacloud", + "shadow", "hindicast", - "anime", "animez", - "guard", - "curve", - "hq", - "ninja", - "alpha", - "kaze", - "zenesis", - "genesis", - "zenith", - "ghost", - "halo", - "kinoecho", - "ee3", - "volt", + "aqua", + "voyager", + "yggdrasil", "putafilme", "ophim", - "kage", ]; const baseUrl = await providerContext.getBaseUrl("rive"); const cors = process.env.CORS_PRXY ? process.env.CORS_PRXY + "?url=" : ""; @@ -109,142 +116,177 @@ export async function getRiveStream( } function generateSecretKey(id: number | string) { - // Array of secret key fragments - updated array from the new implementation + // Array of secret key fragments from the provided implementation const c = [ - "Yhv40uKAZa", - "nn8YU4yBA", - "uNeH", - "ehK", - "jT0", - "n5G", - "99R", - "MvB1M", - "DQtPCh", - "GBRjk4k4I", - "CzIOoa95UT", - "BLE8s", - "GDZlc7", - "Fz45T", - "JW6lWn", - "DE3g4uw0i", - "18KxmYizv", - "8ji", - "JUDdNMnZ", - "oGpBippPgm", - "7De8Pg", - "Zv6", - "VHT9TVN", - "bYH6m", - "aK1", - "WcWH6jU", - "Q47YEMi4k", - "vRD3A", - "CGOsfJO", - "BLn8", - "RgK0drv7l", - "oPTfGCn3a", - "MkpMDkttW9", - "VNI1fPM", - "XNFi6", - "6cq", - "4LvTksXoEI", - "1rRa2KOZB0", - "zoOGRb8HT2", - "mhcXDtvz", - "NUmexFY2Ur", - "6BIMdvSZ", - "Tr0zU2vjRd", - "QPR", - "fhOqJR", - "R9VnFY", - "xkZ99D6S", - "umY7E", - "5Ds8qyDq", - "Cc6jy09y3", - "yvU3iR", - "Bg07zY", - "GccECglg", - "VYd", - "6vOiXqz", - "7xX", - "UdRrbEzF", - "fE6wc", - "BUd25Rb", - "lxq5Zum89o", + "oYRu3JJ5g1C", + "TRlWJIJXT", + "RuoyGA0udvsFVXr", + "Y4s2LNM4y", + "wHzuSgl0fD", + "MGLTaSGs", + "rr0rSBIYfwutV7E", + "ABJXC9c", + "W2BuY0yDB9CcK", + "3yvZP1OJuTM", + "YDoqbu6zdN0zT", + "rnNQ2a5OBaMu", + "eSKa1Uy", + "QsIV8J472Xa", + "cPfTgu27", + "j4mzadQCou9", + "qHLZbLrZQfB", + "8U9YP6hrTz4cJNQ", + "xbAbu4pzFEXz", + "dhuA9zvdw", + "k3A1JGmb", + "eVC3z4COdUNvvzA", + "dwMmuXnrb", + "AqpWzY9I1ZmGPR", + "VGXWUm0JTetmXs", + "gD4sH3CISTanpTs", + "d6w8dntV", + "iL6dvSNqEab4kd", + "mIB8NFtmPjnX1kM", + "F4PXdP0Hx3", + "5Fijua4Z7C", + "wPGnHJrkYa1Tu4P", + "pjrfBfTf", + "vswQDEbM0y64io", + "LAnpQuk6hR2bEWs", + "kX8orxNnkK", + "mRsZ5fjHbC8YuT", + "JnBr1jr", + "2twFGU5PgvDmKdP", + "3wCg6zYtHFjy", + "gaQSJhixHiy1pa8", + "pE2cXTP0GPX", + "xr0ONW3sOnCRdt", + "QZu43flHFsebX", + "yrvtqRTOnHo", + "kvXEs16lgj", + "AGwT2zpQVHCMb09", + "M4BxOh3z2JgC", + "5hbV7briYC7", + "YfHMsm0", + "jC9PAPfz34Vgc", + "ExoJ1tgEXpK", + "eD8WPA4Lmsyf4W", + "h7WSlhT7iNOj", + "RRP61kk", + "QtY0f1aN", + "TlatGjcOQjup", + "MfpeEGbjouYSOa", + "Zz0Qh8B0pwUkdRT", + "Y4SkLSQNU", + "hOk01KFeEVbNRZx", + "fyf4H8MXazm3oY", + "Z116B9F2p", + "GdxNJOnvdz", + "kqVNNHfP", + "IO3hhNu", + "qDdC9Lcllce", + "Et7lLOg", + "6ZlQrvfgZu", + "YXHLeZBF", + "NH6nAd7y", + "ARsut59gfK6j0v", + "jPE2KXiJjnSsjn", + "qYcG5HOJc3TtxM", + "C2w06YGj5C", + "kHx1pT7", + "2enXfHXw", + "koFHBiR054aizN", + "Uj53XTQ92Ntbq7K", + "QjC5euFYi2AuxWb", + "njLwvdMejA", + "NWMzrwTAVZEb", + "s4sVqC0AyTM5h", + "pu01jeZ6AoH", + "SgiOfwx9qkR", + "grjsLtBNn9eTQg", + "XABTTaYgihZk2mq", + "2vlSCZQc3HT27F4", + "kQZ7VQfEL3TC7P", + "MEzqVne021W", + "BLYPZp2SIO", + "5zDMVoqw4nH", + "t14S9uLuGKX7Lb5", + "4McODHAYTyp", + "EAoxL5UKvMPqjH3", + "hJpAbqp", + "tcj63Wpz", + "hGqEu0LxKkMv46P", + "u2wNvb8ou19N3", + "wUKY6Opi1kH", ]; - // Handle undefined input if (id === undefined) { return "rive"; } try { - let fragment, insertPos; - // Convert input to string - const idStr = String(id); + let t: string, n: number; + const r = String(id); + + if (isNaN(Number(id))) { + const sum = r.split("").reduce((e, ch) => e + ch.charCodeAt(0), 0); + t = c[sum % c.length] || btoa(r); + n = Math.floor((sum % r.length) / 2); + } else { + const num = Number(id); + t = c[num % c.length] || btoa(r); + n = Math.floor((num % r.length) / 2); + } + + const i = r.slice(0, n) + t + r.slice(n); - // Updated string hash function to match the new implementation /* eslint-disable no-bitwise */ - const generateStringHash = function (input: string) { - input = String(input); - let hash = 0; - for (let i = 0; i < input.length; i++) { - const char = input.charCodeAt(i); - hash = - ((char + (hash << 6) + (hash << 16) - hash) ^ (char << i % 5)) >>> 0; + const innerHash = (e: string) => { + e = String(e); + let t = 0 >>> 0; + for (let n = 0; n < e.length; n++) { + const r = e.charCodeAt(n); + const i = + (((t = (r + (t << 6) + (t << 16) - t) >>> 0) << n % 5) | + (t >>> (32 - (n % 5)))) >>> + 0; + t = (t ^ (i ^ (((r << n % 7) | (r >>> (8 - (n % 7)))) >>> 0))) >>> 0; + t = (t + ((t >>> 11) ^ (t << 3))) >>> 0; } - hash ^= hash >>> 13; - hash = (1540483477 * hash) >>> 0; - return (hash ^= hash >>> 15).toString(16).padStart(8, "0"); + t ^= t >>> 15; + t = ((t & 65535) * 49842 + ((((t >>> 16) * 49842) & 65535) << 16)) >>> 0; + t ^= t >>> 13; + t = ((t & 65535) * 40503 + ((((t >>> 16) * 40503) & 65535) << 16)) >>> 0; + t ^= t >>> 16; + return t.toString(16).padStart(8, "0"); }; - // Updated MurmurHash-like function to match the new implementation - const applyMurmurHash = function (input: string) { - const str = String(input); - let hash = 3735928559 ^ str.length; - for (let i = 0; i < str.length; i++) { - let char = str.charCodeAt(i); - char ^= ((i + 31) * 131) & 255; - hash = - (668265261 * - (hash = (((hash << 7) | (hash >>> 25)) >>> 0) ^ char)) >>> - 0; + const outerHash = (e: string) => { + const t = String(e); + let n = (3735928559 ^ t.length) >>> 0; + for (let idx = 0; idx < t.length; idx++) { + let r = t.charCodeAt(idx); + r ^= ((131 * idx + 89) ^ (r << idx % 5)) & 255; + n = (((n << 7) | (n >>> 25)) >>> 0) ^ r; + const i = ((n & 65535) * 60205) >>> 0; + const o = (((n >>> 16) * 60205) << 16) >>> 0; + n = (i + o) >>> 0; + n ^= n >>> 11; } - hash ^= hash >>> 16; - hash = (2246822507 * hash) >>> 0; - hash ^= hash >>> 13; - hash = (3266489909 * hash) >>> 0; - return (hash ^= hash >>> 16).toString(16).padStart(8, "0"); + n ^= n >>> 15; + n = (((n & 65535) * 49842 + (((n >>> 16) * 49842) << 16)) >>> 0) >>> 0; + n ^= n >>> 13; + n = (((n & 65535) * 40503 + (((n >>> 16) * 40503) << 16)) >>> 0) >>> 0; + n ^= n >>> 16; + n = (((n & 65535) * 10196 + (((n >>> 16) * 10196) << 16)) >>> 0) >>> 0; + n ^= n >>> 15; + return n.toString(16).padStart(8, "0"); }; /* eslint-enable no-bitwise */ - // Generate the encoded hash using the new implementation - const encodedHash = btoa(applyMurmurHash(generateStringHash(idStr))); - - // Different handling for non-numeric vs numeric inputs - if (isNaN(Number(id))) { - // For non-numeric inputs, sum the character codes - const charSum = idStr - .split("") - .reduce((sum, char) => sum + char.charCodeAt(0), 0); - // Select array element or fallback to base64 encoded input - fragment = c[charSum % c.length] || btoa(idStr); - // Calculate insertion position - insertPos = Math.floor((charSum % encodedHash.length) / 2); - } else { - // For numeric inputs, use the number directly - const numId = Number(id); - fragment = c[numId % c.length] || btoa(idStr); - // Calculate insertion position - insertPos = Math.floor((numId % encodedHash.length) / 2); - } - - // Construct the final key by inserting the selected value into the base64 string - return ( - encodedHash.slice(0, insertPos) + fragment + encodedHash.slice(insertPos) - ); - } catch (error) { - // Return fallback value if any errors occur + const o = outerHash(innerHash(i)); + return btoa(o); + } catch (e) { return "topSecret"; } }