zaileys 4.2.1 → 4.3.0

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.cjs CHANGED
@@ -1,20 +1,20 @@
1
- 'use strict';var lo=require('baileys'),ue=require('node:fs/promises'),url=require('node:url'),os$1=require('node:os'),Ee=require('node:path'),child_process=require('node:child_process'),jimp=require('jimp'),ps=require('node-webpmux'),crypto=require('node:crypto'),fs$1=require('node:fs'),ui=require('qrcode-terminal'),fi=require('pino');require('node:stream');var events=require('node:events');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var lo__default=/*#__PURE__*/_interopDefault(lo);var ue__default=/*#__PURE__*/_interopDefault(ue);var Ee__default=/*#__PURE__*/_interopDefault(Ee);var ps__default=/*#__PURE__*/_interopDefault(ps);var ui__default=/*#__PURE__*/_interopDefault(ui);var fi__default=/*#__PURE__*/_interopDefault(fi);var ns=(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 S={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"}},rn="ffmpeg",sn="ffprobe",tn=false,bt=async(n=false)=>{if(!(n||tn)){tn=true;try{let e=(await import('@ffmpeg-installer/ffmpeg')).default;if(e?.path){rn=e.path;let t=Ee__default.default.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&&(sn=e.path);}catch{}}},We=()=>Date.now().toString(36)+Math.random().toString(36).slice(2,8),k=async n=>{let{fileTypeFromBuffer:e}=await import('file-type');return e(n)},q=class{static generateUniqueId(){return `${Date.now()}_${Math.random().toString(36).slice(2,11)}`}static createTempPath(e,t){return Ee__default.default.join(os$1.tmpdir(),`${e}_${this.generateUniqueId()}.${t}`)}static async cleanup(e){await Promise.allSettled(e.map(t=>ue__default.default.unlink(t)));}static async safeReadFile(e){try{return await ue__default.default.readFile(e)}catch{throw new Error(`Failed to read file: ${e}`)}}static async safeWriteFile(e,t){try{await ue__default.default.writeFile(e,t);}catch{throw new Error(`Failed to write file: ${e}`)}}},M=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 ue__default.default.stat(e).then(t=>t.isFile()).catch(()=>!1))return await ue__default.default.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"}},P=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(S.MIME.IMAGE)||e.startsWith(S.MIME.VIDEO)}static isAnimated(e){return e===S.MIME.GIF||e.startsWith(S.MIME.VIDEO)}},H=class{static async process(e){return await bt(),new Promise((t,r)=>{let s=["-y","-i",e.input,...e.options,e.output],i=child_process.spawn(rn,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=child_process.spawn(sn,["-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 os=3e4,on="application/octet-stream",as=async n=>n.byteLength===0?on:(await k(n))?.mime??on,pe=async n=>({buffer:n,mime:await as(n),size:n.byteLength}),an=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);}},cn=async n=>{try{return await ue.readFile(n)}catch(e){throw new f("MEDIA_LOAD_FAILED",`read ${n} failed: ${e.message}`,{cause:e})}},cs=n=>n.startsWith("http://")||n.startsWith("https://"),I=async(n,e)=>{await bt();let t=os;return Buffer.isBuffer(n)?pe(n):n instanceof URL?n.protocol==="file:"?pe(await cn(url.fileURLToPath(n))):pe(await an(n.toString(),t)):cs(n)?pe(await an(n,t)):pe(await cn(n))};var re=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 se=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),s};var dn=2,ln=30,ds=async n=>{if(n.type==="image")return re(n.src,n.caption!==void 0?{caption:n.caption}:void 0);if(n.type==="video")return se(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)}`)},un=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>ln)throw new f("INVALID_OPTIONS",`album() accepts a maximum of ${ln} items`);let s=0,i=0;for(let l of t)if(l.type==="image")s+=1;else if(l.type==="video")i+=1;else throw new f("INVALID_OPTIONS",`album() item type must be 'image' or 'video', got ${String(l.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(l){throw new f("SEND_FAILED","album parent send rejected",{cause:l})}let d=c?.key;if(!d)throw new f("SEND_FAILED","album parent returned no message key");let u=0;for(let l of t){let y=await ds(l);y.albumParentKey=d;try{await n.sendMessage(e,y);}catch(p){throw new f("SEND_FAILED","album child send rejected",{cause:{parentKey:d,index:u,error:p}})}u+=1;}return d};var B=async(n,e,t,r,s)=>{let i=r.replace(/[^a-z0-9]+/gi,"_").toLowerCase(),o=q.createTempPath(`${i}_in`,e),a=q.createTempPath(`${i}_out`,t);await q.safeWriteFile(o,n);try{let c=typeof s=="function"?await s(o):s;return await H.process({input:o,output:a,options:c,onEnd:async()=>{},onError:async()=>{}}),await q.safeReadFile(a)}catch(c){throw new Error(`${r} failed: ${c instanceof Error?c.message:String(c)}`)}finally{await q.cleanup([o,a]);}};var Ue=64,pn=8e3,z=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 M.toBuffer(e);P.validate(await k(r),S.MIME.AUDIO);let s=await M.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 B(r,s,t==="opus"?"ogg":"mp3",`${t.toUpperCase()} conversion`,i)}static async waveform(e){let t=await M.toBuffer(e),r=await M.getExtension(t),s=await B(t,r,"tmp","Waveform generation",["-vn","-ac","1","-ar",String(pn),"-f","s16le"]),i=Math.floor(s.length/2);return {waveform:this.computeWaveform(s),seconds:Math.max(1,Math.round(i/pn))}}static computeWaveform(e){let t=Math.floor(e.length/2),r=new Uint8Array(Ue);if(t===0)return r;let s=Math.max(1,Math.floor(t/Ue)),i=[];for(let a=0;a<Ue;a++){let c=0,d=0;for(let u=0;u<s;u++){let l=(a*s+u)*2;l+1<e.length&&(c+=Math.abs(e.readInt16LE(l)),d+=1);}i.push(d>0?c/d:0);}let o=Math.max(...i)||1;for(let a=0;a<Ue;a++)r[a]=Math.floor(i[a]/o*100);return r}};var ls=["-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"],F=class{static async toMp4(e){let t=await M.toBuffer(e);P.validate(await k(t),S.MIME.VIDEO);let r=await M.getExtension(t);return B(t,r,"mp4","Video re-encoding",ls)}static async thumbnail(e){let t=await M.toBuffer(e);P.validate(await k(t),S.MIME.VIDEO);let r=await M.getExtension(t),s=S.THUMBNAIL.SIZE;return (await B(t,r,"jpg","Thumbnail generation",async o=>{let a=await H.getDuration(o);return ["-ss",Math.max(0,a*.1).toString(),"-vframes","1","-s",`${s}x${s}`]})).toString("base64")}static async duration(e){return H.getDuration(e)}};var ie=null,mn=false;async function us(){if(mn)return ie;mn=true;let n=e=>{typeof e=="function"&&(ie=e);};try{n(ns("sharp"));}catch{ie=null;}if(!ie)try{let e=await import('sharp');n(e.default??e);}catch{ie=null;}return ie}function fn(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 u=c-r,l=a-s;d=u*u+l*l<=r*r;}else if(e==="rounded"){let u=c>=i&&c<n-i&&a>=0&&a<n,l=c>=0&&c<n&&a>=i&&a<n-i,y=false;for(let p of o){let g=c-p[0],w=a-p[1];if(g*g+w*w<=i*i){y=true;break}}d=u||l||y;}else if(e==="oval"){let u=(c-r)/(n/2),l=(a-s)/(n/3);d=u*u+l*l<=1;}t[a*n+c]=d?255:0;}return t}var Tt=class{sharp;constructor(e){this.sharp=e;}async thumbnail(e){let t=this.sharp,r=t(e).resize(S.THUMBNAIL.SIZE,S.THUMBNAIL.SIZE,{fit:"cover"});return (await r.metadata()).format==="gif"&&(r=t(e,{pages:1}).resize(S.THUMBNAIL.SIZE,S.THUMBNAIL.SIZE)),(await r.jpeg({quality:S.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 M.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=S.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(fn(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()}},Pt=class{async thumbnail(e){let t=S.THUMBNAIL.SIZE,r=await jimp.Jimp.fromBuffer(e);r.cover({w:t,h:t});let s=await r.getBuffer("image/jpeg",{quality:S.THUMBNAIL.QUALITY});return Buffer.from(s).toString("base64")}async resize(e,t,r){let s=await jimp.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 M.toBuffer(e);try{let s=await(await jimp.Jimp.fromBuffer(t)).getBuffer("image/jpeg");return Buffer.from(s)}catch{return t}}async resizeForSticker(e,t,r="default"){let s=S.STICKER.SIZE,i=await jimp.Jimp.fromBuffer(e);if(i.contain({w:s,h:s}),r!=="default"){let c=fn(s,r),d=new jimp.Jimp({width:s,height:s,color:255});for(let u=0;u<s;u++)for(let l=0;l<s;l++)c[u*s+l]===255&&d.setPixelColor(4294967295,l,u);i.mask(d);}let o=Buffer.from(await i.getBuffer("image/png")),a=Math.max(1,Math.min(100,t));return B(o,"png","webp","Jimp WebP conversion",["-vcodec","libwebp","-q:v",`${a}`,"-preset","default"])}},fe=null;async function je(){if(fe)return fe;let n=await us();return n?fe=new Tt(n):(console.warn("\x1B[33m%s\x1B[0m","[media-process] Jimp is slow. For faster performance, run: npm install sharp"),fe=new Pt),fe}var N=class{static async thumbnail(e){return (await je()).thumbnail(e)}static async resize(e,t,r){return (await je()).resize(e,t,r)}static async toJpeg(e){return (await je()).toJpeg(e)}static async resizeForSticker(e,t,r="default"){return (await je()).resizeForSticker(e,t,r)}};var Ke=class{static async create(e,t){try{let r=await M.toBuffer(e),s=await k(r);if(!s)throw new Error("Unable to detect file type");let i=t?.quality||S.STICKER.DEFAULT_QUALITY,o=P.isAnimated(s.mime),a=t?.shape||"default",c=s.mime==="image/webp"?r:o?await this.processAnimated(r,s.mime,i):await N.resizeForSticker(r,i,a),d=this.createExifMetadata(t),u=new ps__default.default.Image;await u.load(c),u.exif=d;let l=await u.save(null);return Buffer.isBuffer(l)?l:Buffer.from(l)}catch(r){throw new Error(`Sticker creation failed: ${r instanceof Error?r.message:String(r)}`)}}static createExifMetadata(e){let t={"sticker-pack-id":We(),"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=S.STICKER.SIZE,i=S.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 B(e,this.getExtension(t),"webp","Animated sticker processing",async c=>{let d=S.STICKER.MAX_DURATION;try{d=Math.min(await F.duration(c),S.STICKER.MAX_DURATION);}catch{console.warn("Using default duration:",S.STICKER.MAX_DURATION);}return ["-vcodec libwebp",`-vf ${o}`,`-q:v ${a}`,"-loop 0","-preset default","-an","-vsync 0",`-t ${d}`,`-compression_level ${S.STICKER.COMPRESSION_LEVEL}`]})}static getExtension(e){return e===S.MIME.GIF?"gif":e.startsWith(S.MIME.VIDEO)?"mp4":"tmp"}};var qe=class{static async create(e){try{let t=await M.toBuffer(e),r=await k(t);if(!r)throw new Error("Unable to detect file type");let s;return r.mime.startsWith(S.MIME.VIDEO)?s=await F.thumbnail(t):P.isMedia(r.mime)?s=await N.thumbnail(t):s="",{document:t,mimetype:r.mime,ext:r.ext,fileName:We(),jpegThumbnail:s}}catch(t){throw new Error(`Document creation failed: ${t instanceof Error?t.message:String(t)}`)}}};var Y=class{input;constructor(e){this.input=e;}get audio(){return {toOpus:()=>z.toOpus(this.input),toMp3:()=>z.toMp3(this.input),convert:(e="opus")=>z.convert(this.input,e),waveform:()=>z.waveform(this.input)}}get video(){return {toMp4:()=>F.toMp4(this.input),thumbnail:()=>F.thumbnail(this.input)}}get image(){return {toJpeg:()=>N.toJpeg(this.input),thumbnail:async()=>{let e=await M.toBuffer(this.input);return N.thumbnail(e)},resize:async(e,t)=>{let r=await M.toBuffer(this.input);return N.resize(r,e,t)}}}get sticker(){return {create:e=>Ke.create(this.input,e)}}get document(){return {create:()=>qe.create(this.input)}}get thumbnail(){return {get:async()=>{let e=await M.toBuffer(this.input),t=await k(e);if(!t||!P.isMedia(t.mime))throw new Error("Invalid media type: expected image or video");return t.mime.startsWith(S.MIME.VIDEO)?F.thumbnail(this.input):N.thumbnail(e)}}}async toBuffer(){return M.toBuffer(this.input)}};var gn=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new Y(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 Y(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 hn=10,_="__zaileysRelayMessage",kt="__zaileysHeaderMedia",J=n=>typeof n=="string"&&n.length>0,ms=n=>{let e=n.text;if(!J(e)||e.trim().length===0)throw new f("INVALID_OPTIONS","button text must be a non-empty string");return e},fs=(n,e)=>{let t=n.type??"reply";if(t==="location"){let s=n.text;return {name:"send_location",buttonParamsJson:JSON.stringify(J(s)?{display_text:s}:{})}}let r=ms(n);if(t==="reply"){let s=n.id;if(!J(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(!J(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(!J(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(!J(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:J(s)?s:r})}}if(t==="address"){let s=n.id;return {name:"address_message",buttonParamsJson:JSON.stringify({display_text:r,id:J(s)?s:r})}}throw new f("INVALID_OPTIONS",`unknown button type: ${String(t)}`)},gs=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):""},It=n=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","buttons() requires at least one button");if(n.length>hn)throw new f("INVALID_OPTIONS",`buttons() accepts at most ${hn} buttons`);let e=new Set;return n.map(t=>fs(t,e))},Je=(n,e)=>{let t=It(n),r={body:{text:e?.text&&e.text.length>0?e.text:" "},nativeFlowMessage:{buttons:t,messageParamsJson:gs(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},[kt]:s}:{[_]:{interactiveMessage:r}}};var yn=10,Ot="__zaileysCardsMedia",wn=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","carousel() requires at least one card");if(n.length>yn)throw new f("INVALID_OPTIONS",`carousel() accepts at most ${yn} 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:It(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},[Ot]:t}:{[_]:{interactiveMessage:s}}};var ys=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 u=n[c+1],l=u==="("?")":">",y=u==="<",p=c+2,g=1;for(;p<n.length&&g>0;)n[p]===u&&n[p-1]!=="\\"?g++:n[p]===l&&n[p-1]!=="\\"&&g--,p++;if(g>0)continue;let w=n.slice(d+1,c).trim(),C=n.slice(c+2,p-1).trim(),A,K;if(y){let[Fe="",vt="",St="",Mt="",At=""]=w.split("|").map(Ct=>Ct.trim());A=`zaileys_LATEX_${o++}`,K=`{{${A}}}${Fe||"image"}{{/${A}}}`,e.push({type:"latex",ie:{key:A,text:Fe,url:C,width:vt,height:St,font_height:Mt,padding:At}});}else w?(A=`zaileys_HYPERLINK_${i++}`,K=`{{${A}}}${C}{{/${A}}}`,e.push({type:"hyperlink",ie:{key:A,text:w,url:C}})):(A=`zaileys_CITATION_${s-1}`,K=`{{${A}}}${C}{{/${A}}}`,e.push({type:"citation",ie:{key:A,reference_id:String(s++),url:C}}));t+=n.slice(r,d)+K,r=p,c=p-1;}return t+=n.slice(r),{text:t,ie:e}},ws=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"}}),vs=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)}))]},Ss={0:"DEFAULT",1:"KEYWORD",2:"METHOD",3:"STR",4:"NUMBER",5:"COMMENT"},$e=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"]),Ms={javascript:$e,js:$e,typescript:$e,ts:$e},As=(n,e)=>{let t=Ms[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 u=i;for(;u<n.length&&/\s/.test(n[u]);)u++;n[u]==="("&&(d=2);}s(c,d);continue}s(o,0),i++;}return r},O=(n,e)=>({view_model:{[Array.isArray(e)?"primitives":"primitive"]:e,__typename:`GenAI${n}LayoutViewModel`}}),Cs="https://github.com/zeative/zaileys",vn=(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=ys(o.text),c=ws(a);r.push({messageType:2,messageText:a.text}),t.push(O("Single",{text:a.text,...c.length>0?{inline_entities:c}:{},__typename:"GenAIMarkdownTextUXPrimitive"}));}else if(o.type==="code"){let a=o.language??"plaintext",c=As(o.content,a);r.push({messageType:5,codeMetadata:{codeLanguage:a,codeBlocks:c}}),t.push(O("Single",{language:a,code_blocks:c.map(d=>({content:d.codeContent,type:Ss[d.highlightType]})),__typename:"GenAICodeUXPrimitive"}));}else if(o.type==="table"){let a=vs(o.rows);r.push({messageType:4,tableMetadata:{title:"",rows:a.map(c=>({items:c.cells,...c.is_header?{isHeading:true}:{}}))}}),t.push(O("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:Cs}))}});for(let c of a)t.push(O("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(O("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(u=>({title:u.title,brand:u.brand??"",price:u.price??"",sale_price:u.salePrice??"",product_url:u.url??"",image:{url:u.image??""},additional_images:[{url:u.icon??""}],__typename:"GenAIProductItemCardPrimitive"}));t.push(a?O("HScroll",d):O("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(O("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(O("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(O("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(O("ActionRow",a.map(c=>({prompt_text:c,prompt_type:"SUGGESTED_PROMPT",__typename:"GenAIFollowUpSuggestionPillPrimitive"}))));}e?.footer&&e.footer.length>0&&t.push(O("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:crypto.randomUUID(),sections:t})).toString("base64")},contextInfo:{forwardingScore:1,isForwarded:true,forwardedAiBotMessageInfo:{botJid:"0@bot"},forwardOrigin:4}}}}};return {[_]:i}};var Es=/^:::([a-zA-Z]+)\s*$/,bs=/^:::\s*$/,Sn=/^```(\w*)\s*$/,Mn=/^!\[[^\]]*\]\(([^)]+)\)\s*$/,Ts=/^\s*\|?\s*:?-{2,}[\s|:-]*$/,Ve=n=>n.split("|").map(e=>e.trim()),xt=n=>{let e={};for(let t of Ve(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},Z=n=>{if(n===void 0||n.trim().length===0)return;let e=Number(n);return Number.isNaN(e)?void 0:e},Cn=n=>n==="true"||n==="1"||n==="yes",An=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())},Ps=n=>{let e=xt(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},ks=n=>{let e=xt(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=Z(e.likes);r!==void 0&&(t.likes=r);let s=Z(e.shares);s!==void 0&&(t.shares=s);let i=Z(e.views);return i!==void 0&&(t.views=i),e.source&&(t.source=e.source),"verified"in e&&(t.verified=Cn(e.verified)),t},Is=n=>{let e=xt(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=Z(e.likes);r!==void 0&&(t.likes=r);let s=Z(e.comments);s!==void 0&&(t.comments=s);let i=Z(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=Cn(e.verified)),t},Os=(n,e)=>{let t=e.map(r=>r.replace(/^[-*]\s*/,"").trim()).filter(r=>r.length>0);if(n==="suggest"){let r=t.flatMap(s=>Ve(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=>Ve(o)[0]??"").filter(o=>o.length>0);if(r.length===0)return null;let s=Z(Ve(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(Ps).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(ks);return r.length>0?{type:"reels",reels:r}:null}if(n==="post"){let r=t.map(Is);return r.length>0?{type:"post",posts:r}:null}return null},En=n=>{let e=n.replace(/\r\n/g,`
1
+ 'use strict';var No=require('baileys'),fe=require('node:fs/promises'),url=require('node:url'),os$1=require('node:os'),Te=require('node:path'),child_process=require('node:child_process'),jimp=require('jimp'),bs=require('node-webpmux'),crypto=require('node:crypto'),fs=require('node:fs'),Ei=require('qrcode-terminal'),Ti=require('pino');require('node:stream');var events=require('node:events');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var No__default=/*#__PURE__*/_interopDefault(No);var fe__default=/*#__PURE__*/_interopDefault(fe);var Te__default=/*#__PURE__*/_interopDefault(Te);var bs__default=/*#__PURE__*/_interopDefault(bs);var Ei__default=/*#__PURE__*/_interopDefault(Ei);var Ti__default=/*#__PURE__*/_interopDefault(Ti);var gs=(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 M={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"}},dn="ffmpeg",ln="ffprobe",an=false,Ot=async(n=false)=>{if(!(n||an)){an=true;try{let e=(await import('@ffmpeg-installer/ffmpeg')).default;if(e?.path){dn=e.path;let t=Te__default.default.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&&(ln=e.path);}catch{}}},Ke=()=>Date.now().toString(36)+Math.random().toString(36).slice(2,8),I=async n=>{let{fileTypeFromBuffer:e}=await import('file-type');return e(n)},J=class{static generateUniqueId(){return `${Date.now()}_${Math.random().toString(36).slice(2,11)}`}static createTempPath(e,t){return Te__default.default.join(os$1.tmpdir(),`${e}_${this.generateUniqueId()}.${t}`)}static async cleanup(e){await Promise.allSettled(e.map(t=>fe__default.default.unlink(t)));}static async safeReadFile(e){try{return await fe__default.default.readFile(e)}catch{throw new Error(`Failed to read file: ${e}`)}}static async safeWriteFile(e,t){try{await fe__default.default.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 fe__default.default.stat(e).then(t=>t.isFile()).catch(()=>!1))return await fe__default.default.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"}},k=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(M.MIME.IMAGE)||e.startsWith(M.MIME.VIDEO)}static isAnimated(e){return e===M.MIME.GIF||e.startsWith(M.MIME.VIDEO)}},z=class{static async process(e){return await Ot(),new Promise((t,r)=>{let s=["-y","-i",e.input,...e.options,e.output],i=child_process.spawn(dn,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=child_process.spawn(ln,["-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 vs=3e4,un="application/octet-stream",Ss=async n=>n.byteLength===0?un:(await I(n))?.mime??un,ge=async n=>({buffer:n,mime:await Ss(n),size:n.byteLength}),pn=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);}},mn=async n=>{try{return await fe.readFile(n)}catch(e){throw new f("MEDIA_LOAD_FAILED",`read ${n} failed: ${e.message}`,{cause:e})}},Ms=n=>n.startsWith("http://")||n.startsWith("https://"),O=async(n,e)=>{await Ot();let t=vs;return Buffer.isBuffer(n)?ge(n):n instanceof URL?n.protocol==="file:"?ge(await mn(url.fileURLToPath(n))):ge(await pn(n.toString(),t)):Ms(n)?ge(await pn(n,t)):ge(await mn(n))};var oe=async(n,e)=>{let{buffer:t}=await O(n),r={image:t};return e?.caption!==void 0&&(r.caption=e.caption),e?.viewOnce!==void 0&&(r.viewOnce=e.viewOnce),r};var ae=async(n,e)=>{let{buffer:t,mime:r}=await O(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),s};var fn=2,gn=30,As=async n=>{if(n.type==="image")return oe(n.src,n.caption!==void 0?{caption:n.caption}:void 0);if(n.type==="video")return ae(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)}`)},hn=async(n,e,t,r)=>{if(!Array.isArray(t)||t.length<fn)throw new f("INVALID_OPTIONS",`album() requires a minimum of ${fn} items`);if(t.length>gn)throw new f("INVALID_OPTIONS",`album() accepts a maximum of ${gn} 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 p=await As(u);p.albumParentKey=d;try{await n.sendMessage(e,p);}catch(v){throw new f("SEND_FAILED","album child send rejected",{cause:{parentKey:d,index:l,error:v}})}l+=1;}return d};var W=async(n,e,t,r,s)=>{let i=r.replace(/[^a-z0-9]+/gi,"_").toLowerCase(),o=J.createTempPath(`${i}_in`,e),a=J.createTempPath(`${i}_out`,t);await J.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 J.safeReadFile(a)}catch(c){throw new Error(`${r} failed: ${c instanceof Error?c.message:String(c)}`)}finally{await J.cleanup([o,a]);}};var qe=64,yn=8e3,Y=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);k.validate(await I(r),M.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 W(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 W(t,r,"tmp","Waveform generation",["-vn","-ac","1","-ar",String(yn),"-f","s16le"]),i=Math.floor(s.length/2);return {waveform:this.computeWaveform(s),seconds:Math.max(1,Math.round(i/yn))}}static computeWaveform(e){let t=Math.floor(e.length/2),r=new Uint8Array(qe);if(t===0)return r;let s=Math.max(1,Math.floor(t/qe)),i=[];for(let a=0;a<qe;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<qe;a++)r[a]=Math.floor(i[a]/o*100);return r}};var Cs=["-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 C.toBuffer(e);k.validate(await I(t),M.MIME.VIDEO);let r=await C.getExtension(t);return W(t,r,"mp4","Video re-encoding",Cs)}static async thumbnail(e){let t=await C.toBuffer(e);k.validate(await I(t),M.MIME.VIDEO);let r=await C.getExtension(t),s=M.THUMBNAIL.SIZE;return (await W(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 ce=null,wn=false;async function Es(){if(wn)return ce;wn=true;let n=e=>{typeof e=="function"&&(ce=e);};try{n(gs("sharp"));}catch{ce=null;}if(!ce)try{let e=await import('sharp');n(e.default??e);}catch{ce=null;}return ce}function vn(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,p=false;for(let v of o){let g=c-v[0],w=a-v[1];if(g*g+w*w<=i*i){p=true;break}}d=l||u||p;}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 xt=class{sharp;constructor(e){this.sharp=e;}async thumbnail(e){let t=this.sharp,r=t(e).resize(M.THUMBNAIL.SIZE,M.THUMBNAIL.SIZE,{fit:"cover"});return (await r.metadata()).format==="gif"&&(r=t(e,{pages:1}).resize(M.THUMBNAIL.SIZE,M.THUMBNAIL.SIZE)),(await r.jpeg({quality:M.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=M.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(vn(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()}},Rt=class{async thumbnail(e){let t=M.THUMBNAIL.SIZE,r=await jimp.Jimp.fromBuffer(e);r.cover({w:t,h:t});let s=await r.getBuffer("image/jpeg",{quality:M.THUMBNAIL.QUALITY});return Buffer.from(s).toString("base64")}async resize(e,t,r){let s=await jimp.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.Jimp.fromBuffer(t)).getBuffer("image/jpeg");return Buffer.from(s)}catch{return t}}async resizeForSticker(e,t,r="default"){let s=M.STICKER.SIZE,i=await jimp.Jimp.fromBuffer(e);if(i.contain({w:s,h:s}),r!=="default"){let c=vn(s,r),d=new jimp.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 W(o,"png","webp","Jimp WebP conversion",["-vcodec","libwebp","-q:v",`${a}`,"-preset","default"])}},ye=null;async function Je(){if(ye)return ye;let n=await Es();return n?ye=new xt(n):(console.warn("\x1B[33m%s\x1B[0m","[media-process] Jimp is slow. For faster performance, run: npm install sharp"),ye=new Rt),ye}var D=class{static async thumbnail(e){return (await Je()).thumbnail(e)}static async resize(e,t,r){return (await Je()).resize(e,t,r)}static async toJpeg(e){return (await Je()).toJpeg(e)}static async resizeForSticker(e,t,r="default"){return (await Je()).resizeForSticker(e,t,r)}};var $e=class{static async create(e,t){try{let r=await C.toBuffer(e),s=await I(r);if(!s)throw new Error("Unable to detect file type");let i=t?.quality||M.STICKER.DEFAULT_QUALITY,o=k.isAnimated(s.mime),a=t?.shape||"default",c=s.mime==="image/webp"?r:o?await this.processAnimated(r,s.mime,i):await D.resizeForSticker(r,i,a),d=this.createExifMetadata(t),l=new bs__default.default.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":Ke(),"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=M.STICKER.SIZE,i=M.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 W(e,this.getExtension(t),"webp","Animated sticker processing",async c=>{let d=M.STICKER.MAX_DURATION;try{d=Math.min(await U.duration(c),M.STICKER.MAX_DURATION);}catch{console.warn("Using default duration:",M.STICKER.MAX_DURATION);}return ["-vcodec libwebp",`-vf ${o}`,`-q:v ${a}`,"-loop 0","-preset default","-an","-vsync 0",`-t ${d}`,`-compression_level ${M.STICKER.COMPRESSION_LEVEL}`]})}static getExtension(e){return e===M.MIME.GIF?"gif":e.startsWith(M.MIME.VIDEO)?"mp4":"tmp"}};var Ve=class{static async create(e){try{let t=await C.toBuffer(e),r=await I(t);if(!r)throw new Error("Unable to detect file type");let s;return r.mime.startsWith(M.MIME.VIDEO)?s=await U.thumbnail(t):k.isMedia(r.mime)?s=await D.thumbnail(t):s="",{document:t,mimetype:r.mime,ext:r.ext,fileName:Ke(),jpegThumbnail:s}}catch(t){throw new Error(`Document creation failed: ${t instanceof Error?t.message:String(t)}`)}}};var Z=class{input;constructor(e){this.input=e;}get audio(){return {toOpus:()=>Y.toOpus(this.input),toMp3:()=>Y.toMp3(this.input),convert:(e="opus")=>Y.convert(this.input,e),waveform:()=>Y.waveform(this.input)}}get video(){return {toMp4:()=>U.toMp4(this.input),thumbnail:()=>U.thumbnail(this.input)}}get image(){return {toJpeg:()=>D.toJpeg(this.input),thumbnail:async()=>{let e=await C.toBuffer(this.input);return D.thumbnail(e)},resize:async(e,t)=>{let r=await C.toBuffer(this.input);return D.resize(r,e,t)}}}get sticker(){return {create:e=>$e.create(this.input,e)}}get document(){return {create:()=>Ve.create(this.input)}}get thumbnail(){return {get:async()=>{let e=await C.toBuffer(this.input),t=await I(e);if(!t||!k.isMedia(t.mime))throw new Error("Invalid media type: expected image or video");return t.mime.startsWith(M.MIME.VIDEO)?U.thumbnail(this.input):D.thumbnail(e)}}}async toBuffer(){return C.toBuffer(this.input)}};var Sn=async(n,e)=>{let{buffer:t}=await O(n),r;try{r=await new Z(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 Z(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 Mn=10,B="__zaileysRelayMessage",Lt="__zaileysHeaderMedia",$=n=>typeof n=="string"&&n.length>0,Ps=n=>{let e=n.text;if(!$(e)||e.trim().length===0)throw new f("INVALID_OPTIONS","button text must be a non-empty string");return e},Ts=(n,e)=>{let t=n.type??"reply";if(t==="location"){let s=n.text;return {name:"send_location",buttonParamsJson:JSON.stringify($(s)?{display_text:s}:{})}}let r=Ps(n);if(t==="reply"){let s=n.id;if(!$(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(!$(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(!$(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(!$(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:$(s)?s:r})}}if(t==="address"){let s=n.id;return {name:"address_message",buttonParamsJson:JSON.stringify({display_text:r,id:$(s)?s:r})}}throw new f("INVALID_OPTIONS",`unknown button type: ${String(t)}`)},ks=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):""},Nt=n=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","buttons() requires at least one button");if(n.length>Mn)throw new f("INVALID_OPTIONS",`buttons() accepts at most ${Mn} buttons`);let e=new Set;return n.map(t=>Ts(t,e))},Ge=(n,e)=>{let t=Nt(n),r={body:{text:e?.text&&e.text.length>0?e.text:" "},nativeFlowMessage:{buttons:t,messageParamsJson:ks(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?{[B]:{interactiveMessage:r},[Lt]:s}:{[B]:{interactiveMessage:r}}};var An=10,_t="__zaileysCardsMedia",Cn=(n,e)=>{if(!Array.isArray(n)||n.length===0)throw new f("INVALID_OPTIONS","carousel() requires at least one card");if(n.length>An)throw new f("INVALID_OPTIONS",`carousel() accepts at most ${An} 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:Nt(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?{[B]:{interactiveMessage:s},[_t]:t}:{[B]:{interactiveMessage:s}}};var Os=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==="("?")":">",p=l==="<",v=c+2,g=1;for(;v<n.length&&g>0;)n[v]===l&&n[v-1]!=="\\"?g++:n[v]===u&&n[v-1]!=="\\"&&g--,v++;if(g>0)continue;let w=n.slice(d+1,c).trim(),y=n.slice(c+2,v-1).trim(),A,E;if(p){let[_="",Et="",bt="",Pt="",Tt=""]=w.split("|").map(kt=>kt.trim());A=`zaileys_LATEX_${o++}`,E=`{{${A}}}${_||"image"}{{/${A}}}`,e.push({type:"latex",ie:{key:A,text:_,url:y,width:Et,height:bt,font_height:Pt,padding:Tt}});}else w?(A=`zaileys_HYPERLINK_${i++}`,E=`{{${A}}}${y}{{/${A}}}`,e.push({type:"hyperlink",ie:{key:A,text:w,url:y}})):(A=`zaileys_CITATION_${s-1}`,E=`{{${A}}}${y}{{/${A}}}`,e.push({type:"citation",ie:{key:A,reference_id:String(s++),url:y}}));t+=n.slice(r,d)+E,r=v,c=v-1;}return t+=n.slice(r),{text:t,ie:e}},xs=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"}}),Rs=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)}))]},Ls={0:"DEFAULT",1:"KEYWORD",2:"METHOD",3:"STR",4:"NUMBER",5:"COMMENT"},He=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"]),Ns={javascript:He,js:He,typescript:He,ts:He},_s=(n,e)=>{let t=Ns[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},x=(n,e)=>({view_model:{[Array.isArray(e)?"primitives":"primitive"]:e,__typename:`GenAI${n}LayoutViewModel`}}),Ds="https://github.com/zeative/zaileys",En=(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=Os(o.text),c=xs(a);r.push({messageType:2,messageText:a.text}),t.push(x("Single",{text:a.text,...c.length>0?{inline_entities:c}:{},__typename:"GenAIMarkdownTextUXPrimitive"}));}else if(o.type==="code"){let a=o.language??"plaintext",c=_s(o.content,a);r.push({messageType:5,codeMetadata:{codeLanguage:a,codeBlocks:c}}),t.push(x("Single",{language:a,code_blocks:c.map(d=>({content:d.codeContent,type:Ls[d.highlightType]})),__typename:"GenAICodeUXPrimitive"}));}else if(o.type==="table"){let a=Rs(o.rows);r.push({messageType:4,tableMetadata:{title:"",rows:a.map(c=>({items:c.cells,...c.is_header?{isHeading:true}:{}}))}}),t.push(x("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:Ds}))}});for(let c of a)t.push(x("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(x("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?x("HScroll",d):x("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(x("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(x("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(x("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(x("ActionRow",a.map(c=>({prompt_text:c,prompt_type:"SUGGESTED_PROMPT",__typename:"GenAIFollowUpSuggestionPillPrimitive"}))));}e?.footer&&e.footer.length>0&&t.push(x("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:crypto.randomUUID(),sections:t})).toString("base64")},contextInfo:{forwardingScore:1,isForwarded:true,forwardedAiBotMessageInfo:{botJid:"0@bot"},forwardOrigin:4}}}}};return {[B]:i}};var Bs=/^:::([a-zA-Z]+)\s*$/,Fs=/^:::\s*$/,bn=/^```(\w*)\s*$/,Pn=/^!\[[^\]]*\]\(([^)]+)\)\s*$/,Ws=/^\s*\|?\s*:?-{2,}[\s|:-]*$/,ze=n=>n.split("|").map(e=>e.trim()),Dt=n=>{let e={};for(let t of ze(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},X=n=>{if(n===void 0||n.trim().length===0)return;let e=Number(n);return Number.isNaN(e)?void 0:e},kn=n=>n==="true"||n==="1"||n==="yes",Tn=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())},Us=n=>{let e=Dt(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},js=n=>{let e=Dt(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=X(e.likes);r!==void 0&&(t.likes=r);let s=X(e.shares);s!==void 0&&(t.shares=s);let i=X(e.views);return i!==void 0&&(t.views=i),e.source&&(t.source=e.source),"verified"in e&&(t.verified=kn(e.verified)),t},Ks=n=>{let e=Dt(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=X(e.likes);r!==void 0&&(t.likes=r);let s=X(e.comments);s!==void 0&&(t.comments=s);let i=X(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=kn(e.verified)),t},qs=(n,e)=>{let t=e.map(r=>r.replace(/^[-*]\s*/,"").trim()).filter(r=>r.length>0);if(n==="suggest"){let r=t.flatMap(s=>ze(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=>ze(o)[0]??"").filter(o=>o.length>0);if(r.length===0)return null;let s=X(ze(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(Us).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(js);return r.length>0?{type:"reels",reels:r}:null}if(n==="post"){let r=t.map(Ks);return r.length>0?{type:"post",posts:r}:null}return null},In=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=Es.exec(o);if(a){s();let l=[];for(i++;i<e.length&&!bs.test(e[i]);)l.push(e[i]),i++;i++;let y=Os(a[1].toLowerCase(),l);y&&t.push(y);continue}let c=Sn.exec(o);if(c){s();let l=[];for(i++;i<e.length&&!Sn.test(e[i]);)l.push(e[i]),i++;i++;let y=c[1]&&c[1].length>0?c[1]:void 0;t.push(y?{type:"code",language:y,content:l.join(`
7
- `)}:{type:"code",content:l.join(`
8
- `)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&Ts.test(d)){s();let l=[An(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)l.push(An(e[i])),i++;t.push({type:"table",rows:l});continue}let u=Mn.exec(o);if(u){s();let l=[u[1]];for(i++;i<e.length;){let y=Mn.exec(e[i]);if(!y)break;l.push(y[1]),i++;}t.push({type:"image",url:l.length===1?l[0]:l});continue}r.push(o),i++;}return s(),t};var bn=(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 Tn=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 Pn=10,kn=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>Pn)throw new f("INVALID_OPTIONS",`list() accepts at most ${Pn} 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 In=(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 On=2,xn=12,Rn=(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<On)throw new f("INVALID_OPTIONS",`poll() requires a minimum of ${On} options`);if(e.length>xn)throw new f("INVALID_OPTIONS",`poll() accepts a maximum of ${xn} 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 Ln=async(n,e)=>{let{buffer:t}=await I(n),r;try{r=await new Y(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 Nn=3,_n=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>Nn)throw new f("INVALID_OPTIONS",`template() accepts at most ${Nn} buttons`);let t={text:`${n.header&&n.header.length>0?`*${n.header}*
6
+ `).trim();o.length>0&&t.push({type:"text",text:o}),r=[];},i=0;for(;i<e.length;){let o=e[i],a=Bs.exec(o);if(a){s();let u=[];for(i++;i<e.length&&!Fs.test(e[i]);)u.push(e[i]),i++;i++;let p=qs(a[1].toLowerCase(),u);p&&t.push(p);continue}let c=bn.exec(o);if(c){s();let u=[];for(i++;i<e.length&&!bn.test(e[i]);)u.push(e[i]),i++;i++;let p=c[1]&&c[1].length>0?c[1]:void 0;t.push(p?{type:"code",language:p,content:u.join(`
7
+ `)}:{type:"code",content:u.join(`
8
+ `)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&Ws.test(d)){s();let u=[Tn(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)u.push(Tn(e[i])),i++;t.push({type:"table",rows:u});continue}let l=Pn.exec(o);if(l){s();let u=[l[1]];for(i++;i<e.length;){let p=Pn.exec(e[i]);if(!p)break;u.push(p[1]),i++;}t.push({type:"image",url:u.length===1?u[0]:u});continue}r.push(o),i++;}return s(),t};var On=(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 xn=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 O(n),s={document:t,fileName:e.fileName,mimetype:e.mimetype??r};return e.caption!==void 0&&(s.caption=e.caption),s};var Rn=10,Ln=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>Rn)throw new f("INVALID_OPTIONS",`list() accepts at most ${Rn} 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}),{[B]:{interactiveMessage:i}}};var Nn=(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 _n=2,Dn=12,Bn=(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<_n)throw new f("INVALID_OPTIONS",`poll() requires a minimum of ${_n} options`);if(e.length>Dn)throw new f("INVALID_OPTIONS",`poll() accepts a maximum of ${Dn} 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 Fn=async(n,e)=>{let{buffer:t}=await O(n),r;try{r=await new Z(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 Wn=3,Un=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>Wn)throw new f("INVALID_OPTIONS",`template() accepts at most ${Wn} 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),Je(n.buttons,t)};var Ge=n=>{if(typeof n!="string"||n.trim().length===0)throw new f("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var Dn=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var Ls=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],$=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r,s){return new n(e,Dn(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=vn(En(e),t):this.internal.content=Ge(e),this}image(e,t){return this.internal.pendingContent=re(e,t),this}video(e,t){return this.internal.pendingContent=se(e,t),this}audio(e,t){return this.internal.pendingContent=gn(e,t),this}document(e,t){return this.internal.pendingContent=Tn(e,t),this}sticker(e,t){return this.internal.pendingContent=Ln(e,t),this}buttons(e,t){return this.internal.content=Je(e,t),this}carousel(e,t){return this.internal.content=wn(e,t),this}list(e){return this.internal.content=kn(e),this}poll(e,t,r){return this.internal.content=Rn(e,t,r),this}location(e,t,r){return this.internal.content=In(e,t,r),this}contact(e){return this.internal.content=bn(e),this}template(e){return this.internal.content=_n(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),un(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[kt],u=s[Ot];return this.sendRelay(i,d,u)}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 lo.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 l=e.interactiveMessage?.header;t!==void 0&&l&&await this.uploadHeaderMedia(l,t);let y=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&y)for(let p of r){let g=y[p.index]?.header;g&&await this.uploadHeaderMedia(g,p);}}catch(l){throw new f("SEND_FAILED","interactive media upload failed",{cause:l})}let o={userJid:this.socket.user?.id??""},a=this.internal.quoted;a!==void 0&&a.message!=null&&(o.quoted=a);let c=lo.generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new f("SEND_FAILED","failed to generate relay message key");let u="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:Ls}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,u);}catch(l){throw new f("SEND_FAILED","socket relayMessage rejected",{cause:l})}return this.internal.recordSent?.(c),c.key}};var ge=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Ge(e),this}image(e,t){return this.pendingContent=re(e,t),this}video(e,t){return this.pendingContent=se(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 Bn=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new f("INVALID_OPTIONS","message key is missing remoteJid");return e},Fn=n=>{if(!n?.key)throw new f("SEND_FAILED","socket returned no message key");return n.key},Rt=async(n,e,t={})=>{let r=Bn(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);},Lt=async(n,e,t)=>{let r=Bn(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return Fn(s)},Nt=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 Fn(i)};var Ns=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,He=n=>Ns.test(n),_t=async(n,e,t,r=_s)=>{if(He(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);}},_s=new Map;var T=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 he=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 T("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new T("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 T("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);}};var ye=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 we=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 T("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);}};var ve=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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))}};var b=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 Ds=n=>{let e=n[0];return e==="{"||e==="["},Bs=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Fs=n=>n===" "||n===" "||n===`
11
- `||n==="\r",Ws=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(Fs(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},Us=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},js=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function Dt(n,e){let t=Us(n,e);if(t===null)return js(n);let r=n.slice(t.length),s=Ws(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 u=d.indexOf("=");if(u!==-1){let y=d.slice(0,u),p=d.slice(u+1);i.flags[y]=p;continue}let l=s[a+1];l!==void 0&&!l.startsWith("--")?(i.flags[d]=l,a+=1):i.flags[d]=true;continue}if(!o&&Ds(c)){let d=Bs(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var Ks=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new b("INVALID_COMMAND_NAME","empty command segment in spec");return e},ze=n=>n.join(" "),Se=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new b("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>Ks(a)),s=r[0],i=r.slice(1).map(a=>ze(a)),o={name:ze(s),aliases:i,parts:s,handler:t};for(let a of r){let c=ze(a);if(this.paths.has(c))throw new b("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(ze(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)}}}list(){return [...this.defs]}};async function Bt(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new b("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 b?c:new b("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function Ft(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=Dt(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(Bt(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let u=d instanceof b?d:new b("HANDLER_ERROR","command handler failed",{cause:d});n.logger.error(u,"command dispatch failed");});},t=n.onText(e),r=false;return {detach(){r||(r=true,t());}}}var E=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 qs=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),X=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new E("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new E("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new E("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??qs;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 Js={"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},$s=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function Wt(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??$s,i={...Js,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,u)=>{let l=i[d]??0,y=o.get(d);if(y!==void 0&&l>0){let p=l-(r()-y);p>0&&await s(p);}return o.set(d,r()),u()};return {run(d,u){if(!t)return u();let y=(a.get(d)??Promise.resolve()).then(()=>c(d,u),()=>c(d,u));return a.set(d,y.then(()=>{},()=>{})),y}}}var Vs={maxRetries:0,backoffMs:()=>0},Gs=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Me=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??Vs,this.sleep=t.sleep??Gs;}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 Hs=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function Ut(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 X({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},u=c?new Me({concurrency:1,retry:c},d):void 0,l=n.length,y=0;for(let p of n){await a.acquire(p);let g=()=>e(t.sendTo(p)).then(()=>{});try{u?await u.add(g):await g(),s.sent.push(p),y+=1,r.onProgress?.(y,l,p,!0);}catch(w){s.failed.push({jid:p,error:Hs(w)}),y+=1,r.onProgress?.(y,l,p,false);}}return s}var zs=1e3,Ae=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??zs,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new E("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 E("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 Zs={set:(n,e)=>setTimeout(n,e),clear:n=>clearTimeout(n)},Xs=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",Ce=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??Zs,this.logger=e.logger,this.acquire=e.acquire;}async scheduleAt(e,t){let r=e.getTime();if(Number.isNaN(r))throw new E("SCHEDULE_INVALID","scheduleAt requires a valid Date");let s=await this.evaluate(t),i=crypto.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),Xs(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 E("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 E("SCHEDULE_INVALID","scheduling interactive/relayed content is not supported; schedule a text or media message")}},i=$.create(s,"");try{await e(i);}catch(o){throw o instanceof E?o:new E("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new E("SCHEDULE_INVALID","scheduled builder produced no content");return t}};var Q="[zaileys]",Qs="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 Un(n){switch(n.kind){case "connecting":return `${Q} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${Q} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${Q} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${Q} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${Q} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
12
- ${Q} ${Qs}`:t}case "disconnect":return n.willReconnect?null:`${Q} Disconnected (${n.reason}).`;default:return null}}var Wn=false,ei=["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:"],ti=n=>typeof n[0]=="string"&&ei.some(e=>n[0].startsWith(e));function jn(){if(Wn)return;Wn=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{ti(r)||t(...r);};};n("info"),n("warn"),n("error");}var m=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 ri="./.zaileys/auth",si=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),be=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",Ze=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??ri;}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 fs$1.promises.readFile(i,"utf8");r[s]=JSON.parse(o,lo.BufferJSON.reviver);}catch(o){if(be(o))return;throw new m("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 fs$1.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(fs$1.promises.unlink(c).catch(d=>{if(!be(d))throw new m("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,lo.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 fs$1.promises.unlink(s);}catch(i){if(!be(i))throw new m("STORE_WRITE_FAILED",`failed to unlink ${s}`,{cause:i})}}));},clear:async()=>{this.assertOpen(),await fs$1.promises.rm(this.basePath,{recursive:true,force:true});},close:async()=>{this.closed=true;}};creds={readCreds:async()=>{this.assertOpen();try{let e=await fs$1.promises.readFile(this.credsPath(),"utf8");return JSON.parse(e,lo.BufferJSON.reviver)}catch(e){if(be(e))return;throw new m("STORE_READ_FAILED","failed to read creds.json",{cause:e})}},writeCreds:async e=>{this.assertOpen(),await fs$1.promises.mkdir(this.basePath,{recursive:true}),await this.atomicWrite(this.credsPath(),JSON.stringify(e,lo.BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await fs$1.promises.unlink(this.credsPath());}catch(e){if(!be(e))throw new m("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return Ee__default.default.join(this.basePath,"creds.json")}signalDir(e){return Ee__default.default.join(this.basePath,"signal",String(e))}signalPath(e,t){return Ee__default.default.join(this.signalDir(e),`${si(t)}.json`)}async atomicWrite(e,t){let r=Ee__default.default.join(Ee__default.default.dirname(e),`tmp-${crypto.randomBytes(8).toString("hex")}`);try{await fs$1.promises.writeFile(r,t,"utf8"),await fs$1.promises.rename(r,e);}catch(s){throw await fs$1.promises.unlink(r).catch(()=>{}),new m("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","FileAuthStore is closed")}};function Kn(n,e){let t=n.signal,s=lo.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 u of a)d[u]=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 qn(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 oi=429;function Jn(n){if(n===oi)return "rate-limited";switch(n){case lo.DisconnectReason.loggedOut:return "logged-out";case lo.DisconnectReason.forbidden:return "forbidden";case lo.DisconnectReason.connectionLost:return "connection-lost";case lo.DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case lo.DisconnectReason.connectionClosed:return "connection-closed";case lo.DisconnectReason.connectionReplaced:return "connection-replaced";case lo.DisconnectReason.badSession:return "bad-session";case lo.DisconnectReason.unavailableService:return "unavailable-service";case lo.DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Te(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function Xe(n){return n==="rate-limited"}function $n(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function Al(n){return !Te(n)}var Qe={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},ai=3e5;function Vn(n={}){let e=n.enabled??Qe.enabled,t=n.maxQrAttempts??Qe.maxQrAttempts,r=n.maxPairingAttempts??Qe.maxPairingAttempts,s=n.pairingCooldownMs??Qe.pairingCooldownMs,i=0,o=0,a=0,c=y=>y<=0?0:Math.min(s*y,ai);return {evaluate:(y,p)=>{if(!e)return {allowed:true,waitMs:0,attempts:y==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(y==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let g=c(o),w=p-a;return o>0&&w<g?{allowed:false,reason:"cooldown",waitMs:g-w,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:(y,p)=>{y==="pairing"?(o+=1,a=p):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var ci=/[\s\-()+]/g;function di(n){return typeof n!="string"?"":n.replace(ci,"")}function li(n){if(!n||typeof n!="string"||!n.trim())throw new Error("phoneNumber is required");let e=di(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 Gn(n){let e=li(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 pi(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{ui__default.default.generate(n,{small:true},t=>e(t));})}async function Hn(n,e=t=>{process.stdout.write(t);}){let t=await pi(n);e(t+`
13
- `);}var oe={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function zn(n,e){let t=n?.enabled??oe.enabled,r=n?.maxAttempts??oe.maxAttempts,s=n?.initialDelayMs??oe.initialDelayMs,i=n?.maxDelayMs??oe.maxDelayMs,o=n?.jitterFactor??oe.jitterFactor,a=n?.rateLimitedDelayMs??oe.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:y=>{if(!t||Te(y))return null;let p=d+1;if(p>r)return null;if(d=p,Xe(y))return {attempt:p,delayMs:a};let g=Math.pow(2,p-1),w=Math.min(i,s*g),C=1+(c()*2-1)*o,A=w*C,K=Math.min(i,Math.max(0,A));return {attempt:p,delayMs:Math.round(K)}},reset:()=>{d=0;},get attempts(){return d}}}var mi={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 Yn(n="idle"){let e=n,t=new Set,r=s=>mi[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 jt=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,et=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=jt(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(jt(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 u=c[0]?.messages;if(Array.isArray(u))for(let l of u)this.saveMessage(l).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d){let l=this.messages.get(jt(u.key));if(l){let y={...l,...u.update};this.saveMessage(y).catch(()=>{});}}},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.saveChat(u).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d){let y={...this.chats.get(u.id)??{},...u};this.saveChat(y).catch(()=>{});}},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.saveContact(u).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let u of Object.keys(d.presences)){let l=d.presences[u];l&&this.savePresence(u,l).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(){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 m("STORE_CLOSED","MemoryMessageStore is closed")}};var gi=["silent","fatal","error","warn","info","debug","trace"];function hi(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":gi.includes(e)?e:"silent"}function yi(n={}){let e=hi(n.level),t=fi__default.default({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var Zn=["debug","info","warn","error","fatal"];function wi(n){if(n===null||typeof n!="object")return false;for(let e of Zn)if(typeof n[e]!="function")return false;return true}function Pe(){}function vi(n){let e={debug:Pe,info:Pe,warn:Pe,error:Pe,fatal:Pe};for(let t of Zn){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function Kt(n,e){return n===void 0?e??yi():wi(n)?n:vi(n)}var _l=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),Xn=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 Si=new Set(["offer","ringing"]),Mi=new Set(["timeout","reject","accept","terminate"]),Qn=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},er=n=>typeof n.id!="string"||n.id.length===0||!Si.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Qn(n.date),status:n.status},tr=n=>typeof n.id!="string"||n.id.length===0||!Mi.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:Qn(n.date),status:n.status};var x=n=>typeof n=="string"&&n.length>0,Ai=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},nr=(n,e,t)=>n.filter(r=>x(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return x(i)&&(s.participantAlt=i),x(e)&&(s.authorPn=e),x(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),rr=n=>x(n?.id)?{groupId:n.id,update:Ai(n),timestamp:Date.now()}:null,sr=n=>{if(!x(n?.groupId)||!x(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 x(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},Ci=new Set(["add","invite","invite-link"]),Ei=new Set(["remove","leave"]),ir=n=>{if(!x(n?.id)||!Ci.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=nr(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 x(n.author)&&(t.by=n.author),t},or=n=>{if(!x(n?.id)||!Ei.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=nr(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 x(n.author)&&(t.by=n.author),t};var ke=n=>typeof n!="string"||n.length===0?null:lo.jidNormalizedUser(n),V=n=>typeof n=="string"&&n.length>0?n:void 0,Pi=["@s.whatsapp.net","@c.us"],ki=n=>n.endsWith("@lid"),Ii=n=>Pi.some(e=>n.endsWith(e)),W=(n,e)=>{if(!n)return null;let t=V(n.participant)??n.remoteJid,r=ke(t);if(r===null)return null;let s=V(n.participantAlt)??V(n.remoteJidAlt),i=s!=null?ke(s):null,o=V(n.participantUsername)??V(n.remoteJidUsername),a={jid:r,isMe:n.fromMe===true},c=i!==null?[r,i]:[r],d=c.find(ki),u=c.find(Ii);d!==void 0&&(a.lid=d),u!==void 0&&(a.pn=u),o!==void 0&&(a.username=o);let l=V(e);return l!==void 0&&(a.pushName=l),a},ar=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=V(n.participant),r=V(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=W(s);return o&&(i.sender=o),i},tt=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 Ie=n=>lo.isJidGroup(n)===true,ae=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 Oi=["quick_reply","cta_url","cta_call","button_click"],xi=["list_select","single_select"],j=n=>typeof n=="string"&&n.length>0,dr=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return W(n.key,e)},lr=n=>ae(n.messageTimestamp)??0,ur=(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}},nt=(n,e)=>{for(let t of e){let r=n[t];if(j(r))return r}},pr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&j(r.selectedButtonId))return qt(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&j(s.selectedId))return qt(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&j(i.name)&&Oi.includes(i.name)){let o=ur(i.paramsJson,e.logger);if(!o)return null;let a=nt(o,["id","button_id"]);return a===void 0?null:qt(n,a,nt(o,["display_text"])??null)}return null},qt=(n,e,t)=>{let r=dr(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:lr(n)};return j(t)&&(s.buttonText=t),s},mr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(j(s))return cr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&j(i.name)&&xi.includes(i.name)){let o=ur(i.paramsJson,e.logger);if(!o)return null;let a=nt(o,["row_id","id"]);return a===void 0?null:cr(n,a,nt(o,["title"])??null)}return null},cr=(n,e,t)=>{let r=dr(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:lr(n)};return j(t)&&(s.title=t),s};var Ri=new Set(["available","unavailable","composing","recording","paused"]),Li=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,fr=n=>n.status!=="complete"&&n.status!=="paused"?null:{syncType:String(n.syncType),status:n.status,explicit:n.explicit===true},Jt=n=>{if(n.source==="connection-update"){let t=n.reachoutTimeLock;return t.isActive!==true?null:{reason:"reachout-timelock",retryAt:Li(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},gr=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"||!Ri.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},Oe=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 _i=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},Di=n=>{let e=`${n.remoteJid??""}|${n.id??""}|${n.fromMe===true?"1":"0"}`,t=2166136261;for(let r=0;r<e.length;r++)t^=e.charCodeAt(r),t=Math.imul(t,16777619)>>>0;return t.toString(16).padStart(8,"0")},Bi=n=>{let e=lo.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"},Fi=n=>n.trim().endsWith("?"),Wi=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),Ui=(n,e)=>{if(e.length===0)return false;let t;try{t=lo.jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return lo.jidNormalizedUser(r)===t}catch{return r===n}})},ji=(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)}},$t=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&Ie(e),r={uniqueId:Di(n.key),channelId:n.channelId,chatId:n.key.id??"",chatType:n.chatType,receiverId:n.receiverId,roomId:t?e:null,senderId:n.sender.pn??n.sender.jid,senderLid:n.sender.lid??null,senderName:n.sender.pushName??null,senderDevice:Bi(n.sender.jid),timestamp:typeof n.message.messageTimestamp=="number"?n.message.messageTimestamp*1e3:0,text:n.text,mentions:n.mentions,links:_i(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:Fi(n.text),isPrefix:Wi(n.text,n.prefixes),isTagMe:Ui(n.selfJid,n.mentions),isEdited:false,isDeleted:false,isPinned:false,isUnPinned:false,isBot:false,isSpam:false,isHideTags:false,isStatusMention:false,isGroupStatusMention:false,isStory:false,roomName:n.resolveRoomName,receiverName:n.resolveReceiverName,replied:n.resolveReplied,reply:n.reply,react:n.react,message:()=>n.message,citation:ji(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(r.media=n.media),r};var Ki={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},qi=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Ki[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=qi(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")}},wr=(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 it={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},vr=n=>{let e=n?.remoteJid;return typeof e=="string"&&e.length>0?e:""},h=n=>n!=null&&typeof n=="object"?n:null,v=n=>typeof n=="string"&&n.length>0?n:null,de=(...n)=>{for(let e of n){let t=v(e);if(t!=null)return t}return null},Ji=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage"],Re=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of Ji){let i=h(h(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},$i=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=v(h(o)?.messageText);a!=null&&s.push(a);}let i=s.join(`
14
- `).trim();return i.length>0?i:null},Vi=n=>{let e=h(n.templateMessage),t=h(e?.hydratedTemplate)??h(e?.hydratedFourRowTemplate);return v(t?.hydratedContentText)},Gi=n=>de(h(n.pollCreationMessage)?.name,h(n.pollCreationMessageV2)?.name,h(n.pollCreationMessageV3)?.name),Hi=n=>{let e=h(n.locationMessage)??h(n.liveLocationMessage);if(e==null)return null;let t=de(e.name,e.address);if(t!=null){let i=v(e.name),o=v(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},zi=n=>{let e=v(h(n.contactMessage)?.displayName);if(e!=null)return e;let t=h(n.contactsArrayMessage),r=v(t?.displayName);if(r!=null)return r;let s=t?.contacts;if(Array.isArray(s)){let i=s.map(o=>v(h(o)?.displayName)).filter(o=>o!=null);if(i.length>0)return i.join(", ")}return null},Sr=n=>de(n.conversation,h(n.extendedTextMessage)?.text,$i(n),v(h(h(n.interactiveMessage)?.body)?.text),h(n.buttonsMessage)?.contentText,h(n.listMessage)?.description,Vi(n),Gi(n),Hi(n),zi(n)),Yi=n=>de(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),Zi=n=>de(h(n.imageMessage)?.caption,h(n.videoMessage)?.caption,h(n.documentMessage)?.caption,h(n.documentMessage)?.fileName),R=n=>{if(typeof n=="number")return n;let e=ae(n);return typeof e=="number"?e:null},Xi=[["pollCreationMessage","poll"],["pollCreationMessageV2","poll"],["pollCreationMessageV3","poll"],["contactMessage","contact"],["contactsArrayMessage","contact"],["locationMessage","location"],["liveLocationMessage","live-location"],["eventMessage","event"],["buttonsMessage","buttons"],["listMessage","list"],["interactiveMessage","interactive"],["templateMessage","template"]],Vt=n=>{let e=h(n.pollCreationMessage)??h(n.pollCreationMessageV2)??h(n.pollCreationMessageV3);if(e!=null){let l=Array.isArray(e.options)?e.options:[];return {type:"poll",name:v(e.name),options:l.map(y=>v(h(y)?.optionName)).filter(y=>y!=null),selectableCount:R(e.selectableOptionsCount)??0}}let t=h(n.contactMessage);if(t!=null)return {type:"contact",displayName:v(t.displayName),vcard:v(t.vcard),contacts:[{displayName:v(t.displayName),vcard:v(t.vcard)}]};let r=h(n.contactsArrayMessage);if(r!=null){let l=Array.isArray(r.contacts)?r.contacts:[];return {type:"contact",displayName:v(r.displayName),vcard:null,contacts:l.map(y=>({displayName:v(h(y)?.displayName),vcard:v(h(y)?.vcard)}))}}let s=h(n.locationMessage);if(s!=null)return {type:"location",latitude:R(s.degreesLatitude),longitude:R(s.degreesLongitude),name:v(s.name),address:v(s.address),accuracy:R(s.accuracyInMeters),speed:R(s.speedInMps),caption:v(s.comment)};let i=h(n.liveLocationMessage);if(i!=null)return {type:"live-location",latitude:R(i.degreesLatitude),longitude:R(i.degreesLongitude),name:null,address:null,accuracy:R(i.accuracyInMeters),speed:R(i.speedInMps),caption:v(i.caption)};let o=h(n.eventMessage);if(o!=null){let l=h(o.location);return {type:"event",name:v(o.name),description:v(o.description),location:l!=null?de(l.name,l.address):null,startTime:R(o.startTime),endTime:R(o.endTime),isCanceled:o.isCanceled===true}}let a=h(n.buttonsMessage);if(a!=null){let l=Array.isArray(a.buttons)?a.buttons:[];return {type:"buttons",contentText:v(a.contentText),footerText:v(a.footerText),buttons:l.map(y=>({id:v(h(y)?.buttonId),text:v(h(h(y)?.buttonText)?.displayText)}))}}let c=h(n.listMessage);if(c!=null){let l=Array.isArray(c.sections)?c.sections:[];return {type:"list",title:v(c.title),description:v(c.description),buttonText:v(c.buttonText),sections:l.map(y=>{let p=Array.isArray(h(y)?.rows)?h(y).rows:[];return {title:v(h(y)?.title),rows:p.map(g=>({id:v(h(g)?.rowId),title:v(h(g)?.title),description:v(h(g)?.description)}))}})}}let d=h(n.interactiveMessage);if(d!=null){let l=h(d.nativeFlowMessage),y=Array.isArray(l?.buttons)?l.buttons:[];return {type:"interactive",title:v(h(d.header)?.title),body:v(h(d.body)?.text),footer:v(h(d.footer)?.text),buttons:y.map(p=>({name:v(h(p)?.name),params:v(h(p)?.buttonParamsJson)}))}}let u=h(n.templateMessage);if(u!=null){let l=h(u.hydratedTemplate)??h(u.hydratedFourRowTemplate),y=Array.isArray(l?.hydratedButtons)?l.hydratedButtons:[];return {type:"template",text:v(l?.hydratedContentText),buttons:y.map(p=>{let g=h(p),w=h(g?.quickReplyButton)??h(g?.urlButton)??h(g?.callButton);return {id:v(w?.id),text:v(w?.displayText)}})}}return null};var st=n=>{let e=h(n.message);if(e==null)return null;let t=Re(e);return Sr(t)??Yi(t)??Zi(t)},Gt=n=>{let e=n.message;if(e==null)return null;let t=e.extendedTextMessage?.contextInfo;if(t!=null)return t;for(let r of Object.values(it)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},Qi=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[it[e]];return r==null||typeof r!="object"?null:r},eo=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(it)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},to=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,xe=n=>{let e=h(n);if(e==null)return "text";let t=Re(e);for(let r of Object.values(it))if(t[r]!=null)return r.replace("Message","");for(let[r,s]of Xi)if(t[r]!=null)return s;return "text"},no=async(n,e,t)=>{try{if(n==null||n.quotedMessage==null)return null;let r=n.stanzaId;if(typeof r!="string"||r.length===0)return null;if(e.resolveQuoted!=null&&t.length>0){let u=await e.resolveQuoted(r,t);if(u!=null&&u.message!=null){let l=st(u)??"",y=ce(u,e,xe(u.message),l);if(y!==null)return y}}let s=ar(n);if(s===null||typeof s.key.id!="string"||s.key.id.length===0)return null;let i=s.key.remoteJid;if(typeof i!="string"||i.length===0)return null;let o=s.key.participant;typeof o=="string"&&e.selfJid.length>0&&lo.jidNormalizedUser(o)===lo.jidNormalizedUser(e.selfJid)&&(s.key.fromMe=!0);let a=n.quotedMessage,c=Object.assign({key:s.key,message:a??null},s.sender?.pushName!=null?{pushName:s.sender.pushName}:{}),d=st(c)??"";return ce(c,e,xe(a),d)}catch{return null}},ce=(n,e,t,r,s)=>{let i=n.key;if(i==null)return null;let o=W(i,n.pushName??void 0);if(o===null)return null;let a=vr(i);if(a.length===0)return null;let c=Gt(n),d=Ie(a),u=a.endsWith("@broadcast"),l=a.endsWith("@newsletter"),y=c?.isForwarded===true||(c?.forwardingScore??0)>0,p=eo(n),g=to(n,c),w=e.channelId??"",C=e.receiverId??"",A=e.prefixes??[],K=()=>d&&e.resolveRoomName!=null?e.resolveRoomName(a):Promise.resolve(null),Fe=e.resolveReceiverName??(()=>Promise.resolve(null)),vt=()=>no(c,e,a),St=a.length>0?a:o.pn??o.jid,Mt=(Et,ts)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(St,Et,ts,n),At=Et=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(i,Et),{mentionedJids:Ct}=tt(c),Xt={message:n,key:i,channelId:w,receiverId:C,selfJid:e.selfJid,text:r,chatType:t,sender:o,mentions:Ct,isViewOnce:p,isEphemeral:g,isForwarded:y,isBroadcast:u,isNewsletter:l,prefixes:A,resolveRoomName:K,resolveReceiverName:Fe,resolveReplied:vt,reply:Mt,react:At},Qt=s!==void 0?{...Xt,media:s}:Xt;return $t(e.citationConfig!==void 0?{...Qt,citationConfig:e.citationConfig}:Qt)},Mr=(n,e)=>{let t=h(n.message);if(t==null)return null;let r=Re(t),s=Sr(r),i=Vt(r)??void 0;return s===null&&i===void 0?null:ce(n,e,xe(n.message),s??"",i)},Le=(n,e,t)=>{let r=Qi(e,n);if(r===null)return null;let s=typeof r.caption=="string"?r.caption:"",i=n,o=yr(e,n,t.logger),a=wr(e,n,t.logger),c={type:n,mimetype:typeof r.mimetype=="string"?r.mimetype:null,caption:typeof r.caption=="string"?r.caption:null,fileName:typeof r.fileName=="string"?r.fileName:null,fileSize:R(r.fileLength),ptt:r.ptt===true,buffer:async()=>(await o()).buffer,stream:a};return ce(e,t,i,s,c)},Ar=(n,e)=>Le("image",n,e),Cr=(n,e)=>Le("video",n,e),Er=(n,e)=>Le("audio",n,e),br=(n,e)=>Le("document",n,e),Tr=(n,e)=>Le("sticker",n,e),ro=(n,e)=>{try{return lo.jidNormalizedUser(n)===lo.jidNormalizedUser(e)}catch{return n===e}},Pr=(n,e)=>{if(n.key==null)return null;let r=Gt(n),{mentionedJids:s}=tt(r);if(s.length===0||!s.some(u=>ro(u,e.selfJid)))return null;let o=h(n.message);if(o==null)return null;let a=st(n)??"",c=Vt(Re(o))??void 0,d=ce(n,e,xe(n.message),a,c);return d===null?null:{...d,mentionedJids:s,selfJid:e.selfJid}},kr=(n,e)=>{let t=n.key;if(t==null)return null;let r=vr(t);if(r.length===0||!Ie(r))return null;let{mentionAll:s}=tt(Gt(n));if(!s)return null;let i=h(n.message);if(i==null)return null;let o=st(n)??"",a=Vt(Re(i))??void 0,c=ce(n,e,xe(n.message),o,a);return c===null?null:{...c,isMentionAll:true,selfJid:e.selfJid}};var ee=(n,e)=>{let t=ae(n);return t===null?e:t},so=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 ""},io=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],Or=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=W(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:ee(t.senderTimestampMs,0)}},xr=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==lo.proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=W(n.key,e.pushName);return s===null?null:{key:r,newContent:so(t.editedMessage),editedAt:ee(n.update.messageTimestamp,0),sender:s}},Rr=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==lo.proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=W(n.key,e.pushName);if(s===null)return null;let i=ke(n.key.remoteJid),o=ke(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:ee(n.update.messageTimestamp,0)}},Lr=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=W(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:io(t.vote?.selectedOptions),voter:s,timestamp:ee(t.senderTimestampMs,ee(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:ee(r.senderTimestampMs,ee(n.update.messageTimestamp,0))}:null}return null};var ot=n=>Array.isArray(n)?n:[],oo=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function Nr(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?p=>{let g=s.get(p);if(g!==void 0)return g;let w=t.groupMetadata;if(w==null)return Promise.resolve(null);let C=w(p).then(A=>A?.subject??null).catch(()=>null);return s.set(p,C),C}:void 0,o={selfJid:t.selfJid,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=(p,g)=>{let w=(...C)=>{try{g(C[0]);}catch(A){t.logger?.warn(A,`inbound pipeline: handler for ${p} threw`);}};e.ev.on(p,w),r.push(()=>e.ev.off(p,w));},u=p=>{l(()=>Mr(p,o),g=>n.emit("text",g)),l(()=>Ar(p,o),g=>n.emit("image",g)),l(()=>Cr(p,o),g=>n.emit("video",g)),l(()=>Er(p,o),g=>n.emit("audio",g)),l(()=>br(p,o),g=>n.emit("document",g)),l(()=>Tr(p,o),g=>n.emit("sticker",g)),l(()=>Pr(p,o),g=>n.emit("mention",g)),l(()=>kr(p,o),g=>n.emit("mention-all",g)),l(()=>pr(p,a),g=>n.emit("button-click",g)),l(()=>mr(p,a),g=>n.emit("list-select",g));},l=(p,g)=>{let w;try{w=p();}catch(C){t.logger?.warn(C,"inbound pipeline: decoder threw");return}w!=null&&g(w);};d("messages.upsert",p=>{let g=Xn(p);for(let w of g.messages)t.ignoreMe===!0&&w.key?.fromMe===!0||u(w);}),d("messages.update",p=>{for(let g of ot(p))l(()=>xr(g,c),w=>n.emit("edit",w)),l(()=>Rr(g,c),w=>n.emit("delete",w)),l(()=>Lr(g,c),w=>n.emit("poll-vote",w));}),d("messages.reaction",p=>{for(let g of ot(p))l(()=>Or(g,c),w=>n.emit("reaction",w));}),d("groups.update",p=>{for(let g of ot(p))l(()=>rr(g),w=>n.emit("group-update",w));}),d("group-participants.update",p=>{let g=p;l(()=>ir(g),w=>n.emit("group-join",w)),l(()=>or(g),w=>n.emit("group-leave",w));}),d("group.member-tag.update",p=>{l(()=>sr(p),g=>n.emit("member-tag",g));}),d("call",p=>{for(let g of ot(p))l(()=>er(g),w=>n.emit("call-incoming",w)),l(()=>tr(g),w=>n.emit("call-ended",w));}),d("messaging-history.status",p=>{l(()=>fr(p),g=>n.emit("history-sync",g));}),d("presence.update",p=>{let g=(()=>{try{return gr(p)}catch(w){return t.logger?.warn(w,"inbound pipeline: decodePresence threw"),[]}})();for(let w of g)n.emit("presence",w);}),d("connection.update",p=>{let g=oo(p);g!==null&&l(()=>Jt({source:"connection-update",reachoutTimeLock:g}),w=>n.emit("limited",w));}),d("message-capping.update",p=>{l(()=>Jt({source:"message-capping",capInfo:p}),g=>n.emit("limited",g));}),d("newsletter.reaction",p=>{l(()=>Oe({source:"reaction",payload:p}),g=>n.emit("newsletter",g));}),d("newsletter.view",p=>{l(()=>Oe({source:"view",payload:p}),g=>n.emit("newsletter",g));}),d("newsletter-participants.update",p=>{l(()=>Oe({source:"participants",payload:p}),g=>n.emit("newsletter",g));}),d("newsletter-settings.update",p=>{l(()=>Oe({source:"settings",payload:p}),g=>n.emit("newsletter",g));});let y=false;return {detach(){if(!y){y=true;for(let p of r)p();r.length=0;}}}}var at=class{inner=new events.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=co,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},co=Symbol("zaileys.typed-ee.tag");var po="default",mo="qr",Dr=6e4,Br=class extends at{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=Yn();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;commandRegistry;commandMiddleware=[];commandPrefixes;citationConfig;ignoreMe;commandDispatcher;_presence;_scheduler;waVersion;versionWarming;constructor(e={}){super({logger:Kt(e.logger)}),this.sessionId=e.sessionId??po,this.logger=Kt(e.logger),this.authType=e.authType??mo,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&jn(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new Ze({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new et,this.reconnectStrategy=zn(this.reconnectOptions),this.authGuard=Vn(e.authGuard),this.operationGuard=Wt(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new X({perSec:t}):void 0,this.commandPrefixes=fo(e.commandPrefix),this.citationConfig=e.citation,this.ignoreMe=e.ignoreMe??true,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 lo.fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=lo.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=Un(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 he(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new ye(()=>this._socket)}get newsletter(){return this._newsletter??=new we(()=>this._socket,this.operationGuard)}get community(){return this._community??=new ve(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new Ae(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),Ut(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Ce({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=Kn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=qn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:Dr,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=lo__default.default(s);this._socket=i,this.store.bind(i),this.wireSocket(i);let o=new Promise((a,c)=>{let d=this.connectResolve,u=this.connectReject;this.connectResolve=()=>{d?.(),a();},this.connectReject=l=>{u?.(l),c(l);};});return this.auth.creds.readCreds().then(a=>{this.credsLoadedAtConnect=!!a,Object.assign(t,a??lo.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._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 Se).register(e,t),this.attachCommandsIfReady(),this}use(e){return this.commandMiddleware.push(e),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=Ft({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 b("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 He(e)?$.create(t,e,void 0,r):$.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new ge(this.requireSocket(),e)}async delete(e,t){await Rt(this.requireSocket(),e,t);}async react(e,t){return Lt(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return Nt(r,this.store,e,s)}resolveRecipient(e){return _t(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=Gn({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 Hn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+Dr});}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=Nr(this,t,{selfJid:typeof e.id=="string"?e.id:"",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),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"));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}}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=go(e?.error),r=Jn(t),s=false;if($n(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(!Te(r)&&!this.authExhausted){Xe(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 fo(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function go(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 Fr=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 m("STORE_CLOSED","MemoryAuthStore is closed")}};var ct=null,ho=async()=>{if(ct)return ct;try{return ct=(await import('better-sqlite3')).default,ct}catch(n){throw new m("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Ht="default",Ur=500,jr=n=>Array.from({length:n},()=>"?").join(","),Kr=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},qr=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(Ht);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Ht,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Ht);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Kr(t,Ur)){let o=jr(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 u=c[d];u===null?i.push({type:a,id:d}):u!==void 0&&s.push({type:a,id:d,blob:this.encodeBlob(u)});}}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=jr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Kr(t,Ur))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 m("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new m("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 ho(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new m("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 m("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,lo.BufferJSON.replacer),"utf8")}catch(t){throw new m("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,lo.BufferJSON.reviver)}catch(t){throw new m("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var lt,yo=async()=>(lt||(lt=import('pg').catch(n=>{throw lt=void 0,new m("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),lt),wo="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",vo="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",Jr=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 m("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new m("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 m("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 yo(),r=t.Pool??t.default?.Pool;if(!r)throw new m("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(wo),await e.query(vo);}catch(t){throw new m("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"),lo.BufferJSON.reviver);}return s}catch(i){throw i instanceof m?i:new m("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,lo.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 m("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 m("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 m("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,lo.BufferJSON.reviver)}catch(t){throw t instanceof m?t:new m("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,lo.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 m("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 m("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var So="zaileys",Mo=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],Ao=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},$r=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??So,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,lo.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),u=this.indexKey(i);c===null?(r.del(d),r.sRem(u,a)):c!==void 0&&(r.set(d,JSON.stringify(c,lo.BufferJSON.replacer)),r.sAdd(u,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 Mo){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,lo.BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,lo.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 m("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 Ao(r)?new m("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new m("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 m("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 m("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("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 m("STORE_CLOSED","RedisAuthStore is closed")}};var Co="zaileys",Ne={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Eo=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},le=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Co,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(Ne.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(Ne.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(Ne.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(Ne.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(Ne.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 Eo(r)?new m("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new m("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 m("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","Convex store is closed")}};var mt="creds",bo="signal:",_e=(n,e)=>`${bo}${n}:${e}`,Vr=class{creds;signal;kv;constructor(e){this.kv=new le(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([mt])).get(mt);return s===void 0?void 0:JSON.parse(s,lo.BufferJSON.reviver)},async writeCreds(r){await t.set([{key:mt,value:JSON.stringify(r,lo.BufferJSON.replacer)}]);},async deleteCreds(){await t.del([mt]);}},this.signal={async read(r,s){let i=s.map(c=>_e(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(_e(r,c));a[c]=d===void 0?void 0:JSON.parse(d,lo.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(_e(o,c)):s.push({key:_e(o,c),value:JSON.stringify(d,lo.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=>_e(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var ft=null,To=async()=>{if(ft)return ft;try{return ft=(await import('better-sqlite3')).default,ft}catch(n){throw new m("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},gt=n=>{try{return Buffer.from(JSON.stringify(n,lo.BufferJSON.replacer),"utf8")}catch(e){throw new m("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},te=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,lo.BufferJSON.reviver)}catch(e){throw new m("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},Gr=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,gt(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?te(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=>te(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,gt(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?te(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>te(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,gt(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?te(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>te(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,gt(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?te(r.data):void 0}bind(e){if(this.closed)throw new m("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 m("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new m("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 To(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new m("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 (
10
+ `:""}${n.body}`};return n.footer!==void 0&&(t.footer=n.footer),Ge(n.buttons,t)};var Ye=n=>{if(typeof n!="string"||n.trim().length===0)throw new f("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var jn=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var Vs=[{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,jn(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=En(In(e),t):this.internal.content=Ye(e),this}image(e,t){return this.internal.pendingContent=oe(e,t),this}video(e,t){return this.internal.pendingContent=ae(e,t),this}audio(e,t){return this.internal.pendingContent=Sn(e,t),this}document(e,t){return this.internal.pendingContent=xn(e,t),this}sticker(e,t){return this.internal.pendingContent=Fn(e,t),this}buttons(e,t){return this.internal.content=Ge(e,t),this}carousel(e,t){return this.internal.content=Cn(e,t),this}list(e){return this.internal.content=Ln(e),this}poll(e,t,r){return this.internal.content=Bn(e,t,r),this}location(e,t,r){return this.internal.content=Nn(e,t,r),this}contact(e){return this.internal.content=On(e),this}template(e){return this.internal.content=Un(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),hn(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[B];if(i!==void 0){let d=s[Lt],l=s[_t];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 O(t.src),s=await No.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 p=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&p)for(let v of r){let g=p[v.index]?.header;g&&await this.uploadHeaderMedia(g,v);}}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=No.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:Vs}:{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 we=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Ye(e),this}image(e,t){return this.pendingContent=oe(e,t),this}video(e,t){return this.pendingContent=ae(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 Kn=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new f("INVALID_OPTIONS","message key is missing remoteJid");return e},qn=n=>{if(!n?.key)throw new f("SEND_FAILED","socket returned no message key");return n.key},Bt=async(n,e,t={})=>{let r=Kn(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);},Ft=async(n,e,t)=>{let r=Kn(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return qn(s)},Wt=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 qn(i)};var Gs=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,Ze=n=>Gs.test(n),Ut=async(n,e,t,r=Hs)=>{if(Ze(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);}},Hs=new Map;var T=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 ve=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 T("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new T("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 T("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);}};var Se=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 Me=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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 T("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);}};var Ae=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new T("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))}};var P=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 zs=n=>{let e=n[0];return e==="{"||e==="["},Ys=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Zs=n=>n===" "||n===" "||n===`
11
+ `||n==="\r",Xs=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(Zs(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},Qs=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},ei=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function jt(n,e){let t=Qs(n,e);if(t===null)return ei(n);let r=n.slice(t.length),s=Xs(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 p=d.slice(0,l),v=d.slice(l+1);i.flags[p]=v;continue}let u=s[a+1];u!==void 0&&!u.startsWith("--")?(i.flags[d]=u,a+=1):i.flags[d]=true;continue}if(!o&&zs(c)){let d=Ys(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var ti=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new P("INVALID_COMMAND_NAME","empty command segment in spec");return e},Xe=n=>n.join(" "),Ce=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new P("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>ti(a)),s=r[0],i=r.slice(1).map(a=>Xe(a)),o={name:Xe(s),aliases:i,parts:s,handler:t};for(let a of r){let c=Xe(a);if(this.paths.has(c))throw new P("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(Xe(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)}}}list(){return [...this.defs]}};async function Kt(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new P("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 P?c:new P("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function qt(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=jt(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(Kt(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let l=d instanceof P?d:new P("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 b=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 ni=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Q=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new b("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new b("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new b("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??ni;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 ri={"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},si=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function Jt(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??si,i={...ri,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,l)=>{let u=i[d]??0,p=o.get(d);if(p!==void 0&&u>0){let v=u-(r()-p);v>0&&await s(v);}return o.set(d,r()),l()};return {run(d,l){if(!t)return l();let p=(a.get(d)??Promise.resolve()).then(()=>c(d,l),()=>c(d,l));return a.set(d,p.then(()=>{},()=>{})),p}}}var ii={maxRetries:0,backoffMs:()=>0},oi=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Ee=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??ii,this.sleep=t.sleep??oi;}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 ai=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function $t(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 Q({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},l=c?new Ee({concurrency:1,retry:c},d):void 0,u=n.length,p=0;for(let v of n){await a.acquire(v);let g=()=>e(t.sendTo(v)).then(()=>{});try{l?await l.add(g):await g(),s.sent.push(v),p+=1,r.onProgress?.(p,u,v,!0);}catch(w){s.failed.push({jid:v,error:ai(w)}),p+=1,r.onProgress?.(p,u,v,false);}}return s}var ci=1e3,be=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??ci,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("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 li={set:(n,e)=>setTimeout(n,e),clear:n=>clearTimeout(n)},ui=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",Pe=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??li,this.logger=e.logger,this.acquire=e.acquire;}async scheduleAt(e,t){let r=e.getTime();if(Number.isNaN(r))throw new b("SCHEDULE_INVALID","scheduleAt requires a valid Date");let s=await this.evaluate(t),i=crypto.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),ui(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 b("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 b("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 b?o:new b("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new b("SCHEDULE_INVALID","scheduled builder produced no content");return t}};var ee="[zaileys]",pi="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 $n(n){switch(n.kind){case "connecting":return `${ee} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${ee} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${ee} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${ee} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${ee} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
12
+ ${ee} ${pi}`:t}case "disconnect":return n.willReconnect?null:`${ee} Disconnected (${n.reason}).`;default:return null}}var Jn=false,mi=["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:"],fi=n=>typeof n[0]=="string"&&mi.some(e=>n[0].startsWith(e));function Vn(){if(Jn)return;Jn=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{fi(r)||t(...r);};};n("info"),n("warn"),n("error");}var m=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 hi="./.zaileys/auth",yi=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),ke=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",et=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??hi;}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 fs.promises.readFile(i,"utf8");r[s]=JSON.parse(o,No.BufferJSON.reviver);}catch(o){if(ke(o))return;throw new m("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 fs.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(fs.promises.unlink(c).catch(d=>{if(!ke(d))throw new m("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,No.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 fs.promises.unlink(s);}catch(i){if(!ke(i))throw new m("STORE_WRITE_FAILED",`failed to unlink ${s}`,{cause:i})}}));},clear:async()=>{this.assertOpen(),await fs.promises.rm(this.basePath,{recursive:true,force:true});},close:async()=>{this.closed=true;}};creds={readCreds:async()=>{this.assertOpen();try{let e=await fs.promises.readFile(this.credsPath(),"utf8");return JSON.parse(e,No.BufferJSON.reviver)}catch(e){if(ke(e))return;throw new m("STORE_READ_FAILED","failed to read creds.json",{cause:e})}},writeCreds:async e=>{this.assertOpen(),await fs.promises.mkdir(this.basePath,{recursive:true}),await this.atomicWrite(this.credsPath(),JSON.stringify(e,No.BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await fs.promises.unlink(this.credsPath());}catch(e){if(!ke(e))throw new m("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return Te__default.default.join(this.basePath,"creds.json")}signalDir(e){return Te__default.default.join(this.basePath,"signal",String(e))}signalPath(e,t){return Te__default.default.join(this.signalDir(e),`${yi(t)}.json`)}async atomicWrite(e,t){let r=Te__default.default.join(Te__default.default.dirname(e),`tmp-${crypto.randomBytes(8).toString("hex")}`);try{await fs.promises.writeFile(r,t,"utf8"),await fs.promises.rename(r,e);}catch(s){throw await fs.promises.unlink(r).catch(()=>{}),new m("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","FileAuthStore is closed")}};function Gn(n,e){let t=n.signal,s=No.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 Hn(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 vi=429;function zn(n){if(n===vi)return "rate-limited";switch(n){case No.DisconnectReason.loggedOut:return "logged-out";case No.DisconnectReason.forbidden:return "forbidden";case No.DisconnectReason.connectionLost:return "connection-lost";case No.DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case No.DisconnectReason.connectionClosed:return "connection-closed";case No.DisconnectReason.connectionReplaced:return "connection-replaced";case No.DisconnectReason.badSession:return "bad-session";case No.DisconnectReason.unavailableService:return "unavailable-service";case No.DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Ie(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function tt(n){return n==="rate-limited"}function Yn(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function Vl(n){return !Ie(n)}var nt={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},Si=3e5;function Zn(n={}){let e=n.enabled??nt.enabled,t=n.maxQrAttempts??nt.maxQrAttempts,r=n.maxPairingAttempts??nt.maxPairingAttempts,s=n.pairingCooldownMs??nt.pairingCooldownMs,i=0,o=0,a=0,c=p=>p<=0?0:Math.min(s*p,Si);return {evaluate:(p,v)=>{if(!e)return {allowed:true,waitMs:0,attempts:p==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(p==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let g=c(o),w=v-a;return o>0&&w<g?{allowed:false,reason:"cooldown",waitMs:g-w,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:(p,v)=>{p==="pairing"?(o+=1,a=v):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var Mi=/[\s\-()+]/g;function Ai(n){return typeof n!="string"?"":n.replace(Mi,"")}function Ci(n){if(!n||typeof n!="string"||!n.trim())throw new Error("phoneNumber is required");let e=Ai(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 Xn(n){let e=Ci(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 bi(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{Ei__default.default.generate(n,{small:true},t=>e(t));})}async function Qn(n,e=t=>{process.stdout.write(t);}){let t=await bi(n);e(t+`
13
+ `);}var de={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function er(n,e){let t=n?.enabled??de.enabled,r=n?.maxAttempts??de.maxAttempts,s=n?.initialDelayMs??de.initialDelayMs,i=n?.maxDelayMs??de.maxDelayMs,o=n?.jitterFactor??de.jitterFactor,a=n?.rateLimitedDelayMs??de.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:p=>{if(!t||Ie(p))return null;let v=d+1;if(v>r)return null;if(d=v,tt(p))return {attempt:v,delayMs:a};let g=Math.pow(2,v-1),w=Math.min(i,s*g),y=1+(c()*2-1)*o,A=w*y,E=Math.min(i,Math.max(0,A));return {attempt:v,delayMs:Math.round(E)}},reset:()=>{d=0;},get attempts(){return d}}}var Pi={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 tr(n="idle"){let e=n,t=new Set,r=s=>Pi[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 Vt=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,rt=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=Vt(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(Vt(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(Vt(l.key));if(u){let p={...u,...l.update};this.saveMessage(p).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 p={...this.chats.get(l.id)??{},...l};this.saveChat(p).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(){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 m("STORE_CLOSED","MemoryMessageStore is closed")}};var ki=["silent","fatal","error","warn","info","debug","trace"];function Ii(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":ki.includes(e)?e:"silent"}function Oi(n={}){let e=Ii(n.level),t=Ti__default.default({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var nr=["debug","info","warn","error","fatal"];function xi(n){if(n===null||typeof n!="object")return false;for(let e of nr)if(typeof n[e]!="function")return false;return true}function Oe(){}function Ri(n){let e={debug:Oe,info:Oe,warn:Oe,error:Oe,fatal:Oe};for(let t of nr){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function Gt(n,e){return n===void 0?e??Oi():xi(n)?n:Ri(n)}var iu=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),rr=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 Li=new Set(["offer","ringing"]),Ni=new Set(["timeout","reject","accept","terminate"]),sr=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},ir=n=>typeof n.id!="string"||n.id.length===0||!Li.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:sr(n.date),status:n.status},or=n=>typeof n.id!="string"||n.id.length===0||!Ni.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:sr(n.date),status:n.status};var R=n=>typeof n=="string"&&n.length>0,_i=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},ar=(n,e,t)=>n.filter(r=>R(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return R(i)&&(s.participantAlt=i),R(e)&&(s.authorPn=e),R(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),cr=n=>R(n?.id)?{groupId:n.id,update:_i(n),timestamp:Date.now()}:null,dr=n=>{if(!R(n?.groupId)||!R(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 R(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},Di=new Set(["add","invite","invite-link"]),Bi=new Set(["remove","leave"]),lr=n=>{if(!R(n?.id)||!Di.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=ar(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 R(n.author)&&(t.by=n.author),t},ur=n=>{if(!R(n?.id)||!Bi.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=ar(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 R(n.author)&&(t.by=n.author),t};var xe=n=>typeof n!="string"||n.length===0?null:No.jidNormalizedUser(n),G=n=>typeof n=="string"&&n.length>0?n:void 0,Ui=["@s.whatsapp.net","@c.us"],st=n=>n.endsWith("@lid"),ji=n=>Ui.some(e=>n.endsWith(e)),j=(n,e)=>{if(!n)return null;let t=G(n.participant)??n.remoteJid,r=xe(t);if(r===null)return null;let s=G(n.participantAlt)??G(n.remoteJidAlt),i=s!=null?xe(s):null,o=G(n.participantUsername)??G(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(st),l=c.find(ji);d!==void 0&&(a.lid=d),l!==void 0&&(a.pn=l),o!==void 0&&(a.username=o);let u=G(e);return u!==void 0&&(a.pushName=u),a},pr=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=G(n.participant),r=G(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=j(s);return o&&(i.sender=o),i},Re=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 le=n=>No.isJidGroup(n)===true,ue=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 Ki=["quick_reply","cta_url","cta_call","button_click"],qi=["list_select","single_select"],q=n=>typeof n=="string"&&n.length>0,fr=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return j(n.key,e)},gr=n=>ue(n.messageTimestamp)??0,hr=(n,e)=>{if(!q(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}},it=(n,e)=>{for(let t of e){let r=n[t];if(q(r))return r}},yr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&q(r.selectedButtonId))return Ht(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&q(s.selectedId))return Ht(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&q(i.name)&&Ki.includes(i.name)){let o=hr(i.paramsJson,e.logger);if(!o)return null;let a=it(o,["id","button_id"]);return a===void 0?null:Ht(n,a,it(o,["display_text"])??null)}return null},Ht=(n,e,t)=>{let r=fr(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:gr(n)};return q(t)&&(s.buttonText=t),s},wr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(q(s))return mr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&q(i.name)&&qi.includes(i.name)){let o=hr(i.paramsJson,e.logger);if(!o)return null;let a=it(o,["row_id","id"]);return a===void 0?null:mr(n,a,it(o,["title"])??null)}return null},mr=(n,e,t)=>{let r=fr(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:gr(n)};return q(t)&&(s.title=t),s};var Ji=new Set(["available","unavailable","composing","recording","paused"]),$i=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,vr=n=>n.status!=="complete"&&n.status!=="paused"?null:{syncType:String(n.syncType),status:n.status,explicit:n.explicit===true},zt=n=>{if(n.source==="connection-update"){let t=n.reachoutTimeLock;return t.isActive!==true?null:{reason:"reachout-timelock",retryAt:$i(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},Sr=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"||!Ji.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},Le=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 Gi=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},Mr=(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},Ar=n=>(Mr(n).toString(16).padStart(8,"0")+Mr(n,2646966556).toString(16).padStart(8,"0")).toUpperCase(),Hi=n=>Ar(`${n.remoteJid??""}|${n.id??""}|${n.fromMe===true?"1":"0"}`),zi=(n,e)=>Ar(`${n??""}|${e}`),Yi=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},Zi=n=>{let e=No.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"},Xi=n=>n.trim().endsWith("?"),Qi=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),eo=(n,e)=>{if(e.length===0)return false;let t;try{t=No.jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return No.jidNormalizedUser(r)===t}catch{return r===n}})},to=(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)}},no=0,ro=14,so=1,io=2,ot=n=>n!=null&&typeof n=="object"?n:null,oo=n=>{let e=ot(n.message);if(e==null)return {isEdited:false,isDeleted:false,isPinned:false,isUnPinned:false,isBot:false,isStatusMention:false,isGroupStatusMention:false};let t=ot(e.protocolMessage),r=typeof t?.type=="number"?t.type:void 0,s=typeof ot(e.pinInChatMessage)?.type=="number"?e.pinInChatMessage.type:void 0;return {isEdited:e.editedMessage!=null||r===ro,isDeleted:r===no,isPinned:s===so,isUnPinned:s===io,isBot:ot(e.messageContextInfo)?.botMetadata!=null,isStatusMention:e.statusMentionMessage!=null,isGroupStatusMention:e.groupStatusMentionMessage!=null}},Yt=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&le(e),r=oo(n.message),s=n.sender.pn??n.sender.jid,i=t?e?No.jidNormalizedUser(e):null:n.key.fromMe===true&&e?No.jidNormalizedUser(e):s,o={uniqueId:Hi(n.key),staticId:zi(i,s),channelId:n.channelId,chatId:n.key.id??"",chatType:n.chatType,receiverId:n.receiverId?No.jidNormalizedUser(n.receiverId):n.receiverId,roomId:i,senderId:s,senderLid:n.sender.lid??null,senderName:n.sender.pushName??null,senderDevice:Zi(n.sender.deviceJid??n.sender.jid),timestamp:Yi(n.message.messageTimestamp),text:n.text,mentions:n.mentions,links:Gi(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:Xi(n.text),isPrefix:Qi(n.text,n.prefixes),isTagMe:eo(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:to(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(o.media=n.media),o};var ao={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},co=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[ao[e]];if(r==null||typeof r!="object")return null;let s=r.mimetype;return typeof s=="string"&&s.length>0?s:null},Cr=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys'),s=await r(n,"buffer",{}),i=co(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")}},Er=(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 ct={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},Pr=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,pe=(...n)=>{for(let e of n){let t=S(e);if(t!=null)return t}return null},lo=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage"],dt=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of lo){let i=h(h(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},uo=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},po=n=>{let e=h(n.templateMessage),t=h(e?.hydratedTemplate)??h(e?.hydratedFourRowTemplate);return S(t?.hydratedContentText)},mo=n=>pe(h(n.pollCreationMessage)?.name,h(n.pollCreationMessageV2)?.name,h(n.pollCreationMessageV3)?.name),fo=n=>{let e=h(n.locationMessage)??h(n.liveLocationMessage);if(e==null)return null;let t=pe(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},go=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},Tr=n=>pe(n.conversation,h(n.extendedTextMessage)?.text,uo(n),S(h(h(n.interactiveMessage)?.body)?.text),h(n.buttonsMessage)?.contentText,h(n.listMessage)?.description,po(n),mo(n),fo(n),go(n)),ho=n=>pe(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),yo=n=>pe(h(n.imageMessage)?.caption,h(n.videoMessage)?.caption,h(n.documentMessage)?.caption,h(n.documentMessage)?.fileName),L=n=>{if(typeof n=="number")return n;let e=ue(n);return typeof e=="number"?e:null},wo=[["pollCreationMessage","poll"],["pollCreationMessageV2","poll"],["pollCreationMessageV3","poll"],["contactMessage","contact"],["contactsArrayMessage","contact"],["locationMessage","location"],["liveLocationMessage","live-location"],["eventMessage","event"],["buttonsMessage","buttons"],["listMessage","list"],["interactiveMessage","interactive"],["templateMessage","template"]],kr=n=>{let e=h(n.pollCreationMessage)??h(n.pollCreationMessageV2)??h(n.pollCreationMessageV3);if(e!=null){let u=Array.isArray(e.options)?e.options:[];return {type:"poll",name:S(e.name),options:u.map(p=>S(h(p)?.optionName)).filter(p=>p!=null),selectableCount:L(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 u=Array.isArray(r.contacts)?r.contacts:[];return {type:"contact",displayName:S(r.displayName),vcard:null,contacts:u.map(p=>({displayName:S(h(p)?.displayName),vcard:S(h(p)?.vcard)}))}}let s=h(n.locationMessage);if(s!=null)return {type:"location",latitude:L(s.degreesLatitude),longitude:L(s.degreesLongitude),name:S(s.name),address:S(s.address),accuracy:L(s.accuracyInMeters),speed:L(s.speedInMps),caption:S(s.comment)};let i=h(n.liveLocationMessage);if(i!=null)return {type:"live-location",latitude:L(i.degreesLatitude),longitude:L(i.degreesLongitude),name:null,address:null,accuracy:L(i.accuracyInMeters),speed:L(i.speedInMps),caption:S(i.caption)};let o=h(n.eventMessage);if(o!=null){let u=h(o.location);return {type:"event",name:S(o.name),description:S(o.description),location:u!=null?pe(u.name,u.address):null,startTime:L(o.startTime),endTime:L(o.endTime),isCanceled:o.isCanceled===true}}let a=h(n.buttonsMessage);if(a!=null){let u=Array.isArray(a.buttons)?a.buttons:[];return {type:"buttons",contentText:S(a.contentText),footerText:S(a.footerText),buttons:u.map(p=>({id:S(h(p)?.buttonId),text:S(h(h(p)?.buttonText)?.displayText)}))}}let c=h(n.listMessage);if(c!=null){let u=Array.isArray(c.sections)?c.sections:[];return {type:"list",title:S(c.title),description:S(c.description),buttonText:S(c.buttonText),sections:u.map(p=>{let v=Array.isArray(h(p)?.rows)?h(p).rows:[];return {title:S(h(p)?.title),rows:v.map(g=>({id:S(h(g)?.rowId),title:S(h(g)?.title),description:S(h(g)?.description)}))}})}}let d=h(n.interactiveMessage);if(d!=null){let u=h(d.nativeFlowMessage),p=Array.isArray(u?.buttons)?u.buttons:[];return {type:"interactive",title:S(h(d.header)?.title),body:S(h(d.body)?.text),footer:S(h(d.footer)?.text),buttons:p.map(v=>({name:S(h(v)?.name),params:S(h(v)?.buttonParamsJson)}))}}let l=h(n.templateMessage);if(l!=null){let u=h(l.hydratedTemplate)??h(l.hydratedFourRowTemplate),p=Array.isArray(u?.hydratedButtons)?u.hydratedButtons:[];return {type:"template",text:S(u?.hydratedContentText),buttons:p.map(v=>{let g=h(v),w=h(g?.quickReplyButton)??h(g?.urlButton)??h(g?.callButton);return {id:S(w?.id),text:S(w?.displayText)}})}}return null};var _e=n=>{let e=h(n.message);if(e==null)return null;let t=dt(e);return Tr(t)??ho(t)??yo(t)},lt=n=>{let e=n.message;if(e==null)return null;let t=e.extendedTextMessage?.contextInfo;if(t!=null)return t;for(let r of Object.values(ct)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},vo=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[ct[e]];return r==null||typeof r!="object"?null:r},So=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(ct)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},Mo=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,te=n=>{let e=h(n);if(e==null)return "text";let t=dt(e);for(let r of Object.values(ct))if(t[r]!=null)return r.replace("Message","");for(let[r,s]of wo)if(t[r]!=null)return s;return "text"},Ao=(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))},Co=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 g=await e.resolveQuoted(i,t);if(g!=null&&g.message!=null){let w=_e(g)??"",y=ne(g,e,te(g.message),w,De(g,e),s);if(y!==null)return y}}let o=pr(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&&at(a,e.selfJid)||e.selfLid!=null&&at(a,e.selfLid)),d=le(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||Ao(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,p=Object.assign({key:o.key,message:u??null},l!=null?{pushName:l}:{}),v=_e(p)??"";return ne(p,e,te(u),v,De(p,e),s)}catch{return null}},Xt=n=>Re(lt(n)).mentionedJids,Eo=n=>{try{return No.jidNormalizedUser(n)}catch{return n}},Ir=(n,e)=>n.map(t=>Eo(e.mentionMap?.get(t)??t)),br=n=>(n.split("@")[0]??"").split(":")[0]??"",bo=(n,e)=>{if(e==null||e.size===0||n.length===0)return n;let t=[...e].map(([s,i])=>[br(s),br(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},ne=(n,e,t,r,s,i)=>{let o=n.key;if(o==null)return null;let a=j(o,n.pushName??void 0);if(a===null)return null;let c=Pr(o);if(c.length===0)return null;let d=lt(n),l=le(c),u=c.endsWith("@broadcast"),p=c.endsWith("@newsletter"),v=d?.isForwarded===true||(d?.forwardingScore??0)>0,g=So(n),w=Mo(n,d),y=e.channelId??"",A=e.receiverId??"",E=e.prefixes??[],_=i??(()=>l?e.resolveRoomName!=null?e.resolveRoomName(c):Promise.resolve(null):Promise.resolve(a.pushName??null)),Et=e.resolveReceiverName??(()=>Promise.resolve(null)),bt=()=>Co(d,e,c,a,_),Pt=c.length>0?c:a.pn??a.jid,Tt=(It,fs)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(Pt,It,fs,n),kt=It=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(o,It),ps=Ir(Re(d).mentionedJids,e),ms=bo(r,e.mentionMap),rn={message:n,key:o,channelId:y,receiverId:A,selfJid:e.selfJid,text:ms,chatType:t,sender:a,mentions:ps,isViewOnce:g,isEphemeral:w,isForwarded:v,isBroadcast:u,isNewsletter:p,prefixes:E,resolveRoomName:_,resolveReceiverName:Et,resolveReplied:bt,reply:Tt,react:kt},sn=s!==void 0?{...rn,media:s}:rn;return Yt(e.citationConfig!==void 0?{...sn,citationConfig:e.citationConfig}:sn)},Po=["image","video","audio","document","sticker"],Or=(n,e,t)=>{let r=vo(n,e);if(r===null)return null;let s=Cr(n,e,t.logger),i=Er(n,e,t.logger);return {type:e,mimetype:typeof r.mimetype=="string"?r.mimetype:null,caption:typeof r.caption=="string"?r.caption:null,fileName:typeof r.fileName=="string"?r.fileName:null,fileSize:L(r.fileLength),ptt:r.ptt===true,buffer:async()=>(await s()).buffer,stream:i}},De=(n,e)=>{let t=h(n.message);if(t==null)return;let r=te(n.message);return Po.includes(r)?Or(n,r,e)??void 0:kr(dt(t))??void 0},xr=(n,e)=>{if(h(n.message)==null)return null;let r=te(n.message),s=De(n,e),i=_e(n)??"";return i===""&&s===void 0?null:ne(n,e,r,i,s)},Rr=(n,e)=>{let t=h(n.message);if(t==null)return null;let r=dt(t),s=Tr(r),i=kr(r)??void 0;return s===null&&i===void 0?null:ne(n,e,te(n.message),s??"",i)},Be=(n,e,t)=>{let r=Or(e,n,t);return r===null?null:ne(e,t,n,r.caption??"",r)},Lr=(n,e)=>Be("image",n,e),Nr=(n,e)=>Be("video",n,e),_r=(n,e)=>Be("audio",n,e),Dr=(n,e)=>Be("document",n,e),Br=(n,e)=>Be("sticker",n,e),at=(n,e)=>{try{return No.jidNormalizedUser(n)===No.jidNormalizedUser(e)}catch{return n===e}},Fr=(n,e)=>{if(n.key==null)return null;let r=lt(n),s=Re(r).mentionedJids;if(s.length===0)return null;let i=Ir(s,e);if(!(i.some(u=>at(u,e.selfJid))||e.selfLid!=null&&s.some(u=>at(u,e.selfLid)))||h(n.message)==null)return null;let c=_e(n)??"",d=De(n,e),l=ne(n,e,te(n.message),c,d);return l===null?null:{...l,mentionedJids:i,selfJid:e.selfJid}},Wr=(n,e)=>{let t=n.key;if(t==null)return null;let r=Pr(t);if(r.length===0||!le(r))return null;let{mentionAll:s}=Re(lt(n));if(!s||h(n.message)==null)return null;let o=_e(n)??"",a=De(n,e),c=ne(n,e,te(n.message),o,a);return c===null?null:{...c,isMentionAll:true,selfJid:e.selfJid}};var re=(n,e)=>{let t=ue(n);return t===null?e:t},To=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 ""},ko=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],jr=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=j(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:re(t.senderTimestampMs,0)}},Kr=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==No.proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=j(n.key,e.pushName);return s===null?null:{key:r,newContent:To(t.editedMessage),editedAt:re(n.update.messageTimestamp,0),sender:s}},qr=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==No.proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=j(n.key,e.pushName);if(s===null)return null;let i=xe(n.key.remoteJid),o=xe(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:re(n.update.messageTimestamp,0)}},Jr=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=j(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:ko(t.vote?.selectedOptions),voter:s,timestamp:re(t.senderTimestampMs,re(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:re(r.senderTimestampMs,re(n.update.messageTimestamp,0))}:null}return null};var ut=n=>Array.isArray(n)?n:[],Io=3e3,Oo=(n,e)=>new Promise(t=>{let r=setTimeout(()=>t(null),e);n.then(s=>{clearTimeout(r),t(s);},()=>{clearTimeout(r),t(null);});}),xo=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function $r(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?g=>{let w=s.get(g);if(w!==void 0)return w;let y=t.groupMetadata;if(y==null)return Promise.resolve(null);let A=y(g).then(E=>E?.subject??null).catch(()=>null);return s.set(g,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=(g,w)=>{let y=(...A)=>{try{w(A[0]);}catch(E){t.logger?.warn(E,`inbound pipeline: handler for ${g} threw`);}};e.ev.on(g,y),r.push(()=>e.ev.off(g,y));},l=(g,w)=>{p(()=>xr(g,w),y=>n.emit("message",y)),p(()=>Rr(g,w),y=>n.emit("text",y)),p(()=>Lr(g,w),y=>n.emit("image",y)),p(()=>Nr(g,w),y=>n.emit("video",y)),p(()=>_r(g,w),y=>n.emit("audio",y)),p(()=>Dr(g,w),y=>n.emit("document",y)),p(()=>Br(g,w),y=>n.emit("sticker",y)),p(()=>Fr(g,w),y=>n.emit("mention",y)),p(()=>Wr(g,w),y=>n.emit("mention-all",y)),p(()=>yr(g,a),y=>n.emit("button-click",y)),p(()=>wr(g,a),y=>n.emit("list-select",y));},u=async g=>{let w=t.resolveLidToPn;if(w==null)return;let y=[...new Set(Xt(g).filter(st))];if(y.length===0)return;let A=new Map;return await Promise.all(y.map(async E=>{try{let _=await Oo(Promise.resolve(w(E)),Io);_!=null&&_.length>0&&A.set(E,_);}catch(_){t.logger?.warn(_,"inbound pipeline: lid->pn resolve threw");}})),A.size>0?A:void 0},p=(g,w)=>{let y;try{y=g();}catch(A){t.logger?.warn(A,"inbound pipeline: decoder threw");return}y!=null&&w(y);};d("messages.upsert",g=>{let w=rr(g);for(let y of w.messages){if(t.ignoreMe===!0&&y.key?.fromMe===!0)continue;if(!(t.resolveLidToPn!=null&&Xt(y).some(st))){l(y,o);continue}u(y).then(E=>l(y,E!=null?{...o,mentionMap:E}:o)).catch(E=>{t.logger?.warn(E,"inbound pipeline: deferred mention emit failed"),l(y,o);});}}),d("messages.update",g=>{for(let w of ut(g))p(()=>Kr(w,c),y=>n.emit("edit",y)),p(()=>qr(w,c),y=>n.emit("delete",y)),p(()=>Jr(w,c),y=>n.emit("poll-vote",y));}),d("messages.reaction",g=>{for(let w of ut(g))p(()=>jr(w,c),y=>n.emit("reaction",y));}),d("groups.update",g=>{for(let w of ut(g))p(()=>cr(w),y=>n.emit("group-update",y));}),d("group-participants.update",g=>{let w=g;p(()=>lr(w),y=>n.emit("group-join",y)),p(()=>ur(w),y=>n.emit("group-leave",y));}),d("group.member-tag.update",g=>{p(()=>dr(g),w=>n.emit("member-tag",w));}),d("call",g=>{for(let w of ut(g))p(()=>ir(w),y=>n.emit("call-incoming",y)),p(()=>or(w),y=>n.emit("call-ended",y));}),d("messaging-history.status",g=>{p(()=>vr(g),w=>n.emit("history-sync",w));}),d("presence.update",g=>{let w=(()=>{try{return Sr(g)}catch(y){return t.logger?.warn(y,"inbound pipeline: decodePresence threw"),[]}})();for(let y of w)n.emit("presence",y);}),d("connection.update",g=>{let w=xo(g);w!==null&&p(()=>zt({source:"connection-update",reachoutTimeLock:w}),y=>n.emit("limited",y));}),d("message-capping.update",g=>{p(()=>zt({source:"message-capping",capInfo:g}),w=>n.emit("limited",w));}),d("newsletter.reaction",g=>{p(()=>Le({source:"reaction",payload:g}),w=>n.emit("newsletter",w));}),d("newsletter.view",g=>{p(()=>Le({source:"view",payload:g}),w=>n.emit("newsletter",w));}),d("newsletter-participants.update",g=>{p(()=>Le({source:"participants",payload:g}),w=>n.emit("newsletter",w));}),d("newsletter-settings.update",g=>{p(()=>Le({source:"settings",payload:g}),w=>n.emit("newsletter",w));});let v=false;return {detach(){if(!v){v=true;for(let g of r)g();r.length=0;}}}}var pt=class{inner=new events.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=Lo,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},Lo=Symbol("zaileys.typed-ee.tag");var Do="default",Bo="qr",Gr=6e4,Hr=class extends pt{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=tr();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;commandRegistry;commandMiddleware=[];commandPrefixes;citationConfig;ignoreMe;commandDispatcher;_presence;_scheduler;waVersion;versionWarming;constructor(e={}){super({logger:Gt(e.logger)}),this.sessionId=e.sessionId??Do,this.logger=Gt(e.logger),this.authType=e.authType??Bo,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&Vn(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new et({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new rt,this.reconnectStrategy=er(this.reconnectOptions),this.authGuard=Zn(e.authGuard),this.operationGuard=Jt(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new Q({perSec:t}):void 0,this.commandPrefixes=Fo(e.commandPrefix),this.citationConfig=e.citation,this.ignoreMe=e.ignoreMe??true,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 No.fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=No.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=$n(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 ve(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new Se(()=>this._socket)}get newsletter(){return this._newsletter??=new Me(()=>this._socket,this.operationGuard)}get community(){return this._community??=new Ae(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new be(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),$t(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Pe({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=Gn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Hn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:Gr,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=No__default.default(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??No.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._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 Ce).register(e,t),this.attachCommandsIfReady(),this}use(e){return this.commandMiddleware.push(e),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=qt({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 P("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 Ze(e)?V.create(t,e,void 0,r):V.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new we(this.requireSocket(),e)}async delete(e,t){await Bt(this.requireSocket(),e,t);}async react(e,t){return Ft(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return Wt(r,this.store,e,s)}resolveRecipient(e){return Ut(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=Xn({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 Qn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+Gr});}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=$r(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"));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}}async lidToPn(e){try{let r=this._socket?.signalRepository?.lidMapping;return r==null||typeof r.getPNForLID!="function"?null:await r.getPNForLID(e)}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=Wo(e?.error),r=zn(t),s=false;if(Yn(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(!Ie(r)&&!this.authExhausted){tt(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 Fo(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function Wo(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 zr=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 m("STORE_CLOSED","MemoryAuthStore is closed")}};var mt=null,Uo=async()=>{if(mt)return mt;try{return mt=(await import('better-sqlite3')).default,mt}catch(n){throw new m("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Qt="default",Zr=500,Xr=n=>Array.from({length:n},()=>"?").join(","),Qr=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},es=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(Qt);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Qt,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Qt);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Qr(t,Zr)){let o=Xr(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=Xr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Qr(t,Zr))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 m("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new m("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 Uo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new m("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 m("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,No.BufferJSON.replacer),"utf8")}catch(t){throw new m("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,No.BufferJSON.reviver)}catch(t){throw new m("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var gt,jo=async()=>(gt||(gt=import('pg').catch(n=>{throw gt=void 0,new m("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),gt),Ko="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",qo="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",ts=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 m("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new m("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 m("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 jo(),r=t.Pool??t.default?.Pool;if(!r)throw new m("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(Ko),await e.query(qo);}catch(t){throw new m("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"),No.BufferJSON.reviver);}return s}catch(i){throw i instanceof m?i:new m("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,No.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 m("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 m("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 m("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,No.BufferJSON.reviver)}catch(t){throw t instanceof m?t:new m("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,No.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 m("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 m("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var Jo="zaileys",$o=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],Vo=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},ns=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??Jo,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,No.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,No.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 $o){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,No.BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,No.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 m("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 Vo(r)?new m("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new m("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 m("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 m("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("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 m("STORE_CLOSED","RedisAuthStore is closed")}};var Go="zaileys",Fe={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Ho=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},me=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Go,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(Fe.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(Fe.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(Fe.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(Fe.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(Fe.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 Ho(r)?new m("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new m("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 m("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","Convex store is closed")}};var wt="creds",zo="signal:",We=(n,e)=>`${zo}${n}:${e}`,rs=class{creds;signal;kv;constructor(e){this.kv=new me(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([wt])).get(wt);return s===void 0?void 0:JSON.parse(s,No.BufferJSON.reviver)},async writeCreds(r){await t.set([{key:wt,value:JSON.stringify(r,No.BufferJSON.replacer)}]);},async deleteCreds(){await t.del([wt]);}},this.signal={async read(r,s){let i=s.map(c=>We(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(We(r,c));a[c]=d===void 0?void 0:JSON.parse(d,No.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(We(o,c)):s.push({key:We(o,c),value:JSON.stringify(d,No.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=>We(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var vt=null,Yo=async()=>{if(vt)return vt;try{return vt=(await import('better-sqlite3')).default,vt}catch(n){throw new m("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},St=n=>{try{return Buffer.from(JSON.stringify(n,No.BufferJSON.replacer),"utf8")}catch(e){throw new m("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},se=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,No.BufferJSON.reviver)}catch(e){throw new m("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},ss=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,St(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?se(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=>se(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,St(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?se(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>se(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,St(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?se(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>se(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,St(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?se(r.data):void 0}bind(e){if(this.closed)throw new m("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 m("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new m("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 Yo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new m("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 (
18
18
  remote_jid TEXT NOT NULL,
19
19
  id TEXT NOT NULL,
20
20
  from_me INTEGER NOT NULL,
@@ -29,4 +29,4 @@ ${Q} ${Qs}`:t}case "disconnect":return n.willReconnect?null:`${Q} Disconnected (
29
29
  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(?, ?, ?)
30
30
  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(?, ?)
31
31
  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(?, ?)
32
- 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")};}};var ht,Po=async()=>(ht||(ht=import('pg').catch(n=>{throw ht=void 0,new m("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),ht),ko=["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())"],ne=n=>{if(n==null)return n;let e=typeof n=="string"?n:JSON.stringify(n);return JSON.parse(e,lo.BufferJSON.reviver)},zr=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 m("STORE_CONNECTION_FAILED","PostgresMessageStore: provide either pool or connectionString, not both");if(!t&&!r)throw new m("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 m("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 Po(),r=t.Pool??t.default?.Pool;if(!r)throw new m("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 ko)await e.query(t);}catch(t){throw new m("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,lo.BufferJSON.replacer)]);}catch(a){throw new m("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?ne(s.data):void 0}catch(r){throw r instanceof m?r:new m("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=>ne(a.data))}catch(o){throw new m("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,lo.BufferJSON.replacer)]);}catch(i){throw new m("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?ne(s.data):void 0}catch(r){throw new m("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=>ne(i.data))}catch(s){throw new m("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,lo.BufferJSON.replacer)]);}catch(r){throw new m("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?ne(s.data):void 0}catch(r){throw new m("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=>ne(r.data))}catch(t){throw new m("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,lo.BufferJSON.replacer)]);}catch(s){throw new m("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?ne(s.data):void 0}catch(r){throw new m("STORE_READ_FAILED","failed to read presence",{cause:r})}}bind(e){this.assertOpen(),this.boundSocket=e;let t=(...c)=>{let u=c[0]?.messages;if(Array.isArray(u))for(let l of u)this.saveMessage(l).catch(()=>{});},r=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.getMessage(u.key).then(l=>{if(!l)return;let y={...l,...u.update};return this.saveMessage(y)}).catch(()=>{});},s=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.saveChat(u).catch(()=>{});},i=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.getChat(u.id).then(l=>{let y={...l??{},...u};return this.saveChat(y)}).catch(()=>{});},o=(...c)=>{let d=c[0];if(Array.isArray(d))for(let u of d)this.saveContact(u).catch(()=>{});},a=(...c)=>{let d=c[0];if(d?.presences)for(let u of Object.keys(d.presences)){let l=d.presences[u];l&&this.savePresence(u,l).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 m("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 Io="zaileys",Oo=300,xo=1e3,Yr=n=>`${n.id??""}|${n.fromMe?1:0}`,Ro=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},Zr=class{namespace;externalClient;url;ownedClient;ready;closed=false;boundSocket;listeners=new Map;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","RedisMessageStore requires either client or url");this.namespace=e.namespace??Io,this.externalClient=e.client,this.url=e.url;}async saveMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.key.remoteJid??"",s=Yr(e.key),i=Number(e.messageTimestamp??0),o=JSON.stringify(e,lo.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),Yr(e)));if(s!=null)return JSON.parse(s,lo.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)),u=[];for(let l of d)l!=null&&u.push(JSON.parse(l,lo.BufferJSON.reviver));return u}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,lo.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,lo.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,lo.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,lo.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,lo.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,lo.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,lo.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,lo.BufferJSON.replacer),{EX:Oo}));}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,lo.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:xo}));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;}}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 m("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 Ro(r)?new m("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new m("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 m("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 m("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("STORE_WRITE_FAILED","redis write failed",{cause:t})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","RedisMessageStore is closed")}};var es="msg:",yt="chat:",wt="contact:",zt="presence:",Yt="job:",Lo=n=>`${n.id??""}|${n.fromMe?1:0}`,Zt=n=>`${es}${n.remoteJid??""}:${Lo(n)}`,Be=n=>JSON.stringify(n,lo.BufferJSON.replacer),G=n=>JSON.parse(n,lo.BufferJSON.reviver),Xr=class{kv;closed=false;boundSocket;listeners=new Map;constructor(e){this.kv=new le(e);}async saveMessage(e){this.assertOpen(),await this.kv.set([{key:Zt(e.key),value:Be(e),sortKey:Number(e.messageTimestamp??0)}]);}async getMessage(e){this.assertOpen();let r=(await this.kv.get([Zt(e)])).get(Zt(e));return r===void 0?void 0:G(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(`${es}${e}:`,r)).map(i=>G(i.value))}async saveChat(e){this.assertOpen();let t=e.id;t&&await this.kv.set([{key:`${yt}${t}`,value:Be(e)}]);}async getChat(e){this.assertOpen();let r=(await this.kv.get([`${yt}${e}`])).get(`${yt}${e}`);return r===void 0?void 0:G(r)}async listChats(e){this.assertOpen();let t=await this.kv.list(yt),r=[];for(let s of t){let i=G(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:`${wt}${e.id}`,value:Be(e)}]);}async getContact(e){this.assertOpen();let r=(await this.kv.get([`${wt}${e}`])).get(`${wt}${e}`);return r===void 0?void 0:G(r)}async listContacts(){return this.assertOpen(),(await this.kv.list(wt)).map(t=>G(t.value))}async savePresence(e,t){this.assertOpen(),await this.kv.set([{key:`${zt}${e}`,value:Be(t)}]);}async getPresence(e){this.assertOpen();let r=(await this.kv.get([`${zt}${e}`])).get(`${zt}${e}`);return r===void 0?void 0:G(r)}async saveScheduledJob(e){this.assertOpen(),await this.kv.set([{key:`${Yt}${e.id}`,value:Be(e),sortKey:e.fireAt}]);}async listScheduledJobs(){return this.assertOpen(),(await this.kv.list(Yt)).map(t=>G(t.value))}async deleteScheduledJob(e){this.assertOpen(),await this.kv.del([`${Yt}${e}`]);}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 m("STORE_CLOSED","ConvexMessageStore is closed")}};var No=(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};exports.AudioProcessor=z;exports.BufferConverter=M;exports.Client=Br;exports.CommandRegistry=Se;exports.CommunityModule=ve;exports.ConvexAuthStore=Vr;exports.ConvexMessageStore=Xr;exports.DocumentProcessor=qe;exports.EditBuilder=ge;exports.FFMPEG_CONSTANTS=S;exports.FFmpegProcessor=H;exports.FileAuthStore=Ze;exports.FileManager=q;exports.GroupModule=he;exports.ImageProcessor=N;exports.Media=Y;exports.MemoryAuthStore=Fr;exports.MemoryMessageStore=et;exports.MessageBuilder=$;exports.MimeValidator=P;exports.NewsletterModule=we;exports.PostgresAuthStore=Jr;exports.PostgresMessageStore=zr;exports.PresenceModule=Ae;exports.PrivacyModule=ye;exports.RateLimiter=X;exports.RedisAuthStore=$r;exports.RedisMessageStore=Zr;exports.SELF_ONLY_PROTOCOL_TYPES=_l;exports.Scheduler=Ce;exports.SqliteAuthStore=qr;exports.SqliteMessageStore=Gr;exports.StickerProcessor=Ke;exports.TaskQueue=Me;exports.TypedEventEmitter=at;exports.VideoProcessor=F;exports.ZaileysAutomationError=E;exports.ZaileysBuilderError=f;exports.ZaileysCommandError=b;exports.ZaileysDomainError=T;exports.ZaileysStoreError=m;exports.adoptLogger=Kt;exports.attachCommandDispatcher=Ft;exports.buildMessageContext=$t;exports.chunk=No;exports.createAuthGuard=Vn;exports.createConnectionStateMachine=Yn;exports.createLogger=yi;exports.createOperationGuard=Wt;exports.createPairingFlow=Gn;exports.createReconnectStrategy=zn;exports.deleteMessage=Rt;exports.detectFileType=k;exports.dropSpoofedSelfOnly=Xn;exports.ffmpegTransform=B;exports.forwardMessage=Nt;exports.generateId=We;exports.initializeFFmpeg=bt;exports.isFatalDisconnect=Te;exports.isJid=He;exports.isRateLimited=Xe;exports.makeCacheableAuthStore=Kn;exports.mapDisconnectReason=Jn;exports.normalizePhoneNumber=di;exports.parseCommand=Dt;exports.printQrToTerminal=Hn;exports.reactToMessage=Lt;exports.renderQrInTerminal=pi;exports.resolveUsername=_t;exports.runBroadcast=Ut;exports.runMiddleware=Bt;exports.shouldClearAuth=$n;exports.shouldReconnect=Al;exports.signalKeyStoreFromAuthStore=qn;exports.validateE164=li;
32
+ 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")};}};var Mt,Zo=async()=>(Mt||(Mt=import('pg').catch(n=>{throw Mt=void 0,new m("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),Mt),Xo=["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())"],ie=n=>{if(n==null)return n;let e=typeof n=="string"?n:JSON.stringify(n);return JSON.parse(e,No.BufferJSON.reviver)},os=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 m("STORE_CONNECTION_FAILED","PostgresMessageStore: provide either pool or connectionString, not both");if(!t&&!r)throw new m("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 m("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 Zo(),r=t.Pool??t.default?.Pool;if(!r)throw new m("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 Xo)await e.query(t);}catch(t){throw new m("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,No.BufferJSON.replacer)]);}catch(a){throw new m("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?ie(s.data):void 0}catch(r){throw r instanceof m?r:new m("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=>ie(a.data))}catch(o){throw new m("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,No.BufferJSON.replacer)]);}catch(i){throw new m("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?ie(s.data):void 0}catch(r){throw new m("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=>ie(i.data))}catch(s){throw new m("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,No.BufferJSON.replacer)]);}catch(r){throw new m("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?ie(s.data):void 0}catch(r){throw new m("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=>ie(r.data))}catch(t){throw new m("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,No.BufferJSON.replacer)]);}catch(s){throw new m("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?ie(s.data):void 0}catch(r){throw new m("STORE_READ_FAILED","failed to read presence",{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 p={...u,...l.update};return this.saveMessage(p)}).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 p={...u??{},...l};return this.saveChat(p)}).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 m("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 Qo="zaileys",ea=300,ta=1e3,as=n=>`${n.id??""}|${n.fromMe?1:0}`,na=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},cs=class{namespace;externalClient;url;ownedClient;ready;closed=false;boundSocket;listeners=new Map;constructor(e){if(e.client&&e.url)throw new m("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new m("STORE_CONNECTION_FAILED","RedisMessageStore requires either client or url");this.namespace=e.namespace??Qo,this.externalClient=e.client,this.url=e.url;}async saveMessage(e){this.assertOpen();let t=await this.ensureReady(),r=e.key.remoteJid??"",s=as(e.key),i=Number(e.messageTimestamp??0),o=JSON.stringify(e,No.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),as(e)));if(s!=null)return JSON.parse(s,No.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,No.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,No.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,No.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,No.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,No.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,No.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,No.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,No.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,No.BufferJSON.replacer),{EX:ea}));}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,No.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:ta}));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;}}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 m("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 na(r)?new m("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new m("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 m("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 m("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new m("STORE_WRITE_FAILED","redis write failed",{cause:t})}}assertOpen(){if(this.closed)throw new m("STORE_CLOSED","RedisMessageStore is closed")}};var us="msg:",At="chat:",Ct="contact:",en="presence:",tn="job:",ra=n=>`${n.id??""}|${n.fromMe?1:0}`,nn=n=>`${us}${n.remoteJid??""}:${ra(n)}`,je=n=>JSON.stringify(n,No.BufferJSON.replacer),H=n=>JSON.parse(n,No.BufferJSON.reviver),ds=class{kv;closed=false;boundSocket;listeners=new Map;constructor(e){this.kv=new me(e);}async saveMessage(e){this.assertOpen(),await this.kv.set([{key:nn(e.key),value:je(e),sortKey:Number(e.messageTimestamp??0)}]);}async getMessage(e){this.assertOpen();let r=(await this.kv.get([nn(e)])).get(nn(e));return r===void 0?void 0:H(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(`${us}${e}:`,r)).map(i=>H(i.value))}async saveChat(e){this.assertOpen();let t=e.id;t&&await this.kv.set([{key:`${At}${t}`,value:je(e)}]);}async getChat(e){this.assertOpen();let r=(await this.kv.get([`${At}${e}`])).get(`${At}${e}`);return r===void 0?void 0:H(r)}async listChats(e){this.assertOpen();let t=await this.kv.list(At),r=[];for(let s of t){let i=H(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:`${Ct}${e.id}`,value:je(e)}]);}async getContact(e){this.assertOpen();let r=(await this.kv.get([`${Ct}${e}`])).get(`${Ct}${e}`);return r===void 0?void 0:H(r)}async listContacts(){return this.assertOpen(),(await this.kv.list(Ct)).map(t=>H(t.value))}async savePresence(e,t){this.assertOpen(),await this.kv.set([{key:`${en}${e}`,value:je(t)}]);}async getPresence(e){this.assertOpen();let r=(await this.kv.get([`${en}${e}`])).get(`${en}${e}`);return r===void 0?void 0:H(r)}async saveScheduledJob(e){this.assertOpen(),await this.kv.set([{key:`${tn}${e.id}`,value:je(e),sortKey:e.fireAt}]);}async listScheduledJobs(){return this.assertOpen(),(await this.kv.list(tn)).map(t=>H(t.value))}async deleteScheduledJob(e){this.assertOpen(),await this.kv.del([`${tn}${e}`]);}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 m("STORE_CLOSED","ConvexMessageStore is closed")}};var sa=(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};exports.AudioProcessor=Y;exports.BufferConverter=C;exports.Client=Hr;exports.CommandRegistry=Ce;exports.CommunityModule=Ae;exports.ConvexAuthStore=rs;exports.ConvexMessageStore=ds;exports.DocumentProcessor=Ve;exports.EditBuilder=we;exports.FFMPEG_CONSTANTS=M;exports.FFmpegProcessor=z;exports.FileAuthStore=et;exports.FileManager=J;exports.GroupModule=ve;exports.ImageProcessor=D;exports.Media=Z;exports.MemoryAuthStore=zr;exports.MemoryMessageStore=rt;exports.MessageBuilder=V;exports.MimeValidator=k;exports.NewsletterModule=Me;exports.PostgresAuthStore=ts;exports.PostgresMessageStore=os;exports.PresenceModule=be;exports.PrivacyModule=Se;exports.RateLimiter=Q;exports.RedisAuthStore=ns;exports.RedisMessageStore=cs;exports.SELF_ONLY_PROTOCOL_TYPES=iu;exports.Scheduler=Pe;exports.SqliteAuthStore=es;exports.SqliteMessageStore=ss;exports.StickerProcessor=$e;exports.TaskQueue=Ee;exports.TypedEventEmitter=pt;exports.VideoProcessor=U;exports.ZaileysAutomationError=b;exports.ZaileysBuilderError=f;exports.ZaileysCommandError=P;exports.ZaileysDomainError=T;exports.ZaileysStoreError=m;exports.adoptLogger=Gt;exports.attachCommandDispatcher=qt;exports.buildMessageContext=Yt;exports.chunk=sa;exports.createAuthGuard=Zn;exports.createConnectionStateMachine=tr;exports.createLogger=Oi;exports.createOperationGuard=Jt;exports.createPairingFlow=Xn;exports.createReconnectStrategy=er;exports.deleteMessage=Bt;exports.detectFileType=I;exports.dropSpoofedSelfOnly=rr;exports.ffmpegTransform=W;exports.forwardMessage=Wt;exports.generateId=Ke;exports.initializeFFmpeg=Ot;exports.isFatalDisconnect=Ie;exports.isJid=Ze;exports.isRateLimited=tt;exports.makeCacheableAuthStore=Gn;exports.mapDisconnectReason=zn;exports.normalizePhoneNumber=Ai;exports.parseCommand=jt;exports.printQrToTerminal=Qn;exports.reactToMessage=Ft;exports.renderQrInTerminal=bi;exports.resolveUsername=Ut;exports.runBroadcast=$t;exports.runMiddleware=Kt;exports.shouldClearAuth=Yn;exports.shouldReconnect=Vl;exports.signalKeyStoreFromAuthStore=Hn;exports.validateE164=Ci;