zaileys 4.1.1 → 4.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +2 -2
- package/dist/index.d.cts +2 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.mjs +2 -2
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -7,12 +7,12 @@
|
|
|
7
7
|
`)}:{type:"code",content:u.join(`
|
|
8
8
|
`)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&Es.test(d)){s();let u=[wn(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)u.push(wn(e[i])),i++;t.push({type:"table",rows:u});continue}let l=yn.exec(o);if(l){s();let u=[l[1]];for(i++;i<e.length;){let h=yn.exec(e[i]);if(!h)break;u.push(h[1]),i++;}t.push({type:"image",url:u.length===1?u[0]:u});continue}r.push(o),i++;}return s(),t};var An=(n,e)=>{if(typeof n!="string"||!n.trimStart().startsWith("BEGIN:VCARD"))throw new m("INVALID_OPTIONS","contact() requires a vcard string starting with BEGIN:VCARD");let t={contacts:[{vcard:n}]};return {contacts:t}};var Mn=async(n,e)=>{if(typeof e?.fileName!="string"||e.fileName.trim().length===0)throw new m("INVALID_OPTIONS","document() requires a non-empty fileName");let{buffer:t,mime:r}=await k(n),s={document:t,fileName:e.fileName,mimetype:e.mimetype??r};return e.caption!==void 0&&(s.caption=e.caption),s};var Cn=10,En=n=>{if(typeof n?.buttonText!="string"||n.buttonText.trim().length===0)throw new m("INVALID_OPTIONS","list() requires a non-empty buttonText");if(!Array.isArray(n.sections)||n.sections.length===0)throw new m("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 m("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 m("INVALID_OPTIONS","list row id must be a non-empty string");if(typeof d.title!="string"||d.title.trim().length===0)throw new m("INVALID_OPTIONS","list row title must be a non-empty string");if(t.has(d.id))throw new m("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>Cn)throw new m("INVALID_OPTIONS",`list() accepts at most ${Cn} 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}),{[L]:{interactiveMessage:i}}};var bn=(n,e,t)=>{if(typeof n!="number"||Number.isNaN(n)||n<-90||n>90)throw new m("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 m("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 Pn=2,Tn=12,kn=(n,e,t)=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","poll() requires a non-empty question");if(!Array.isArray(e)||e.length<Pn)throw new m("INVALID_OPTIONS",`poll() requires a minimum of ${Pn} options`);if(e.length>Tn)throw new m("INVALID_OPTIONS",`poll() accepts a maximum of ${Tn} options`);let r=new Set;for(let i of e){if(typeof i!="string"||i.trim().length===0)throw new m("INVALID_OPTIONS","poll options must be non-empty strings");if(r.has(i))throw new m("INVALID_OPTIONS",`duplicate poll options: ${i}`);r.add(i);}return {poll:{name:n,values:e,selectableCount:t?.multipleChoice?e.length:1}}};var In=async(n,e)=>{let{buffer:t}=await k(n),r;try{r=await new z(t).sticker.create();}catch(i){throw new m("MEDIA_LOAD_FAILED",`sticker() conversion failed: ${i.message}`,{cause:i})}return {sticker:r,isAnimated:e?.animated??false}};var On=3,xn=n=>{if(typeof n?.body!="string"||n.body.trim().length===0)throw new m("INVALID_OPTIONS","template() requires a non-empty body");if(!Array.isArray(n.buttons)||n.buttons.length===0)throw new m("INVALID_OPTIONS","template() requires at least one button");if(n.buttons.length>On)throw new m("INVALID_OPTIONS",`template() accepts at most ${On} 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 Je=n=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var Rn=(n,e)=>({recipient:n,...e?{resolveRecipient:e}:{}});var xs=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],J=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r){return new n(e,Rn(t,r))}to(e){return this.internal.recipient=e,delete this.internal.resolveRecipient,this}text(e,t){return t?.rich===true?this.internal.content=gn(Sn(e),t):this.internal.content=Je(e),this}image(e,t){return this.internal.pendingContent=ne(e,t),this}video(e,t){return this.internal.pendingContent=re(e,t),this}audio(e,t){return this.internal.pendingContent=un(e,t),this}document(e,t){return this.internal.pendingContent=Mn(e,t),this}sticker(e,t){return this.internal.pendingContent=In(e,t),this}buttons(e,t){return this.internal.content=je(e,t),this}carousel(e,t){return this.internal.content=fn(e,t),this}list(e){return this.internal.content=En(e),this}poll(e,t,r){return this.internal.content=kn(e,t,r),this}location(e,t,r){return this.internal.content=bn(e,t,r),this}contact(e){return this.internal.content=An(e),this}template(e){return this.internal.content=xn(e),this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new m("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 m("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new m("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 m("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),an(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 m("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[L];if(i!==void 0){let d=s[bt],l=s[Tt];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 m("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new m("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await k(t.src),s=await ao.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 m("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 h=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&h)for(let f of r){let g=h[f.index]?.header;g&&await this.uploadHeaderMedia(g,f);}}catch(u){throw new m("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=ao.generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new m("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:xs}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new m("SEND_FAILED","socket relayMessage rejected",{cause:u})}return c.key}};var pe=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Je(e),this}image(e,t){return this.pendingContent=ne(e,t),this}video(e,t){return this.pendingContent=re(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 m("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new m("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 m("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new m("SEND_FAILED","socket returned no message key");return r.key}};var Ln=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new m("INVALID_OPTIONS","message key is missing remoteJid");return e},_n=n=>{if(!n?.key)throw new m("SEND_FAILED","socket returned no message key");return n.key},It=async(n,e,t={})=>{let r=Ln(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new m("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},Ot=async(n,e,t)=>{let r=Ln(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return _n(s)},xt=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new m("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return _n(i)};var Rs=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,$e=n=>Rs.test(n),Rt=async(n,e,t,r=Ls)=>{if($e(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 m("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);}},Ls=new Map;var b=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 me=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new b("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 b("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 fe=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 ge=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("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 he=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 E=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 _s=n=>{let e=n[0];return e==="{"||e==="["},Ns=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Ds=n=>n===" "||n===" "||n===`
|
|
10
|
+
`:""}${n.body}`};return n.footer!==void 0&&(t.footer=n.footer),je(n.buttons,t)};var Je=n=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var Rn=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var xs=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],J=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r,s){return new n(e,Rn(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=gn(Sn(e),t):this.internal.content=Je(e),this}image(e,t){return this.internal.pendingContent=ne(e,t),this}video(e,t){return this.internal.pendingContent=re(e,t),this}audio(e,t){return this.internal.pendingContent=un(e,t),this}document(e,t){return this.internal.pendingContent=Mn(e,t),this}sticker(e,t){return this.internal.pendingContent=In(e,t),this}buttons(e,t){return this.internal.content=je(e,t),this}carousel(e,t){return this.internal.content=fn(e,t),this}list(e){return this.internal.content=En(e),this}poll(e,t,r){return this.internal.content=kn(e,t,r),this}location(e,t,r){return this.internal.content=bn(e,t,r),this}contact(e){return this.internal.content=An(e),this}template(e){return this.internal.content=xn(e),this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new m("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 m("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new m("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 m("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),an(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 m("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[L];if(i!==void 0){let d=s[bt],l=s[Tt];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 m("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new m("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await k(t.src),s=await ao.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 m("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 h=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&h)for(let f of r){let g=h[f.index]?.header;g&&await this.uploadHeaderMedia(g,f);}}catch(u){throw new m("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=ao.generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new m("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:xs}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new m("SEND_FAILED","socket relayMessage rejected",{cause:u})}return this.internal.recordSent?.(c),c.key}};var pe=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Je(e),this}image(e,t){return this.pendingContent=ne(e,t),this}video(e,t){return this.pendingContent=re(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 m("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new m("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 m("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new m("SEND_FAILED","socket returned no message key");return r.key}};var Ln=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new m("INVALID_OPTIONS","message key is missing remoteJid");return e},_n=n=>{if(!n?.key)throw new m("SEND_FAILED","socket returned no message key");return n.key},It=async(n,e,t={})=>{let r=Ln(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new m("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},Ot=async(n,e,t)=>{let r=Ln(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return _n(s)},xt=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new m("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return _n(i)};var Rs=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,$e=n=>Rs.test(n),Rt=async(n,e,t,r=Ls)=>{if($e(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 m("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);}},Ls=new Map;var b=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 me=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new b("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 b("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 fe=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 ge=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("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 he=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 E=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 _s=n=>{let e=n[0];return e==="{"||e==="["},Ns=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Ds=n=>n===" "||n===" "||n===`
|
|
11
11
|
`||n==="\r",Bs=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(Ds(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},Fs=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},Ws=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function Lt(n,e){let t=Fs(n,e);if(t===null)return Ws(n);let r=n.slice(t.length),s=Bs(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 h=d.slice(0,l),f=d.slice(l+1);i.flags[h]=f;continue}let u=s[a+1];u!==void 0&&!u.startsWith("--")?(i.flags[d]=u,a+=1):i.flags[d]=true;continue}if(!o&&_s(c)){let d=Ns(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var Us=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new E("INVALID_COMMAND_NAME","empty command segment in spec");return e},Ve=n=>n.join(" "),ye=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new E("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>Us(a)),s=r[0],i=r.slice(1).map(a=>Ve(a)),o={name:Ve(s),aliases:i,parts:s,handler:t};for(let a of r){let c=Ve(a);if(this.paths.has(c))throw new E("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(Ve(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 _t(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new E("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 E?c:new E("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function Nt(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=Lt(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(_t(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let l=d instanceof E?d:new E("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 C=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 js=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Z=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new C("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new C("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new C("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??js;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 Ks={"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},qs=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function Dt(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??qs,i={...Ks,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,l)=>{let u=i[d]??0,h=o.get(d);if(h!==void 0&&u>0){let f=u-(r()-h);f>0&&await s(f);}return o.set(d,r()),l()};return {run(d,l){if(!t)return l();let h=(a.get(d)??Promise.resolve()).then(()=>c(d,l),()=>c(d,l));return a.set(d,h.then(()=>{},()=>{})),h}}}var Js={maxRetries:0,backoffMs:()=>0},$s=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),we=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??Js,this.sleep=t.sleep??$s;}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 Vs=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function Bt(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 Z({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},l=c?new we({concurrency:1,retry:c},d):void 0,u=n.length,h=0;for(let f of n){await a.acquire(f);let g=()=>e(t.sendTo(f)).then(()=>{});try{l?await l.add(g):await g(),s.sent.push(f),h+=1,r.onProgress?.(h,u,f,!0);}catch(y){s.failed.push({jid:f,error:Vs(y)}),h+=1,r.onProgress?.(h,u,f,false);}}return s}var Gs=1e3,ve=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??Gs,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new C("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 C("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)},Ys=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",Se=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 C("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),Ys(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 C("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 C("SCHEDULE_INVALID","scheduling interactive/relayed content is not supported; schedule a text or media message")}},i=J.create(s,"");try{await e(i);}catch(o){throw o instanceof C?o:new C("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new C("SCHEDULE_INVALID","scheduled builder produced no content");return t}};var X="[zaileys]",Zs="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 Dn(n){switch(n.kind){case "connecting":return `${X} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${X} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${X} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${X} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${X} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
|
|
12
12
|
${X} ${Zs}`:t}case "disconnect":return n.willReconnect?null:`${X} Disconnected (${n.reason}).`;default:return null}}var Nn=false,Xs=["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:"],Qs=n=>typeof n[0]=="string"&&Xs.some(e=>n[0].startsWith(e));function Bn(){if(Nn)return;Nn=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{Qs(r)||t(...r);};};n("info"),n("warn"),n("error");}var p=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 ti="./.zaileys/auth",ni=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),Me=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",He=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??ti;}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,ao.BufferJSON.reviver);}catch(o){if(Me(o))return;throw new p("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(!Me(d))throw new p("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,ao.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(!Me(i))throw new p("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,ao.BufferJSON.reviver)}catch(e){if(Me(e))return;throw new p("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,ao.BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await fs.promises.unlink(this.credsPath());}catch(e){if(!Me(e))throw new p("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return Ae__default.default.join(this.basePath,"creds.json")}signalDir(e){return Ae__default.default.join(this.basePath,"signal",String(e))}signalPath(e,t){return Ae__default.default.join(this.signalDir(e),`${ni(t)}.json`)}async atomicWrite(e,t){let r=Ae__default.default.join(Ae__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 p("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new p("STORE_CLOSED","FileAuthStore is closed")}};function Fn(n,e){let t=n.signal,s=ao.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 Wn(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 si=429;function Un(n){if(n===si)return "rate-limited";switch(n){case ao.DisconnectReason.loggedOut:return "logged-out";case ao.DisconnectReason.forbidden:return "forbidden";case ao.DisconnectReason.connectionLost:return "connection-lost";case ao.DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case ao.DisconnectReason.connectionClosed:return "connection-closed";case ao.DisconnectReason.connectionReplaced:return "connection-replaced";case ao.DisconnectReason.badSession:return "bad-session";case ao.DisconnectReason.unavailableService:return "unavailable-service";case ao.DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Ce(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function ze(n){return n==="rate-limited"}function jn(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function Sl(n){return !Ce(n)}var Ye={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},ii=3e5;function Kn(n={}){let e=n.enabled??Ye.enabled,t=n.maxQrAttempts??Ye.maxQrAttempts,r=n.maxPairingAttempts??Ye.maxPairingAttempts,s=n.pairingCooldownMs??Ye.pairingCooldownMs,i=0,o=0,a=0,c=h=>h<=0?0:Math.min(s*h,ii);return {evaluate:(h,f)=>{if(!e)return {allowed:true,waitMs:0,attempts:h==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(h==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let g=c(o),y=f-a;return o>0&&y<g?{allowed:false,reason:"cooldown",waitMs:g-y,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:(h,f)=>{h==="pairing"?(o+=1,a=f):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var oi=/[\s\-()+]/g;function ai(n){return typeof n!="string"?"":n.replace(oi,"")}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 qn(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 li(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{di__default.default.generate(n,{small:true},t=>e(t));})}async function Jn(n,e=t=>{process.stdout.write(t);}){let t=await li(n);e(t+`
|
|
13
13
|
`);}var ie={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function $n(n,e){let t=n?.enabled??ie.enabled,r=n?.maxAttempts??ie.maxAttempts,s=n?.initialDelayMs??ie.initialDelayMs,i=n?.maxDelayMs??ie.maxDelayMs,o=n?.jitterFactor??ie.jitterFactor,a=n?.rateLimitedDelayMs??ie.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:h=>{if(!t||Ce(h))return null;let f=d+1;if(f>r)return null;if(d=f,ze(h))return {attempt:f,delayMs:a};let g=Math.pow(2,f-1),y=Math.min(i,s*g),M=1+(c()*2-1)*o,A=y*M,j=Math.min(i,Math.max(0,A));return {attempt:f,delayMs:Math.round(j)}},reset:()=>{d=0;},get attempts(){return d}}}var ui={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 Vn(n="idle"){let e=n,t=new Set,r=s=>ui[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 Ft=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,Ze=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=Ft(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(Ft(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(Ft(l.key));if(u){let h={...u,...l.update};this.saveMessage(h).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 h={...this.chats.get(l.id)??{},...l};this.saveChat(h).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 p("STORE_CLOSED","MemoryMessageStore is closed")}};var mi=["silent","fatal","error","warn","info","debug","trace"];function fi(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":mi.includes(e)?e:"silent"}function gi(n={}){let e=fi(n.level),t=pi__default.default({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var Gn=["debug","info","warn","error","fatal"];function hi(n){if(n===null||typeof n!="object")return false;for(let e of Gn)if(typeof n[e]!="function")return false;return true}function Ee(){}function yi(n){let e={debug:Ee,info:Ee,warn:Ee,error:Ee,fatal:Ee};for(let t of Gn){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function Wt(n,e){return n===void 0?e??gi():hi(n)?n:yi(n)}var Ll=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),Hn=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 wi=new Set(["offer","ringing"]),vi=new Set(["timeout","reject","accept","terminate"]),zn=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},Yn=n=>typeof n.id!="string"||n.id.length===0||!wi.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:zn(n.date),status:n.status},Zn=n=>typeof n.id!="string"||n.id.length===0||!vi.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:zn(n.date),status:n.status};var O=n=>typeof n=="string"&&n.length>0,Si=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},Xn=(n,e,t)=>n.filter(r=>O(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return O(i)&&(s.participantAlt=i),O(e)&&(s.authorPn=e),O(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),Qn=n=>O(n?.id)?{groupId:n.id,update:Si(n),timestamp:Date.now()}:null,er=n=>{if(!O(n?.groupId)||!O(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 O(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},Ai=new Set(["add","invite","invite-link"]),Mi=new Set(["remove","leave"]),tr=n=>{if(!O(n?.id)||!Ai.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Xn(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 O(n.author)&&(t.by=n.author),t},nr=n=>{if(!O(n?.id)||!Mi.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Xn(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 O(n.author)&&(t.by=n.author),t};var be=n=>typeof n!="string"||n.length===0?null:ao.jidNormalizedUser(n),$=n=>typeof n=="string"&&n.length>0?n:void 0,bi=["@s.whatsapp.net","@c.us"],Pi=n=>n.endsWith("@lid"),Ti=n=>bi.some(e=>n.endsWith(e)),B=(n,e)=>{if(!n)return null;let t=$(n.participant)??n.remoteJid,r=be(t);if(r===null)return null;let s=$(n.participantAlt)??$(n.remoteJidAlt),i=s!=null?be(s):null,o=$(n.participantUsername)??$(n.remoteJidUsername),a={jid:r,isMe:n.fromMe===true},c=i!==null?[r,i]:[r],d=c.find(Pi),l=c.find(Ti);d!==void 0&&(a.lid=d),l!==void 0&&(a.pn=l),o!==void 0&&(a.username=o);let u=$(e);return u!==void 0&&(a.pushName=u),a},rr=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=$(n.participant),r=$(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=B(s);return o&&(i.sender=o),i},Xe=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 Pe=n=>ao.isJidGroup(n)===true,Qe=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"],Ii=["list_select","single_select"],W=n=>typeof n=="string"&&n.length>0,ir=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return B(n.key,e)},or=n=>Qe(n.messageTimestamp)??0,ar=(n,e)=>{if(!W(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}},et=(n,e)=>{for(let t of e){let r=n[t];if(W(r))return r}},cr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&W(r.selectedButtonId))return Ut(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&W(s.selectedId))return Ut(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&W(i.name)&&ki.includes(i.name)){let o=ar(i.paramsJson,e.logger);if(!o)return null;let a=et(o,["id","button_id"]);return a===void 0?null:Ut(n,a,et(o,["display_text"])??null)}return null},Ut=(n,e,t)=>{let r=ir(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:or(n)};return W(t)&&(s.buttonText=t),s},dr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(W(s))return sr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&W(i.name)&&Ii.includes(i.name)){let o=ar(i.paramsJson,e.logger);if(!o)return null;let a=et(o,["row_id","id"]);return a===void 0?null:sr(n,a,et(o,["title"])??null)}return null},sr=(n,e,t)=>{let r=ir(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:or(n)};return W(t)&&(s.title=t),s};var Oi=new Set(["available","unavailable","composing","recording","paused"]),xi=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,lr=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:xi(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},ur=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"||!Oi.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},Te=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 Li=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},_i=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")},Ni=n=>{let e=ao.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"},Di=n=>n.trim().endsWith("?"),Bi=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),Fi=(n,e)=>{if(e.length===0)return false;let t;try{t=ao.jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return ao.jidNormalizedUser(r)===t}catch{return r===n}})},Wi=(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)}},Kt=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&Pe(e),r={uniqueId:_i(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:Ni(n.sender.jid),timestamp:typeof n.message.messageTimestamp=="number"?n.message.messageTimestamp*1e3:0,text:n.text,mentions:n.mentions,links:Li(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:Di(n.text),isPrefix:Bi(n.text,n.prefixes),isTagMe:Fi(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:Wi(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(r.media=n.media),r};var Ui={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},ji=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Ui[e]];if(r==null||typeof r!="object")return null;let s=r.mimetype;return typeof s=="string"&&s.length>0?s:null},mr=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys'),s=await r(n,"buffer",{}),i=ji(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")}},fr=(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 ke={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},hr=n=>{let e=n?.remoteJid;return typeof e=="string"&&e.length>0?e:""},w=n=>n!=null&&typeof n=="object"?n:null,U=n=>typeof n=="string"&&n.length>0?n:null,Ie=(...n)=>{for(let e of n){let t=U(e);if(t!=null)return t}return null},Ki=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage"],yr=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of Ki){let i=w(w(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},qi=n=>{let t=w(w(w(n.botForwardedMessage)?.message)?.richResponseMessage)??w(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=U(w(o)?.messageText);a!=null&&s.push(a);}let i=s.join(`
|
|
14
14
|
`).trim();return i.length>0?i:null},Ji=n=>{let e=w(n.templateMessage),t=w(e?.hydratedTemplate)??w(e?.hydratedFourRowTemplate);return U(t?.hydratedContentText)},$i=n=>Ie(w(n.pollCreationMessage)?.name,w(n.pollCreationMessageV2)?.name,w(n.pollCreationMessageV3)?.name),Vi=n=>{let e=w(n.locationMessage)??w(n.liveLocationMessage);if(e==null)return null;let t=Ie(e.name,e.address);if(t!=null){let i=U(e.name),o=U(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},Gi=n=>{let e=U(w(n.contactMessage)?.displayName);if(e!=null)return e;let t=w(n.contactsArrayMessage),r=U(t?.displayName);if(r!=null)return r;let s=t?.contacts;if(Array.isArray(s)){let i=s.map(o=>U(w(o)?.displayName)).filter(o=>o!=null);if(i.length>0)return i.join(", ")}return null},wr=n=>Ie(n.conversation,w(n.extendedTextMessage)?.text,qi(n),U(w(w(n.interactiveMessage)?.body)?.text),w(n.buttonsMessage)?.contentText,w(n.listMessage)?.description,Ji(n),$i(n),Vi(n),Gi(n)),Hi=n=>Ie(w(n.buttonsResponseMessage)?.selectedDisplayText,w(n.buttonsResponseMessage)?.selectedButtonId,w(n.templateButtonReplyMessage)?.selectedDisplayText,w(n.templateButtonReplyMessage)?.selectedId,w(n.listResponseMessage)?.title,w(w(n.listResponseMessage)?.singleSelectReply)?.selectedRowId,w(w(n.interactiveResponseMessage)?.body)?.text),zi=n=>Ie(w(n.imageMessage)?.caption,w(n.videoMessage)?.caption,w(n.documentMessage)?.caption,w(n.documentMessage)?.fileName),Yi=n=>{let e=w(n.message);return e==null?null:wr(yr(e))},nt=n=>{let e=w(n.message);if(e==null)return null;let t=yr(e);return wr(t)??Hi(t)??zi(t)},qt=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(ke)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},Zi=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[ke[e]];return r==null||typeof r!="object"?null:r},Xi=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(ke)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},Qi=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,gr=n=>{if(n==null)return "text";for(let e of Object.values(ke))if(n[e]!=null)return e.replace("Message","");return "text"},eo=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 l=await e.resolveQuoted(r,t);if(l!=null&&l.message!=null){let u=nt(l)??"",h=oe(l,e,gr(l.message),u);if(h!==null)return h}}let s=rr(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&&ao.jidNormalizedUser(o)===ao.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=nt(c)??"";return oe(c,e,gr(a),d)}catch{return null}},oe=(n,e,t,r,s)=>{let i=n.key;if(i==null)return null;let o=B(i,n.pushName??void 0);if(o===null)return null;let a=hr(i);if(a.length===0)return null;let c=qt(n),d=Pe(a),l=a.endsWith("@broadcast"),u=a.endsWith("@newsletter"),h=c?.isForwarded===true||(c?.forwardingScore??0)>0,f=Xi(n),g=Qi(n,c),y=e.channelId??"",M=e.receiverId??"",A=e.prefixes??[],j=()=>d&&e.resolveRoomName!=null?e.resolveRoomName(a):Promise.resolve(null),Ne=e.resolveReceiverName??(()=>Promise.resolve(null)),ht=()=>eo(c,e,a),yt=a.length>0?a:o.pn??o.jid,wt=(At,Qr)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(yt,At,Qr,n),vt=At=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(i,At),{mentionedJids:St}=Xe(c),Ht={message:n,key:i,channelId:y,receiverId:M,selfJid:e.selfJid,text:r,chatType:t,sender:o,mentions:St,isViewOnce:f,isEphemeral:g,isForwarded:h,isBroadcast:l,isNewsletter:u,prefixes:A,resolveRoomName:j,resolveReceiverName:Ne,resolveReplied:ht,reply:wt,react:vt},zt=s!==void 0?{...Ht,media:s}:Ht;return Kt(e.citationConfig!==void 0?{...zt,citationConfig:e.citationConfig}:zt)},vr=(n,e)=>{let t=Yi(n);return t===null?null:oe(n,e,"text",t)},Oe=(n,e,t)=>{let r=Zi(e,n);if(r===null)return null;let s=typeof r.caption=="string"?r.caption:"",i=n,o=mr(e,n,t.logger),a=fr(e,n,t.logger);return oe(e,t,i,s,{buffer:async()=>(await o()).buffer,stream:a})},Sr=(n,e)=>Oe("image",n,e),Ar=(n,e)=>Oe("video",n,e),Mr=(n,e)=>Oe("audio",n,e),Cr=(n,e)=>Oe("document",n,e),Er=(n,e)=>Oe("sticker",n,e),to=(n,e)=>{try{return ao.jidNormalizedUser(n)===ao.jidNormalizedUser(e)}catch{return n===e}},br=(n,e)=>{if(n.key==null)return null;let r=qt(n),{mentionedJids:s}=Xe(r);if(s.length===0||!s.some(l=>to(l,e.selfJid)))return null;let o=n.message;if(o==null)return null;let a=nt(n)??"",c="text";if(o!=null){let l=Object.values(ke);for(let u of l)if(o[u]!=null){c=u.replace("Message","");break}}let d=oe(n,e,c,a);return d===null?null:{...d,mentionedJids:s,selfJid:e.selfJid}},Pr=(n,e)=>{let t=n.key;if(t==null)return null;let r=hr(t);if(r.length===0||!Pe(r))return null;let{mentionAll:s}=Xe(qt(n));if(!s||n.message==null)return null;let o=nt(n)??"",a=oe(n,e,"text",o);return a===null?null:{...a,isMentionAll:true,selfJid:e.selfJid}};var Q=(n,e)=>{let t=Qe(n);return t===null?e:t},no=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;return typeof s=="string"?s:""},ro=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],kr=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=B(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:Q(t.senderTimestampMs,0)}},Ir=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==ao.proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=B(n.key,e.pushName);return s===null?null:{key:r,newContent:no(t.editedMessage),editedAt:Q(n.update.messageTimestamp,0),sender:s}},Or=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==ao.proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=B(n.key,e.pushName);if(s===null)return null;let i=be(n.key.remoteJid),o=be(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:Q(n.update.messageTimestamp,0)}},xr=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=B(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:ro(t.vote?.selectedOptions),voter:s,timestamp:Q(t.senderTimestampMs,Q(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:Q(r.senderTimestampMs,Q(n.update.messageTimestamp,0))}:null}return null};var rt=n=>Array.isArray(n)?n:[],so=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function Rr(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?f=>{let g=s.get(f);if(g!==void 0)return g;let y=t.groupMetadata;if(y==null)return Promise.resolve(null);let M=y(f).then(A=>A?.subject??null).catch(()=>null);return s.set(f,M),M}: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=(f,g)=>{let y=(...M)=>{try{g(M[0]);}catch(A){t.logger?.warn(A,`inbound pipeline: handler for ${f} threw`);}};e.ev.on(f,y),r.push(()=>e.ev.off(f,y));},l=f=>{u(()=>vr(f,o),g=>n.emit("text",g)),u(()=>Sr(f,o),g=>n.emit("image",g)),u(()=>Ar(f,o),g=>n.emit("video",g)),u(()=>Mr(f,o),g=>n.emit("audio",g)),u(()=>Cr(f,o),g=>n.emit("document",g)),u(()=>Er(f,o),g=>n.emit("sticker",g)),u(()=>br(f,o),g=>n.emit("mention",g)),u(()=>Pr(f,o),g=>n.emit("mention-all",g)),u(()=>cr(f,a),g=>n.emit("button-click",g)),u(()=>dr(f,a),g=>n.emit("list-select",g));},u=(f,g)=>{let y;try{y=f();}catch(M){t.logger?.warn(M,"inbound pipeline: decoder threw");return}y!=null&&g(y);};d("messages.upsert",f=>{let g=Hn(f);for(let y of g.messages)t.ignoreMe===!0&&y.key?.fromMe===!0||l(y);}),d("messages.update",f=>{for(let g of rt(f))u(()=>Ir(g,c),y=>n.emit("edit",y)),u(()=>Or(g,c),y=>n.emit("delete",y)),u(()=>xr(g,c),y=>n.emit("poll-vote",y));}),d("messages.reaction",f=>{for(let g of rt(f))u(()=>kr(g,c),y=>n.emit("reaction",y));}),d("groups.update",f=>{for(let g of rt(f))u(()=>Qn(g),y=>n.emit("group-update",y));}),d("group-participants.update",f=>{let g=f;u(()=>tr(g),y=>n.emit("group-join",y)),u(()=>nr(g),y=>n.emit("group-leave",y));}),d("group.member-tag.update",f=>{u(()=>er(f),g=>n.emit("member-tag",g));}),d("call",f=>{for(let g of rt(f))u(()=>Yn(g),y=>n.emit("call-incoming",y)),u(()=>Zn(g),y=>n.emit("call-ended",y));}),d("messaging-history.status",f=>{u(()=>lr(f),g=>n.emit("history-sync",g));}),d("presence.update",f=>{let g=(()=>{try{return ur(f)}catch(y){return t.logger?.warn(y,"inbound pipeline: decodePresence threw"),[]}})();for(let y of g)n.emit("presence",y);}),d("connection.update",f=>{let g=so(f);g!==null&&u(()=>jt({source:"connection-update",reachoutTimeLock:g}),y=>n.emit("limited",y));}),d("message-capping.update",f=>{u(()=>jt({source:"message-capping",capInfo:f}),g=>n.emit("limited",g));}),d("newsletter.reaction",f=>{u(()=>Te({source:"reaction",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter.view",f=>{u(()=>Te({source:"view",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter-participants.update",f=>{u(()=>Te({source:"participants",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter-settings.update",f=>{u(()=>Te({source:"settings",payload:f}),g=>n.emit("newsletter",g));});let h=false;return {detach(){if(!h){h=true;for(let f of r)f();r.length=0;}}}}var st=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=oo,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},oo=Symbol("zaileys.typed-ee.tag");var lo="default",uo="qr",_r=6e4,Nr=class extends st{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=Vn();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:Wt(e.logger)}),this.sessionId=e.sessionId??lo,this.logger=Wt(e.logger),this.authType=e.authType??uo,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&Bn(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new He({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new Ze,this.reconnectStrategy=$n(this.reconnectOptions),this.authGuard=Kn(e.authGuard),this.operationGuard=Dt(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new Z({perSec:t}):void 0,this.commandPrefixes=po(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 ao.fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=ao.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=Dn(e);t&&process.stderr.write(`${t}
|
|
15
|
-
`);}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 me(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new fe(()=>this._socket)}get newsletter(){return this._newsletter??=new ge(()=>this._socket,this.operationGuard)}get community(){return this._community??=new he(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new ve(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),Bt(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Se({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=Fn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Wn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:_r,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=ao__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??ao.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 ye).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=Nt({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 E("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();return $e(e)?J.create(t,e):J.create(t,e,r=>this.resolveRecipient(r))}edit(e){return new pe(this.requireSocket(),e)}async delete(e,t){await It(this.requireSocket(),e,t);}async react(e,t){return Ot(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return xt(r,this.store,e,s)}resolveRecipient(e){return Rt(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new m("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=qn({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 Jn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+_r});}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=Rr(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=mo(e?.error),r=Un(t),s=false;if(jn(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(!Ce(r)&&!this.authExhausted){ze(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 po(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function mo(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 Dr=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 p("STORE_CLOSED","MemoryAuthStore is closed")}};var it=null,fo=async()=>{if(it)return it;try{return it=(await import('better-sqlite3')).default,it}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Jt="default",Fr=500,Wr=n=>Array.from({length:n},()=>"?").join(","),Ur=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},jr=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(Jt);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Jt,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Jt);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Ur(t,Fr)){let o=Wr(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=Wr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Ur(t,Fr))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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new p("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 fo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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;
|
|
15
|
+
`);}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 me(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new fe(()=>this._socket)}get newsletter(){return this._newsletter??=new ge(()=>this._socket,this.operationGuard)}get community(){return this._community??=new he(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new ve(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),Bt(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Se({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=Fn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Wn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:_r,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=ao__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??ao.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 ye).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=Nt({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 E("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 $e(e)?J.create(t,e,void 0,r):J.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new pe(this.requireSocket(),e)}async delete(e,t){await It(this.requireSocket(),e,t);}async react(e,t){return Ot(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return xt(r,this.store,e,s)}resolveRecipient(e){return Rt(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new m("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=qn({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 Jn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+_r});}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=Rr(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=mo(e?.error),r=Un(t),s=false;if(jn(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(!Ce(r)&&!this.authExhausted){ze(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 po(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function mo(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 Dr=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 p("STORE_CLOSED","MemoryAuthStore is closed")}};var it=null,fo=async()=>{if(it)return it;try{return it=(await import('better-sqlite3')).default,it}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Jt="default",Fr=500,Wr=n=>Array.from({length:n},()=>"?").join(","),Ur=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},jr=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(Jt);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Jt,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Jt);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Ur(t,Fr)){let o=Wr(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=Wr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Ur(t,Fr))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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new p("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 fo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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;
|
|
16
16
|
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 p("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,ao.BufferJSON.replacer),"utf8")}catch(t){throw new p("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,ao.BufferJSON.reviver)}catch(t){throw new p("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var at,go=async()=>(at||(at=import('pg').catch(n=>{throw at=void 0,new p("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),at),ho="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",yo="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",Kr=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 p("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new p("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 p("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 go(),r=t.Pool??t.default?.Pool;if(!r)throw new p("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(ho),await e.query(yo);}catch(t){throw new p("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"),ao.BufferJSON.reviver);}return s}catch(i){throw i instanceof p?i:new p("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,ao.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 p("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 p("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 p("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,ao.BufferJSON.reviver)}catch(t){throw t instanceof p?t:new p("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,ao.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 p("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 p("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var wo="zaileys",vo=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],So=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},qr=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new p("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new p("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??wo,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,ao.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,ao.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 vo){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,ao.BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,ao.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 p("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 So(r)?new p("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new p("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 p("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 p("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new p("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 p("STORE_CLOSED","RedisAuthStore is closed")}};var Ao="zaileys",xe={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Mo=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},ae=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new p("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new p("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Ao,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(xe.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(xe.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(xe.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(xe.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(xe.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 Mo(r)?new p("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new p("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 p("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new p("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new p("STORE_CLOSED","Convex store is closed")}};var lt="creds",Co="signal:",Re=(n,e)=>`${Co}${n}:${e}`,Jr=class{creds;signal;kv;constructor(e){this.kv=new ae(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([lt])).get(lt);return s===void 0?void 0:JSON.parse(s,ao.BufferJSON.reviver)},async writeCreds(r){await t.set([{key:lt,value:JSON.stringify(r,ao.BufferJSON.replacer)}]);},async deleteCreds(){await t.del([lt]);}},this.signal={async read(r,s){let i=s.map(c=>Re(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(Re(r,c));a[c]=d===void 0?void 0:JSON.parse(d,ao.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(Re(o,c)):s.push({key:Re(o,c),value:JSON.stringify(d,ao.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=>Re(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var ut=null,Eo=async()=>{if(ut)return ut;try{return ut=(await import('better-sqlite3')).default,ut}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},pt=n=>{try{return Buffer.from(JSON.stringify(n,ao.BufferJSON.replacer),"utf8")}catch(e){throw new p("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},ee=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,ao.BufferJSON.reviver)}catch(e){throw new p("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},$r=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,pt(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?ee(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=>ee(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,pt(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?ee(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>ee(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,pt(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?ee(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>ee(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,pt(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?ee(r.data):void 0}bind(e){if(this.closed)throw new p("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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new p("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 Eo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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 (
|
|
17
17
|
remote_jid TEXT NOT NULL,
|
|
18
18
|
id TEXT NOT NULL,
|
package/dist/index.d.cts
CHANGED
|
@@ -172,6 +172,7 @@ type BuilderInternalState = {
|
|
|
172
172
|
mentionAll?: boolean;
|
|
173
173
|
disappearingSeconds?: number;
|
|
174
174
|
resolveRecipient?: (raw: string) => Promise<string>;
|
|
175
|
+
recordSent?: (message: WAMessage) => void;
|
|
175
176
|
};
|
|
176
177
|
|
|
177
178
|
interface BuilderSocketLike {
|
|
@@ -194,7 +195,7 @@ declare class MessageBuilder<State extends BuilderState> {
|
|
|
194
195
|
protected readonly socket: BuilderSocketLike;
|
|
195
196
|
protected readonly internal: BuilderInternalState;
|
|
196
197
|
constructor(socket: BuilderSocketLike, internal: BuilderInternalState);
|
|
197
|
-
static create(socket: BuilderSocketLike, recipient: string, resolveRecipient?: (raw: string) => Promise<string
|
|
198
|
+
static create(socket: BuilderSocketLike, recipient: string, resolveRecipient?: (raw: string) => Promise<string>, recordSent?: (message: WAMessage) => void): MessageBuilder<'init'>;
|
|
198
199
|
to(this: MessageBuilder<'init'>, recipient: string): MessageBuilder<'init'>;
|
|
199
200
|
text(this: MessageBuilder<'init'>, content: string, opts?: TextOptions): MessageBuilder<'content-set'>;
|
|
200
201
|
image(this: MessageBuilder<'init'>, src: MediaSource, opts?: ImageOptions): MessageBuilder<'content-set'>;
|
package/dist/index.d.ts
CHANGED
|
@@ -172,6 +172,7 @@ type BuilderInternalState = {
|
|
|
172
172
|
mentionAll?: boolean;
|
|
173
173
|
disappearingSeconds?: number;
|
|
174
174
|
resolveRecipient?: (raw: string) => Promise<string>;
|
|
175
|
+
recordSent?: (message: WAMessage) => void;
|
|
175
176
|
};
|
|
176
177
|
|
|
177
178
|
interface BuilderSocketLike {
|
|
@@ -194,7 +195,7 @@ declare class MessageBuilder<State extends BuilderState> {
|
|
|
194
195
|
protected readonly socket: BuilderSocketLike;
|
|
195
196
|
protected readonly internal: BuilderInternalState;
|
|
196
197
|
constructor(socket: BuilderSocketLike, internal: BuilderInternalState);
|
|
197
|
-
static create(socket: BuilderSocketLike, recipient: string, resolveRecipient?: (raw: string) => Promise<string
|
|
198
|
+
static create(socket: BuilderSocketLike, recipient: string, resolveRecipient?: (raw: string) => Promise<string>, recordSent?: (message: WAMessage) => void): MessageBuilder<'init'>;
|
|
198
199
|
to(this: MessageBuilder<'init'>, recipient: string): MessageBuilder<'init'>;
|
|
199
200
|
text(this: MessageBuilder<'init'>, content: string, opts?: TextOptions): MessageBuilder<'content-set'>;
|
|
200
201
|
image(this: MessageBuilder<'init'>, src: MediaSource, opts?: ImageOptions): MessageBuilder<'content-set'>;
|
package/dist/index.mjs
CHANGED
|
@@ -7,12 +7,12 @@ import ao,{prepareWAMessageMedia,generateWAMessageFromContent,BufferJSON,makeCac
|
|
|
7
7
|
`)}:{type:"code",content:u.join(`
|
|
8
8
|
`)});continue}let d=e[i+1];if(o.includes("|")&&d!==void 0&&d.includes("|")&&Es.test(d)){s();let u=[wn(o)];for(i+=2;i<e.length&&e[i].includes("|")&&e[i].trim().length>0;)u.push(wn(e[i])),i++;t.push({type:"table",rows:u});continue}let l=yn.exec(o);if(l){s();let u=[l[1]];for(i++;i<e.length;){let h=yn.exec(e[i]);if(!h)break;u.push(h[1]),i++;}t.push({type:"image",url:u.length===1?u[0]:u});continue}r.push(o),i++;}return s(),t};var An=(n,e)=>{if(typeof n!="string"||!n.trimStart().startsWith("BEGIN:VCARD"))throw new m("INVALID_OPTIONS","contact() requires a vcard string starting with BEGIN:VCARD");let t={contacts:[{vcard:n}]};return {contacts:t}};var Mn=async(n,e)=>{if(typeof e?.fileName!="string"||e.fileName.trim().length===0)throw new m("INVALID_OPTIONS","document() requires a non-empty fileName");let{buffer:t,mime:r}=await k(n),s={document:t,fileName:e.fileName,mimetype:e.mimetype??r};return e.caption!==void 0&&(s.caption=e.caption),s};var Cn=10,En=n=>{if(typeof n?.buttonText!="string"||n.buttonText.trim().length===0)throw new m("INVALID_OPTIONS","list() requires a non-empty buttonText");if(!Array.isArray(n.sections)||n.sections.length===0)throw new m("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 m("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 m("INVALID_OPTIONS","list row id must be a non-empty string");if(typeof d.title!="string"||d.title.trim().length===0)throw new m("INVALID_OPTIONS","list row title must be a non-empty string");if(t.has(d.id))throw new m("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>Cn)throw new m("INVALID_OPTIONS",`list() accepts at most ${Cn} 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}),{[L]:{interactiveMessage:i}}};var bn=(n,e,t)=>{if(typeof n!="number"||Number.isNaN(n)||n<-90||n>90)throw new m("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 m("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 Pn=2,Tn=12,kn=(n,e,t)=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","poll() requires a non-empty question");if(!Array.isArray(e)||e.length<Pn)throw new m("INVALID_OPTIONS",`poll() requires a minimum of ${Pn} options`);if(e.length>Tn)throw new m("INVALID_OPTIONS",`poll() accepts a maximum of ${Tn} options`);let r=new Set;for(let i of e){if(typeof i!="string"||i.trim().length===0)throw new m("INVALID_OPTIONS","poll options must be non-empty strings");if(r.has(i))throw new m("INVALID_OPTIONS",`duplicate poll options: ${i}`);r.add(i);}return {poll:{name:n,values:e,selectableCount:t?.multipleChoice?e.length:1}}};var In=async(n,e)=>{let{buffer:t}=await k(n),r;try{r=await new z(t).sticker.create();}catch(i){throw new m("MEDIA_LOAD_FAILED",`sticker() conversion failed: ${i.message}`,{cause:i})}return {sticker:r,isAnimated:e?.animated??false}};var On=3,xn=n=>{if(typeof n?.body!="string"||n.body.trim().length===0)throw new m("INVALID_OPTIONS","template() requires a non-empty body");if(!Array.isArray(n.buttons)||n.buttons.length===0)throw new m("INVALID_OPTIONS","template() requires at least one button");if(n.buttons.length>On)throw new m("INVALID_OPTIONS",`template() accepts at most ${On} 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 Je=n=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var Rn=(n,e)=>({recipient:n,...e?{resolveRecipient:e}:{}});var xs=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],J=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r){return new n(e,Rn(t,r))}to(e){return this.internal.recipient=e,delete this.internal.resolveRecipient,this}text(e,t){return t?.rich===true?this.internal.content=gn(Sn(e),t):this.internal.content=Je(e),this}image(e,t){return this.internal.pendingContent=ne(e,t),this}video(e,t){return this.internal.pendingContent=re(e,t),this}audio(e,t){return this.internal.pendingContent=un(e,t),this}document(e,t){return this.internal.pendingContent=Mn(e,t),this}sticker(e,t){return this.internal.pendingContent=In(e,t),this}buttons(e,t){return this.internal.content=je(e,t),this}carousel(e,t){return this.internal.content=fn(e,t),this}list(e){return this.internal.content=En(e),this}poll(e,t,r){return this.internal.content=kn(e,t,r),this}location(e,t,r){return this.internal.content=bn(e,t,r),this}contact(e){return this.internal.content=An(e),this}template(e){return this.internal.content=xn(e),this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new m("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 m("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new m("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 m("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),an(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 m("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[L];if(i!==void 0){let d=s[bt],l=s[Tt];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 m("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new m("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await k(t.src),s=await prepareWAMessageMedia({[t.kind]:r},{upload:this.socket.waUploadToServer});e.hasMediaAttachment=true,t.kind==="image"&&s.imageMessage&&(e.imageMessage=s.imageMessage),t.kind==="video"&&s.videoMessage&&(e.videoMessage=s.videoMessage);}async sendRelay(e,t,r){let s=this.socket.relayMessage;if(typeof s!="function")throw new m("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 h=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&h)for(let f of r){let g=h[f.index]?.header;g&&await this.uploadHeaderMedia(g,f);}}catch(u){throw new m("SEND_FAILED","interactive media upload failed",{cause:u})}let o={userJid:this.socket.user?.id??""},a=this.internal.quoted;a!==void 0&&a.message!=null&&(o.quoted=a);let c=generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new m("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:xs}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new m("SEND_FAILED","socket relayMessage rejected",{cause:u})}return c.key}};var pe=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Je(e),this}image(e,t){return this.pendingContent=ne(e,t),this}video(e,t){return this.pendingContent=re(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 m("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new m("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 m("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new m("SEND_FAILED","socket returned no message key");return r.key}};var Ln=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new m("INVALID_OPTIONS","message key is missing remoteJid");return e},_n=n=>{if(!n?.key)throw new m("SEND_FAILED","socket returned no message key");return n.key},It=async(n,e,t={})=>{let r=Ln(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new m("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},Ot=async(n,e,t)=>{let r=Ln(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return _n(s)},xt=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new m("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return _n(i)};var Rs=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,$e=n=>Rs.test(n),Rt=async(n,e,t,r=Ls)=>{if($e(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 m("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);}},Ls=new Map;var b=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 me=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new b("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 b("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 fe=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 ge=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("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 he=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 E=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 _s=n=>{let e=n[0];return e==="{"||e==="["},Ns=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Ds=n=>n===" "||n===" "||n===`
|
|
10
|
+
`:""}${n.body}`};return n.footer!==void 0&&(t.footer=n.footer),je(n.buttons,t)};var Je=n=>{if(typeof n!="string"||n.trim().length===0)throw new m("EMPTY_CONTENT","text() requires a non-empty string");return {text:n}};var Rn=(n,e,t)=>({recipient:n,...e?{resolveRecipient:e}:{},...t?{recordSent:t}:{}});var xs=[{tag:"biz",attrs:{},content:[{tag:"interactive",attrs:{type:"native_flow",v:"1"},content:[{tag:"native_flow",attrs:{v:"9",name:"mixed"}}]}]}],J=class n{socket;internal;constructor(e,t){this.socket=e,this.internal=t;}static create(e,t,r,s){return new n(e,Rn(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=gn(Sn(e),t):this.internal.content=Je(e),this}image(e,t){return this.internal.pendingContent=ne(e,t),this}video(e,t){return this.internal.pendingContent=re(e,t),this}audio(e,t){return this.internal.pendingContent=un(e,t),this}document(e,t){return this.internal.pendingContent=Mn(e,t),this}sticker(e,t){return this.internal.pendingContent=In(e,t),this}buttons(e,t){return this.internal.content=je(e,t),this}carousel(e,t){return this.internal.content=fn(e,t),this}list(e){return this.internal.content=En(e),this}poll(e,t,r){return this.internal.content=kn(e,t,r),this}location(e,t,r){return this.internal.content=bn(e,t,r),this}contact(e){return this.internal.content=An(e),this}template(e){return this.internal.content=xn(e),this}album(e){return this.internal.albumItems=e,this}reply(e){if(e==null)throw new m("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 m("INVALID_OPTIONS","mentions() requires at least one jid");for(let r of e)if(typeof r!="string"||!r.includes("@"))throw new m("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 m("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),an(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 m("EMPTY_CONTENT","no content set");let s=this.internal.content,i=s[L];if(i!==void 0){let d=s[bt],l=s[Tt];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 m("SEND_FAILED","socket sendMessage rejected",{cause:d})}if(!c?.key)throw new m("SEND_FAILED","socket returned no message key");return c.key})().then(e,t)}async uploadHeaderMedia(e,t){let{buffer:r}=await k(t.src),s=await prepareWAMessageMedia({[t.kind]:r},{upload:this.socket.waUploadToServer});e.hasMediaAttachment=true,t.kind==="image"&&s.imageMessage&&(e.imageMessage=s.imageMessage),t.kind==="video"&&s.videoMessage&&(e.videoMessage=s.videoMessage);}async sendRelay(e,t,r){let s=this.socket.relayMessage;if(typeof s!="function")throw new m("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 h=e.interactiveMessage?.carouselMessage?.cards;if(r!==void 0&&h)for(let f of r){let g=h[f.index]?.header;g&&await this.uploadHeaderMedia(g,f);}}catch(u){throw new m("SEND_FAILED","interactive media upload failed",{cause:u})}let o={userJid:this.socket.user?.id??""},a=this.internal.quoted;a!==void 0&&a.message!=null&&(o.quoted=a);let c=generateWAMessageFromContent(this.internal.recipient,e,o);if(typeof c.key?.id!="string")throw new m("SEND_FAILED","failed to generate relay message key");let l="interactiveMessage"in e&&e.interactiveMessage!=null?{messageId:c.key.id,additionalNodes:xs}:{messageId:c.key.id};try{await s(this.internal.recipient,c.message,l);}catch(u){throw new m("SEND_FAILED","socket relayMessage rejected",{cause:u})}return this.internal.recordSent?.(c),c.key}};var pe=class{socket;key;content;pendingContent;constructor(e,t){this.socket=e,this.key=t;}text(e){return this.content=Je(e),this}image(e,t){return this.pendingContent=ne(e,t),this}video(e,t){return this.pendingContent=re(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 m("INVALID_OPTIONS","message key is missing remoteJid");if(this.pendingContent&&(this.content=await this.pendingContent),!this.content)throw new m("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 m("SEND_FAILED","socket sendMessage rejected",{cause:s})}if(!r?.key)throw new m("SEND_FAILED","socket returned no message key");return r.key}};var Ln=n=>{let e=n.remoteJid;if(typeof e!="string"||e.length===0)throw new m("INVALID_OPTIONS","message key is missing remoteJid");return e},_n=n=>{if(!n?.key)throw new m("SEND_FAILED","socket returned no message key");return n.key},It=async(n,e,t={})=>{let r=Ln(e);if(t.forEveryone??true){await n.sendMessage(r,{delete:e});return}if(typeof n.chatModify!="function")throw new m("INVALID_OPTIONS","delete-for-me is not supported by this socket");await n.chatModify({deleteForMe:{deleteMedia:false,key:e,timestamp:Date.now()}},r);},Ot=async(n,e,t)=>{let r=Ln(e),s=await n.sendMessage(r,{react:{text:t,key:e}});return _n(s)},xt=async(n,e,t,r)=>{let s=await e.getMessage(t);if(!s)throw new m("MESSAGE_NOT_FOUND","message not found in store for forward");let i=await n.sendMessage(r,{forward:s});return _n(i)};var Rs=/@(s\.whatsapp\.net|g\.us|lid|newsletter|broadcast|c\.us)$/,$e=n=>Rs.test(n),Rt=async(n,e,t,r=Ls)=>{if($e(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 m("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);}},Ls=new Map;var b=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 me=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("OPERATION_FAILED","invite code unavailable");return t}async revokeInvite(e){let t=await this.requireSocket().groupRevokeInvite(e);if(!t)throw new b("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 b("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 fe=class{constructor(e){this.getSocket=e;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 ge=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 b("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 he=class{constructor(e,t){this.getSocket=e;this.guard=t;}requireSocket(){let e=this.getSocket();if(!e)throw new b("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 E=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 _s=n=>{let e=n[0];return e==="{"||e==="["},Ns=n=>{try{return {ok:!0,value:JSON.parse(n)}}catch{return {ok:false}}},Ds=n=>n===" "||n===" "||n===`
|
|
11
11
|
`||n==="\r",Bs=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(Ds(c)){i&&(e.push(t),t="",i=false),o=true;continue}t+=c,i=true,o=false;}return i&&e.push(t),e},Fs=(n,e)=>{for(let t of e)if(t.length>0&&n.startsWith(t))return t;return null},Ws=n=>({matched:false,args:[],flags:{},json:void 0,raw:n});function Lt(n,e){let t=Fs(n,e);if(t===null)return Ws(n);let r=n.slice(t.length),s=Bs(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 h=d.slice(0,l),f=d.slice(l+1);i.flags[h]=f;continue}let u=s[a+1];u!==void 0&&!u.startsWith("--")?(i.flags[d]=u,a+=1):i.flags[d]=true;continue}if(!o&&_s(c)){let d=Ns(c);d.ok&&(i.json=d.value,o=true);}i.args.push(c);}}return i}var Us=n=>{let e=n.trim().split(/\s+/).filter(t=>t.length>0).map(t=>t.toLowerCase());if(e.length===0)throw new E("INVALID_COMMAND_NAME","empty command segment in spec");return e},Ve=n=>n.join(" "),ye=class{paths=new Map;defs=[];maxDepth=1;register(e,t){if(e.trim().length===0)throw new E("INVALID_COMMAND_NAME","command spec must not be empty");let r=e.split("|").map(a=>Us(a)),s=r[0],i=r.slice(1).map(a=>Ve(a)),o={name:Ve(s),aliases:i,parts:s,handler:t};for(let a of r){let c=Ve(a);if(this.paths.has(c))throw new E("DUPLICATE_COMMAND",`command "${c}" is already registered`)}for(let a of r)this.paths.set(Ve(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 _t(n,e,t){let r=-1,s={error:void 0,thrown:false},i=async o=>{if(o<=r)throw new E("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 E?c:new E("MIDDLEWARE_ERROR","middleware threw during execution",{cause:c})}};await i(0);}function Nt(n){if(n.prefixes.length===0)return {detach(){}};let e=s=>{let i=Lt(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(_t(n.middleware,c,()=>o.def.handler(c))).catch(d=>{let l=d instanceof E?d:new E("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 C=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 js=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),Z=class{now;sleep;perJidRatePerMs;perJidCapacity;global;perJid=new Map;constructor(e,t={}){if(!(e.perSec>0))throw new C("RATE_LIMIT_INVALID","perSec must be greater than zero");if(e.perJidPerSec!==void 0&&!(e.perJidPerSec>0))throw new C("RATE_LIMIT_INVALID","perJidPerSec must be greater than zero");if(e.burst!==void 0&&!(e.burst>0))throw new C("RATE_LIMIT_INVALID","burst must be greater than zero");this.now=t.now??Date.now,this.sleep=t.sleep??js;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 Ks={"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},qs=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n));function Dt(n={},e={}){let t=n.enabled??true,r=e.now??Date.now,s=e.sleep??qs,i={...Ks,...n.intervalsMs??{}},o=new Map,a=new Map,c=async(d,l)=>{let u=i[d]??0,h=o.get(d);if(h!==void 0&&u>0){let f=u-(r()-h);f>0&&await s(f);}return o.set(d,r()),l()};return {run(d,l){if(!t)return l();let h=(a.get(d)??Promise.resolve()).then(()=>c(d,l),()=>c(d,l));return a.set(d,h.then(()=>{},()=>{})),h}}}var Js={maxRetries:0,backoffMs:()=>0},$s=n=>n<=0?Promise.resolve():new Promise(e=>setTimeout(e,n)),we=class{concurrency;retry;sleep;pending=[];active=0;idleWaiters=[];constructor(e={},t={}){this.concurrency=e.concurrency??1,this.retry=e.retry??Js,this.sleep=t.sleep??$s;}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 Vs=n=>n instanceof Error?n:new Error(typeof n=="string"?n:String(n));async function Bt(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 Z({perSec:i},o),c=r.retry,d=t.sleep?{sleep:t.sleep}:{},l=c?new we({concurrency:1,retry:c},d):void 0,u=n.length,h=0;for(let f of n){await a.acquire(f);let g=()=>e(t.sendTo(f)).then(()=>{});try{l?await l.add(g):await g(),s.sent.push(f),h+=1,r.onProgress?.(h,u,f,!0);}catch(y){s.failed.push({jid:f,error:Vs(y)}),h+=1,r.onProgress?.(h,u,f,false);}}return s}var Gs=1e3,ve=class{constructor(e,t,r){this.getSocket=e;this.throttleEnabled=t?.enabled??true,this.minIntervalMs=t?.minIntervalMs??Gs,this.now=r?.now??Date.now;}throttleEnabled;minIntervalMs;now;lastSent=new Map;requireSocket(){let e=this.getSocket();if(!e)throw new C("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 C("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)},Ys=n=>typeof n=="object"&&n!==null&&typeof n.recipient=="string"&&typeof n.content=="object",Se=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 C("SCHEDULE_INVALID","scheduleAt requires a valid Date");let s=await this.evaluate(t),i=randomUUID(),o={id:i,fireAt:r,recipient:s.recipient,payload:s};return await this.persist(o),this.arm(o),{id:i,cancel:()=>{this.cancel(i);}}}async loadPending(){let e=this.store.listScheduledJobs;if(!e){for(let r of this.memory.values())this.timers.has(r.id)||this.arm(r);return}let t;try{t=await e.call(this.store);}catch(r){this.logger?.warn(r,"scheduler loadPending failed");return}for(let r of t)this.timers.has(r.id)||(this.memory.set(r.id,r),this.arm(r));}dispose(){for(let e of this.timers.values())this.timer.clear(e);this.timers.clear();}cancel(e){let t=this.timers.get(e);t!==void 0&&(this.timer.clear(t),this.timers.delete(e)),this.memory.delete(e),this.remove(e);}arm(e){let t=Math.max(0,e.fireAt-this.now()),r=this.timer.set(()=>{this.fire(e);},t);this.timers.set(e.id,r);}async fire(e){if(this.timers.delete(e.id),Ys(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 C("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 C("SCHEDULE_INVALID","scheduling interactive/relayed content is not supported; schedule a text or media message")}},i=J.create(s,"");try{await e(i);}catch(o){throw o instanceof C?o:new C("SCHEDULE_INVALID","scheduled builder evaluation failed",{cause:o})}if(!t)throw new C("SCHEDULE_INVALID","scheduled builder produced no content");return t}};var X="[zaileys]",Zs="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 Dn(n){switch(n.kind){case "connecting":return `${X} Connecting to WhatsApp (session: ${n.sessionId})...`;case "qr":return `${X} Scan the QR code above with WhatsApp > Linked devices to authenticate.`;case "pairing-code":return `${X} Pairing code: ${n.code} \u2014 enter it in WhatsApp > Linked devices > Link with phone number.`;case "connected":return `${X} Connected as ${n.id}.`;case "reconnecting":{let e=(n.delayMs/1e3).toFixed(1),t=`${X} Connection lost (${n.reason}). Reconnecting in ${e}s (attempt ${n.attempt})...`;return n.invalidCredsSuspected?`${t}
|
|
12
12
|
${X} ${Zs}`:t}case "disconnect":return n.willReconnect?null:`${X} Disconnected (${n.reason}).`;default:return null}}var Nn=false,Xs=["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:"],Qs=n=>typeof n[0]=="string"&&Xs.some(e=>n[0].startsWith(e));function Bn(){if(Nn)return;Nn=true;let n=e=>{let t=console[e].bind(console);console[e]=(...r)=>{Qs(r)||t(...r);};};n("info"),n("warn"),n("error");}var p=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 ti="./.zaileys/auth",ni=n=>n.replace(/[^a-zA-Z0-9._-]/g,e=>`_${e.charCodeAt(0).toString(16)}`),Me=n=>typeof n=="object"&&n!==null&&n.code==="ENOENT",He=class{basePath;closed=false;constructor(e){this.basePath=e?.basePath??ti;}signal={read:async(e,t)=>{this.assertOpen();let r={};return await Promise.all(t.map(async s=>{let i=this.signalPath(e,s);try{let o=await promises.readFile(i,"utf8");r[s]=JSON.parse(o,BufferJSON.reviver);}catch(o){if(Me(o))return;throw new p("STORE_READ_FAILED",`failed to read ${i}`,{cause:o})}})),r},write:async e=>{this.assertOpen();let t=[];for(let r of Object.keys(e)){let s=e[r];if(!s)continue;let i=this.signalDir(r);await promises.mkdir(i,{recursive:true});for(let o of Object.keys(s)){let a=s[o],c=this.signalPath(r,o);a===null?t.push(promises.unlink(c).catch(d=>{if(!Me(d))throw new p("STORE_WRITE_FAILED",`failed to unlink ${c}`,{cause:d})})):a!==void 0&&t.push(this.atomicWrite(c,JSON.stringify(a,BufferJSON.replacer)));}}await Promise.all(t);},delete:async(e,t)=>{this.assertOpen(),await Promise.all(t.map(async r=>{let s=this.signalPath(e,r);try{await promises.unlink(s);}catch(i){if(!Me(i))throw new p("STORE_WRITE_FAILED",`failed to unlink ${s}`,{cause:i})}}));},clear:async()=>{this.assertOpen(),await promises.rm(this.basePath,{recursive:true,force:true});},close:async()=>{this.closed=true;}};creds={readCreds:async()=>{this.assertOpen();try{let e=await promises.readFile(this.credsPath(),"utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){if(Me(e))return;throw new p("STORE_READ_FAILED","failed to read creds.json",{cause:e})}},writeCreds:async e=>{this.assertOpen(),await promises.mkdir(this.basePath,{recursive:true}),await this.atomicWrite(this.credsPath(),JSON.stringify(e,BufferJSON.replacer));},deleteCreds:async()=>{this.assertOpen();try{await promises.unlink(this.credsPath());}catch(e){if(!Me(e))throw new p("STORE_WRITE_FAILED","failed to delete creds.json",{cause:e})}}};credsPath(){return Ae.join(this.basePath,"creds.json")}signalDir(e){return Ae.join(this.basePath,"signal",String(e))}signalPath(e,t){return Ae.join(this.signalDir(e),`${ni(t)}.json`)}async atomicWrite(e,t){let r=Ae.join(Ae.dirname(e),`tmp-${randomBytes(8).toString("hex")}`);try{await promises.writeFile(r,t,"utf8"),await promises.rename(r,e);}catch(s){throw await promises.unlink(r).catch(()=>{}),new p("STORE_WRITE_FAILED",`failed to write ${e}`,{cause:s})}}assertOpen(){if(this.closed)throw new p("STORE_CLOSED","FileAuthStore is closed")}};function Fn(n,e){let t=n.signal,s=makeCacheableSignalKeyStore({get:(o,a)=>t.read(o,a),set:o=>t.write(o),clear:()=>t.clear()},e?.logger??void 0),i={read:async(o,a)=>await s.get(o,[...a]),write:async o=>{await s.set(o);},delete:async(o,a)=>{await t.delete(o,a);let c={},d={};for(let l of a)d[l]=null;c[o]=d,await s.set(c);},clear:async()=>{let o=s.clear;typeof o=="function"?await o.call(s):await t.clear();},close:()=>t.close()};return {creds:n.creds,signal:i}}function Wn(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 si=429;function Un(n){if(n===si)return "rate-limited";switch(n){case DisconnectReason.loggedOut:return "logged-out";case DisconnectReason.forbidden:return "forbidden";case DisconnectReason.connectionLost:return "connection-lost";case DisconnectReason.multideviceMismatch:return "multi-device-mismatch";case DisconnectReason.connectionClosed:return "connection-closed";case DisconnectReason.connectionReplaced:return "connection-replaced";case DisconnectReason.badSession:return "bad-session";case DisconnectReason.unavailableService:return "unavailable-service";case DisconnectReason.restartRequired:return "restart-required";default:return "unknown"}}function Ce(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"}function ze(n){return n==="rate-limited"}function jn(n){return n==="logged-out"||n==="connection-replaced"||n==="forbidden"||n==="bad-session"}function Sl(n){return !Ce(n)}var Ye={enabled:true,maxQrAttempts:5,maxPairingAttempts:3,pairingCooldownMs:6e4},ii=3e5;function Kn(n={}){let e=n.enabled??Ye.enabled,t=n.maxQrAttempts??Ye.maxQrAttempts,r=n.maxPairingAttempts??Ye.maxPairingAttempts,s=n.pairingCooldownMs??Ye.pairingCooldownMs,i=0,o=0,a=0,c=h=>h<=0?0:Math.min(s*h,ii);return {evaluate:(h,f)=>{if(!e)return {allowed:true,waitMs:0,attempts:h==="pairing"?o:i,max:Number.POSITIVE_INFINITY};if(h==="pairing"){if(o>=r)return {allowed:false,reason:"budget-exhausted",waitMs:0,attempts:o,max:r};let g=c(o),y=f-a;return o>0&&y<g?{allowed:false,reason:"cooldown",waitMs:g-y,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:(h,f)=>{h==="pairing"?(o+=1,a=f):i+=1;},reset:()=>{i=0,o=0,a=0;},get enabled(){return e},get qrAttempts(){return i},get pairingAttempts(){return o}}}var oi=/[\s\-()+]/g;function ai(n){return typeof n!="string"?"":n.replace(oi,"")}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 qn(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 li(n){return !n||typeof n!="string"||!n.trim()?Promise.reject(new Error("qr string is required")):new Promise(e=>{di.generate(n,{small:true},t=>e(t));})}async function Jn(n,e=t=>{process.stdout.write(t);}){let t=await li(n);e(t+`
|
|
13
13
|
`);}var ie={enabled:true,maxAttempts:Number.POSITIVE_INFINITY,initialDelayMs:3e3,maxDelayMs:6e4,jitterFactor:.2,rateLimitedDelayMs:3e5};function $n(n,e){let t=n?.enabled??ie.enabled,r=n?.maxAttempts??ie.maxAttempts,s=n?.initialDelayMs??ie.initialDelayMs,i=n?.maxDelayMs??ie.maxDelayMs,o=n?.jitterFactor??ie.jitterFactor,a=n?.rateLimitedDelayMs??ie.rateLimitedDelayMs,c=e?.random??Math.random,d=0;return {next:h=>{if(!t||Ce(h))return null;let f=d+1;if(f>r)return null;if(d=f,ze(h))return {attempt:f,delayMs:a};let g=Math.pow(2,f-1),y=Math.min(i,s*g),M=1+(c()*2-1)*o,A=y*M,j=Math.min(i,Math.max(0,A));return {attempt:f,delayMs:Math.round(j)}},reset:()=>{d=0;},get attempts(){return d}}}var ui={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 Vn(n="idle"){let e=n,t=new Set,r=s=>ui[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 Ft=n=>`${n.remoteJid??""}|${n.id??""}|${n.fromMe?1:0}`,Ze=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=Ft(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(Ft(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(Ft(l.key));if(u){let h={...u,...l.update};this.saveMessage(h).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 h={...this.chats.get(l.id)??{},...l};this.saveChat(h).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 p("STORE_CLOSED","MemoryMessageStore is closed")}};var mi=["silent","fatal","error","warn","info","debug","trace"];function fi(n){if(n)return n;let e=process.env.ZAILEYS_DEBUG;return e===void 0?"silent":e==="1"?"info":mi.includes(e)?e:"silent"}function gi(n={}){let e=fi(n.level),t=pi({level:e});return n.sessionId!==void 0?t.child({sessionId:n.sessionId}):t}var Gn=["debug","info","warn","error","fatal"];function hi(n){if(n===null||typeof n!="object")return false;for(let e of Gn)if(typeof n[e]!="function")return false;return true}function Ee(){}function yi(n){let e={debug:Ee,info:Ee,warn:Ee,error:Ee,fatal:Ee};for(let t of Gn){let r=n[t];typeof r=="function"&&(e[t]=r.bind(n));}return e}function Wt(n,e){return n===void 0?e??gi():hi(n)?n:yi(n)}var Ll=Object.freeze(["HISTORY_SYNC_NOTIFICATION","APP_STATE_SYNC_KEY_SHARE","LID_MIGRATION_MAPPING_SYNC","PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"]),Hn=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 wi=new Set(["offer","ringing"]),vi=new Set(["timeout","reject","accept","terminate"]),zn=n=>{let e=n instanceof Date?n.getTime():Date.parse(String(n));return Number.isFinite(e)?e:0},Yn=n=>typeof n.id!="string"||n.id.length===0||!wi.has(n.status)?null:{kind:"incoming",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:zn(n.date),status:n.status},Zn=n=>typeof n.id!="string"||n.id.length===0||!vi.has(n.status)?null:{kind:"ended",callId:n.id,from:n.from,isGroup:n.isGroup===true,isVideo:n.isVideo===true,timestamp:zn(n.date),status:n.status};var O=n=>typeof n=="string"&&n.length>0,Si=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},Xn=(n,e,t)=>n.filter(r=>O(r?.id)).map(r=>{let s={jid:r.id},i=r.lid??r.pn??r.phoneNumber;return O(i)&&(s.participantAlt=i),O(e)&&(s.authorPn=e),O(t)&&(s.authorUsername=t),s.isAdmin=r.admin==="admin"||r.admin==="superadmin",s}),Qn=n=>O(n?.id)?{groupId:n.id,update:Si(n),timestamp:Date.now()}:null,er=n=>{if(!O(n?.groupId)||!O(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 O(n.participantAlt)&&(e.participantAlt=n.participantAlt),e},Ai=new Set(["add","invite","invite-link"]),Mi=new Set(["remove","leave"]),tr=n=>{if(!O(n?.id)||!Ai.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Xn(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 O(n.author)&&(t.by=n.author),t},nr=n=>{if(!O(n?.id)||!Mi.has(n.action)||!Array.isArray(n.participants)||n.participants.length===0)return null;let e=Xn(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 O(n.author)&&(t.by=n.author),t};var be=n=>typeof n!="string"||n.length===0?null:jidNormalizedUser(n),$=n=>typeof n=="string"&&n.length>0?n:void 0,bi=["@s.whatsapp.net","@c.us"],Pi=n=>n.endsWith("@lid"),Ti=n=>bi.some(e=>n.endsWith(e)),B=(n,e)=>{if(!n)return null;let t=$(n.participant)??n.remoteJid,r=be(t);if(r===null)return null;let s=$(n.participantAlt)??$(n.remoteJidAlt),i=s!=null?be(s):null,o=$(n.participantUsername)??$(n.remoteJidUsername),a={jid:r,isMe:n.fromMe===true},c=i!==null?[r,i]:[r],d=c.find(Pi),l=c.find(Ti);d!==void 0&&(a.lid=d),l!==void 0&&(a.pn=l),o!==void 0&&(a.username=o);let u=$(e);return u!==void 0&&(a.pushName=u),a},rr=n=>{if(!n)return null;let e=n.stanzaId;if(typeof e!="string"||e.length===0)return null;let t=$(n.participant),r=$(n.remoteJid)??t,s={id:e};typeof r=="string"&&(s.remoteJid=r),typeof t=="string"&&(s.participant=t);let i={key:s},o=B(s);return o&&(i.sender=o),i},Xe=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 Pe=n=>isJidGroup(n)===true,Qe=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"],Ii=["list_select","single_select"],W=n=>typeof n=="string"&&n.length>0,ir=n=>{let e=typeof n.pushName=="string"?n.pushName:void 0;return B(n.key,e)},or=n=>Qe(n.messageTimestamp)??0,ar=(n,e)=>{if(!W(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}},et=(n,e)=>{for(let t of e){let r=n[t];if(W(r))return r}},cr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.buttonsResponseMessage;if(r&&W(r.selectedButtonId))return Ut(n,r.selectedButtonId,r.selectedDisplayText);let s=t.templateButtonReplyMessage;if(s&&W(s.selectedId))return Ut(n,s.selectedId,s.selectedDisplayText);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&W(i.name)&&ki.includes(i.name)){let o=ar(i.paramsJson,e.logger);if(!o)return null;let a=et(o,["id","button_id"]);return a===void 0?null:Ut(n,a,et(o,["display_text"])??null)}return null},Ut=(n,e,t)=>{let r=ir(n);if(!r||!n.key)return null;let s={key:n.key,buttonId:e,sender:r,timestamp:or(n)};return W(t)&&(s.buttonText=t),s},dr=(n,e)=>{let t=n.message;if(!t)return null;let r=t.listResponseMessage,s=r?.singleSelectReply?.selectedRowId;if(W(s))return sr(n,s,r?.title);let i=t.interactiveResponseMessage?.nativeFlowResponseMessage;if(i&&W(i.name)&&Ii.includes(i.name)){let o=ar(i.paramsJson,e.logger);if(!o)return null;let a=et(o,["row_id","id"]);return a===void 0?null:sr(n,a,et(o,["title"])??null)}return null},sr=(n,e,t)=>{let r=ir(n);if(!r||!n.key)return null;let s={key:n.key,rowId:e,sender:r,timestamp:or(n)};return W(t)&&(s.title=t),s};var Oi=new Set(["available","unavailable","composing","recording","paused"]),xi=n=>n instanceof Date?n.getTime():typeof n=="number"&&Number.isFinite(n)?n:0,lr=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:xi(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},ur=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"||!Oi.has(s)||e.push({jid:n.id,participant:t,status:s});}return e},Te=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 Li=n=>{let e=n.match(/(https?:\/\/[^\s]+)/g);return e?e.map(t=>t.replace(/[.,;:!?]+$/,"")):[]},_i=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")},Ni=n=>{let e=jidDecode(n);if(!e)return "unknown";let t=e.device;return t===void 0||t===0?"android":t===2?"ios":t===3?"web":t===4?"desktop":"unknown"},Di=n=>n.trim().endsWith("?"),Bi=(n,e)=>e.length===0?false:e.some(t=>t.length>0&&n.startsWith(t)),Fi=(n,e)=>{if(e.length===0)return false;let t;try{t=jidNormalizedUser(n);}catch{t=n;}return e.some(r=>{try{return jidNormalizedUser(r)===t}catch{return r===n}})},Wi=(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)}},Kt=n=>{let e=typeof n.key.remoteJid=="string"?n.key.remoteJid:null,t=e!==null&&Pe(e),r={uniqueId:_i(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:Ni(n.sender.jid),timestamp:typeof n.message.messageTimestamp=="number"?n.message.messageTimestamp*1e3:0,text:n.text,mentions:n.mentions,links:Li(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:Di(n.text),isPrefix:Bi(n.text,n.prefixes),isTagMe:Fi(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:Wi(n.citationConfig,n.sender.pn??n.sender.jid)};return n.media!==void 0&&(r.media=n.media),r};var Ui={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},ji=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[Ui[e]];if(r==null||typeof r!="object")return null;let s=r.mimetype;return typeof s=="string"&&s.length>0?s:null},mr=(n,e,t)=>async()=>{try{let{downloadMediaMessage:r}=await import('baileys'),s=await r(n,"buffer",{}),i=ji(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")}},fr=(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 ke={image:"imageMessage",video:"videoMessage",audio:"audioMessage",document:"documentMessage",sticker:"stickerMessage"},hr=n=>{let e=n?.remoteJid;return typeof e=="string"&&e.length>0?e:""},w=n=>n!=null&&typeof n=="object"?n:null,U=n=>typeof n=="string"&&n.length>0?n:null,Ie=(...n)=>{for(let e of n){let t=U(e);if(t!=null)return t}return null},Ki=["ephemeralMessage","viewOnceMessage","viewOnceMessageV2","viewOnceMessageV2Extension","documentWithCaptionMessage","editedMessage"],yr=n=>{let e=n;for(let t=0;t<5;t++){let r=null;for(let s of Ki){let i=w(w(e[s])?.message);if(i!=null){r=i;break}}if(r==null)break;e=r;}return e},qi=n=>{let t=w(w(w(n.botForwardedMessage)?.message)?.richResponseMessage)??w(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=U(w(o)?.messageText);a!=null&&s.push(a);}let i=s.join(`
|
|
14
14
|
`).trim();return i.length>0?i:null},Ji=n=>{let e=w(n.templateMessage),t=w(e?.hydratedTemplate)??w(e?.hydratedFourRowTemplate);return U(t?.hydratedContentText)},$i=n=>Ie(w(n.pollCreationMessage)?.name,w(n.pollCreationMessageV2)?.name,w(n.pollCreationMessageV3)?.name),Vi=n=>{let e=w(n.locationMessage)??w(n.liveLocationMessage);if(e==null)return null;let t=Ie(e.name,e.address);if(t!=null){let i=U(e.name),o=U(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},Gi=n=>{let e=U(w(n.contactMessage)?.displayName);if(e!=null)return e;let t=w(n.contactsArrayMessage),r=U(t?.displayName);if(r!=null)return r;let s=t?.contacts;if(Array.isArray(s)){let i=s.map(o=>U(w(o)?.displayName)).filter(o=>o!=null);if(i.length>0)return i.join(", ")}return null},wr=n=>Ie(n.conversation,w(n.extendedTextMessage)?.text,qi(n),U(w(w(n.interactiveMessage)?.body)?.text),w(n.buttonsMessage)?.contentText,w(n.listMessage)?.description,Ji(n),$i(n),Vi(n),Gi(n)),Hi=n=>Ie(w(n.buttonsResponseMessage)?.selectedDisplayText,w(n.buttonsResponseMessage)?.selectedButtonId,w(n.templateButtonReplyMessage)?.selectedDisplayText,w(n.templateButtonReplyMessage)?.selectedId,w(n.listResponseMessage)?.title,w(w(n.listResponseMessage)?.singleSelectReply)?.selectedRowId,w(w(n.interactiveResponseMessage)?.body)?.text),zi=n=>Ie(w(n.imageMessage)?.caption,w(n.videoMessage)?.caption,w(n.documentMessage)?.caption,w(n.documentMessage)?.fileName),Yi=n=>{let e=w(n.message);return e==null?null:wr(yr(e))},nt=n=>{let e=w(n.message);if(e==null)return null;let t=yr(e);return wr(t)??Hi(t)??zi(t)},qt=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(ke)){let s=e[r];if(s!=null&&typeof s=="object"){let i=s.contextInfo;if(i!=null)return i}}return null},Zi=(n,e)=>{let t=n.message;if(t==null)return null;let r=t[ke[e]];return r==null||typeof r!="object"?null:r},Xi=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(ke)){let r=e[t];if(r!=null&&typeof r=="object"&&r.viewOnce===true)return true}return false},Qi=(n,e)=>n.message?.ephemeralMessage!=null?true:typeof e?.expiration=="number"&&e.expiration>0,gr=n=>{if(n==null)return "text";for(let e of Object.values(ke))if(n[e]!=null)return e.replace("Message","");return "text"},eo=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 l=await e.resolveQuoted(r,t);if(l!=null&&l.message!=null){let u=nt(l)??"",h=oe(l,e,gr(l.message),u);if(h!==null)return h}}let s=rr(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&&jidNormalizedUser(o)===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=nt(c)??"";return oe(c,e,gr(a),d)}catch{return null}},oe=(n,e,t,r,s)=>{let i=n.key;if(i==null)return null;let o=B(i,n.pushName??void 0);if(o===null)return null;let a=hr(i);if(a.length===0)return null;let c=qt(n),d=Pe(a),l=a.endsWith("@broadcast"),u=a.endsWith("@newsletter"),h=c?.isForwarded===true||(c?.forwardingScore??0)>0,f=Xi(n),g=Qi(n,c),y=e.channelId??"",M=e.receiverId??"",A=e.prefixes??[],j=()=>d&&e.resolveRoomName!=null?e.resolveRoomName(a):Promise.resolve(null),Ne=e.resolveReceiverName??(()=>Promise.resolve(null)),ht=()=>eo(c,e,a),yt=a.length>0?a:o.pn??o.jid,wt=(At,Qr)=>e.reply==null?Promise.reject(new Error("zaileys: ctx.reply() requires a connected client")):e.reply(yt,At,Qr,n),vt=At=>e.react==null?Promise.reject(new Error("zaileys: ctx.react() requires a connected client")):e.react(i,At),{mentionedJids:St}=Xe(c),Ht={message:n,key:i,channelId:y,receiverId:M,selfJid:e.selfJid,text:r,chatType:t,sender:o,mentions:St,isViewOnce:f,isEphemeral:g,isForwarded:h,isBroadcast:l,isNewsletter:u,prefixes:A,resolveRoomName:j,resolveReceiverName:Ne,resolveReplied:ht,reply:wt,react:vt},zt=s!==void 0?{...Ht,media:s}:Ht;return Kt(e.citationConfig!==void 0?{...zt,citationConfig:e.citationConfig}:zt)},vr=(n,e)=>{let t=Yi(n);return t===null?null:oe(n,e,"text",t)},Oe=(n,e,t)=>{let r=Zi(e,n);if(r===null)return null;let s=typeof r.caption=="string"?r.caption:"",i=n,o=mr(e,n,t.logger),a=fr(e,n,t.logger);return oe(e,t,i,s,{buffer:async()=>(await o()).buffer,stream:a})},Sr=(n,e)=>Oe("image",n,e),Ar=(n,e)=>Oe("video",n,e),Mr=(n,e)=>Oe("audio",n,e),Cr=(n,e)=>Oe("document",n,e),Er=(n,e)=>Oe("sticker",n,e),to=(n,e)=>{try{return jidNormalizedUser(n)===jidNormalizedUser(e)}catch{return n===e}},br=(n,e)=>{if(n.key==null)return null;let r=qt(n),{mentionedJids:s}=Xe(r);if(s.length===0||!s.some(l=>to(l,e.selfJid)))return null;let o=n.message;if(o==null)return null;let a=nt(n)??"",c="text";if(o!=null){let l=Object.values(ke);for(let u of l)if(o[u]!=null){c=u.replace("Message","");break}}let d=oe(n,e,c,a);return d===null?null:{...d,mentionedJids:s,selfJid:e.selfJid}},Pr=(n,e)=>{let t=n.key;if(t==null)return null;let r=hr(t);if(r.length===0||!Pe(r))return null;let{mentionAll:s}=Xe(qt(n));if(!s||n.message==null)return null;let o=nt(n)??"",a=oe(n,e,"text",o);return a===null?null:{...a,isMentionAll:true,selfJid:e.selfJid}};var Q=(n,e)=>{let t=Qe(n);return t===null?e:t},no=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;return typeof s=="string"?s:""},ro=n=>Array.isArray(n)?n.map(e=>Buffer.from(e).toString("hex")):[],kr=(n,e)=>{let t=n?.reaction,r=t?.key;if(!r)return null;let s=B(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:Q(t.senderTimestampMs,0)}},Ir=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.MESSAGE_EDIT)return null;let r=t.key;if(!r)return null;let s=B(n.key,e.pushName);return s===null?null:{key:r,newContent:no(t.editedMessage),editedAt:Q(n.update.messageTimestamp,0),sender:s}},Or=(n,e)=>{let t=n?.update?.message?.protocolMessage;if(!t||t.type!==proto.Message.ProtocolMessage.Type.REVOKE)return null;let r=t.key;if(!r)return null;let s=B(n.key,e.pushName);if(s===null)return null;let i=be(n.key.remoteJid),o=be(e.selfJid);return {key:r,deletedFor:i!==null&&o!==null&&i===o?"me":"everyone",sender:s,timestamp:Q(n.update.messageTimestamp,0)}},xr=(n,e)=>{let t=n?.update?.pollUpdates?.[0],r=n?.update?.message?.pollUpdateMessage,s=B(n?.key,e.pushName);if(s===null)return null;if(t){let i=t.pollUpdateMessageKey;return i?{pollKey:i,selectedOptions:ro(t.vote?.selectedOptions),voter:s,timestamp:Q(t.senderTimestampMs,Q(n.update.messageTimestamp,0))}:null}if(r){let i=r.pollCreationMessageKey;return i?{pollKey:i,selectedOptions:[],voter:s,timestamp:Q(r.senderTimestampMs,Q(n.update.messageTimestamp,0))}:null}return null};var rt=n=>Array.isArray(n)?n:[],so=n=>{if(n==null||typeof n!="object")return null;let e=n.reachoutTimeLock;return e==null||typeof e!="object"?null:e};function Rr(n,e,t){let r=[],s=new Map,i=t.groupMetadata!=null?f=>{let g=s.get(f);if(g!==void 0)return g;let y=t.groupMetadata;if(y==null)return Promise.resolve(null);let M=y(f).then(A=>A?.subject??null).catch(()=>null);return s.set(f,M),M}: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=(f,g)=>{let y=(...M)=>{try{g(M[0]);}catch(A){t.logger?.warn(A,`inbound pipeline: handler for ${f} threw`);}};e.ev.on(f,y),r.push(()=>e.ev.off(f,y));},l=f=>{u(()=>vr(f,o),g=>n.emit("text",g)),u(()=>Sr(f,o),g=>n.emit("image",g)),u(()=>Ar(f,o),g=>n.emit("video",g)),u(()=>Mr(f,o),g=>n.emit("audio",g)),u(()=>Cr(f,o),g=>n.emit("document",g)),u(()=>Er(f,o),g=>n.emit("sticker",g)),u(()=>br(f,o),g=>n.emit("mention",g)),u(()=>Pr(f,o),g=>n.emit("mention-all",g)),u(()=>cr(f,a),g=>n.emit("button-click",g)),u(()=>dr(f,a),g=>n.emit("list-select",g));},u=(f,g)=>{let y;try{y=f();}catch(M){t.logger?.warn(M,"inbound pipeline: decoder threw");return}y!=null&&g(y);};d("messages.upsert",f=>{let g=Hn(f);for(let y of g.messages)t.ignoreMe===!0&&y.key?.fromMe===!0||l(y);}),d("messages.update",f=>{for(let g of rt(f))u(()=>Ir(g,c),y=>n.emit("edit",y)),u(()=>Or(g,c),y=>n.emit("delete",y)),u(()=>xr(g,c),y=>n.emit("poll-vote",y));}),d("messages.reaction",f=>{for(let g of rt(f))u(()=>kr(g,c),y=>n.emit("reaction",y));}),d("groups.update",f=>{for(let g of rt(f))u(()=>Qn(g),y=>n.emit("group-update",y));}),d("group-participants.update",f=>{let g=f;u(()=>tr(g),y=>n.emit("group-join",y)),u(()=>nr(g),y=>n.emit("group-leave",y));}),d("group.member-tag.update",f=>{u(()=>er(f),g=>n.emit("member-tag",g));}),d("call",f=>{for(let g of rt(f))u(()=>Yn(g),y=>n.emit("call-incoming",y)),u(()=>Zn(g),y=>n.emit("call-ended",y));}),d("messaging-history.status",f=>{u(()=>lr(f),g=>n.emit("history-sync",g));}),d("presence.update",f=>{let g=(()=>{try{return ur(f)}catch(y){return t.logger?.warn(y,"inbound pipeline: decodePresence threw"),[]}})();for(let y of g)n.emit("presence",y);}),d("connection.update",f=>{let g=so(f);g!==null&&u(()=>jt({source:"connection-update",reachoutTimeLock:g}),y=>n.emit("limited",y));}),d("message-capping.update",f=>{u(()=>jt({source:"message-capping",capInfo:f}),g=>n.emit("limited",g));}),d("newsletter.reaction",f=>{u(()=>Te({source:"reaction",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter.view",f=>{u(()=>Te({source:"view",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter-participants.update",f=>{u(()=>Te({source:"participants",payload:f}),g=>n.emit("newsletter",g));}),d("newsletter-settings.update",f=>{u(()=>Te({source:"settings",payload:f}),g=>n.emit("newsletter",g));});let h=false;return {detach(){if(!h){h=true;for(let f of r)f();r.length=0;}}}}var st=class{inner=new EventEmitter;emitterLogger;constructor(e){this.emitterLogger=e?.logger,this.inner.setMaxListeners(0);}on(e,t){let r=this.wrap(e,t);this.tag(t,e,r),this.inner.on(e,r);let s=false;return ()=>{s||(s=true,this.inner.off(e,r),this.untag(t,e));}}off(e,t){let r=this.lookup(t,e);r&&(this.inner.off(e,r),this.untag(t,e));}emit(e,t){let r=this.inner.listeners(e).slice();for(let s of r)try{s(t);}catch(i){this.emitterLogger?.error(i,"listener threw");}}removeAllListeners(e){e===void 0?this.inner.removeAllListeners():this.inner.removeAllListeners(e);}listenerCount(e){return this.inner.listenerCount(e)}wrap(e,t){return r=>{try{t(r);}catch(s){this.emitterLogger?.error(s,"listener threw");}}}tag(e,t,r){this.tagMap(e).set(t,r);}untag(e,t){this.tagMap(e).delete(t);}lookup(e,t){return this.tagMap(e).get(t)}tagMap(e){let t=oo,r=e,s=r[t];return s||(s=new Map,r[t]=s),s}},oo=Symbol("zaileys.typed-ee.tag");var lo="default",uo="qr",_r=6e4,Nr=class extends st{sessionId;auth;store;logger;authType;phoneNumber;cacheSignal;qrTerminal;statusLog;reconnectOptions;baileysExtra;machine=Vn();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:Wt(e.logger)}),this.sessionId=e.sessionId??lo,this.logger=Wt(e.logger),this.authType=e.authType??uo,this.phoneNumber=e.phoneNumber,this.cacheSignal=e.cacheSignal??true,this.qrTerminal=e.qrTerminal??true,this.statusLog=e.statusLog??true,this.statusLog&&Bn(),this.reconnectOptions=e.reconnect??{},this.baileysExtra=e.baileys??{},this.auth=e.auth??new He({basePath:`./.zaileys/auth/${this.sessionId}`}),this.store=e.store??new Ze,this.reconnectStrategy=$n(this.reconnectOptions),this.authGuard=Kn(e.authGuard),this.operationGuard=Dt(e.operationGuard),this.presenceThrottle=e.presence;let t=e.scheduleRateLimitPerSec??1;this.scheduleLimiter=t>0?new Z({perSec:t}):void 0,this.commandPrefixes=po(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 fetchLatestBaileysVersion!="function"?Promise.resolve():(this.versionWarming=fetchLatestBaileysVersion().then(({version:e})=>{this.waVersion=e;}).catch(e=>{this.logger.warn(e,"fetchLatestBaileysVersion failed; using bundled version");}),this.versionWarming)}catch{return Promise.resolve()}}emitAutoConnectError(e){let t=e instanceof Error?e:new Error(String(e));this.logger.error(t,"auto-connect failed"),this.listenerCount("error")>0&&this.emit("error",{sessionId:this.sessionId,error:t});}logStatus(e){if(!this.statusLog)return;let t=Dn(e);t&&process.stderr.write(`${t}
|
|
15
|
-
`);}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 me(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new fe(()=>this._socket)}get newsletter(){return this._newsletter??=new ge(()=>this._socket,this.operationGuard)}get community(){return this._community??=new he(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new ve(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),Bt(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Se({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=Fn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Wn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:_r,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=ao(s);this._socket=i,this.store.bind(i),this.wireSocket(i);let o=new Promise((a,c)=>{let d=this.connectResolve,l=this.connectReject;this.connectResolve=()=>{d?.(),a();},this.connectReject=u=>{l?.(u),c(u);};});return this.auth.creds.readCreds().then(a=>{this.credsLoadedAtConnect=!!a,Object.assign(t,a??initAuthCreds());}).catch(a=>{this.rejectPendingConnect(a instanceof Error?a:new Error(String(a)));}),o}async disconnect(){if(!(this.machine.state==="idle"||this.machine.state==="disconnected")){this.machine.transition("disconnecting"),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands(),this._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 ye).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=Nt({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 E("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();return $e(e)?J.create(t,e):J.create(t,e,r=>this.resolveRecipient(r))}edit(e){return new pe(this.requireSocket(),e)}async delete(e,t){await It(this.requireSocket(),e,t);}async react(e,t){return Ot(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return xt(r,this.store,e,s)}resolveRecipient(e){return Rt(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new m("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=qn({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 Jn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+_r});}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=Rr(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=mo(e?.error),r=Un(t),s=false;if(jn(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(!Ce(r)&&!this.authExhausted){ze(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 po(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function mo(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 Dr=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 p("STORE_CLOSED","MemoryAuthStore is closed")}};var it=null,fo=async()=>{if(it)return it;try{return it=(await import('better-sqlite3')).default,it}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Jt="default",Fr=500,Wr=n=>Array.from({length:n},()=>"?").join(","),Ur=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},jr=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(Jt);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Jt,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Jt);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Ur(t,Fr)){let o=Wr(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=Wr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Ur(t,Fr))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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new p("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 fo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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;
|
|
15
|
+
`);}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 me(()=>this._socket,this.operationGuard)}get privacy(){return this._privacy??=new fe(()=>this._socket)}get newsletter(){return this._newsletter??=new ge(()=>this._socket,this.operationGuard)}get community(){return this._community??=new he(()=>this._socket,this.operationGuard)}get presence(){return this._presence??=new ve(()=>this._socket,this.presenceThrottle)}async broadcast(e,t,r){return this.requireSocket(),Bt(e,t,{sendTo:s=>this.send(s)},r)}async scheduleAt(e,t){return this.ensureScheduler().scheduleAt(e,t)}ensureScheduler(){return this._scheduler??=new Se({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=Fn(this.auth,{logger:this.logger}),this.cachedSignalWrap=true),this.warmVersion();let t={};this.creds=t;let r=Wn(this.auth.signal,this.logger),s={markOnlineOnConnect:false,syncFullHistory:false,qrTimeout:_r,...this.waVersion?{version:this.waVersion}:{},...this.baileysExtra,auth:{creds:t,keys:r},logger:this.logger,getMessage:a=>this.resolveMessageForResend(a)},i=ao(s);this._socket=i,this.store.bind(i),this.wireSocket(i);let o=new Promise((a,c)=>{let d=this.connectResolve,l=this.connectReject;this.connectResolve=()=>{d?.(),a();},this.connectReject=u=>{l?.(u),c(u);};});return this.auth.creds.readCreds().then(a=>{this.credsLoadedAtConnect=!!a,Object.assign(t,a??initAuthCreds());}).catch(a=>{this.rejectPendingConnect(a instanceof Error?a:new Error(String(a)));}),o}async disconnect(){if(!(this.machine.state==="idle"||this.machine.state==="disconnected")){this.machine.transition("disconnecting"),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=void 0),this.inboundHandle?.detach(),this.inboundHandle=void 0,this.detachCommands(),this._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 ye).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=Nt({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 E("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 $e(e)?J.create(t,e,void 0,r):J.create(t,e,s=>this.resolveRecipient(s),r)}edit(e){return new pe(this.requireSocket(),e)}async delete(e,t){await It(this.requireSocket(),e,t);}async react(e,t){return Ot(this.requireSocket(),e,t)}async forward(e,t){let r=this.requireSocket(),s=await this.resolveRecipient(t);return xt(r,this.store,e,s)}resolveRecipient(e){return Rt(this.requireSocket(),e,this.usernameCache)}requireSocket(){if(!this._socket)throw new m("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=qn({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 Jn(e);}catch(s){this.logger.warn(s,"printQrToTerminal failed");}this.logStatus({kind:"qr"}),this.emit("qr",{sessionId:this.sessionId,qrString:e,expiresAt:t+_r});}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=Rr(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=mo(e?.error),r=Un(t),s=false;if(jn(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(!Ce(r)&&!this.authExhausted){ze(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 po(n){return n===void 0?[]:(Array.isArray(n)?n:[n]).filter(t=>t.length>0)}function mo(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 Dr=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 p("STORE_CLOSED","MemoryAuthStore is closed")}};var it=null,fo=async()=>{if(it)return it;try{return it=(await import('better-sqlite3')).default,it}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},Jt="default",Fr=500,Wr=n=>Array.from({length:n},()=>"?").join(","),Ur=(n,e)=>{let t=[];for(let r=0;r<n.length;r+=e)t.push(n.slice(r,r+e));return t},jr=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(Jt);if(t)return this.parseBlob(t.data)},writeCreds:async e=>{let t=await this.ensureReady(),r=this.encodeBlob(e);t.writeCreds.run(Jt,r);},deleteCreds:async()=>{(await this.ensureReady()).deleteCreds.run(Jt);}};signal={read:async(e,t)=>{await this.ensureReady();let r={};if(t.length===0)return r;let s=this.db;for(let i of Ur(t,Fr)){let o=Wr(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=Wr(i.length);r.prepare(`DELETE FROM auth_signal WHERE type = ? AND id IN (${o})`).run(e,...i);});for(let i of Ur(t,Fr))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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}};async ensureReady(){if(this.closed)throw new p("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 fo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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;
|
|
16
16
|
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 p("STORE_CONNECTION_FAILED","failed to migrate sqlite schema",{cause:r})}this.db=t,this.prepared={readCreds:t.prepare("SELECT data FROM auth_creds WHERE id = ?"),writeCreds:t.prepare("INSERT INTO auth_creds(id, data) VALUES(?, ?) ON CONFLICT(id) DO UPDATE SET data = excluded.data"),deleteCreds:t.prepare("DELETE FROM auth_creds WHERE id = ?"),writeSignal:t.prepare("INSERT INTO auth_signal(type, id, data) VALUES(?, ?, ?) ON CONFLICT(type, id) DO UPDATE SET data = excluded.data"),deleteSignal:t.prepare("DELETE FROM auth_signal WHERE type = ? AND id = ?"),clearSignal:t.prepare("DELETE FROM auth_signal"),clearCreds:t.prepare("DELETE FROM auth_creds")};}encodeBlob(e){try{return Buffer.from(JSON.stringify(e,BufferJSON.replacer),"utf8")}catch(t){throw new p("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:t})}}parseBlob(e){try{let t=Buffer.isBuffer(e)?e.toString("utf8"):Buffer.from(e).toString("utf8");return JSON.parse(t,BufferJSON.reviver)}catch(t){throw new p("STORE_CORRUPTED","failed to parse sqlite blob",{cause:t})}}};var at,go=async()=>(at||(at=import('pg').catch(n=>{throw at=void 0,new p("STORE_NOT_AVAILABLE","pg is not installed. Run: pnpm add pg",{cause:n})})),at),ho="CREATE TABLE IF NOT EXISTS zaileys_auth_creds (id text PRIMARY KEY, data jsonb NOT NULL)",yo="CREATE TABLE IF NOT EXISTS zaileys_auth_signal (type text NOT NULL, id text NOT NULL, data bytea NOT NULL, PRIMARY KEY(type, id))",Kr=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 p("STORE_CONNECTION_FAILED","PostgresAuthStore: provide either pool or connectionString, not both");if(!t&&!r)throw new p("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 p("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 go(),r=t.Pool??t.default?.Pool;if(!r)throw new p("STORE_NOT_AVAILABLE","pg.Pool constructor not found");e=new r({connectionString:this.connectionString,max:this.poolMax}),this.ownedPool=e;}try{await e.query(ho),await e.query(yo);}catch(t){throw new p("STORE_CONNECTION_FAILED","failed to migrate auth schema",{cause:t})}return this.resolvedPool=e,e})());try{return await this.readyPromise}catch(e){throw this.readyPromise=void 0,e}}signal={read:async(e,t)=>{let r=await this.ensureReady(),s={};if(t.length===0)return s;try{let i=t.map((a,c)=>`$${c+2}`).join(", "),o=await r.query(`SELECT id, data FROM zaileys_auth_signal WHERE type = $1 AND id IN (${i})`,[String(e),...Array.from(t)]);for(let a of o.rows){let c=Buffer.isBuffer(a.data)?a.data:Buffer.from(a.data);s[a.id]=JSON.parse(c.toString("utf8"),BufferJSON.reviver);}return s}catch(i){throw i instanceof p?i:new p("STORE_READ_FAILED","failed to read signal rows",{cause:i})}},write:async e=>{let t=await this.ensureReady(),r=[];for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a];if(c===null)r.push({kind:"delete",type:String(i),id:a});else if(c!==void 0){let d=Buffer.from(JSON.stringify(c,BufferJSON.replacer),"utf8");r.push({kind:"upsert",type:String(i),id:a,value:d});}}}if(r.length===0)return;let s;try{s=await t.connect(),await s.query("BEGIN");for(let i of r)i.kind==="delete"?await s.query("DELETE FROM zaileys_auth_signal WHERE type = $1 AND id = $2",[i.type,i.id]):await s.query("INSERT INTO zaileys_auth_signal(type, id, data) VALUES ($1, $2, $3) ON CONFLICT (type, id) DO UPDATE SET data = EXCLUDED.data",[i.type,i.id,i.value]);await s.query("COMMIT");}catch(i){if(s)try{await s.query("ROLLBACK");}catch{}throw new p("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 p("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 p("STORE_WRITE_FAILED","failed to clear auth tables",{cause:r})}finally{t?.release();}},close:async()=>{if(this.closed)return;this.closed=true;let e=this.ownedPool;if(this.ownedPool=void 0,this.resolvedPool=void 0,this.readyPromise=void 0,e)try{await e.end();}catch{}}};creds={readCreds:async()=>{let e=await this.ensureReady();try{let r=(await e.query("SELECT data FROM zaileys_auth_creds WHERE id = 'default'")).rows[0];if(!r)return;let s=typeof r.data=="string"?r.data:JSON.stringify(r.data);return JSON.parse(s,BufferJSON.reviver)}catch(t){throw t instanceof p?t:new p("STORE_READ_FAILED","failed to read creds",{cause:t})}},writeCreds:async e=>{let t=await this.ensureReady();try{let r=JSON.stringify(e,BufferJSON.replacer);await t.query("INSERT INTO zaileys_auth_creds(id, data) VALUES ('default', $1::jsonb) ON CONFLICT (id) DO UPDATE SET data = EXCLUDED.data",[r]);}catch(r){throw new p("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 p("STORE_WRITE_FAILED","failed to delete creds",{cause:t})}}}};var wo="zaileys",vo=["pre-key","session","sender-key","sender-key-memory","app-state-sync-key","app-state-sync-version","lid-mapping","device-list","tctoken","identity-key"],So=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},qr=class{namespace;externalClient;url;ownedClient;ready;closed=false;constructor(e){if(e.client&&e.url)throw new p("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new p("STORE_CONNECTION_FAILED","RedisAuthStore requires either client or url");this.namespace=e.namespace??wo,this.externalClient=e.client,this.url=e.url;}signal={read:async(e,t)=>{if(this.assertOpen(),t.length===0)return {};let r=await this.ensureReady(),s=t.map(a=>this.signalKey(e,a)),i=await this.runRead(()=>r.mGet(s)),o={};for(let a=0;a<t.length;a+=1){let c=i[a];c!=null&&(o[t[a]]=JSON.parse(c,BufferJSON.reviver));}return o},write:async e=>{this.assertOpen();let r=(await this.ensureReady()).multi(),s=0;for(let i of Object.keys(e)){let o=e[i];if(o)for(let a of Object.keys(o)){let c=o[a],d=this.signalKey(i,a),l=this.indexKey(i);c===null?(r.del(d),r.sRem(l,a)):c!==void 0&&(r.set(d,JSON.stringify(c,BufferJSON.replacer)),r.sAdd(l,a)),s+=1;}}s!==0&&await this.runWrite(()=>r.exec());},delete:async(e,t)=>{if(this.assertOpen(),t.length===0)return;let s=(await this.ensureReady()).multi();for(let i of t)s.del(this.signalKey(e,i)),s.sRem(this.indexKey(e),i);await this.runWrite(()=>s.exec());},clear:async()=>{this.assertOpen();let e=await this.ensureReady(),t=e.multi();for(let r of vo){let s=this.indexKey(r),i=await this.runRead(()=>e.sMembers(s));for(let o of i)t.del(this.signalKey(r,o));t.del(s);}t.del(this.credsKey()),await this.runWrite(()=>t.exec());},close:async()=>{await this.shutdown();}};creds={readCreds:async()=>{this.assertOpen();let e=await this.ensureReady(),t=await this.runRead(()=>e.get(this.credsKey()));if(t!=null)return JSON.parse(t,BufferJSON.reviver)},writeCreds:async e=>{this.assertOpen();let t=await this.ensureReady();await this.runWrite(()=>t.set(this.credsKey(),JSON.stringify(e,BufferJSON.replacer)));},deleteCreds:async()=>{this.assertOpen();let e=await this.ensureReady();await this.runWrite(()=>e.del(this.credsKey()));}};credsKey(){return `${this.namespace}:auth:creds`}signalKey(e,t){return `${this.namespace}:auth:signal:${String(e)}:${t}`}indexKey(e){return `${this.namespace}:auth:signal-index:${String(e)}`}async ensureReady(){return this.ready||(this.ready=this.connect()),this.ready}async connect(){if(this.externalClient){if(!this.externalClient.isOpen)throw new p("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 So(r)?new p("STORE_NOT_AVAILABLE","redis peer dependency missing. Run: pnpm add redis",{cause:r}):new p("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 p("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 p("STORE_READ_FAILED","redis read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new p("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 p("STORE_CLOSED","RedisAuthStore is closed")}};var Ao="zaileys",xe={get:"zaileys:get",set:"zaileys:set",del:"zaileys:del",clear:"zaileys:clear",list:"zaileys:list"},Mo=n=>{if(typeof n!="object"||n===null)return false;let e=n.code;return e==="ERR_MODULE_NOT_FOUND"||e==="MODULE_NOT_FOUND"},ae=class{namespace;externalClient;url;client;closed=false;constructor(e){if(e.client&&e.url)throw new p("STORE_CONNECTION_FAILED","pass either client OR url, not both");if(!e.client&&!e.url)throw new p("STORE_CONNECTION_FAILED","ConvexKv requires either client or url");this.namespace=e.namespace??Ao,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(xe.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(xe.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(xe.del,{namespace:this.namespace,keys:[...e]}));}async clear(e){this.assertOpen();let t=await this.ensureClient();await this.runWrite(()=>t.mutation(xe.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(xe.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 Mo(r)?new p("STORE_NOT_AVAILABLE","convex peer dependency missing. Run: pnpm add convex",{cause:r}):new p("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 p("STORE_READ_FAILED","convex read failed",{cause:t})}}async runWrite(e){try{return await e()}catch(t){throw new p("STORE_WRITE_FAILED","convex write failed",{cause:t})}}assertOpen(){if(this.closed)throw new p("STORE_CLOSED","Convex store is closed")}};var lt="creds",Co="signal:",Re=(n,e)=>`${Co}${n}:${e}`,Jr=class{creds;signal;kv;constructor(e){this.kv=new ae(e);let t=this.kv;this.creds={async readCreds(){let s=(await t.get([lt])).get(lt);return s===void 0?void 0:JSON.parse(s,BufferJSON.reviver)},async writeCreds(r){await t.set([{key:lt,value:JSON.stringify(r,BufferJSON.replacer)}]);},async deleteCreds(){await t.del([lt]);}},this.signal={async read(r,s){let i=s.map(c=>Re(r,c)),o=await t.get(i),a={};for(let c of s){let d=o.get(Re(r,c));a[c]=d===void 0?void 0:JSON.parse(d,BufferJSON.reviver);}return a},async write(r){let s=[],i=[];for(let o of Object.keys(r)){let a=r[o];if(a)for(let c of Object.keys(a)){let d=a[c];d==null?i.push(Re(o,c)):s.push({key:Re(o,c),value:JSON.stringify(d,BufferJSON.replacer)});}}s.length>0&&await t.set(s),i.length>0&&await t.del(i);},async delete(r,s){await t.del(s.map(i=>Re(r,i)));},async clear(){await t.clear();},async close(){t.close();}};}};var ut=null,Eo=async()=>{if(ut)return ut;try{return ut=(await import('better-sqlite3')).default,ut}catch(n){throw new p("STORE_NOT_AVAILABLE","better-sqlite3 belum terpasang. Run: pnpm add better-sqlite3",{cause:n})}},pt=n=>{try{return Buffer.from(JSON.stringify(n,BufferJSON.replacer),"utf8")}catch(e){throw new p("STORE_WRITE_FAILED","failed to serialize sqlite blob",{cause:e})}},ee=n=>{try{let e=Buffer.isBuffer(n)?n.toString("utf8"):Buffer.from(n).toString("utf8");return JSON.parse(e,BufferJSON.reviver)}catch(e){throw new p("STORE_CORRUPTED","failed to parse sqlite blob",{cause:e})}},$r=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,pt(e));}async getMessage(e){let r=(await this.ensureReady()).getMessage.get(e.remoteJid??"",e.id??"",e.fromMe?1:0);return r?ee(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=>ee(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,pt(e));}async getChat(e){let r=(await this.ensureReady()).getChat.get(e);return r?ee(r.data):void 0}async listChats(e){let t=await this.ensureReady();return (e?.archived===true?t.listChatsArchived.all():t.listChats.all()).map(s=>ee(s.data))}async saveContact(e){(await this.ensureReady()).upsertContact.run(e.id,pt(e));}async getContact(e){let r=(await this.ensureReady()).getContact.get(e);return r?ee(r.data):void 0}async listContacts(){return (await this.ensureReady()).listContacts.all().map(r=>ee(r.data))}async savePresence(e,t){(await this.ensureReady()).upsertPresence.run(e,pt(t));}async getPresence(e){let r=(await this.ensureReady()).getPresence.get(e);return r?ee(r.data):void 0}bind(e){if(this.closed)throw new p("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 p("STORE_WRITE_FAILED","failed to close sqlite database",{cause:e})}finally{this.db=null,this.prepared=null;}}}async ensureReady(){if(this.closed)throw new p("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 Eo(),t;try{t=new e(this.options.database,{readonly:this.options.readonly??!1});}catch(r){throw new p("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 (
|
|
17
17
|
remote_jid TEXT NOT NULL,
|
|
18
18
|
id TEXT NOT NULL,
|