@askexenow/exe-os 0.9.127 → 0.9.129
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/active-agent-3FDJYREJ.js +22 -0
- package/dist/active-agent-WC7YK3L5.js +23 -0
- package/dist/agent-context-CDWUZEXY.js +11 -0
- package/dist/agent-loop-G4VUR5ME.js +10 -0
- package/dist/agentic-ontology-2VYNTMNO.js +25 -0
- package/dist/backfill-metadata-OJWOCLSZ.js +601 -0
- package/dist/background-jobs-LGRDXGXC.js +25 -0
- package/dist/bash-Y5PEW5UQ.js +8 -0
- package/dist/behaviors-CSB2YLDT.js +22 -0
- package/dist/bin/age-ontology-load.js +10 -258
- package/dist/bin/agentic-ontology-backfill.js +23 -5296
- package/dist/bin/agentic-reflection-backfill.js +19 -4739
- package/dist/bin/agentic-semantic-label.js +28 -4723
- package/dist/bin/backfill-conversations.js +42 -5543
- package/dist/bin/backfill-responses.js +41 -5542
- package/dist/bin/backfill-vectors.js +43 -4795
- package/dist/bin/bulk-sync-postgres.js +22 -5313
- package/dist/bin/cc-doctor.js +10 -602
- package/dist/bin/cleanup-stale-review-tasks.js +32 -6803
- package/dist/bin/cli.js +169 -38993
- package/dist/bin/exe-agent-config.js +21 -253
- package/dist/bin/exe-agent.js +63 -2429
- package/dist/bin/exe-assign.js +34 -5810
- package/dist/bin/exe-boot.js +180 -12726
- package/dist/bin/exe-call.js +48 -1409
- package/dist/bin/exe-cloud.js +64 -8516
- package/dist/bin/exe-dispatch.js +35 -10818
- package/dist/bin/exe-doctor.js +24 -7537
- package/dist/bin/exe-export-behaviors.js +18 -6122
- package/dist/bin/exe-forget.js +22 -6274
- package/dist/bin/exe-gateway.js +62 -15286
- package/dist/bin/exe-healthcheck.js +9 -602
- package/dist/bin/exe-heartbeat.js +51 -6898
- package/dist/bin/exe-kill.js +30 -5961
- package/dist/bin/exe-launch-agent.js +101 -6788
- package/dist/bin/exe-new-employee.js +42 -3774
- package/dist/bin/exe-pending-messages.js +28 -6833
- package/dist/bin/exe-pending-notifications.js +31 -6869
- package/dist/bin/exe-pending-reviews.js +38 -6910
- package/dist/bin/exe-rename.js +57 -5766
- package/dist/bin/exe-review.js +29 -5948
- package/dist/bin/exe-search.js +22 -7692
- package/dist/bin/exe-session-cleanup.js +52 -11147
- package/dist/bin/exe-settings.js +35 -524
- package/dist/bin/exe-start-codex.js +70 -6641
- package/dist/bin/exe-start-opencode.js +54 -6584
- package/dist/bin/exe-status.js +26 -7081
- package/dist/bin/exe-support.js +10 -546
- package/dist/bin/exe-team.js +18 -5942
- package/dist/bin/git-sweep.js +26 -10909
- package/dist/bin/graph-backfill.js +24 -5979
- package/dist/bin/graph-export.js +31 -6128
- package/dist/bin/graph-layer-benchmark.js +4 -8
- package/dist/bin/install.js +47 -2322
- package/dist/bin/intercom-check.js +25 -11501
- package/dist/bin/list-providers.js +4 -18
- package/dist/bin/postgres-agentic-reflection-backfill.js +14 -357
- package/dist/bin/postgres-agentic-semantic-backfill.js +14 -404
- package/dist/bin/pre-publish.js +4 -298
- package/dist/bin/registry-proxy.js +8 -172
- package/dist/bin/scan-tasks.js +47 -10881
- package/dist/bin/setup.js +6 -9492
- package/dist/bin/shard-migrate.js +30 -5149
- package/dist/bin/stack-update.js +75 -203
- package/dist/bin/update.js +20 -654
- package/dist/capacity-monitor-3GZIHLB4.js +46 -0
- package/dist/catchup-brief-67QDCINS.js +148 -0
- package/dist/chunk-2QD7KBJN.js +664 -0
- package/dist/chunk-2WGSIVI4.js +149 -0
- package/dist/chunk-35TVNLJI.js +57 -0
- package/dist/chunk-3SYV36U5.js +47 -0
- package/dist/chunk-46SQTBQW.js +207 -0
- package/dist/chunk-4CMVLKEI.js +171 -0
- package/dist/chunk-4FLUOZTR.js +116 -0
- package/dist/chunk-4NYQAS33.js +17 -0
- package/dist/chunk-4QNPADWL.js +902 -0
- package/dist/chunk-4Y6QZBEO.js +58 -0
- package/dist/chunk-557C2IGL.js +0 -0
- package/dist/chunk-55S56YDO.js +305 -0
- package/dist/chunk-5BS5ELMC.js +85 -0
- package/dist/chunk-5DHM77JE.js +256 -0
- package/dist/chunk-5QTWQKNF.js +137 -0
- package/dist/chunk-6A7P74QV.js +53 -0
- package/dist/chunk-6BFIFI5F.js +45 -0
- package/dist/chunk-6KFICEAT.js +20 -0
- package/dist/chunk-6LKDJ5WX.js +317 -0
- package/dist/chunk-6M5II4EV.js +148 -0
- package/dist/chunk-6QEFN3DV.js +302 -0
- package/dist/chunk-6WTMJAG3.js +171 -0
- package/dist/chunk-6Y4B3QF6.js +19 -0
- package/dist/chunk-7RK3AYJE.js +163 -0
- package/dist/chunk-7TCP2XTP.js +390 -0
- package/dist/chunk-A2NZP64U.js +2307 -0
- package/dist/chunk-AFYIYM2K.js +322 -0
- package/dist/chunk-AJWFPKQS.js +573 -0
- package/dist/chunk-AVE2B4DQ.js +140 -0
- package/dist/chunk-B4TT2QQA.js +87 -0
- package/dist/chunk-BCMOO4OQ.js +1066 -0
- package/dist/chunk-BU3ID2WT.js +432 -0
- package/dist/chunk-CFIM43JH.js +862 -0
- package/dist/chunk-CURJUF3W.js +66 -0
- package/dist/chunk-DC4ZD76Y.js +288 -0
- package/dist/chunk-DL52JPGF.js +706 -0
- package/dist/chunk-DRSC6ZRA.js +36 -0
- package/dist/chunk-E2Q4Y22A.js +86 -0
- package/dist/chunk-ECGTESAP.js +236 -0
- package/dist/chunk-EHOJUXYG.js +365 -0
- package/dist/chunk-EIT6J37V.js +119 -0
- package/dist/chunk-ELE2C7L4.js +31 -0
- package/dist/chunk-EQSQ4HBW.js +9 -0
- package/dist/chunk-FWFFZGSC.js +94 -0
- package/dist/chunk-GCNWCYJI.js +249 -0
- package/dist/chunk-GGTUUI7J.js +6 -0
- package/dist/chunk-GU56L7OY.js +223 -0
- package/dist/chunk-HF25XPZE.js +83 -0
- package/dist/chunk-HOKOOBDL.js +52 -0
- package/dist/chunk-HP43GLZ6.js +89 -0
- package/dist/chunk-HSRM6PNM.js +682 -0
- package/dist/chunk-HVRTW3OP.js +164 -0
- package/dist/chunk-IHDHL5ML.js +125 -0
- package/dist/chunk-IHF5RXJM.js +168 -0
- package/dist/chunk-IJ73YE73.js +409 -0
- package/dist/chunk-INO4ZD5Y.js +162 -0
- package/dist/chunk-IRQTM7DY.js +475 -0
- package/dist/chunk-JD4FAPYG.js +1208 -0
- package/dist/chunk-JN44LQ53.js +316 -0
- package/dist/chunk-JQ6TLNIV.js +133 -0
- package/dist/chunk-JT76KRZQ.js +35 -0
- package/dist/chunk-K6OEWZTB.js +262 -0
- package/dist/chunk-KCUYRZSX.js +72 -0
- package/dist/chunk-KFQGP6VL.js +33 -0
- package/dist/chunk-KRLOFIPI.js +83 -0
- package/dist/chunk-KVPG5UT6.js +305 -0
- package/dist/chunk-L3TB7CC3.js +170 -0
- package/dist/chunk-L4X5EUHR.js +283 -0
- package/dist/chunk-LAN26C3W.js +655 -0
- package/dist/chunk-LPGBKR4H.js +54 -0
- package/dist/chunk-LVNMOVGD.js +132 -0
- package/dist/chunk-LX5WEEZ7.js +157 -0
- package/dist/chunk-MBH42QNH.js +295 -0
- package/dist/chunk-MFO7MNSD.js +102 -0
- package/dist/chunk-MILTNDZH.js +736 -0
- package/dist/chunk-MJAE4NB7.js +1090 -0
- package/dist/chunk-MLCUPTP7.js +132 -0
- package/dist/chunk-MPURH6JI.js +445 -0
- package/dist/chunk-MVBWW2EO.js +89 -0
- package/dist/chunk-MZIGUUDQ.js +42 -0
- package/dist/chunk-N3DTSVKE.js +157 -0
- package/dist/chunk-N5RRQOAC.js +134 -0
- package/dist/chunk-N7L33TED.js +1664 -0
- package/dist/chunk-NDYSNVI5.js +122 -0
- package/dist/chunk-NEAHEC5G.js +155 -0
- package/dist/chunk-NGVOA6ZQ.js +84 -0
- package/dist/chunk-NHK5KW6Y.js +193 -0
- package/dist/chunk-NMQKGFEP.js +458 -0
- package/dist/chunk-NPT4EHZK.js +352 -0
- package/dist/chunk-NXFJHTED.js +55 -0
- package/dist/chunk-NZLCDI6Y.js +216 -0
- package/dist/chunk-O377P7GM.js +100 -0
- package/dist/chunk-O4VFZRA5.js +33 -0
- package/dist/chunk-O7YD7JYE.js +237 -0
- package/dist/chunk-OFK72LTZ.js +81 -0
- package/dist/chunk-ORCCI2VV.js +140 -0
- package/dist/chunk-OVQR4KMC.js +579 -0
- package/dist/chunk-P3CVUMEH.js +54 -0
- package/dist/chunk-P4HIF72O.js +30 -0
- package/dist/chunk-PEDLSJBL.js +1039 -0
- package/dist/chunk-PFICKZZ5.js +219 -0
- package/dist/chunk-PGW7TIV6.js +142 -0
- package/dist/chunk-PJHHFJAN.js +63 -0
- package/dist/chunk-PP4SNOJ5.js +471 -0
- package/dist/chunk-PRKVT4KN.js +90 -0
- package/dist/chunk-Q2O4VJHH.js +305 -0
- package/dist/chunk-Q36CMZIX.js +38 -0
- package/dist/chunk-Q3V7K4ME.js +149 -0
- package/dist/chunk-QGYPJGHB.js +81 -0
- package/dist/chunk-R23EMFJV.js +198 -0
- package/dist/chunk-R4M6XCMU.js +39 -0
- package/dist/chunk-R4WMF32C.js +81 -0
- package/dist/chunk-RJT7H2KR.js +349 -0
- package/dist/chunk-RJZMRZNV.js +280 -0
- package/dist/chunk-RMFDPCA2.js +72 -0
- package/dist/chunk-RUG3N6P4.js +292 -0
- package/dist/chunk-RWO327FJ.js +84 -0
- package/dist/chunk-SG7EFHQ7.js +108 -0
- package/dist/chunk-SH45SJQW.js +0 -0
- package/dist/chunk-SPKE5ANC.js +42 -0
- package/dist/chunk-SVMFVPBF.js +104 -0
- package/dist/chunk-SVXDCELZ.js +163 -0
- package/dist/chunk-TMEE7AT7.js +72 -0
- package/dist/chunk-TWYEE4FB.js +125 -0
- package/dist/chunk-TYLF4LSW.js +110 -0
- package/dist/chunk-V4TZI6EO.js +60 -0
- package/dist/chunk-VFZTXKQI.js +372 -0
- package/dist/chunk-VQ4K2MLM.js +199 -0
- package/dist/chunk-VU447UAO.js +173 -0
- package/dist/chunk-WMC3TXJF.js +50 -0
- package/dist/chunk-WPOA7XAE.js +84 -0
- package/dist/chunk-WZQ4CPRG.js +64 -0
- package/dist/chunk-X2IMCCM5.js +49 -0
- package/dist/chunk-X2Z5GT3V.js +118 -0
- package/dist/chunk-XEKO37NM.js +43 -0
- package/dist/chunk-XUHFQHGZ.js +505 -0
- package/dist/chunk-YGAAZN3E.js +47 -0
- package/dist/chunk-YKOW7KMK.js +558 -0
- package/dist/chunk-YOQKMB6N.js +145 -0
- package/dist/chunk-YZFZDJWZ.js +107 -0
- package/dist/chunk-ZBY4AUD4.js +10342 -0
- package/dist/chunk-ZOJYPNCM.js +127 -0
- package/dist/chunk-ZS7MGQSD.js +1494 -0
- package/dist/chunk-ZTZQ5A6B.js +191 -0
- package/dist/code-context-index-HXGC4IJL.js +28 -0
- package/dist/content-extractor-UVZXRIPC.js +8 -0
- package/dist/conversation-entity-extractor-HKSNDF4L.js +113 -0
- package/dist/conversation-wiki-populator-NKDAQEZ5.js +105 -0
- package/dist/crdt-sync-T7MHVQCS.js +33 -0
- package/dist/crm-bridge-Q5JBVJ6P.js +19 -0
- package/dist/crm-webhook-OAFTLJYA.js +10 -0
- package/dist/cto-delegation-gate-XWHZCUJH.js +208 -0
- package/dist/daemon-auth-GWUXTUYO.js +15 -0
- package/dist/daemon-orchestration-2C3TVOHO.js +91 -0
- package/dist/daemon-protocol-RLH2XM2K.js +19 -0
- package/dist/db-backup-CH2KG3JY.js +23 -0
- package/dist/devtools-PLJCAU53.js +8 -0
- package/dist/discord-G4BQJ2VX.js +7 -0
- package/dist/email-XMRNMFXR.js +137 -0
- package/dist/entity-boost-IOER4VRR.js +249 -0
- package/dist/exe-drift-2IJFQV43.js +68 -0
- package/dist/exe-export-Y2RFXGNB.js +71 -0
- package/dist/exe-import-LN6PE2YT.js +74 -0
- package/dist/exe-key-DHKBWLIT.js +571 -0
- package/dist/exe-org-F7LZRHFB.js +73 -0
- package/dist/factory-YTD23AW7.js +67 -0
- package/dist/fast-db-init-IIP6EGWT.js +7 -0
- package/dist/file-edit-FJVEO7XZ.js +8 -0
- package/dist/file-read-Q2NH3J35.js +8 -0
- package/dist/file-write-UNSFXNH4.js +8 -0
- package/dist/gateway/index.js +87 -16563
- package/dist/gateway-client-APTYJNCL.js +11 -0
- package/dist/git-staleness-I2BUEDE2.js +111 -0
- package/dist/git-task-sweep-UEOTXRW4.js +35 -0
- package/dist/glob-GRMXLDMB.js +7 -0
- package/dist/global-procedures-MFE5LGRF.js +19 -0
- package/dist/graph-query-657O5JYJ.js +25 -0
- package/dist/graph-rag-ZE5N7C65.js +28 -0
- package/dist/grep-NBV6SKYZ.js +7 -0
- package/dist/hooks/bug-report-worker.js +41 -10823
- package/dist/hooks/codex-stop-task-finalizer.js +38 -9055
- package/dist/hooks/commit-complete.js +32 -10914
- package/dist/hooks/error-recall.js +35 -7955
- package/dist/hooks/exe-heartbeat-hook.js +17 -327
- package/dist/hooks/ingest-worker.js +16 -565
- package/dist/hooks/ingest.js +98 -11436
- package/dist/hooks/instructions-loaded.js +25 -6209
- package/dist/hooks/notification.js +16 -6098
- package/dist/hooks/post-compact.js +34 -7041
- package/dist/hooks/post-tool-combined.js +27 -9751
- package/dist/hooks/pre-compact.js +38 -11130
- package/dist/hooks/pre-tool-use.js +61 -7233
- package/dist/hooks/prompt-submit.js +113 -13358
- package/dist/hooks/session-end.js +57 -11503
- package/dist/hooks/session-start.js +46 -9423
- package/dist/hooks/stop.js +70 -7210
- package/dist/hooks/subagent-stop.js +33 -6897
- package/dist/hooks/summary-worker.js +86 -8629
- package/dist/hooks-KD3N2D7P.js +9 -0
- package/dist/imessage-L7WKA2WD.js +7 -0
- package/dist/index.js +49 -19391
- package/dist/installer-5N24GXFB.js +32 -0
- package/dist/installer-QSD76YRY.js +291 -0
- package/dist/installer-ZPQUKHU5.js +331 -0
- package/dist/intercom-queue-PEEGAJ33.js +19 -0
- package/dist/key-backup-status-57UB74DU.js +41 -0
- package/dist/lib/agent-config.js +19 -224
- package/dist/lib/cloud-sync.js +44 -5398
- package/dist/lib/cloudflare-dns.js +7 -111
- package/dist/lib/config.js +18 -278
- package/dist/lib/consolidation.js +21 -1047
- package/dist/lib/crypto.js +7 -45
- package/dist/lib/database.js +20 -2932
- package/dist/lib/db-daemon-client.js +24 -460
- package/dist/lib/db.js +22 -2932
- package/dist/lib/device-registry.js +20 -2992
- package/dist/lib/embedder.js +14 -822
- package/dist/lib/employee-templates.js +21 -1102
- package/dist/lib/employees.js +30 -497
- package/dist/lib/error-detector.js +9 -149
- package/dist/lib/exe-daemon-client.js +16 -570
- package/dist/lib/exe-daemon.js +509 -18398
- package/dist/lib/file-grep.js +2 -0
- package/dist/lib/hybrid-search.js +18 -7674
- package/dist/lib/identity-templates.js +2 -0
- package/dist/lib/identity.js +13 -309
- package/dist/lib/keychain.js +9 -499
- package/dist/lib/license.js +21 -549
- package/dist/lib/messaging.js +35 -1631
- package/dist/lib/post-tool-memory.js +8 -370
- package/dist/lib/registry-proxy.js +8 -155
- package/dist/lib/reminders.js +11 -231
- package/dist/lib/runtime-table.js +7 -20
- package/dist/lib/schedules.js +16 -4614
- package/dist/lib/session-registry.js +9 -57
- package/dist/lib/session-wrappers.js +3 -127
- package/dist/lib/skill-learning.js +20 -2101
- package/dist/lib/status-brief.js +4 -368
- package/dist/lib/store.js +25 -5593
- package/dist/lib/task-router.js +12 -254
- package/dist/lib/tasks.js +44 -5801
- package/dist/lib/tmux-routing.js +45 -5804
- package/dist/lib/tmux-status.js +16 -248
- package/dist/lib/tmux-transport.js +6 -90
- package/dist/lib/token-spend.js +9 -337
- package/dist/lib/transport.js +8 -134
- package/dist/lib/ws-auth.js +6 -14
- package/dist/lib/ws-client.js +4 -22
- package/dist/license-gate-NXXDOOAQ.js +14 -0
- package/dist/mcp/register-tools.js +90 -32454
- package/dist/mcp/server.js +139 -32625
- package/dist/mcp/tools/complete-reminder.js +10 -237
- package/dist/mcp/tools/create-reminder.js +10 -222
- package/dist/mcp/tools/create-task.js +28 -6730
- package/dist/mcp/tools/deactivate-behavior.js +13 -476
- package/dist/mcp/tools/list-reminders.js +10 -232
- package/dist/mcp/tools/list-tasks.js +28 -1571
- package/dist/mcp/tools/send-message.js +25 -1672
- package/dist/mcp/tools/update-task.js +27 -6123
- package/dist/mcp-diagnostics-OOZ3TDPY.js +200 -0
- package/dist/memory-cards-RIL5BZHK.js +175 -0
- package/dist/memory-queue-JYIJ7TMQ.js +13 -0
- package/dist/memory-queue-client-PE7757HU.js +14 -0
- package/dist/notifications-CJFULBMN.js +42 -0
- package/dist/orchestration-phase-Y2TYNW5H.js +23 -0
- package/dist/orchestrator-RXIPT6PZ.js +29 -0
- package/dist/permission-presets-WI524OSE.js +25 -0
- package/dist/permissions-TYT6YMNZ.js +14 -0
- package/dist/pg-ssl-KFHNJPGO.js +7 -0
- package/dist/plan-limits-5WY5YK6X.js +27 -0
- package/dist/preferences-MW3BYTQ5.js +10 -0
- package/dist/project-name-PL2ZDWNU.js +11 -0
- package/dist/projection-worker-OY4WYZW6.js +661 -0
- package/dist/reranker-LFJ73RRS.js +19 -0
- package/dist/review-gate-E6K7QQE5.js +120 -0
- package/dist/runtime/index.js +82 -13408
- package/dist/self-query-router-IZANO632.js +83 -0
- package/dist/session-events-TQ6S5KQN.js +32 -0
- package/dist/session-kill-telemetry-46YIJWE2.js +30 -0
- package/dist/session-scope-3MYK3YRV.js +34 -0
- package/dist/setup-wizard-ZJ7UCRBP.js +12 -0
- package/dist/shard-manager-RCFZ6RXY.js +29 -0
- package/dist/signal-XN2C7PIG.js +7 -0
- package/dist/slack-Z77TFJCK.js +7 -0
- package/dist/task-enforcement-337DZI3I.js +252 -0
- package/dist/task-scanner-IMIR3T7T.js +11 -0
- package/dist/task-scope-MUU4KXE6.js +32 -0
- package/dist/tasks-crud-PMLK3MM4.js +53 -0
- package/dist/tasks-review-56LVKKNL.js +44 -0
- package/dist/telegram-CRPZO7JT.js +7 -0
- package/dist/telemetry-SPVGPKU7.js +9 -0
- package/dist/tool-capability-index-XNBSDCH3.js +10 -0
- package/dist/tool-gates-LGH6CSY4.js +14 -0
- package/dist/tool-gates-W7SZCYTX.js +13 -0
- package/dist/tool-registry-436LVVLY.js +11 -0
- package/dist/tool-telemetry-L77WNAYT.js +15 -0
- package/dist/tui/App.js +253 -14668
- package/dist/tui-data-SB45REYU.js +161 -0
- package/dist/update-check-LZGZISRJ.js +11 -0
- package/dist/webhook-VVP7KQVC.js +96 -0
- package/dist/whatsapp-J6QNDBGY.js +9 -0
- package/dist/whatsapp-accounts-RTJF3LM6.js +15 -0
- package/dist/wiki-client-EKCIKCVC.js +136 -0
- package/dist/worker-gate-UYNN62GJ.js +19 -0
- package/dist/worktree-4T4BPWPN.js +205 -0
- package/package.json +1 -1
|
@@ -0,0 +1,432 @@
|
|
|
1
|
+
// src/gateway/adapters/whatsapp.ts
|
|
2
|
+
import { randomUUID } from "crypto";
|
|
3
|
+
import { homedir } from "os";
|
|
4
|
+
import { join } from "path";
|
|
5
|
+
import { mkdirSync } from "fs";
|
|
6
|
+
var INITIAL_BACKOFF_MS = 1e3;
|
|
7
|
+
var MAX_BACKOFF_MS = 3e5;
|
|
8
|
+
var BACKOFF_MULTIPLIER = 2;
|
|
9
|
+
var JITTER_FACTOR = 0.25;
|
|
10
|
+
var AUTH_DIR = join(homedir(), ".exe-os", "whatsapp-auth");
|
|
11
|
+
function createBaileysLogger(accountName) {
|
|
12
|
+
const prefix = accountName ? `[whatsapp:${accountName}]` : "[whatsapp]";
|
|
13
|
+
let logger;
|
|
14
|
+
logger = {
|
|
15
|
+
level: "warn",
|
|
16
|
+
trace: () => {
|
|
17
|
+
},
|
|
18
|
+
debug: () => {
|
|
19
|
+
},
|
|
20
|
+
info: () => {
|
|
21
|
+
},
|
|
22
|
+
warn: (...args) => console.warn(prefix, ...args),
|
|
23
|
+
error: (...args) => console.error(prefix, ...args),
|
|
24
|
+
fatal: (...args) => console.error(prefix, ...args),
|
|
25
|
+
child: () => logger
|
|
26
|
+
};
|
|
27
|
+
return logger;
|
|
28
|
+
}
|
|
29
|
+
function calculateBackoff(retryCount) {
|
|
30
|
+
const base = Math.min(
|
|
31
|
+
INITIAL_BACKOFF_MS * BACKOFF_MULTIPLIER ** retryCount,
|
|
32
|
+
MAX_BACKOFF_MS
|
|
33
|
+
);
|
|
34
|
+
const jitter = base * JITTER_FACTOR * (2 * Math.random() - 1);
|
|
35
|
+
return Math.max(INITIAL_BACKOFF_MS, Math.round(base + jitter));
|
|
36
|
+
}
|
|
37
|
+
var WhatsAppAdapter = class {
|
|
38
|
+
platform = "whatsapp";
|
|
39
|
+
sock = null;
|
|
40
|
+
messageHandler = null;
|
|
41
|
+
connected = false;
|
|
42
|
+
abortController = null;
|
|
43
|
+
authDir = AUTH_DIR;
|
|
44
|
+
baileysLogger = createBaileysLogger();
|
|
45
|
+
// Resilience state
|
|
46
|
+
retryCount = 0;
|
|
47
|
+
disconnectedAt = 0;
|
|
48
|
+
async connect(config) {
|
|
49
|
+
this.authDir = config.credentials.authDir ?? AUTH_DIR;
|
|
50
|
+
mkdirSync(this.authDir, { recursive: true });
|
|
51
|
+
const baileys = await import("@whiskeysockets/baileys");
|
|
52
|
+
const { makeWASocket, useMultiFileAuthState, fetchLatestBaileysVersion, DisconnectReason, makeCacheableSignalKeyStore } = baileys;
|
|
53
|
+
const { state, saveCreds } = await useMultiFileAuthState(this.authDir);
|
|
54
|
+
const { version } = await fetchLatestBaileysVersion();
|
|
55
|
+
this.baileysLogger = createBaileysLogger();
|
|
56
|
+
this.abortController = new AbortController();
|
|
57
|
+
let agent;
|
|
58
|
+
const socksProxy = config.credentials.socksProxy;
|
|
59
|
+
if (socksProxy) {
|
|
60
|
+
try {
|
|
61
|
+
const modName = "socks-proxy-agent";
|
|
62
|
+
const mod = await import(modName);
|
|
63
|
+
const SocksProxyAgent = mod.SocksProxyAgent ?? mod.default;
|
|
64
|
+
agent = new SocksProxyAgent(socksProxy);
|
|
65
|
+
console.log(`[whatsapp] Using SOCKS proxy: ${socksProxy.replace(/\/\/.*@/, "//***@")}`);
|
|
66
|
+
} catch {
|
|
67
|
+
console.error("[whatsapp] socks-proxy-agent not installed \u2014 run: npm i socks-proxy-agent");
|
|
68
|
+
throw new Error("SOCKS proxy configured but socks-proxy-agent package not installed");
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
const sock = makeWASocket({
|
|
72
|
+
auth: {
|
|
73
|
+
creds: state.creds,
|
|
74
|
+
keys: makeCacheableSignalKeyStore(state.keys, this.baileysLogger)
|
|
75
|
+
},
|
|
76
|
+
logger: this.baileysLogger,
|
|
77
|
+
version,
|
|
78
|
+
printQRInTerminal: true,
|
|
79
|
+
browser: ["exe-os", "cli", "1.0"],
|
|
80
|
+
syncFullHistory: false,
|
|
81
|
+
markOnlineOnConnect: false,
|
|
82
|
+
...agent ? { agent } : {}
|
|
83
|
+
});
|
|
84
|
+
this.sock = sock;
|
|
85
|
+
sock.ev.on("creds.update", saveCreds);
|
|
86
|
+
sock.ev.on("connection.update", (update) => {
|
|
87
|
+
const { connection, lastDisconnect } = update;
|
|
88
|
+
if (connection === "close") {
|
|
89
|
+
this.connected = false;
|
|
90
|
+
if (this.disconnectedAt === 0) this.disconnectedAt = Date.now();
|
|
91
|
+
const statusCode = lastDisconnect?.error?.output?.statusCode;
|
|
92
|
+
const shouldReconnect = statusCode !== DisconnectReason.loggedOut;
|
|
93
|
+
if (shouldReconnect && !this.abortController?.signal.aborted) {
|
|
94
|
+
const delay = calculateBackoff(this.retryCount);
|
|
95
|
+
this.retryCount++;
|
|
96
|
+
console.log(
|
|
97
|
+
`[whatsapp] Connection closed (code=${statusCode}), retry #${this.retryCount} in ${(delay / 1e3).toFixed(1)}s` + (socksProxy ? ` (proxy: ${socksProxy.replace(/\/\/.*@/, "//***@")})` : "")
|
|
98
|
+
);
|
|
99
|
+
setTimeout(() => void this.connect(config), delay);
|
|
100
|
+
} else {
|
|
101
|
+
console.log("[whatsapp] Logged out \u2014 clear auth and re-scan QR");
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (connection === "open") {
|
|
105
|
+
if (this.retryCount > 0) {
|
|
106
|
+
const downtimeSec = this.disconnectedAt > 0 ? ((Date.now() - this.disconnectedAt) / 1e3).toFixed(1) : "?";
|
|
107
|
+
console.log(
|
|
108
|
+
`[whatsapp] Reconnected after ${this.retryCount} retries (${downtimeSec}s downtime)`
|
|
109
|
+
);
|
|
110
|
+
} else {
|
|
111
|
+
console.log("[whatsapp] Connected via Baileys (linked device)");
|
|
112
|
+
}
|
|
113
|
+
this.connected = true;
|
|
114
|
+
this.retryCount = 0;
|
|
115
|
+
this.disconnectedAt = 0;
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
sock.ev.on("messages.upsert", (upsert) => {
|
|
119
|
+
if (!this.messageHandler) return;
|
|
120
|
+
const { messages, type } = upsert;
|
|
121
|
+
if (type !== "notify") return;
|
|
122
|
+
for (const msg of messages) {
|
|
123
|
+
if (msg.key.fromMe) continue;
|
|
124
|
+
const normalized = this.normalizeMessage(msg);
|
|
125
|
+
if (normalized) {
|
|
126
|
+
void this.messageHandler(normalized).catch((err) => {
|
|
127
|
+
console.error("[whatsapp] Message handler error:", err);
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
sock.ev.on("message-receipt.update", (updates) => {
|
|
133
|
+
if (!this.messageHandler) return;
|
|
134
|
+
for (const update of updates) {
|
|
135
|
+
const receipt = this.normalizeReadReceipt(update);
|
|
136
|
+
if (receipt) {
|
|
137
|
+
void this.messageHandler(receipt).catch((err) => {
|
|
138
|
+
console.error("[whatsapp] Read receipt handler error:", err);
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
sock.ev.on("contacts.upsert", (contacts) => {
|
|
144
|
+
if (!this.messageHandler) return;
|
|
145
|
+
for (const contact of contacts) {
|
|
146
|
+
const synced = this.normalizeContactSync(contact);
|
|
147
|
+
if (synced) {
|
|
148
|
+
void this.messageHandler(synced).catch((err) => {
|
|
149
|
+
console.error("[whatsapp] Contact sync handler error:", err);
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
sock.ev.on("groups.upsert", (groups) => {
|
|
155
|
+
if (!this.messageHandler) return;
|
|
156
|
+
for (const group of groups) {
|
|
157
|
+
const normalized = this.normalizeGroupInfo(group);
|
|
158
|
+
if (normalized) {
|
|
159
|
+
void this.messageHandler(normalized).catch((err) => {
|
|
160
|
+
console.error("[whatsapp] Group handler error:", err);
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
sock.ev.on("messages.reaction", (reactions) => {
|
|
166
|
+
if (!this.messageHandler) return;
|
|
167
|
+
for (const reaction of reactions) {
|
|
168
|
+
const normalized = this.normalizeReaction(reaction);
|
|
169
|
+
if (normalized) {
|
|
170
|
+
void this.messageHandler(normalized).catch((err) => {
|
|
171
|
+
console.error("[whatsapp] Reaction handler error:", err);
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
sock.ev.on("call", (calls) => {
|
|
177
|
+
if (!this.messageHandler) return;
|
|
178
|
+
for (const call of calls) {
|
|
179
|
+
const normalized = this.normalizeCall(call);
|
|
180
|
+
if (normalized) {
|
|
181
|
+
void this.messageHandler(normalized).catch((err) => {
|
|
182
|
+
console.error("[whatsapp] Call handler error:", err);
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
sock.ev.on("messaging-history.set", (history) => {
|
|
188
|
+
if (!this.messageHandler) return;
|
|
189
|
+
const { messages: historyMessages } = history;
|
|
190
|
+
if (!Array.isArray(historyMessages)) return;
|
|
191
|
+
for (const msg of historyMessages) {
|
|
192
|
+
if (msg.key?.fromMe) continue;
|
|
193
|
+
const normalized = this.normalizeMessage(msg);
|
|
194
|
+
if (normalized) {
|
|
195
|
+
normalized.dataCategory = "history_sync";
|
|
196
|
+
normalized.isHistorical = true;
|
|
197
|
+
void this.messageHandler(normalized).catch((err) => {
|
|
198
|
+
console.error("[whatsapp] History sync handler error:", err);
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
async disconnect() {
|
|
205
|
+
this.abortController?.abort();
|
|
206
|
+
this.abortController = null;
|
|
207
|
+
this.sock?.ws?.close();
|
|
208
|
+
this.sock = null;
|
|
209
|
+
this.connected = false;
|
|
210
|
+
}
|
|
211
|
+
onMessage(handler) {
|
|
212
|
+
this.messageHandler = handler;
|
|
213
|
+
}
|
|
214
|
+
async sendText(channelId, text, options) {
|
|
215
|
+
if (!this.sock || !this.connected) throw new Error("WhatsApp not connected");
|
|
216
|
+
const jid = channelId.includes("@") ? channelId : `${channelId}@s.whatsapp.net`;
|
|
217
|
+
await this.sock.sendMessage(jid, {
|
|
218
|
+
text,
|
|
219
|
+
...options?.replyToMessageId ? { quoted: { key: { remoteJid: jid, id: options.replyToMessageId } } } : {}
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
async sendTyping(channelId) {
|
|
223
|
+
if (!this.sock || !this.connected) return;
|
|
224
|
+
const jid = channelId.includes("@") ? channelId : `${channelId}@s.whatsapp.net`;
|
|
225
|
+
await this.sock.sendPresenceUpdate("composing", jid);
|
|
226
|
+
}
|
|
227
|
+
async healthCheck() {
|
|
228
|
+
return { connected: this.connected };
|
|
229
|
+
}
|
|
230
|
+
/** Verify webhook for backward compat — no-op for Baileys */
|
|
231
|
+
verifyWebhook(_mode, _token, _challenge) {
|
|
232
|
+
return null;
|
|
233
|
+
}
|
|
234
|
+
/** Inject message — no-op for Baileys (messages arrive via socket) */
|
|
235
|
+
async injectMessage(_rawPayload) {
|
|
236
|
+
}
|
|
237
|
+
normalizeMessage(msg) {
|
|
238
|
+
const text = msg.message?.conversation ?? msg.message?.extendedTextMessage?.text ?? msg.message?.imageMessage?.caption ?? msg.message?.videoMessage?.caption ?? msg.message?.documentMessage?.caption ?? "";
|
|
239
|
+
if (!text && !msg.message) return null;
|
|
240
|
+
const remoteJid = msg.key.remoteJid ?? "";
|
|
241
|
+
const isGroup = remoteJid.endsWith("@g.us");
|
|
242
|
+
const senderId = isGroup ? msg.key.participant ?? "" : remoteJid.replace("@s.whatsapp.net", "");
|
|
243
|
+
const media = this.extractMedia(msg.message);
|
|
244
|
+
const replyContext = msg.message?.extendedTextMessage?.contextInfo;
|
|
245
|
+
const location = this.extractLocation(msg.message);
|
|
246
|
+
const dataCategory = location ? "location" : "message";
|
|
247
|
+
return {
|
|
248
|
+
messageId: msg.key.id ?? randomUUID(),
|
|
249
|
+
platform: "whatsapp",
|
|
250
|
+
senderId,
|
|
251
|
+
senderName: msg.pushName ?? void 0,
|
|
252
|
+
senderPhone: senderId.replace("@s.whatsapp.net", ""),
|
|
253
|
+
channelId: remoteJid,
|
|
254
|
+
chatType: isGroup ? "group" : "direct",
|
|
255
|
+
text,
|
|
256
|
+
timestamp: msg.messageTimestamp ? new Date(Number(msg.messageTimestamp) * 1e3).toISOString() : (/* @__PURE__ */ new Date()).toISOString(),
|
|
257
|
+
media,
|
|
258
|
+
replyTo: replyContext?.quotedMessage ? {
|
|
259
|
+
messageId: replyContext.stanzaId ?? "",
|
|
260
|
+
text: replyContext.quotedMessage.conversation ?? "",
|
|
261
|
+
senderId: replyContext.participant ?? ""
|
|
262
|
+
} : void 0,
|
|
263
|
+
raw: msg,
|
|
264
|
+
dataCategory,
|
|
265
|
+
location
|
|
266
|
+
};
|
|
267
|
+
}
|
|
268
|
+
extractLocation(message) {
|
|
269
|
+
const loc = message?.locationMessage;
|
|
270
|
+
const live = message?.liveLocationMessage;
|
|
271
|
+
const src = loc ?? live;
|
|
272
|
+
if (!src) return void 0;
|
|
273
|
+
return {
|
|
274
|
+
latitude: src.degreesLatitude,
|
|
275
|
+
longitude: src.degreesLongitude,
|
|
276
|
+
address: src.address ?? void 0,
|
|
277
|
+
venueName: src.name ?? void 0,
|
|
278
|
+
isLive: !!live
|
|
279
|
+
};
|
|
280
|
+
}
|
|
281
|
+
normalizeReadReceipt(update) {
|
|
282
|
+
const key = update.key;
|
|
283
|
+
if (!key) return null;
|
|
284
|
+
const remoteJid = key.remoteJid ?? "";
|
|
285
|
+
const receipt = update.receipt;
|
|
286
|
+
if (!receipt) return null;
|
|
287
|
+
let status = "delivered";
|
|
288
|
+
if (receipt.readTimestamp || receipt.receiptTimestamp) {
|
|
289
|
+
status = "read";
|
|
290
|
+
}
|
|
291
|
+
const timestamp = receipt.readTimestamp ?? receipt.receiptTimestamp ?? Date.now() / 1e3;
|
|
292
|
+
return {
|
|
293
|
+
messageId: randomUUID(),
|
|
294
|
+
platform: "whatsapp",
|
|
295
|
+
senderId: remoteJid.replace("@s.whatsapp.net", "").replace("@g.us", ""),
|
|
296
|
+
channelId: remoteJid,
|
|
297
|
+
chatType: remoteJid.endsWith("@g.us") ? "group" : "direct",
|
|
298
|
+
text: "",
|
|
299
|
+
timestamp: new Date(Number(timestamp) * 1e3).toISOString(),
|
|
300
|
+
raw: update,
|
|
301
|
+
dataCategory: "read_receipt",
|
|
302
|
+
readReceipt: {
|
|
303
|
+
messageId: key.id ?? "",
|
|
304
|
+
status,
|
|
305
|
+
timestamp: new Date(Number(timestamp) * 1e3).toISOString(),
|
|
306
|
+
readBy: key.participant ?? void 0
|
|
307
|
+
}
|
|
308
|
+
};
|
|
309
|
+
}
|
|
310
|
+
normalizeContactSync(contact) {
|
|
311
|
+
const id = contact.id;
|
|
312
|
+
if (!id) return null;
|
|
313
|
+
const phone = id.replace("@s.whatsapp.net", "").replace("@g.us", "");
|
|
314
|
+
const name = contact.name ?? contact.notify ?? phone;
|
|
315
|
+
return {
|
|
316
|
+
messageId: randomUUID(),
|
|
317
|
+
platform: "whatsapp",
|
|
318
|
+
senderId: phone,
|
|
319
|
+
senderName: name,
|
|
320
|
+
senderPhone: phone,
|
|
321
|
+
channelId: id,
|
|
322
|
+
chatType: "direct",
|
|
323
|
+
text: "",
|
|
324
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
325
|
+
raw: contact,
|
|
326
|
+
dataCategory: "contact_sync",
|
|
327
|
+
contactSync: {
|
|
328
|
+
name,
|
|
329
|
+
phone,
|
|
330
|
+
pushName: contact.notify ?? void 0
|
|
331
|
+
}
|
|
332
|
+
};
|
|
333
|
+
}
|
|
334
|
+
normalizeGroupInfo(group) {
|
|
335
|
+
const groupId = group.id;
|
|
336
|
+
if (!groupId) return null;
|
|
337
|
+
const participants = (group.participants ?? []).map((p) => p.id ?? p);
|
|
338
|
+
const admins = (group.participants ?? []).filter((p) => p.admin === "admin" || p.admin === "superadmin").map((p) => p.id ?? p);
|
|
339
|
+
return {
|
|
340
|
+
messageId: randomUUID(),
|
|
341
|
+
platform: "whatsapp",
|
|
342
|
+
senderId: groupId,
|
|
343
|
+
channelId: groupId,
|
|
344
|
+
chatType: "group",
|
|
345
|
+
text: "",
|
|
346
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
347
|
+
raw: group,
|
|
348
|
+
dataCategory: "group",
|
|
349
|
+
groupInfo: {
|
|
350
|
+
groupId,
|
|
351
|
+
groupName: group.subject ?? "",
|
|
352
|
+
participants,
|
|
353
|
+
admins,
|
|
354
|
+
description: group.desc ?? void 0
|
|
355
|
+
}
|
|
356
|
+
};
|
|
357
|
+
}
|
|
358
|
+
normalizeReaction(reaction) {
|
|
359
|
+
const key = reaction.key;
|
|
360
|
+
if (!key) return null;
|
|
361
|
+
const reactionData = reaction.reaction;
|
|
362
|
+
if (!reactionData) return null;
|
|
363
|
+
const remoteJid = key.remoteJid ?? "";
|
|
364
|
+
return {
|
|
365
|
+
messageId: randomUUID(),
|
|
366
|
+
platform: "whatsapp",
|
|
367
|
+
senderId: reactionData.key?.participant ?? reactionData.key?.remoteJid?.replace("@s.whatsapp.net", "") ?? "",
|
|
368
|
+
channelId: remoteJid,
|
|
369
|
+
chatType: remoteJid.endsWith("@g.us") ? "group" : "direct",
|
|
370
|
+
text: "",
|
|
371
|
+
timestamp: reactionData.senderTimestampMs ? new Date(Number(reactionData.senderTimestampMs)).toISOString() : (/* @__PURE__ */ new Date()).toISOString(),
|
|
372
|
+
raw: reaction,
|
|
373
|
+
dataCategory: "reaction",
|
|
374
|
+
reaction: {
|
|
375
|
+
emoji: reactionData.text ?? "",
|
|
376
|
+
targetMessageId: key.id ?? "",
|
|
377
|
+
reactedBy: reactionData.key?.participant ?? reactionData.key?.remoteJid?.replace("@s.whatsapp.net", "") ?? "",
|
|
378
|
+
timestamp: reactionData.senderTimestampMs ? new Date(Number(reactionData.senderTimestampMs)).toISOString() : (/* @__PURE__ */ new Date()).toISOString()
|
|
379
|
+
}
|
|
380
|
+
};
|
|
381
|
+
}
|
|
382
|
+
normalizeCall(call) {
|
|
383
|
+
const chatId = call.chatId ?? call.from;
|
|
384
|
+
if (!chatId) return null;
|
|
385
|
+
const caller = call.from?.replace("@s.whatsapp.net", "") ?? "";
|
|
386
|
+
return {
|
|
387
|
+
messageId: randomUUID(),
|
|
388
|
+
platform: "whatsapp",
|
|
389
|
+
senderId: caller,
|
|
390
|
+
channelId: chatId,
|
|
391
|
+
chatType: call.isGroup ? "group" : "direct",
|
|
392
|
+
text: "",
|
|
393
|
+
timestamp: call.date ? new Date(call.date * 1e3).toISOString() : (/* @__PURE__ */ new Date()).toISOString(),
|
|
394
|
+
raw: call,
|
|
395
|
+
dataCategory: "call_log",
|
|
396
|
+
callLog: {
|
|
397
|
+
callType: call.isVideo ? "video" : "voice",
|
|
398
|
+
status: call.status ?? "offered",
|
|
399
|
+
duration: call.duration ?? void 0,
|
|
400
|
+
caller,
|
|
401
|
+
callee: call.from === chatId ? "" : chatId.replace("@s.whatsapp.net", ""),
|
|
402
|
+
timestamp: call.date ? new Date(call.date * 1e3).toISOString() : (/* @__PURE__ */ new Date()).toISOString(),
|
|
403
|
+
isGroup: call.isGroup ?? false
|
|
404
|
+
}
|
|
405
|
+
};
|
|
406
|
+
}
|
|
407
|
+
extractMedia(message) {
|
|
408
|
+
if (!message) return void 0;
|
|
409
|
+
const media = [];
|
|
410
|
+
if (message.imageMessage) {
|
|
411
|
+
media.push({ type: "image", fileName: "image.jpg" });
|
|
412
|
+
}
|
|
413
|
+
if (message.videoMessage) {
|
|
414
|
+
media.push({ type: "video", fileName: "video.mp4" });
|
|
415
|
+
}
|
|
416
|
+
if (message.audioMessage) {
|
|
417
|
+
media.push({ type: "audio", fileName: "audio.ogg" });
|
|
418
|
+
}
|
|
419
|
+
if (message.documentMessage) {
|
|
420
|
+
media.push({
|
|
421
|
+
type: "document",
|
|
422
|
+
fileName: message.documentMessage.fileName ?? "document"
|
|
423
|
+
});
|
|
424
|
+
}
|
|
425
|
+
return media.length > 0 ? media : void 0;
|
|
426
|
+
}
|
|
427
|
+
};
|
|
428
|
+
|
|
429
|
+
export {
|
|
430
|
+
calculateBackoff,
|
|
431
|
+
WhatsAppAdapter
|
|
432
|
+
};
|