zaileys 4.6.0 → 4.6.2

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/index.mjs CHANGED
@@ -1,25 +1,25 @@
1
- import La,{prepareWAMessageMedia,generateWAMessageFromContent,BufferJSON,makeCacheableSignalKeyStore,DisconnectReason,jidNormalizedUser,jidDecode,fetchLatestBaileysVersion,initAuthCreds,isJidGroup,proto}from'baileys';export{areJidsSameUser,getDevice,isJidBroadcast,isJidGroup,isJidNewsletter,isLidUser,isPnUser,jidDecode,jidEncode,jidNormalizedUser}from'baileys';import be,{readFile}from'node:fs/promises';import {fileURLToPath,pathToFileURL}from'node:url';import hi,{tmpdir}from'node:os';import te from'node:path';import {spawn}from'node:child_process';import {Jimp}from'jimp';import Ei from'node-webpmux';import {randomUUID,randomBytes}from'node:crypto';import {promises,watch}from'node:fs';import Io from'qrcode-terminal';import Lo from'pino';import'stream';import {EventEmitter}from'node:events';var it=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var f=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysBuilderError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var b={OPUS:{CODEC:"libopus",CHANNELS:1,FREQUENCY:48e3,BITRATE:"48k",FORMAT:"ogg"},THUMBNAIL:{SIZE:100,QUALITY:50,TIMESTAMP:"10%"},STICKER:{SIZE:512,MAX_DURATION:6,FPS:10,DEFAULT_QUALITY:60,COMPRESSION_LEVEL:6},MIME:{AUDIO:"audio/",VIDEO:"video/",IMAGE:"image/",GIF:"image/gif",MP4:"video/mp4"}},zt="ffmpeg",xn="ffprobe",On=false,ot="ffmpeg",ue=async(n=false)=>{if(!(n||On)){On=true;try{let e=(await import('@ffmpeg-installer/ffmpeg')).default;if(e?.path){zt=e.path,ot=zt;let t=te.dirname(e.path),r=process.platform==="win32"?";":":",s=process.env.PATH??"";s.split(r).includes(t)||(process.env.PATH=`${t}${r}${s}`);}}catch{}try{let e=(await import('@ffprobe-installer/ffprobe')).default;e?.path&&(xn=e.path);}catch{}}},pe=()=>Date.now().toString(36)+Math.random().toString(36).slice(2,8),L=async n=>{let{fileTypeFromBuffer:e}=await import('file-type');return e(n)},U=class{static generateUniqueId(){return `${Date.now()}_${Math.random().toString(36).slice(2,11)}`}static createTempPath(e,t){return te.join(tmpdir(),`${e}_${this.generateUniqueId()}.${t}`)}static async cleanup(e){await Promise.allSettled(e.map(t=>be.unlink(t)));}static async safeReadFile(e){try{return await be.readFile(e)}catch{throw new Error(`Failed to read file: ${e}`)}}static async safeWriteFile(e,t){try{await be.writeFile(e,t);}catch{throw new Error(`Failed to write file: ${e}`)}}},C=class{static async toBuffer(e){if(Buffer.isBuffer(e))return e;if(e instanceof ArrayBuffer)return Buffer.from(e);if(typeof e=="string")return this.fromString(e);throw new Error("Invalid input type: expected string, Buffer, or ArrayBuffer")}static async fromString(e){if(e.startsWith("http://")||e.startsWith("https://"))return this.fromUrl(e);try{if(await be.stat(e).then(t=>t.isFile()).catch(()=>!1))return await be.readFile(e)}catch{}return Buffer.from(e,"base64")}static async fromUrl(e){try{let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status}: ${t.statusText}`);let r=await t.arrayBuffer();return Buffer.from(r)}catch(t){throw new Error(`Failed to fetch URL: ${t instanceof Error?t.message:String(t)}`)}}static async getExtension(e){let{fileTypeFromBuffer:t}=await import('file-type'),r=await t(e);if(!r)return "tmp";let s=r.ext.toLowerCase();return ["wav","ogg","mp4","gif","jpg","webp","tmp","mp3","png"].includes(s)?s:"tmp"}},R=class{static validate(e,t){if(!e?.mime?.startsWith(t))throw new Error(`Invalid file type: expected ${t}*, got ${e?.mime||"unknown"}`)}static isMedia(e){return e.startsWith(b.MIME.IMAGE)||e.startsWith(b.MIME.VIDEO)}static isAnimated(e){return e===b.MIME.GIF||e.startsWith(b.MIME.VIDEO)}},X=class{static async process(e){return await ue(),new Promise((t,r)=>{let s=["-y","-i",e.input,...e.options,e.output],i=spawn(zt,s,{stdio:"ignore"});i.on("close",async o=>{if(o===0)try{await e.onEnd(),t();}catch(a){r(a);}else try{let a=new Error(`FFmpeg exited with code ${o}`);await e.onError(a),r(a);}catch(a){r(a);}}),i.on("error",async o=>{try{await e.onError(o);}finally{r(o);}});})}static async getDuration(e){return new Promise((t,r)=>{let s=spawn(xn,["-v","error","-show_entries","format=duration","-of","default=noprint_wrappers=1:nokey=1",e]),i="";s.stdout.on("data",o=>i+=o.toString()),s.on("close",o=>{o===0?t(parseFloat(i.trim())||0):r(new Error(`ffprobe exited with code ${o}`));}),s.on("error",r);})}};var ui=3e4,Rn="application/octet-stream",Nn=async n=>n.byteLength===0?Rn:(await L(n))?.mime??Rn,Pe=async n=>({buffer:n,mime:await Nn(n),size:n.byteLength}),Ln=async(n,e)=>{let t=new AbortController,r=setTimeout(()=>t.abort(),e);try{let s=await fetch(n,{signal:t.signal});if(!s.ok)throw new f("MEDIA_LOAD_FAILED",`fetch ${n} failed with status ${s.status}`,{cause:s.status});return Buffer.from(await s.arrayBuffer())}catch(s){throw s instanceof f?s:new f("MEDIA_LOAD_FAILED",`fetch ${n} failed: ${s.message}`,{cause:s})}finally{clearTimeout(r);}},_n=async n=>{try{return await readFile(n)}catch(e){throw new f("MEDIA_LOAD_FAILED",`read ${n} failed: ${e.message}`,{cause:e})}},pi=n=>n.startsWith("http://")||n.startsWith("https://"),I=async(n,e)=>{await ue();let t=e?.timeoutMs??ui;return Buffer.isBuffer(n)?Pe(n):n instanceof URL?n.protocol==="file:"?Pe(await _n(fileURLToPath(n))):Pe(await Ln(n.toString(),t)):pi(n)?Pe(await Ln(n,t)):Pe(await _n(n))};var me=async(n,e)=>{let{buffer:t}=await I(n),r={image:t};return e?.caption!==void 0&&(r.caption=e.caption),e?.viewOnce!==void 0&&(r.viewOnce=e.viewOnce),r};var Q=async(n,e)=>{let{buffer:t,mime:r}=await I(n);if(!r.startsWith("video/"))throw new f("INVALID_OPTIONS",`video() expects a video source, got mime ${r}`);let s={video:t};return e?.caption!==void 0&&(s.caption=e.caption),e?.gifPlayback!==void 0&&(s.gifPlayback=e.gifPlayback),e?.viewOnce!==void 0&&(s.viewOnce=e.viewOnce),e?.ptv===true&&(s.ptv=true),s};var Dn=2,Bn=30,mi=async n=>{if(n.type==="image")return me(n.src,n.caption!==void 0?{caption:n.caption}:void 0);if(n.type==="video")return Q(n.src,n.caption!==void 0?{caption:n.caption}:void 0);throw new f("INVALID_OPTIONS",`album() item type must be 'image' or 'video', got ${String(n.type)}`)},Fn=async(n,e,t,r)=>{if(!Array.isArray(t)||t.length<Dn)throw new f("INVALID_OPTIONS",`album() requires a minimum of ${Dn} items`);if(t.length>Bn)throw new f("INVALID_OPTIONS",`album() accepts a maximum of ${Bn} items`);let s=0,i=0;for(let u of t)if(u.type==="image")s+=1;else if(u.type==="video")i+=1;else throw new f("INVALID_OPTIONS",`album() item type must be 'image' or 'video', got ${String(u.type)}`);let o={album:{expectedImageCount:s,expectedVideoCount:i}};r.mentions&&r.mentions.length>0&&(o.mentions=r.mentions),r.mentionAll&&(o.mentionAll=true);let a={};r.quoted&&(a.quoted=r.quoted),r.disappearingSeconds!==void 0&&(a.ephemeralExpiration=r.disappearingSeconds);let c;try{c=await n.sendMessage(e,o,a);}catch(u){throw new f("SEND_FAILED","album parent send rejected",{cause:u})}let d=c?.key;if(!d)throw new f("SEND_FAILED","album parent returned no message key");let l=0;for(let u of t){let w=await mi(u);w.albumParentKey=d;try{await n.sendMessage(e,w);}catch(M){throw new f("SEND_FAILED","album child send rejected",{cause:{parentKey:d,index:l,error:M}})}l+=1;}return d};var j=async(n,e,t,r,s)=>{let i=r.replace(/[^a-z0-9]+/gi,"_").toLowerCase(),o=U.createTempPath(`${i}_in`,e),a=U.createTempPath(`${i}_out`,t);await U.safeWriteFile(o,n);try{let c=typeof s=="function"?await s(o):s;return await X.process({input:o,output:a,options:c,onEnd:async()=>{},onError:async()=>{}}),await U.safeReadFile(a)}catch(c){throw new Error(`${r} failed: ${c instanceof Error?c.message:String(c)}`)}finally{await U.cleanup([o,a]);}};var at=64,Wn=8e3,ee=class{static async toOpus(e){return this.convert(e,"opus")}static async toMp3(e){return this.convert(e,"mp3")}static async convert(e,t="opus"){let r=await C.toBuffer(e);R.validate(await L(r),b.MIME.AUDIO);let s=await C.getExtension(r),i=t==="opus"?["-vn","-c:a","libopus","-b:a","48k","-ac","1","-avoid_negative_ts","make_zero","-map_metadata","-1","-f","ogg"]:["-vn","-c:a","libmp3lame","-b:a","128k","-ac","2","-avoid_negative_ts","make_zero","-map_metadata","-1","-f","mp3"];return j(r,s,t==="opus"?"ogg":"mp3",`${t.toUpperCase()} conversion`,i)}static async waveform(e){let t=await C.toBuffer(e),r=await C.getExtension(t),s=await j(t,r,"tmp","Waveform generation",["-vn","-ac","1","-ar",String(Wn),"-f","s16le"]),i=Math.floor(s.length/2);return {waveform:this.computeWaveform(s),seconds:Math.max(1,Math.round(i/Wn))}}static computeWaveform(e){let t=Math.floor(e.length/2),r=new Uint8Array(at);if(t===0)return r;let s=Math.max(1,Math.floor(t/at)),i=[];for(let a=0;a<at;a++){let c=0,d=0;for(let l=0;l<s;l++){let u=(a*s+l)*2;u+1<e.length&&(c+=Math.abs(e.readInt16LE(u)),d+=1);}i.push(d>0?c/d:0);}let o=Math.max(...i)||1;for(let a=0;a<at;a++)r[a]=Math.floor(i[a]/o*100);return r}};var fi=["-c:v","libx264","-preset","ultrafast","-crf","28","-c:a","aac","-b:a","128k","-movflags","+faststart","-vf","scale=trunc(iw/2)*2:trunc(ih/2)*2","-pix_fmt","yuv420p","-f","mp4"],q=class{static async toMp4(e){let t=await C.toBuffer(e);R.validate(await L(t),b.MIME.VIDEO);let r=await C.getExtension(t);return j(t,r,"mp4","Video re-encoding",fi)}static async thumbnail(e){let t=await C.toBuffer(e);R.validate(await L(t),b.MIME.VIDEO);let r=await C.getExtension(t),s=b.THUMBNAIL.SIZE;return (await j(t,r,"jpg","Thumbnail generation",async o=>{let a=await X.getDuration(o);return ["-ss",Math.max(0,a*.1).toString(),"-vframes","1","-s",`${s}x${s}`]})).toString("base64")}static async duration(e){return X.getDuration(e)}};var fe=null,Un=false;async function gi(){if(Un)return fe;Un=true;let n=e=>{typeof e=="function"&&(fe=e);};try{n(it("sharp"));}catch{fe=null;}if(!fe)try{let e=await import('sharp');n(e.default??e);}catch{fe=null;}return fe}function jn(n,e){let t=new Uint8Array(n*n),r=n/2,s=n/2,i=n/10,o=[[i,i],[n-i,i],[i,n-i],[n-i,n-i]];for(let a=0;a<n;a++)for(let c=0;c<n;c++){let d=false;if(e==="circle"){let l=c-r,u=a-s;d=l*l+u*u<=r*r;}else if(e==="rounded"){let l=c>=i&&c<n-i&&a>=0&&a<n,u=c>=0&&c<n&&a>=i&&a<n-i,w=false;for(let M of o){let v=c-M[0],E=a-M[1];if(v*v+E*E<=i*i){w=true;break}}d=l||u||w;}else if(e==="oval"){let l=(c-r)/(n/2),u=(a-s)/(n/3);d=l*l+u*u<=1;}t[a*n+c]=d?255:0;}return t}var Yt=class{sharp;constructor(e){this.sharp=e;}async thumbnail(e){let t=this.sharp,r=t(e).resize(b.THUMBNAIL.SIZE,b.THUMBNAIL.SIZE,{fit:"cover"});return (await r.metadata()).format==="gif"&&(r=t(e,{pages:1}).resize(b.THUMBNAIL.SIZE,b.THUMBNAIL.SIZE)),(await r.jpeg({quality:b.THUMBNAIL.QUALITY}).toBuffer()).toString("base64")}async resize(e,t,r){return this.sharp(e).resize(t,r,{fit:"cover"}).png().toBuffer()}async toJpeg(e){let t=this.sharp,r=await C.toBuffer(e),s=await t(r).metadata();if(!s.format)throw new Error("Invalid image type: format could not be determined");return s.format==="webp"||s.format==="png"?t(r).jpeg().toBuffer():r}async resizeForSticker(e,t,r="default"){let s=this.sharp,i=b.STICKER.SIZE,o=s(e).resize(i,i,{fit:"contain",background:{r:0,g:0,b:0,alpha:0}});if(r!=="default"){let a=Buffer.from(jn(i,r)),c=s(a,{raw:{width:i,height:i,channels:1}});o=o.joinChannel(await c.png().toBuffer());}return o.webp({quality:t}).toBuffer()}},Zt=class{async thumbnail(e){let t=b.THUMBNAIL.SIZE,r=await Jimp.fromBuffer(e);r.cover({w:t,h:t});let s=await r.getBuffer("image/jpeg",{quality:b.THUMBNAIL.QUALITY});return Buffer.from(s).toString("base64")}async resize(e,t,r){let s=await Jimp.fromBuffer(e);s.cover({w:t,h:r});let i=await s.getBuffer("image/png");return Buffer.from(i)}async toJpeg(e){let t=await C.toBuffer(e);try{let s=await(await Jimp.fromBuffer(t)).getBuffer("image/jpeg");return Buffer.from(s)}catch{return t}}async resizeForSticker(e,t,r="default"){let s=b.STICKER.SIZE,i=await Jimp.fromBuffer(e);if(i.contain({w:s,h:s}),r!=="default"){let c=jn(s,r),d=new Jimp({width:s,height:s,color:255});for(let l=0;l<s;l++)for(let u=0;u<s;u++)c[l*s+u]===255&&d.setPixelColor(4294967295,u,l);i.mask(d);}let o=Buffer.from(await i.getBuffer("image/png")),a=Math.max(1,Math.min(100,t));return j(o,"png","webp","Jimp WebP conversion",["-vcodec","libwebp","-q:v",`${a}`,"-preset","default"])}},Ce=null;async function ct(){if(Ce)return Ce;let n=await gi();return n?Ce=new Yt(n):(console.warn("\x1B[33m%s\x1B[0m","[media-process] Jimp is slow. For faster performance, run: npm install sharp"),Ce=new Zt),Ce}var F=class{static async thumbnail(e){return (await ct()).thumbnail(e)}static async resize(e,t,r){return (await ct()).resize(e,t,r)}static async toJpeg(e){return (await ct()).toJpeg(e)}static async resizeForSticker(e,t,r="default"){return (await ct()).resizeForSticker(e,t,r)}};var ge=null,Kn=false,dt=null,Jn=false;async function $n(){try{let n=import.meta.resolve("rlottie/wasm"),{fileURLToPath:e}=await import('node:url'),t=e(n);return {wasmPath:t,jsPath:t.replace("/rlottie.wasm","/rlottie.js")}}catch{}try{let n=typeof it<"u"?it:null;if(n){let e=n.resolve("rlottie"),t=te.dirname(e);return {wasmPath:te.join(t,"rlottie.wasm"),jsPath:te.join(t,"rlottie.js")}}}catch{}return null}async function yi(n){let e=(t,r,s)=>n.cwrap(t,r,s);return {lottie_init:e("lottie_init","number",[]),lottie_destroy:t=>{n.cwrap("lottie_destroy",null,["number"])(t);},lottie_resize:(t,r,s)=>{n.cwrap("lottie_resize",null,["number","number","number"])(t,r,s);},lottie_buffer:e("lottie_buffer","number",["number"]),lottie_render:(t,r)=>{n.cwrap("lottie_render",null,["number","number"])(t,r);},lottie_load_from_data:e("lottie_load_from_data","number",["number","number"]),HEAPU8:n.HEAPU8,_malloc:n._malloc}}async function wi(){if(Kn)return ge;Kn=true;try{try{let{init:e}=await import('rlottie'),t=await $n(),r=t?pathToFileURL(t.wasmPath).href:void 0;return ge=await e(r),ge}catch{}let n=await $n();if(n){let e=await be.readFile(n.wasmPath),t=await import(pathToFileURL(n.jsPath).href);ge=await yi(await t.default({wasmBinary:e}));}}catch{ge=null;}return ge}async function Gn(){if(Jn)return dt;Jn=true;try{let n=await import('fflate'),e=n.default??n;typeof e.gunzipSync=="function"&&(dt=e);}catch{dt=null;}return dt}var zn=[80,75,3,4],Yn=[31,139];function lt(n,e){return e.every((t,r)=>n[r]===t)}function Zn(n){if(n.length<2)return false;if(lt(n,zn)||lt(n,Yn))return true;if(n[0]===123)try{let e=JSON.parse(n.toString("utf8"));return typeof e=="object"&&e!==null&&("layers"in e||"fr"in e)}catch{return false}return false}async function vi(n){if(lt(n,zn)){let e=await Gn();if(!e)throw new Error("fflate not installed; run: pnpm add fflate");let t=e.unzipSync(new Uint8Array(n)),r=Object.keys(t).find(i=>i==="animation/data.json"||i==="animation.json"||i.endsWith(".json")&&!i.includes("manifest"));if(!r)throw new Error("No Lottie JSON found in .was ZIP");let s=JSON.parse(Buffer.from(t[r]).toString("utf8"));if(Array.isArray(s.assets)){for(let i of s.assets)if(i.e===0&&typeof i.u=="string"&&typeof i.p=="string"){let o=i.u+i.p,a=Object.keys(t).find(c=>c===o||c.endsWith("/"+i.p));a&&t[a]&&(i.p="data:image/png;base64,"+Buffer.from(t[a]).toString("base64"),i.u="",i.e=1);}}return s}if(lt(n,Yn)){let e=await Gn();if(!e)throw new Error("fflate not installed; run: pnpm add fflate");let t=e.gunzipSync(new Uint8Array(n));return JSON.parse(Buffer.from(t).toString("utf8"))}return JSON.parse(n.toString("utf8"))}async function Mi(n,e,t,r){return await ue(),new Promise((s,i)=>{let o=["-y","-f","rawvideo","-pixel_format","rgba","-video_size",`${e}x${t}`,"-i","pipe:0","-frames:v","1","-f","image2",r],a=spawn(ot,o,{stdio:["pipe","ignore","ignore"]});a.on("close",c=>c===0?s():i(new Error(`ffmpeg rawvideo exit ${c}`))),a.on("error",i),a.stdin.end(Buffer.from(n.buffer,n.byteOffset,n.byteLength));})}async function Si(n,e,t,r,s){await ue();let i=te.join(n,"out.webp"),o=Math.max(1,Math.min(100,s));return new Promise((a,c)=>{let d=["-y","-framerate",String(e),"-i",te.join(n,"frame_%04d.png"),"-vf",`scale=${t}:${r}:force_original_aspect_ratio=decrease,pad=${t}:${r}:(ow-iw)/2:(oh-ih)/2:color=0x00000000,format=rgba`,"-vcodec","libwebp","-loop","0","-q:v",String(o),"-preset","default","-compression_level",String(b.STICKER.COMPRESSION_LEVEL),"-an",i],l=spawn(ot,d,{stdio:"ignore"});l.on("close",u=>u===0?a(i):c(new Error(`ffmpeg webp assembly exit ${u}`))),l.on("error",c);})}var Vn=b.STICKER.SIZE,Ai=15,bi=3,ut=class{static async toWebp(e,t=b.STICKER.DEFAULT_QUALITY){let r=await wi();if(!r)throw new Error("rlottie not installed; run: pnpm add rlottie");let s=await vi(e),i=Math.max(1,Number(s.fr)||24),o=Number(s.ip)||0,c=(Number(s.op)||o+i)-o,d=Math.min(i,Ai),l=Math.min(c,Math.ceil(bi*d)),u=Vn,w=Vn,M=r.lottie_init(),v=Buffer.from(JSON.stringify(s)+"\0"),E=r._malloc(v.length),y=r.HEAPU8;for(let m=0;m<v.length;m++)y[E+m]=v[m];r.lottie_load_from_data(M,E),r.lottie_resize(M,u,w);let p=te.join(Pi(),`lottie_${pe()}`);await be.mkdir(p,{recursive:true});try{let m=u*w*4;for(let P=0;P<l;P++){r.lottie_render(M,o+P);let J=r.lottie_buffer(M),Ae=new Uint8Array(r.HEAPU8.buffer.slice(J,J+m));await Mi(Ae,u,w,te.join(p,`frame_${String(P).padStart(4,"0")}.png`));}r.lottie_destroy(M);let A=await Si(p,d,u,w,t);return await U.safeReadFile(A)}finally{await be.rm(p,{recursive:true,force:true}).catch(()=>{});}}};function Pi(){return hi.tmpdir()}var pt=class{static async create(e,t){try{let r=await C.toBuffer(e),s=t?.quality||b.STICKER.DEFAULT_QUALITY,i=t?.shape||"default";if(Zn(r)){let d=await ut.toWebp(r,s);return await this.applyExif(d,t)}let o=await L(r);if(!o)throw new Error("Unable to detect file type");let a=R.isAnimated(o.mime),c=o.mime==="image/webp"?r:a?await this.processAnimated(r,o.mime,s):await F.resizeForSticker(r,s,i);return await this.applyExif(c,t)}catch(r){throw new Error(`Sticker creation failed: ${r instanceof Error?r.message:String(r)}`)}}static async applyExif(e,t){let r=this.createExifMetadata(t),s=new Ei.Image;await s.load(e),s.exif=r;let i=await s.save(null);return Buffer.isBuffer(i)?i:Buffer.from(i)}static createExifMetadata(e){let t={"sticker-pack-id":pe(),"sticker-pack-name":e?.packageName||"Zaileys Library","sticker-pack-publisher":e?.authorName||"https://github.com/zeative/zaileys",emojis:["\u{1F913}"],"android-app-store-link":"https://play.google.com/store/apps/details?id=com.marsvard.stickermakerforwhatsapp","ios-app-store-link":"https://itunes.apple.com/app/sticker-maker-studio/id1443326857"},r=Buffer.from([73,73,42,0,8,0,0,0,1,0,65,87,7,0,0,0,0,0,22,0,0,0]),s=Buffer.from(JSON.stringify(t),"utf8"),i=Buffer.concat([r,s]);return i.writeUIntLE(s.length,14,4),i}static async processAnimated(e,t,r){let s=b.STICKER.SIZE,i=b.STICKER.FPS,o=`scale=${s}:${s}:force_original_aspect_ratio=decrease,fps=${i},pad=${s}:${s}:(ow-iw)/2:(oh-ih)/2:color=0x00000000,format=rgba`,a=Math.max(1,Math.min(100,r));return j(e,this.getExtension(t),"webp","Animated sticker processing",async c=>{let d=b.STICKER.MAX_DURATION;try{d=Math.min(await q.duration(c),b.STICKER.MAX_DURATION);}catch{console.warn("Using default duration:",b.STICKER.MAX_DURATION);}return ["-vcodec libwebp",`-vf ${o}`,`-q:v ${a}`,"-loop 0","-preset default","-an","-vsync 0",`-t ${d}`,`-compression_level ${b.STICKER.COMPRESSION_LEVEL}`]})}static getExtension(e){return e===b.MIME.GIF?"gif":e.startsWith(b.MIME.VIDEO)?"mp4":"tmp"}};var mt=class{static async create(e){try{let t=await C.toBuffer(e),r=await L(t);if(!r)throw new Error("Unable to detect file type");let s;return r.mime.startsWith(b.MIME.VIDEO)?s=await q.thumbnail(t):R.isMedia(r.mime)?s=await F.thumbnail(t):s="",{document:t,mimetype:r.mime,ext:r.ext,fileName:pe(),jpegThumbnail:s}}catch(t){throw new Error(`Document creation failed: ${t instanceof Error?t.message:String(t)}`)}}};var ne=class{input;constructor(e){this.input=e;}get audio(){return {toOpus:()=>ee.toOpus(this.input),toMp3:()=>ee.toMp3(this.input),convert:(e="opus")=>ee.convert(this.input,e),waveform:()=>ee.waveform(this.input)}}get video(){return {toMp4:()=>q.toMp4(this.input),thumbnail:()=>q.thumbnail(this.input)}}get image(){return {toJpeg:()=>F.toJpeg(this.input),thumbnail:async()=>{let e=await C.toBuffer(this.input);return F.thumbnail(e)},resize:async(e,t)=>{let r=await C.toBuffer(this.input);return F.resize(r,e,t)}}}get sticker(){return {create:e=>pt.create(this.input,e)}}get document(){return {create:()=>mt.create(this.input)}}get thumbnail(){return {get:async()=>{let e=await C.toBuffer(this.input),t=await L(e);if(!t||!R.isMedia(t.mime))throw new Error("Invalid media type: expected image or video");return t.mime.startsWith(b.MIME.VIDEO)?q.thumbnail(this.input):F.thumbnail(e)}}}async toBuffer(){return C.toBuffer(this.input)}};var Xn=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new ne(t).audio.toOpus();}catch(o){throw new f("MEDIA_LOAD_FAILED",`audio() transcode failed: ${o.message}`,{cause:o})}let s=e?.ptt??true,i={audio:r,ptt:s};if(s)try{let{waveform:o,seconds:a}=await new ne(t).audio.waveform();i.waveform=o,e?.seconds===void 0&&(i.seconds=a);}catch{}return e?.seconds!==void 0&&(i.seconds=e.seconds),i};var Qn=10,_="__zaileysRelayMessage",Qt="__zaileysHeaderMedia",V=n=>typeof n=="string"&&n.length>0,Ci=n=>{let e=n.text;if(!V(e)||e.trim().length===0)throw new f("INVALID_OPTIONS","button text must be a non-empty string");return e},ki=(n,e)=>{let t=n.type??"reply";if(t==="location"){let s=n.text;return {name:"send_location",buttonParamsJson:JSON.stringify(V(s)?{display_text:s}:{})}}let r=Ci(n);if(t==="reply"){let s=n.id;if(!V(s))throw new f("INVALID_OPTIONS","reply button requires a non-empty id");if(e.has(s))throw new f("INVALID_OPTIONS",`duplicate button id: ${s}`);return e.add(s),{name:"quick_reply",buttonParamsJson:JSON.stringify({display_text:r,id:s})}}if(t==="url"){let s=n.url;if(!V(s))throw new f("INVALID_OPTIONS","url button requires a non-empty url");let i=n.webview===true;return {name:"cta_url",buttonParamsJson:JSON.stringify({display_text:r,url:s,merchant_url:s,webview_interaction:i})}}if(t==="copy"){let s=n.code;if(!V(s))throw new f("INVALID_OPTIONS","copy button requires a non-empty code");return {name:"cta_copy",buttonParamsJson:JSON.stringify({display_text:r,id:s,copy_code:s})}}if(t==="call"){let s=n.phone;if(!V(s))throw new f("INVALID_OPTIONS","call button requires a non-empty phone");return {name:"cta_call",buttonParamsJson:JSON.stringify({display_text:r,id:s,phone_number:s})}}if(t==="reminder"||t==="cancel-reminder"){let s=n.id;return {name:t==="reminder"?"cta_reminder":"cta_cancel_reminder",buttonParamsJson:JSON.stringify({display_text:r,id:V(s)?s:r})}}if(t==="address"){let s=n.id;return {name:"address_message",buttonParamsJson:JSON.stringify({display_text:r,id:V(s)?s:r})}}throw new f("INVALID_OPTIONS",`unknown button type: ${String(t)}`)},Ti=n=>{let e={};if(n?.bottomSheet){let t=n.bottomSheet;e.bottom_sheet={...t.buttonsLimit!==void 0?{in_thread_buttons_limit:t.buttonsLimit}:{},...t.dividers!==void 0?{divider_indices:t.dividers}:{},...t.listTitle!==void 0?{list_title:t.listTitle}:{},...t.buttonTitle!==void 0?{button_title:t.buttonTitle}:{}};}if(n?.limitedTimeOffer){let t=n.limitedTimeOffer;e.limited_time_offer={...t.text!==void 0?{text:t.text}:{},...t.url!==void 0?{url:t.url}:{},...t.copyCode!==void 0?{copy_code:t.copyCode}:{},...t.expiresAt!==void 0?{expiration_time:t.expiresAt}:{}};}return Object.keys(e).length>0?JSON.stringify(e):""},en=n=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","buttons() requires at least one button");if(n.length>Qn)throw new f("INVALID_OPTIONS",`buttons() accepts at most ${Qn} buttons`);let e=new Set;return n.map(t=>ki(t,e))},ft=(n,e)=>{let t=en(n),r={body:{text:e?.text&&e.text.length>0?e.text:" "},nativeFlowMessage:{buttons:t,messageParamsJson:Ti(e)}};e?.footer&&e.footer.length>0&&(r.footer={text:e.footer});let s=e?.image?{kind:"image",src:e.image}:e?.video?{kind:"video",src:e.video}:void 0;return (e?.title&&e.title.length>0||e?.subtitle&&e.subtitle.length>0||s)&&(r.header={title:e?.title??"",subtitle:e?.subtitle??"",hasMediaAttachment:s!==void 0}),s!==void 0?{[_]:{interactiveMessage:r},[Qt]:s}:{[_]:{interactiveMessage:r}}};var er=10,tn="__zaileysCardsMedia",tr=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","carousel() requires at least one card");if(n.length>er)throw new f("INVALID_OPTIONS",`carousel() accepts at most ${er} cards`);let t=[],r=n.map((o,a)=>{let c={body:{text:o.body&&o.body.length>0?o.body:" "}};o.buttons&&o.buttons.length>0&&(c.nativeFlowMessage={buttons:en(o.buttons),messageParamsJson:""}),o.footer&&o.footer.length>0&&(c.footer={text:o.footer});let d=o.image?{kind:"image",src:o.image}:o.video?{kind:"video",src:o.video}:void 0;return (o.title&&o.title.length>0||o.subtitle&&o.subtitle.length>0||d)&&(c.header={title:o.title??"",subtitle:o.subtitle??"",hasMediaAttachment:d!==void 0}),d&&t.push({...d,index:a}),c}),s={body:{text:e?.text&&e.text.length>0?e.text:" "},carouselMessage:{cards:r}};return t.length>0?{[_]:{interactiveMessage:s},[tn]:t}:{[_]:{interactiveMessage:s}}};var Ii=n=>{let e=[],t="",r=0,s=1,i=0,o=0,a=[];for(let c=0;c<n.length;c++)if(n[c]==="["&&n[c-1]!=="\\")a.push(c);else if(n[c]==="]"&&(n[c+1]==="("||n[c+1]==="<")){let d=a.pop();if(d==null)continue;let l=n[c+1],u=l==="("?")":">",w=l==="<",M=c+2,v=1;for(;M<n.length&&v>0;)n[M]===l&&n[M-1]!=="\\"?v++:n[M]===u&&n[M-1]!=="\\"&&v--,M++;if(v>0)continue;let E=n.slice(d+1,c).trim(),y=n.slice(c+2,M-1).trim(),p,m;if(w){let[A="",P="",J="",Ae="",Gt=""]=E.split("|").map(Vt=>Vt.trim());p=`zaileys_LATEX_${o++}`,m=`{{${p}}}${A||"image"}{{/${p}}}`,e.push({type:"latex",ie:{key:p,text:A,url:y,width:P,height:J,font_height:Ae,padding:Gt}});}else E?(p=`zaileys_HYPERLINK_${i++}`,m=`{{${p}}}${y}{{/${p}}}`,e.push({type:"hyperlink",ie:{key:p,text:E,url:y}})):(p=`zaileys_CITATION_${s-1}`,m=`{{${p}}}${y}{{/${p}}}`,e.push({type:"citation",ie:{key:p,reference_id:String(s++),url:y}}));t+=n.slice(r,d)+m,r=M,c=M-1;}return t+=n.slice(r),{text:t,ie:e}},xi=n=>n.ie.map(({type:e,ie:t})=>e==="hyperlink"?{key:t.key,metadata:{display_name:t.text,is_trusted:true,url:t.url,__typename:"GenAIInlineLinkItem"}}:e==="latex"?{key:t.key,metadata:{latex_expression:t.text,latex_image:{url:t.url,width:Number(t.width)||100,height:Number(t.height)||100},font_height:Number(t.font_height)||83.33333333333333,padding:Number(t.padding)||15,__typename:"GenAILatexItem"}}:{key:t.key,metadata:{reference_id:Number(t.reference_id),reference_url:t.url,reference_title:t.url,reference_display_name:t.url,sources:[],__typename:"GenAISearchCitationItem"}}),Ri=n=>{if(!Array.isArray(n)||n.length===0||!n.every(i=>Array.isArray(i)))throw new f("INVALID_OPTIONS","table must be a non-empty array of string rows");let[e,...t]=n,r=Math.max(e.length,...t.map(i=>i.length)),s=i=>[...i,...Array(r-i.length).fill("")];return [{is_header:true,cells:s(e)},...t.map(i=>({is_header:false,cells:s(i)}))]},Li={0:"DEFAULT",1:"KEYWORD",2:"METHOD",3:"STR",4:"NUMBER",5:"COMMENT"},gt=new Set(["break","case","catch","continue","debugger","delete","do","else","finally","for","function","if","in","instanceof","new","return","switch","this","throw","try","typeof","var","void","while","with","true","false","null","undefined","class","const","let","super","extends","export","import","from","as","default","yield","static","constructor","async","await","get","set"]),_i={javascript:gt,js:gt,typescript:gt,ts:gt},Ni=(n,e)=>{let t=_i[e.toLowerCase()]??new Set,r=[],s=(o,a)=>{if(!o)return;let c=r[r.length-1];c&&c.highlightType===a?c.codeContent+=o:r.push({codeContent:o,highlightType:a});},i=0;for(;i<n.length;){let o=n[i];if(/\s/.test(o)){let a=i;for(;i<n.length&&/\s/.test(n[i]);)i++;s(n.slice(a,i),0);continue}if(o==="/"&&n[i+1]==="/"){let a=i;for(i+=2;i<n.length&&n[i]!==`
2
- `;)i++;s(n.slice(a,i),5);continue}if(o==='"'||o==="'"||o==="`"){let a=i,c=o;for(i++;i<n.length;)if(n[i]==="\\"&&i+1<n.length)i+=2;else if(n[i]===c){i++;break}else i++;s(n.slice(a,i),3);continue}if(/[0-9]/.test(o)){let a=i;for(;i<n.length&&/[0-9.]/.test(n[i]);)i++;s(n.slice(a,i),4);continue}if(/[a-zA-Z_$]/.test(o)){let a=i;for(;i<n.length&&/[a-zA-Z0-9_$]/.test(n[i]);)i++;let c=n.slice(a,i),d=0;if(t.has(c))d=1;else {let l=i;for(;l<n.length&&/\s/.test(n[l]);)l++;n[l]==="("&&(d=2);}s(c,d);continue}s(o,0),i++;}return r},N=(n,e)=>({view_model:{[Array.isArray(e)?"primitives":"primitive"]:e,__typename:`GenAI${n}LayoutViewModel`}}),Di="https://github.com/zeative/zaileys",nr=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","text({ rich: true }) requires non-empty markdown content");let t=[],r=[];for(let o of n)if(o.type==="text"){let a=Ii(o.text),c=xi(a);r.push({messageType:2,messageText:a.text}),t.push(N("Single",{text:a.text,...c.length>0?{inline_entities:c}:{},__typename:"GenAIMarkdownTextUXPrimitive"}));}else if(o.type==="code"){let a=o.language??"plaintext",c=Ni(o.content,a);r.push({messageType:5,codeMetadata:{codeLanguage:a,codeBlocks:c}}),t.push(N("Single",{language:a,code_blocks:c.map(d=>({content:d.codeContent,type:Li[d.highlightType]})),__typename:"GenAICodeUXPrimitive"}));}else if(o.type==="table"){let a=Ri(o.rows);r.push({messageType:4,tableMetadata:{title:"",rows:a.map(c=>({items:c.cells,...c.is_header?{isHeading:true}:{}}))}}),t.push(N("Single",{rows:a,__typename:"GenATableUXPrimitive"}));}else if(o.type==="image"){let a=Array.isArray(o.url)?o.url:[o.url];if(a.length===0)throw new f("INVALID_OPTIONS","image requires at least one url");r.push({messageType:1,gridImageMetadata:{gridImageUrl:{imagePreviewUrl:a[0]},imageUrls:a.map(c=>({imagePreviewUrl:c,imageHighResUrl:c,sourceUrl:Di}))}});for(let c of a)t.push(N("Single",{media:{url:c,mime_type:"image/png"},imagine_type:"IMAGE",status:{status:"READY"},__typename:"GenAIImaginePrimitive"}));}else if(o.type==="video"){let a=Array.isArray(o.url)?o.url:[o.url];if(a.length===0)throw new f("INVALID_OPTIONS","video requires at least one url");r.push({messageType:2,messageText:"[ CANNOT_LOAD_VIDEO - zaileys ]"});for(let c of a)t.push(N("Single",{media:{url:c,mime_type:"video/mp4",duration:o.duration??0},imagine_type:"ANIMATE",status:{status:"READY"},__typename:"GenAIImaginePrimitive"}));}else if(o.type==="product"){let a=Array.isArray(o.products),c=a?o.products:[o.products];if(c.length===0)throw new f("INVALID_OPTIONS","product requires at least one item");r.push({messageType:2,messageText:"[ CANNOT_LOAD_PRODUCT - zaileys ]"});let d=c.map(l=>({title:l.title,brand:l.brand??"",price:l.price??"",sale_price:l.salePrice??"",product_url:l.url??"",image:{url:l.image??""},additional_images:[{url:l.icon??""}],__typename:"GenAIProductItemCardPrimitive"}));t.push(a?N("HScroll",d):N("Single",d[0]));}else if(o.type==="reels"){let a=Array.isArray(o.reels)?o.reels:[o.reels];if(a.length===0)throw new f("INVALID_OPTIONS","reels requires at least one item");r.push({messageType:9,contentItemsMetadata:{contentType:1,itemsMetadata:a.map(c=>({reelItem:{title:c.username??"",profileIconUrl:c.profileUrl??"",thumbnailUrl:c.thumbnail??"",videoUrl:c.url??""}}))}}),t.push(N("HScroll",a.map(c=>({reels_url:c.url??"",thumbnail_url:c.thumbnail??"",creator:c.username??c.title??"",avatar_url:c.profileUrl??"",reels_title:c.title??"",likes_count:c.likes??0,shares_count:c.shares??0,view_count:c.views??0,reel_source:c.source??"IG",is_verified:!!c.verified,__typename:"GenAIReelPrimitive"}))));}else if(o.type==="post"){let a=Array.isArray(o.posts)?o.posts:[o.posts];if(a.length===0)throw new f("INVALID_OPTIONS","post requires at least one item");r.push({messageType:2,messageText:"[ CANNOT_LOAD_POST - zaileys ]"}),t.push(N("HScroll",a.map(c=>({title:c.title??"",subtitle:c.subtitle??"",username:c.username??"",profile_picture_url:c.profileUrl??"",is_verified:!!c.verified,thumbnail_url:c.thumbnail??"",post_caption:c.caption??"",likes_count:c.likes??0,comments_count:c.comments??0,shares_count:c.shares??0,post_url:c.url??"",post_deeplink:c.deeplink??"",source_app:c.source??"INSTAGRAM",footer_label:c.footer??"",footer_icon:c.icon??"",is_carousel:a.length>1,orientation:c.orientation??"LANDSCAPE",post_type:c.postType??"VIDEO",__typename:"GenAIPostPrimitive"}))));}else if(o.type==="tip")r.push({messageType:2,messageText:o.text}),t.push(N("Single",{text:o.text,__typename:"GenAIMetadataTextPrimitive"}));else {let a=Array.isArray(o.prompts)?o.prompts:[o.prompts];if(a.length===0)throw new f("INVALID_OPTIONS","suggest requires at least one prompt");t.push(N("ActionRow",a.map(c=>({prompt_text:c,prompt_type:"SUGGESTED_PROMPT",__typename:"GenAIFollowUpSuggestionPillPrimitive"}))));}e?.footer&&e.footer.length>0&&t.push(N("Single",{text:e.footer,__typename:"GenAIMetadataTextPrimitive"}));let s=(e?.sources??[]).map(([o,a,c])=>({source_type:"THIRD_PARTY",source_display_name:c??"",source_subtitle:"AI",source_url:a??"",favicon:{url:o??"",mime_type:"image/jpeg",width:16,height:16}})),i={messageContextInfo:{deviceListMetadata:{},deviceListMetadataVersion:2,botMetadata:{messageDisclaimerText:e?.title??"",richResponseSourcesMetadata:{sources:s}}},botForwardedMessage:{message:{richResponseMessage:{messageType:1,submessages:r,unifiedResponse:{data:Buffer.from(JSON.stringify({response_id:randomUUID(),sections:t})).toString("base64")},contextInfo:{forwardingScore:1,isForwarded:true,forwardedAiBotMessageInfo:{botJid:"0@bot"},forwardOrigin:4}}}}};return {[_]:i}};var Bi=/^:::([a-zA-Z]+)\s*$/,Fi=/^:::\s*$/,rr=/^```(\w*)\s*$/,sr=/^!\[[^\]]*\]\(([^)]+)\)\s*$/,Wi=/^\s*\|?\s*:?-{2,}[\s|:-]*$/,ht=n=>n.split("|").map(e=>e.trim()),nn=n=>{let e={};for(let t of ht(n)){let r=t.indexOf(":");if(r===-1)continue;let s=t.slice(0,r).trim().toLowerCase(),i=t.slice(r+1).trim();s.length>0&&(e[s]=i);}return e},re=n=>{if(n===void 0||n.trim().length===0)return;let e=Number(n);return Number.isNaN(e)?void 0:e},or=n=>n==="true"||n==="1"||n==="yes",ir=n=>{let e=n.trim();return e.startsWith("|")&&(e=e.slice(1)),e.endsWith("|")&&(e=e.slice(0,-1)),e.split("|").map(t=>t.trim())},Ui=n=>{let e=nn(n),t=e.title;if(t===void 0||t.length===0)return null;let r={title:t};return e.price&&(r.price=e.price),e.sale&&(r.salePrice=e.sale),e.saleprice&&(r.salePrice=e.saleprice),e.brand&&(r.brand=e.brand),e.url&&(r.url=e.url),e.image&&(r.image=e.image),e.icon&&(r.icon=e.icon),r},ji=n=>{let e=nn(n),t={};e.user&&(t.username=e.user),e.username&&(t.username=e.username),e.title&&(t.title=e.title),e.profile&&(t.profileUrl=e.profile),e.thumb&&(t.thumbnail=e.thumb),e.url&&(t.url=e.url);let r=re(e.likes);r!==void 0&&(t.likes=r);let s=re(e.shares);s!==void 0&&(t.shares=s);let i=re(e.views);return i!==void 0&&(t.views=i),e.source&&(t.source=e.source),"verified"in e&&(t.verified=or(e.verified)),t},qi=n=>{let e=nn(n),t={};e.user&&(t.username=e.user),e.username&&(t.username=e.username),e.title&&(t.title=e.title),e.subtitle&&(t.subtitle=e.subtitle),e.profile&&(t.profileUrl=e.profile),e.thumb&&(t.thumbnail=e.thumb),e.caption&&(t.caption=e.caption);let r=re(e.likes);r!==void 0&&(t.likes=r);let s=re(e.comments);s!==void 0&&(t.comments=s);let i=re(e.shares);return i!==void 0&&(t.shares=i),e.url&&(t.url=e.url),e.source&&(t.source=e.source),e.footer&&(t.footer=e.footer),e.icon&&(t.icon=e.icon),"verified"in e&&(t.verified=or(e.verified)),t},Ki=(n,e)=>{let t=e.map(r=>r.replace(/^[-*]\s*/,"").trim()).filter(r=>r.length>0);if(n==="suggest"){let r=t.flatMap(s=>ht(s)).filter(s=>s.length>0);return r.length>0?{type:"suggest",prompts:r}:null}if(n==="tip")return t.length>0?{type:"tip",text:t.join(`
3
- `)}:null;if(n==="image")return t.length>0?{type:"image",url:t.length===1?t[0]:t}:null;if(n==="video"){if(t.length===0)return null;let r=t.map(o=>ht(o)[0]??"").filter(o=>o.length>0);if(r.length===0)return null;let s=re(ht(t[0])[1]),i={type:"video",url:r.length===1?r[0]:r};return s!==void 0&&(i.duration=s),i}if(n==="product"){let r=t.map(Ui).filter(s=>s!==null);return r.length>0?{type:"product",products:r.length===1?r[0]:r}:null}if(n==="reels"){let r=t.map(ji);return r.length>0?{type:"reels",reels:r}:null}if(n==="post"){let r=t.map(qi);return r.length>0?{type:"post",posts:r}:null}return null},ar=n=>{let e=n.replace(/\r\n/g,`
1
+ import aa,{prepareWAMessageMedia,generateWAMessageFromContent,BufferJSON,makeCacheableSignalKeyStore,DisconnectReason,jidNormalizedUser,jidDecode,fetchLatestBaileysVersion,initAuthCreds,isJidGroup,proto}from'baileys';export{areJidsSameUser,getDevice,isJidBroadcast,isJidGroup,isJidNewsletter,isLidUser,isPnUser,jidDecode,jidEncode,jidNormalizedUser}from'baileys';import we,{readFile}from'node:fs/promises';import {fileURLToPath,pathToFileURL}from'node:url';import {tmpdir}from'node:os';import We from'node:path';import {spawn}from'node:child_process';import {Jimp}from'jimp';import Qs from'node-webpmux';import {randomUUID,randomBytes}from'node:crypto';import {promises,watch}from'node:fs';import ro from'qrcode-terminal';import oo from'pino';import'stream';import {EventEmitter}from'node:events';var Js=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var g=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysBuilderError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var P={OPUS:{CODEC:"libopus",CHANNELS:1,FREQUENCY:48e3,BITRATE:"48k",FORMAT:"ogg"},THUMBNAIL:{SIZE:100,QUALITY:50,TIMESTAMP:"10%"},STICKER:{SIZE:512,MAX_DURATION:6,FPS:10,DEFAULT_QUALITY:60,COMPRESSION_LEVEL:6},MIME:{AUDIO:"audio/",VIDEO:"video/",IMAGE:"image/",GIF:"image/gif",MP4:"video/mp4"}},An="ffmpeg",Pn="ffprobe",Mn=false,Ut=async(n=false)=>{if(!(n||Mn)){Mn=true;try{let e=(await import('@ffmpeg-installer/ffmpeg')).default;if(e?.path){An=e.path;let t=We.dirname(e.path),r=process.platform==="win32"?";":":",s=process.env.PATH??"";s.split(r).includes(t)||(process.env.PATH=`${t}${r}${s}`);}}catch{}try{let e=(await import('@ffprobe-installer/ffprobe')).default;e?.path&&(Pn=e.path);}catch{}}},et=()=>Date.now().toString(36)+Math.random().toString(36).slice(2,8),L=async n=>{let{fileTypeFromBuffer:e}=await import('file-type');return e(n)},$=class{static generateUniqueId(){return `${Date.now()}_${Math.random().toString(36).slice(2,11)}`}static createTempPath(e,t){return We.join(tmpdir(),`${e}_${this.generateUniqueId()}.${t}`)}static async cleanup(e){await Promise.allSettled(e.map(t=>we.unlink(t)));}static async safeReadFile(e){try{return await we.readFile(e)}catch{throw new Error(`Failed to read file: ${e}`)}}static async safeWriteFile(e,t){try{await we.writeFile(e,t);}catch{throw new Error(`Failed to write file: ${e}`)}}},b=class{static async toBuffer(e){if(Buffer.isBuffer(e))return e;if(e instanceof ArrayBuffer)return Buffer.from(e);if(typeof e=="string")return this.fromString(e);throw new Error("Invalid input type: expected string, Buffer, or ArrayBuffer")}static async fromString(e){if(e.startsWith("http://")||e.startsWith("https://"))return this.fromUrl(e);try{if(await we.stat(e).then(t=>t.isFile()).catch(()=>!1))return await we.readFile(e)}catch{}return Buffer.from(e,"base64")}static async fromUrl(e){try{let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status}: ${t.statusText}`);let r=await t.arrayBuffer();return Buffer.from(r)}catch(t){throw new Error(`Failed to fetch URL: ${t instanceof Error?t.message:String(t)}`)}}static async getExtension(e){let{fileTypeFromBuffer:t}=await import('file-type'),r=await t(e);if(!r)return "tmp";let s=r.ext.toLowerCase();return ["wav","ogg","mp4","gif","jpg","webp","tmp","mp3","png"].includes(s)?s:"tmp"}},R=class{static validate(e,t){if(!e?.mime?.startsWith(t))throw new Error(`Invalid file type: expected ${t}*, got ${e?.mime||"unknown"}`)}static isMedia(e){return e.startsWith(P.MIME.IMAGE)||e.startsWith(P.MIME.VIDEO)}static isAnimated(e){return e===P.MIME.GIF||e.startsWith(P.MIME.VIDEO)}},Z=class{static async process(e){return await Ut(),new Promise((t,r)=>{let s=["-y","-i",e.input,...e.options,e.output],i=spawn(An,s,{stdio:"ignore"});i.on("close",async o=>{if(o===0)try{await e.onEnd(),t();}catch(a){r(a);}else try{let a=new Error(`FFmpeg exited with code ${o}`);await e.onError(a),r(a);}catch(a){r(a);}}),i.on("error",async o=>{try{await e.onError(o);}finally{r(o);}});})}static async getDuration(e){return new Promise((t,r)=>{let s=spawn(Pn,["-v","error","-show_entries","format=duration","-of","default=noprint_wrappers=1:nokey=1",e]),i="";s.stdout.on("data",o=>i+=o.toString()),s.on("close",o=>{o===0?t(parseFloat(i.trim())||0):r(new Error(`ffprobe exited with code ${o}`));}),s.on("error",r);})}};var Hs=3e4,Cn="application/octet-stream",kn=async n=>n.byteLength===0?Cn:(await L(n))?.mime??Cn,ve=async n=>({buffer:n,mime:await kn(n),size:n.byteLength}),En=async(n,e)=>{let t=new AbortController,r=setTimeout(()=>t.abort(),e);try{let s=await fetch(n,{signal:t.signal});if(!s.ok)throw new g("MEDIA_LOAD_FAILED",`fetch ${n} failed with status ${s.status}`,{cause:s.status});return Buffer.from(await s.arrayBuffer())}catch(s){throw s instanceof g?s:new g("MEDIA_LOAD_FAILED",`fetch ${n} failed: ${s.message}`,{cause:s})}finally{clearTimeout(r);}},bn=async n=>{try{return await readFile(n)}catch(e){throw new g("MEDIA_LOAD_FAILED",`read ${n} failed: ${e.message}`,{cause:e})}},zs=n=>n.startsWith("http://")||n.startsWith("https://"),I=async(n,e)=>{await Ut();let t=e?.timeoutMs??Hs;return Buffer.isBuffer(n)?ve(n):n instanceof URL?n.protocol==="file:"?ve(await bn(fileURLToPath(n))):ve(await En(n.toString(),t)):zs(n)?ve(await En(n,t)):ve(await bn(n))};var le=async(n,e)=>{let{buffer:t}=await I(n),r={image:t};return e?.caption!==void 0&&(r.caption=e.caption),e?.viewOnce!==void 0&&(r.viewOnce=e.viewOnce),r};var X=async(n,e)=>{let{buffer:t,mime:r}=await I(n);if(!r.startsWith("video/"))throw new g("INVALID_OPTIONS",`video() expects a video source, got mime ${r}`);let s={video:t};return e?.caption!==void 0&&(s.caption=e.caption),e?.gifPlayback!==void 0&&(s.gifPlayback=e.gifPlayback),e?.viewOnce!==void 0&&(s.viewOnce=e.viewOnce),e?.ptv===true&&(s.ptv=true),s};var Tn=2,On=30,Ys=async n=>{if(n.type==="image")return le(n.src,n.caption!==void 0?{caption:n.caption}:void 0);if(n.type==="video")return X(n.src,n.caption!==void 0?{caption:n.caption}:void 0);throw new g("INVALID_OPTIONS",`album() item type must be 'image' or 'video', got ${String(n.type)}`)},In=async(n,e,t,r)=>{if(!Array.isArray(t)||t.length<Tn)throw new g("INVALID_OPTIONS",`album() requires a minimum of ${Tn} items`);if(t.length>On)throw new g("INVALID_OPTIONS",`album() accepts a maximum of ${On} items`);let s=0,i=0;for(let u of t)if(u.type==="image")s+=1;else if(u.type==="video")i+=1;else throw new g("INVALID_OPTIONS",`album() item type must be 'image' or 'video', got ${String(u.type)}`);let o={album:{expectedImageCount:s,expectedVideoCount:i}};r.mentions&&r.mentions.length>0&&(o.mentions=r.mentions),r.mentionAll&&(o.mentionAll=true);let a={};r.quoted&&(a.quoted=r.quoted),r.disappearingSeconds!==void 0&&(a.ephemeralExpiration=r.disappearingSeconds);let c;try{c=await n.sendMessage(e,o,a);}catch(u){throw new g("SEND_FAILED","album parent send rejected",{cause:u})}let d=c?.key;if(!d)throw new g("SEND_FAILED","album parent returned no message key");let l=0;for(let u of t){let w=await Ys(u);w.albumParentKey=d;try{await n.sendMessage(e,w);}catch(S){throw new g("SEND_FAILED","album child send rejected",{cause:{parentKey:d,index:l,error:S}})}l+=1;}return d};var j=async(n,e,t,r,s)=>{let i=r.replace(/[^a-z0-9]+/gi,"_").toLowerCase(),o=$.createTempPath(`${i}_in`,e),a=$.createTempPath(`${i}_out`,t);await $.safeWriteFile(o,n);try{let c=typeof s=="function"?await s(o):s;return await Z.process({input:o,output:a,options:c,onEnd:async()=>{},onError:async()=>{}}),await $.safeReadFile(a)}catch(c){throw new Error(`${r} failed: ${c instanceof Error?c.message:String(c)}`)}finally{await $.cleanup([o,a]);}};var tt=64,xn=8e3,Q=class{static async toOpus(e){return this.convert(e,"opus")}static async toMp3(e){return this.convert(e,"mp3")}static async convert(e,t="opus"){let r=await b.toBuffer(e);R.validate(await L(r),P.MIME.AUDIO);let s=await b.getExtension(r),i=t==="opus"?["-vn","-c:a","libopus","-b:a","48k","-ac","1","-avoid_negative_ts","make_zero","-map_metadata","-1","-f","ogg"]:["-vn","-c:a","libmp3lame","-b:a","128k","-ac","2","-avoid_negative_ts","make_zero","-map_metadata","-1","-f","mp3"];return j(r,s,t==="opus"?"ogg":"mp3",`${t.toUpperCase()} conversion`,i)}static async waveform(e){let t=await b.toBuffer(e),r=await b.getExtension(t),s=await j(t,r,"tmp","Waveform generation",["-vn","-ac","1","-ar",String(xn),"-f","s16le"]),i=Math.floor(s.length/2);return {waveform:this.computeWaveform(s),seconds:Math.max(1,Math.round(i/xn))}}static computeWaveform(e){let t=Math.floor(e.length/2),r=new Uint8Array(tt);if(t===0)return r;let s=Math.max(1,Math.floor(t/tt)),i=[];for(let a=0;a<tt;a++){let c=0,d=0;for(let l=0;l<s;l++){let u=(a*s+l)*2;u+1<e.length&&(c+=Math.abs(e.readInt16LE(u)),d+=1);}i.push(d>0?c/d:0);}let o=Math.max(...i)||1;for(let a=0;a<tt;a++)r[a]=Math.floor(i[a]/o*100);return r}};var Zs=["-c:v","libx264","-preset","ultrafast","-crf","28","-c:a","aac","-b:a","128k","-movflags","+faststart","-vf","scale=trunc(iw/2)*2:trunc(ih/2)*2","-pix_fmt","yuv420p","-f","mp4"],U=class{static async toMp4(e){let t=await b.toBuffer(e);R.validate(await L(t),P.MIME.VIDEO);let r=await b.getExtension(t);return j(t,r,"mp4","Video re-encoding",Zs)}static async thumbnail(e){let t=await b.toBuffer(e);R.validate(await L(t),P.MIME.VIDEO);let r=await b.getExtension(t),s=P.THUMBNAIL.SIZE;return (await j(t,r,"jpg","Thumbnail generation",async o=>{let a=await Z.getDuration(o);return ["-ss",Math.max(0,a*.1).toString(),"-vframes","1","-s",`${s}x${s}`]})).toString("base64")}static async duration(e){return Z.getDuration(e)}};var ue=null,Rn=false;async function Xs(){if(Rn)return ue;Rn=true;let n=e=>{typeof e=="function"&&(ue=e);};try{n(Js("sharp"));}catch{ue=null;}if(!ue)try{let e=await import('sharp');n(e.default??e);}catch{ue=null;}return ue}function Ln(n,e){let t=new Uint8Array(n*n),r=n/2,s=n/2,i=n/10,o=[[i,i],[n-i,i],[i,n-i],[n-i,n-i]];for(let a=0;a<n;a++)for(let c=0;c<n;c++){let d=false;if(e==="circle"){let l=c-r,u=a-s;d=l*l+u*u<=r*r;}else if(e==="rounded"){let l=c>=i&&c<n-i&&a>=0&&a<n,u=c>=0&&c<n&&a>=i&&a<n-i,w=false;for(let S of o){let v=c-S[0],C=a-S[1];if(v*v+C*C<=i*i){w=true;break}}d=l||u||w;}else if(e==="oval"){let l=(c-r)/(n/2),u=(a-s)/(n/3);d=l*l+u*u<=1;}t[a*n+c]=d?255:0;}return t}var qt=class{sharp;constructor(e){this.sharp=e;}async thumbnail(e){let t=this.sharp,r=t(e).resize(P.THUMBNAIL.SIZE,P.THUMBNAIL.SIZE,{fit:"cover"});return (await r.metadata()).format==="gif"&&(r=t(e,{pages:1}).resize(P.THUMBNAIL.SIZE,P.THUMBNAIL.SIZE)),(await r.jpeg({quality:P.THUMBNAIL.QUALITY}).toBuffer()).toString("base64")}async resize(e,t,r){return this.sharp(e).resize(t,r,{fit:"cover"}).png().toBuffer()}async toJpeg(e){let t=this.sharp,r=await b.toBuffer(e),s=await t(r).metadata();if(!s.format)throw new Error("Invalid image type: format could not be determined");return s.format==="webp"||s.format==="png"?t(r).jpeg().toBuffer():r}async resizeForSticker(e,t,r="default"){let s=this.sharp,i=P.STICKER.SIZE,o=s(e).resize(i,i,{fit:"contain",background:{r:0,g:0,b:0,alpha:0}});if(r!=="default"){let a=Buffer.from(Ln(i,r)),c=s(a,{raw:{width:i,height:i,channels:1}});o=o.joinChannel(await c.png().toBuffer());}return o.webp({quality:t}).toBuffer()}},Kt=class{async thumbnail(e){let t=P.THUMBNAIL.SIZE,r=await Jimp.fromBuffer(e);r.cover({w:t,h:t});let s=await r.getBuffer("image/jpeg",{quality:P.THUMBNAIL.QUALITY});return Buffer.from(s).toString("base64")}async resize(e,t,r){let s=await Jimp.fromBuffer(e);s.cover({w:t,h:r});let i=await s.getBuffer("image/png");return Buffer.from(i)}async toJpeg(e){let t=await b.toBuffer(e);try{let s=await(await Jimp.fromBuffer(t)).getBuffer("image/jpeg");return Buffer.from(s)}catch{return t}}async resizeForSticker(e,t,r="default"){let s=P.STICKER.SIZE,i=await Jimp.fromBuffer(e);if(i.contain({w:s,h:s}),r!=="default"){let c=Ln(s,r),d=new Jimp({width:s,height:s,color:255});for(let l=0;l<s;l++)for(let u=0;u<s;u++)c[l*s+u]===255&&d.setPixelColor(4294967295,u,l);i.mask(d);}let o=Buffer.from(await i.getBuffer("image/png")),a=Math.max(1,Math.min(100,t));return j(o,"png","webp","Jimp WebP conversion",["-vcodec","libwebp","-q:v",`${a}`,"-preset","default"])}},Se=null;async function nt(){if(Se)return Se;let n=await Xs();return n?Se=new qt(n):(console.warn("\x1B[33m%s\x1B[0m","[media-process] Jimp is slow. For faster performance, run: npm install sharp"),Se=new Kt),Se}var F=class{static async thumbnail(e){return (await nt()).thumbnail(e)}static async resize(e,t,r){return (await nt()).resize(e,t,r)}static async toJpeg(e){return (await nt()).toJpeg(e)}static async resizeForSticker(e,t,r="default"){return (await nt()).resizeForSticker(e,t,r)}};var rt=class{static async create(e,t){try{let r=await b.toBuffer(e),s=await L(r);if(!s)throw new Error("Unable to detect file type");let i=t?.quality||P.STICKER.DEFAULT_QUALITY,o=R.isAnimated(s.mime),a=t?.shape||"default",c=s.mime==="image/webp"?r:o?await this.processAnimated(r,s.mime,i):await F.resizeForSticker(r,i,a),d=this.createExifMetadata(t),l=new Qs.Image;await l.load(c),l.exif=d;let u=await l.save(null);return Buffer.isBuffer(u)?u:Buffer.from(u)}catch(r){throw new Error(`Sticker creation failed: ${r instanceof Error?r.message:String(r)}`)}}static createExifMetadata(e){let t={"sticker-pack-id":et(),"sticker-pack-name":e?.packageName||"Zaileys Library","sticker-pack-publisher":e?.authorName||"https://github.com/zeative/zaileys",emojis:["\u{1F913}"],"android-app-store-link":"https://play.google.com/store/apps/details?id=com.marsvard.stickermakerforwhatsapp","ios-app-store-link":"https://itunes.apple.com/app/sticker-maker-studio/id1443326857"},r=Buffer.from([73,73,42,0,8,0,0,0,1,0,65,87,7,0,0,0,0,0,22,0,0,0]),s=Buffer.from(JSON.stringify(t),"utf8"),i=Buffer.concat([r,s]);return i.writeUIntLE(s.length,14,4),i}static async processAnimated(e,t,r){let s=P.STICKER.SIZE,i=P.STICKER.FPS,o=`scale=${s}:${s}:force_original_aspect_ratio=decrease,fps=${i},pad=${s}:${s}:(ow-iw)/2:(oh-ih)/2:color=0x00000000,format=rgba`,a=Math.max(1,Math.min(100,r));return j(e,this.getExtension(t),"webp","Animated sticker processing",async c=>{let d=P.STICKER.MAX_DURATION;try{d=Math.min(await U.duration(c),P.STICKER.MAX_DURATION);}catch{console.warn("Using default duration:",P.STICKER.MAX_DURATION);}return ["-vcodec libwebp",`-vf ${o}`,`-q:v ${a}`,"-loop 0","-preset default","-an","-vsync 0",`-t ${d}`,`-compression_level ${P.STICKER.COMPRESSION_LEVEL}`]})}static getExtension(e){return e===P.MIME.GIF?"gif":e.startsWith(P.MIME.VIDEO)?"mp4":"tmp"}};var st=class{static async create(e){try{let t=await b.toBuffer(e),r=await L(t);if(!r)throw new Error("Unable to detect file type");let s;return r.mime.startsWith(P.MIME.VIDEO)?s=await U.thumbnail(t):R.isMedia(r.mime)?s=await F.thumbnail(t):s="",{document:t,mimetype:r.mime,ext:r.ext,fileName:et(),jpegThumbnail:s}}catch(t){throw new Error(`Document creation failed: ${t instanceof Error?t.message:String(t)}`)}}};var ee=class{input;constructor(e){this.input=e;}get audio(){return {toOpus:()=>Q.toOpus(this.input),toMp3:()=>Q.toMp3(this.input),convert:(e="opus")=>Q.convert(this.input,e),waveform:()=>Q.waveform(this.input)}}get video(){return {toMp4:()=>U.toMp4(this.input),thumbnail:()=>U.thumbnail(this.input)}}get image(){return {toJpeg:()=>F.toJpeg(this.input),thumbnail:async()=>{let e=await b.toBuffer(this.input);return F.thumbnail(e)},resize:async(e,t)=>{let r=await b.toBuffer(this.input);return F.resize(r,e,t)}}}get sticker(){return {create:e=>rt.create(this.input,e)}}get document(){return {create:()=>st.create(this.input)}}get thumbnail(){return {get:async()=>{let e=await b.toBuffer(this.input),t=await L(e);if(!t||!R.isMedia(t.mime))throw new Error("Invalid media type: expected image or video");return t.mime.startsWith(P.MIME.VIDEO)?U.thumbnail(this.input):F.thumbnail(e)}}}async toBuffer(){return b.toBuffer(this.input)}};var Nn=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new ee(t).audio.toOpus();}catch(o){throw new g("MEDIA_LOAD_FAILED",`audio() transcode failed: ${o.message}`,{cause:o})}let s=e?.ptt??true,i={audio:r,ptt:s};if(s)try{let{waveform:o,seconds:a}=await new ee(t).audio.waveform();i.waveform=o,e?.seconds===void 0&&(i.seconds=a);}catch{}return e?.seconds!==void 0&&(i.seconds=e.seconds),i};var Dn=10,N="__zaileysRelayMessage",Jt="__zaileysHeaderMedia",G=n=>typeof n=="string"&&n.length>0,ei=n=>{let e=n.text;if(!G(e)||e.trim().length===0)throw new g("INVALID_OPTIONS","button text must be a non-empty string");return e},ti=(n,e)=>{let t=n.type??"reply";if(t==="location"){let s=n.text;return {name:"send_location",buttonParamsJson:JSON.stringify(G(s)?{display_text:s}:{})}}let r=ei(n);if(t==="reply"){let s=n.id;if(!G(s))throw new g("INVALID_OPTIONS","reply button requires a non-empty id");if(e.has(s))throw new g("INVALID_OPTIONS",`duplicate button id: ${s}`);return e.add(s),{name:"quick_reply",buttonParamsJson:JSON.stringify({display_text:r,id:s})}}if(t==="url"){let s=n.url;if(!G(s))throw new g("INVALID_OPTIONS","url button requires a non-empty url");let i=n.webview===true;return {name:"cta_url",buttonParamsJson:JSON.stringify({display_text:r,url:s,merchant_url:s,webview_interaction:i})}}if(t==="copy"){let s=n.code;if(!G(s))throw new g("INVALID_OPTIONS","copy button requires a non-empty code");return {name:"cta_copy",buttonParamsJson:JSON.stringify({display_text:r,id:s,copy_code:s})}}if(t==="call"){let s=n.phone;if(!G(s))throw new g("INVALID_OPTIONS","call button requires a non-empty phone");return {name:"cta_call",buttonParamsJson:JSON.stringify({display_text:r,id:s,phone_number:s})}}if(t==="reminder"||t==="cancel-reminder"){let s=n.id;return {name:t==="reminder"?"cta_reminder":"cta_cancel_reminder",buttonParamsJson:JSON.stringify({display_text:r,id:G(s)?s:r})}}if(t==="address"){let s=n.id;return {name:"address_message",buttonParamsJson:JSON.stringify({display_text:r,id:G(s)?s:r})}}throw new g("INVALID_OPTIONS",`unknown button type: ${String(t)}`)},ni=n=>{let e={};if(n?.bottomSheet){let t=n.bottomSheet;e.bottom_sheet={...t.buttonsLimit!==void 0?{in_thread_buttons_limit:t.buttonsLimit}:{},...t.dividers!==void 0?{divider_indices:t.dividers}:{},...t.listTitle!==void 0?{list_title:t.listTitle}:{},...t.buttonTitle!==void 0?{button_title:t.buttonTitle}:{}};}if(n?.limitedTimeOffer){let t=n.limitedTimeOffer;e.limited_time_offer={...t.text!==void 0?{text:t.text}:{},...t.url!==void 0?{url:t.url}:{},...t.copyCode!==void 0?{copy_code:t.copyCode}:{},...t.expiresAt!==void 0?{expiration_time:t.expiresAt}:{}};}return Object.keys(e).length>0?JSON.stringify(e):""},$t=n=>{if(!Array.isArray(n)||n.length===0)throw new g("INVALID_OPTIONS","buttons() requires at least one button");if(n.length>Dn)throw new g("INVALID_OPTIONS",`buttons() accepts at most ${Dn} buttons`);let e=new Set;return n.map(t=>ti(t,e))},it=(n,e)=>{let t=$t(n),r={body:{text:e?.text&&e.text.length>0?e.text:" "},nativeFlowMessage:{buttons:t,messageParamsJson:ni(e)}};e?.footer&&e.footer.length>0&&(r.footer={text:e.footer});let s=e?.image?{kind:"image",src:e.image}:e?.video?{kind:"video",src:e.video}:void 0;return (e?.title&&e.title.length>0||e?.subtitle&&e.subtitle.length>0||s)&&(r.header={title:e?.title??"",subtitle:e?.subtitle??"",hasMediaAttachment:s!==void 0}),s!==void 0?{[N]:{interactiveMessage:r},[Jt]:s}:{[N]:{interactiveMessage:r}}};var _n=10,Gt="__zaileysCardsMedia",Bn=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new g("INVALID_OPTIONS","carousel() requires at least one card");if(n.length>_n)throw new g("INVALID_OPTIONS",`carousel() accepts at most ${_n} cards`);let t=[],r=n.map((o,a)=>{let c={body:{text:o.body&&o.body.length>0?o.body:" "}};o.buttons&&o.buttons.length>0&&(c.nativeFlowMessage={buttons:$t(o.buttons),messageParamsJson:""}),o.footer&&o.footer.length>0&&(c.footer={text:o.footer});let d=o.image?{kind:"image",src:o.image}:o.video?{kind:"video",src:o.video}:void 0;return (o.title&&o.title.length>0||o.subtitle&&o.subtitle.length>0||d)&&(c.header={title:o.title??"",subtitle:o.subtitle??"",hasMediaAttachment:d!==void 0}),d&&t.push({...d,index:a}),c}),s={body:{text:e?.text&&e.text.length>0?e.text:" "},carouselMessage:{cards:r}};return t.length>0?{[N]:{interactiveMessage:s},[Gt]:t}:{[N]:{interactiveMessage:s}}};var si=n=>{let e=[],t="",r=0,s=1,i=0,o=0,a=[];for(let c=0;c<n.length;c++)if(n[c]==="["&&n[c-1]!=="\\")a.push(c);else if(n[c]==="]"&&(n[c+1]==="("||n[c+1]==="<")){let d=a.pop();if(d==null)continue;let l=n[c+1],u=l==="("?")":">",w=l==="<",S=c+2,v=1;for(;S<n.length&&v>0;)n[S]===l&&n[S-1]!=="\\"?v++:n[S]===u&&n[S-1]!=="\\"&&v--,S++;if(v>0)continue;let C=n.slice(d+1,c).trim(),y=n.slice(c+2,S-1).trim(),p,m;if(w){let[A="",E="",de="",Bt="",Ft=""]=C.split("|").map(Wt=>Wt.trim());p=`zaileys_LATEX_${o++}`,m=`{{${p}}}${A||"image"}{{/${p}}}`,e.push({type:"latex",ie:{key:p,text:A,url:y,width:E,height:de,font_height:Bt,padding:Ft}});}else C?(p=`zaileys_HYPERLINK_${i++}`,m=`{{${p}}}${y}{{/${p}}}`,e.push({type:"hyperlink",ie:{key:p,text:C,url:y}})):(p=`zaileys_CITATION_${s-1}`,m=`{{${p}}}${y}{{/${p}}}`,e.push({type:"citation",ie:{key:p,reference_id:String(s++),url:y}}));t+=n.slice(r,d)+m,r=S,c=S-1;}return t+=n.slice(r),{text:t,ie:e}},ii=n=>n.ie.map(({type:e,ie:t})=>e==="hyperlink"?{key:t.key,metadata:{display_name:t.text,is_trusted:true,url:t.url,__typename:"GenAIInlineLinkItem"}}:e==="latex"?{key:t.key,metadata:{latex_expression:t.text,latex_image:{url:t.url,width:Number(t.width)||100,height:Number(t.height)||100},font_height:Number(t.font_height)||83.33333333333333,padding:Number(t.padding)||15,__typename:"GenAILatexItem"}}:{key:t.key,metadata:{reference_id:Number(t.reference_id),reference_url:t.url,reference_title:t.url,reference_display_name:t.url,sources:[],__typename:"GenAISearchCitationItem"}}),oi=n=>{if(!Array.isArray(n)||n.length===0||!n.every(i=>Array.isArray(i)))throw new g("INVALID_OPTIONS","table must be a non-empty array of string rows");let[e,...t]=n,r=Math.max(e.length,...t.map(i=>i.length)),s=i=>[...i,...Array(r-i.length).fill("")];return [{is_header:true,cells:s(e)},...t.map(i=>({is_header:false,cells:s(i)}))]},ai={0:"DEFAULT",1:"KEYWORD",2:"METHOD",3:"STR",4:"NUMBER",5:"COMMENT"},ot=new Set(["break","case","catch","continue","debugger","delete","do","else","finally","for","function","if","in","instanceof","new","return","switch","this","throw","try","typeof","var","void","while","with","true","false","null","undefined","class","const","let","super","extends","export","import","from","as","default","yield","static","constructor","async","await","get","set"]),ci={javascript:ot,js:ot,typescript:ot,ts:ot},di=(n,e)=>{let t=ci[e.toLowerCase()]??new Set,r=[],s=(o,a)=>{if(!o)return;let c=r[r.length-1];c&&c.highlightType===a?c.codeContent+=o:r.push({codeContent:o,highlightType:a});},i=0;for(;i<n.length;){let o=n[i];if(/\s/.test(o)){let a=i;for(;i<n.length&&/\s/.test(n[i]);)i++;s(n.slice(a,i),0);continue}if(o==="/"&&n[i+1]==="/"){let a=i;for(i+=2;i<n.length&&n[i]!==`
2
+ `;)i++;s(n.slice(a,i),5);continue}if(o==='"'||o==="'"||o==="`"){let a=i,c=o;for(i++;i<n.length;)if(n[i]==="\\"&&i+1<n.length)i+=2;else if(n[i]===c){i++;break}else i++;s(n.slice(a,i),3);continue}if(/[0-9]/.test(o)){let a=i;for(;i<n.length&&/[0-9.]/.test(n[i]);)i++;s(n.slice(a,i),4);continue}if(/[a-zA-Z_$]/.test(o)){let a=i;for(;i<n.length&&/[a-zA-Z0-9_$]/.test(n[i]);)i++;let c=n.slice(a,i),d=0;if(t.has(c))d=1;else {let l=i;for(;l<n.length&&/\s/.test(n[l]);)l++;n[l]==="("&&(d=2);}s(c,d);continue}s(o,0),i++;}return r},D=(n,e)=>({view_model:{[Array.isArray(e)?"primitives":"primitive"]:e,__typename:`GenAI${n}LayoutViewModel`}}),li="https://github.com/zeative/zaileys",Fn=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new g("INVALID_OPTIONS","text({ rich: true }) requires non-empty markdown content");let t=[],r=[];for(let o of n)if(o.type==="text"){let a=si(o.text),c=ii(a);r.push({messageType:2,messageText:a.text}),t.push(D("Single",{text:a.text,...c.length>0?{inline_entities:c}:{},__typename:"GenAIMarkdownTextUXPrimitive"}));}else if(o.type==="code"){let a=o.language??"plaintext",c=di(o.content,a);r.push({messageType:5,codeMetadata:{codeLanguage:a,codeBlocks:c}}),t.push(D("Single",{language:a,code_blocks:c.map(d=>({content:d.codeContent,type:ai[d.highlightType]})),__typename:"GenAICodeUXPrimitive"}));}else if(o.type==="table"){let a=oi(o.rows);r.push({messageType:4,tableMetadata:{title:"",rows:a.map(c=>({items:c.cells,...c.is_header?{isHeading:true}:{}}))}}),t.push(D("Single",{rows:a,__typename:"GenATableUXPrimitive"}));}else if(o.type==="image"){let a=Array.isArray(o.url)?o.url:[o.url];if(a.length===0)throw new g("INVALID_OPTIONS","image requires at least one url");r.push({messageType:1,gridImageMetadata:{gridImageUrl:{imagePreviewUrl:a[0]},imageUrls:a.map(c=>({imagePreviewUrl:c,imageHighResUrl:c,sourceUrl:li}))}});for(let c of a)t.push(D("Single",{media:{url:c,mime_type:"image/png"},imagine_type:"IMAGE",status:{status:"READY"},__typename:"GenAIImaginePrimitive"}));}else if(o.type==="video"){let a=Array.isArray(o.url)?o.url:[o.url];if(a.length===0)throw new g("INVALID_OPTIONS","video requires at least one url");r.push({messageType:2,messageText:"[ CANNOT_LOAD_VIDEO - zaileys ]"});for(let c of a)t.push(D("Single",{media:{url:c,mime_type:"video/mp4",duration:o.duration??0},imagine_type:"ANIMATE",status:{status:"READY"},__typename:"GenAIImaginePrimitive"}));}else if(o.type==="product"){let a=Array.isArray(o.products),c=a?o.products:[o.products];if(c.length===0)throw new g("INVALID_OPTIONS","product requires at least one item");r.push({messageType:2,messageText:"[ CANNOT_LOAD_PRODUCT - zaileys ]"});let d=c.map(l=>({title:l.title,brand:l.brand??"",price:l.price??"",sale_price:l.salePrice??"",product_url:l.url??"",image:{url:l.image??""},additional_images:[{url:l.icon??""}],__typename:"GenAIProductItemCardPrimitive"}));t.push(a?D("HScroll",d):D("Single",d[0]));}else if(o.type==="reels"){let a=Array.isArray(o.reels)?o.reels:[o.reels];if(a.length===0)throw new g("INVALID_OPTIONS","reels requires at least one item");r.push({messageType:9,contentItemsMetadata:{contentType:1,itemsMetadata:a.map(c=>({reelItem:{title:c.username??"",profileIconUrl:c.profileUrl??"",thumbnailUrl:c.thumbnail??"",videoUrl:c.url??""}}))}}),t.push(D("HScroll",a.map(c=>({reels_url:c.url??"",thumbnail_url:c.thumbnail??"",creator:c.username??c.title??"",avatar_url:c.profileUrl??"",reels_title:c.title??"",likes_count:c.likes??0,shares_count:c.shares??0,view_count:c.views??0,reel_source:c.source??"IG",is_verified:!!c.verified,__typename:"GenAIReelPrimitive"}))));}else if(o.type==="post"){let a=Array.isArray(o.posts)?o.posts:[o.posts];if(a.length===0)throw new g("INVALID_OPTIONS","post requires at least one item");r.push({messageType:2,messageText:"[ CANNOT_LOAD_POST - zaileys ]"}),t.push(D("HScroll",a.map(c=>({title:c.title??"",subtitle:c.subtitle??"",username:c.username??"",profile_picture_url:c.profileUrl??"",is_verified:!!c.verified,thumbnail_url:c.thumbnail??"",post_caption:c.caption??"",likes_count:c.likes??0,comments_count:c.comments??0,shares_count:c.shares??0,post_url:c.url??"",post_deeplink:c.deeplink??"",source_app:c.source??"INSTAGRAM",footer_label:c.footer??"",footer_icon:c.icon??"",is_carousel:a.length>1,orientation:c.orientation??"LANDSCAPE",post_type:c.postType??"VIDEO",__typename:"GenAIPostPrimitive"}))));}else if(o.type==="tip")r.push({messageType:2,messageText:o.text}),t.push(D("Single",{text:o.text,__typename:"GenAIMetadataTextPrimitive"}));else {let a=Array.isArray(o.prompts)?o.prompts:[o.prompts];if(a.length===0)throw new g("INVALID_OPTIONS","suggest requires at least one prompt");t.push(D("ActionRow",a.map(c=>({prompt_text:c,prompt_type:"SUGGESTED_PROMPT",__typename:"GenAIFollowUpSuggestionPillPrimitive"}))));}e?.footer&&e.footer.length>0&&t.push(D("Single",{text:e.footer,__typename:"GenAIMetadataTextPrimitive"}));let s=(e?.sources??[]).map(([o,a,c])=>({source_type:"THIRD_PARTY",source_display_name:c??"",source_subtitle:"AI",source_url:a??"",favicon:{url:o??"",mime_type:"image/jpeg",width:16,height:16}})),i={messageContextInfo:{deviceListMetadata:{},deviceListMetadataVersion:2,botMetadata:{messageDisclaimerText:e?.title??"",richResponseSourcesMetadata:{sources:s}}},botForwardedMessage:{message:{richResponseMessage:{messageType:1,submessages:r,unifiedResponse:{data:Buffer.from(JSON.stringify({response_id:randomUUID(),sections:t})).toString("base64")},contextInfo:{forwardingScore:1,isForwarded:true,forwardedAiBotMessageInfo:{botJid:"0@bot"},forwardOrigin:4}}}}};return {[N]:i}};var ui=/^:::([a-zA-Z]+)\s*$/,pi=/^:::\s*$/,Wn=/^```(\w*)\s*$/,jn=/^!\[[^\]]*\]\(([^)]+)\)\s*$/,mi=/^\s*\|?\s*:?-{2,}[\s|:-]*$/,at=n=>n.split("|").map(e=>e.trim()),Vt=n=>{let e={};for(let t of at(n)){let r=t.indexOf(":");if(r===-1)continue;let s=t.slice(0,r).trim().toLowerCase(),i=t.slice(r+1).trim();s.length>0&&(e[s]=i);}return e},te=n=>{if(n===void 0||n.trim().length===0)return;let e=Number(n);return Number.isNaN(e)?void 0:e},qn=n=>n==="true"||n==="1"||n==="yes",Un=n=>{let e=n.trim();return e.startsWith("|")&&(e=e.slice(1)),e.endsWith("|")&&(e=e.slice(0,-1)),e.split("|").map(t=>t.trim())},gi=n=>{let e=Vt(n),t=e.title;if(t===void 0||t.length===0)return null;let r={title:t};return e.price&&(r.price=e.price),e.sale&&(r.salePrice=e.sale),e.saleprice&&(r.salePrice=e.saleprice),e.brand&&(r.brand=e.brand),e.url&&(r.url=e.url),e.image&&(r.image=e.image),e.icon&&(r.icon=e.icon),r},fi=n=>{let e=Vt(n),t={};e.user&&(t.username=e.user),e.username&&(t.username=e.username),e.title&&(t.title=e.title),e.profile&&(t.profileUrl=e.profile),e.thumb&&(t.thumbnail=e.thumb),e.url&&(t.url=e.url);let r=te(e.likes);r!==void 0&&(t.likes=r);let s=te(e.shares);s!==void 0&&(t.shares=s);let i=te(e.views);return i!==void 0&&(t.views=i),e.source&&(t.source=e.source),"verified"in e&&(t.verified=qn(e.verified)),t},hi=n=>{let e=Vt(n),t={};e.user&&(t.username=e.user),e.username&&(t.username=e.username),e.title&&(t.title=e.title),e.subtitle&&(t.subtitle=e.subtitle),e.profile&&(t.profileUrl=e.profile),e.thumb&&(t.thumbnail=e.thumb),e.caption&&(t.caption=e.caption);let r=te(e.likes);r!==void 0&&(t.likes=r);let s=te(e.comments);s!==void 0&&(t.comments=s);let i=te(e.shares);return i!==void 0&&(t.shares=i),e.url&&(t.url=e.url),e.source&&(t.source=e.source),e.footer&&(t.footer=e.footer),e.icon&&(t.icon=e.icon),"verified"in e&&(t.verified=qn(e.verified)),t},yi=(n,e)=>{let t=e.map(r=>r.replace(/^[-*]\s*/,"").trim()).filter(r=>r.length>0);if(n==="suggest"){let r=t.flatMap(s=>at(s)).filter(s=>s.length>0);return r.length>0?{type:"suggest",prompts:r}:null}if(n==="tip")return t.length>0?{type:"tip",text:t.join(`
3
+ `)}:null;if(n==="image")return t.length>0?{type:"image",url:t.length===1?t[0]:t}:null;if(n==="video"){if(t.length===0)return null;let r=t.map(o=>at(o)[0]??"").filter(o=>o.length>0);if(r.length===0)return null;let s=te(at(t[0])[1]),i={type:"video",url:r.length===1?r[0]:r};return s!==void 0&&(i.duration=s),i}if(n==="product"){let r=t.map(gi).filter(s=>s!==null);return r.length>0?{type:"product",products:r.length===1?r[0]:r}:null}if(n==="reels"){let r=t.map(fi);return r.length>0?{type:"reels",reels:r}:null}if(n==="post"){let r=t.map(hi);return r.length>0?{type:"post",posts:r}:null}return null},Kn=n=>{let e=n.replace(/\r\n/g,`
4
4
  `).split(`
5
5
  `),t=[],r=[],s=()=>{let o=r.join(`
6
- `).trim();o.length>0&&t.push({type:"text",text:o}),r=[];},i=0;for(;i<e.length;){let o=e[i],a=Bi.exec(o);if(a){s();let u=[];for(i++;i<e.length&&!Fi.test(e[i]);)u.push(e[i]),i++;i++;let w=Ki(a[1].toLowerCase(),u);w&&t.push(w);continue}let c=rr.exec(o);if(c){s();let u=[];for(i++;i<e.length&&!rr.test(e[i]);)u.push(e[i]),i++;i++;let w=c[1]&&c[1].length>0?c[1]:void 0;t.push(w?{type:"code",language:w,content:u.join(`
6
+ `).trim();o.length>0&&t.push({type:"text",text:o}),r=[];},i=0;for(;i<e.length;){let o=e[i],a=ui.exec(o);if(a){s();let u=[];for(i++;i<e.length&&!pi.test(e[i]);)u.push(e[i]),i++;i++;let w=yi(a[1].toLowerCase(),u);w&&t.push(w);continue}let c=Wn.exec(o);if(c){s();let u=[];for(i++;i<e.length&&!Wn.test(e[i]);)u.push(e[i]),i++;i++;let w=c[1]&&c[1].length>0?c[1]:void 0;t.push(w?{type:"code",language:w,content:u.join(`
7
7
  `)}:{type:"code",content:u.join(`
8
- `)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&Wi.test(d)){s();let u=[ir(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)u.push(ir(e[i])),i++;t.push({type:"table",rows:u});continue}let l=sr.exec(o);if(l){s();let u=[l[1]];for(i++;i<e.length;){let w=sr.exec(e[i]);if(!w)break;u.push(w[1]),i++;}t.push({type:"image",url:u.length===1?u[0]:u});continue}r.push(o),i++;}return s(),t};var cr=(n,e)=>{if(typeof n!="string"||!n.trimStart().startsWith("BEGIN:VCARD"))throw new f("INVALID_OPTIONS","contact() requires a vcard string starting with BEGIN:VCARD");let t={contacts:[{vcard:n}]};return {contacts:t}};var dr=async(n,e)=>{if(typeof e?.fileName!="string"||e.fileName.trim().length===0)throw new f("INVALID_OPTIONS","document() requires a non-empty fileName");let{buffer:t,mime:r}=await I(n),s={document:t,fileName:e.fileName,mimetype:e.mimetype??r};return e.caption!==void 0&&(s.caption=e.caption),s};var lr=(n,e)=>{let t=n instanceof Date?n:new Date(n);if(Number.isNaN(t.getTime()))throw new f("INVALID_OPTIONS",`event() ${e} must be a valid Date or epoch ms`);return new Date(Math.floor(t.getTime()/1e3)*1e3)},ur=n=>{if(n==null||typeof n.name!="string"||n.name.trim().length===0)throw new f("INVALID_OPTIONS","event() requires a non-empty name");return {event:{name:n.name,startDate:lr(n.startAt,"startAt"),...n.description!==void 0?{description:n.description}:{},...n.endAt!==void 0?{endDate:lr(n.endAt,"endAt")}:{},...n.call!==void 0?{call:n.call}:{},...n.canceled!==void 0?{isCancelled:n.canceled}:{},...n.location!==void 0?{location:{degreesLatitude:n.location.latitude,degreesLongitude:n.location.longitude,...n.location.name!==void 0?{name:n.location.name}:{},...n.location.address!==void 0?{address:n.location.address}:{}}}:{}}}};var pr=n=>{if(n==null||typeof n.jid!="string"||!n.jid.endsWith("@g.us"))throw new f("INVALID_OPTIONS","groupInvite() requires a group jid ending in @g.us");if(typeof n.code!="string"||n.code.trim().length===0)throw new f("INVALID_OPTIONS","groupInvite() requires an invite code");let e={inviteCode:n.code,inviteExpiration:n.expiresAt??Math.floor(Date.now()/1e3)+3*86400,groupJid:n.jid,groupName:n.subject??"",caption:n.caption??""};return n.thumbnail!==void 0&&(e.jpegThumbnail=n.thumbnail),{[_]:{groupInviteMessage:e}}};var mr=10,fr=n=>{if(typeof n?.buttonText!="string"||n.buttonText.trim().length===0)throw new f("INVALID_OPTIONS","list() requires a non-empty buttonText");if(!Array.isArray(n.sections)||n.sections.length===0)throw new f("INVALID_OPTIONS","list() requires at least one section");let e=0,t=new Set,r=n.sections.map(a=>{if(!Array.isArray(a.rows)||a.rows.length===0)throw new f("INVALID_OPTIONS","each list section requires at least one row");let c=a.rows.map(d=>{if(typeof d.id!="string"||d.id.length===0)throw new f("INVALID_OPTIONS","list row id must be a non-empty string");if(typeof d.title!="string"||d.title.trim().length===0)throw new f("INVALID_OPTIONS","list row title must be a non-empty string");if(t.has(d.id))throw new f("INVALID_OPTIONS",`duplicate list row id: ${d.id}`);return t.add(d.id),e+=1,{header:"",title:d.title,description:d.description??"",id:d.id}});return {title:a.title,highlight_label:"",rows:c}});if(e>mr)throw new f("INVALID_OPTIONS",`list() accepts at most ${mr} rows total`);let s={name:"single_select",buttonParamsJson:JSON.stringify({title:n.buttonText,sections:r})},i={body:{text:n.description&&n.description.length>0?n.description:" "},nativeFlowMessage:{buttons:[s],messageParamsJson:""}};return n.footerText&&n.footerText.length>0&&(i.footer={text:n.footerText}),n.title&&n.title.length>0&&(i.header={title:n.title,subtitle:"",hasMediaAttachment:false}),{[_]:{interactiveMessage:i}}};var gr=(n,e,t)=>{if(typeof n!="number"||Number.isNaN(n)||n<-90||n>90)throw new f("INVALID_OPTIONS",`location() latitude must be within -90..90, got ${String(n)}`);if(typeof e!="number"||Number.isNaN(e)||e<-180||e>180)throw new f("INVALID_OPTIONS",`location() longitude must be within -180..180, got ${String(e)}`);let r={degreesLatitude:n,degreesLongitude:e};return t?.name!==void 0&&(r.name=t.name),t?.address!==void 0&&(r.address=t.address),{location:r}};var hr=2,yr=12,wr=(n,e,t)=>{if(typeof n!="string"||n.trim().length===0)throw new f("EMPTY_CONTENT","poll() requires a non-empty question");if(!Array.isArray(e)||e.length<hr)throw new f("INVALID_OPTIONS",`poll() requires a minimum of ${hr} options`);if(e.length>yr)throw new f("INVALID_OPTIONS",`poll() accepts a maximum of ${yr} options`);let r=new Set;for(let i of e){if(typeof i!="string"||i.trim().length===0)throw new f("INVALID_OPTIONS","poll options must be non-empty strings");if(r.has(i))throw new f("INVALID_OPTIONS",`duplicate poll options: ${i}`);r.add(i);}return {poll:{name:n,values:e,selectableCount:t?.multipleChoice?e.length:1}}};var vr=async n=>{if(n==null||typeof n.title!="string"||n.title.trim().length===0)throw new f("INVALID_OPTIONS","product() requires a non-empty title");if(typeof n.businessOwnerId!="string"||n.businessOwnerId.length===0)throw new f("INVALID_OPTIONS","product() requires businessOwnerId");let{buffer:e}=await I(n.image),t={productImage:e,title:n.title};n.productId!==void 0&&(t.productId=n.productId),n.description!==void 0&&(t.description=n.description),n.currency!==void 0&&(t.currencyCode=n.currency),n.price!==void 0&&(t.priceAmount1000=Math.round(n.price*1e3)),n.retailerId!==void 0&&(t.retailerId=n.retailerId),n.url!==void 0&&(t.url=n.url);let r={product:t,businessOwnerJid:n.businessOwnerId};return n.body!==void 0&&(r.body=n.body),n.footer!==void 0&&(r.footer=n.footer),r};var Mr=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new ne(t).sticker.create();}catch(i){throw new f("MEDIA_LOAD_FAILED",`sticker() conversion failed: ${i.message}`,{cause:i})}return {sticker:r,isAnimated:e?.animated??false}};var Sr=3,Ar=n=>{if(typeof n?.body!="string"||n.body.trim().length===0)throw new f("INVALID_OPTIONS","template() requires a non-empty body");if(!Array.isArray(n.buttons)||n.buttons.length===0)throw new f("INVALID_OPTIONS","template() requires at least one button");if(n.buttons.length>Sr)throw new f("INVALID_OPTIONS",`template() accepts at most ${Sr} buttons`);let t={text:`${n.header&&n.header.length>0?`*${n.header}*
8
+ `)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&mi.test(d)){s();let u=[Un(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)u.push(Un(e[i])),i++;t.push({type:"table",rows:u});continue}let l=jn.exec(o);if(l){s();let u=[l[1]];for(i++;i<e.length;){let w=jn.exec(e[i]);if(!w)break;u.push(w[1]),i++;}t.push({type:"image",url:u.length===1?u[0]:u});continue}r.push(o),i++;}return s(),t};var Jn=(n,e)=>{if(typeof n!="string"||!n.trimStart().startsWith("BEGIN:VCARD"))throw new g("INVALID_OPTIONS","contact() requires a vcard string starting with BEGIN:VCARD");let t={contacts:[{vcard:n}]};return {contacts:t}};var $n=async(n,e)=>{if(typeof e?.fileName!="string"||e.fileName.trim().length===0)throw new g("INVALID_OPTIONS","document() requires a non-empty fileName");let{buffer:t,mime:r}=await I(n),s={document:t,fileName:e.fileName,mimetype:e.mimetype??r};return e.caption!==void 0&&(s.caption=e.caption),s};var Gn=(n,e)=>{let t=n instanceof Date?n:new Date(n);if(Number.isNaN(t.getTime()))throw new g("INVALID_OPTIONS",`event() ${e} must be a valid Date or epoch ms`);return new Date(Math.floor(t.getTime()/1e3)*1e3)},Vn=n=>{if(n==null||typeof n.name!="string"||n.name.trim().length===0)throw new g("INVALID_OPTIONS","event() requires a non-empty name");return {event:{name:n.name,startDate:Gn(n.startAt,"startAt"),...n.description!==void 0?{description:n.description}:{},...n.endAt!==void 0?{endDate:Gn(n.endAt,"endAt")}:{},...n.call!==void 0?{call:n.call}:{},...n.canceled!==void 0?{isCancelled:n.canceled}:{},...n.location!==void 0?{location:{degreesLatitude:n.location.latitude,degreesLongitude:n.location.longitude,...n.location.name!==void 0?{name:n.location.name}:{},...n.location.address!==void 0?{address:n.location.address}:{}}}:{}}}};var Hn=n=>{if(n==null||typeof n.jid!="string"||!n.jid.endsWith("@g.us"))throw new g("INVALID_OPTIONS","groupInvite() requires a group jid ending in @g.us");if(typeof n.code!="string"||n.code.trim().length===0)throw new g("INVALID_OPTIONS","groupInvite() requires an invite code");let e={inviteCode:n.code,inviteExpiration:n.expiresAt??Math.floor(Date.now()/1e3)+3*86400,groupJid:n.jid,groupName:n.subject??"",caption:n.caption??""};return n.thumbnail!==void 0&&(e.jpegThumbnail=n.thumbnail),{[N]:{groupInviteMessage:e}}};var zn=10,Yn=n=>{if(typeof n?.buttonText!="string"||n.buttonText.trim().length===0)throw new g("INVALID_OPTIONS","list() requires a non-empty buttonText");if(!Array.isArray(n.sections)||n.sections.length===0)throw new g("INVALID_OPTIONS","list() requires at least one section");let e=0,t=new Set,r=n.sections.map(a=>{if(!Array.isArray(a.rows)||a.rows.length===0)throw new g("INVALID_OPTIONS","each list section requires at least one row");let c=a.rows.map(d=>{if(typeof d.id!="string"||d.id.length===0)throw new g("INVALID_OPTIONS","list row id must be a non-empty string");if(typeof d.title!="string"||d.title.trim().length===0)throw new g("INVALID_OPTIONS","list row title must be a non-empty string");if(t.has(d.id))throw new g("INVALID_OPTIONS",`duplicate list row id: ${d.id}`);return t.add(d.id),e+=1,{header:"",title:d.title,description:d.description??"",id:d.id}});return {title:a.title,highlight_label:"",rows:c}});if(e>zn)throw new g("INVALID_OPTIONS",`list() accepts at most ${zn} rows total`);let s={name:"single_select",buttonParamsJson:JSON.stringify({title:n.buttonText,sections:r})},i={body:{text:n.description&&n.description.length>0?n.description:" "},nativeFlowMessage:{buttons:[s],messageParamsJson:""}};return n.footerText&&n.footerText.length>0&&(i.footer={text:n.footerText}),n.title&&n.title.length>0&&(i.header={title:n.title,subtitle:"",hasMediaAttachment:false}),{[N]:{interactiveMessage:i}}};var Zn=(n,e,t)=>{if(typeof n!="number"||Number.isNaN(n)||n<-90||n>90)throw new g("INVALID_OPTIONS",`location() latitude must be within -90..90, got ${String(n)}`);if(typeof e!="number"||Number.isNaN(e)||e<-180||e>180)throw new g("INVALID_OPTIONS",`location() longitude must be within -180..180, got ${String(e)}`);let r={degreesLatitude:n,degreesLongitude:e};return t?.name!==void 0&&(r.name=t.name),t?.address!==void 0&&(r.address=t.address),{location:r}};var Xn=2,Qn=12,er=(n,e,t)=>{if(typeof n!="string"||n.trim().length===0)throw new g("EMPTY_CONTENT","poll() requires a non-empty question");if(!Array.isArray(e)||e.length<Xn)throw new g("INVALID_OPTIONS",`poll() requires a minimum of ${Xn} options`);if(e.length>Qn)throw new g("INVALID_OPTIONS",`poll() accepts a maximum of ${Qn} options`);let r=new Set;for(let i of e){if(typeof i!="string"||i.trim().length===0)throw new g("INVALID_OPTIONS","poll options must be non-empty strings");if(r.has(i))throw new g("INVALID_OPTIONS",`duplicate poll options: ${i}`);r.add(i);}return {poll:{name:n,values:e,selectableCount:t?.multipleChoice?e.length:1}}};var tr=async n=>{if(n==null||typeof n.title!="string"||n.title.trim().length===0)throw new g("INVALID_OPTIONS","product() requires a non-empty title");if(typeof n.businessOwnerId!="string"||n.businessOwnerId.length===0)throw new g("INVALID_OPTIONS","product() requires businessOwnerId");let{buffer:e}=await I(n.image),t={productImage:e,title:n.title};n.productId!==void 0&&(t.productId=n.productId),n.description!==void 0&&(t.description=n.description),n.currency!==void 0&&(t.currencyCode=n.currency),n.price!==void 0&&(t.priceAmount1000=Math.round(n.price*1e3)),n.retailerId!==void 0&&(t.retailerId=n.retailerId),n.url!==void 0&&(t.url=n.url);let r={product:t,businessOwnerJid:n.businessOwnerId};return n.body!==void 0&&(r.body=n.body),n.footer!==void 0&&(r.footer=n.footer),r};var nr=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new ee(t).sticker.create();}catch(i){throw new g("MEDIA_LOAD_FAILED",`sticker() conversion failed: ${i.message}`,{cause:i})}return {sticker:r,isAnimated:e?.animated??false}};var rr=3,sr=n=>{if(typeof n?.body!="string"||n.body.trim().length===0)throw new g("INVALID_OPTIONS","template() requires a non-empty body");if(!Array.isArray(n.buttons)||n.buttons.length===0)throw new g("INVALID_OPTIONS","template() requires at least one button");if(n.buttons.length>rr)throw new g("INVALID_OPTIONS",`template() accepts at most ${rr} buttons`);let t={text:`${n.header&&n.header.length>0?`*${n.header}*
9
9
 
10
- `:""}${n.body}`};return n.footer!==void 0&&(t.footer=n.footer),ft(n.buttons,t)};var yt=n=>{if(typeof n!="string"||n.trim().length===0)throw new f("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var br=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var Gi=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],H=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r,s){return new n(e,br(t,r,s))}to(e){return this.internal.recipient=e,delete this.internal.resolveRecipient,this}text(e,t){return t?.rich===true?this.internal.content=nr(ar(e),t):this.internal.content=yt(e),this}image(e,t){return this.internal.pendingContent=me(e,t),this}videoNote(e,t){return this.internal.pendingContent=Q(e,{...t,ptv:true}),this}video(e,t){return this.internal.pendingContent=Q(e,t),this}audio(e,t){return this.internal.pendingContent=Xn(e,t),this}document(e,t){return this.internal.pendingContent=dr(e,t),this}sticker(e,t){return this.internal.pendingContent=Mr(e,t),this}buttons(e,t){return this.internal.content=ft(e,t),this}carousel(e,t){return this.internal.content=tr(e,t),this}list(e){return this.internal.content=fr(e),this}poll(e,t,r){return this.internal.content=wr(e,t,r),this}location(e,t,r){return this.internal.content=gr(e,t,r),this}contact(e){return this.internal.content=cr(e),this}template(e){return this.internal.content=Ar(e),this}event(e){return this.internal.content=ur(e),this}groupInvite(e){return this.internal.content=pr(e),this}product(e){return this.internal.pendingContent=vr(e),this}requestPhoneNumber(){return this.internal.content={requestPhoneNumber:{}},this}sharePhoneNumber(){return this.internal.content={sharePhoneNumber:{}},this}limitSharing(e=true){return this.internal.content={limitSharing:e},this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new f("INVALID_OPTIONS","reply() requires a quoted message or key");let t="key"in e&&e.key!=null;return this.internal.quoted=t?e:{key:e},this}mentions(e){if(e.length===0)throw new f("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new f("INVALID_OPTIONS",`invalid jid: ${String(r)}`);let t=new Set([...this.internal.mentions??[],...e]);return this.internal.mentions=[...t],this}mentionAll(){return this.internal.mentionAll=true,this}disappearing(e){if(!Number.isInteger(e)||e<=0)throw new f("INVALID_OPTIONS","disappearing() requires a positive integer duration");return this.internal.disappearingSeconds=e,this}then(e,t){return (async()=>{if(this.internal.resolveRecipient&&(this.internal.recipient=await this.internal.resolveRecipient(this.internal.recipient),delete this.internal.resolveRecipient),this.internal.albumItems){let d={recipient:this.internal.recipient};return this.internal.quoted!==void 0&&(d.quoted=this.internal.quoted),this.internal.mentions!==void 0&&(d.mentions=this.internal.mentions),this.internal.mentionAll!==void 0&&(d.mentionAll=this.internal.mentionAll),this.internal.disappearingSeconds!==void 0&&(d.disappearingSeconds=this.internal.disappearingSeconds),Fn(this.socket,this.internal.recipient,this.internal.albumItems,d)}if(this.internal.pendingContent&&(this.internal.content=await this.internal.pendingContent),!this.internal.content)throw new f("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[_];if(i!==void 0){let d=s[Qt],l=s[tn];return this.sendRelay(i,d,l)}let o=this.internal.content;this.internal.mentions&&this.internal.mentions.length>0&&(o.mentions=this.internal.mentions),this.internal.mentionAll&&(o.mentionAll=true);let a={};this.internal.quoted&&(a.quoted=this.internal.quoted),this.internal.disappearingSeconds!==void 0&&(a.ephemeralExpiration=this.internal.disappearingSeconds);let c;try{c=await this.socket.sendMessage(this.internal.recipient,o,a);}catch(d){throw new f("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new f("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await I(t.src),s=await prepareWAMessageMedia({[t.kind]:r},{upload:this.socket.waUploadToServer});e.hasMediaAttachment=true,t.kind==="image"&&s.imageMessage&&(e.imageMessage=s.imageMessage),t.kind==="video"&&s.videoMessage&&(e.videoMessage=s.videoMessage);}async sendRelay(e,t,r){let s=this.socket.relayMessage;if(typeof s!="function")throw new f("SEND_FAILED","socket does not support relayMessage (interactive content)");if(this.socket.waUploadToServer!==void 0)try{let u=e.interactiveMessage?.header;t!==void 0&&u&&await this.uploadHeaderMedia(u,t);let w=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&w)for(let M of r){let v=w[M.index]?.header;v&&await this.uploadHeaderMedia(v,M);}}catch(u){throw new f("SEND_FAILED","interactive media upload failed",{cause:u})}let o={userJid:this.socket.user?.id??""},a=this.internal.quoted;a!==void 0&&a.message!=null&&(o.quoted=a);let c=generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new f("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:Gi}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new f("SEND_FAILED","socket relayMessage rejected",{cause:u})}return this.internal.recordSent?.(c),c.key}};var ke=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=yt(e),this}image(e,t){return this.pendingContent=me(e,t),this}video(e,t){return this.pendingContent=Q(e,t),this}then(e,t){return this.send().then(e,t)}async send(){let e=this.key.remoteJid;if(typeof e!="string"||e.length===0)throw new f("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new f("EMPTY_CONTENT","edit() requires a content method before await");let t={...this.content,edit:this.key},r;try{r=await this.socket.sendMessage(e,t);}catch(s){throw new f("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new f("SEND_FAILED","socket returned no message key");return r.key}};var rn=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new f("INVALID_OPTIONS","message key is missing remoteJid");return e},sn=n=>{if(!n?.key)throw new f("SEND_FAILED","socket returned no message key");return n.key},on=async(n,e,t={})=>{let r=rn(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new f("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},an=async(n,e,t)=>{let r=rn(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return sn(s)},cn=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new f("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return sn(i)},wt=async(n,e,t,r={})=>{let s=rn(e),i={pin:e,type:t?1:2,time:r.duration??86400},o=await n.sendMessage(s,i);return sn(o)};var Vi=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,Te=n=>Vi.test(n),dn=async(n,e,t,r=Hi)=>{if(Te(e))return e;let s=t.get(e);if(s!==void 0)return s;let i=r.get(e);if(i!==void 0)return i;let o=(async()=>{let c=(await n.onWhatsApp(e))?.find(d=>d.exists&&d.jid);if(!c)throw new f("USERNAME_NOT_FOUND",`username "${e}" not found`);return t.set(e,c.jid),c.jid})();r.set(e,o);try{return await o}finally{r.delete(e);}},Hi=new Map;var k=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysDomainError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Oe=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}mapParticipants(e){return e.map(t=>({jid:t.jid,status:t.status}))}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("group.create",()=>this.requireSocket().groupCreate(e,t))}async addMember(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"add"));return this.mapParticipants(r)}async removeMember(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"remove"));return this.mapParticipants(r)}async promote(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"promote"));return this.mapParticipants(r)}async demote(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"demote"));return this.mapParticipants(r)}async updateSubject(e,t){await this.requireSocket().groupUpdateSubject(e,t);}async updateDescription(e,t){await this.requireSocket().groupUpdateDescription(e,t);}async leave(e){await this.requireSocket().groupLeave(e);}async metadata(e){return this.requireSocket().groupMetadata(e)}async tagMember(e,t,r){await this.requireSocket().updateMemberLabel(e,r);}async inviteCode(e){let t=await this.requireSocket().groupInviteCode(e);if(!t)throw new k("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new k("OPERATION_FAILED","invite code unavailable");return t}async acceptInvite(e){let t=await this.run("group.join",()=>this.requireSocket().groupAcceptInvite(e));if(!t)throw new k("OPERATION_FAILED","invite acceptance failed");return t}async toggleEphemeral(e,t){await this.requireSocket().groupToggleEphemeral(e,t);}async setting(e,t){await this.requireSocket().groupSettingUpdate(e,t);}async list(){let e=await this.requireSocket().groupFetchAllParticipating();return Object.values(e)}async inviteInfo(e){return this.requireSocket().groupGetInviteInfo(e)}async joinRequests(e){return this.requireSocket().groupRequestParticipantsList(e)}async approveJoin(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupRequestParticipantsUpdate(e,t,"approve"));return this.mapParticipants(r)}async rejectJoin(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupRequestParticipantsUpdate(e,t,"reject"));return this.mapParticipants(r)}async joinApproval(e,t){await this.requireSocket().groupJoinApprovalMode(e,t?"on":"off");}async memberAddMode(e,t){await this.requireSocket().groupMemberAddMode(e,t?"admin_add":"all_member_add");}};var Ie=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async set(e){let t=this.requireSocket();if(e.lastSeen!==void 0&&await t.updateLastSeenPrivacy(e.lastSeen),e.online!==void 0&&await t.updateOnlinePrivacy(e.online),e.profile!==void 0&&await t.updateProfilePicturePrivacy(e.profile),e.status!==void 0&&await t.updateStatusPrivacy(e.status),e.readReceipts!==void 0){let r=typeof e.readReceipts=="boolean"?e.readReceipts?"all":"none":e.readReceipts;await t.updateReadReceiptsPrivacy(r);}e.groupAdd!==void 0&&await t.updateGroupsAddPrivacy(e.groupAdd);}async get(){return this.requireSocket().fetchPrivacySettings()}async block(e){await this.requireSocket().updateBlockStatus(e,"block");}async unblock(e){await this.requireSocket().updateBlockStatus(e,"unblock");}async blocklist(){return this.requireSocket().fetchBlocklist()}async disappearingMode(e){await this.requireSocket().updateDefaultDisappearingMode(e);}};var xe=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("newsletter.create",async()=>{let r=this.requireSocket(),s=await r.newsletterCreate(e,t?.description);return t?.picture&&await r.newsletterUpdatePicture(s.id,t.picture),s})}async follow(e){await this.run("newsletter.follow",()=>this.requireSocket().newsletterFollow(e));}async unfollow(e){await this.run("newsletter.follow",()=>this.requireSocket().newsletterUnfollow(e));}async metadata(e){let r=await this.requireSocket().newsletterMetadata("jid",e);if(!r)throw new k("NEWSLETTER_NOT_FOUND",`newsletter ${e} not found`);return r}async updateName(e,t){await this.requireSocket().newsletterUpdateName(e,t);}async updateDescription(e,t){await this.requireSocket().newsletterUpdateDescription(e,t);}async updatePicture(e,t){await this.requireSocket().newsletterUpdatePicture(e,t);}async mute(e){await this.requireSocket().newsletterMute(e);}async unmute(e){await this.requireSocket().newsletterUnmute(e);}async delete(e){await this.requireSocket().newsletterDelete(e);}async removePicture(e){await this.requireSocket().newsletterRemovePicture(e);}async react(e,t,r){await this.requireSocket().newsletterReactMessage(e,t,r);}async unreact(e,t){await this.requireSocket().newsletterReactMessage(e,t);}async subscribers(e){return this.requireSocket().newsletterSubscribers(e)}async messages(e,t=50,r){return this.requireSocket().newsletterFetchMessages(e,t,r?.since,r?.after)}async adminCount(e){return this.requireSocket().newsletterAdminCount(e)}async changeOwner(e,t){await this.requireSocket().newsletterChangeOwner(e,t);}async demote(e,t){await this.requireSocket().newsletterDemote(e,t);}};var Re=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("community.create",()=>this.requireSocket().communityCreate(e,t))}async createGroup(e,t,r){return this.run("community.create",()=>this.requireSocket().communityCreateGroup(e,t,r))}async linkGroup(e,t){await this.requireSocket().communityLinkGroup(t,e);}async unlinkGroup(e,t){await this.requireSocket().communityUnlinkGroup(t,e);}async subGroups(e){return (await this.requireSocket().communityFetchLinkedGroups(e)).linkedGroups}async leave(e){await this.requireSocket().communityLeave(e);}async updateSubject(e,t){await this.requireSocket().communityUpdateSubject(e,t);}async updateDescription(e,t){await this.requireSocket().communityUpdateDescription(e,t);}async inviteCode(e){return this.requireSocket().communityInviteCode(e)}async revokeInvite(e){return this.requireSocket().communityRevokeInvite(e)}async acceptInvite(e){return this.run("community.join",()=>this.requireSocket().communityAcceptInvite(e))}async metadata(e){return this.requireSocket().communityMetadata(e)}async list(){return Object.values(await this.requireSocket().communityFetchAllParticipating())}async inviteInfo(e){return this.requireSocket().communityGetInviteInfo(e)}async toggleEphemeral(e,t){await this.requireSocket().communityToggleEphemeral(e,t);}async setting(e,t){await this.requireSocket().communitySettingUpdate(e,t);}async memberAddMode(e,t){await this.requireSocket().communityMemberAddMode(e,t?"admin_add":"all_member_add");}async joinApproval(e,t){await this.requireSocket().communityJoinApprovalMode(e,t?"on":"off");}};var Le=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async setName(e){await this.requireSocket().updateProfileName(e);}async setStatus(e){await this.requireSocket().updateProfileStatus(e);}async setPicture(e,t){await this.requireSocket().updateProfilePicture(e,t);}async removePicture(e){await this.requireSocket().removeProfilePicture(e);}async getPicture(e,t=false){return await this.requireSocket().profilePictureUrl(e,t?"image":"preview")??null}async getStatus(e){return this.requireSocket().fetchStatus(e)}};var zi=n=>{if(typeof n.remoteJid!="string"||n.remoteJid.length===0)throw new k("OPERATION_FAILED","message key is missing remoteJid");return n.remoteJid},_e=class{constructor(e,t){this.getSocket=e;this.resolveLast=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async last(e){return await this.resolveLast?.(e)??[]}async archive(e){await this.requireSocket().chatModify({archive:true,lastMessages:await this.last(e)},e);}async unarchive(e){await this.requireSocket().chatModify({archive:false,lastMessages:await this.last(e)},e);}async pin(e){await this.requireSocket().chatModify({pin:true},e);}async unpin(e){await this.requireSocket().chatModify({pin:false},e);}async mute(e,t){await this.requireSocket().chatModify({mute:t??Date.now()+365*24*60*60*1e3},e);}async unmute(e){await this.requireSocket().chatModify({mute:null},e);}async markRead(e){await this.requireSocket().chatModify({markRead:true,lastMessages:await this.last(e)},e);}async markUnread(e){await this.requireSocket().chatModify({markRead:false,lastMessages:await this.last(e)},e);}async star(e,t=true){let r=zi(e);await this.requireSocket().chatModify({star:{messages:[{id:e.id??"",fromMe:e.fromMe===true}],star:t}},r);}async unstar(e){await this.star(e,false);}async delete(e){await this.requireSocket().chatModify({delete:true,lastMessages:await this.last(e)},e);}async clear(e){await this.requireSocket().chatModify({clear:true,lastMessages:await this.last(e)},e);}};var Ne=class{constructor(e,t){this.getSocket=e;this.normalize=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async check(...e){return (await this.requireSocket().onWhatsApp(...e)??[]).map(r=>{let s={jid:r.jid,exists:r.exists};return r.lid!==void 0&&(s.lid=r.lid),s})}async exists(e){let[t]=await this.check(e);return t?.exists??false}async save(e,t){await this.requireSocket().addOrEditContact(this.normalize(e),t);}async remove(e){await this.requireSocket().removeContact(this.normalize(e));}};var De=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async profile(e){return this.requireSocket().getBusinessProfile(e)}async catalog(e={}){return this.requireSocket().getCatalog(e)}async collections(e,t){return this.requireSocket().getCollections(e,t)}async orderDetails(e,t){return this.requireSocket().getOrderDetails(e,t)}async createProduct(e){return this.requireSocket().productCreate(e)}async updateProduct(e,t){return this.requireSocket().productUpdate(e,t)}async deleteProduct(...e){return this.requireSocket().productDelete(e)}};var x=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysCommandError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Yi=n=>{let e=n[0];return e==="{"||e==="["},Zi=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Xi=n=>n===" "||n===" "||n===`
11
- `||n==="\r",Qi=n=>{let e=[],t="",r=null,s=false,i=false,o=true;for(let a=0;a<n.length;a+=1){let c=n[a];if(s){t+=c,s=false,i=true,o=false;continue}if(c==="\\"&&r!==null){s=true;continue}if(r!==null){c===r?r=null:t+=c,o=false;continue}if((c==='"'||c==="'")&&o){r=c,i=true,o=false;continue}if(Xi(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},eo=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},to=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function ln(n,e){let t=eo(n,e);if(t===null)return to(n);let r=n.slice(t.length),s=Qi(r),i={matched:true,args:[],flags:{},json:void 0,raw:n};if(s.length===0)return i.name="",i;i.name=(s[0]??"").toLowerCase();let o=false;for(let a=1;a<s.length;a+=1){let c=s[a];if(c!==void 0){if(c.startsWith("--")){let d=c.slice(2);if(d.length===0){i.args.push(c);continue}let l=d.indexOf("=");if(l!==-1){let w=d.slice(0,l),M=d.slice(l+1);i.flags[w]=M;continue}let u=s[a+1];u!==void 0&&!u.startsWith("--")?(i.flags[d]=u,a+=1):i.flags[d]=true;continue}if(!o&&Yi(c)){let d=Zi(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var Pr=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new x("INVALID_COMMAND_NAME","empty command segment in spec");return e},he=n=>n.join(" "),Be=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new x("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>Pr(a)),s=r[0],i=r.slice(1).map(a=>he(a)),o={name:he(s),aliases:i,parts:s,handler:t};for(let a of r){let c=he(a);if(this.paths.has(c))throw new x("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(he(a),o),a.length>this.maxDepth&&(this.maxDepth=a.length);this.defs.push(o);}resolve(e){if(!e.matched||e.name===void 0||e.name.length===0)return;let t=[e.name.toLowerCase(),...e.args.map(s=>s.toLowerCase())],r=Math.min(this.maxDepth,t.length);for(let s=r;s>=1;s-=1){let i=t.slice(0,s).join(" "),o=this.paths.get(i);if(o!==void 0)return {def:o,args:e.args.slice(s-1)}}}unregister(e){let t=e.split("|").map(o=>Pr(o)),r=he(t[0]),s=this.paths.get(r);if(s===void 0)return;for(let o of [s.parts,...s.aliases.map(a=>a.split(" "))])this.paths.delete(he(o));let i=this.defs.indexOf(s);i>=0&&this.defs.splice(i,1),this.maxDepth=this.defs.reduce((o,a)=>Math.max(o,a.parts.length),1);}list(){return [...this.defs]}};async function un(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new x("MIDDLEWARE_ERROR","next() called multiple times");if(r=o,o===n.length){try{await t();}catch(c){throw s.error=c,s.thrown=true,c}return}let a=n[o];try{await a(e,()=>i(o+1));}catch(c){throw s.thrown||c instanceof x?c:new x("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function pn(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=ln(s.text,n.prefixes);if(!i.matched)return;let o=n.registry.resolve(i);if(o===void 0)return;let a={command:o.def.name,args:o.args,flags:i.flags,json:i.json,raw:i.raw},c=n.buildContext(a,s);Promise.resolve(un(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let l=d instanceof x?d:new x("HANDLER_ERROR","command handler failed",{cause:d});n.logger.error(l,"command dispatch failed");});},t=n.onText(e),r=false;return {detach(){r||(r=true,t());}}}var Er=n=>n;var Fe=class{host;logger;plugins=new Map;constructor(e){this.host=e.client,this.logger=e.logger??e.client.logger;}has(e){return this.plugins.has(e)}list(){return [...this.plugins.keys()]}async loadPlugin(e,t){if(typeof e?.name!="string"||typeof e?.setup!="function"){this.logger?.warn({file:t},"plugin: invalid shape (need name + setup); skipped");return}if(this.plugins.has(e.name)){this.logger?.warn({name:e.name,file:t},"plugin: duplicate name; skipped");return}let r=[],s={client:this.host,logger:this.logger,pluginDir:te.dirname(t),command:(i,o)=>{this.host.command(i,o),r.push(()=>this.host.unregisterCommand(i));},use:i=>{this.host.use(i),r.push(()=>{this.host.unuse(i);});},on:(i,o)=>{let a=this.host.on(i,o);return r.push(a),a},once:(i,o)=>{let a=false,c=this.host.on(i,d=>{a||(a=true,c(),o(d));});return r.push(c),c}};try{let i=await e.setup(s);typeof i=="function"&&r.push(i);}catch(i){for(let o of [...r].reverse())try{await o();}catch{}this.logger?.error({err:i,name:e.name,file:t},"plugin: setup failed; skipped");return}this.plugins.set(e.name,{plugin:e,file:t,disposers:r});}async unload(e){let t=this.plugins.get(e);if(t){this.plugins.delete(e);for(let r of [...t.disposers].reverse())try{await r();}catch(s){this.logger?.warn({err:s,name:e},"plugin: disposer threw");}try{await t.plugin.onUnload?.();}catch(r){this.logger?.warn({err:r,name:e},"plugin: onUnload threw");}}}async unloadAll(){for(let e of this.list())await this.unload(e);}};var io=/\.(ts|js|mjs|cjs)$/,oo=/(\.d\.ts$|^_|[/\\]_)/;async function fn(n,e,t){let r;try{r=await promises.readdir(n,{withFileTypes:!0});}catch{return []}let s=[];for(let i of r){let o=te.join(n,i.name);t.test(i.name)||t.test(o)||(i.isDirectory()?s.push(...await fn(o,e,t)):e.test(i.name)&&s.push(o));}return s}async function kr(n,e){try{let r=await import(pathToFileURL(n).href+(e!==void 0?`?t=${e}`:"")),s=r.default??r;return s&&typeof s.name=="string"&&typeof s.setup=="function"?s:void 0}catch{return}}var We=class{dir;pattern;ignore;watchEnabled;onError;registry;logger;watcher;fileToName=new Map;bust=0;debounce;pending=new Set;flushChain=Promise.resolve();constructor(e){this.registry=e.registry,this.logger=e.logger,this.dir=te.resolve(e.options.dir??"./plugins"),this.pattern=e.options.pattern??io,this.ignore=e.options.ignore??oo,this.watchEnabled=e.options.watch!==false,this.onError=e.options.onError;}async start(){let e=await fn(this.dir,this.pattern,this.ignore);for(let t of e)await this.loadFile(t);this.watchEnabled&&this.startWatch();}async stop(){this.debounce&&clearTimeout(this.debounce),this.watcher?.close(),this.watcher=void 0,await this.flushChain,await this.registry.unloadAll(),this.fileToName.clear();}async loadFile(e){let t=await kr(e,this.bust);if(!t){let i=new Error(`failed to import plugin: ${e}`);this.onError?.(i,e),this.logger?.warn({file:e},"plugin: import failed; skipped");return}let r=this.registry.list();await this.registry.loadPlugin(t,e);let s=this.registry.list().find(i=>!r.includes(i));s&&this.fileToName.set(e,s);}startWatch(){try{this.watcher=watch(this.dir,{recursive:!0},(e,t)=>{if(t==null)return;let r=te.join(this.dir,t.toString());this.ignore.test(t.toString())||!this.pattern.test(t.toString())||(this.pending.add(r),this.debounce&&clearTimeout(this.debounce),this.debounce=setTimeout(()=>{this.flushChain=this.flushChain.then(()=>this.flush());},150),this.debounce.unref?.());});}catch(e){this.logger?.warn({err:e,dir:this.dir},"plugin: watch unavailable; hot-reload disabled");}}async flush(){let e=[...this.pending];this.pending.clear(),this.bust+=1;for(let t of e){let r=this.fileToName.get(t);r&&(await this.registry.unload(r),this.fileToName.delete(t));let s=true;try{await promises.access(t);}catch{s=false;}s&&await this.loadFile(t);}}};var O=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysAutomationError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var ao=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),se=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new O("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new O("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new O("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??ao;let r=e.burst??e.perSec;this.global={tokens:r,capacity:r,ratePerMs:e.perSec/1e3,last:this.now()},e.perJidPerSec!==void 0&&(this.perJidRatePerMs=e.perJidPerSec/1e3,this.perJidCapacity=e.perJidPerSec);}async acquire(e){await this.consume(this.global),e!==void 0&&this.perJidRatePerMs!==void 0&&await this.consume(this.bucketFor(e));}bucketFor(e){let t=this.perJid.get(e);if(t)return t;let r=this.perJidCapacity??1,s={tokens:r,capacity:r,ratePerMs:this.perJidRatePerMs??1,last:this.now()};return this.perJid.set(e,s),s}consume(e){if(this.refill(e),e.tokens>=1)return e.tokens-=1,Promise.resolve();let t=(1-e.tokens)/e.ratePerMs;return e.tokens-=1,this.sleep(t)}refill(e){let t=this.now(),r=t-e.last;r>0&&(e.tokens=Math.min(e.capacity,e.tokens+r*e.ratePerMs),e.last=t);}};var co={"group.create":6e4,"group.join":3e4,"group.participants":1e4,"group.update":3e3,"community.create":12e4,"community.join":3e4,"community.update":3e3,"newsletter.create":12e4,"newsletter.follow":2e3,"newsletter.update":3e3},lo=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function gn(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??lo,i={...co,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,l)=>{let u=i[d]??0,w=o.get(d);if(w!==void 0&&u>0){let M=u-(r()-w);M>0&&await s(M);}return o.set(d,r()),l()};return {run(d,l){if(!t)return l();let w=(a.get(d)??Promise.resolve()).then(()=>c(d,l),()=>c(d,l));return a.set(d,w.then(()=>{},()=>{})),w}}}var uo={maxRetries:0,backoffMs:()=>0},po=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Ue=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??uo,this.sleep=t.sleep??po;}add(e){return new Promise((t,r)=>{this.pending.push({run:()=>this.execute(e).then(t,r)}),this.pump();})}onIdle(){return this.active===0&&this.pending.length===0?Promise.resolve():new Promise(e=>{this.idleWaiters.push(e);})}pump(){for(;this.active<this.concurrency&&this.pending.length>0;){let e=this.pending.shift();if(!e)break;this.active++,e.run().finally(()=>{this.active--,this.pump(),this.settleIdle();});}}settleIdle(){if(this.active===0&&this.pending.length===0&&this.idleWaiters.length>0){let e=this.idleWaiters;this.idleWaiters=[];for(let t of e)t();}}async execute(e){let t=0;for(;;)try{return await e()}catch(r){if(t>=this.retry.maxRetries)throw r;t+=1,await this.sleep(this.retry.backoffMs(t));}}};var mo=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function hn(n,e,t,r={}){let s={sent:[],failed:[]};if(n.length===0)return s;let i=r.rateLimitPerSec??5,o={};t.now&&(o.now=t.now),t.sleep&&(o.sleep=t.sleep);let a=t.limiter??new se({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},l=c?new Ue({concurrency:1,retry:c},d):void 0,u=n.length,w=0;for(let M of n){await a.acquire(M);let v=()=>e(t.sendTo(M)).then(()=>{});try{l?await l.add(v):await v(),s.sent.push(M),w+=1,r.onProgress?.(w,u,M,!0);}catch(E){s.failed.push({jid:M,error:mo(E)}),w+=1,r.onProgress?.(w,u,M,false);}}return s}var fo=1e3,je=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??fo,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new O("NOT_CONNECTED","client not connected");return e}throttled(e,t){if(!this.throttleEnabled||this.minIntervalMs<=0)return false;let r=`${e}:${t??"global"}`,s=this.lastSent.get(r),i=this.now();return s!==void 0&&i-s<this.minIntervalMs?true:(this.lastSent.set(r,i),false)}async update(e,t){let r=this.requireSocket();if(!this.throttled(e,t))try{await(t===void 0?r.sendPresenceUpdate(e):r.sendPresenceUpdate(e,t));}catch(s){throw new O("PRESENCE_FAILED",`presence update '${e}' failed`,{cause:s})}}scheduleClear(e,t){let r=this.getSocket();if(!r)return;let s=setTimeout(()=>{r.sendPresenceUpdate("paused",e).catch(()=>{});},t);typeof s.unref=="function"&&s.unref();}async online(){await this.update("available");}async offline(){await this.update("unavailable");}async typing(e,t){await this.update("composing",e),t!==void 0&&this.scheduleClear(e,t);}async recording(e,t){await this.update("recording",e),t!==void 0&&this.scheduleClear(e,t);}};var ho={set:(n,e)=>setTimeout(n,e),clear:n=>clearTimeout(n)},yo=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",qe=class{store;sendSnapshot;now;timer;logger;acquire;memory=new Map;timers=new Map;constructor(e){this.store=e.store,this.sendSnapshot=e.sendSnapshot,this.now=e.now??(()=>Date.now()),this.timer=e.timer??ho,this.logger=e.logger,this.acquire=e.acquire;}async scheduleAt(e,t){let r=e.getTime();if(Number.isNaN(r))throw new O("SCHEDULE_INVALID","scheduleAt requires a valid Date");let s=await this.evaluate(t),i=randomUUID(),o={id:i,fireAt:r,recipient:s.recipient,payload:s};return await this.persist(o),this.arm(o),{id:i,cancel:()=>{this.cancel(i);}}}async loadPending(){let e=this.store.listScheduledJobs;if(!e){for(let r of this.memory.values())this.timers.has(r.id)||this.arm(r);return}let t;try{t=await e.call(this.store);}catch(r){this.logger?.warn(r,"scheduler loadPending failed");return}for(let r of t)this.timers.has(r.id)||(this.memory.set(r.id,r),this.arm(r));}dispose(){for(let e of this.timers.values())this.timer.clear(e);this.timers.clear();}cancel(e){let t=this.timers.get(e);t!==void 0&&(this.timer.clear(t),this.timers.delete(e)),this.memory.delete(e),this.remove(e);}arm(e){let t=Math.max(0,e.fireAt-this.now()),r=this.timer.set(()=>{this.fire(e);},t);this.timers.set(e.id,r);}async fire(e){if(this.timers.delete(e.id),yo(e.payload))try{this.acquire&&await this.acquire(),await this.sendSnapshot(e.payload);}catch(t){this.logger?.warn(t,"scheduled send failed; retaining job for retry");return}this.memory.delete(e.id),await this.remove(e.id);}async persist(e){let t=this.store.saveScheduledJob;if(t){await t.call(this.store,e);return}this.memory.set(e.id,e);}async remove(e){let t=this.store.deleteScheduledJob;if(t)try{await t.call(this.store,e);}catch(r){this.logger?.warn(r,"scheduler deleteScheduledJob failed");}this.memory.delete(e);}async evaluate(e){let t,r=0,s={sendMessage:async(o,a,c)=>{if(r+=1,r>1)throw new O("SCHEDULE_INVALID","scheduling multi-part messages (e.g. album) is not supported; schedule a single message");return t=c?{recipient:o,content:a,options:c}:{recipient:o,content:a},{key:{remoteJid:o,id:"scheduled-snapshot",fromMe:true}}},relayMessage:async()=>{throw new O("SCHEDULE_INVALID","scheduling interactive/relayed content is not supported; schedule a text or media message")}},i=H.create(s,"");try{await e(i);}catch(o){throw o instanceof O?o:new O("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new O("SCHEDULE_INVALID","scheduled builder produced no content");return t}};async function Tr(n,e){if(typeof n.deleteMessage!="function"||typeof n.listChats!="function")return 0;let t=await n.listChats(),r=0;for(let s of t){let i=s.id??"";if(i.length===0||e.chatFilter&&!e.chatFilter(i))continue;let a=[...await n.listMessages(i)].sort((c,d)=>Number(d.messageTimestamp??0)-Number(c.messageTimestamp??0));for(let c=0;c<a.length;c+=1){let d=a[c],l=Number(d.messageTimestamp??0),u=e.olderThan!==void 0&&l<e.olderThan,w=e.maxPerChat!==void 0&&c>=e.maxPerChat;(u||w)&&(await n.deleteMessage(d.key),r+=1);}}return r}var Ke=class{store;options;logger;now;timer;running=false;warnedUnsupported=false;disabled=false;constructor(e){this.store=e.store,this.options=e.options,this.logger=e.logger,this.now=e.now??Date.now;}get active(){return this.options.maxAgeMs!==void 0||this.options.maxPerChat!==void 0}buildPruneOptions(){let e={};return this.options.maxAgeMs!==void 0&&(e.olderThan=Math.floor((this.now()-this.options.maxAgeMs)/1e3)),this.options.maxPerChat!==void 0&&(e.maxPerChat=this.options.maxPerChat),typeof this.options.chats=="function"&&(e.chatFilter=this.options.chats),e}async runOnce(){if(!this.active||this.disabled)return 0;let e=this.buildPruneOptions();return typeof this.store.pruneMessages=="function"?this.store.pruneMessages(e):typeof this.store.deleteMessage=="function"?Tr(this.store,e):(this.disabled=true,this.warnedUnsupported||(this.warnedUnsupported=true,this.logger?.warn({code:"AUTO_DELETE_UNSUPPORTED"},"autoDelete: store implements neither pruneMessages nor deleteMessage; sweeper disabled")),0)}start(){if(!this.active||this.timer)return;let e=this.options.intervalMs??6e4;this.timer=setInterval(()=>{this.running||(this.running=true,this.runOnce().catch(t=>this.logger?.warn(t,"autoDelete sweep failed")).finally(()=>{this.running=false;}));},e),this.timer.unref?.();}stop(){this.timer&&(clearInterval(this.timer),this.timer=void 0);}};var ie="[zaileys]",wo="The saved session looks invalid or corrupted (connection keeps closing before it authenticates). Delete the auth folder (default: ./.zaileys) and run again to scan a fresh QR / request a new pairing code.";function Ir(n){switch(n.kind){case "connecting":return `${ie} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${ie} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${ie} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${ie} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${ie} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
12
- ${ie} ${wo}`:t}case "disconnect":return n.willReconnect?null:`${ie} Disconnected (${n.reason}).`;default:return null}}var Or=false,vo=["Closing session:","Closing open session","Closing stale open session","Opening session:","Removing old closed session","Migrating session to:","Session already closed","Decrypted message with closed session","Failed to decrypt message with any known session","Session error:"],Mo=n=>typeof n[0]=="string"&&vo.some(e=>n[0].startsWith(e));function xr(){if(Or)return;Or=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{Mo(r)||t(...r);};};n("info"),n("warn"),n("error");}var g=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysStoreError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Ao="./.zaileys/auth",bo=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),$e=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",Mt=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??Ao;}signal={read:async(e,t)=>{this.assertOpen();let r={};return await Promise.all(t.map(async s=>{let i=this.signalPath(e,s);try{let o=await promises.readFile(i,"utf8");r[s]=JSON.parse(o,BufferJSON.reviver);}catch(o){if($e(o))return;throw new g("STORE_READ_FAILED",`failed to read ${i}`,{cause:o})}})),r},write:async e=>{this.assertOpen();let t=[];for(let r of Object.keys(e)){let s=e[r];if(!s)continue;let i=this.signalDir(r);await promises.mkdir(i,{recursive:true});for(let o of Object.keys(s)){let a=s[o],c=this.signalPath(r,o);a===null?t.push(promises.unlink(c).catch(d=>{if(!$e(d))throw new g("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,BufferJSON.replacer)));}}await Promise.all(t);},delete:async(e,t)=>{this.assertOpen(),await Promise.all(t.map(async r=>{let s=this.signalPath(e,r);try{await promises.unlink(s);}catch(i){if(!$e(i))throw new g("STORE_WRITE_FAILED",`failed to unlink ${s}`,{cause:i})}}));},clear:async()=>{this.assertOpen(),await promises.rm(this.basePath,{recursive:true,force:true});},close:async()=>{this.closed=true;}};creds={readCreds:async()=>{this.assertOpen();try{let e=await promises.readFile(this.credsPath(),"utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){if($e(e))return;throw new g("STORE_READ_FAILED","failed to read creds.json",{cause:e})}},writeCreds:async e=>{this.assertOpen(),await promises.mkdir(this.basePath,{recursive:true}),await this.atomicWrite(this.credsPath(),JSON.stringify(e,BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await promises.unlink(this.credsPath());}catch(e){if(!$e(e))throw new g("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return te.join(this.basePath,"creds.json")}signalDir(e){return te.join(this.basePath,"signal",String(e))}signalPath(e,t){return te.join(this.signalDir(e),`${bo(t)}.json`)}async atomicWrite(e,t){let r=te.join(te.dirname(e),`tmp-${randomBytes(8).toString("hex")}`);try{await promises.writeFile(r,t,"utf8"),await promises.rename(r,e);}catch(s){throw await promises.unlink(r).catch(()=>{}),new g("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","FileAuthStore is closed")}};function Rr(n,e){let t=n.signal,s=makeCacheableSignalKeyStore({get:(o,a)=>t.read(o,a),set:o=>t.write(o),clear:()=>t.clear()},e?.logger??void 0),i={read:async(o,a)=>await s.get(o,[...a]),write:async o=>{await s.set(o);},delete:async(o,a)=>{await t.delete(o,a);let c={},d={};for(let l of a)d[l]=null;c[o]=d,await s.set(c);},clear:async()=>{let o=s.clear;typeof o=="function"?await o.call(s):await t.clear();},close:()=>t.close()};return {creds:n.creds,signal:i}}function Lr(n,e){return {get:async(t,r)=>await n.read(t,r),set:async t=>{await n.write(t);},clear:async()=>{await n.clear();}}}var Eo=429;function _r(n){if(n===Eo)return "rate-limited";switch(n){case DisconnectReason.loggedOut:return "logged-out";case DisconnectReason.forbidden:return "forbidden";case DisconnectReason.connectionLost:return "connection-lost";case DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case DisconnectReason.connectionClosed:return "connection-closed";case DisconnectReason.connectionReplaced:return "connection-replaced";case DisconnectReason.badSession:return "bad-session";case DisconnectReason.unavailableService:return "unavailable-service";case DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Ge(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function St(n){return n==="rate-limited"}function Nr(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function Dp(n){return !Ge(n)}var At={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},Co=3e5;function Dr(n={}){let e=n.enabled??At.enabled,t=n.maxQrAttempts??At.maxQrAttempts,r=n.maxPairingAttempts??At.maxPairingAttempts,s=n.pairingCooldownMs??At.pairingCooldownMs,i=0,o=0,a=0,c=w=>w<=0?0:Math.min(s*w,Co);return {evaluate:(w,M)=>{if(!e)return {allowed:true,waitMs:0,attempts:w==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(w==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let v=c(o),E=M-a;return o>0&&E<v?{allowed:false,reason:"cooldown",waitMs:v-E,attempts:o,max:r}:{allowed:true,waitMs:0,attempts:o,max:r}}return i>=t?{allowed:false,reason:"budget-exhausted",waitMs:0,attempts:i,max:t}:{allowed:true,waitMs:0,attempts:i,max:t}},record:(w,M)=>{w==="pairing"?(o+=1,a=M):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var ko=/[\s\-()+]/g;function To(n){return typeof n!="string"?"":n.replace(ko,"")}function Oo(n){if(!n||typeof n!="string"||!n.trim())throw new Error("phoneNumber is required");let e=To(n);if(!/^\d+$/.test(e))throw new Error("phoneNumber must be E.164 with country code");if(e.length<8||e.length>15)throw new Error("phoneNumber must be E.164 with country code");return e}function Br(n){let e=Oo(n.phoneNumber),t=n.ttlMs??6e4;return {phoneNumber:e,async requestCode(r){let s;try{s=await r.requestPairingCode(e);}catch(i){let o=i instanceof Error?i.message:String(i);throw new Error(`failed to request pairing code: ${o}`)}return {code:s,expiresAt:Date.now()+t}}}}function xo(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{Io.generate(n,{small:true},t=>e(t));})}async function Fr(n,e=t=>{process.stdout.write(t);}){let t=await xo(n);e(t+`
13
- `);}var ye={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function Wr(n,e){let t=n?.enabled??ye.enabled,r=n?.maxAttempts??ye.maxAttempts,s=n?.initialDelayMs??ye.initialDelayMs,i=n?.maxDelayMs??ye.maxDelayMs,o=n?.jitterFactor??ye.jitterFactor,a=n?.rateLimitedDelayMs??ye.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:w=>{if(!t||Ge(w))return null;let M=d+1;if(M>r)return null;if(d=M,St(w))return {attempt:M,delayMs:a};let v=Math.pow(2,M-1),E=Math.min(i,s*v),y=1+(c()*2-1)*o,p=E*y,m=Math.min(i,Math.max(0,p));return {attempt:M,delayMs:Math.round(m)}},reset:()=>{d=0;},get attempts(){return d}}}var Ro={idle:["connecting"],connecting:["qr-pending","pairing-pending","connected","reconnecting","disconnecting","disconnected"],"qr-pending":["connecting","connected","reconnecting","disconnecting","disconnected"],"pairing-pending":["connecting","connected","reconnecting","disconnecting","disconnected"],connected:["disconnecting","reconnecting","disconnected"],reconnecting:["connecting","disconnecting","disconnected"],disconnecting:["disconnected"],disconnected:["idle","connecting","reconnecting"]};function Ur(n="idle"){let e=n,t=new Set,r=s=>Ro[e].includes(s);return {get state(){return e},canTransition:r,transition(s){if(!r(s))throw new Error(`invalid state transition: ${e} -> ${s}`);let i=e;e=s;for(let o of t)try{o(i,s);}catch{}},onChange(s){return t.add(s),()=>{t.delete(s);}}}}var bt=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,Pt=class{messages=new Map;messagesByJid=new Map;chats=new Map;contacts=new Map;presence=new Map;boundSocket;listeners=new Map;closed=false;async saveMessage(e){this.assertOpen();let t=bt(e.key);this.messages.set(t,structuredClone(e));let r=e.key.remoteJid??"",s=this.messagesByJid.get(r);s||(s=new Set,this.messagesByJid.set(r,s)),s.add(t);}async getMessage(e){this.assertOpen();let t=this.messages.get(bt(e));return t?structuredClone(t):void 0}async listMessages(e,t){this.assertOpen();let r=this.messagesByJid.get(e);if(!r)return [];let s=[];for(let o of r){let a=this.messages.get(o);a&&s.push(a);}s.sort((o,a)=>Number(a.messageTimestamp)-Number(o.messageTimestamp));let i=s;if(typeof t?.before=="number"){let o=t.before;i=i.filter(a=>Number(a.messageTimestamp)<o);}return typeof t?.limit=="number"&&(i=i.slice(0,t.limit)),i.map(o=>structuredClone(o))}async saveChat(e){this.assertOpen();let t=e.id;t&&this.chats.set(t,structuredClone(e));}async getChat(e){this.assertOpen();let t=this.chats.get(e);return t?structuredClone(t):void 0}async listChats(e){this.assertOpen();let t=[];for(let r of this.chats.values())e?.archived===true&&r.archived!==true||t.push(structuredClone(r));return t}async saveContact(e){this.assertOpen(),this.contacts.set(e.id,structuredClone(e));}async getContact(e){this.assertOpen();let t=this.contacts.get(e);return t?structuredClone(t):void 0}async listContacts(){return this.assertOpen(),Array.from(this.contacts.values(),e=>structuredClone(e))}async savePresence(e,t){this.assertOpen(),this.presence.set(e,structuredClone(t));}async getPresence(e){this.assertOpen();let t=this.presence.get(e);return t?structuredClone(t):void 0}bind(e){this.assertOpen(),this.boundSocket=e;let t=(...c)=>{let l=c[0]?.messages;if(Array.isArray(l))for(let u of l)this.saveMessage(u).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d){let u=this.messages.get(bt(l.key));if(u){let w={...u,...l.update};this.saveMessage(w).catch(()=>{});}}},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveChat(l).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d){let w={...this.chats.get(l.id)??{},...l};this.saveChat(w).catch(()=>{});}},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveContact(l).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let l of Object.keys(d.presences)){let u=d.presences[l];u&&this.savePresence(l,u).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("messages.update",r),this.listeners.set("chats.upsert",s),this.listeners.set("chats.update",i),this.listeners.set("contacts.upsert",o),this.listeners.set("presence.update",a);for(let[c,d]of this.listeners)e.ev.on(c,d);}async deleteMessage(e){this.assertOpen();let t=bt(e);this.messages.delete(t);let r=e.remoteJid??"",s=this.messagesByJid.get(r);s&&(s.delete(t),s.size===0&&this.messagesByJid.delete(r));}async pruneMessages(e){this.assertOpen();let t=0;for(let[r,s]of [...this.messagesByJid.entries()]){if(e.chatFilter&&!e.chatFilter(r))continue;let i=[];for(let a of s){let c=this.messages.get(a);c&&i.push(c);}i.sort((a,c)=>Number(c.messageTimestamp??0)-Number(a.messageTimestamp??0));let o=i.filter((a,c)=>{let d=Number(a.messageTimestamp??0);return e.olderThan!==void 0&&d<e.olderThan||e.maxPerChat!==void 0&&c>=e.maxPerChat});for(let a of o)await this.deleteMessage(a.key),t+=1;}return t}async clear(){this.assertOpen(),this.messages.clear(),this.messagesByJid.clear(),this.chats.clear(),this.contacts.clear(),this.presence.clear();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);return this.listeners.clear(),this.boundSocket=void 0,Promise.resolve()}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","MemoryMessageStore is closed")}};var _o=["silent","fatal","error","warn","info","debug","trace"];function No(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":_o.includes(e)?e:"silent"}function Do(n={}){let e=No(n.level),t=Lo({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var jr=["debug","info","warn","error","fatal"];function Bo(n){if(n===null||typeof n!="object")return false;for(let e of jr)if(typeof n[e]!="function")return false;return true}function Ve(){}function Fo(n){let e={debug:Ve,info:Ve,warn:Ve,error:Ve,fatal:Ve};for(let t of jr){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function yn(n,e){return n===void 0?e??Do():Bo(n)?n:Fo(n)}var zp=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),qr=n=>{let e=n.requestId!=null,t=n.messages.filter(r=>{if(e)return false;let s=r.messageStubParameters;if(Array.isArray(s)){for(let i of s)if(typeof i=="string"&&i.startsWith("requestId:"))return false}return true});return {...n,messages:t}};var Wo=new Set(["offer","ringing"]),Uo=new Set(["timeout","reject","accept","terminate"]),Kr=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},Jr=n=>typeof n.id!="string"||n.id.length===0||!Wo.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Kr(n.date),status:n.status},$r=n=>typeof n.id!="string"||n.id.length===0||!Uo.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Kr(n.date),status:n.status};var D=n=>typeof n=="string"&&n.length>0,jo=n=>{let e={};return typeof n.subject=="string"&&(e.subject=n.subject),typeof n.desc=="string"&&(e.description=n.desc),typeof n.announce=="boolean"&&(e.announce=n.announce),typeof n.restrict=="boolean"&&(e.restrict=n.restrict),typeof n.ephemeralDuration=="number"&&(e.ephemeralDuration=n.ephemeralDuration),e},Gr=(n,e,t)=>n.filter(r=>D(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return D(i)&&(s.participantAlt=i),D(e)&&(s.authorPn=e),D(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),Vr=n=>D(n?.id)?{groupId:n.id,update:jo(n),timestamp:Date.now()}:null,Hr=n=>{if(!D(n?.groupId)||!D(n?.participant))return null;let e={groupId:n.groupId,participant:n.participant,label:typeof n.label=="string"?n.label:"",timestamp:typeof n.messageTimestamp=="number"?n.messageTimestamp:Date.now()};return D(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},qo=new Set(["add","invite","invite-link"]),Ko=new Set(["remove","leave"]),zr=n=>{if(!D(n?.id)||!qo.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Gr(n.participants,n.authorPn,n.authorUsername);if(e.length===0)return null;let t={groupId:n.id,participants:e,action:n.action,timestamp:Date.now()};return D(n.author)&&(t.by=n.author),t},Yr=n=>{if(!D(n?.id)||!Ko.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Gr(n.participants,n.authorPn,n.authorUsername);if(e.length===0)return null;let t={groupId:n.id,participants:e,action:n.action,timestamp:Date.now()};return D(n.author)&&(t.by=n.author),t};var we=n=>typeof n!="string"||n.length===0?null:jidNormalizedUser(n),z=n=>typeof n=="string"&&n.length>0?n:void 0,Go=["@s.whatsapp.net","@c.us"],Et=n=>n.endsWith("@lid"),Zr=n=>Go.some(e=>n.endsWith(e)),K=(n,e)=>{if(!n)return null;let t=z(n.participant)??n.remoteJid,r=we(t);if(r===null)return null;let s=z(n.participantAlt)??z(n.remoteJidAlt),i=s!=null?we(s):null,o=z(n.participantUsername)??z(n.remoteJidUsername),a={jid:r,isMe:n.fromMe===true};typeof t=="string"&&t.length>0&&(a.deviceJid=t);let c=i!==null?[r,i]:[r],d=c.find(Et),l=c.find(Zr);d!==void 0&&(a.lid=d),l!==void 0&&(a.pn=l),o!==void 0&&(a.username=o);let u=z(e);return u!==void 0&&(a.pushName=u),a},Xr=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=z(n.participant),r=z(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=K(s);return o&&(i.sender=o),i},He=n=>{if(!n)return {mentionedJids:[],mentionAll:false};let e=n.mentionedJid,t=Array.isArray(e)?e.filter(i=>typeof i=="string"):[],r=n.groupMentions,s=Array.isArray(r)&&r.length>0;return {mentionedJids:t,mentionAll:s}};var ve=n=>isJidGroup(n)===true,Me=n=>{if(n==null)return null;if(typeof n=="number")return Number.isFinite(n)?n:null;if(typeof n.toNumber=="function"){let e=n.toNumber();return Number.isFinite(e)?e:null}return null};var Vo=["quick_reply","cta_url","cta_call","button_click"],Ho=["list_select","single_select"],G=n=>typeof n=="string"&&n.length>0,es=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return K(n.key,e)},ts=n=>Me(n.messageTimestamp)??0,ns=(n,e)=>{if(!G(n))return null;try{let t=JSON.parse(n);return t!==null&&typeof t=="object"?t:null}catch{return e?.debug({paramsJson:n},"interactive: failed to parse nativeFlow paramsJson"),null}},Ct=(n,e)=>{for(let t of e){let r=n[t];if(G(r))return r}},rs=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&G(r.selectedButtonId))return wn(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&G(s.selectedId))return wn(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&G(i.name)&&Vo.includes(i.name)){let o=ns(i.paramsJson,e.logger);if(!o)return null;let a=Ct(o,["id","button_id"]);return a===void 0?null:wn(n,a,Ct(o,["display_text"])??null)}return null},wn=(n,e,t)=>{let r=es(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:ts(n)};return G(t)&&(s.buttonText=t),s},ss=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(G(s))return Qr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&G(i.name)&&Ho.includes(i.name)){let o=ns(i.paramsJson,e.logger);if(!o)return null;let a=Ct(o,["row_id","id"]);return a===void 0?null:Qr(n,a,Ct(o,["title"])??null)}return null},Qr=(n,e,t)=>{let r=es(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:ts(n)};return G(t)&&(s.title=t),s};var zo=new Set(["available","unavailable","composing","recording","paused"]),Yo=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,is=n=>n.status!=="complete"&&n.status!=="paused"?null:{syncType:String(n.syncType),status:n.status,explicit:n.explicit===true},vn=n=>{if(n.source==="connection-update"){let t=n.reachoutTimeLock;return t.isActive!==true?null:{reason:"reachout-timelock",retryAt:Yo(t.timeEnforcementEnds)}}if(n.capInfo.capping_status!=="CAPPED")return null;let e={reason:"chat-limit-reached"};return typeof n.capInfo.used_quota=="number"&&(e.usedQuota=n.capInfo.used_quota),typeof n.capInfo.total_quota=="number"&&(e.totalQuota=n.capInfo.total_quota),e},os=n=>{if(typeof n.id!="string"||n.id.length===0)return [];let e=[];for(let[t,r]of Object.entries(n.presences??{})){let s=r?.lastKnownPresence;typeof s!="string"||!zo.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},ze=n=>{let e=n.payload.id;if(typeof e!="string"||e.length===0)return null;let t=Date.now();switch(n.source){case "reaction":{let r={action:"reaction",newsletterId:e,timestamp:t};return typeof n.payload.server_id=="string"&&(r.serverId=n.payload.server_id),typeof n.payload.reaction?.code=="string"&&(r.emoji=n.payload.reaction.code),r}case "view":{let r={action:"view",newsletterId:e,timestamp:t};return typeof n.payload.server_id=="string"&&(r.serverId=n.payload.server_id),typeof n.payload.count=="number"&&(r.count=n.payload.count),r}case "participants":return {action:"participants",newsletterId:e,timestamp:t};case "settings":{let r={action:"settings",newsletterId:e,timestamp:t};return n.payload.update&&(r.update=n.payload.update),r}}};var cs=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},as=(n,e=2166136261)=>{let t=e>>>0;for(let r=0;r<n.length;r++)t^=n.charCodeAt(r),t=Math.imul(t,16777619)>>>0;return t>>>0},ds=n=>(as(n).toString(16).padStart(8,"0")+as(n,2646966556).toString(16).padStart(8,"0")).toUpperCase(),ls=n=>ds(`${n.remoteJid??""}|${n.id??""}|${n.fromMe===true?"1":"0"}`),us=(n,e)=>ds(`${n??""}|${e}`),ps=n=>{let e=null;if(typeof n=="number")e=n;else if(typeof n=="bigint")e=Number(n);else if(typeof n=="string"){let t=Number.parseInt(n,10);e=Number.isFinite(t)?t:null;}else if(n!=null&&typeof n=="object"){let t=n;typeof t.toNumber=="function"?e=t.toNumber():typeof t.low=="number"&&(e=(typeof t.high=="number"?t.high:0)*4294967296+(t.low>>>0));}return e!=null&&Number.isFinite(e)&&e>0?e*1e3:0},ms=n=>{let e=jidDecode(n);if(!e)return "unknown";let t=e.device;return t===void 0||t===0?"android":t===2?"ios":t===3?"web":t===4?"desktop":"unknown"},Xo=n=>n.trim().endsWith("?"),Qo=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),ea=(n,e)=>{if(e.length===0)return false;let t;try{t=jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return jidNormalizedUser(r)===t}catch{return r===n}})},ta=(n,e)=>{let t=async r=>r===void 0?false:Array.isArray(r)?r.includes(e):r(e);return {authors:()=>t(n?.authors),banned:()=>t(n?.banned)}},na=0,ra=14,sa=1,ia=2,kt=n=>n!=null&&typeof n=="object"?n:null,oa=n=>{let e=kt(n.message);if(e==null)return {isEdited:false,isDeleted:false,isPinned:false,isUnPinned:false,isBot:false,isStatusMention:false,isGroupStatusMention:false};let t=kt(e.protocolMessage),r=typeof t?.type=="number"?t.type:void 0,s=typeof kt(e.pinInChatMessage)?.type=="number"?e.pinInChatMessage.type:void 0;return {isEdited:e.editedMessage!=null||r===ra,isDeleted:r===na,isPinned:s===sa,isUnPinned:s===ia,isBot:kt(e.messageContextInfo)?.botMetadata!=null,isStatusMention:e.statusMentionMessage!=null,isGroupStatusMention:e.groupStatusMentionMessage!=null}},Mn=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&ve(e),r=oa(n.message),s=c=>n.lidMap!=null&&c.endsWith("@lid")?n.lidMap.get(c)??c:c,i=s(n.sender.pn??n.sender.jid),o=t?e?jidNormalizedUser(e):null:n.key.fromMe===true&&e?s(jidNormalizedUser(e)):i,a={uniqueId:ls(n.key),staticId:us(o,i),channelId:n.channelId,chatId:n.key.id??"",chatType:n.chatType,receiverId:n.receiverId?s(jidNormalizedUser(n.receiverId)):n.receiverId,roomId:o,senderId:i,senderLid:n.sender.lid??null,senderName:n.sender.pushName??null,senderDevice:ms(n.sender.deviceJid??n.sender.jid),timestamp:ps(n.message.messageTimestamp),text:n.text,mentions:n.mentions,links:cs(n.text),isFromMe:n.key.fromMe===true,isGroup:t,isNewsletter:n.isNewsletter,isBroadcast:n.isBroadcast,isViewOnce:n.isViewOnce,isEphemeral:n.isEphemeral,isForwarded:n.isForwarded,isQuestion:Xo(n.text),isPrefix:Qo(n.text,n.prefixes),isTagMe:ea(n.selfJid,n.mentions),isEdited:r.isEdited,isDeleted:r.isDeleted,isPinned:r.isPinned,isUnPinned:r.isUnPinned,isBot:r.isBot,isSpam:false,isHideTags:n.mentions.length>0&&!/@\d/.test(n.text),isStatusMention:r.isStatusMention,isGroupStatusMention:r.isGroupStatusMention,isStory:e==="status@broadcast",roomName:n.resolveRoomName,receiverName:n.resolveReceiverName,replied:n.resolveReplied,reply:n.reply,react:n.react,message:()=>n.message,citation:ta(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(a.media=n.media),a};var aa={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},ca=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[aa[e]];if(r==null||typeof r!="object")return null;let s=r.mimetype;return typeof s=="string"&&s.length>0?s:null},fs=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys'),s=await r(n,"buffer",{}),i=ca(n,e)??"application/octet-stream";return {buffer:s,mime:i,size:s.byteLength}}catch(r){throw t?.warn({error:r,kind:e,id:n.key?.id},"media download failed"),r instanceof Error?r:new Error("media download failed")}},gs=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys');return await r(n,"stream",{})}catch(r){throw t?.warn({error:r,kind:e,id:n.key?.id},"media stream download failed"),r instanceof Error?r:new Error("media stream download failed")}};var Ot={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},ys=n=>{let e=n?.remoteJid;return typeof e=="string"&&e.length>0?e:""},h=n=>n!=null&&typeof n=="object"?n:null,S=n=>typeof n=="string"&&n.length>0?n:null,Y=(...n)=>{for(let e of n){let t=S(e);if(t!=null)return t}return null},da=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage","lottieStickerMessage"],Qe=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of da){let i=h(h(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},ws=n=>{let e=h(n.message);if(e==null)return n;let t=Qe(e);return t===e?n:{...n,message:t}},la=n=>{let t=h(h(h(n.botForwardedMessage)?.message)?.richResponseMessage)??h(n.richResponseMessage);if(t==null)return null;let r=t.submessages;if(!Array.isArray(r))return null;let s=[];for(let o of r){let a=S(h(o)?.messageText);a!=null&&s.push(a);}let i=s.join(`
14
- `).trim();return i.length>0?i:null},ua=n=>{let e=h(n.templateMessage),t=h(e?.hydratedTemplate)??h(e?.hydratedFourRowTemplate);return S(t?.hydratedContentText)},pa=n=>Y(h(n.pollCreationMessage)?.name,h(n.pollCreationMessageV2)?.name,h(n.pollCreationMessageV3)?.name),ma=n=>{let e=h(n.locationMessage)??h(n.liveLocationMessage);if(e==null)return null;let t=Y(e.name,e.address);if(t!=null){let i=S(e.name),o=S(e.address);return i!=null&&o!=null&&i!==o?`${i} \u2014 ${o}`:t}let r=e.degreesLatitude,s=e.degreesLongitude;return typeof r=="number"&&typeof s=="number"?`${r}, ${s}`:null},fa=n=>{let e=S(h(n.contactMessage)?.displayName);if(e!=null)return e;let t=h(n.contactsArrayMessage),r=S(t?.displayName);if(r!=null)return r;let s=t?.contacts;if(Array.isArray(s)){let i=s.map(o=>S(h(o)?.displayName)).filter(o=>o!=null);if(i.length>0)return i.join(", ")}return null},vs=n=>Y(n.conversation,h(n.extendedTextMessage)?.text,la(n),S(h(h(n.interactiveMessage)?.body)?.text),h(n.buttonsMessage)?.contentText,h(n.listMessage)?.description,ua(n),pa(n),ma(n),fa(n)),ga=n=>Y(h(n.buttonsResponseMessage)?.selectedDisplayText,h(n.buttonsResponseMessage)?.selectedButtonId,h(n.templateButtonReplyMessage)?.selectedDisplayText,h(n.templateButtonReplyMessage)?.selectedId,h(n.listResponseMessage)?.title,h(h(n.listResponseMessage)?.singleSelectReply)?.selectedRowId,h(h(n.interactiveResponseMessage)?.body)?.text),ha=n=>Y(h(n.imageMessage)?.caption,h(n.videoMessage)?.caption,h(n.documentMessage)?.caption,h(n.documentMessage)?.fileName),T=n=>{if(typeof n=="number")return n;let e=Me(n);return typeof e=="number"?e:null},ya=[["pollCreationMessage","poll"],["pollCreationMessageV2","poll"],["pollCreationMessageV3","poll"],["contactMessage","contact"],["contactsArrayMessage","contact"],["locationMessage","location"],["liveLocationMessage","live-location"],["eventMessage","event"],["albumMessage","album"],["groupInviteMessage","group-invite"],["productMessage","product"],["orderMessage","order"],["requestPaymentMessage","payment"],["sendPaymentMessage","payment"],["paymentInviteMessage","payment"],["buttonsMessage","buttons"],["listMessage","list"],["interactiveMessage","interactive"],["templateMessage","template"]],Ms=n=>{let e=h(n.pollCreationMessage)??h(n.pollCreationMessageV2)??h(n.pollCreationMessageV3);if(e!=null){let p=Array.isArray(e.options)?e.options:[];return {type:"poll",name:S(e.name),options:p.map(m=>S(h(m)?.optionName)).filter(m=>m!=null),selectableCount:T(e.selectableOptionsCount)??0}}let t=h(n.contactMessage);if(t!=null)return {type:"contact",displayName:S(t.displayName),vcard:S(t.vcard),contacts:[{displayName:S(t.displayName),vcard:S(t.vcard)}]};let r=h(n.contactsArrayMessage);if(r!=null){let p=Array.isArray(r.contacts)?r.contacts:[];return {type:"contact",displayName:S(r.displayName),vcard:null,contacts:p.map(m=>({displayName:S(h(m)?.displayName),vcard:S(h(m)?.vcard)}))}}let s=h(n.locationMessage);if(s!=null)return {type:"location",latitude:T(s.degreesLatitude),longitude:T(s.degreesLongitude),name:S(s.name),address:S(s.address),accuracy:T(s.accuracyInMeters),speed:T(s.speedInMps),caption:S(s.comment)};let i=h(n.liveLocationMessage);if(i!=null)return {type:"live-location",latitude:T(i.degreesLatitude),longitude:T(i.degreesLongitude),name:null,address:null,accuracy:T(i.accuracyInMeters),speed:T(i.speedInMps),caption:S(i.caption)};let o=h(n.albumMessage);if(o!=null)return {type:"album",expectedImageCount:T(o.expectedImageCount),expectedVideoCount:T(o.expectedVideoCount)};let a=h(n.groupInviteMessage);if(a!=null)return {type:"group-invite",groupId:S(a.groupJid),groupName:S(a.groupName),inviteCode:S(a.inviteCode),caption:S(a.caption),expiresAt:T(a.inviteExpiration)};let c=h(h(n.productMessage)?.product);if(h(n.productMessage)!=null){let p=S(h(n.productMessage)?.businessOwnerJid),m=T(c?.priceAmount1000);return {type:"product",productId:S(c?.productId),title:S(c?.title),description:S(c?.description),price:m!=null?m/1e3:null,currency:S(c?.currencyCode),retailerId:S(c?.retailerId),url:S(c?.url),businessOwnerId:p}}let d=h(n.orderMessage);if(d!=null){let p=T(d.totalAmount1000),m={1:"inquiry",2:"accepted",3:"declined"},A=d.status;return {type:"order",orderId:S(d.orderId),title:S(d.orderTitle),itemCount:T(d.itemCount),total:p!=null?p/1e3:null,currency:S(d.totalCurrencyCode),status:typeof A=="number"?m[A]??null:S(A),message:S(d.message)}}let l=h(n.requestPaymentMessage)!=null&&{node:n.requestPaymentMessage,kind:"request"}||h(n.sendPaymentMessage)!=null&&{node:n.sendPaymentMessage,kind:"send"}||h(n.paymentInviteMessage)!=null&&{node:n.paymentInviteMessage,kind:"invite"};if(l!==false){let p=h(l.node),m=T(p?.amount1000),A=h(p?.noteMessage);return {type:"payment",kind:l.kind,amount:m!=null?m/1e3:null,currency:S(p?.currencyCodeIso4217),note:Y(A?.conversation,h(A?.extendedTextMessage)?.text),expiresAt:T(p?.expiryTimestamp)}}let u=h(n.eventMessage);if(u!=null){let p=h(u.location);return {type:"event",name:S(u.name),description:S(u.description),location:p!=null?Y(p.name,p.address):null,startTime:T(u.startTime),endTime:T(u.endTime),isCanceled:u.isCanceled===true}}let w=h(n.buttonsMessage);if(w!=null){let p=Array.isArray(w.buttons)?w.buttons:[];return {type:"buttons",contentText:S(w.contentText),footerText:S(w.footerText),buttons:p.map(m=>({id:S(h(m)?.buttonId),text:S(h(h(m)?.buttonText)?.displayText)}))}}let M=h(n.listMessage);if(M!=null){let p=Array.isArray(M.sections)?M.sections:[];return {type:"list",title:S(M.title),description:S(M.description),buttonText:S(M.buttonText),sections:p.map(m=>{let A=Array.isArray(h(m)?.rows)?h(m).rows:[];return {title:S(h(m)?.title),rows:A.map(P=>({id:S(h(P)?.rowId),title:S(h(P)?.title),description:S(h(P)?.description)}))}})}}let v=h(n.interactiveMessage);if(v!=null){let p=h(v.nativeFlowMessage),m=Array.isArray(p?.buttons)?p.buttons:[];return {type:"interactive",title:S(h(v.header)?.title),body:S(h(v.body)?.text),footer:S(h(v.footer)?.text),buttons:m.map(A=>({name:S(h(A)?.name),params:S(h(A)?.buttonParamsJson)}))}}let E=h(n.templateMessage);if(E!=null){let p=h(E.hydratedTemplate)??h(E.hydratedFourRowTemplate),m=Array.isArray(p?.hydratedButtons)?p.hydratedButtons:[];return {type:"template",text:S(p?.hydratedContentText),buttons:m.map(A=>{let P=h(A),J=h(P?.quickReplyButton)??h(P?.urlButton)??h(P?.callButton);return {id:S(J?.id),text:S(J?.displayText)}})}}let y=h(n.extendedTextMessage);if(y!=null){let p=Y(y.canonicalUrl,y.matchedText),m=S(y.title),A=S(y.description);if(p!=null&&(m!=null||A!=null))return {type:"link",url:p,title:m,description:A}}return null};var Ze=n=>{let e=h(n.message);if(e==null)return null;let t=Qe(e);return vs(t)??ga(t)??ha(t)},It=n=>{let e=h(ws(n).message);if(e==null)return null;let t=h(e.extendedTextMessage)?.contextInfo;if(t!=null)return t;for(let r of Object.values(Ot)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},wa=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Ot[e]];return r==null||typeof r!="object"?null:r},va=n=>{let e=n.message;if(e==null)return false;if(e.viewOnceMessage!=null||e.viewOnceMessageV2!=null||e.viewOnceMessageV2Extension!=null)return true;for(let t of Object.values(Ot)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},Ma=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,oe=n=>{let e=h(n);if(e==null)return "text";let t=Qe(e);for(let r of Object.values(Ot))if(t[r]!=null)return r.replace("Message","");for(let[r,s]of ya)if(t[r]!=null)return s;return "text"},Sa=(n,e)=>{if(n==null)return false;let t=[n.pn,n.lid,n.jid].filter(s=>typeof s=="string"&&s.length>0),r=[e.pn,e.lid,e.jid].filter(s=>typeof s=="string"&&s.length>0);return t.some(s=>r.includes(s))},Aa=async(n,e,t,r,s)=>{try{if(n==null||n.quotedMessage==null)return null;let i=n.stanzaId;if(typeof i!="string"||i.length===0)return null;if(e.resolveQuoted!=null&&t.length>0){let v=await e.resolveQuoted(i,t);if(v!=null&&v.message!=null){let E=Ze(v)??"",y=ae(v,e,oe(v.message),E,Xe(v,e),s);if(y!==null)return y}}let o=Xr(n);if(o===null||typeof o.key.id!="string"||o.key.id.length===0||(t.length>0&&(o.key.remoteJid=t),typeof o.key.remoteJid!="string"||o.key.remoteJid.length===0))return null;let a=o.key.participant,c=typeof a=="string"&&(e.selfJid.length>0&&Tt(a,e.selfJid)||e.selfLid!=null&&Tt(a,e.selfLid)),d=ve(t),l=o.sender?.pushName;c?(o.key.fromMe=!0,e.selfJid.length>0&&(o.key.participant=e.selfJid),e.selfLid!=null&&(o.key.participantAlt=e.selfLid),l==null&&(l=e.selfName)):r!=null&&(!d||Sa(o.sender,r))&&(r.pn!=null&&(o.key.participant=r.pn),r.lid!=null&&(o.key.participantAlt=r.lid),l==null&&(l=r.pushName));let u=n.quotedMessage,w=Object.assign({key:o.key,message:u??null},l!=null?{pushName:l}:{}),M=Ze(w)??"";return ae(w,e,oe(u),M,Xe(w,e),s)}catch{return null}},Ss=n=>He(It(n)).mentionedJids,ba=n=>{try{return jidNormalizedUser(n)}catch{return n}},As=(n,e)=>n.map(t=>{let r=ba(t);return e.lidMap?.get(r)??r}),hs=n=>(n.split("@")[0]??"").split(":")[0]??"",Pa=(n,e)=>{if(e==null||e.size===0||n.length===0)return n;let t=[...e].map(([s,i])=>[hs(s),hs(i)]).filter(([s,i])=>s.length>0&&i.length>0&&s!==i).sort((s,i)=>i[0].length-s[0].length),r=n;for(let[s,i]of t)r=r.split(`@${s}`).join(`@${i}`);return r},ae=(n,e,t,r,s,i)=>{let o=n.key;if(o==null)return null;let a=K(o,n.pushName??void 0);if(a===null)return null;let c=ys(o);if(c.length===0)return null;let d=It(n),l=ve(c),u=c.endsWith("@broadcast"),w=c.endsWith("@newsletter"),M=d?.isForwarded===true||(d?.forwardingScore??0)>0,v=va(n),E=Ma(n,d),y=e.channelId??"",p=e.receiverId??"",m=e.prefixes??[],A=i??(()=>l?e.resolveRoomName!=null?e.resolveRoomName(c):Promise.resolve(null):Promise.resolve(a.pushName??null)),P=e.resolveReceiverName??(()=>Promise.resolve(null)),J=()=>Aa(d,e,c,a,A),Ae=c.length>0?c:a.pn??a.jid,Gt=(Ht,ai)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(Ae,Ht,ai,n),Vt=Ht=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(o,Ht),ii=As(He(d).mentionedJids,e),oi=Pa(r,e.lidMap),Cn={message:n,key:o,channelId:y,receiverId:p,selfJid:e.selfJid,text:oi,chatType:t,sender:a,mentions:ii,isViewOnce:v,isEphemeral:E,isForwarded:M,isBroadcast:u,isNewsletter:w,prefixes:m,...e.lidMap!=null?{lidMap:e.lidMap}:{},resolveRoomName:A,resolveReceiverName:P,resolveReplied:J,reply:Gt,react:Vt},kn=s!==void 0?{...Cn,media:s}:Cn;return Mn(e.citationConfig!==void 0?{...kn,citationConfig:e.citationConfig}:kn)},Ea=["image","video","audio","document","sticker"],bs=(n,e,t)=>{let r=ws(n),s=wa(r,e);if(s===null)return null;let i=fs(r,e,t.logger),o=gs(r,e,t.logger);return {type:e,mimetype:typeof s.mimetype=="string"?s.mimetype:null,caption:typeof s.caption=="string"?s.caption:null,fileName:typeof s.fileName=="string"?s.fileName:null,fileSize:T(s.fileLength),ptt:s.ptt===true,buffer:async()=>(await i()).buffer,stream:o}},Xe=(n,e)=>{let t=h(n.message);if(t==null)return;let r=oe(n.message);return Ea.includes(r)?bs(n,r,e)??void 0:Ms(Qe(t))??void 0},Ps=(n,e)=>{if(h(n.message)==null)return null;let r=oe(n.message),s=Xe(n,e),i=Ze(n)??"";return i===""&&s===void 0?null:ae(n,e,r,i,s)},Es=(n,e)=>{let t=h(n.message);if(t==null)return null;let r=Qe(t),s=vs(r),i=Ms(r)??void 0;return s===null&&i===void 0?null:ae(n,e,oe(n.message),s??"",i)},et=(n,e,t)=>{let r=bs(e,n,t);return r===null?null:ae(e,t,n,r.caption??"",r)},Cs=(n,e)=>et("image",n,e),ks=(n,e)=>et("video",n,e),Ts=(n,e)=>et("audio",n,e),Os=(n,e)=>et("document",n,e),Is=(n,e)=>et("sticker",n,e),Tt=(n,e)=>{try{return jidNormalizedUser(n)===jidNormalizedUser(e)}catch{return n===e}},xs=(n,e)=>{if(n.key==null)return null;let r=It(n),s=He(r).mentionedJids;if(s.length===0)return null;let i=As(s,e);if(!(i.some(u=>Tt(u,e.selfJid))||e.selfLid!=null&&s.some(u=>Tt(u,e.selfLid)))||h(n.message)==null)return null;let c=Ze(n)??"",d=Xe(n,e),l=ae(n,e,oe(n.message),c,d);return l===null?null:{...l,mentionedJids:i,selfJid:e.selfJid}},Rs=(n,e)=>{let t=n.key;if(t==null)return null;let r=ys(t);if(r.length===0||!ve(r))return null;let{mentionAll:s}=He(It(n));if(!s||h(n.message)==null)return null;let o=Ze(n)??"",a=Xe(n,e),c=ae(n,e,oe(n.message),o,a);return c===null?null:{...c,isMentionAll:true,selfJid:e.selfJid}};var ce=(n,e)=>{let t=Me(n);return t===null?e:t},Ca=n=>{if(!n)return "";if(typeof n.conversation=="string")return n.conversation;let e=n.extendedTextMessage?.text;if(typeof e=="string")return e;let t=n.imageMessage?.caption;if(typeof t=="string")return t;let r=n.videoMessage?.caption;if(typeof r=="string")return r;let s=n.documentMessage?.caption;if(typeof s=="string")return s;let o=(n.botForwardedMessage?.message?.richResponseMessage??n.richResponseMessage)?.submessages;if(Array.isArray(o)){let a=o.map(c=>c?.messageText).filter(c=>typeof c=="string"&&c.length>0);if(a.length>0)return a.join(`
15
- `)}return ""},ka=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],_s=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=K(n.key,e.pushName);if(s===null)return null;let i=t.text,o=typeof i=="string"&&i.length>0?i:null;return {key:r,emoji:o,sender:s,timestamp:ce(t.senderTimestampMs,0)}},Ns=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=K(n.key,e.pushName);return s===null?null:{key:r,newContent:Ca(t.editedMessage),editedAt:ce(n.update.messageTimestamp,0),sender:s}},Ds=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=K(n.key,e.pushName);if(s===null)return null;let i=we(n.key.remoteJid),o=we(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:ce(n.update.messageTimestamp,0)}},Bs=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=K(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:ka(t.vote?.selectedOptions),voter:s,timestamp:ce(t.senderTimestampMs,ce(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:ce(r.senderTimestampMs,ce(n.update.messageTimestamp,0))}:null}return null};var xt=n=>Array.isArray(n)?n:[],Ta=3e3,Oa=(n,e)=>new Promise(t=>{let r=setTimeout(()=>t(null),e);n.then(s=>{clearTimeout(r),t(s);},()=>{clearTimeout(r),t(null);});}),Ia=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function Ws(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?y=>{let p=s.get(y);if(p!==void 0)return p;let m=t.groupMetadata;if(m==null)return Promise.resolve(null);let A=m(y).then(P=>P?.subject??null).catch(()=>null);return s.set(y,A),A}:void 0,o={selfJid:t.selfJid,...t.selfLid!=null?{selfLid:t.selfLid}:{},...t.selfName!=null?{selfName:t.selfName}:{},receiverId:t.receiverId??t.selfJid,...t.logger!=null?{logger:t.logger}:{},...t.channelId!=null?{channelId:t.channelId}:{},...t.prefixes!=null?{prefixes:t.prefixes}:{},...t.citationConfig!=null?{citationConfig:t.citationConfig}:{},...i!=null?{resolveRoomName:i}:{},...t.receiverName!=null?{resolveReceiverName:t.receiverName}:{},...t.resolveQuoted!=null?{resolveQuoted:t.resolveQuoted}:{},...t.sendReply!=null?{reply:t.sendReply}:{},...t.react!=null?{react:t.react}:{}},a=t.logger?{selfJid:t.selfJid,logger:t.logger}:{selfJid:t.selfJid},c={selfJid:t.selfJid},d=(y,p)=>{let m=(...A)=>{try{p(A[0]);}catch(P){t.logger?.warn(P,`inbound pipeline: handler for ${y} threw`);}};e.ev.on(y,m),r.push(()=>e.ev.off(y,m));},l=(y,p)=>{v(()=>Ps(y,p),m=>n.emit("message",m)),v(()=>Es(y,p),m=>n.emit("text",m)),v(()=>Cs(y,p),m=>n.emit("image",m)),v(()=>ks(y,p),m=>n.emit("video",m)),v(()=>Ts(y,p),m=>n.emit("audio",m)),v(()=>Os(y,p),m=>n.emit("document",m)),v(()=>Is(y,p),m=>n.emit("sticker",m)),v(()=>xs(y,p),m=>n.emit("mention",m)),v(()=>Rs(y,p),m=>n.emit("mention-all",m)),v(()=>rs(y,a),m=>n.emit("button-click",m)),v(()=>ss(y,a),m=>n.emit("list-select",m));},u=y=>{if(typeof y!="string"||y.length===0)return null;let p;try{p=jidNormalizedUser(y);}catch{p=y;}return Et(p)?p:null},w=y=>{let p=new Set;for(let m of [y.key?.participant,y.key?.remoteJid,t.selfJid,...Ss(y)]){let A=u(m);A!=null&&p.add(A);}return [...p]},M=async y=>{let p=t.resolveLidToPn;if(p==null||y.length===0)return;let m=new Map;return await Promise.all(y.map(async A=>{try{let P=await Oa(Promise.resolve(p(A)),Ta);if(P!=null&&P.length>0)try{m.set(A,jidNormalizedUser(P));}catch{m.set(A,P);}}catch(P){t.logger?.warn(P,"inbound pipeline: lid->pn resolve threw");}})),m.size>0?m:void 0},v=(y,p)=>{let m;try{m=y();}catch(A){t.logger?.warn(A,"inbound pipeline: decoder threw");return}m!=null&&p(m);};d("messages.upsert",y=>{let p=qr(y);for(let m of p.messages){if(t.ignoreMe===!0&&m.key?.fromMe===!0)continue;let A=t.resolveLidToPn!=null?w(m):[];if(A.length===0){l(m,o);continue}M(A).then(P=>l(m,P!=null?{...o,lidMap:P}:o)).catch(P=>{t.logger?.warn(P,"inbound pipeline: deferred lid resolve emit failed"),l(m,o);});}}),d("messages.update",y=>{for(let p of xt(y))v(()=>Ns(p,c),m=>n.emit("edit",m)),v(()=>Ds(p,c),m=>n.emit("delete",m)),v(()=>Bs(p,c),m=>n.emit("poll-vote",m));}),d("messages.reaction",y=>{for(let p of xt(y))v(()=>_s(p,c),m=>n.emit("reaction",m));}),d("groups.update",y=>{for(let p of xt(y))v(()=>Vr(p),m=>n.emit("group-update",m));}),d("group-participants.update",y=>{let p=y;v(()=>zr(p),m=>n.emit("group-join",m)),v(()=>Yr(p),m=>n.emit("group-leave",m));}),d("group.member-tag.update",y=>{v(()=>Hr(y),p=>n.emit("member-tag",p));}),d("call",y=>{for(let p of xt(y))v(()=>Jr(p),m=>n.emit("call-incoming",m)),v(()=>$r(p),m=>n.emit("call-ended",m));}),d("messaging-history.status",y=>{v(()=>is(y),p=>n.emit("history-sync",p));}),d("presence.update",y=>{let p=(()=>{try{return os(y)}catch(m){return t.logger?.warn(m,"inbound pipeline: decodePresence threw"),[]}})();for(let m of p)n.emit("presence",m);}),d("connection.update",y=>{let p=Ia(y);p!==null&&v(()=>vn({source:"connection-update",reachoutTimeLock:p}),m=>n.emit("limited",m));}),d("message-capping.update",y=>{v(()=>vn({source:"message-capping",capInfo:y}),p=>n.emit("limited",p));}),d("newsletter.reaction",y=>{v(()=>ze({source:"reaction",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter.view",y=>{v(()=>ze({source:"view",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter-participants.update",y=>{v(()=>ze({source:"participants",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter-settings.update",y=>{v(()=>ze({source:"settings",payload:y}),p=>n.emit("newsletter",p));});let E=false;return {detach(){if(!E){E=true;for(let y of r)y();r.length=0;}}}}var Rt=class{inner=new EventEmitter;emitterLogger;constructor(e){this.emitterLogger=e?.logger,this.inner.setMaxListeners(0);}on(e,t){let r=this.wrap(e,t);this.tag(t,e,r),this.inner.on(e,r);let s=false;return ()=>{s||(s=true,this.inner.off(e,r),this.untag(t,e));}}off(e,t){let r=this.lookup(t,e);r&&(this.inner.off(e,r),this.untag(t,e));}emit(e,t){let r=this.inner.listeners(e).slice();for(let s of r)try{s(t);}catch(i){this.emitterLogger?.error(i,"listener threw");}}removeAllListeners(e){e===void 0?this.inner.removeAllListeners():this.inner.removeAllListeners(e);}listenerCount(e){return this.inner.listenerCount(e)}wrap(e,t){return r=>{try{t(r);}catch(s){this.emitterLogger?.error(s,"listener threw");}}}tag(e,t,r){this.tagMap(e).set(t,r);}untag(e,t){this.tagMap(e).delete(t);}lookup(e,t){return this.tagMap(e).get(t)}tagMap(e){let t=Ra,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},Ra=Symbol("zaileys.typed-ee.tag");var Na="default",Da="qr",js=6e4,qs=class extends Rt{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=Ur();reconnectStrategy;authGuard;operationGuard;presenceThrottle;scheduleLimiter;authExhausted=false;_socket;reconnectTimer;listenerCleanup=[];inboundHandle;connectResolve;connectReject;pairingRequested=false;cachedSignalWrap=false;creds;credsLoadedAtConnect=false;openedThisRun=false;credsHintShown=false;disconnectEmittedFor=0;connectAttemptSeq=0;pendingDisconnectReason;usernameCache=new Map;_group;_privacy;_newsletter;_community;_profile;_chat;_contact;_business;commandRegistry;commandMiddleware=[];commandPrefixes;citationConfig;ignoreMe;commandDispatcher;_presence;_scheduler;autoDeleteOptions;autoDeleteSweeper;pluginsOptions;pluginRegistry;pluginLoader;waVersion;versionWarming;constructor(e={}){super({logger:yn(e.logger)}),this.sessionId=e.sessionId??Na,this.logger=yn(e.logger),this.authType=e.authType??Da,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&xr(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new Mt({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new Pt,this.reconnectStrategy=Wr(this.reconnectOptions),this.authGuard=Dr(e.authGuard),this.operationGuard=gn(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new se({perSec:t}):void 0,this.commandPrefixes=Ba(e.commandPrefix),this.citationConfig=e.citation,this.ignoreMe=e.ignoreMe??true,this.autoDeleteOptions=e.autoDelete===false?void 0:{maxAgeMs:720*60*60*1e3,...e.autoDelete},this.pluginsOptions=e.plugins,this.attachEmitterLogger(),(e.autoConnect??true)&&queueMicrotask(()=>{this.machine.state==="idle"&&this.warmVersion().finally(()=>{if(this.machine.state==="idle")try{this.connect().catch(r=>this.emitAutoConnectError(r));}catch(r){this.emitAutoConnectError(r);}});});}warmVersion(){if(this.waVersion)return Promise.resolve();if(this.versionWarming)return this.versionWarming;try{return typeof fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=fetchLatestBaileysVersion().then(({version:e})=>{this.waVersion=e;}).catch(e=>{this.logger.warn(e,"fetchLatestBaileysVersion failed; using bundled version");}),this.versionWarming)}catch{return Promise.resolve()}}emitAutoConnectError(e){let t=e instanceof Error?e:new Error(String(e));this.logger.error(t,"auto-connect failed"),this.listenerCount("error")>0&&this.emit("error",{sessionId:this.sessionId,error:t});}logStatus(e){if(!this.statusLog)return;let t=Ir(e);t&&process.stderr.write(`${t}
16
- `);}resolveMe(){let e=this._socket?.user;if(e&&typeof e.id=="string"&&e.id.length>0)return e;let t=this.creds?.me;return t&&typeof t.id=="string"&&t.id.length>0?t:{id:""}}get state(){return this.machine.state}get socket(){return this._socket}get group(){return this._group??=new Oe(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new Ie(()=>this._socket)}get newsletter(){return this._newsletter??=new xe(()=>this._socket,this.operationGuard)}get community(){return this._community??=new Re(()=>this._socket,this.operationGuard)}get profile(){return this._profile??=new Le(()=>this._socket)}get chat(){return this._chat??=new _e(()=>this._socket,async e=>{try{return (await this.store.listMessages(e,{limit:1})).filter(r=>r.key!=null).map(r=>({key:r.key,messageTimestamp:Number(r.messageTimestamp??0)}))}catch{return []}})}get contact(){return this._contact??=new Ne(()=>this._socket,e=>Te(e)?e:`${e.replace(/\D/g,"")}@s.whatsapp.net`)}get business(){return this._business??=new De(()=>this._socket)}get presence(){return this._presence??=new je(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),hn(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new qe({store:this.store,sendSnapshot:e=>this.dispatchSnapshot(e),logger:this.logger,...this.scheduleLimiter?{acquire:()=>this.scheduleLimiter.acquire()}:{}})}async dispatchSnapshot(e){await this.requireSocket().sendMessage(e.recipient,e.content,e.options);}connect(){if(this.authType==="pairing"&&!this.phoneNumber)return Promise.reject(new Error('phoneNumber is required when authType is "pairing"'));if(this.machine.state==="connecting"||this.machine.state==="connected"||this.machine.state!=="idle"&&this.machine.state!=="disconnected"&&this.machine.state!=="reconnecting")return Promise.resolve();if(this._socket){for(let a of this.listenerCleanup)a.off();this.listenerCleanup=[],this._socket=void 0;}let e=this.machine.state==="reconnecting";e||(this.authGuard.reset(),this.authExhausted=false),this.machine.transition("connecting"),this.connectAttemptSeq+=1,this.pairingRequested=false,this.openedThisRun=false,e||this.logStatus({kind:"connecting",sessionId:this.sessionId}),this.cacheSignal&&!this.cachedSignalWrap&&(this.auth=Rr(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Lr(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:js,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=La(s);this._socket=i,this.store.bind(i),this.wireSocket(i);let o=new Promise((a,c)=>{let d=this.connectResolve,l=this.connectReject;this.connectResolve=()=>{d?.(),a();},this.connectReject=u=>{l?.(u),c(u);};});return this.auth.creds.readCreds().then(a=>{this.credsLoadedAtConnect=!!a,Object.assign(t,a??initAuthCreds());}).catch(a=>{this.rejectPendingConnect(a instanceof Error?a:new Error(String(a)));}),o}async disconnect(){if(!(this.machine.state==="idle"||this.machine.state==="disconnected")){this.machine.transition("disconnecting"),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands(),this.autoDeleteSweeper?.stop(),this.autoDeleteSweeper=void 0,await this.pluginLoader?.stop().catch(()=>{}),this.pluginLoader=void 0,this.pluginRegistry=void 0,this._scheduler?.dispose();for(let e of this.listenerCleanup)e.off();if(this.listenerCleanup=[],this._socket){try{this._socket.end(void 0);}catch(e){this.logger.warn(e,"socket.end threw");}this._socket=void 0;}try{await this.auth.signal.close();}catch(e){this.logger.warn(e,"auth.signal.close failed");}try{await this.store.close();}catch(e){this.logger.warn(e,"store.close failed");}if(this.machine.transition("disconnected"),this.disconnectEmittedFor!==this.connectAttemptSeq){let e=this.pendingDisconnectReason??"unknown";this.pendingDisconnectReason=void 0,this.disconnectEmittedFor=this.connectAttemptSeq,this.emit("disconnect",{sessionId:this.sessionId,reason:e,willReconnect:false});}this.rejectPendingConnect(new Error("disconnected before connect resolved"));}}async logout(){if(this.pendingDisconnectReason="logged-out",this._socket)try{await this._socket.logout();}catch(e){this.logger.warn(e,"socket.logout failed");}try{await this.auth.signal.clear();}catch(e){this.logger.warn(e,"auth.signal.clear failed");}try{await this.auth.creds.deleteCreds();}catch(e){this.logger.warn(e,"auth.creds.deleteCreds failed");}if(this.machine.state==="idle"||this.machine.state==="disconnected"){this.disconnectEmittedFor!==this.connectAttemptSeq&&(this.disconnectEmittedFor=this.connectAttemptSeq,this.emit("disconnect",{sessionId:this.sessionId,reason:"logged-out",willReconnect:false})),this.pendingDisconnectReason=void 0;return}await this.disconnect();}command(e,t){return (this.commandRegistry??=new Be).register(e,t),this.attachCommandsIfReady(),this}unregisterCommand(e){return this.commandRegistry?.unregister(e),this}use(e){return this.commandMiddleware.push(e),this}unuse(e){let t=this.commandMiddleware.indexOf(e);return t>=0&&this.commandMiddleware.splice(t,1),this}attachCommandsIfReady(){if(this.commandDispatcher||this.commandPrefixes.length===0||this.commandRegistry===void 0||this.commandRegistry.list().length===0||!this._socket)return;let e=this.commandRegistry;this.commandDispatcher=pn({registry:e,middleware:this.commandMiddleware,prefixes:this.commandPrefixes,logger:this.logger,onText:t=>{let r=s=>t(s);return this.on("text",r),()=>this.off("text",r)},buildContext:(t,r)=>this.buildCommandContext(t,r)});}buildCommandContext(e,t){let r;return {...t,raw:e.raw,command:e.command,args:e.args,flags:e.flags,json:e.json,reply:async(s,i)=>{let o=t.message().key.remoteJid??t.roomId??t.senderId,a=await this.send(o).text(s,i).reply(t.message());return r=a,a},react:s=>this.react(t.message().key,s),edit:async s=>{if(r===void 0)throw new x("NO_SENT_MESSAGE","ctx.edit requires a prior ctx.reply");await this.edit(r).text(s);}}}detachCommands(){this.commandDispatcher?.detach(),this.commandDispatcher=void 0;}send(e){let t=this.requireSocket(),r=s=>{this.store.saveMessage(s).catch(i=>this.logger.warn(i,"recordSent failed"));};return Te(e)?H.create(t,e,void 0,r):H.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new ke(this.requireSocket(),e)}async delete(e,t){await on(this.requireSocket(),e,t);}async react(e,t){return an(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return cn(r,this.store,e,s)}async pin(e,t){return wt(this.requireSocket(),e,true,t)}async unpin(e){return wt(this.requireSocket(),e,false)}async setDisappearing(e,t){let r=await this.resolveRecipient(e);await this.requireSocket().sendMessage(r,{disappearingMessagesInChat:t});}resolveRecipient(e){return dn(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new f("INVALID_OPTIONS","client not connected");return this._socket}attachEmitterLogger(){this.logger;}wireSocket(e){let t=s=>{this.handleConnectionUpdate(s);},r=s=>{let i=this.creds?Object.assign(this.creds,s):s;this.creds=i,this.auth.creds.writeCreds(i).catch(o=>{this.logger.warn(o,"auth.creds.writeCreds failed");});};e.ev.on("connection.update",t),e.ev.on("creds.update",r),this.listenerCleanup.push({off:()=>e.ev.off("connection.update",t)}),this.listenerCleanup.push({off:()=>e.ev.off("creds.update",r)});}async handleConnectionUpdate(e){if(e.qr&&await this.handleQrUpdate(e.qr),e.connection==="open"){this.handleOpen();return}e.connection==="close"&&await this.handleClose(e.lastDisconnect);}async handleQrUpdate(e){if(this.authExhausted)return;if(this.authType==="pairing"&&this.phoneNumber){if(this.pairingRequested)return;let s=Date.now(),i=this.authGuard.evaluate("pairing",s);if(!i.allowed){i.reason==="budget-exhausted"&&this.handleAuthExhausted("pairing",i.attempts,i.max);return}this.pairingRequested=true,this.authGuard.record("pairing",s),this.machine.canTransition("pairing-pending")&&this.machine.transition("pairing-pending");try{let o=Br({phoneNumber:this.phoneNumber}),a=this._socket;if(!a)return;let c=await o.requestCode(a);this.logStatus({kind:"pairing-code",code:c.code}),this.emit("pairing-code",{sessionId:this.sessionId,code:c.code,expiresAt:c.expiresAt});}catch(o){this.logger.warn(o,"pairing-code request failed");}return}let t=Date.now(),r=this.authGuard.evaluate("qr",t);if(!r.allowed){this.handleAuthExhausted("qr",r.attempts,r.max);return}if(this.authGuard.record("qr",t),this.machine.canTransition("qr-pending")&&this.machine.transition("qr-pending"),this.qrTerminal)try{await Fr(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+js});}handleAuthExhausted(e,t,r){this.authExhausted||(this.authExhausted=true,this.logger.warn({sessionId:this.sessionId,kind:e,attempts:t,max:r},`auth attempts exhausted (${t}/${r} ${e}); stopping to avoid WhatsApp spam restriction \u2014 call connect() to retry`),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.emit("auth-exhausted",{sessionId:this.sessionId,kind:e,attempts:t,max:r}),this.disconnect());}handleOpen(){this.machine.canTransition("connected")&&this.machine.transition("connected"),this.openedThisRun=true,this.credsHintShown=false,this.authExhausted=false,this.authGuard.reset(),this.reconnectStrategy.reset();let e=this.resolveMe();this.logStatus({kind:"connected",id:typeof e.id=="string"?e.id:""}),this.emit("connect",{sessionId:this.sessionId,me:e});let t=this._socket;t&&(this.inboundHandle?.detach(),this.inboundHandle=Ws(this,t,{selfJid:typeof e.id=="string"?e.id:"",...typeof e.lid=="string"&&e.lid.length>0?{selfLid:e.lid}:{},...typeof e.name=="string"&&e.name.length>0?{selfName:e.name}:{},channelId:this.sessionId,receiverId:typeof e.id=="string"?e.id:"",prefixes:this.commandPrefixes,logger:this.logger,...this.citationConfig!=null?{citationConfig:this.citationConfig}:{},groupMetadata:s=>this.group.metadata(s).catch(()=>null),receiverName:()=>Promise.resolve(this.resolveMe().name??null),resolveQuoted:(s,i)=>this.lookupQuoted(s,i),resolveLidToPn:s=>this.lidToPn(s),sendReply:async(s,i,o,a)=>await this.send(s).text(i,o).reply(a),react:(s,i)=>this.react(s,i),ignoreMe:this.ignoreMe})),this.attachCommandsIfReady(),this.ensureScheduler().loadPending().catch(s=>this.logger.warn(s,"scheduler loadPending failed")),this.autoDeleteOptions&&(this.autoDeleteSweeper?.stop(),this.autoDeleteSweeper=new Ke({store:this.store,options:this.autoDeleteOptions,logger:this.logger}),this.autoDeleteSweeper.start()),this.pluginsOptions&&!this.pluginLoader&&(this.pluginRegistry=new Fe({client:this,logger:this.logger}),this.pluginLoader=new We({registry:this.pluginRegistry,options:this.pluginsOptions,logger:this.logger}),this.pluginLoader.start().catch(s=>this.logger.error(s,"plugin loader start failed")));let r=this.connectResolve;this.connectResolve=void 0,this.connectReject=void 0,r&&r();}async resolveMessageForResend(e){try{return (await this.store.getMessage(e))?.message??void 0}catch(t){this.logger.warn(t,"getMessage resend lookup failed");return}}lidMapping(){return this._socket?.signalRepository?.lidMapping}async lidToPn(e){try{let t=this.lidMapping()?.getPNForLID;return typeof t=="function"?await t(e):null}catch{return null}}async pnToLid(e){try{let t=this.lidMapping()?.getLIDForPN;return typeof t=="function"?await t(e):null}catch{return null}}async lookupQuoted(e,t){for(let r of [false,true])try{let s=await this.store.getMessage({id:e,remoteJid:t,fromMe:r});if(s!=null)return s}catch{continue}return null}async handleClose(e){this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands();let t=Fa(e?.error),r=_r(t),s=false;if(Nr(r)){try{await this.auth.signal.clear();}catch(i){this.logger.warn(i,"auth.signal.clear failed (post-close)");}try{await this.auth.creds.deleteCreds();}catch(i){this.logger.warn(i,"auth.creds.deleteCreds failed (post-close)");}}if(!Ge(r)&&!this.authExhausted){St(r)&&this.logger.warn({sessionId:this.sessionId},"WhatsApp returned rate-limited (429); backing off before reconnect to avoid restriction");let i=this.reconnectStrategy.next(r);if(i!==null){s=true,this.machine.canTransition("reconnecting")&&this.machine.transition("reconnecting");let o=this.credsLoadedAtConnect&&!this.openedThisRun&&i.attempt>=2&&!this.credsHintShown;o&&(this.credsHintShown=true),this.logStatus({kind:"reconnecting",attempt:i.attempt,delayMs:i.delayMs,reason:r,invalidCredsSuspected:o}),this.emit("reconnecting",{sessionId:this.sessionId,attempt:i.attempt,delayMs:i.delayMs,reason:r}),this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=void 0,this.connect().catch(a=>{this.logger.warn(a,"reconnect attempt failed");});},i.delayMs);}}if(this.disconnectEmittedFor=this.connectAttemptSeq,this.logStatus({kind:"disconnect",reason:r,willReconnect:s}),this.emit("disconnect",{sessionId:this.sessionId,reason:r,willReconnect:s}),!s){if(this._socket){for(let i of this.listenerCleanup)i.off();this.listenerCleanup=[],this._socket=void 0;}this.machine.canTransition("disconnected")&&this.machine.transition("disconnected"),this.rejectPendingConnect(new Error(`connection closed (${r})`));}}rejectPendingConnect(e){let t=this.connectReject;this.connectResolve=void 0,this.connectReject=void 0,t&&t(e);}};function Ba(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function Fa(n){if(!n||typeof n!="object")return;let e=n.output;if(!e)return;let t=e.statusCode;return typeof t=="number"?t:void 0}var Ks=class{credsBlob;signalMap=new Map;closed=false;signal={read:async(e,t)=>{this.assertOpen();let r=this.signalMap.get(e),s={};if(!r)return s;for(let i of t){let o=r.get(i);o!==void 0&&(s[i]=o);}return s},write:async e=>{this.assertOpen();for(let t of Object.keys(e)){let r=e[t];if(!r)continue;let s=this.signalMap.get(t);s||(s=new Map,this.signalMap.set(t,s));for(let i of Object.keys(r)){let o=r[i];o===null?s.delete(i):o!==void 0&&s.set(i,o);}}},delete:async(e,t)=>{this.assertOpen();let r=this.signalMap.get(e);if(r)for(let s of t)r.delete(s);},clear:async()=>{this.assertOpen(),this.signalMap.clear(),this.credsBlob=void 0;},close:async()=>{this.closed=true;}};creds={readCreds:async()=>(this.assertOpen(),this.credsBlob),writeCreds:async e=>{this.assertOpen(),this.credsBlob=structuredClone(e);},deleteCreds:async()=>{this.assertOpen(),this.credsBlob=void 0;}};assertOpen(){if(this.closed)throw new g("STORE_CLOSED","MemoryAuthStore is closed")}};var Lt=null,Wa=async()=>{if(Lt)return Lt;try{return Lt=(await import('better-sqlite3')).default,Lt}catch(n){throw new g("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},An="default",$s=500,Gs=n=>Array.from({length:n},()=>"?").join(","),Vs=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},Hs=class{options;db=null;prepared=null;readyPromise=null;closed=false;constructor(e){this.options=e;}creds={readCreds:async()=>{let t=(await this.ensureReady()).readCreds.get(An);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(An,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(An);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Vs(t,$s)){let o=Gs(i.length),c=s.prepare(`SELECT id, data FROM auth_signal WHERE type = ? AND id IN (${o})`).all(e,...i);for(let d of c)r[d.id]=this.parseBlob(d.data);}return r},write:async e=>{let t=await this.ensureReady(),r=this.db,s=[],i=[];for(let a of Object.keys(e)){let c=e[a];if(c)for(let d of Object.keys(c)){let l=c[d];l===null?i.push({type:a,id:d}):l!==void 0&&s.push({type:a,id:d,blob:this.encodeBlob(l)});}}r.transaction(()=>{for(let a of s)t.writeSignal.run(a.type,a.id,a.blob);for(let a of i)t.deleteSignal.run(a.type,a.id);})();},delete:async(e,t)=>{if(await this.ensureReady(),t.length===0)return;let r=this.db,s=r.transaction(i=>{let o=Gs(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Vs(t,$s))s(i);},clear:async()=>{let e=await this.ensureReady();this.db.transaction(()=>{e.clearSignal.run(),e.clearCreds.run();})();},close:async()=>{if(!this.closed){this.closed=true;try{this.db?.close();}catch(e){throw new g("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new g("STORE_CLOSED","SqliteAuthStore is closed");return this.prepared?this.prepared:(this.readyPromise||(this.readyPromise=this.openAndMigrate().catch(e=>{throw this.readyPromise=null,e})),await this.readyPromise,this.prepared)}async openAndMigrate(){let e=await Wa(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new g("STORE_CONNECTION_FAILED",`failed to open sqlite database at ${String(this.options.database)}`,{cause:r})}try{t.pragma("journal_mode = WAL"),t.pragma("synchronous = NORMAL"),t.pragma("foreign_keys = ON"),t.exec(`CREATE TABLE IF NOT EXISTS auth_creds (id TEXT PRIMARY KEY, data BLOB NOT NULL) WITHOUT ROWID;
17
- CREATE TABLE IF NOT EXISTS auth_signal (type TEXT NOT NULL, id TEXT NOT NULL, data BLOB NOT NULL, PRIMARY KEY(type, id)) WITHOUT ROWID;`);}catch(r){throw t.close(),new g("STORE_CONNECTION_FAILED","failed to migrate sqlite schema",{cause:r})}this.db=t,this.prepared={readCreds:t.prepare("SELECT data FROM auth_creds WHERE id = ?"),writeCreds:t.prepare("INSERT INTO auth_creds(id, data) VALUES(?, ?) ON CONFLICT(id) DO UPDATE SET data = excluded.data"),deleteCreds:t.prepare("DELETE FROM auth_creds WHERE id = ?"),writeSignal:t.prepare("INSERT INTO auth_signal(type, id, data) VALUES(?, ?, ?) ON CONFLICT(type, id) DO UPDATE SET data = excluded.data"),deleteSignal:t.prepare("DELETE FROM auth_signal WHERE type = ? AND id = ?"),clearSignal:t.prepare("DELETE FROM auth_signal"),clearCreds:t.prepare("DELETE FROM auth_creds")};}encodeBlob(e){try{return Buffer.from(JSON.stringify(e,BufferJSON.replacer),"utf8")}catch(t){throw new g("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:t})}}parseBlob(e){try{let t=Buffer.isBuffer(e)?e.toString("utf8"):Buffer.from(e).toString("utf8");return JSON.parse(t,BufferJSON.reviver)}catch(t){throw new g("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var Nt,Ua=async()=>(Nt||(Nt=import('pg').catch(n=>{throw Nt=void 0,new g("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),Nt),ja="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",qa="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",zs=class{externalPool;connectionString;poolMax;ownedPool;resolvedPool;readyPromise;closed=false;constructor(e){let t=e.pool!==void 0,r=e.connectionString!==void 0;if(t&&r)throw new g("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new g("STORE_CONNECTION_FAILED","PostgresAuthStore: pool or connectionString is required");this.externalPool=e.pool,this.connectionString=e.connectionString,this.poolMax=e.max;}async ensureReady(){if(this.closed)throw new g("STORE_CLOSED","PostgresAuthStore is closed");if(this.resolvedPool)return this.resolvedPool;this.readyPromise||(this.readyPromise=(async()=>{let e;if(this.externalPool)e=this.externalPool;else {let t=await Ua(),r=t.Pool??t.default?.Pool;if(!r)throw new g("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(ja),await e.query(qa);}catch(t){throw new g("STORE_CONNECTION_FAILED","failed to migrate auth schema",{cause:t})}return this.resolvedPool=e,e})());try{return await this.readyPromise}catch(e){throw this.readyPromise=void 0,e}}signal={read:async(e,t)=>{let r=await this.ensureReady(),s={};if(t.length===0)return s;try{let i=t.map((a,c)=>`$${c+2}`).join(", "),o=await r.query(`SELECT id, data FROM zaileys_auth_signal WHERE type = $1 AND id IN (${i})`,[String(e),...Array.from(t)]);for(let a of o.rows){let c=Buffer.isBuffer(a.data)?a.data:Buffer.from(a.data);s[a.id]=JSON.parse(c.toString("utf8"),BufferJSON.reviver);}return s}catch(i){throw i instanceof g?i:new g("STORE_READ_FAILED","failed to read signal rows",{cause:i})}},write:async e=>{let t=await this.ensureReady(),r=[];for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a];if(c===null)r.push({kind:"delete",type:String(i),id:a});else if(c!==void 0){let d=Buffer.from(JSON.stringify(c,BufferJSON.replacer),"utf8");r.push({kind:"upsert",type:String(i),id:a,value:d});}}}if(r.length===0)return;let s;try{s=await t.connect(),await s.query("BEGIN");for(let i of r)i.kind==="delete"?await s.query("DELETE FROM zaileys_auth_signal WHERE type = $1 AND id = $2",[i.type,i.id]):await s.query("INSERT INTO zaileys_auth_signal(type, id, data) VALUES ($1, $2, $3) ON CONFLICT (type, id) DO UPDATE SET data = EXCLUDED.data",[i.type,i.id,i.value]);await s.query("COMMIT");}catch(i){if(s)try{await s.query("ROLLBACK");}catch{}throw new g("STORE_WRITE_FAILED","failed to write signal rows",{cause:i})}finally{s?.release();}},delete:async(e,t)=>{let r=await this.ensureReady();if(t.length!==0)try{let s=t.map((i,o)=>`$${o+2}`).join(", ");await r.query(`DELETE FROM zaileys_auth_signal WHERE type = $1 AND id IN (${s})`,[String(e),...Array.from(t)]);}catch(s){throw new g("STORE_WRITE_FAILED","failed to delete signal rows",{cause:s})}},clear:async()=>{let e=await this.ensureReady(),t;try{t=await e.connect(),await t.query("BEGIN"),await t.query("DELETE FROM zaileys_auth_signal"),await t.query("DELETE FROM zaileys_auth_creds"),await t.query("COMMIT");}catch(r){if(t)try{await t.query("ROLLBACK");}catch{}throw new g("STORE_WRITE_FAILED","failed to clear auth tables",{cause:r})}finally{t?.release();}},close:async()=>{if(this.closed)return;this.closed=true;let e=this.ownedPool;if(this.ownedPool=void 0,this.resolvedPool=void 0,this.readyPromise=void 0,e)try{await e.end();}catch{}}};creds={readCreds:async()=>{let e=await this.ensureReady();try{let r=(await e.query("SELECT data FROM zaileys_auth_creds WHERE id = 'default'")).rows[0];if(!r)return;let s=typeof r.data=="string"?r.data:JSON.stringify(r.data);return JSON.parse(s,BufferJSON.reviver)}catch(t){throw t instanceof g?t:new g("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,BufferJSON.replacer);await t.query("INSERT INTO zaileys_auth_creds(id, data) VALUES ('default', $1::jsonb) ON CONFLICT (id) DO UPDATE SET data = EXCLUDED.data",[r]);}catch(r){throw new g("STORE_WRITE_FAILED","failed to write creds",{cause:r})}},deleteCreds:async()=>{let e=await this.ensureReady();try{await e.query("DELETE FROM zaileys_auth_creds WHERE id = 'default'");}catch(t){throw new g("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var Ka="zaileys",Ja=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],$a=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},Ys=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new g("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new g("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??Ka,this.externalClient=e.client,this.url=e.url;}signal={read:async(e,t)=>{if(this.assertOpen(),t.length===0)return {};let r=await this.ensureReady(),s=t.map(a=>this.signalKey(e,a)),i=await this.runRead(()=>r.mGet(s)),o={};for(let a=0;a<t.length;a+=1){let c=i[a];c!=null&&(o[t[a]]=JSON.parse(c,BufferJSON.reviver));}return o},write:async e=>{this.assertOpen();let r=(await this.ensureReady()).multi(),s=0;for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a],d=this.signalKey(i,a),l=this.indexKey(i);c===null?(r.del(d),r.sRem(l,a)):c!==void 0&&(r.set(d,JSON.stringify(c,BufferJSON.replacer)),r.sAdd(l,a)),s+=1;}}s!==0&&await this.runWrite(()=>r.exec());},delete:async(e,t)=>{if(this.assertOpen(),t.length===0)return;let s=(await this.ensureReady()).multi();for(let i of t)s.del(this.signalKey(e,i)),s.sRem(this.indexKey(e),i);await this.runWrite(()=>s.exec());},clear:async()=>{this.assertOpen();let e=await this.ensureReady(),t=e.multi();for(let r of Ja){let s=this.indexKey(r),i=await this.runRead(()=>e.sMembers(s));for(let o of i)t.del(this.signalKey(r,o));t.del(s);}t.del(this.credsKey()),await this.runWrite(()=>t.exec());},close:async()=>{await this.shutdown();}};creds={readCreds:async()=>{this.assertOpen();let e=await this.ensureReady(),t=await this.runRead(()=>e.get(this.credsKey()));if(t!=null)return JSON.parse(t,BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,BufferJSON.replacer)));},deleteCreds:async()=>{this.assertOpen();let e=await this.ensureReady();await this.runWrite(()=>e.del(this.credsKey()));}};credsKey(){return `${this.namespace}:auth:creds`}signalKey(e,t){return `${this.namespace}:auth:signal:${String(e)}:${t}`}indexKey(e){return `${this.namespace}:auth:signal-index:${String(e)}`}async ensureReady(){return this.ready||(this.ready=this.connect()),this.ready}async connect(){if(this.externalClient){if(!this.externalClient.isOpen)throw new g("STORE_CONNECTION_FAILED","provided redis client is not open (call await client.connect() first)");return this.externalClient}let e;try{e=await import('redis');}catch(r){throw $a(r)?new g("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new g("STORE_CONNECTION_FAILED","failed to load redis module",{cause:r})}let t=e.createClient({url:this.url});try{await t.connect();}catch(r){throw new g("STORE_CONNECTION_FAILED",`failed to connect to redis at ${this.url}`,{cause:r})}return this.ownedClient=t,t}async runRead(e){try{return await e()}catch(t){throw new g("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new g("STORE_WRITE_FAILED","redis write failed",{cause:t})}}async shutdown(){if(!this.closed){if(this.closed=true,this.ownedClient){try{await this.ownedClient.quit();}catch{}this.ownedClient=void 0;}this.ready=void 0;}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","RedisAuthStore is closed")}};var Ga="zaileys",tt={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Va=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},Se=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new g("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new g("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Ga,this.externalClient=e.client,this.url=e.url;}async get(e){if(this.assertOpen(),e.length===0)return new Map;let t=await this.ensureClient(),r=await this.runRead(()=>t.query(tt.get,{namespace:this.namespace,keys:[...e]})),s=new Map;for(let i of r??[])s.set(i.key,i.value);return s}async set(e){if(this.assertOpen(),e.length===0)return;let t=await this.ensureClient();await this.runWrite(()=>t.mutation(tt.set,{namespace:this.namespace,items:[...e]}));}async del(e){if(this.assertOpen(),e.length===0)return;let t=await this.ensureClient();await this.runWrite(()=>t.mutation(tt.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(tt.clear,e===void 0?{namespace:this.namespace}:{namespace:this.namespace,prefix:e}));}async list(e,t){this.assertOpen();let r=await this.ensureClient(),s={namespace:this.namespace,prefix:e};return typeof t?.before=="number"&&(s.before=t.before),typeof t?.limit=="number"&&(s.limit=t.limit),await this.runRead(()=>r.query(tt.list,s))??[]}close(){this.closed=true,this.client=void 0;}async ensureClient(){if(this.externalClient)return this.externalClient;if(this.client)return this.client;let e="convex/browser",t;try{t=await import(e);}catch(r){throw Va(r)?new g("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new g("STORE_CONNECTION_FAILED","failed to load convex module",{cause:r})}return this.client=new t.ConvexHttpClient(this.url),this.client}async runRead(e){try{return await e()}catch(t){throw new g("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new g("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","Convex store is closed")}};var Ft="creds",Ha="signal:",nt=(n,e)=>`${Ha}${n}:${e}`,Zs=class{creds;signal;kv;constructor(e){this.kv=new Se(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([Ft])).get(Ft);return s===void 0?void 0:JSON.parse(s,BufferJSON.reviver)},async writeCreds(r){await t.set([{key:Ft,value:JSON.stringify(r,BufferJSON.replacer)}]);},async deleteCreds(){await t.del([Ft]);}},this.signal={async read(r,s){let i=s.map(c=>nt(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(nt(r,c));a[c]=d===void 0?void 0:JSON.parse(d,BufferJSON.reviver);}return a},async write(r){let s=[],i=[];for(let o of Object.keys(r)){let a=r[o];if(a)for(let c of Object.keys(a)){let d=a[c];d==null?i.push(nt(o,c)):s.push({key:nt(o,c),value:JSON.stringify(d,BufferJSON.replacer)});}}s.length>0&&await t.set(s),i.length>0&&await t.del(i);},async delete(r,s){await t.del(s.map(i=>nt(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var Wt=null,za=async()=>{if(Wt)return Wt;try{return Wt=(await import('better-sqlite3')).default,Wt}catch(n){throw new g("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Ut=n=>{try{return Buffer.from(JSON.stringify(n,BufferJSON.replacer),"utf8")}catch(e){throw new g("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},de=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){throw new g("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},Xs=class{options;db=null;prepared=null;readyPromise=null;closed=false;boundSocket;listeners=new Map;constructor(e){this.options=e;}async saveMessage(e){let t=await this.ensureReady(),r=e.key.remoteJid??"",s=e.key.id??"",i=e.key.fromMe?1:0,o=Number(e.messageTimestamp??0);t.upsertMessage.run(r,s,i,o,Ut(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?de(r.data):void 0}async listMessages(e,t){let r=await this.ensureReady(),s=t?.limit??100,i=t?.before;return (typeof i=="number"?r.listMessages.all(e,i,s):r.listMessages.all(e,Number.MAX_SAFE_INTEGER,s)).map(a=>de(a.data))}async saveChat(e){let t=await this.ensureReady(),r=e.id;if(!r)return;let s=e.archived?1:0;t.upsertChat.run(r,s,Ut(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?de(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>de(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,Ut(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?de(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>de(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,Ut(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?de(r.data):void 0}async deleteMessage(e){(await this.ensureReady()).deleteMessage.run(e.remoteJid??"",e.id??"",e.fromMe===true?1:0);}async pruneMessages(e){let t=await this.ensureReady(),r=this.db,s=0,i=e.chatFilter?r.prepare("SELECT DISTINCT remote_jid FROM messages").all().map(o=>o.remote_jid).filter(o=>e.chatFilter(o)):void 0;if(e.olderThan!==void 0)if(i)for(let o of i)s+=t.pruneByAgeChat.run(e.olderThan,o).changes;else s+=t.pruneByAge.run(e.olderThan).changes;if(e.maxPerChat!==void 0){let o=i?"WHERE remote_jid IN ("+i.map(()=>"?").join(",")+")":"",a=r.prepare(`DELETE FROM messages WHERE rowid IN (
10
+ `:""}${n.body}`};return n.footer!==void 0&&(t.footer=n.footer),it(n.buttons,t)};var ct=n=>{if(typeof n!="string"||n.trim().length===0)throw new g("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var ir=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var Mi=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],V=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r,s){return new n(e,ir(t,r,s))}to(e){return this.internal.recipient=e,delete this.internal.resolveRecipient,this}text(e,t){return t?.rich===true?this.internal.content=Fn(Kn(e),t):this.internal.content=ct(e),this}image(e,t){return this.internal.pendingContent=le(e,t),this}videoNote(e,t){return this.internal.pendingContent=X(e,{...t,ptv:true}),this}video(e,t){return this.internal.pendingContent=X(e,t),this}audio(e,t){return this.internal.pendingContent=Nn(e,t),this}document(e,t){return this.internal.pendingContent=$n(e,t),this}sticker(e,t){return this.internal.pendingContent=nr(e,t),this}buttons(e,t){return this.internal.content=it(e,t),this}carousel(e,t){return this.internal.content=Bn(e,t),this}list(e){return this.internal.content=Yn(e),this}poll(e,t,r){return this.internal.content=er(e,t,r),this}location(e,t,r){return this.internal.content=Zn(e,t,r),this}contact(e){return this.internal.content=Jn(e),this}template(e){return this.internal.content=sr(e),this}event(e){return this.internal.content=Vn(e),this}groupInvite(e){return this.internal.content=Hn(e),this}product(e){return this.internal.pendingContent=tr(e),this}requestPhoneNumber(){return this.internal.content={requestPhoneNumber:{}},this}sharePhoneNumber(){return this.internal.content={sharePhoneNumber:{}},this}limitSharing(e=true){return this.internal.content={limitSharing:e},this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new g("INVALID_OPTIONS","reply() requires a quoted message or key");let t="key"in e&&e.key!=null;return this.internal.quoted=t?e:{key:e},this}mentions(e){if(e.length===0)throw new g("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new g("INVALID_OPTIONS",`invalid jid: ${String(r)}`);let t=new Set([...this.internal.mentions??[],...e]);return this.internal.mentions=[...t],this}mentionAll(){return this.internal.mentionAll=true,this}disappearing(e){if(!Number.isInteger(e)||e<=0)throw new g("INVALID_OPTIONS","disappearing() requires a positive integer duration");return this.internal.disappearingSeconds=e,this}then(e,t){return (async()=>{if(this.internal.resolveRecipient&&(this.internal.recipient=await this.internal.resolveRecipient(this.internal.recipient),delete this.internal.resolveRecipient),this.internal.albumItems){let d={recipient:this.internal.recipient};return this.internal.quoted!==void 0&&(d.quoted=this.internal.quoted),this.internal.mentions!==void 0&&(d.mentions=this.internal.mentions),this.internal.mentionAll!==void 0&&(d.mentionAll=this.internal.mentionAll),this.internal.disappearingSeconds!==void 0&&(d.disappearingSeconds=this.internal.disappearingSeconds),In(this.socket,this.internal.recipient,this.internal.albumItems,d)}if(this.internal.pendingContent&&(this.internal.content=await this.internal.pendingContent),!this.internal.content)throw new g("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[N];if(i!==void 0){let d=s[Jt],l=s[Gt];return this.sendRelay(i,d,l)}let o=this.internal.content;this.internal.mentions&&this.internal.mentions.length>0&&(o.mentions=this.internal.mentions),this.internal.mentionAll&&(o.mentionAll=true);let a={};this.internal.quoted&&(a.quoted=this.internal.quoted),this.internal.disappearingSeconds!==void 0&&(a.ephemeralExpiration=this.internal.disappearingSeconds);let c;try{c=await this.socket.sendMessage(this.internal.recipient,o,a);}catch(d){throw new g("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new g("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await I(t.src),s=await prepareWAMessageMedia({[t.kind]:r},{upload:this.socket.waUploadToServer});e.hasMediaAttachment=true,t.kind==="image"&&s.imageMessage&&(e.imageMessage=s.imageMessage),t.kind==="video"&&s.videoMessage&&(e.videoMessage=s.videoMessage);}async sendRelay(e,t,r){let s=this.socket.relayMessage;if(typeof s!="function")throw new g("SEND_FAILED","socket does not support relayMessage (interactive content)");if(this.socket.waUploadToServer!==void 0)try{let u=e.interactiveMessage?.header;t!==void 0&&u&&await this.uploadHeaderMedia(u,t);let w=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&w)for(let S of r){let v=w[S.index]?.header;v&&await this.uploadHeaderMedia(v,S);}}catch(u){throw new g("SEND_FAILED","interactive media upload failed",{cause:u})}let o={userJid:this.socket.user?.id??""},a=this.internal.quoted;a!==void 0&&a.message!=null&&(o.quoted=a);let c=generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new g("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:Mi}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new g("SEND_FAILED","socket relayMessage rejected",{cause:u})}return this.internal.recordSent?.(c),c.key}};var Ae=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=ct(e),this}image(e,t){return this.pendingContent=le(e,t),this}video(e,t){return this.pendingContent=X(e,t),this}then(e,t){return this.send().then(e,t)}async send(){let e=this.key.remoteJid;if(typeof e!="string"||e.length===0)throw new g("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new g("EMPTY_CONTENT","edit() requires a content method before await");let t={...this.content,edit:this.key},r;try{r=await this.socket.sendMessage(e,t);}catch(s){throw new g("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new g("SEND_FAILED","socket returned no message key");return r.key}};var Ht=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new g("INVALID_OPTIONS","message key is missing remoteJid");return e},zt=n=>{if(!n?.key)throw new g("SEND_FAILED","socket returned no message key");return n.key},Yt=async(n,e,t={})=>{let r=Ht(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new g("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},Zt=async(n,e,t)=>{let r=Ht(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return zt(s)},Xt=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new g("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return zt(i)},dt=async(n,e,t,r={})=>{let s=Ht(e),i={pin:e,type:t?1:2,time:r.duration??86400},o=await n.sendMessage(s,i);return zt(o)};var Si=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,Pe=n=>Si.test(n),Qt=async(n,e,t,r=Ai)=>{if(Pe(e))return e;let s=t.get(e);if(s!==void 0)return s;let i=r.get(e);if(i!==void 0)return i;let o=(async()=>{let c=(await n.onWhatsApp(e))?.find(d=>d.exists&&d.jid);if(!c)throw new g("USERNAME_NOT_FOUND",`username "${e}" not found`);return t.set(e,c.jid),c.jid})();r.set(e,o);try{return await o}finally{r.delete(e);}},Ai=new Map;var k=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysDomainError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Ce=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}mapParticipants(e){return e.map(t=>({jid:t.jid,status:t.status}))}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("group.create",()=>this.requireSocket().groupCreate(e,t))}async addMember(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"add"));return this.mapParticipants(r)}async removeMember(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"remove"));return this.mapParticipants(r)}async promote(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"promote"));return this.mapParticipants(r)}async demote(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupParticipantsUpdate(e,t,"demote"));return this.mapParticipants(r)}async updateSubject(e,t){await this.requireSocket().groupUpdateSubject(e,t);}async updateDescription(e,t){await this.requireSocket().groupUpdateDescription(e,t);}async leave(e){await this.requireSocket().groupLeave(e);}async metadata(e){return this.requireSocket().groupMetadata(e)}async tagMember(e,t,r){await this.requireSocket().updateMemberLabel(e,r);}async inviteCode(e){let t=await this.requireSocket().groupInviteCode(e);if(!t)throw new k("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new k("OPERATION_FAILED","invite code unavailable");return t}async acceptInvite(e){let t=await this.run("group.join",()=>this.requireSocket().groupAcceptInvite(e));if(!t)throw new k("OPERATION_FAILED","invite acceptance failed");return t}async toggleEphemeral(e,t){await this.requireSocket().groupToggleEphemeral(e,t);}async setting(e,t){await this.requireSocket().groupSettingUpdate(e,t);}async list(){let e=await this.requireSocket().groupFetchAllParticipating();return Object.values(e)}async inviteInfo(e){return this.requireSocket().groupGetInviteInfo(e)}async joinRequests(e){return this.requireSocket().groupRequestParticipantsList(e)}async approveJoin(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupRequestParticipantsUpdate(e,t,"approve"));return this.mapParticipants(r)}async rejectJoin(e,t){let r=await this.run("group.participants",()=>this.requireSocket().groupRequestParticipantsUpdate(e,t,"reject"));return this.mapParticipants(r)}async joinApproval(e,t){await this.requireSocket().groupJoinApprovalMode(e,t?"on":"off");}async memberAddMode(e,t){await this.requireSocket().groupMemberAddMode(e,t?"admin_add":"all_member_add");}};var Ee=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async set(e){let t=this.requireSocket();if(e.lastSeen!==void 0&&await t.updateLastSeenPrivacy(e.lastSeen),e.online!==void 0&&await t.updateOnlinePrivacy(e.online),e.profile!==void 0&&await t.updateProfilePicturePrivacy(e.profile),e.status!==void 0&&await t.updateStatusPrivacy(e.status),e.readReceipts!==void 0){let r=typeof e.readReceipts=="boolean"?e.readReceipts?"all":"none":e.readReceipts;await t.updateReadReceiptsPrivacy(r);}e.groupAdd!==void 0&&await t.updateGroupsAddPrivacy(e.groupAdd);}async get(){return this.requireSocket().fetchPrivacySettings()}async block(e){await this.requireSocket().updateBlockStatus(e,"block");}async unblock(e){await this.requireSocket().updateBlockStatus(e,"unblock");}async blocklist(){return this.requireSocket().fetchBlocklist()}async disappearingMode(e){await this.requireSocket().updateDefaultDisappearingMode(e);}};var be=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("newsletter.create",async()=>{let r=this.requireSocket(),s=await r.newsletterCreate(e,t?.description);return t?.picture&&await r.newsletterUpdatePicture(s.id,t.picture),s})}async follow(e){await this.run("newsletter.follow",()=>this.requireSocket().newsletterFollow(e));}async unfollow(e){await this.run("newsletter.follow",()=>this.requireSocket().newsletterUnfollow(e));}async metadata(e){let r=await this.requireSocket().newsletterMetadata("jid",e);if(!r)throw new k("NEWSLETTER_NOT_FOUND",`newsletter ${e} not found`);return r}async updateName(e,t){await this.requireSocket().newsletterUpdateName(e,t);}async updateDescription(e,t){await this.requireSocket().newsletterUpdateDescription(e,t);}async updatePicture(e,t){await this.requireSocket().newsletterUpdatePicture(e,t);}async mute(e){await this.requireSocket().newsletterMute(e);}async unmute(e){await this.requireSocket().newsletterUnmute(e);}async delete(e){await this.requireSocket().newsletterDelete(e);}async removePicture(e){await this.requireSocket().newsletterRemovePicture(e);}async react(e,t,r){await this.requireSocket().newsletterReactMessage(e,t,r);}async unreact(e,t){await this.requireSocket().newsletterReactMessage(e,t);}async subscribers(e){return this.requireSocket().newsletterSubscribers(e)}async messages(e,t=50,r){return this.requireSocket().newsletterFetchMessages(e,t,r?.since,r?.after)}async adminCount(e){return this.requireSocket().newsletterAdminCount(e)}async changeOwner(e,t){await this.requireSocket().newsletterChangeOwner(e,t);}async demote(e,t){await this.requireSocket().newsletterDemote(e,t);}};var ke=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}run(e,t){return this.guard?this.guard.run(e,t):t()}async create(e,t){return this.run("community.create",()=>this.requireSocket().communityCreate(e,t))}async createGroup(e,t,r){return this.run("community.create",()=>this.requireSocket().communityCreateGroup(e,t,r))}async linkGroup(e,t){await this.requireSocket().communityLinkGroup(t,e);}async unlinkGroup(e,t){await this.requireSocket().communityUnlinkGroup(t,e);}async subGroups(e){return (await this.requireSocket().communityFetchLinkedGroups(e)).linkedGroups}async leave(e){await this.requireSocket().communityLeave(e);}async updateSubject(e,t){await this.requireSocket().communityUpdateSubject(e,t);}async updateDescription(e,t){await this.requireSocket().communityUpdateDescription(e,t);}async inviteCode(e){return this.requireSocket().communityInviteCode(e)}async revokeInvite(e){return this.requireSocket().communityRevokeInvite(e)}async acceptInvite(e){return this.run("community.join",()=>this.requireSocket().communityAcceptInvite(e))}async metadata(e){return this.requireSocket().communityMetadata(e)}async list(){return Object.values(await this.requireSocket().communityFetchAllParticipating())}async inviteInfo(e){return this.requireSocket().communityGetInviteInfo(e)}async toggleEphemeral(e,t){await this.requireSocket().communityToggleEphemeral(e,t);}async setting(e,t){await this.requireSocket().communitySettingUpdate(e,t);}async memberAddMode(e,t){await this.requireSocket().communityMemberAddMode(e,t?"admin_add":"all_member_add");}async joinApproval(e,t){await this.requireSocket().communityJoinApprovalMode(e,t?"on":"off");}};var Te=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async setName(e){await this.requireSocket().updateProfileName(e);}async setStatus(e){await this.requireSocket().updateProfileStatus(e);}async setPicture(e,t){await this.requireSocket().updateProfilePicture(e,t);}async removePicture(e){await this.requireSocket().removeProfilePicture(e);}async getPicture(e,t=false){return await this.requireSocket().profilePictureUrl(e,t?"image":"preview")??null}async getStatus(e){return this.requireSocket().fetchStatus(e)}};var Pi=n=>{if(typeof n.remoteJid!="string"||n.remoteJid.length===0)throw new k("OPERATION_FAILED","message key is missing remoteJid");return n.remoteJid},Oe=class{constructor(e,t){this.getSocket=e;this.resolveLast=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async last(e){return await this.resolveLast?.(e)??[]}async archive(e){await this.requireSocket().chatModify({archive:true,lastMessages:await this.last(e)},e);}async unarchive(e){await this.requireSocket().chatModify({archive:false,lastMessages:await this.last(e)},e);}async pin(e){await this.requireSocket().chatModify({pin:true},e);}async unpin(e){await this.requireSocket().chatModify({pin:false},e);}async mute(e,t){await this.requireSocket().chatModify({mute:t??Date.now()+365*24*60*60*1e3},e);}async unmute(e){await this.requireSocket().chatModify({mute:null},e);}async markRead(e){await this.requireSocket().chatModify({markRead:true,lastMessages:await this.last(e)},e);}async markUnread(e){await this.requireSocket().chatModify({markRead:false,lastMessages:await this.last(e)},e);}async star(e,t=true){let r=Pi(e);await this.requireSocket().chatModify({star:{messages:[{id:e.id??"",fromMe:e.fromMe===true}],star:t}},r);}async unstar(e){await this.star(e,false);}async delete(e){await this.requireSocket().chatModify({delete:true,lastMessages:await this.last(e)},e);}async clear(e){await this.requireSocket().chatModify({clear:true,lastMessages:await this.last(e)},e);}};var Ie=class{constructor(e,t){this.getSocket=e;this.normalize=t;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async check(...e){return (await this.requireSocket().onWhatsApp(...e)??[]).map(r=>{let s={jid:r.jid,exists:r.exists};return r.lid!==void 0&&(s.lid=r.lid),s})}async exists(e){let[t]=await this.check(e);return t?.exists??false}async save(e,t){await this.requireSocket().addOrEditContact(this.normalize(e),t);}async remove(e){await this.requireSocket().removeContact(this.normalize(e));}};var xe=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new k("NOT_CONNECTED","client not connected");return e}async profile(e){return this.requireSocket().getBusinessProfile(e)}async catalog(e={}){return this.requireSocket().getCatalog(e)}async collections(e,t){return this.requireSocket().getCollections(e,t)}async orderDetails(e,t){return this.requireSocket().getOrderDetails(e,t)}async createProduct(e){return this.requireSocket().productCreate(e)}async updateProduct(e,t){return this.requireSocket().productUpdate(e,t)}async deleteProduct(...e){return this.requireSocket().productDelete(e)}};var x=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysCommandError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Ci=n=>{let e=n[0];return e==="{"||e==="["},Ei=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},bi=n=>n===" "||n===" "||n===`
11
+ `||n==="\r",ki=n=>{let e=[],t="",r=null,s=false,i=false,o=true;for(let a=0;a<n.length;a+=1){let c=n[a];if(s){t+=c,s=false,i=true,o=false;continue}if(c==="\\"&&r!==null){s=true;continue}if(r!==null){c===r?r=null:t+=c,o=false;continue}if((c==='"'||c==="'")&&o){r=c,i=true,o=false;continue}if(bi(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},Ti=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},Oi=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function en(n,e){let t=Ti(n,e);if(t===null)return Oi(n);let r=n.slice(t.length),s=ki(r),i={matched:true,args:[],flags:{},json:void 0,raw:n};if(s.length===0)return i.name="",i;i.name=(s[0]??"").toLowerCase();let o=false;for(let a=1;a<s.length;a+=1){let c=s[a];if(c!==void 0){if(c.startsWith("--")){let d=c.slice(2);if(d.length===0){i.args.push(c);continue}let l=d.indexOf("=");if(l!==-1){let w=d.slice(0,l),S=d.slice(l+1);i.flags[w]=S;continue}let u=s[a+1];u!==void 0&&!u.startsWith("--")?(i.flags[d]=u,a+=1):i.flags[d]=true;continue}if(!o&&Ci(c)){let d=Ei(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var or=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new x("INVALID_COMMAND_NAME","empty command segment in spec");return e},pe=n=>n.join(" "),Re=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new x("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>or(a)),s=r[0],i=r.slice(1).map(a=>pe(a)),o={name:pe(s),aliases:i,parts:s,handler:t};for(let a of r){let c=pe(a);if(this.paths.has(c))throw new x("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(pe(a),o),a.length>this.maxDepth&&(this.maxDepth=a.length);this.defs.push(o);}resolve(e){if(!e.matched||e.name===void 0||e.name.length===0)return;let t=[e.name.toLowerCase(),...e.args.map(s=>s.toLowerCase())],r=Math.min(this.maxDepth,t.length);for(let s=r;s>=1;s-=1){let i=t.slice(0,s).join(" "),o=this.paths.get(i);if(o!==void 0)return {def:o,args:e.args.slice(s-1)}}}unregister(e){let t=e.split("|").map(o=>or(o)),r=pe(t[0]),s=this.paths.get(r);if(s===void 0)return;for(let o of [s.parts,...s.aliases.map(a=>a.split(" "))])this.paths.delete(pe(o));let i=this.defs.indexOf(s);i>=0&&this.defs.splice(i,1),this.maxDepth=this.defs.reduce((o,a)=>Math.max(o,a.parts.length),1);}list(){return [...this.defs]}};async function tn(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new x("MIDDLEWARE_ERROR","next() called multiple times");if(r=o,o===n.length){try{await t();}catch(c){throw s.error=c,s.thrown=true,c}return}let a=n[o];try{await a(e,()=>i(o+1));}catch(c){throw s.thrown||c instanceof x?c:new x("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function nn(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=en(s.text,n.prefixes);if(!i.matched)return;let o=n.registry.resolve(i);if(o===void 0)return;let a={command:o.def.name,args:o.args,flags:i.flags,json:i.json,raw:i.raw},c=n.buildContext(a,s);Promise.resolve(tn(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let l=d instanceof x?d:new x("HANDLER_ERROR","command handler failed",{cause:d});n.logger.error(l,"command dispatch failed");});},t=n.onText(e),r=false;return {detach(){r||(r=true,t());}}}var ar=n=>n;var Le=class{host;logger;plugins=new Map;constructor(e){this.host=e.client,this.logger=e.logger??e.client.logger;}has(e){return this.plugins.has(e)}list(){return [...this.plugins.keys()]}async loadPlugin(e,t){if(typeof e?.name!="string"||typeof e?.setup!="function"){this.logger?.warn({file:t},"plugin: invalid shape (need name + setup); skipped");return}if(this.plugins.has(e.name)){this.logger?.warn({name:e.name,file:t},"plugin: duplicate name; skipped");return}let r=[],s={client:this.host,logger:this.logger,pluginDir:We.dirname(t),command:(i,o)=>{this.host.command(i,o),r.push(()=>this.host.unregisterCommand(i));},use:i=>{this.host.use(i),r.push(()=>{this.host.unuse(i);});},on:(i,o)=>{let a=this.host.on(i,o);return r.push(a),a},once:(i,o)=>{let a=false,c=this.host.on(i,d=>{a||(a=true,c(),o(d));});return r.push(c),c}};try{let i=await e.setup(s);typeof i=="function"&&r.push(i);}catch(i){for(let o of [...r].reverse())try{await o();}catch{}this.logger?.error({err:i,name:e.name,file:t},"plugin: setup failed; skipped");return}this.plugins.set(e.name,{plugin:e,file:t,disposers:r});}async unload(e){let t=this.plugins.get(e);if(t){this.plugins.delete(e);for(let r of [...t.disposers].reverse())try{await r();}catch(s){this.logger?.warn({err:s,name:e},"plugin: disposer threw");}try{await t.plugin.onUnload?.();}catch(r){this.logger?.warn({err:r,name:e},"plugin: onUnload threw");}}}async unloadAll(){for(let e of this.list())await this.unload(e);}};var Li=/\.(ts|js|mjs|cjs)$/,Ni=/(\.d\.ts$|^_|[/\\]_)/;async function sn(n,e,t){let r;try{r=await promises.readdir(n,{withFileTypes:!0});}catch{return []}let s=[];for(let i of r){let o=We.join(n,i.name);t.test(i.name)||t.test(o)||(i.isDirectory()?s.push(...await sn(o,e,t)):e.test(i.name)&&s.push(o));}return s}async function dr(n,e){try{let r=await import(pathToFileURL(n).href+(e!==void 0?`?t=${e}`:"")),s=r.default??r;return s&&typeof s.name=="string"&&typeof s.setup=="function"?s:void 0}catch{return}}var Ne=class{dir;pattern;ignore;watchEnabled;onError;registry;logger;watcher;fileToName=new Map;bust=0;debounce;pending=new Set;flushChain=Promise.resolve();constructor(e){this.registry=e.registry,this.logger=e.logger,this.dir=We.resolve(e.options.dir??"./plugins"),this.pattern=e.options.pattern??Li,this.ignore=e.options.ignore??Ni,this.watchEnabled=e.options.watch!==false,this.onError=e.options.onError;}async start(){let e=await sn(this.dir,this.pattern,this.ignore);for(let t of e)await this.loadFile(t);this.watchEnabled&&this.startWatch();}async stop(){this.debounce&&clearTimeout(this.debounce),this.watcher?.close(),this.watcher=void 0,await this.flushChain,await this.registry.unloadAll(),this.fileToName.clear();}async loadFile(e){let t=await dr(e,this.bust);if(!t){let i=new Error(`failed to import plugin: ${e}`);this.onError?.(i,e),this.logger?.warn({file:e},"plugin: import failed; skipped");return}let r=this.registry.list();await this.registry.loadPlugin(t,e);let s=this.registry.list().find(i=>!r.includes(i));s&&this.fileToName.set(e,s);}startWatch(){try{this.watcher=watch(this.dir,{recursive:!0},(e,t)=>{if(t==null)return;let r=We.join(this.dir,t.toString());this.ignore.test(t.toString())||!this.pattern.test(t.toString())||(this.pending.add(r),this.debounce&&clearTimeout(this.debounce),this.debounce=setTimeout(()=>{this.flushChain=this.flushChain.then(()=>this.flush());},150),this.debounce.unref?.());});}catch(e){this.logger?.warn({err:e,dir:this.dir},"plugin: watch unavailable; hot-reload disabled");}}async flush(){let e=[...this.pending];this.pending.clear(),this.bust+=1;for(let t of e){let r=this.fileToName.get(t);r&&(await this.registry.unload(r),this.fileToName.delete(t));let s=true;try{await promises.access(t);}catch{s=false;}s&&await this.loadFile(t);}}};var O=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysAutomationError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var Di=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),ne=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new O("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new O("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new O("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??Di;let r=e.burst??e.perSec;this.global={tokens:r,capacity:r,ratePerMs:e.perSec/1e3,last:this.now()},e.perJidPerSec!==void 0&&(this.perJidRatePerMs=e.perJidPerSec/1e3,this.perJidCapacity=e.perJidPerSec);}async acquire(e){await this.consume(this.global),e!==void 0&&this.perJidRatePerMs!==void 0&&await this.consume(this.bucketFor(e));}bucketFor(e){let t=this.perJid.get(e);if(t)return t;let r=this.perJidCapacity??1,s={tokens:r,capacity:r,ratePerMs:this.perJidRatePerMs??1,last:this.now()};return this.perJid.set(e,s),s}consume(e){if(this.refill(e),e.tokens>=1)return e.tokens-=1,Promise.resolve();let t=(1-e.tokens)/e.ratePerMs;return e.tokens-=1,this.sleep(t)}refill(e){let t=this.now(),r=t-e.last;r>0&&(e.tokens=Math.min(e.capacity,e.tokens+r*e.ratePerMs),e.last=t);}};var _i={"group.create":6e4,"group.join":3e4,"group.participants":1e4,"group.update":3e3,"community.create":12e4,"community.join":3e4,"community.update":3e3,"newsletter.create":12e4,"newsletter.follow":2e3,"newsletter.update":3e3},Bi=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function on(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??Bi,i={..._i,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,l)=>{let u=i[d]??0,w=o.get(d);if(w!==void 0&&u>0){let S=u-(r()-w);S>0&&await s(S);}return o.set(d,r()),l()};return {run(d,l){if(!t)return l();let w=(a.get(d)??Promise.resolve()).then(()=>c(d,l),()=>c(d,l));return a.set(d,w.then(()=>{},()=>{})),w}}}var Fi={maxRetries:0,backoffMs:()=>0},Wi=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),De=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??Fi,this.sleep=t.sleep??Wi;}add(e){return new Promise((t,r)=>{this.pending.push({run:()=>this.execute(e).then(t,r)}),this.pump();})}onIdle(){return this.active===0&&this.pending.length===0?Promise.resolve():new Promise(e=>{this.idleWaiters.push(e);})}pump(){for(;this.active<this.concurrency&&this.pending.length>0;){let e=this.pending.shift();if(!e)break;this.active++,e.run().finally(()=>{this.active--,this.pump(),this.settleIdle();});}}settleIdle(){if(this.active===0&&this.pending.length===0&&this.idleWaiters.length>0){let e=this.idleWaiters;this.idleWaiters=[];for(let t of e)t();}}async execute(e){let t=0;for(;;)try{return await e()}catch(r){if(t>=this.retry.maxRetries)throw r;t+=1,await this.sleep(this.retry.backoffMs(t));}}};var ji=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function an(n,e,t,r={}){let s={sent:[],failed:[]};if(n.length===0)return s;let i=r.rateLimitPerSec??5,o={};t.now&&(o.now=t.now),t.sleep&&(o.sleep=t.sleep);let a=t.limiter??new ne({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},l=c?new De({concurrency:1,retry:c},d):void 0,u=n.length,w=0;for(let S of n){await a.acquire(S);let v=()=>e(t.sendTo(S)).then(()=>{});try{l?await l.add(v):await v(),s.sent.push(S),w+=1,r.onProgress?.(w,u,S,!0);}catch(C){s.failed.push({jid:S,error:ji(C)}),w+=1,r.onProgress?.(w,u,S,false);}}return s}var Ui=1e3,_e=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??Ui,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new O("NOT_CONNECTED","client not connected");return e}throttled(e,t){if(!this.throttleEnabled||this.minIntervalMs<=0)return false;let r=`${e}:${t??"global"}`,s=this.lastSent.get(r),i=this.now();return s!==void 0&&i-s<this.minIntervalMs?true:(this.lastSent.set(r,i),false)}async update(e,t){let r=this.requireSocket();if(!this.throttled(e,t))try{await(t===void 0?r.sendPresenceUpdate(e):r.sendPresenceUpdate(e,t));}catch(s){throw new O("PRESENCE_FAILED",`presence update '${e}' failed`,{cause:s})}}scheduleClear(e,t){let r=this.getSocket();if(!r)return;let s=setTimeout(()=>{r.sendPresenceUpdate("paused",e).catch(()=>{});},t);typeof s.unref=="function"&&s.unref();}async online(){await this.update("available");}async offline(){await this.update("unavailable");}async typing(e,t){await this.update("composing",e),t!==void 0&&this.scheduleClear(e,t);}async recording(e,t){await this.update("recording",e),t!==void 0&&this.scheduleClear(e,t);}};var Ki={set:(n,e)=>setTimeout(n,e),clear:n=>clearTimeout(n)},Ji=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",Be=class{store;sendSnapshot;now;timer;logger;acquire;memory=new Map;timers=new Map;constructor(e){this.store=e.store,this.sendSnapshot=e.sendSnapshot,this.now=e.now??(()=>Date.now()),this.timer=e.timer??Ki,this.logger=e.logger,this.acquire=e.acquire;}async scheduleAt(e,t){let r=e.getTime();if(Number.isNaN(r))throw new O("SCHEDULE_INVALID","scheduleAt requires a valid Date");let s=await this.evaluate(t),i=randomUUID(),o={id:i,fireAt:r,recipient:s.recipient,payload:s};return await this.persist(o),this.arm(o),{id:i,cancel:()=>{this.cancel(i);}}}async loadPending(){let e=this.store.listScheduledJobs;if(!e){for(let r of this.memory.values())this.timers.has(r.id)||this.arm(r);return}let t;try{t=await e.call(this.store);}catch(r){this.logger?.warn(r,"scheduler loadPending failed");return}for(let r of t)this.timers.has(r.id)||(this.memory.set(r.id,r),this.arm(r));}dispose(){for(let e of this.timers.values())this.timer.clear(e);this.timers.clear();}cancel(e){let t=this.timers.get(e);t!==void 0&&(this.timer.clear(t),this.timers.delete(e)),this.memory.delete(e),this.remove(e);}arm(e){let t=Math.max(0,e.fireAt-this.now()),r=this.timer.set(()=>{this.fire(e);},t);this.timers.set(e.id,r);}async fire(e){if(this.timers.delete(e.id),Ji(e.payload))try{this.acquire&&await this.acquire(),await this.sendSnapshot(e.payload);}catch(t){this.logger?.warn(t,"scheduled send failed; retaining job for retry");return}this.memory.delete(e.id),await this.remove(e.id);}async persist(e){let t=this.store.saveScheduledJob;if(t){await t.call(this.store,e);return}this.memory.set(e.id,e);}async remove(e){let t=this.store.deleteScheduledJob;if(t)try{await t.call(this.store,e);}catch(r){this.logger?.warn(r,"scheduler deleteScheduledJob failed");}this.memory.delete(e);}async evaluate(e){let t,r=0,s={sendMessage:async(o,a,c)=>{if(r+=1,r>1)throw new O("SCHEDULE_INVALID","scheduling multi-part messages (e.g. album) is not supported; schedule a single message");return t=c?{recipient:o,content:a,options:c}:{recipient:o,content:a},{key:{remoteJid:o,id:"scheduled-snapshot",fromMe:true}}},relayMessage:async()=>{throw new O("SCHEDULE_INVALID","scheduling interactive/relayed content is not supported; schedule a text or media message")}},i=V.create(s,"");try{await e(i);}catch(o){throw o instanceof O?o:new O("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new O("SCHEDULE_INVALID","scheduled builder produced no content");return t}};async function lr(n,e){if(typeof n.deleteMessage!="function"||typeof n.listChats!="function")return 0;let t=await n.listChats(),r=0;for(let s of t){let i=s.id??"";if(i.length===0||e.chatFilter&&!e.chatFilter(i))continue;let a=[...await n.listMessages(i)].sort((c,d)=>Number(d.messageTimestamp??0)-Number(c.messageTimestamp??0));for(let c=0;c<a.length;c+=1){let d=a[c],l=Number(d.messageTimestamp??0),u=e.olderThan!==void 0&&l<e.olderThan,w=e.maxPerChat!==void 0&&c>=e.maxPerChat;(u||w)&&(await n.deleteMessage(d.key),r+=1);}}return r}var Fe=class{store;options;logger;now;timer;running=false;warnedUnsupported=false;disabled=false;constructor(e){this.store=e.store,this.options=e.options,this.logger=e.logger,this.now=e.now??Date.now;}get active(){return this.options.maxAgeMs!==void 0||this.options.maxPerChat!==void 0}buildPruneOptions(){let e={};return this.options.maxAgeMs!==void 0&&(e.olderThan=Math.floor((this.now()-this.options.maxAgeMs)/1e3)),this.options.maxPerChat!==void 0&&(e.maxPerChat=this.options.maxPerChat),typeof this.options.chats=="function"&&(e.chatFilter=this.options.chats),e}async runOnce(){if(!this.active||this.disabled)return 0;let e=this.buildPruneOptions();return typeof this.store.pruneMessages=="function"?this.store.pruneMessages(e):typeof this.store.deleteMessage=="function"?lr(this.store,e):(this.disabled=true,this.warnedUnsupported||(this.warnedUnsupported=true,this.logger?.warn({code:"AUTO_DELETE_UNSUPPORTED"},"autoDelete: store implements neither pruneMessages nor deleteMessage; sweeper disabled")),0)}start(){if(!this.active||this.timer)return;let e=this.options.intervalMs??6e4;this.timer=setInterval(()=>{this.running||(this.running=true,this.runOnce().catch(t=>this.logger?.warn(t,"autoDelete sweep failed")).finally(()=>{this.running=false;}));},e),this.timer.unref?.();}stop(){this.timer&&(clearInterval(this.timer),this.timer=void 0);}};var re="[zaileys]",$i="The saved session looks invalid or corrupted (connection keeps closing before it authenticates). Delete the auth folder (default: ./.zaileys) and run again to scan a fresh QR / request a new pairing code.";function pr(n){switch(n.kind){case "connecting":return `${re} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${re} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${re} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${re} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${re} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
12
+ ${re} ${$i}`:t}case "disconnect":return n.willReconnect?null:`${re} Disconnected (${n.reason}).`;default:return null}}var ur=false,Gi=["Closing session:","Closing open session","Closing stale open session","Opening session:","Removing old closed session","Migrating session to:","Session already closed","Decrypted message with closed session","Failed to decrypt message with any known session","Session error:"],Vi=n=>typeof n[0]=="string"&&Gi.some(e=>n[0].startsWith(e));function mr(){if(ur)return;ur=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{Vi(r)||t(...r);};};n("info"),n("warn"),n("error");}var f=class n extends Error{code;cause;constructor(e,t,r){super(t),this.name="ZaileysStoreError",this.code=e,r&&"cause"in r&&(this.cause=r.cause),typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n);}};var zi="./.zaileys/auth",Yi=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),je=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",ut=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??zi;}signal={read:async(e,t)=>{this.assertOpen();let r={};return await Promise.all(t.map(async s=>{let i=this.signalPath(e,s);try{let o=await promises.readFile(i,"utf8");r[s]=JSON.parse(o,BufferJSON.reviver);}catch(o){if(je(o))return;throw new f("STORE_READ_FAILED",`failed to read ${i}`,{cause:o})}})),r},write:async e=>{this.assertOpen();let t=[];for(let r of Object.keys(e)){let s=e[r];if(!s)continue;let i=this.signalDir(r);await promises.mkdir(i,{recursive:true});for(let o of Object.keys(s)){let a=s[o],c=this.signalPath(r,o);a===null?t.push(promises.unlink(c).catch(d=>{if(!je(d))throw new f("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,BufferJSON.replacer)));}}await Promise.all(t);},delete:async(e,t)=>{this.assertOpen(),await Promise.all(t.map(async r=>{let s=this.signalPath(e,r);try{await promises.unlink(s);}catch(i){if(!je(i))throw new f("STORE_WRITE_FAILED",`failed to unlink ${s}`,{cause:i})}}));},clear:async()=>{this.assertOpen(),await promises.rm(this.basePath,{recursive:true,force:true});},close:async()=>{this.closed=true;}};creds={readCreds:async()=>{this.assertOpen();try{let e=await promises.readFile(this.credsPath(),"utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){if(je(e))return;throw new f("STORE_READ_FAILED","failed to read creds.json",{cause:e})}},writeCreds:async e=>{this.assertOpen(),await promises.mkdir(this.basePath,{recursive:true}),await this.atomicWrite(this.credsPath(),JSON.stringify(e,BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await promises.unlink(this.credsPath());}catch(e){if(!je(e))throw new f("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return We.join(this.basePath,"creds.json")}signalDir(e){return We.join(this.basePath,"signal",String(e))}signalPath(e,t){return We.join(this.signalDir(e),`${Yi(t)}.json`)}async atomicWrite(e,t){let r=We.join(We.dirname(e),`tmp-${randomBytes(8).toString("hex")}`);try{await promises.writeFile(r,t,"utf8"),await promises.rename(r,e);}catch(s){throw await promises.unlink(r).catch(()=>{}),new f("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","FileAuthStore is closed")}};function gr(n,e){let t=n.signal,s=makeCacheableSignalKeyStore({get:(o,a)=>t.read(o,a),set:o=>t.write(o),clear:()=>t.clear()},e?.logger??void 0),i={read:async(o,a)=>await s.get(o,[...a]),write:async o=>{await s.set(o);},delete:async(o,a)=>{await t.delete(o,a);let c={},d={};for(let l of a)d[l]=null;c[o]=d,await s.set(c);},clear:async()=>{let o=s.clear;typeof o=="function"?await o.call(s):await t.clear();},close:()=>t.close()};return {creds:n.creds,signal:i}}function fr(n,e){return {get:async(t,r)=>await n.read(t,r),set:async t=>{await n.write(t);},clear:async()=>{await n.clear();}}}var Xi=429;function hr(n){if(n===Xi)return "rate-limited";switch(n){case DisconnectReason.loggedOut:return "logged-out";case DisconnectReason.forbidden:return "forbidden";case DisconnectReason.connectionLost:return "connection-lost";case DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case DisconnectReason.connectionClosed:return "connection-closed";case DisconnectReason.connectionReplaced:return "connection-replaced";case DisconnectReason.badSession:return "bad-session";case DisconnectReason.unavailableService:return "unavailable-service";case DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Ue(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function pt(n){return n==="rate-limited"}function yr(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function ep(n){return !Ue(n)}var mt={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},Qi=3e5;function wr(n={}){let e=n.enabled??mt.enabled,t=n.maxQrAttempts??mt.maxQrAttempts,r=n.maxPairingAttempts??mt.maxPairingAttempts,s=n.pairingCooldownMs??mt.pairingCooldownMs,i=0,o=0,a=0,c=w=>w<=0?0:Math.min(s*w,Qi);return {evaluate:(w,S)=>{if(!e)return {allowed:true,waitMs:0,attempts:w==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(w==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let v=c(o),C=S-a;return o>0&&C<v?{allowed:false,reason:"cooldown",waitMs:v-C,attempts:o,max:r}:{allowed:true,waitMs:0,attempts:o,max:r}}return i>=t?{allowed:false,reason:"budget-exhausted",waitMs:0,attempts:i,max:t}:{allowed:true,waitMs:0,attempts:i,max:t}},record:(w,S)=>{w==="pairing"?(o+=1,a=S):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var eo=/[\s\-()+]/g;function to(n){return typeof n!="string"?"":n.replace(eo,"")}function no(n){if(!n||typeof n!="string"||!n.trim())throw new Error("phoneNumber is required");let e=to(n);if(!/^\d+$/.test(e))throw new Error("phoneNumber must be E.164 with country code");if(e.length<8||e.length>15)throw new Error("phoneNumber must be E.164 with country code");return e}function vr(n){let e=no(n.phoneNumber),t=n.ttlMs??6e4;return {phoneNumber:e,async requestCode(r){let s;try{s=await r.requestPairingCode(e);}catch(i){let o=i instanceof Error?i.message:String(i);throw new Error(`failed to request pairing code: ${o}`)}return {code:s,expiresAt:Date.now()+t}}}}function so(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{ro.generate(n,{small:true},t=>e(t));})}async function Mr(n,e=t=>{process.stdout.write(t);}){let t=await so(n);e(t+`
13
+ `);}var me={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function Sr(n,e){let t=n?.enabled??me.enabled,r=n?.maxAttempts??me.maxAttempts,s=n?.initialDelayMs??me.initialDelayMs,i=n?.maxDelayMs??me.maxDelayMs,o=n?.jitterFactor??me.jitterFactor,a=n?.rateLimitedDelayMs??me.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:w=>{if(!t||Ue(w))return null;let S=d+1;if(S>r)return null;if(d=S,pt(w))return {attempt:S,delayMs:a};let v=Math.pow(2,S-1),C=Math.min(i,s*v),y=1+(c()*2-1)*o,p=C*y,m=Math.min(i,Math.max(0,p));return {attempt:S,delayMs:Math.round(m)}},reset:()=>{d=0;},get attempts(){return d}}}var io={idle:["connecting"],connecting:["qr-pending","pairing-pending","connected","reconnecting","disconnecting","disconnected"],"qr-pending":["connecting","connected","reconnecting","disconnecting","disconnected"],"pairing-pending":["connecting","connected","reconnecting","disconnecting","disconnected"],connected:["disconnecting","reconnecting","disconnected"],reconnecting:["connecting","disconnecting","disconnected"],disconnecting:["disconnected"],disconnected:["idle","connecting","reconnecting"]};function Ar(n="idle"){let e=n,t=new Set,r=s=>io[e].includes(s);return {get state(){return e},canTransition:r,transition(s){if(!r(s))throw new Error(`invalid state transition: ${e} -> ${s}`);let i=e;e=s;for(let o of t)try{o(i,s);}catch{}},onChange(s){return t.add(s),()=>{t.delete(s);}}}}var gt=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,ft=class{messages=new Map;messagesByJid=new Map;chats=new Map;contacts=new Map;presence=new Map;boundSocket;listeners=new Map;closed=false;async saveMessage(e){this.assertOpen();let t=gt(e.key);this.messages.set(t,structuredClone(e));let r=e.key.remoteJid??"",s=this.messagesByJid.get(r);s||(s=new Set,this.messagesByJid.set(r,s)),s.add(t);}async getMessage(e){this.assertOpen();let t=this.messages.get(gt(e));return t?structuredClone(t):void 0}async listMessages(e,t){this.assertOpen();let r=this.messagesByJid.get(e);if(!r)return [];let s=[];for(let o of r){let a=this.messages.get(o);a&&s.push(a);}s.sort((o,a)=>Number(a.messageTimestamp)-Number(o.messageTimestamp));let i=s;if(typeof t?.before=="number"){let o=t.before;i=i.filter(a=>Number(a.messageTimestamp)<o);}return typeof t?.limit=="number"&&(i=i.slice(0,t.limit)),i.map(o=>structuredClone(o))}async saveChat(e){this.assertOpen();let t=e.id;t&&this.chats.set(t,structuredClone(e));}async getChat(e){this.assertOpen();let t=this.chats.get(e);return t?structuredClone(t):void 0}async listChats(e){this.assertOpen();let t=[];for(let r of this.chats.values())e?.archived===true&&r.archived!==true||t.push(structuredClone(r));return t}async saveContact(e){this.assertOpen(),this.contacts.set(e.id,structuredClone(e));}async getContact(e){this.assertOpen();let t=this.contacts.get(e);return t?structuredClone(t):void 0}async listContacts(){return this.assertOpen(),Array.from(this.contacts.values(),e=>structuredClone(e))}async savePresence(e,t){this.assertOpen(),this.presence.set(e,structuredClone(t));}async getPresence(e){this.assertOpen();let t=this.presence.get(e);return t?structuredClone(t):void 0}bind(e){this.assertOpen(),this.boundSocket=e;let t=(...c)=>{let l=c[0]?.messages;if(Array.isArray(l))for(let u of l)this.saveMessage(u).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d){let u=this.messages.get(gt(l.key));if(u){let w={...u,...l.update};this.saveMessage(w).catch(()=>{});}}},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveChat(l).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d){let w={...this.chats.get(l.id)??{},...l};this.saveChat(w).catch(()=>{});}},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveContact(l).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let l of Object.keys(d.presences)){let u=d.presences[l];u&&this.savePresence(l,u).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("messages.update",r),this.listeners.set("chats.upsert",s),this.listeners.set("chats.update",i),this.listeners.set("contacts.upsert",o),this.listeners.set("presence.update",a);for(let[c,d]of this.listeners)e.ev.on(c,d);}async deleteMessage(e){this.assertOpen();let t=gt(e);this.messages.delete(t);let r=e.remoteJid??"",s=this.messagesByJid.get(r);s&&(s.delete(t),s.size===0&&this.messagesByJid.delete(r));}async pruneMessages(e){this.assertOpen();let t=0;for(let[r,s]of [...this.messagesByJid.entries()]){if(e.chatFilter&&!e.chatFilter(r))continue;let i=[];for(let a of s){let c=this.messages.get(a);c&&i.push(c);}i.sort((a,c)=>Number(c.messageTimestamp??0)-Number(a.messageTimestamp??0));let o=i.filter((a,c)=>{let d=Number(a.messageTimestamp??0);return e.olderThan!==void 0&&d<e.olderThan||e.maxPerChat!==void 0&&c>=e.maxPerChat});for(let a of o)await this.deleteMessage(a.key),t+=1;}return t}async clear(){this.assertOpen(),this.messages.clear(),this.messagesByJid.clear(),this.chats.clear(),this.contacts.clear(),this.presence.clear();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);return this.listeners.clear(),this.boundSocket=void 0,Promise.resolve()}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","MemoryMessageStore is closed")}};var ao=["silent","fatal","error","warn","info","debug","trace"];function co(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":ao.includes(e)?e:"silent"}function lo(n={}){let e=co(n.level),t=oo({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var Pr=["debug","info","warn","error","fatal"];function uo(n){if(n===null||typeof n!="object")return false;for(let e of Pr)if(typeof n[e]!="function")return false;return true}function qe(){}function po(n){let e={debug:qe,info:qe,warn:qe,error:qe,fatal:qe};for(let t of Pr){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function cn(n,e){return n===void 0?e??lo():uo(n)?n:po(n)}var mp=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),Cr=n=>{let e=n.requestId!=null,t=n.messages.filter(r=>{if(e)return false;let s=r.messageStubParameters;if(Array.isArray(s)){for(let i of s)if(typeof i=="string"&&i.startsWith("requestId:"))return false}return true});return {...n,messages:t}};var mo=new Set(["offer","ringing"]),go=new Set(["timeout","reject","accept","terminate"]),Er=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},br=n=>typeof n.id!="string"||n.id.length===0||!mo.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Er(n.date),status:n.status},kr=n=>typeof n.id!="string"||n.id.length===0||!go.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Er(n.date),status:n.status};var _=n=>typeof n=="string"&&n.length>0,fo=n=>{let e={};return typeof n.subject=="string"&&(e.subject=n.subject),typeof n.desc=="string"&&(e.description=n.desc),typeof n.announce=="boolean"&&(e.announce=n.announce),typeof n.restrict=="boolean"&&(e.restrict=n.restrict),typeof n.ephemeralDuration=="number"&&(e.ephemeralDuration=n.ephemeralDuration),e},Tr=(n,e,t)=>n.filter(r=>_(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return _(i)&&(s.participantAlt=i),_(e)&&(s.authorPn=e),_(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),Or=n=>_(n?.id)?{groupId:n.id,update:fo(n),timestamp:Date.now()}:null,Ir=n=>{if(!_(n?.groupId)||!_(n?.participant))return null;let e={groupId:n.groupId,participant:n.participant,label:typeof n.label=="string"?n.label:"",timestamp:typeof n.messageTimestamp=="number"?n.messageTimestamp:Date.now()};return _(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},ho=new Set(["add","invite","invite-link"]),yo=new Set(["remove","leave"]),xr=n=>{if(!_(n?.id)||!ho.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Tr(n.participants,n.authorPn,n.authorUsername);if(e.length===0)return null;let t={groupId:n.id,participants:e,action:n.action,timestamp:Date.now()};return _(n.author)&&(t.by=n.author),t},Rr=n=>{if(!_(n?.id)||!yo.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Tr(n.participants,n.authorPn,n.authorUsername);if(e.length===0)return null;let t={groupId:n.id,participants:e,action:n.action,timestamp:Date.now()};return _(n.author)&&(t.by=n.author),t};var ge=n=>typeof n!="string"||n.length===0?null:jidNormalizedUser(n),H=n=>typeof n=="string"&&n.length>0?n:void 0,Mo=["@s.whatsapp.net","@c.us"],ht=n=>n.endsWith("@lid"),Lr=n=>Mo.some(e=>n.endsWith(e)),q=(n,e)=>{if(!n)return null;let t=H(n.participant)??n.remoteJid,r=ge(t);if(r===null)return null;let s=H(n.participantAlt)??H(n.remoteJidAlt),i=s!=null?ge(s):null,o=H(n.participantUsername)??H(n.remoteJidUsername),a={jid:r,isMe:n.fromMe===true};typeof t=="string"&&t.length>0&&(a.deviceJid=t);let c=i!==null?[r,i]:[r],d=c.find(ht),l=c.find(Lr);d!==void 0&&(a.lid=d),l!==void 0&&(a.pn=l),o!==void 0&&(a.username=o);let u=H(e);return u!==void 0&&(a.pushName=u),a},Nr=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=H(n.participant),r=H(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=q(s);return o&&(i.sender=o),i},Ke=n=>{if(!n)return {mentionedJids:[],mentionAll:false};let e=n.mentionedJid,t=Array.isArray(e)?e.filter(i=>typeof i=="string"):[],r=n.groupMentions,s=Array.isArray(r)&&r.length>0;return {mentionedJids:t,mentionAll:s}};var fe=n=>isJidGroup(n)===true,he=n=>{if(n==null)return null;if(typeof n=="number")return Number.isFinite(n)?n:null;if(typeof n.toNumber=="function"){let e=n.toNumber();return Number.isFinite(e)?e:null}return null};var So=["quick_reply","cta_url","cta_call","button_click"],Ao=["list_select","single_select"],J=n=>typeof n=="string"&&n.length>0,_r=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return q(n.key,e)},Br=n=>he(n.messageTimestamp)??0,Fr=(n,e)=>{if(!J(n))return null;try{let t=JSON.parse(n);return t!==null&&typeof t=="object"?t:null}catch{return e?.debug({paramsJson:n},"interactive: failed to parse nativeFlow paramsJson"),null}},yt=(n,e)=>{for(let t of e){let r=n[t];if(J(r))return r}},Wr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&J(r.selectedButtonId))return dn(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&J(s.selectedId))return dn(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&J(i.name)&&So.includes(i.name)){let o=Fr(i.paramsJson,e.logger);if(!o)return null;let a=yt(o,["id","button_id"]);return a===void 0?null:dn(n,a,yt(o,["display_text"])??null)}return null},dn=(n,e,t)=>{let r=_r(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:Br(n)};return J(t)&&(s.buttonText=t),s},jr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(J(s))return Dr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&J(i.name)&&Ao.includes(i.name)){let o=Fr(i.paramsJson,e.logger);if(!o)return null;let a=yt(o,["row_id","id"]);return a===void 0?null:Dr(n,a,yt(o,["title"])??null)}return null},Dr=(n,e,t)=>{let r=_r(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:Br(n)};return J(t)&&(s.title=t),s};var Po=new Set(["available","unavailable","composing","recording","paused"]),Co=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,Ur=n=>n.status!=="complete"&&n.status!=="paused"?null:{syncType:String(n.syncType),status:n.status,explicit:n.explicit===true},ln=n=>{if(n.source==="connection-update"){let t=n.reachoutTimeLock;return t.isActive!==true?null:{reason:"reachout-timelock",retryAt:Co(t.timeEnforcementEnds)}}if(n.capInfo.capping_status!=="CAPPED")return null;let e={reason:"chat-limit-reached"};return typeof n.capInfo.used_quota=="number"&&(e.usedQuota=n.capInfo.used_quota),typeof n.capInfo.total_quota=="number"&&(e.totalQuota=n.capInfo.total_quota),e},qr=n=>{if(typeof n.id!="string"||n.id.length===0)return [];let e=[];for(let[t,r]of Object.entries(n.presences??{})){let s=r?.lastKnownPresence;typeof s!="string"||!Po.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},Je=n=>{let e=n.payload.id;if(typeof e!="string"||e.length===0)return null;let t=Date.now();switch(n.source){case "reaction":{let r={action:"reaction",newsletterId:e,timestamp:t};return typeof n.payload.server_id=="string"&&(r.serverId=n.payload.server_id),typeof n.payload.reaction?.code=="string"&&(r.emoji=n.payload.reaction.code),r}case "view":{let r={action:"view",newsletterId:e,timestamp:t};return typeof n.payload.server_id=="string"&&(r.serverId=n.payload.server_id),typeof n.payload.count=="number"&&(r.count=n.payload.count),r}case "participants":return {action:"participants",newsletterId:e,timestamp:t};case "settings":{let r={action:"settings",newsletterId:e,timestamp:t};return n.payload.update&&(r.update=n.payload.update),r}}};var Jr=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},Kr=(n,e=2166136261)=>{let t=e>>>0;for(let r=0;r<n.length;r++)t^=n.charCodeAt(r),t=Math.imul(t,16777619)>>>0;return t>>>0},$r=n=>(Kr(n).toString(16).padStart(8,"0")+Kr(n,2646966556).toString(16).padStart(8,"0")).toUpperCase(),Gr=n=>$r(`${n.remoteJid??""}|${n.id??""}|${n.fromMe===true?"1":"0"}`),Vr=(n,e)=>$r(`${n??""}|${e}`),Hr=n=>{let e=null;if(typeof n=="number")e=n;else if(typeof n=="bigint")e=Number(n);else if(typeof n=="string"){let t=Number.parseInt(n,10);e=Number.isFinite(t)?t:null;}else if(n!=null&&typeof n=="object"){let t=n;typeof t.toNumber=="function"?e=t.toNumber():typeof t.low=="number"&&(e=(typeof t.high=="number"?t.high:0)*4294967296+(t.low>>>0));}return e!=null&&Number.isFinite(e)&&e>0?e*1e3:0},zr=n=>{let e=jidDecode(n);if(!e)return "unknown";let t=e.device;return t===void 0||t===0?"android":t===2?"ios":t===3?"web":t===4?"desktop":"unknown"},bo=n=>n.trim().endsWith("?"),ko=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),To=(n,e)=>{if(e.length===0)return false;let t;try{t=jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return jidNormalizedUser(r)===t}catch{return r===n}})},Oo=(n,e)=>{let t=async r=>r===void 0?false:Array.isArray(r)?r.includes(e):r(e);return {authors:()=>t(n?.authors),banned:()=>t(n?.banned)}},Io=0,xo=14,Ro=1,Lo=2,wt=n=>n!=null&&typeof n=="object"?n:null,No=n=>{let e=wt(n.message);if(e==null)return {isEdited:false,isDeleted:false,isPinned:false,isUnPinned:false,isBot:false,isStatusMention:false,isGroupStatusMention:false};let t=wt(e.protocolMessage),r=typeof t?.type=="number"?t.type:void 0,s=typeof wt(e.pinInChatMessage)?.type=="number"?e.pinInChatMessage.type:void 0;return {isEdited:e.editedMessage!=null||r===xo,isDeleted:r===Io,isPinned:s===Ro,isUnPinned:s===Lo,isBot:wt(e.messageContextInfo)?.botMetadata!=null,isStatusMention:e.statusMentionMessage!=null,isGroupStatusMention:e.groupStatusMentionMessage!=null}},un=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&fe(e),r=No(n.message),s=c=>n.lidMap!=null&&c.endsWith("@lid")?n.lidMap.get(c)??c:c,i=s(n.sender.pn??n.sender.jid),o=t?e?jidNormalizedUser(e):null:n.key.fromMe===true&&e?s(jidNormalizedUser(e)):i,a={uniqueId:Gr(n.key),staticId:Vr(o,i),channelId:n.channelId,chatId:n.key.id??"",chatType:n.chatType,receiverId:n.receiverId?s(jidNormalizedUser(n.receiverId)):n.receiverId,roomId:o,senderId:i,senderLid:n.sender.lid??null,senderName:n.sender.pushName??null,senderDevice:zr(n.sender.deviceJid??n.sender.jid),timestamp:Hr(n.message.messageTimestamp),text:n.text,mentions:n.mentions,links:Jr(n.text),isFromMe:n.key.fromMe===true,isGroup:t,isNewsletter:n.isNewsletter,isBroadcast:n.isBroadcast,isViewOnce:n.isViewOnce,isEphemeral:n.isEphemeral,isForwarded:n.isForwarded,isQuestion:bo(n.text),isPrefix:ko(n.text,n.prefixes),isTagMe:To(n.selfJid,n.mentions),isEdited:r.isEdited,isDeleted:r.isDeleted,isPinned:r.isPinned,isUnPinned:r.isUnPinned,isBot:r.isBot,isSpam:false,isHideTags:n.mentions.length>0&&!/@\d/.test(n.text),isStatusMention:r.isStatusMention,isGroupStatusMention:r.isGroupStatusMention,isStory:e==="status@broadcast",roomName:n.resolveRoomName,receiverName:n.resolveReceiverName,replied:n.resolveReplied,reply:n.reply,react:n.react,message:()=>n.message,citation:Oo(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(a.media=n.media),a};var Do={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},_o=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Do[e]];if(r==null||typeof r!="object")return null;let s=r.mimetype;return typeof s=="string"&&s.length>0?s:null},Yr=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys'),s=await r(n,"buffer",{}),i=_o(n,e)??"application/octet-stream";return {buffer:s,mime:i,size:s.byteLength}}catch(r){throw t?.warn({error:r,kind:e,id:n.key?.id},"media download failed"),r instanceof Error?r:new Error("media download failed")}},Zr=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys');return await r(n,"stream",{})}catch(r){throw t?.warn({error:r,kind:e,id:n.key?.id},"media stream download failed"),r instanceof Error?r:new Error("media stream download failed")}};var Mt={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},Qr=n=>{let e=n?.remoteJid;return typeof e=="string"&&e.length>0?e:""},h=n=>n!=null&&typeof n=="object"?n:null,M=n=>typeof n=="string"&&n.length>0?n:null,z=(...n)=>{for(let e of n){let t=M(e);if(t!=null)return t}return null},Bo=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage","lottieStickerMessage"],He=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of Bo){let i=h(h(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},es=n=>{let e=h(n.message);if(e==null)return n;let t=He(e);return t===e?n:{...n,message:t}},Fo=n=>{let t=h(h(h(n.botForwardedMessage)?.message)?.richResponseMessage)??h(n.richResponseMessage);if(t==null)return null;let r=t.submessages;if(!Array.isArray(r))return null;let s=[];for(let o of r){let a=M(h(o)?.messageText);a!=null&&s.push(a);}let i=s.join(`
14
+ `).trim();return i.length>0?i:null},Wo=n=>{let e=h(n.templateMessage),t=h(e?.hydratedTemplate)??h(e?.hydratedFourRowTemplate);return M(t?.hydratedContentText)},jo=n=>z(h(n.pollCreationMessage)?.name,h(n.pollCreationMessageV2)?.name,h(n.pollCreationMessageV3)?.name),Uo=n=>{let e=h(n.locationMessage)??h(n.liveLocationMessage);if(e==null)return null;let t=z(e.name,e.address);if(t!=null){let i=M(e.name),o=M(e.address);return i!=null&&o!=null&&i!==o?`${i} \u2014 ${o}`:t}let r=e.degreesLatitude,s=e.degreesLongitude;return typeof r=="number"&&typeof s=="number"?`${r}, ${s}`:null},qo=n=>{let e=M(h(n.contactMessage)?.displayName);if(e!=null)return e;let t=h(n.contactsArrayMessage),r=M(t?.displayName);if(r!=null)return r;let s=t?.contacts;if(Array.isArray(s)){let i=s.map(o=>M(h(o)?.displayName)).filter(o=>o!=null);if(i.length>0)return i.join(", ")}return null},ts=n=>z(n.conversation,h(n.extendedTextMessage)?.text,Fo(n),M(h(h(n.interactiveMessage)?.body)?.text),h(n.buttonsMessage)?.contentText,h(n.listMessage)?.description,Wo(n),jo(n),Uo(n),qo(n)),Ko=n=>z(h(n.buttonsResponseMessage)?.selectedDisplayText,h(n.buttonsResponseMessage)?.selectedButtonId,h(n.templateButtonReplyMessage)?.selectedDisplayText,h(n.templateButtonReplyMessage)?.selectedId,h(n.listResponseMessage)?.title,h(h(n.listResponseMessage)?.singleSelectReply)?.selectedRowId,h(h(n.interactiveResponseMessage)?.body)?.text),Jo=n=>z(h(n.imageMessage)?.caption,h(n.videoMessage)?.caption,h(n.documentMessage)?.caption,h(n.documentMessage)?.fileName),T=n=>{if(typeof n=="number")return n;let e=he(n);return typeof e=="number"?e:null},$o=[["pollCreationMessage","poll"],["pollCreationMessageV2","poll"],["pollCreationMessageV3","poll"],["contactMessage","contact"],["contactsArrayMessage","contact"],["locationMessage","location"],["liveLocationMessage","live-location"],["eventMessage","event"],["albumMessage","album"],["groupInviteMessage","group-invite"],["productMessage","product"],["orderMessage","order"],["requestPaymentMessage","payment"],["sendPaymentMessage","payment"],["paymentInviteMessage","payment"],["buttonsMessage","buttons"],["listMessage","list"],["interactiveMessage","interactive"],["templateMessage","template"]],ns=n=>{let e=h(n.pollCreationMessage)??h(n.pollCreationMessageV2)??h(n.pollCreationMessageV3);if(e!=null){let p=Array.isArray(e.options)?e.options:[];return {type:"poll",name:M(e.name),options:p.map(m=>M(h(m)?.optionName)).filter(m=>m!=null),selectableCount:T(e.selectableOptionsCount)??0}}let t=h(n.contactMessage);if(t!=null)return {type:"contact",displayName:M(t.displayName),vcard:M(t.vcard),contacts:[{displayName:M(t.displayName),vcard:M(t.vcard)}]};let r=h(n.contactsArrayMessage);if(r!=null){let p=Array.isArray(r.contacts)?r.contacts:[];return {type:"contact",displayName:M(r.displayName),vcard:null,contacts:p.map(m=>({displayName:M(h(m)?.displayName),vcard:M(h(m)?.vcard)}))}}let s=h(n.locationMessage);if(s!=null)return {type:"location",latitude:T(s.degreesLatitude),longitude:T(s.degreesLongitude),name:M(s.name),address:M(s.address),accuracy:T(s.accuracyInMeters),speed:T(s.speedInMps),caption:M(s.comment)};let i=h(n.liveLocationMessage);if(i!=null)return {type:"live-location",latitude:T(i.degreesLatitude),longitude:T(i.degreesLongitude),name:null,address:null,accuracy:T(i.accuracyInMeters),speed:T(i.speedInMps),caption:M(i.caption)};let o=h(n.albumMessage);if(o!=null)return {type:"album",expectedImageCount:T(o.expectedImageCount),expectedVideoCount:T(o.expectedVideoCount)};let a=h(n.groupInviteMessage);if(a!=null)return {type:"group-invite",groupId:M(a.groupJid),groupName:M(a.groupName),inviteCode:M(a.inviteCode),caption:M(a.caption),expiresAt:T(a.inviteExpiration)};let c=h(h(n.productMessage)?.product);if(h(n.productMessage)!=null){let p=M(h(n.productMessage)?.businessOwnerJid),m=T(c?.priceAmount1000);return {type:"product",productId:M(c?.productId),title:M(c?.title),description:M(c?.description),price:m!=null?m/1e3:null,currency:M(c?.currencyCode),retailerId:M(c?.retailerId),url:M(c?.url),businessOwnerId:p}}let d=h(n.orderMessage);if(d!=null){let p=T(d.totalAmount1000),m={1:"inquiry",2:"accepted",3:"declined"},A=d.status;return {type:"order",orderId:M(d.orderId),title:M(d.orderTitle),itemCount:T(d.itemCount),total:p!=null?p/1e3:null,currency:M(d.totalCurrencyCode),status:typeof A=="number"?m[A]??null:M(A),message:M(d.message)}}let l=h(n.requestPaymentMessage)!=null&&{node:n.requestPaymentMessage,kind:"request"}||h(n.sendPaymentMessage)!=null&&{node:n.sendPaymentMessage,kind:"send"}||h(n.paymentInviteMessage)!=null&&{node:n.paymentInviteMessage,kind:"invite"};if(l!==false){let p=h(l.node),m=T(p?.amount1000),A=h(p?.noteMessage);return {type:"payment",kind:l.kind,amount:m!=null?m/1e3:null,currency:M(p?.currencyCodeIso4217),note:z(A?.conversation,h(A?.extendedTextMessage)?.text),expiresAt:T(p?.expiryTimestamp)}}let u=h(n.eventMessage);if(u!=null){let p=h(u.location);return {type:"event",name:M(u.name),description:M(u.description),location:p!=null?z(p.name,p.address):null,startTime:T(u.startTime),endTime:T(u.endTime),isCanceled:u.isCanceled===true}}let w=h(n.buttonsMessage);if(w!=null){let p=Array.isArray(w.buttons)?w.buttons:[];return {type:"buttons",contentText:M(w.contentText),footerText:M(w.footerText),buttons:p.map(m=>({id:M(h(m)?.buttonId),text:M(h(h(m)?.buttonText)?.displayText)}))}}let S=h(n.listMessage);if(S!=null){let p=Array.isArray(S.sections)?S.sections:[];return {type:"list",title:M(S.title),description:M(S.description),buttonText:M(S.buttonText),sections:p.map(m=>{let A=Array.isArray(h(m)?.rows)?h(m).rows:[];return {title:M(h(m)?.title),rows:A.map(E=>({id:M(h(E)?.rowId),title:M(h(E)?.title),description:M(h(E)?.description)}))}})}}let v=h(n.interactiveMessage);if(v!=null){let p=h(v.nativeFlowMessage),m=Array.isArray(p?.buttons)?p.buttons:[];return {type:"interactive",title:M(h(v.header)?.title),body:M(h(v.body)?.text),footer:M(h(v.footer)?.text),buttons:m.map(A=>({name:M(h(A)?.name),params:M(h(A)?.buttonParamsJson)}))}}let C=h(n.templateMessage);if(C!=null){let p=h(C.hydratedTemplate)??h(C.hydratedFourRowTemplate),m=Array.isArray(p?.hydratedButtons)?p.hydratedButtons:[];return {type:"template",text:M(p?.hydratedContentText),buttons:m.map(A=>{let E=h(A),de=h(E?.quickReplyButton)??h(E?.urlButton)??h(E?.callButton);return {id:M(de?.id),text:M(de?.displayText)}})}}let y=h(n.extendedTextMessage);if(y!=null){let p=z(y.canonicalUrl,y.matchedText),m=M(y.title),A=M(y.description);if(p!=null&&(m!=null||A!=null))return {type:"link",url:p,title:m,description:A}}return null};var Ge=n=>{let e=h(n.message);if(e==null)return null;let t=He(e);return ts(t)??Ko(t)??Jo(t)},St=n=>{let e=h(es(n).message);if(e==null)return null;let t=h(e.extendedTextMessage)?.contextInfo;if(t!=null)return t;for(let r of Object.values(Mt)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},Go=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Mt[e]];return r==null||typeof r!="object"?null:r},Vo=n=>{let e=n.message;if(e==null)return false;if(e.viewOnceMessage!=null||e.viewOnceMessageV2!=null||e.viewOnceMessageV2Extension!=null)return true;for(let t of Object.values(Mt)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},Ho=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,se=n=>{let e=h(n);if(e==null)return "text";let t=He(e);for(let r of Object.values(Mt))if(t[r]!=null)return r.replace("Message","");for(let[r,s]of $o)if(t[r]!=null)return s;return "text"},zo=(n,e)=>{if(n==null)return false;let t=[n.pn,n.lid,n.jid].filter(s=>typeof s=="string"&&s.length>0),r=[e.pn,e.lid,e.jid].filter(s=>typeof s=="string"&&s.length>0);return t.some(s=>r.includes(s))},Yo=async(n,e,t,r,s)=>{try{if(n==null||n.quotedMessage==null)return null;let i=n.stanzaId;if(typeof i!="string"||i.length===0)return null;if(e.resolveQuoted!=null&&t.length>0){let v=await e.resolveQuoted(i,t);if(v!=null&&v.message!=null){let C=Ge(v)??"",y=ie(v,e,se(v.message),C,Ve(v,e),s);if(y!==null)return y}}let o=Nr(n);if(o===null||typeof o.key.id!="string"||o.key.id.length===0||(t.length>0&&(o.key.remoteJid=t),typeof o.key.remoteJid!="string"||o.key.remoteJid.length===0))return null;let a=o.key.participant,c=typeof a=="string"&&(e.selfJid.length>0&&vt(a,e.selfJid)||e.selfLid!=null&&vt(a,e.selfLid)),d=fe(t),l=o.sender?.pushName;c?(o.key.fromMe=!0,e.selfJid.length>0&&(o.key.participant=e.selfJid),e.selfLid!=null&&(o.key.participantAlt=e.selfLid),l==null&&(l=e.selfName)):r!=null&&(!d||zo(o.sender,r))&&(r.pn!=null&&(o.key.participant=r.pn),r.lid!=null&&(o.key.participantAlt=r.lid),l==null&&(l=r.pushName));let u=n.quotedMessage,w=Object.assign({key:o.key,message:u??null},l!=null?{pushName:l}:{}),S=Ge(w)??"";return ie(w,e,se(u),S,Ve(w,e),s)}catch{return null}},rs=n=>Ke(St(n)).mentionedJids,Zo=n=>{try{return jidNormalizedUser(n)}catch{return n}},ss=(n,e)=>n.map(t=>{let r=Zo(t);return e.lidMap?.get(r)??r}),Xr=n=>(n.split("@")[0]??"").split(":")[0]??"",Xo=(n,e)=>{if(e==null||e.size===0||n.length===0)return n;let t=[...e].map(([s,i])=>[Xr(s),Xr(i)]).filter(([s,i])=>s.length>0&&i.length>0&&s!==i).sort((s,i)=>i[0].length-s[0].length),r=n;for(let[s,i]of t)r=r.split(`@${s}`).join(`@${i}`);return r},ie=(n,e,t,r,s,i)=>{let o=n.key;if(o==null)return null;let a=q(o,n.pushName??void 0);if(a===null)return null;let c=Qr(o);if(c.length===0)return null;let d=St(n),l=fe(c),u=c.endsWith("@broadcast"),w=c.endsWith("@newsletter"),S=d?.isForwarded===true||(d?.forwardingScore??0)>0,v=Vo(n),C=Ho(n,d),y=e.channelId??"",p=e.receiverId??"",m=e.prefixes??[],A=i??(()=>l?e.resolveRoomName!=null?e.resolveRoomName(c):Promise.resolve(null):Promise.resolve(a.pushName??null)),E=e.resolveReceiverName??(()=>Promise.resolve(null)),de=()=>Yo(d,e,c,a,A),Bt=c.length>0?c:a.pn??a.jid,Ft=(jt,Ks)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(Bt,jt,Ks,n),Wt=jt=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(o,jt),Us=ss(Ke(d).mentionedJids,e),qs=Xo(r,e.lidMap),yn={message:n,key:o,channelId:y,receiverId:p,selfJid:e.selfJid,text:qs,chatType:t,sender:a,mentions:Us,isViewOnce:v,isEphemeral:C,isForwarded:S,isBroadcast:u,isNewsletter:w,prefixes:m,...e.lidMap!=null?{lidMap:e.lidMap}:{},resolveRoomName:A,resolveReceiverName:E,resolveReplied:de,reply:Ft,react:Wt},wn=s!==void 0?{...yn,media:s}:yn;return un(e.citationConfig!==void 0?{...wn,citationConfig:e.citationConfig}:wn)},Qo=["image","video","audio","document","sticker"],is=(n,e,t)=>{let r=es(n),s=Go(r,e);if(s===null)return null;let i=Yr(r,e,t.logger),o=Zr(r,e,t.logger);return {type:e,mimetype:typeof s.mimetype=="string"?s.mimetype:null,caption:typeof s.caption=="string"?s.caption:null,fileName:typeof s.fileName=="string"?s.fileName:null,fileSize:T(s.fileLength),ptt:s.ptt===true,buffer:async()=>(await i()).buffer,stream:o}},Ve=(n,e)=>{let t=h(n.message);if(t==null)return;let r=se(n.message);return Qo.includes(r)?is(n,r,e)??void 0:ns(He(t))??void 0},os=(n,e)=>{if(h(n.message)==null)return null;let r=se(n.message),s=Ve(n,e),i=Ge(n)??"";return i===""&&s===void 0?null:ie(n,e,r,i,s)},as=(n,e)=>{let t=h(n.message);if(t==null)return null;let r=He(t),s=ts(r),i=ns(r)??void 0;return s===null&&i===void 0?null:ie(n,e,se(n.message),s??"",i)},ze=(n,e,t)=>{let r=is(e,n,t);return r===null?null:ie(e,t,n,r.caption??"",r)},cs=(n,e)=>ze("image",n,e),ds=(n,e)=>ze("video",n,e),ls=(n,e)=>ze("audio",n,e),us=(n,e)=>ze("document",n,e),ps=(n,e)=>ze("sticker",n,e),vt=(n,e)=>{try{return jidNormalizedUser(n)===jidNormalizedUser(e)}catch{return n===e}},ms=(n,e)=>{if(n.key==null)return null;let r=St(n),s=Ke(r).mentionedJids;if(s.length===0)return null;let i=ss(s,e);if(!(i.some(u=>vt(u,e.selfJid))||e.selfLid!=null&&s.some(u=>vt(u,e.selfLid)))||h(n.message)==null)return null;let c=Ge(n)??"",d=Ve(n,e),l=ie(n,e,se(n.message),c,d);return l===null?null:{...l,mentionedJids:i,selfJid:e.selfJid}},gs=(n,e)=>{let t=n.key;if(t==null)return null;let r=Qr(t);if(r.length===0||!fe(r))return null;let{mentionAll:s}=Ke(St(n));if(!s||h(n.message)==null)return null;let o=Ge(n)??"",a=Ve(n,e),c=ie(n,e,se(n.message),o,a);return c===null?null:{...c,isMentionAll:true,selfJid:e.selfJid}};var oe=(n,e)=>{let t=he(n);return t===null?e:t},ea=n=>{if(!n)return "";if(typeof n.conversation=="string")return n.conversation;let e=n.extendedTextMessage?.text;if(typeof e=="string")return e;let t=n.imageMessage?.caption;if(typeof t=="string")return t;let r=n.videoMessage?.caption;if(typeof r=="string")return r;let s=n.documentMessage?.caption;if(typeof s=="string")return s;let o=(n.botForwardedMessage?.message?.richResponseMessage??n.richResponseMessage)?.submessages;if(Array.isArray(o)){let a=o.map(c=>c?.messageText).filter(c=>typeof c=="string"&&c.length>0);if(a.length>0)return a.join(`
15
+ `)}return ""},ta=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],hs=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=q(n.key,e.pushName);if(s===null)return null;let i=t.text,o=typeof i=="string"&&i.length>0?i:null;return {key:r,emoji:o,sender:s,timestamp:oe(t.senderTimestampMs,0)}},ys=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=q(n.key,e.pushName);return s===null?null:{key:r,newContent:ea(t.editedMessage),editedAt:oe(n.update.messageTimestamp,0),sender:s}},ws=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=q(n.key,e.pushName);if(s===null)return null;let i=ge(n.key.remoteJid),o=ge(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:oe(n.update.messageTimestamp,0)}},vs=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=q(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:ta(t.vote?.selectedOptions),voter:s,timestamp:oe(t.senderTimestampMs,oe(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:oe(r.senderTimestampMs,oe(n.update.messageTimestamp,0))}:null}return null};var At=n=>Array.isArray(n)?n:[],na=3e3,ra=(n,e)=>new Promise(t=>{let r=setTimeout(()=>t(null),e);n.then(s=>{clearTimeout(r),t(s);},()=>{clearTimeout(r),t(null);});}),sa=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function Ss(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?y=>{let p=s.get(y);if(p!==void 0)return p;let m=t.groupMetadata;if(m==null)return Promise.resolve(null);let A=m(y).then(E=>E?.subject??null).catch(()=>null);return s.set(y,A),A}:void 0,o={selfJid:t.selfJid,...t.selfLid!=null?{selfLid:t.selfLid}:{},...t.selfName!=null?{selfName:t.selfName}:{},receiverId:t.receiverId??t.selfJid,...t.logger!=null?{logger:t.logger}:{},...t.channelId!=null?{channelId:t.channelId}:{},...t.prefixes!=null?{prefixes:t.prefixes}:{},...t.citationConfig!=null?{citationConfig:t.citationConfig}:{},...i!=null?{resolveRoomName:i}:{},...t.receiverName!=null?{resolveReceiverName:t.receiverName}:{},...t.resolveQuoted!=null?{resolveQuoted:t.resolveQuoted}:{},...t.sendReply!=null?{reply:t.sendReply}:{},...t.react!=null?{react:t.react}:{}},a=t.logger?{selfJid:t.selfJid,logger:t.logger}:{selfJid:t.selfJid},c={selfJid:t.selfJid},d=(y,p)=>{let m=(...A)=>{try{p(A[0]);}catch(E){t.logger?.warn(E,`inbound pipeline: handler for ${y} threw`);}};e.ev.on(y,m),r.push(()=>e.ev.off(y,m));},l=(y,p)=>{v(()=>os(y,p),m=>n.emit("message",m)),v(()=>as(y,p),m=>n.emit("text",m)),v(()=>cs(y,p),m=>n.emit("image",m)),v(()=>ds(y,p),m=>n.emit("video",m)),v(()=>ls(y,p),m=>n.emit("audio",m)),v(()=>us(y,p),m=>n.emit("document",m)),v(()=>ps(y,p),m=>n.emit("sticker",m)),v(()=>ms(y,p),m=>n.emit("mention",m)),v(()=>gs(y,p),m=>n.emit("mention-all",m)),v(()=>Wr(y,a),m=>n.emit("button-click",m)),v(()=>jr(y,a),m=>n.emit("list-select",m));},u=y=>{if(typeof y!="string"||y.length===0)return null;let p;try{p=jidNormalizedUser(y);}catch{p=y;}return ht(p)?p:null},w=y=>{let p=new Set;for(let m of [y.key?.participant,y.key?.remoteJid,t.selfJid,...rs(y)]){let A=u(m);A!=null&&p.add(A);}return [...p]},S=async y=>{let p=t.resolveLidToPn;if(p==null||y.length===0)return;let m=new Map;return await Promise.all(y.map(async A=>{try{let E=await ra(Promise.resolve(p(A)),na);if(E!=null&&E.length>0)try{m.set(A,jidNormalizedUser(E));}catch{m.set(A,E);}}catch(E){t.logger?.warn(E,"inbound pipeline: lid->pn resolve threw");}})),m.size>0?m:void 0},v=(y,p)=>{let m;try{m=y();}catch(A){t.logger?.warn(A,"inbound pipeline: decoder threw");return}m!=null&&p(m);};d("messages.upsert",y=>{let p=Cr(y);for(let m of p.messages){if(t.ignoreMe===!0&&m.key?.fromMe===!0)continue;let A=t.resolveLidToPn!=null?w(m):[];if(A.length===0){l(m,o);continue}S(A).then(E=>l(m,E!=null?{...o,lidMap:E}:o)).catch(E=>{t.logger?.warn(E,"inbound pipeline: deferred lid resolve emit failed"),l(m,o);});}}),d("messages.update",y=>{for(let p of At(y))v(()=>ys(p,c),m=>n.emit("edit",m)),v(()=>ws(p,c),m=>n.emit("delete",m)),v(()=>vs(p,c),m=>n.emit("poll-vote",m));}),d("messages.reaction",y=>{for(let p of At(y))v(()=>hs(p,c),m=>n.emit("reaction",m));}),d("groups.update",y=>{for(let p of At(y))v(()=>Or(p),m=>n.emit("group-update",m));}),d("group-participants.update",y=>{let p=y;v(()=>xr(p),m=>n.emit("group-join",m)),v(()=>Rr(p),m=>n.emit("group-leave",m));}),d("group.member-tag.update",y=>{v(()=>Ir(y),p=>n.emit("member-tag",p));}),d("call",y=>{for(let p of At(y))v(()=>br(p),m=>n.emit("call-incoming",m)),v(()=>kr(p),m=>n.emit("call-ended",m));}),d("messaging-history.status",y=>{v(()=>Ur(y),p=>n.emit("history-sync",p));}),d("presence.update",y=>{let p=(()=>{try{return qr(y)}catch(m){return t.logger?.warn(m,"inbound pipeline: decodePresence threw"),[]}})();for(let m of p)n.emit("presence",m);}),d("connection.update",y=>{let p=sa(y);p!==null&&v(()=>ln({source:"connection-update",reachoutTimeLock:p}),m=>n.emit("limited",m));}),d("message-capping.update",y=>{v(()=>ln({source:"message-capping",capInfo:y}),p=>n.emit("limited",p));}),d("newsletter.reaction",y=>{v(()=>Je({source:"reaction",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter.view",y=>{v(()=>Je({source:"view",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter-participants.update",y=>{v(()=>Je({source:"participants",payload:y}),p=>n.emit("newsletter",p));}),d("newsletter-settings.update",y=>{v(()=>Je({source:"settings",payload:y}),p=>n.emit("newsletter",p));});let C=false;return {detach(){if(!C){C=true;for(let y of r)y();r.length=0;}}}}var Pt=class{inner=new EventEmitter;emitterLogger;constructor(e){this.emitterLogger=e?.logger,this.inner.setMaxListeners(0);}on(e,t){let r=this.wrap(e,t);this.tag(t,e,r),this.inner.on(e,r);let s=false;return ()=>{s||(s=true,this.inner.off(e,r),this.untag(t,e));}}off(e,t){let r=this.lookup(t,e);r&&(this.inner.off(e,r),this.untag(t,e));}emit(e,t){let r=this.inner.listeners(e).slice();for(let s of r)try{s(t);}catch(i){this.emitterLogger?.error(i,"listener threw");}}removeAllListeners(e){e===void 0?this.inner.removeAllListeners():this.inner.removeAllListeners(e);}listenerCount(e){return this.inner.listenerCount(e)}wrap(e,t){return r=>{try{t(r);}catch(s){this.emitterLogger?.error(s,"listener threw");}}}tag(e,t,r){this.tagMap(e).set(t,r);}untag(e,t){this.tagMap(e).delete(t);}lookup(e,t){return this.tagMap(e).get(t)}tagMap(e){let t=oa,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},oa=Symbol("zaileys.typed-ee.tag");var da="default",la="qr",Ps=6e4,Cs=class extends Pt{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=Ar();reconnectStrategy;authGuard;operationGuard;presenceThrottle;scheduleLimiter;authExhausted=false;_socket;reconnectTimer;listenerCleanup=[];inboundHandle;connectResolve;connectReject;pairingRequested=false;cachedSignalWrap=false;creds;credsLoadedAtConnect=false;openedThisRun=false;credsHintShown=false;disconnectEmittedFor=0;connectAttemptSeq=0;pendingDisconnectReason;usernameCache=new Map;_group;_privacy;_newsletter;_community;_profile;_chat;_contact;_business;commandRegistry;commandMiddleware=[];commandPrefixes;citationConfig;ignoreMe;commandDispatcher;_presence;_scheduler;autoDeleteOptions;autoDeleteSweeper;pluginsOptions;pluginRegistry;pluginLoader;waVersion;versionWarming;constructor(e={}){super({logger:cn(e.logger)}),this.sessionId=e.sessionId??da,this.logger=cn(e.logger),this.authType=e.authType??la,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&mr(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new ut({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new ft,this.reconnectStrategy=Sr(this.reconnectOptions),this.authGuard=wr(e.authGuard),this.operationGuard=on(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new ne({perSec:t}):void 0,this.commandPrefixes=ua(e.commandPrefix),this.citationConfig=e.citation,this.ignoreMe=e.ignoreMe??true,this.autoDeleteOptions=e.autoDelete===false?void 0:{maxAgeMs:720*60*60*1e3,...e.autoDelete},this.pluginsOptions=e.plugins,this.attachEmitterLogger(),(e.autoConnect??true)&&queueMicrotask(()=>{this.machine.state==="idle"&&this.warmVersion().finally(()=>{if(this.machine.state==="idle")try{this.connect().catch(r=>this.emitAutoConnectError(r));}catch(r){this.emitAutoConnectError(r);}});});}warmVersion(){if(this.waVersion)return Promise.resolve();if(this.versionWarming)return this.versionWarming;try{return typeof fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=fetchLatestBaileysVersion().then(({version:e})=>{this.waVersion=e;}).catch(e=>{this.logger.warn(e,"fetchLatestBaileysVersion failed; using bundled version");}),this.versionWarming)}catch{return Promise.resolve()}}emitAutoConnectError(e){let t=e instanceof Error?e:new Error(String(e));this.logger.error(t,"auto-connect failed"),this.listenerCount("error")>0&&this.emit("error",{sessionId:this.sessionId,error:t});}logStatus(e){if(!this.statusLog)return;let t=pr(e);t&&process.stderr.write(`${t}
16
+ `);}resolveMe(){let e=this._socket?.user;if(e&&typeof e.id=="string"&&e.id.length>0)return e;let t=this.creds?.me;return t&&typeof t.id=="string"&&t.id.length>0?t:{id:""}}get state(){return this.machine.state}get socket(){return this._socket}get group(){return this._group??=new Ce(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new Ee(()=>this._socket)}get newsletter(){return this._newsletter??=new be(()=>this._socket,this.operationGuard)}get community(){return this._community??=new ke(()=>this._socket,this.operationGuard)}get profile(){return this._profile??=new Te(()=>this._socket)}get chat(){return this._chat??=new Oe(()=>this._socket,async e=>{try{return (await this.store.listMessages(e,{limit:1})).filter(r=>r.key!=null).map(r=>({key:r.key,messageTimestamp:Number(r.messageTimestamp??0)}))}catch{return []}})}get contact(){return this._contact??=new Ie(()=>this._socket,e=>Pe(e)?e:`${e.replace(/\D/g,"")}@s.whatsapp.net`)}get business(){return this._business??=new xe(()=>this._socket)}get presence(){return this._presence??=new _e(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),an(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Be({store:this.store,sendSnapshot:e=>this.dispatchSnapshot(e),logger:this.logger,...this.scheduleLimiter?{acquire:()=>this.scheduleLimiter.acquire()}:{}})}async dispatchSnapshot(e){await this.requireSocket().sendMessage(e.recipient,e.content,e.options);}connect(){if(this.authType==="pairing"&&!this.phoneNumber)return Promise.reject(new Error('phoneNumber is required when authType is "pairing"'));if(this.machine.state==="connecting"||this.machine.state==="connected"||this.machine.state!=="idle"&&this.machine.state!=="disconnected"&&this.machine.state!=="reconnecting")return Promise.resolve();if(this._socket){for(let a of this.listenerCleanup)a.off();this.listenerCleanup=[],this._socket=void 0;}let e=this.machine.state==="reconnecting";e||(this.authGuard.reset(),this.authExhausted=false),this.machine.transition("connecting"),this.connectAttemptSeq+=1,this.pairingRequested=false,this.openedThisRun=false,e||this.logStatus({kind:"connecting",sessionId:this.sessionId}),this.cacheSignal&&!this.cachedSignalWrap&&(this.auth=gr(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=fr(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:Ps,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=aa(s);this._socket=i,this.store.bind(i),this.wireSocket(i);let o=new Promise((a,c)=>{let d=this.connectResolve,l=this.connectReject;this.connectResolve=()=>{d?.(),a();},this.connectReject=u=>{l?.(u),c(u);};});return this.auth.creds.readCreds().then(a=>{this.credsLoadedAtConnect=!!a,Object.assign(t,a??initAuthCreds());}).catch(a=>{this.rejectPendingConnect(a instanceof Error?a:new Error(String(a)));}),o}async disconnect(){if(!(this.machine.state==="idle"||this.machine.state==="disconnected")){this.machine.transition("disconnecting"),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands(),this.autoDeleteSweeper?.stop(),this.autoDeleteSweeper=void 0,await this.pluginLoader?.stop().catch(()=>{}),this.pluginLoader=void 0,this.pluginRegistry=void 0,this._scheduler?.dispose();for(let e of this.listenerCleanup)e.off();if(this.listenerCleanup=[],this._socket){try{this._socket.end(void 0);}catch(e){this.logger.warn(e,"socket.end threw");}this._socket=void 0;}try{await this.auth.signal.close();}catch(e){this.logger.warn(e,"auth.signal.close failed");}try{await this.store.close();}catch(e){this.logger.warn(e,"store.close failed");}if(this.machine.transition("disconnected"),this.disconnectEmittedFor!==this.connectAttemptSeq){let e=this.pendingDisconnectReason??"unknown";this.pendingDisconnectReason=void 0,this.disconnectEmittedFor=this.connectAttemptSeq,this.emit("disconnect",{sessionId:this.sessionId,reason:e,willReconnect:false});}this.rejectPendingConnect(new Error("disconnected before connect resolved"));}}async logout(){if(this.pendingDisconnectReason="logged-out",this._socket)try{await this._socket.logout();}catch(e){this.logger.warn(e,"socket.logout failed");}try{await this.auth.signal.clear();}catch(e){this.logger.warn(e,"auth.signal.clear failed");}try{await this.auth.creds.deleteCreds();}catch(e){this.logger.warn(e,"auth.creds.deleteCreds failed");}if(this.machine.state==="idle"||this.machine.state==="disconnected"){this.disconnectEmittedFor!==this.connectAttemptSeq&&(this.disconnectEmittedFor=this.connectAttemptSeq,this.emit("disconnect",{sessionId:this.sessionId,reason:"logged-out",willReconnect:false})),this.pendingDisconnectReason=void 0;return}await this.disconnect();}command(e,t){return (this.commandRegistry??=new Re).register(e,t),this.attachCommandsIfReady(),this}unregisterCommand(e){return this.commandRegistry?.unregister(e),this}use(e){return this.commandMiddleware.push(e),this}unuse(e){let t=this.commandMiddleware.indexOf(e);return t>=0&&this.commandMiddleware.splice(t,1),this}attachCommandsIfReady(){if(this.commandDispatcher||this.commandPrefixes.length===0||this.commandRegistry===void 0||this.commandRegistry.list().length===0||!this._socket)return;let e=this.commandRegistry;this.commandDispatcher=nn({registry:e,middleware:this.commandMiddleware,prefixes:this.commandPrefixes,logger:this.logger,onText:t=>{let r=s=>t(s);return this.on("text",r),()=>this.off("text",r)},buildContext:(t,r)=>this.buildCommandContext(t,r)});}buildCommandContext(e,t){let r;return {...t,raw:e.raw,command:e.command,args:e.args,flags:e.flags,json:e.json,reply:async(s,i)=>{let o=t.message().key.remoteJid??t.roomId??t.senderId,a=await this.send(o).text(s,i).reply(t.message());return r=a,a},react:s=>this.react(t.message().key,s),edit:async s=>{if(r===void 0)throw new x("NO_SENT_MESSAGE","ctx.edit requires a prior ctx.reply");await this.edit(r).text(s);}}}detachCommands(){this.commandDispatcher?.detach(),this.commandDispatcher=void 0;}send(e){let t=this.requireSocket(),r=s=>{this.store.saveMessage(s).catch(i=>this.logger.warn(i,"recordSent failed"));};return Pe(e)?V.create(t,e,void 0,r):V.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new Ae(this.requireSocket(),e)}async delete(e,t){await Yt(this.requireSocket(),e,t);}async react(e,t){return Zt(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return Xt(r,this.store,e,s)}async pin(e,t){return dt(this.requireSocket(),e,true,t)}async unpin(e){return dt(this.requireSocket(),e,false)}async setDisappearing(e,t){let r=await this.resolveRecipient(e);await this.requireSocket().sendMessage(r,{disappearingMessagesInChat:t});}resolveRecipient(e){return Qt(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new g("INVALID_OPTIONS","client not connected");return this._socket}attachEmitterLogger(){this.logger;}wireSocket(e){let t=s=>{this.handleConnectionUpdate(s);},r=s=>{let i=this.creds?Object.assign(this.creds,s):s;this.creds=i,this.auth.creds.writeCreds(i).catch(o=>{this.logger.warn(o,"auth.creds.writeCreds failed");});};e.ev.on("connection.update",t),e.ev.on("creds.update",r),this.listenerCleanup.push({off:()=>e.ev.off("connection.update",t)}),this.listenerCleanup.push({off:()=>e.ev.off("creds.update",r)});}async handleConnectionUpdate(e){if(e.qr&&await this.handleQrUpdate(e.qr),e.connection==="open"){this.handleOpen();return}e.connection==="close"&&await this.handleClose(e.lastDisconnect);}async handleQrUpdate(e){if(this.authExhausted)return;if(this.authType==="pairing"&&this.phoneNumber){if(this.pairingRequested)return;let s=Date.now(),i=this.authGuard.evaluate("pairing",s);if(!i.allowed){i.reason==="budget-exhausted"&&this.handleAuthExhausted("pairing",i.attempts,i.max);return}this.pairingRequested=true,this.authGuard.record("pairing",s),this.machine.canTransition("pairing-pending")&&this.machine.transition("pairing-pending");try{let o=vr({phoneNumber:this.phoneNumber}),a=this._socket;if(!a)return;let c=await o.requestCode(a);this.logStatus({kind:"pairing-code",code:c.code}),this.emit("pairing-code",{sessionId:this.sessionId,code:c.code,expiresAt:c.expiresAt});}catch(o){this.logger.warn(o,"pairing-code request failed");}return}let t=Date.now(),r=this.authGuard.evaluate("qr",t);if(!r.allowed){this.handleAuthExhausted("qr",r.attempts,r.max);return}if(this.authGuard.record("qr",t),this.machine.canTransition("qr-pending")&&this.machine.transition("qr-pending"),this.qrTerminal)try{await Mr(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+Ps});}handleAuthExhausted(e,t,r){this.authExhausted||(this.authExhausted=true,this.logger.warn({sessionId:this.sessionId,kind:e,attempts:t,max:r},`auth attempts exhausted (${t}/${r} ${e}); stopping to avoid WhatsApp spam restriction \u2014 call connect() to retry`),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.emit("auth-exhausted",{sessionId:this.sessionId,kind:e,attempts:t,max:r}),this.disconnect());}handleOpen(){this.machine.canTransition("connected")&&this.machine.transition("connected"),this.openedThisRun=true,this.credsHintShown=false,this.authExhausted=false,this.authGuard.reset(),this.reconnectStrategy.reset();let e=this.resolveMe();this.logStatus({kind:"connected",id:typeof e.id=="string"?e.id:""}),this.emit("connect",{sessionId:this.sessionId,me:e});let t=this._socket;t&&(this.inboundHandle?.detach(),this.inboundHandle=Ss(this,t,{selfJid:typeof e.id=="string"?e.id:"",...typeof e.lid=="string"&&e.lid.length>0?{selfLid:e.lid}:{},...typeof e.name=="string"&&e.name.length>0?{selfName:e.name}:{},channelId:this.sessionId,receiverId:typeof e.id=="string"?e.id:"",prefixes:this.commandPrefixes,logger:this.logger,...this.citationConfig!=null?{citationConfig:this.citationConfig}:{},groupMetadata:s=>this.group.metadata(s).catch(()=>null),receiverName:()=>Promise.resolve(this.resolveMe().name??null),resolveQuoted:(s,i)=>this.lookupQuoted(s,i),resolveLidToPn:s=>this.lidToPn(s),sendReply:async(s,i,o,a)=>await this.send(s).text(i,o).reply(a),react:(s,i)=>this.react(s,i),ignoreMe:this.ignoreMe})),this.attachCommandsIfReady(),this.ensureScheduler().loadPending().catch(s=>this.logger.warn(s,"scheduler loadPending failed")),this.autoDeleteOptions&&(this.autoDeleteSweeper?.stop(),this.autoDeleteSweeper=new Fe({store:this.store,options:this.autoDeleteOptions,logger:this.logger}),this.autoDeleteSweeper.start()),this.pluginsOptions&&!this.pluginLoader&&(this.pluginRegistry=new Le({client:this,logger:this.logger}),this.pluginLoader=new Ne({registry:this.pluginRegistry,options:this.pluginsOptions,logger:this.logger}),this.pluginLoader.start().catch(s=>this.logger.error(s,"plugin loader start failed")));let r=this.connectResolve;this.connectResolve=void 0,this.connectReject=void 0,r&&r();}async resolveMessageForResend(e){try{return (await this.store.getMessage(e))?.message??void 0}catch(t){this.logger.warn(t,"getMessage resend lookup failed");return}}lidMapping(){return this._socket?.signalRepository?.lidMapping}async lidToPn(e){try{let t=this.lidMapping()?.getPNForLID;return typeof t=="function"?await t(e):null}catch{return null}}async pnToLid(e){try{let t=this.lidMapping()?.getLIDForPN;return typeof t=="function"?await t(e):null}catch{return null}}async lookupQuoted(e,t){for(let r of [false,true])try{let s=await this.store.getMessage({id:e,remoteJid:t,fromMe:r});if(s!=null)return s}catch{continue}return null}async handleClose(e){this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands();let t=pa(e?.error),r=hr(t),s=false;if(yr(r)){try{await this.auth.signal.clear();}catch(i){this.logger.warn(i,"auth.signal.clear failed (post-close)");}try{await this.auth.creds.deleteCreds();}catch(i){this.logger.warn(i,"auth.creds.deleteCreds failed (post-close)");}}if(!Ue(r)&&!this.authExhausted){pt(r)&&this.logger.warn({sessionId:this.sessionId},"WhatsApp returned rate-limited (429); backing off before reconnect to avoid restriction");let i=this.reconnectStrategy.next(r);if(i!==null){s=true,this.machine.canTransition("reconnecting")&&this.machine.transition("reconnecting");let o=this.credsLoadedAtConnect&&!this.openedThisRun&&i.attempt>=2&&!this.credsHintShown;o&&(this.credsHintShown=true),this.logStatus({kind:"reconnecting",attempt:i.attempt,delayMs:i.delayMs,reason:r,invalidCredsSuspected:o}),this.emit("reconnecting",{sessionId:this.sessionId,attempt:i.attempt,delayMs:i.delayMs,reason:r}),this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=void 0,this.connect().catch(a=>{this.logger.warn(a,"reconnect attempt failed");});},i.delayMs);}}if(this.disconnectEmittedFor=this.connectAttemptSeq,this.logStatus({kind:"disconnect",reason:r,willReconnect:s}),this.emit("disconnect",{sessionId:this.sessionId,reason:r,willReconnect:s}),!s){if(this._socket){for(let i of this.listenerCleanup)i.off();this.listenerCleanup=[],this._socket=void 0;}this.machine.canTransition("disconnected")&&this.machine.transition("disconnected"),this.rejectPendingConnect(new Error(`connection closed (${r})`));}}rejectPendingConnect(e){let t=this.connectReject;this.connectResolve=void 0,this.connectReject=void 0,t&&t(e);}};function ua(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function pa(n){if(!n||typeof n!="object")return;let e=n.output;if(!e)return;let t=e.statusCode;return typeof t=="number"?t:void 0}var Es=class{credsBlob;signalMap=new Map;closed=false;signal={read:async(e,t)=>{this.assertOpen();let r=this.signalMap.get(e),s={};if(!r)return s;for(let i of t){let o=r.get(i);o!==void 0&&(s[i]=o);}return s},write:async e=>{this.assertOpen();for(let t of Object.keys(e)){let r=e[t];if(!r)continue;let s=this.signalMap.get(t);s||(s=new Map,this.signalMap.set(t,s));for(let i of Object.keys(r)){let o=r[i];o===null?s.delete(i):o!==void 0&&s.set(i,o);}}},delete:async(e,t)=>{this.assertOpen();let r=this.signalMap.get(e);if(r)for(let s of t)r.delete(s);},clear:async()=>{this.assertOpen(),this.signalMap.clear(),this.credsBlob=void 0;},close:async()=>{this.closed=true;}};creds={readCreds:async()=>(this.assertOpen(),this.credsBlob),writeCreds:async e=>{this.assertOpen(),this.credsBlob=structuredClone(e);},deleteCreds:async()=>{this.assertOpen(),this.credsBlob=void 0;}};assertOpen(){if(this.closed)throw new f("STORE_CLOSED","MemoryAuthStore is closed")}};var Ct=null,ma=async()=>{if(Ct)return Ct;try{return Ct=(await import('better-sqlite3')).default,Ct}catch(n){throw new f("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},mn="default",ks=500,Ts=n=>Array.from({length:n},()=>"?").join(","),Os=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},Is=class{options;db=null;prepared=null;readyPromise=null;closed=false;constructor(e){this.options=e;}creds={readCreds:async()=>{let t=(await this.ensureReady()).readCreds.get(mn);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(mn,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(mn);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Os(t,ks)){let o=Ts(i.length),c=s.prepare(`SELECT id, data FROM auth_signal WHERE type = ? AND id IN (${o})`).all(e,...i);for(let d of c)r[d.id]=this.parseBlob(d.data);}return r},write:async e=>{let t=await this.ensureReady(),r=this.db,s=[],i=[];for(let a of Object.keys(e)){let c=e[a];if(c)for(let d of Object.keys(c)){let l=c[d];l===null?i.push({type:a,id:d}):l!==void 0&&s.push({type:a,id:d,blob:this.encodeBlob(l)});}}r.transaction(()=>{for(let a of s)t.writeSignal.run(a.type,a.id,a.blob);for(let a of i)t.deleteSignal.run(a.type,a.id);})();},delete:async(e,t)=>{if(await this.ensureReady(),t.length===0)return;let r=this.db,s=r.transaction(i=>{let o=Ts(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Os(t,ks))s(i);},clear:async()=>{let e=await this.ensureReady();this.db.transaction(()=>{e.clearSignal.run(),e.clearCreds.run();})();},close:async()=>{if(!this.closed){this.closed=true;try{this.db?.close();}catch(e){throw new f("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new f("STORE_CLOSED","SqliteAuthStore is closed");return this.prepared?this.prepared:(this.readyPromise||(this.readyPromise=this.openAndMigrate().catch(e=>{throw this.readyPromise=null,e})),await this.readyPromise,this.prepared)}async openAndMigrate(){let e=await ma(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new f("STORE_CONNECTION_FAILED",`failed to open sqlite database at ${String(this.options.database)}`,{cause:r})}try{t.pragma("journal_mode = WAL"),t.pragma("synchronous = NORMAL"),t.pragma("foreign_keys = ON"),t.exec(`CREATE TABLE IF NOT EXISTS auth_creds (id TEXT PRIMARY KEY, data BLOB NOT NULL) WITHOUT ROWID;
17
+ CREATE TABLE IF NOT EXISTS auth_signal (type TEXT NOT NULL, id TEXT NOT NULL, data BLOB NOT NULL, PRIMARY KEY(type, id)) WITHOUT ROWID;`);}catch(r){throw t.close(),new f("STORE_CONNECTION_FAILED","failed to migrate sqlite schema",{cause:r})}this.db=t,this.prepared={readCreds:t.prepare("SELECT data FROM auth_creds WHERE id = ?"),writeCreds:t.prepare("INSERT INTO auth_creds(id, data) VALUES(?, ?) ON CONFLICT(id) DO UPDATE SET data = excluded.data"),deleteCreds:t.prepare("DELETE FROM auth_creds WHERE id = ?"),writeSignal:t.prepare("INSERT INTO auth_signal(type, id, data) VALUES(?, ?, ?) ON CONFLICT(type, id) DO UPDATE SET data = excluded.data"),deleteSignal:t.prepare("DELETE FROM auth_signal WHERE type = ? AND id = ?"),clearSignal:t.prepare("DELETE FROM auth_signal"),clearCreds:t.prepare("DELETE FROM auth_creds")};}encodeBlob(e){try{return Buffer.from(JSON.stringify(e,BufferJSON.replacer),"utf8")}catch(t){throw new f("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:t})}}parseBlob(e){try{let t=Buffer.isBuffer(e)?e.toString("utf8"):Buffer.from(e).toString("utf8");return JSON.parse(t,BufferJSON.reviver)}catch(t){throw new f("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var bt,ga=async()=>(bt||(bt=import('pg').catch(n=>{throw bt=void 0,new f("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),bt),fa="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",ha="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",xs=class{externalPool;connectionString;poolMax;ownedPool;resolvedPool;readyPromise;closed=false;constructor(e){let t=e.pool!==void 0,r=e.connectionString!==void 0;if(t&&r)throw new f("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new f("STORE_CONNECTION_FAILED","PostgresAuthStore: pool or connectionString is required");this.externalPool=e.pool,this.connectionString=e.connectionString,this.poolMax=e.max;}async ensureReady(){if(this.closed)throw new f("STORE_CLOSED","PostgresAuthStore is closed");if(this.resolvedPool)return this.resolvedPool;this.readyPromise||(this.readyPromise=(async()=>{let e;if(this.externalPool)e=this.externalPool;else {let t=await ga(),r=t.Pool??t.default?.Pool;if(!r)throw new f("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(fa),await e.query(ha);}catch(t){throw new f("STORE_CONNECTION_FAILED","failed to migrate auth schema",{cause:t})}return this.resolvedPool=e,e})());try{return await this.readyPromise}catch(e){throw this.readyPromise=void 0,e}}signal={read:async(e,t)=>{let r=await this.ensureReady(),s={};if(t.length===0)return s;try{let i=t.map((a,c)=>`$${c+2}`).join(", "),o=await r.query(`SELECT id, data FROM zaileys_auth_signal WHERE type = $1 AND id IN (${i})`,[String(e),...Array.from(t)]);for(let a of o.rows){let c=Buffer.isBuffer(a.data)?a.data:Buffer.from(a.data);s[a.id]=JSON.parse(c.toString("utf8"),BufferJSON.reviver);}return s}catch(i){throw i instanceof f?i:new f("STORE_READ_FAILED","failed to read signal rows",{cause:i})}},write:async e=>{let t=await this.ensureReady(),r=[];for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a];if(c===null)r.push({kind:"delete",type:String(i),id:a});else if(c!==void 0){let d=Buffer.from(JSON.stringify(c,BufferJSON.replacer),"utf8");r.push({kind:"upsert",type:String(i),id:a,value:d});}}}if(r.length===0)return;let s;try{s=await t.connect(),await s.query("BEGIN");for(let i of r)i.kind==="delete"?await s.query("DELETE FROM zaileys_auth_signal WHERE type = $1 AND id = $2",[i.type,i.id]):await s.query("INSERT INTO zaileys_auth_signal(type, id, data) VALUES ($1, $2, $3) ON CONFLICT (type, id) DO UPDATE SET data = EXCLUDED.data",[i.type,i.id,i.value]);await s.query("COMMIT");}catch(i){if(s)try{await s.query("ROLLBACK");}catch{}throw new f("STORE_WRITE_FAILED","failed to write signal rows",{cause:i})}finally{s?.release();}},delete:async(e,t)=>{let r=await this.ensureReady();if(t.length!==0)try{let s=t.map((i,o)=>`$${o+2}`).join(", ");await r.query(`DELETE FROM zaileys_auth_signal WHERE type = $1 AND id IN (${s})`,[String(e),...Array.from(t)]);}catch(s){throw new f("STORE_WRITE_FAILED","failed to delete signal rows",{cause:s})}},clear:async()=>{let e=await this.ensureReady(),t;try{t=await e.connect(),await t.query("BEGIN"),await t.query("DELETE FROM zaileys_auth_signal"),await t.query("DELETE FROM zaileys_auth_creds"),await t.query("COMMIT");}catch(r){if(t)try{await t.query("ROLLBACK");}catch{}throw new f("STORE_WRITE_FAILED","failed to clear auth tables",{cause:r})}finally{t?.release();}},close:async()=>{if(this.closed)return;this.closed=true;let e=this.ownedPool;if(this.ownedPool=void 0,this.resolvedPool=void 0,this.readyPromise=void 0,e)try{await e.end();}catch{}}};creds={readCreds:async()=>{let e=await this.ensureReady();try{let r=(await e.query("SELECT data FROM zaileys_auth_creds WHERE id = 'default'")).rows[0];if(!r)return;let s=typeof r.data=="string"?r.data:JSON.stringify(r.data);return JSON.parse(s,BufferJSON.reviver)}catch(t){throw t instanceof f?t:new f("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,BufferJSON.replacer);await t.query("INSERT INTO zaileys_auth_creds(id, data) VALUES ('default', $1::jsonb) ON CONFLICT (id) DO UPDATE SET data = EXCLUDED.data",[r]);}catch(r){throw new f("STORE_WRITE_FAILED","failed to write creds",{cause:r})}},deleteCreds:async()=>{let e=await this.ensureReady();try{await e.query("DELETE FROM zaileys_auth_creds WHERE id = 'default'");}catch(t){throw new f("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var ya="zaileys",wa=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],va=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},Rs=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new f("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new f("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??ya,this.externalClient=e.client,this.url=e.url;}signal={read:async(e,t)=>{if(this.assertOpen(),t.length===0)return {};let r=await this.ensureReady(),s=t.map(a=>this.signalKey(e,a)),i=await this.runRead(()=>r.mGet(s)),o={};for(let a=0;a<t.length;a+=1){let c=i[a];c!=null&&(o[t[a]]=JSON.parse(c,BufferJSON.reviver));}return o},write:async e=>{this.assertOpen();let r=(await this.ensureReady()).multi(),s=0;for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a],d=this.signalKey(i,a),l=this.indexKey(i);c===null?(r.del(d),r.sRem(l,a)):c!==void 0&&(r.set(d,JSON.stringify(c,BufferJSON.replacer)),r.sAdd(l,a)),s+=1;}}s!==0&&await this.runWrite(()=>r.exec());},delete:async(e,t)=>{if(this.assertOpen(),t.length===0)return;let s=(await this.ensureReady()).multi();for(let i of t)s.del(this.signalKey(e,i)),s.sRem(this.indexKey(e),i);await this.runWrite(()=>s.exec());},clear:async()=>{this.assertOpen();let e=await this.ensureReady(),t=e.multi();for(let r of wa){let s=this.indexKey(r),i=await this.runRead(()=>e.sMembers(s));for(let o of i)t.del(this.signalKey(r,o));t.del(s);}t.del(this.credsKey()),await this.runWrite(()=>t.exec());},close:async()=>{await this.shutdown();}};creds={readCreds:async()=>{this.assertOpen();let e=await this.ensureReady(),t=await this.runRead(()=>e.get(this.credsKey()));if(t!=null)return JSON.parse(t,BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,BufferJSON.replacer)));},deleteCreds:async()=>{this.assertOpen();let e=await this.ensureReady();await this.runWrite(()=>e.del(this.credsKey()));}};credsKey(){return `${this.namespace}:auth:creds`}signalKey(e,t){return `${this.namespace}:auth:signal:${String(e)}:${t}`}indexKey(e){return `${this.namespace}:auth:signal-index:${String(e)}`}async ensureReady(){return this.ready||(this.ready=this.connect()),this.ready}async connect(){if(this.externalClient){if(!this.externalClient.isOpen)throw new f("STORE_CONNECTION_FAILED","provided redis client is not open (call await client.connect() first)");return this.externalClient}let e;try{e=await import('redis');}catch(r){throw va(r)?new f("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new f("STORE_CONNECTION_FAILED","failed to load redis module",{cause:r})}let t=e.createClient({url:this.url});try{await t.connect();}catch(r){throw new f("STORE_CONNECTION_FAILED",`failed to connect to redis at ${this.url}`,{cause:r})}return this.ownedClient=t,t}async runRead(e){try{return await e()}catch(t){throw new f("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new f("STORE_WRITE_FAILED","redis write failed",{cause:t})}}async shutdown(){if(!this.closed){if(this.closed=true,this.ownedClient){try{await this.ownedClient.quit();}catch{}this.ownedClient=void 0;}this.ready=void 0;}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","RedisAuthStore is closed")}};var Ma="zaileys",Ye={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Sa=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},ye=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new f("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new f("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Ma,this.externalClient=e.client,this.url=e.url;}async get(e){if(this.assertOpen(),e.length===0)return new Map;let t=await this.ensureClient(),r=await this.runRead(()=>t.query(Ye.get,{namespace:this.namespace,keys:[...e]})),s=new Map;for(let i of r??[])s.set(i.key,i.value);return s}async set(e){if(this.assertOpen(),e.length===0)return;let t=await this.ensureClient();await this.runWrite(()=>t.mutation(Ye.set,{namespace:this.namespace,items:[...e]}));}async del(e){if(this.assertOpen(),e.length===0)return;let t=await this.ensureClient();await this.runWrite(()=>t.mutation(Ye.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(Ye.clear,e===void 0?{namespace:this.namespace}:{namespace:this.namespace,prefix:e}));}async list(e,t){this.assertOpen();let r=await this.ensureClient(),s={namespace:this.namespace,prefix:e};return typeof t?.before=="number"&&(s.before=t.before),typeof t?.limit=="number"&&(s.limit=t.limit),await this.runRead(()=>r.query(Ye.list,s))??[]}close(){this.closed=true,this.client=void 0;}async ensureClient(){if(this.externalClient)return this.externalClient;if(this.client)return this.client;let e="convex/browser",t;try{t=await import(e);}catch(r){throw Sa(r)?new f("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new f("STORE_CONNECTION_FAILED","failed to load convex module",{cause:r})}return this.client=new t.ConvexHttpClient(this.url),this.client}async runRead(e){try{return await e()}catch(t){throw new f("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new f("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","Convex store is closed")}};var Ot="creds",Aa="signal:",Ze=(n,e)=>`${Aa}${n}:${e}`,Ls=class{creds;signal;kv;constructor(e){this.kv=new ye(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([Ot])).get(Ot);return s===void 0?void 0:JSON.parse(s,BufferJSON.reviver)},async writeCreds(r){await t.set([{key:Ot,value:JSON.stringify(r,BufferJSON.replacer)}]);},async deleteCreds(){await t.del([Ot]);}},this.signal={async read(r,s){let i=s.map(c=>Ze(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(Ze(r,c));a[c]=d===void 0?void 0:JSON.parse(d,BufferJSON.reviver);}return a},async write(r){let s=[],i=[];for(let o of Object.keys(r)){let a=r[o];if(a)for(let c of Object.keys(a)){let d=a[c];d==null?i.push(Ze(o,c)):s.push({key:Ze(o,c),value:JSON.stringify(d,BufferJSON.replacer)});}}s.length>0&&await t.set(s),i.length>0&&await t.del(i);},async delete(r,s){await t.del(s.map(i=>Ze(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var It=null,Pa=async()=>{if(It)return It;try{return It=(await import('better-sqlite3')).default,It}catch(n){throw new f("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},xt=n=>{try{return Buffer.from(JSON.stringify(n,BufferJSON.replacer),"utf8")}catch(e){throw new f("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},ae=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){throw new f("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},Ns=class{options;db=null;prepared=null;readyPromise=null;closed=false;boundSocket;listeners=new Map;constructor(e){this.options=e;}async saveMessage(e){let t=await this.ensureReady(),r=e.key.remoteJid??"",s=e.key.id??"",i=e.key.fromMe?1:0,o=Number(e.messageTimestamp??0);t.upsertMessage.run(r,s,i,o,xt(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?ae(r.data):void 0}async listMessages(e,t){let r=await this.ensureReady(),s=t?.limit??100,i=t?.before;return (typeof i=="number"?r.listMessages.all(e,i,s):r.listMessages.all(e,Number.MAX_SAFE_INTEGER,s)).map(a=>ae(a.data))}async saveChat(e){let t=await this.ensureReady(),r=e.id;if(!r)return;let s=e.archived?1:0;t.upsertChat.run(r,s,xt(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?ae(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>ae(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,xt(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?ae(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>ae(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,xt(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?ae(r.data):void 0}async deleteMessage(e){(await this.ensureReady()).deleteMessage.run(e.remoteJid??"",e.id??"",e.fromMe===true?1:0);}async pruneMessages(e){let t=await this.ensureReady(),r=this.db,s=0,i=e.chatFilter?r.prepare("SELECT DISTINCT remote_jid FROM messages").all().map(o=>o.remote_jid).filter(o=>e.chatFilter(o)):void 0;if(e.olderThan!==void 0)if(i)for(let o of i)s+=t.pruneByAgeChat.run(e.olderThan,o).changes;else s+=t.pruneByAge.run(e.olderThan).changes;if(e.maxPerChat!==void 0){let o=i?"WHERE remote_jid IN ("+i.map(()=>"?").join(",")+")":"",a=r.prepare(`DELETE FROM messages WHERE rowid IN (
18
18
  SELECT rowid FROM (
19
19
  SELECT rowid, ROW_NUMBER() OVER (PARTITION BY remote_jid ORDER BY timestamp DESC) AS rn
20
20
  FROM messages ${o}
21
21
  ) WHERE rn > ?
22
- )`);s+=a.run(...i??[],e.maxPerChat).changes;}return s}bind(e){if(this.closed)throw new g("STORE_CLOSED","SqliteMessageStore is closed");this.boundSocket=e;let t=(...o)=>{let c=o[0]?.messages;if(Array.isArray(c))for(let d of c)this.saveMessage(d).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){let e=await this.ensureReady();this.db.transaction(()=>{e.clearMessages.run(),e.clearChats.run(),e.clearContacts.run(),e.clearPresence.run();})();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);this.listeners.clear(),this.boundSocket=void 0;try{this.db?.close();}catch(e){throw new g("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new g("STORE_CLOSED","SqliteMessageStore is closed");return this.prepared?this.prepared:(this.readyPromise||(this.readyPromise=this.openAndMigrate().catch(e=>{throw this.readyPromise=null,e})),await this.readyPromise,this.prepared)}async openAndMigrate(){let e=await za(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new g("STORE_CONNECTION_FAILED",`failed to open sqlite database at ${String(this.options.database)}`,{cause:r})}try{t.pragma("journal_mode = WAL"),t.pragma("synchronous = NORMAL"),t.pragma("foreign_keys = ON"),t.exec(`CREATE TABLE IF NOT EXISTS messages (
22
+ )`);s+=a.run(...i??[],e.maxPerChat).changes;}return s}bind(e){if(this.closed)throw new f("STORE_CLOSED","SqliteMessageStore is closed");this.boundSocket=e;let t=(...o)=>{let c=o[0]?.messages;if(Array.isArray(c))for(let d of c)this.saveMessage(d).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){let e=await this.ensureReady();this.db.transaction(()=>{e.clearMessages.run(),e.clearChats.run(),e.clearContacts.run(),e.clearPresence.run();})();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);this.listeners.clear(),this.boundSocket=void 0;try{this.db?.close();}catch(e){throw new f("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new f("STORE_CLOSED","SqliteMessageStore is closed");return this.prepared?this.prepared:(this.readyPromise||(this.readyPromise=this.openAndMigrate().catch(e=>{throw this.readyPromise=null,e})),await this.readyPromise,this.prepared)}async openAndMigrate(){let e=await Pa(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new f("STORE_CONNECTION_FAILED",`failed to open sqlite database at ${String(this.options.database)}`,{cause:r})}try{t.pragma("journal_mode = WAL"),t.pragma("synchronous = NORMAL"),t.pragma("foreign_keys = ON"),t.exec(`CREATE TABLE IF NOT EXISTS messages (
23
23
  remote_jid TEXT NOT NULL,
24
24
  id TEXT NOT NULL,
25
25
  from_me INTEGER NOT NULL,
@@ -30,8 +30,8 @@ ${ie} ${wo}`:t}case "disconnect":return n.willReconnect?null:`${ie} Disconnected
30
30
  CREATE INDEX IF NOT EXISTS messages_by_jid_ts ON messages(remote_jid, timestamp DESC);
31
31
  CREATE TABLE IF NOT EXISTS chats (jid TEXT PRIMARY KEY, archived INTEGER NOT NULL DEFAULT 0, data BLOB NOT NULL) WITHOUT ROWID;
32
32
  CREATE TABLE IF NOT EXISTS contacts (jid TEXT PRIMARY KEY, data BLOB NOT NULL) WITHOUT ROWID;
33
- CREATE TABLE IF NOT EXISTS presence (jid TEXT PRIMARY KEY, data BLOB NOT NULL) WITHOUT ROWID;`);}catch(r){throw t.close(),new g("STORE_CONNECTION_FAILED","failed to migrate sqlite schema",{cause:r})}this.db=t,this.prepared={upsertMessage:t.prepare(`INSERT INTO messages(remote_jid, id, from_me, timestamp, data) VALUES(?, ?, ?, ?, ?)
33
+ CREATE TABLE IF NOT EXISTS presence (jid TEXT PRIMARY KEY, data BLOB NOT NULL) WITHOUT ROWID;`);}catch(r){throw t.close(),new f("STORE_CONNECTION_FAILED","failed to migrate sqlite schema",{cause:r})}this.db=t,this.prepared={upsertMessage:t.prepare(`INSERT INTO messages(remote_jid, id, from_me, timestamp, data) VALUES(?, ?, ?, ?, ?)
34
34
  ON CONFLICT(remote_jid, id, from_me) DO UPDATE SET timestamp = excluded.timestamp, data = excluded.data`),getMessage:t.prepare("SELECT data FROM messages WHERE remote_jid = ? AND id = ? AND from_me = ?"),listMessages:t.prepare("SELECT data FROM messages WHERE remote_jid = ? AND timestamp < ? ORDER BY timestamp DESC LIMIT ?"),upsertChat:t.prepare(`INSERT INTO chats(jid, archived, data) VALUES(?, ?, ?)
35
35
  ON CONFLICT(jid) DO UPDATE SET archived = excluded.archived, data = excluded.data`),getChat:t.prepare("SELECT data FROM chats WHERE jid = ?"),listChats:t.prepare("SELECT data FROM chats"),listChatsArchived:t.prepare("SELECT data FROM chats WHERE archived = 1"),upsertContact:t.prepare(`INSERT INTO contacts(jid, data) VALUES(?, ?)
36
36
  ON CONFLICT(jid) DO UPDATE SET data = excluded.data`),getContact:t.prepare("SELECT data FROM contacts WHERE jid = ?"),listContacts:t.prepare("SELECT data FROM contacts"),upsertPresence:t.prepare(`INSERT INTO presence(jid, data) VALUES(?, ?)
37
- ON CONFLICT(jid) DO UPDATE SET data = excluded.data`),getPresence:t.prepare("SELECT data FROM presence WHERE jid = ?"),clearMessages:t.prepare("DELETE FROM messages"),clearChats:t.prepare("DELETE FROM chats"),clearContacts:t.prepare("DELETE FROM contacts"),clearPresence:t.prepare("DELETE FROM presence"),deleteMessage:t.prepare("DELETE FROM messages WHERE remote_jid = ? AND id = ? AND from_me = ?"),pruneByAge:t.prepare("DELETE FROM messages WHERE timestamp < ?"),pruneByAgeChat:t.prepare("DELETE FROM messages WHERE timestamp < ? AND remote_jid = ?")};}};var jt,Ya=async()=>(jt||(jt=import('pg').catch(n=>{throw jt=void 0,new g("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),jt),Za=["CREATE TABLE IF NOT EXISTS zaileys_messages (remote_jid text NOT NULL, id text NOT NULL, from_me boolean NOT NULL, timestamp bigint NOT NULL, data jsonb NOT NULL, PRIMARY KEY(remote_jid, id, from_me))","CREATE INDEX IF NOT EXISTS zaileys_messages_jid_ts_idx ON zaileys_messages(remote_jid, timestamp DESC)","CREATE TABLE IF NOT EXISTS zaileys_chats (jid text PRIMARY KEY, archived boolean NOT NULL DEFAULT false, data jsonb NOT NULL)","CREATE INDEX IF NOT EXISTS zaileys_chats_archived_idx ON zaileys_chats(archived) WHERE archived = true","CREATE TABLE IF NOT EXISTS zaileys_contacts (jid text PRIMARY KEY, data jsonb NOT NULL)","CREATE TABLE IF NOT EXISTS zaileys_presence (jid text PRIMARY KEY, data jsonb NOT NULL, updated_at timestamptz NOT NULL DEFAULT now())"],le=n=>{if(n==null)return n;let e=typeof n=="string"?n:JSON.stringify(n);return JSON.parse(e,BufferJSON.reviver)},ei=class{externalPool;connectionString;poolMax;ownedPool;resolvedPool;readyPromise;boundSocket;listeners=new Map;closed=false;constructor(e){let t=e.pool!==void 0,r=e.connectionString!==void 0;if(t&&r)throw new g("STORE_CONNECTION_FAILED","PostgresMessageStore: provide either pool or connectionString, not both");if(!t&&!r)throw new g("STORE_CONNECTION_FAILED","PostgresMessageStore: pool or connectionString is required");this.externalPool=e.pool,this.connectionString=e.connectionString,this.poolMax=e.max;}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","PostgresMessageStore is closed")}async ensureReady(){if(this.assertOpen(),this.resolvedPool)return this.resolvedPool;this.readyPromise||(this.readyPromise=(async()=>{let e;if(this.externalPool)e=this.externalPool;else {let t=await Ya(),r=t.Pool??t.default?.Pool;if(!r)throw new g("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{for(let t of Za)await e.query(t);}catch(t){throw new g("STORE_CONNECTION_FAILED","failed to migrate message schema",{cause:t})}return this.resolvedPool=e,e})());try{return await this.readyPromise}catch(e){throw this.readyPromise=void 0,e}}async saveMessage(e){let t=await this.ensureReady(),r=e.key.remoteJid??"",s=e.key.id??"",i=e.key.fromMe===true,o=Number(e.messageTimestamp??0);try{await t.query("INSERT INTO zaileys_messages(remote_jid, id, from_me, timestamp, data) VALUES ($1, $2, $3, $4, $5::jsonb) ON CONFLICT (remote_jid, id, from_me) DO UPDATE SET data = EXCLUDED.data, timestamp = EXCLUDED.timestamp",[r,s,i,o,JSON.stringify(e,BufferJSON.replacer)]);}catch(a){throw new g("STORE_WRITE_FAILED","failed to save message",{cause:a})}}async getMessage(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[e.remoteJid??"",e.id??"",e.fromMe===!0])).rows[0];return s?le(s.data):void 0}catch(r){throw r instanceof g?r:new g("STORE_READ_FAILED","failed to read message",{cause:r})}}async listMessages(e,t){let r=await this.ensureReady(),s=t?.limit??100,i=typeof t?.before=="number"?t.before:null;try{return (await r.query("SELECT data FROM zaileys_messages WHERE remote_jid = $1 AND ($2::bigint IS NULL OR timestamp < $2::bigint) ORDER BY timestamp DESC LIMIT $3",[e,i,s])).rows.map(a=>le(a.data))}catch(o){throw new g("STORE_READ_FAILED","failed to list messages",{cause:o})}}async saveChat(e){let t=await this.ensureReady(),r=e.id;if(!r)return;let s=e.archived===true;try{await t.query("INSERT INTO zaileys_chats(jid, archived, data) VALUES ($1, $2, $3::jsonb) ON CONFLICT (jid) DO UPDATE SET archived = EXCLUDED.archived, data = EXCLUDED.data",[r,s,JSON.stringify(e,BufferJSON.replacer)]);}catch(i){throw new g("STORE_WRITE_FAILED","failed to save chat",{cause:i})}}async getChat(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_chats WHERE jid = $1",[e])).rows[0];return s?le(s.data):void 0}catch(r){throw new g("STORE_READ_FAILED","failed to read chat",{cause:r})}}async listChats(e){let t=await this.ensureReady(),r=typeof e?.archived=="boolean"?e.archived:null;try{return (await t.query("SELECT data FROM zaileys_chats WHERE ($1::boolean IS NULL OR archived = $1::boolean)",[r])).rows.map(i=>le(i.data))}catch(s){throw new g("STORE_READ_FAILED","failed to list chats",{cause:s})}}async saveContact(e){let t=await this.ensureReady();try{await t.query("INSERT INTO zaileys_contacts(jid, data) VALUES ($1, $2::jsonb) ON CONFLICT (jid) DO UPDATE SET data = EXCLUDED.data",[e.id,JSON.stringify(e,BufferJSON.replacer)]);}catch(r){throw new g("STORE_WRITE_FAILED","failed to save contact",{cause:r})}}async getContact(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_contacts WHERE jid = $1",[e])).rows[0];return s?le(s.data):void 0}catch(r){throw new g("STORE_READ_FAILED","failed to read contact",{cause:r})}}async listContacts(){let e=await this.ensureReady();try{return (await e.query("SELECT data FROM zaileys_contacts")).rows.map(r=>le(r.data))}catch(t){throw new g("STORE_READ_FAILED","failed to list contacts",{cause:t})}}async savePresence(e,t){let r=await this.ensureReady();try{await r.query("INSERT INTO zaileys_presence(jid, data, updated_at) VALUES ($1, $2::jsonb, now()) ON CONFLICT (jid) DO UPDATE SET data = EXCLUDED.data, updated_at = now()",[e,JSON.stringify(t,BufferJSON.replacer)]);}catch(s){throw new g("STORE_WRITE_FAILED","failed to save presence",{cause:s})}}async getPresence(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_presence WHERE jid = $1",[e])).rows[0];return s?le(s.data):void 0}catch(r){throw new g("STORE_READ_FAILED","failed to read presence",{cause:r})}}async deleteMessage(e){let t=await this.ensureReady();try{await t.query("DELETE FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[e.remoteJid??"",e.id??"",e.fromMe===!0]);}catch(r){throw new g("STORE_WRITE_FAILED","failed to delete message",{cause:r})}}async pruneMessages(e){let t=await this.ensureReady();try{let r=0,s;if(e.chatFilter&&(s=(await t.query("SELECT DISTINCT remote_jid FROM zaileys_messages",[])).rows.map(o=>o.remote_jid).filter(o=>e.chatFilter(o))),e.olderThan!==void 0){let i=s?await t.query("DELETE FROM zaileys_messages WHERE timestamp < $1 AND remote_jid = ANY($2::text[])",[e.olderThan,s]):await t.query("DELETE FROM zaileys_messages WHERE timestamp < $1",[e.olderThan]);r+=i.rowCount??0;}if(e.maxPerChat!==void 0){let i=s??await t.query("SELECT DISTINCT remote_jid FROM zaileys_messages",[]).then(o=>o.rows.map(a=>a.remote_jid));for(let o of i){let c=(await t.query("SELECT id, from_me FROM zaileys_messages WHERE remote_jid = $1 ORDER BY timestamp DESC",[o])).rows.slice(e.maxPerChat);if(c.length!==0)for(let d of c){let l=await t.query("DELETE FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[o,d.id,d.from_me]);r+=l.rowCount??0;}}}return r}catch(r){throw new g("STORE_WRITE_FAILED","failed to prune messages",{cause:r})}}bind(e){this.assertOpen(),this.boundSocket=e;let t=(...c)=>{let l=c[0]?.messages;if(Array.isArray(l))for(let u of l)this.saveMessage(u).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.getMessage(l.key).then(u=>{if(!u)return;let w={...u,...l.update};return this.saveMessage(w)}).catch(()=>{});},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveChat(l).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.getChat(l.id).then(u=>{let w={...u??{},...l};return this.saveChat(w)}).catch(()=>{});},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveContact(l).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let l of Object.keys(d.presences)){let u=d.presences[l];u&&this.savePresence(l,u).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("messages.update",r),this.listeners.set("chats.upsert",s),this.listeners.set("chats.update",i),this.listeners.set("contacts.upsert",o),this.listeners.set("presence.update",a);for(let[c,d]of this.listeners)e.ev.on(c,d);}async clear(){let e=await this.ensureReady(),t;try{t=await e.connect(),await t.query("BEGIN"),await t.query("DELETE FROM zaileys_messages"),await t.query("DELETE FROM zaileys_chats"),await t.query("DELETE FROM zaileys_contacts"),await t.query("DELETE FROM zaileys_presence"),await t.query("COMMIT");}catch(r){if(t)try{await t.query("ROLLBACK");}catch{}throw new g("STORE_WRITE_FAILED","failed to clear message tables",{cause:r})}finally{t?.release();}}async close(){if(this.closed)return;if(this.closed=true,this.boundSocket?.ev.off)for(let[t,r]of this.listeners)this.boundSocket.ev.off(t,r);this.listeners.clear(),this.boundSocket=void 0;let e=this.ownedPool;if(this.ownedPool=void 0,this.resolvedPool=void 0,this.readyPromise=void 0,e)try{await e.end();}catch{}}};var Xa="zaileys",Qa=300,ti=1e3,bn=n=>`${n.id??""}|${n.fromMe?1:0}`,ec=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},ni=class{namespace;externalClient;url;ownedClient;ready;closed=false;boundSocket;listeners=new Map;constructor(e){if(e.client&&e.url)throw new g("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new g("STORE_CONNECTION_FAILED","RedisMessageStore requires either client or url");this.namespace=e.namespace??Xa,this.externalClient=e.client,this.url=e.url;}async saveMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.key.remoteJid??"",s=bn(e.key),i=Number(e.messageTimestamp??0),o=JSON.stringify(e,BufferJSON.replacer),a=t.multi();a.zAdd(this.msgIndexKey(r),{score:i,value:s}),a.hSet(this.msgDataKey(r),s,o),await this.runWrite(()=>a.exec());}async getMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.remoteJid??"",s=await this.runRead(()=>t.hGet(this.msgDataKey(r),bn(e)));if(s!=null)return JSON.parse(s,BufferJSON.reviver)}async listMessages(e,t){this.assertOpen();let r=await this.ensureReady(),s=t?.limit??100,i=typeof t?.before=="number"?`(${t.before}`:"+inf",o=await this.runRead(()=>r.zRangeByScore(this.msgIndexKey(e),"-inf",i,{LIMIT:{offset:0,count:s+1024}}));if(o.length===0)return [];let c=[...o].reverse().slice(0,s),d=await this.runRead(()=>r.hmGet(this.msgDataKey(e),c)),l=[];for(let u of d)u!=null&&l.push(JSON.parse(u,BufferJSON.reviver));return l}async saveChat(e){this.assertOpen();let t=e.id;if(!t)return;let s=(await this.ensureReady()).multi();s.hSet(this.chatsKey(),t,JSON.stringify(e,BufferJSON.replacer)),e.archived===true?s.sAdd(this.chatsArchiveKey(),t):s.sRem(this.chatsArchiveKey(),t),await this.runWrite(()=>s.exec());}async getChat(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.hGet(this.chatsKey(),e));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}async listChats(e){this.assertOpen();let t=await this.ensureReady();if(e?.archived===true){let i=await this.runRead(()=>t.sMembers(this.chatsArchiveKey()));if(i.length===0)return [];let o=await this.runRead(()=>t.hmGet(this.chatsKey(),i)),a=[];for(let c of o)c!=null&&a.push(JSON.parse(c,BufferJSON.reviver));return a}let r=await this.runRead(()=>t.hGetAll(this.chatsKey())),s=[];for(let i of Object.keys(r)){let o=r[i];if(o==null)continue;let a=JSON.parse(o,BufferJSON.reviver);e?.archived===false&&await this.runRead(()=>t.sIsMember(this.chatsArchiveKey(),i))||s.push(a);}return s}async saveContact(e){this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.hSet(this.contactsKey(),e.id,JSON.stringify(e,BufferJSON.replacer)));}async getContact(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.hGet(this.contactsKey(),e));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}async listContacts(){this.assertOpen();let e=await this.ensureReady(),t=await this.runRead(()=>e.hGetAll(this.contactsKey())),r=[];for(let s of Object.keys(t)){let i=t[s];i!=null&&r.push(JSON.parse(i,BufferJSON.reviver));}return r}async savePresence(e,t){this.assertOpen();let r=await this.ensureReady();await this.runWrite(()=>r.set(this.presenceKey(e),JSON.stringify(t,BufferJSON.replacer),{EX:Qa}));}async getPresence(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.get(this.presenceKey(e)));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}bind(e){if(this.assertOpen(),this.boundSocket&&this.boundSocket.ev.off)for(let[o,a]of this.listeners)this.boundSocket.ev.off(o,a);this.listeners.clear(),this.boundSocket=e;let t=(...o)=>{let c=o[0]?.messages;if(Array.isArray(c))for(let d of c)this.saveMessage(d).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){this.assertOpen();let e=await this.ensureReady(),t=`${this.namespace}:*`,r=0;do{let s=await this.runRead(()=>e.scan(r,{MATCH:t,COUNT:ti}));r=Number(s.cursor),s.keys.length>0&&await this.runWrite(()=>e.del(s.keys));}while(r!==0)}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);if(this.listeners.clear(),this.boundSocket=void 0,this.ownedClient){try{await this.ownedClient.quit();}catch{}this.ownedClient=void 0;}this.ready=void 0;}}async deleteMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.remoteJid??"",s=bn(e),i=t.multi();i.zRem(this.msgIndexKey(r),s),i.hDel(this.msgDataKey(r),s),await this.runWrite(()=>i.exec());}async pruneMessages(e){this.assertOpen();let t=await this.ensureReady(),r=0,s=[],i=this.msgIndexKey("*"),o=0,a=this.msgDataKey("");do{let c=await this.runRead(()=>t.scan(o,{MATCH:i,COUNT:ti}));o=Number(c.cursor);for(let d of c.keys)d.startsWith(a)||s.push(d);}while(o!==0);for(let c of s){let d=this.jidFromIndexKey(c);if(e.chatFilter&&!e.chatFilter(d))continue;let l=this.msgDataKey(d),u=new Set;if(e.olderThan!==void 0){let v=await this.runRead(()=>t.zRangeByScore(c,"-inf",`(${e.olderThan}`));for(let E of v)u.add(E);}if(e.maxPerChat!==void 0){let v=e.maxPerChat,E=await this.runRead(()=>t.zRange(c,0,-(v+1)));for(let y of E)u.add(y);}if(u.size===0)continue;let w=[...u],M=t.multi();M.zRem(c,w),M.hDel(l,w),await this.runWrite(()=>M.exec()),r+=w.length;}return r}jidFromIndexKey(e){let t=this.msgIndexKey("");return e.startsWith(t)?e.slice(t.length):e}msgIndexKey(e){return `${this.namespace}:msg:${e}`}msgDataKey(e){return `${this.namespace}:msg-data:${e}`}chatsKey(){return `${this.namespace}:chats`}chatsArchiveKey(){return `${this.namespace}:chats-archived`}contactsKey(){return `${this.namespace}:contacts`}presenceKey(e){return `${this.namespace}:presence:${e}`}async ensureReady(){return this.ready||(this.ready=this.connect()),this.ready}async connect(){if(this.externalClient){if(!this.externalClient.isOpen)throw new g("STORE_CONNECTION_FAILED","provided redis client is not open (call await client.connect() first)");return this.externalClient}let e;try{e=await import('redis');}catch(r){throw ec(r)?new g("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new g("STORE_CONNECTION_FAILED","failed to load redis module",{cause:r})}let t=e.createClient({url:this.url});try{await t.connect();}catch(r){throw new g("STORE_CONNECTION_FAILED",`failed to connect to redis at ${this.url}`,{cause:r})}return this.ownedClient=t,t}async runRead(e){try{return await e()}catch(t){throw new g("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new g("STORE_WRITE_FAILED","redis write failed",{cause:t})}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","RedisMessageStore is closed")}};var $t="msg:",qt="chat:",Kt="contact:",Pn="presence:",En="job:",tc=n=>`${n.id??""}|${n.fromMe?1:0}`,Jt=n=>`${$t}${n.remoteJid??""}:${tc(n)}`,st=n=>JSON.stringify(n,BufferJSON.replacer),Z=n=>JSON.parse(n,BufferJSON.reviver),ri=class{kv;closed=false;boundSocket;listeners=new Map;constructor(e){this.kv=new Se(e);}async saveMessage(e){this.assertOpen(),await this.kv.set([{key:Jt(e.key),value:st(e),sortKey:Number(e.messageTimestamp??0)}]);}async getMessage(e){this.assertOpen();let r=(await this.kv.get([Jt(e)])).get(Jt(e));return r===void 0?void 0:Z(r)}async listMessages(e,t){this.assertOpen();let r={};return typeof t?.before=="number"&&(r.before=t.before),typeof t?.limit=="number"&&(r.limit=t.limit),(await this.kv.list(`${$t}${e}:`,r)).map(i=>Z(i.value))}async saveChat(e){this.assertOpen();let t=e.id;t&&await this.kv.set([{key:`${qt}${t}`,value:st(e)}]);}async getChat(e){this.assertOpen();let r=(await this.kv.get([`${qt}${e}`])).get(`${qt}${e}`);return r===void 0?void 0:Z(r)}async listChats(e){this.assertOpen();let t=await this.kv.list(qt),r=[];for(let s of t){let i=Z(s.value),o=i.archived===true;e?.archived===true&&!o||e?.archived===false&&o||r.push(i);}return r}async saveContact(e){this.assertOpen(),await this.kv.set([{key:`${Kt}${e.id}`,value:st(e)}]);}async getContact(e){this.assertOpen();let r=(await this.kv.get([`${Kt}${e}`])).get(`${Kt}${e}`);return r===void 0?void 0:Z(r)}async listContacts(){return this.assertOpen(),(await this.kv.list(Kt)).map(t=>Z(t.value))}async savePresence(e,t){this.assertOpen(),await this.kv.set([{key:`${Pn}${e}`,value:st(t)}]);}async getPresence(e){this.assertOpen();let r=(await this.kv.get([`${Pn}${e}`])).get(`${Pn}${e}`);return r===void 0?void 0:Z(r)}async saveScheduledJob(e){this.assertOpen(),await this.kv.set([{key:`${En}${e.id}`,value:st(e),sortKey:e.fireAt}]);}async listScheduledJobs(){return this.assertOpen(),(await this.kv.list(En)).map(t=>Z(t.value))}async deleteScheduledJob(e){this.assertOpen(),await this.kv.del([`${En}${e}`]);}async deleteMessage(e){this.assertOpen(),await this.kv.del([Jt(e)]);}async pruneMessages(e){this.assertOpen();let t=await this.kv.list($t,{}),r=new Map;for(let i of t){let o=i.key.slice($t.length),a=o.slice(0,o.indexOf(":"));if(e.chatFilter&&!e.chatFilter(a))continue;let c=r.get(a)??[];c.push({key:i.key,ts:i.sortKey??0}),r.set(a,c);}let s=[];for(let i of r.values()){i.sort((o,a)=>a.ts-o.ts);for(let o=0;o<i.length;o++){let a=i[o];(e.olderThan!==void 0&&a.ts<e.olderThan||e.maxPerChat!==void 0&&o>=e.maxPerChat)&&s.push(a.key);}}return s.length>0&&await this.kv.del(s),s.length}bind(e){if(this.assertOpen(),this.boundSocket?.ev.off)for(let[o,a]of this.listeners)this.boundSocket.ev.off(o,a);this.listeners.clear(),this.boundSocket=e;let t=(...o)=>{let a=o[0]?.messages;if(Array.isArray(a))for(let c of a)this.saveMessage(c).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){this.assertOpen(),await this.kv.clear();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);this.listeners.clear(),this.boundSocket=void 0,this.kv.close();}}assertOpen(){if(this.closed)throw new g("STORE_CLOSED","ConvexMessageStore is closed")}};var nc=(n,e)=>{if(e<=0)throw new RangeError("chunk size must be positive");let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t};var ug=n=>{let t=(n.split("@")[0]??"").split(":")[0]?.replace(/\D/g,"")??"";return n.endsWith("@s.whatsapp.net")||n.endsWith("@c.us")?t:""},pg=n=>`${n.replace(/\D/g,"")}@s.whatsapp.net`;export{ee as AudioProcessor,Ke as AutoDeleteSweeper,C as BufferConverter,De as BusinessModule,_e as ChatModule,qs as Client,Be as CommandRegistry,Re as CommunityModule,Ne as ContactModule,Zs as ConvexAuthStore,ri as ConvexMessageStore,mt as DocumentProcessor,ke as EditBuilder,b as FFMPEG_CONSTANTS,X as FFmpegProcessor,Mt as FileAuthStore,U as FileManager,Oe as GroupModule,F as ImageProcessor,ut as LottieProcessor,ne as Media,Ks as MemoryAuthStore,Pt as MemoryMessageStore,H as MessageBuilder,R as MimeValidator,xe as NewsletterModule,zs as PostgresAuthStore,ei as PostgresMessageStore,je as PresenceModule,Ie as PrivacyModule,Le as ProfileModule,se as RateLimiter,Ys as RedisAuthStore,ni as RedisMessageStore,zp as SELF_ONLY_PROTOCOL_TYPES,qe as Scheduler,Hs as SqliteAuthStore,Xs as SqliteMessageStore,pt as StickerProcessor,Ue as TaskQueue,Rt as TypedEventEmitter,q as VideoProcessor,O as ZaileysAutomationError,f as ZaileysBuilderError,x as ZaileysCommandError,k as ZaileysDomainError,g as ZaileysStoreError,yn as adoptLogger,pn as attachCommandDispatcher,Mn as buildMessageContext,nc as chunk,us as computeStaticId,ls as computeUniqueId,Dr as createAuthGuard,Ur as createConnectionStateMachine,Do as createLogger,gn as createOperationGuard,Br as createPairingFlow,Wr as createReconnectStrategy,Er as definePlugin,on as deleteMessage,L as detectFileType,Nn as detectMimeFromBuffer,qr as dropSpoofedSelfOnly,ps as epochSecondsToMs,cs as extractLinks,ot as ffmpegBin,j as ffmpegTransform,cn as forwardMessage,pe as generateId,Tr as genericPrune,ue as initializeFFmpeg,Ge as isFatalDisconnect,Te as isJid,Et as isLidJid,Zn as isLottieWas,Zr as isPnJid,St as isRateLimited,ug as jidToPhone,I as loadMedia,Rr as makeCacheableAuthStore,_r as mapDisconnectReason,we as normalizeJid,To as normalizePhoneNumber,ln as parseCommand,pg as phoneToJid,wt as pinMessage,Fr as printQrToTerminal,an as reactToMessage,xo as renderQrInTerminal,dn as resolveUsername,hn as runBroadcast,un as runMiddleware,ms as senderDeviceOf,Nr as shouldClearAuth,Dp as shouldReconnect,Lr as signalKeyStoreFromAuthStore,Oo as validateE164};
37
+ ON CONFLICT(jid) DO UPDATE SET data = excluded.data`),getPresence:t.prepare("SELECT data FROM presence WHERE jid = ?"),clearMessages:t.prepare("DELETE FROM messages"),clearChats:t.prepare("DELETE FROM chats"),clearContacts:t.prepare("DELETE FROM contacts"),clearPresence:t.prepare("DELETE FROM presence"),deleteMessage:t.prepare("DELETE FROM messages WHERE remote_jid = ? AND id = ? AND from_me = ?"),pruneByAge:t.prepare("DELETE FROM messages WHERE timestamp < ?"),pruneByAgeChat:t.prepare("DELETE FROM messages WHERE timestamp < ? AND remote_jid = ?")};}};var Rt,Ca=async()=>(Rt||(Rt=import('pg').catch(n=>{throw Rt=void 0,new f("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),Rt),Ea=["CREATE TABLE IF NOT EXISTS zaileys_messages (remote_jid text NOT NULL, id text NOT NULL, from_me boolean NOT NULL, timestamp bigint NOT NULL, data jsonb NOT NULL, PRIMARY KEY(remote_jid, id, from_me))","CREATE INDEX IF NOT EXISTS zaileys_messages_jid_ts_idx ON zaileys_messages(remote_jid, timestamp DESC)","CREATE TABLE IF NOT EXISTS zaileys_chats (jid text PRIMARY KEY, archived boolean NOT NULL DEFAULT false, data jsonb NOT NULL)","CREATE INDEX IF NOT EXISTS zaileys_chats_archived_idx ON zaileys_chats(archived) WHERE archived = true","CREATE TABLE IF NOT EXISTS zaileys_contacts (jid text PRIMARY KEY, data jsonb NOT NULL)","CREATE TABLE IF NOT EXISTS zaileys_presence (jid text PRIMARY KEY, data jsonb NOT NULL, updated_at timestamptz NOT NULL DEFAULT now())"],ce=n=>{if(n==null)return n;let e=typeof n=="string"?n:JSON.stringify(n);return JSON.parse(e,BufferJSON.reviver)},_s=class{externalPool;connectionString;poolMax;ownedPool;resolvedPool;readyPromise;boundSocket;listeners=new Map;closed=false;constructor(e){let t=e.pool!==void 0,r=e.connectionString!==void 0;if(t&&r)throw new f("STORE_CONNECTION_FAILED","PostgresMessageStore: provide either pool or connectionString, not both");if(!t&&!r)throw new f("STORE_CONNECTION_FAILED","PostgresMessageStore: pool or connectionString is required");this.externalPool=e.pool,this.connectionString=e.connectionString,this.poolMax=e.max;}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","PostgresMessageStore is closed")}async ensureReady(){if(this.assertOpen(),this.resolvedPool)return this.resolvedPool;this.readyPromise||(this.readyPromise=(async()=>{let e;if(this.externalPool)e=this.externalPool;else {let t=await Ca(),r=t.Pool??t.default?.Pool;if(!r)throw new f("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{for(let t of Ea)await e.query(t);}catch(t){throw new f("STORE_CONNECTION_FAILED","failed to migrate message schema",{cause:t})}return this.resolvedPool=e,e})());try{return await this.readyPromise}catch(e){throw this.readyPromise=void 0,e}}async saveMessage(e){let t=await this.ensureReady(),r=e.key.remoteJid??"",s=e.key.id??"",i=e.key.fromMe===true,o=Number(e.messageTimestamp??0);try{await t.query("INSERT INTO zaileys_messages(remote_jid, id, from_me, timestamp, data) VALUES ($1, $2, $3, $4, $5::jsonb) ON CONFLICT (remote_jid, id, from_me) DO UPDATE SET data = EXCLUDED.data, timestamp = EXCLUDED.timestamp",[r,s,i,o,JSON.stringify(e,BufferJSON.replacer)]);}catch(a){throw new f("STORE_WRITE_FAILED","failed to save message",{cause:a})}}async getMessage(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[e.remoteJid??"",e.id??"",e.fromMe===!0])).rows[0];return s?ce(s.data):void 0}catch(r){throw r instanceof f?r:new f("STORE_READ_FAILED","failed to read message",{cause:r})}}async listMessages(e,t){let r=await this.ensureReady(),s=t?.limit??100,i=typeof t?.before=="number"?t.before:null;try{return (await r.query("SELECT data FROM zaileys_messages WHERE remote_jid = $1 AND ($2::bigint IS NULL OR timestamp < $2::bigint) ORDER BY timestamp DESC LIMIT $3",[e,i,s])).rows.map(a=>ce(a.data))}catch(o){throw new f("STORE_READ_FAILED","failed to list messages",{cause:o})}}async saveChat(e){let t=await this.ensureReady(),r=e.id;if(!r)return;let s=e.archived===true;try{await t.query("INSERT INTO zaileys_chats(jid, archived, data) VALUES ($1, $2, $3::jsonb) ON CONFLICT (jid) DO UPDATE SET archived = EXCLUDED.archived, data = EXCLUDED.data",[r,s,JSON.stringify(e,BufferJSON.replacer)]);}catch(i){throw new f("STORE_WRITE_FAILED","failed to save chat",{cause:i})}}async getChat(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_chats WHERE jid = $1",[e])).rows[0];return s?ce(s.data):void 0}catch(r){throw new f("STORE_READ_FAILED","failed to read chat",{cause:r})}}async listChats(e){let t=await this.ensureReady(),r=typeof e?.archived=="boolean"?e.archived:null;try{return (await t.query("SELECT data FROM zaileys_chats WHERE ($1::boolean IS NULL OR archived = $1::boolean)",[r])).rows.map(i=>ce(i.data))}catch(s){throw new f("STORE_READ_FAILED","failed to list chats",{cause:s})}}async saveContact(e){let t=await this.ensureReady();try{await t.query("INSERT INTO zaileys_contacts(jid, data) VALUES ($1, $2::jsonb) ON CONFLICT (jid) DO UPDATE SET data = EXCLUDED.data",[e.id,JSON.stringify(e,BufferJSON.replacer)]);}catch(r){throw new f("STORE_WRITE_FAILED","failed to save contact",{cause:r})}}async getContact(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_contacts WHERE jid = $1",[e])).rows[0];return s?ce(s.data):void 0}catch(r){throw new f("STORE_READ_FAILED","failed to read contact",{cause:r})}}async listContacts(){let e=await this.ensureReady();try{return (await e.query("SELECT data FROM zaileys_contacts")).rows.map(r=>ce(r.data))}catch(t){throw new f("STORE_READ_FAILED","failed to list contacts",{cause:t})}}async savePresence(e,t){let r=await this.ensureReady();try{await r.query("INSERT INTO zaileys_presence(jid, data, updated_at) VALUES ($1, $2::jsonb, now()) ON CONFLICT (jid) DO UPDATE SET data = EXCLUDED.data, updated_at = now()",[e,JSON.stringify(t,BufferJSON.replacer)]);}catch(s){throw new f("STORE_WRITE_FAILED","failed to save presence",{cause:s})}}async getPresence(e){let t=await this.ensureReady();try{let s=(await t.query("SELECT data FROM zaileys_presence WHERE jid = $1",[e])).rows[0];return s?ce(s.data):void 0}catch(r){throw new f("STORE_READ_FAILED","failed to read presence",{cause:r})}}async deleteMessage(e){let t=await this.ensureReady();try{await t.query("DELETE FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[e.remoteJid??"",e.id??"",e.fromMe===!0]);}catch(r){throw new f("STORE_WRITE_FAILED","failed to delete message",{cause:r})}}async pruneMessages(e){let t=await this.ensureReady();try{let r=0,s;if(e.chatFilter&&(s=(await t.query("SELECT DISTINCT remote_jid FROM zaileys_messages",[])).rows.map(o=>o.remote_jid).filter(o=>e.chatFilter(o))),e.olderThan!==void 0){let i=s?await t.query("DELETE FROM zaileys_messages WHERE timestamp < $1 AND remote_jid = ANY($2::text[])",[e.olderThan,s]):await t.query("DELETE FROM zaileys_messages WHERE timestamp < $1",[e.olderThan]);r+=i.rowCount??0;}if(e.maxPerChat!==void 0){let i=s??await t.query("SELECT DISTINCT remote_jid FROM zaileys_messages",[]).then(o=>o.rows.map(a=>a.remote_jid));for(let o of i){let c=(await t.query("SELECT id, from_me FROM zaileys_messages WHERE remote_jid = $1 ORDER BY timestamp DESC",[o])).rows.slice(e.maxPerChat);if(c.length!==0)for(let d of c){let l=await t.query("DELETE FROM zaileys_messages WHERE remote_jid = $1 AND id = $2 AND from_me = $3",[o,d.id,d.from_me]);r+=l.rowCount??0;}}}return r}catch(r){throw new f("STORE_WRITE_FAILED","failed to prune messages",{cause:r})}}bind(e){this.assertOpen(),this.boundSocket=e;let t=(...c)=>{let l=c[0]?.messages;if(Array.isArray(l))for(let u of l)this.saveMessage(u).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.getMessage(l.key).then(u=>{if(!u)return;let w={...u,...l.update};return this.saveMessage(w)}).catch(()=>{});},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveChat(l).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.getChat(l.id).then(u=>{let w={...u??{},...l};return this.saveChat(w)}).catch(()=>{});},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let l of d)this.saveContact(l).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let l of Object.keys(d.presences)){let u=d.presences[l];u&&this.savePresence(l,u).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("messages.update",r),this.listeners.set("chats.upsert",s),this.listeners.set("chats.update",i),this.listeners.set("contacts.upsert",o),this.listeners.set("presence.update",a);for(let[c,d]of this.listeners)e.ev.on(c,d);}async clear(){let e=await this.ensureReady(),t;try{t=await e.connect(),await t.query("BEGIN"),await t.query("DELETE FROM zaileys_messages"),await t.query("DELETE FROM zaileys_chats"),await t.query("DELETE FROM zaileys_contacts"),await t.query("DELETE FROM zaileys_presence"),await t.query("COMMIT");}catch(r){if(t)try{await t.query("ROLLBACK");}catch{}throw new f("STORE_WRITE_FAILED","failed to clear message tables",{cause:r})}finally{t?.release();}}async close(){if(this.closed)return;if(this.closed=true,this.boundSocket?.ev.off)for(let[t,r]of this.listeners)this.boundSocket.ev.off(t,r);this.listeners.clear(),this.boundSocket=void 0;let e=this.ownedPool;if(this.ownedPool=void 0,this.resolvedPool=void 0,this.readyPromise=void 0,e)try{await e.end();}catch{}}};var ba="zaileys",ka=300,Bs=1e3,gn=n=>`${n.id??""}|${n.fromMe?1:0}`,Ta=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},Fs=class{namespace;externalClient;url;ownedClient;ready;closed=false;boundSocket;listeners=new Map;constructor(e){if(e.client&&e.url)throw new f("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new f("STORE_CONNECTION_FAILED","RedisMessageStore requires either client or url");this.namespace=e.namespace??ba,this.externalClient=e.client,this.url=e.url;}async saveMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.key.remoteJid??"",s=gn(e.key),i=Number(e.messageTimestamp??0),o=JSON.stringify(e,BufferJSON.replacer),a=t.multi();a.zAdd(this.msgIndexKey(r),{score:i,value:s}),a.hSet(this.msgDataKey(r),s,o),await this.runWrite(()=>a.exec());}async getMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.remoteJid??"",s=await this.runRead(()=>t.hGet(this.msgDataKey(r),gn(e)));if(s!=null)return JSON.parse(s,BufferJSON.reviver)}async listMessages(e,t){this.assertOpen();let r=await this.ensureReady(),s=t?.limit??100,i=typeof t?.before=="number"?`(${t.before}`:"+inf",o=await this.runRead(()=>r.zRangeByScore(this.msgIndexKey(e),"-inf",i,{LIMIT:{offset:0,count:s+1024}}));if(o.length===0)return [];let c=[...o].reverse().slice(0,s),d=await this.runRead(()=>r.hmGet(this.msgDataKey(e),c)),l=[];for(let u of d)u!=null&&l.push(JSON.parse(u,BufferJSON.reviver));return l}async saveChat(e){this.assertOpen();let t=e.id;if(!t)return;let s=(await this.ensureReady()).multi();s.hSet(this.chatsKey(),t,JSON.stringify(e,BufferJSON.replacer)),e.archived===true?s.sAdd(this.chatsArchiveKey(),t):s.sRem(this.chatsArchiveKey(),t),await this.runWrite(()=>s.exec());}async getChat(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.hGet(this.chatsKey(),e));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}async listChats(e){this.assertOpen();let t=await this.ensureReady();if(e?.archived===true){let i=await this.runRead(()=>t.sMembers(this.chatsArchiveKey()));if(i.length===0)return [];let o=await this.runRead(()=>t.hmGet(this.chatsKey(),i)),a=[];for(let c of o)c!=null&&a.push(JSON.parse(c,BufferJSON.reviver));return a}let r=await this.runRead(()=>t.hGetAll(this.chatsKey())),s=[];for(let i of Object.keys(r)){let o=r[i];if(o==null)continue;let a=JSON.parse(o,BufferJSON.reviver);e?.archived===false&&await this.runRead(()=>t.sIsMember(this.chatsArchiveKey(),i))||s.push(a);}return s}async saveContact(e){this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.hSet(this.contactsKey(),e.id,JSON.stringify(e,BufferJSON.replacer)));}async getContact(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.hGet(this.contactsKey(),e));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}async listContacts(){this.assertOpen();let e=await this.ensureReady(),t=await this.runRead(()=>e.hGetAll(this.contactsKey())),r=[];for(let s of Object.keys(t)){let i=t[s];i!=null&&r.push(JSON.parse(i,BufferJSON.reviver));}return r}async savePresence(e,t){this.assertOpen();let r=await this.ensureReady();await this.runWrite(()=>r.set(this.presenceKey(e),JSON.stringify(t,BufferJSON.replacer),{EX:ka}));}async getPresence(e){this.assertOpen();let t=await this.ensureReady(),r=await this.runRead(()=>t.get(this.presenceKey(e)));if(r!=null)return JSON.parse(r,BufferJSON.reviver)}bind(e){if(this.assertOpen(),this.boundSocket&&this.boundSocket.ev.off)for(let[o,a]of this.listeners)this.boundSocket.ev.off(o,a);this.listeners.clear(),this.boundSocket=e;let t=(...o)=>{let c=o[0]?.messages;if(Array.isArray(c))for(let d of c)this.saveMessage(d).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){this.assertOpen();let e=await this.ensureReady(),t=`${this.namespace}:*`,r=0;do{let s=await this.runRead(()=>e.scan(r,{MATCH:t,COUNT:Bs}));r=Number(s.cursor),s.keys.length>0&&await this.runWrite(()=>e.del(s.keys));}while(r!==0)}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);if(this.listeners.clear(),this.boundSocket=void 0,this.ownedClient){try{await this.ownedClient.quit();}catch{}this.ownedClient=void 0;}this.ready=void 0;}}async deleteMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.remoteJid??"",s=gn(e),i=t.multi();i.zRem(this.msgIndexKey(r),s),i.hDel(this.msgDataKey(r),s),await this.runWrite(()=>i.exec());}async pruneMessages(e){this.assertOpen();let t=await this.ensureReady(),r=0,s=[],i=this.msgIndexKey("*"),o=0,a=this.msgDataKey("");do{let c=await this.runRead(()=>t.scan(o,{MATCH:i,COUNT:Bs}));o=Number(c.cursor);for(let d of c.keys)d.startsWith(a)||s.push(d);}while(o!==0);for(let c of s){let d=this.jidFromIndexKey(c);if(e.chatFilter&&!e.chatFilter(d))continue;let l=this.msgDataKey(d),u=new Set;if(e.olderThan!==void 0){let v=await this.runRead(()=>t.zRangeByScore(c,"-inf",`(${e.olderThan}`));for(let C of v)u.add(C);}if(e.maxPerChat!==void 0){let v=e.maxPerChat,C=await this.runRead(()=>t.zRange(c,0,-(v+1)));for(let y of C)u.add(y);}if(u.size===0)continue;let w=[...u],S=t.multi();S.zRem(c,w),S.hDel(l,w),await this.runWrite(()=>S.exec()),r+=w.length;}return r}jidFromIndexKey(e){let t=this.msgIndexKey("");return e.startsWith(t)?e.slice(t.length):e}msgIndexKey(e){return `${this.namespace}:msg:${e}`}msgDataKey(e){return `${this.namespace}:msg-data:${e}`}chatsKey(){return `${this.namespace}:chats`}chatsArchiveKey(){return `${this.namespace}:chats-archived`}contactsKey(){return `${this.namespace}:contacts`}presenceKey(e){return `${this.namespace}:presence:${e}`}async ensureReady(){return this.ready||(this.ready=this.connect()),this.ready}async connect(){if(this.externalClient){if(!this.externalClient.isOpen)throw new f("STORE_CONNECTION_FAILED","provided redis client is not open (call await client.connect() first)");return this.externalClient}let e;try{e=await import('redis');}catch(r){throw Ta(r)?new f("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new f("STORE_CONNECTION_FAILED","failed to load redis module",{cause:r})}let t=e.createClient({url:this.url});try{await t.connect();}catch(r){throw new f("STORE_CONNECTION_FAILED",`failed to connect to redis at ${this.url}`,{cause:r})}return this.ownedClient=t,t}async runRead(e){try{return await e()}catch(t){throw new f("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new f("STORE_WRITE_FAILED","redis write failed",{cause:t})}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","RedisMessageStore is closed")}};var _t="msg:",Lt="chat:",Nt="contact:",fn="presence:",hn="job:",Oa=n=>`${n.id??""}|${n.fromMe?1:0}`,Dt=n=>`${_t}${n.remoteJid??""}:${Oa(n)}`,Qe=n=>JSON.stringify(n,BufferJSON.replacer),Y=n=>JSON.parse(n,BufferJSON.reviver),Ws=class{kv;closed=false;boundSocket;listeners=new Map;constructor(e){this.kv=new ye(e);}async saveMessage(e){this.assertOpen(),await this.kv.set([{key:Dt(e.key),value:Qe(e),sortKey:Number(e.messageTimestamp??0)}]);}async getMessage(e){this.assertOpen();let r=(await this.kv.get([Dt(e)])).get(Dt(e));return r===void 0?void 0:Y(r)}async listMessages(e,t){this.assertOpen();let r={};return typeof t?.before=="number"&&(r.before=t.before),typeof t?.limit=="number"&&(r.limit=t.limit),(await this.kv.list(`${_t}${e}:`,r)).map(i=>Y(i.value))}async saveChat(e){this.assertOpen();let t=e.id;t&&await this.kv.set([{key:`${Lt}${t}`,value:Qe(e)}]);}async getChat(e){this.assertOpen();let r=(await this.kv.get([`${Lt}${e}`])).get(`${Lt}${e}`);return r===void 0?void 0:Y(r)}async listChats(e){this.assertOpen();let t=await this.kv.list(Lt),r=[];for(let s of t){let i=Y(s.value),o=i.archived===true;e?.archived===true&&!o||e?.archived===false&&o||r.push(i);}return r}async saveContact(e){this.assertOpen(),await this.kv.set([{key:`${Nt}${e.id}`,value:Qe(e)}]);}async getContact(e){this.assertOpen();let r=(await this.kv.get([`${Nt}${e}`])).get(`${Nt}${e}`);return r===void 0?void 0:Y(r)}async listContacts(){return this.assertOpen(),(await this.kv.list(Nt)).map(t=>Y(t.value))}async savePresence(e,t){this.assertOpen(),await this.kv.set([{key:`${fn}${e}`,value:Qe(t)}]);}async getPresence(e){this.assertOpen();let r=(await this.kv.get([`${fn}${e}`])).get(`${fn}${e}`);return r===void 0?void 0:Y(r)}async saveScheduledJob(e){this.assertOpen(),await this.kv.set([{key:`${hn}${e.id}`,value:Qe(e),sortKey:e.fireAt}]);}async listScheduledJobs(){return this.assertOpen(),(await this.kv.list(hn)).map(t=>Y(t.value))}async deleteScheduledJob(e){this.assertOpen(),await this.kv.del([`${hn}${e}`]);}async deleteMessage(e){this.assertOpen(),await this.kv.del([Dt(e)]);}async pruneMessages(e){this.assertOpen();let t=await this.kv.list(_t,{}),r=new Map;for(let i of t){let o=i.key.slice(_t.length),a=o.slice(0,o.indexOf(":"));if(e.chatFilter&&!e.chatFilter(a))continue;let c=r.get(a)??[];c.push({key:i.key,ts:i.sortKey??0}),r.set(a,c);}let s=[];for(let i of r.values()){i.sort((o,a)=>a.ts-o.ts);for(let o=0;o<i.length;o++){let a=i[o];(e.olderThan!==void 0&&a.ts<e.olderThan||e.maxPerChat!==void 0&&o>=e.maxPerChat)&&s.push(a.key);}}return s.length>0&&await this.kv.del(s),s.length}bind(e){if(this.assertOpen(),this.boundSocket?.ev.off)for(let[o,a]of this.listeners)this.boundSocket.ev.off(o,a);this.listeners.clear(),this.boundSocket=e;let t=(...o)=>{let a=o[0]?.messages;if(Array.isArray(a))for(let c of a)this.saveMessage(c).catch(()=>{});},r=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveChat(c).catch(()=>{});},s=(...o)=>{let a=o[0];if(Array.isArray(a))for(let c of a)this.saveContact(c).catch(()=>{});},i=(...o)=>{let a=o[0];if(a?.presences)for(let c of Object.keys(a.presences)){let d=a.presences[c];d&&this.savePresence(c,d).catch(()=>{});}};this.listeners.set("messages.upsert",t),this.listeners.set("chats.upsert",r),this.listeners.set("contacts.upsert",s),this.listeners.set("presence.update",i);for(let[o,a]of this.listeners)e.ev.on(o,a);}async clear(){this.assertOpen(),await this.kv.clear();}async close(){if(!this.closed){if(this.closed=true,this.boundSocket?.ev.off)for(let[e,t]of this.listeners)this.boundSocket.ev.off(e,t);this.listeners.clear(),this.boundSocket=void 0,this.kv.close();}}assertOpen(){if(this.closed)throw new f("STORE_CLOSED","ConvexMessageStore is closed")}};var Ia=(n,e)=>{if(e<=0)throw new RangeError("chunk size must be positive");let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t};var Tg=n=>{let t=(n.split("@")[0]??"").split(":")[0]?.replace(/\D/g,"")??"";return n.endsWith("@s.whatsapp.net")||n.endsWith("@c.us")?t:""},Og=n=>`${n.replace(/\D/g,"")}@s.whatsapp.net`;export{Q as AudioProcessor,Fe as AutoDeleteSweeper,b as BufferConverter,xe as BusinessModule,Oe as ChatModule,Cs as Client,Re as CommandRegistry,ke as CommunityModule,Ie as ContactModule,Ls as ConvexAuthStore,Ws as ConvexMessageStore,st as DocumentProcessor,Ae as EditBuilder,P as FFMPEG_CONSTANTS,Z as FFmpegProcessor,ut as FileAuthStore,$ as FileManager,Ce as GroupModule,F as ImageProcessor,ee as Media,Es as MemoryAuthStore,ft as MemoryMessageStore,V as MessageBuilder,R as MimeValidator,be as NewsletterModule,xs as PostgresAuthStore,_s as PostgresMessageStore,_e as PresenceModule,Ee as PrivacyModule,Te as ProfileModule,ne as RateLimiter,Rs as RedisAuthStore,Fs as RedisMessageStore,mp as SELF_ONLY_PROTOCOL_TYPES,Be as Scheduler,Is as SqliteAuthStore,Ns as SqliteMessageStore,rt as StickerProcessor,De as TaskQueue,Pt as TypedEventEmitter,U as VideoProcessor,O as ZaileysAutomationError,g as ZaileysBuilderError,x as ZaileysCommandError,k as ZaileysDomainError,f as ZaileysStoreError,cn as adoptLogger,nn as attachCommandDispatcher,un as buildMessageContext,Ia as chunk,Vr as computeStaticId,Gr as computeUniqueId,wr as createAuthGuard,Ar as createConnectionStateMachine,lo as createLogger,on as createOperationGuard,vr as createPairingFlow,Sr as createReconnectStrategy,ar as definePlugin,Yt as deleteMessage,L as detectFileType,kn as detectMimeFromBuffer,Cr as dropSpoofedSelfOnly,Hr as epochSecondsToMs,Jr as extractLinks,j as ffmpegTransform,Xt as forwardMessage,et as generateId,lr as genericPrune,Ut as initializeFFmpeg,Ue as isFatalDisconnect,Pe as isJid,ht as isLidJid,Lr as isPnJid,pt as isRateLimited,Tg as jidToPhone,I as loadMedia,gr as makeCacheableAuthStore,hr as mapDisconnectReason,ge as normalizeJid,to as normalizePhoneNumber,en as parseCommand,Og as phoneToJid,dt as pinMessage,Mr as printQrToTerminal,Zt as reactToMessage,so as renderQrInTerminal,Qt as resolveUsername,an as runBroadcast,tn as runMiddleware,zr as senderDeviceOf,yr as shouldClearAuth,ep as shouldReconnect,fr as signalKeyStoreFromAuthStore,no as validateE164};