@openclaw/discord 2026.5.2 → 2026.5.3-beta.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/access-B9ujuUtS.js +89 -0
- package/dist/account-inspect-C2UEUhbG.js +81 -0
- package/dist/account-inspect-api.js +10 -0
- package/dist/accounts-BKnkNaoA.js +128 -0
- package/dist/action-runtime-api.js +2 -0
- package/dist/agent-components.runtime-DUhLr9hy.js +4 -0
- package/dist/allow-list-ek-1hMKN.js +336 -0
- package/dist/api-DzNBVTto.js +130 -0
- package/dist/api.js +24 -0
- package/dist/approval-handler.runtime-v8nzQHlT.js +426 -0
- package/dist/approval-native-DqWGp0bM.js +153 -0
- package/dist/approval-shared-DKnwwjZM.js +93 -0
- package/dist/audit-CJ92YD6J.js +102 -0
- package/dist/channel-B3aTtBj1.js +745 -0
- package/dist/channel-access-ewDxhd9q.js +62 -0
- package/dist/channel-actions-TNih7k3w.js +140 -0
- package/dist/channel-actions.runtime-CaPytiY4.js +236 -0
- package/dist/channel-api-CTSWMrnD.js +21 -0
- package/dist/channel-config-api.js +2 -0
- package/dist/channel-plugin-api.js +2 -0
- package/dist/channel.setup-Dt4tIDrl.js +336 -0
- package/dist/components-BapWDmDM.js +760 -0
- package/dist/config-api-CFZtoMaS.js +2 -0
- package/dist/config-schema-DwFkL904.js +252 -0
- package/dist/configured-state.js +6 -0
- package/dist/contract-api.js +8 -0
- package/dist/conversation-identity-BN9wSmxJ.js +31 -0
- package/dist/directory-cache-D93eSrpB.js +62 -0
- package/dist/directory-config-LyMP0sdv.js +49 -0
- package/dist/directory-contract-api.js +2 -0
- package/dist/directory-live-BQapdpkZ.js +101 -0
- package/dist/discord-D1kDh0X_.js +2751 -0
- package/dist/doctor-B2G7WqO0.js +244 -0
- package/dist/doctor-contract-D3pSutkb.js +383 -0
- package/dist/doctor-contract-api.js +2 -0
- package/dist/doctor-shared-DU8RcnF5.js +4 -0
- package/dist/format-D8TsaXxW.js +24 -0
- package/dist/gateway-registry-BKG4KIVC.js +74 -0
- package/dist/handle-action.guild-admin-BuqsSVXu.js +283 -0
- package/dist/inbound-context-e_oBBJtF.js +51 -0
- package/dist/index.js +26 -0
- package/dist/manager.runtime-M2aAa7qA.js +1019 -0
- package/dist/mentions-BPZUaFk7.js +88 -0
- package/dist/message-handler-D6JfFV3P.js +381 -0
- package/dist/message-handler.preflight-DqaF3vHm.js +1022 -0
- package/dist/message-handler.process-tl3Nwnhr.js +1124 -0
- package/dist/message-utils-Dmgu-7fC.js +512 -0
- package/dist/normalize-B-ktw-T_.js +275 -0
- package/dist/outbound-adapter-DJf9_sfH.js +451 -0
- package/dist/outbound-session-route-uHGLDP-Y.js +43 -0
- package/dist/pluralkit-voQvSN3g.js +22 -0
- package/dist/preflight-audio-BpYtUAT6.js +72 -0
- package/dist/preflight-audio.runtime-BAGmU6uO.js +7 -0
- package/dist/preview-streaming-C0O92Qqz.js +14 -0
- package/dist/probe-DcNEodPI.js +139 -0
- package/dist/probe.runtime-P-e4r1Hl.js +2 -0
- package/dist/provider-CMvXOp-3.js +8440 -0
- package/dist/provider-session.runtime-JFemrDZT.js +6 -0
- package/dist/provider.runtime-BO007oR2.js +2 -0
- package/dist/reply-delivery-D9So77a6.js +131 -0
- package/dist/resolve-allowlist-common-DqqFY_qa.js +34 -0
- package/dist/resolve-channels-CGPntufJ.js +265 -0
- package/dist/resolve-users-CDvSlW0V.js +120 -0
- package/dist/rolldown-runtime-C3SqQTfK.js +28 -0
- package/dist/route-resolution-BYiC-6Cc.js +236 -0
- package/dist/runtime-K9RT6Egn.js +8 -0
- package/dist/runtime-api.actions.js +3 -0
- package/dist/runtime-api.js +31 -0
- package/dist/runtime-api.lookup.js +7 -0
- package/dist/runtime-api.monitor-BC-XN0tY.js +6 -0
- package/dist/runtime-api.monitor.js +9 -0
- package/dist/runtime-api.send.js +6 -0
- package/dist/runtime-api.threads.js +6 -0
- package/dist/runtime-n5xZHW55.js +1001 -0
- package/dist/runtime-setter-api.js +2 -0
- package/dist/secret-config-contract-CoGryS5c.js +115 -0
- package/dist/secret-contract-api.js +2 -0
- package/dist/security-audit-Cdz2iq3m.js +120 -0
- package/dist/security-audit-contract-api.js +2 -0
- package/dist/security-audit.runtime-DBV1T1_N.js +2 -0
- package/dist/security-contract-api.js +2 -0
- package/dist/security-contract-ei3Mz8Sa.js +26 -0
- package/dist/security-doctor-CzTzpXV8.js +18 -0
- package/dist/send-B_frVn_Q.js +845 -0
- package/dist/send.components-B1EgHAds.js +468 -0
- package/dist/send.outbound-DlBAuW7y.js +211 -0
- package/dist/send.shared-Db0opnak.js +708 -0
- package/dist/sender-identity-BiSDAk2P.js +43 -0
- package/dist/session-contract-goJZckp2.js +6 -0
- package/dist/session-key-api.js +2 -0
- package/dist/session-key-normalization-Daag9II6.js +23 -0
- package/dist/setup-entry.js +11 -0
- package/dist/setup-plugin-api.js +2 -0
- package/dist/shared-CqlrJmSs.js +166 -0
- package/dist/shared-interactive-KgJjCqnB.js +79 -0
- package/dist/subagent-hooks-api.js +22 -0
- package/dist/subagent-hooks-mEK5ARfP.js +113 -0
- package/dist/system-events-Bu9jmO4W.js +34 -0
- package/dist/targets-kKlbZ4ai.js +3 -0
- package/dist/test-api.js +45 -0
- package/dist/thread-binding-api.js +4 -0
- package/dist/thread-bindings-Bj1R-6QH.js +256 -0
- package/dist/thread-bindings.discord-api-ClPMuIr8.js +184 -0
- package/dist/thread-bindings.manager-BaN0l4y8.js +535 -0
- package/dist/thread-bindings.session-updates-TTP020qQ.js +54 -0
- package/dist/thread-bindings.state-Dzu1gCE7.js +318 -0
- package/dist/threading-CWhdYHVx.js +475 -0
- package/dist/timeouts-C7jeTtGs.js +52 -0
- package/dist/timeouts.js +2 -0
- package/dist/token-D-w3Rigl.js +42 -0
- package/dist/typing-CJiowRTZ.js +15 -0
- package/package.json +14 -6
- package/account-inspect-api.ts +0 -6
- package/action-runtime-api.ts +0 -1
- package/api.ts +0 -132
- package/channel-config-api.ts +0 -1
- package/channel-plugin-api.ts +0 -3
- package/config-api.ts +0 -4
- package/configured-state.ts +0 -6
- package/contract-api.ts +0 -21
- package/directory-contract-api.ts +0 -4
- package/doctor-contract-api.ts +0 -1
- package/index.test.ts +0 -13
- package/index.ts +0 -24
- package/runtime-api.actions.ts +0 -15
- package/runtime-api.lookup.ts +0 -22
- package/runtime-api.monitor.ts +0 -50
- package/runtime-api.send.ts +0 -79
- package/runtime-api.threads.ts +0 -30
- package/runtime-api.ts +0 -180
- package/runtime-setter-api.ts +0 -3
- package/secret-contract-api.ts +0 -4
- package/security-audit-contract-api.ts +0 -1
- package/security-contract-api.ts +0 -4
- package/session-key-api.ts +0 -1
- package/setup-entry.ts +0 -9
- package/setup-plugin-api.ts +0 -3
- package/src/account-inspect.test.ts +0 -126
- package/src/account-inspect.ts +0 -132
- package/src/accounts.test.ts +0 -247
- package/src/accounts.ts +0 -196
- package/src/actions/handle-action.guild-admin.ts +0 -411
- package/src/actions/handle-action.test.ts +0 -306
- package/src/actions/handle-action.ts +0 -372
- package/src/actions/runtime.guild.ts +0 -446
- package/src/actions/runtime.messaging.messages.ts +0 -205
- package/src/actions/runtime.messaging.reactions.ts +0 -67
- package/src/actions/runtime.messaging.runtime.ts +0 -69
- package/src/actions/runtime.messaging.send.ts +0 -248
- package/src/actions/runtime.messaging.shared.ts +0 -97
- package/src/actions/runtime.messaging.ts +0 -37
- package/src/actions/runtime.moderation-shared.ts +0 -48
- package/src/actions/runtime.moderation.authz.test.ts +0 -151
- package/src/actions/runtime.moderation.ts +0 -116
- package/src/actions/runtime.presence.test.ts +0 -160
- package/src/actions/runtime.presence.ts +0 -117
- package/src/actions/runtime.shared.ts +0 -83
- package/src/actions/runtime.test.ts +0 -1087
- package/src/actions/runtime.ts +0 -87
- package/src/api-barrel.test.ts +0 -80
- package/src/api.test.ts +0 -130
- package/src/api.ts +0 -169
- package/src/approval-handler.runtime.test.ts +0 -41
- package/src/approval-handler.runtime.ts +0 -632
- package/src/approval-native.test.ts +0 -330
- package/src/approval-native.ts +0 -219
- package/src/approval-runtime.ts +0 -14
- package/src/approval-shared.ts +0 -53
- package/src/audit-core.ts +0 -141
- package/src/audit.test.ts +0 -145
- package/src/audit.ts +0 -32
- package/src/channel-actions.contract.test.ts +0 -45
- package/src/channel-actions.runtime.ts +0 -1
- package/src/channel-actions.test.ts +0 -275
- package/src/channel-actions.ts +0 -203
- package/src/channel-api.ts +0 -29
- package/src/channel.conversation.ts +0 -159
- package/src/channel.loaders.ts +0 -47
- package/src/channel.runtime.ts +0 -1
- package/src/channel.setup.ts +0 -12
- package/src/channel.test.ts +0 -571
- package/src/channel.ts +0 -629
- package/src/chunk.test.ts +0 -157
- package/src/chunk.ts +0 -321
- package/src/client.proxy.test.ts +0 -176
- package/src/client.test.ts +0 -76
- package/src/client.ts +0 -132
- package/src/component-custom-id.ts +0 -72
- package/src/components-registry.ts +0 -356
- package/src/components.builders.ts +0 -409
- package/src/components.modal.ts +0 -124
- package/src/components.parse.ts +0 -407
- package/src/components.test.ts +0 -312
- package/src/components.ts +0 -54
- package/src/components.types.ts +0 -187
- package/src/config-schema.test.ts +0 -325
- package/src/config-schema.ts +0 -6
- package/src/config-ui-hints.ts +0 -249
- package/src/conversation-identity.ts +0 -58
- package/src/delivery-retry.ts +0 -56
- package/src/directory-cache.ts +0 -116
- package/src/directory-config.ts +0 -58
- package/src/directory-contract.test.ts +0 -129
- package/src/directory-live.test.ts +0 -126
- package/src/directory-live.ts +0 -135
- package/src/doctor-contract.ts +0 -477
- package/src/doctor-shared.ts +0 -5
- package/src/doctor.test.ts +0 -405
- package/src/doctor.ts +0 -340
- package/src/draft-chunking.test.ts +0 -64
- package/src/draft-chunking.ts +0 -43
- package/src/draft-stream.test.ts +0 -159
- package/src/draft-stream.ts +0 -154
- package/src/error-body.ts +0 -38
- package/src/exec-approvals.test.ts +0 -88
- package/src/exec-approvals.ts +0 -110
- package/src/gateway-logging.test.ts +0 -98
- package/src/gateway-logging.ts +0 -67
- package/src/group-policy.ts +0 -113
- package/src/guilds.ts +0 -29
- package/src/inbound-context.contract.test.ts +0 -11
- package/src/interactive-dispatch.ts +0 -104
- package/src/internal/api.commands.ts +0 -51
- package/src/internal/api.guild.ts +0 -164
- package/src/internal/api.interactions.ts +0 -53
- package/src/internal/api.messages.ts +0 -113
- package/src/internal/api.reactions.ts +0 -38
- package/src/internal/api.test.ts +0 -262
- package/src/internal/api.ts +0 -61
- package/src/internal/api.users.ts +0 -19
- package/src/internal/api.webhooks.ts +0 -13
- package/src/internal/client.test.ts +0 -440
- package/src/internal/client.ts +0 -310
- package/src/internal/command-deploy.ts +0 -297
- package/src/internal/commands.ts +0 -188
- package/src/internal/components.base.ts +0 -65
- package/src/internal/components.message.ts +0 -279
- package/src/internal/components.modal.ts +0 -95
- package/src/internal/components.ts +0 -31
- package/src/internal/discord.ts +0 -11
- package/src/internal/embeds.ts +0 -35
- package/src/internal/entity-cache.ts +0 -98
- package/src/internal/event-queue.ts +0 -162
- package/src/internal/gateway-close-codes.ts +0 -25
- package/src/internal/gateway-dispatch.ts +0 -96
- package/src/internal/gateway-identify-limiter.ts +0 -26
- package/src/internal/gateway-lifecycle.ts +0 -61
- package/src/internal/gateway-rate-limit.ts +0 -104
- package/src/internal/gateway.test.ts +0 -603
- package/src/internal/gateway.ts +0 -476
- package/src/internal/interaction-dispatch.test.ts +0 -148
- package/src/internal/interaction-dispatch.ts +0 -162
- package/src/internal/interaction-options.ts +0 -98
- package/src/internal/interaction-response.ts +0 -53
- package/src/internal/interactions.test.ts +0 -325
- package/src/internal/interactions.ts +0 -378
- package/src/internal/listeners.ts +0 -85
- package/src/internal/live-smoke.live.test.ts +0 -26
- package/src/internal/modal-fields.ts +0 -95
- package/src/internal/payload.ts +0 -69
- package/src/internal/rest-body.ts +0 -115
- package/src/internal/rest-errors.ts +0 -88
- package/src/internal/rest-routes.ts +0 -50
- package/src/internal/rest-scheduler.ts +0 -557
- package/src/internal/rest.test.ts +0 -673
- package/src/internal/rest.ts +0 -322
- package/src/internal/schemas.ts +0 -36
- package/src/internal/structures.test.ts +0 -43
- package/src/internal/structures.ts +0 -280
- package/src/internal/test-builders.test-support.ts +0 -167
- package/src/internal/voice.ts +0 -49
- package/src/media-detection.ts +0 -28
- package/src/mentions.test.ts +0 -111
- package/src/mentions.ts +0 -147
- package/src/monitor/access-groups.ts +0 -55
- package/src/monitor/ack-reactions.ts +0 -70
- package/src/monitor/acp-bind-here.integration.test.ts +0 -211
- package/src/monitor/agent-components-auth.ts +0 -7
- package/src/monitor/agent-components-context.ts +0 -154
- package/src/monitor/agent-components-data.ts +0 -224
- package/src/monitor/agent-components-dm-auth.ts +0 -221
- package/src/monitor/agent-components-guild-auth.ts +0 -322
- package/src/monitor/agent-components-helpers.runtime.ts +0 -5
- package/src/monitor/agent-components-helpers.ts +0 -34
- package/src/monitor/agent-components-reply.ts +0 -10
- package/src/monitor/agent-components.deps.runtime.ts +0 -2
- package/src/monitor/agent-components.dispatch.ts +0 -366
- package/src/monitor/agent-components.handlers.ts +0 -303
- package/src/monitor/agent-components.modal.ts +0 -160
- package/src/monitor/agent-components.plugin-interactive.ts +0 -187
- package/src/monitor/agent-components.runtime.ts +0 -14
- package/src/monitor/agent-components.system-controls.ts +0 -211
- package/src/monitor/agent-components.ts +0 -70
- package/src/monitor/agent-components.types.ts +0 -58
- package/src/monitor/agent-components.wildcard-controls.ts +0 -168
- package/src/monitor/agent-components.wildcard.test.ts +0 -71
- package/src/monitor/allow-list.test.ts +0 -14
- package/src/monitor/allow-list.ts +0 -633
- package/src/monitor/auto-presence.test.ts +0 -156
- package/src/monitor/auto-presence.ts +0 -356
- package/src/monitor/channel-access.test.ts +0 -99
- package/src/monitor/channel-access.ts +0 -102
- package/src/monitor/commands.test.ts +0 -24
- package/src/monitor/commands.ts +0 -9
- package/src/monitor/dm-command-auth.test.ts +0 -197
- package/src/monitor/dm-command-auth.ts +0 -158
- package/src/monitor/dm-command-decision.test.ts +0 -113
- package/src/monitor/dm-command-decision.ts +0 -49
- package/src/monitor/exec-approvals.test.ts +0 -226
- package/src/monitor/exec-approvals.ts +0 -158
- package/src/monitor/format.ts +0 -45
- package/src/monitor/gateway-handle.ts +0 -34
- package/src/monitor/gateway-metadata.test.ts +0 -29
- package/src/monitor/gateway-metadata.ts +0 -298
- package/src/monitor/gateway-plugin.test.ts +0 -297
- package/src/monitor/gateway-plugin.ts +0 -294
- package/src/monitor/gateway-registry.ts +0 -37
- package/src/monitor/gateway-supervisor.test.ts +0 -150
- package/src/monitor/gateway-supervisor.ts +0 -206
- package/src/monitor/inbound-context.test-helpers.ts +0 -37
- package/src/monitor/inbound-context.test.ts +0 -106
- package/src/monitor/inbound-context.ts +0 -103
- package/src/monitor/inbound-dedupe.ts +0 -79
- package/src/monitor/inbound-job.test.ts +0 -203
- package/src/monitor/inbound-job.ts +0 -118
- package/src/monitor/listeners.queue.ts +0 -91
- package/src/monitor/listeners.reactions.ts +0 -610
- package/src/monitor/listeners.test.ts +0 -200
- package/src/monitor/listeners.ts +0 -150
- package/src/monitor/message-channel-info.ts +0 -96
- package/src/monitor/message-forwarded.ts +0 -107
- package/src/monitor/message-handler.batch-gate.test.ts +0 -22
- package/src/monitor/message-handler.batch-gate.ts +0 -19
- package/src/monitor/message-handler.bot-self-filter.test.ts +0 -68
- package/src/monitor/message-handler.context.ts +0 -406
- package/src/monitor/message-handler.dm-preflight.ts +0 -123
- package/src/monitor/message-handler.draft-preview.ts +0 -246
- package/src/monitor/message-handler.hydration.test.ts +0 -80
- package/src/monitor/message-handler.hydration.ts +0 -198
- package/src/monitor/message-handler.inbound-context.test.ts +0 -59
- package/src/monitor/message-handler.module-test-helpers.ts +0 -31
- package/src/monitor/message-handler.preflight-channel-access.ts +0 -86
- package/src/monitor/message-handler.preflight-channel-context.test.ts +0 -18
- package/src/monitor/message-handler.preflight-channel-context.ts +0 -58
- package/src/monitor/message-handler.preflight-context.ts +0 -54
- package/src/monitor/message-handler.preflight-helpers.ts +0 -164
- package/src/monitor/message-handler.preflight-history.ts +0 -23
- package/src/monitor/message-handler.preflight-logging.ts +0 -36
- package/src/monitor/message-handler.preflight-pluralkit.ts +0 -26
- package/src/monitor/message-handler.preflight-runtime.ts +0 -28
- package/src/monitor/message-handler.preflight-thread.ts +0 -49
- package/src/monitor/message-handler.preflight.acp-bindings.test.ts +0 -369
- package/src/monitor/message-handler.preflight.test-helpers.ts +0 -111
- package/src/monitor/message-handler.preflight.test.ts +0 -1623
- package/src/monitor/message-handler.preflight.ts +0 -679
- package/src/monitor/message-handler.preflight.types.ts +0 -110
- package/src/monitor/message-handler.process.test.ts +0 -1369
- package/src/monitor/message-handler.process.ts +0 -686
- package/src/monitor/message-handler.queue.test.ts +0 -496
- package/src/monitor/message-handler.routing-preflight.ts +0 -112
- package/src/monitor/message-handler.test-harness.ts +0 -99
- package/src/monitor/message-handler.test-helpers.ts +0 -75
- package/src/monitor/message-handler.ts +0 -274
- package/src/monitor/message-media.ts +0 -509
- package/src/monitor/message-run-queue.ts +0 -101
- package/src/monitor/message-text.ts +0 -171
- package/src/monitor/message-utils.test.ts +0 -1157
- package/src/monitor/message-utils.ts +0 -32
- package/src/monitor/model-picker-preferences.test.ts +0 -67
- package/src/monitor/model-picker-preferences.ts +0 -184
- package/src/monitor/model-picker.state.ts +0 -364
- package/src/monitor/model-picker.test-utils.ts +0 -26
- package/src/monitor/model-picker.test.ts +0 -794
- package/src/monitor/model-picker.ts +0 -38
- package/src/monitor/model-picker.view.ts +0 -695
- package/src/monitor/monitor.agent-components.test.ts +0 -375
- package/src/monitor/monitor.test.ts +0 -849
- package/src/monitor/monitor.threading-utils.test.ts +0 -598
- package/src/monitor/native-command-agent-reply.ts +0 -125
- package/src/monitor/native-command-arg-ui.ts +0 -233
- package/src/monitor/native-command-auth.ts +0 -308
- package/src/monitor/native-command-bypass.ts +0 -13
- package/src/monitor/native-command-context.test.ts +0 -98
- package/src/monitor/native-command-context.ts +0 -103
- package/src/monitor/native-command-dispatch.ts +0 -35
- package/src/monitor/native-command-model-picker-apply.ts +0 -177
- package/src/monitor/native-command-model-picker-interaction.ts +0 -461
- package/src/monitor/native-command-model-picker-ui.ts +0 -368
- package/src/monitor/native-command-reply.test.ts +0 -68
- package/src/monitor/native-command-reply.ts +0 -185
- package/src/monitor/native-command-route.ts +0 -91
- package/src/monitor/native-command-status.ts +0 -76
- package/src/monitor/native-command-ui.ts +0 -26
- package/src/monitor/native-command-ui.types.ts +0 -20
- package/src/monitor/native-command.args.ts +0 -45
- package/src/monitor/native-command.command-arg.test.ts +0 -99
- package/src/monitor/native-command.commands-allowfrom.test.ts +0 -490
- package/src/monitor/native-command.model-picker.test.ts +0 -767
- package/src/monitor/native-command.options.test.ts +0 -369
- package/src/monitor/native-command.options.ts +0 -153
- package/src/monitor/native-command.plugin-dispatch.test.ts +0 -961
- package/src/monitor/native-command.runtime.ts +0 -50
- package/src/monitor/native-command.status-direct.test.ts +0 -272
- package/src/monitor/native-command.test-helpers.ts +0 -64
- package/src/monitor/native-command.think-autocomplete.test.ts +0 -416
- package/src/monitor/native-command.ts +0 -700
- package/src/monitor/native-command.types.ts +0 -9
- package/src/monitor/native-interaction-channel-context.ts +0 -50
- package/src/monitor/preflight-audio.runtime.ts +0 -9
- package/src/monitor/preflight-audio.test.ts +0 -157
- package/src/monitor/preflight-audio.ts +0 -130
- package/src/monitor/presence-cache.ts +0 -61
- package/src/monitor/presence.test.ts +0 -44
- package/src/monitor/presence.ts +0 -50
- package/src/monitor/provider-session.runtime.ts +0 -12
- package/src/monitor/provider.acp.ts +0 -89
- package/src/monitor/provider.allowlist.test.ts +0 -149
- package/src/monitor/provider.allowlist.ts +0 -394
- package/src/monitor/provider.cleanup.ts +0 -41
- package/src/monitor/provider.commands.ts +0 -129
- package/src/monitor/provider.config-log.ts +0 -45
- package/src/monitor/provider.deploy-errors.ts +0 -362
- package/src/monitor/provider.deploy.ts +0 -221
- package/src/monitor/provider.interactions.ts +0 -160
- package/src/monitor/provider.lifecycle.test.ts +0 -713
- package/src/monitor/provider.lifecycle.ts +0 -552
- package/src/monitor/provider.proxy.test.ts +0 -745
- package/src/monitor/provider.rest-proxy.test.ts +0 -121
- package/src/monitor/provider.runtime.ts +0 -1
- package/src/monitor/provider.skill-dedupe.test.ts +0 -42
- package/src/monitor/provider.startup-log.ts +0 -32
- package/src/monitor/provider.startup.test.ts +0 -426
- package/src/monitor/provider.startup.ts +0 -330
- package/src/monitor/provider.test.ts +0 -1111
- package/src/monitor/provider.ts +0 -713
- package/src/monitor/reply-context.ts +0 -64
- package/src/monitor/reply-delivery.test.ts +0 -244
- package/src/monitor/reply-delivery.ts +0 -203
- package/src/monitor/rest-fetch.ts +0 -43
- package/src/monitor/route-resolution.test.ts +0 -204
- package/src/monitor/route-resolution.ts +0 -140
- package/src/monitor/sender-identity.ts +0 -81
- package/src/monitor/startup-status.test.ts +0 -30
- package/src/monitor/startup-status.ts +0 -10
- package/src/monitor/status.ts +0 -22
- package/src/monitor/system-events.ts +0 -55
- package/src/monitor/thread-bindings.config.ts +0 -35
- package/src/monitor/thread-bindings.discord-api.test.ts +0 -229
- package/src/monitor/thread-bindings.discord-api.ts +0 -310
- package/src/monitor/thread-bindings.lifecycle.test.ts +0 -1871
- package/src/monitor/thread-bindings.lifecycle.ts +0 -354
- package/src/monitor/thread-bindings.manager.ts +0 -553
- package/src/monitor/thread-bindings.messages.ts +0 -6
- package/src/monitor/thread-bindings.persona.test.ts +0 -34
- package/src/monitor/thread-bindings.persona.ts +0 -25
- package/src/monitor/thread-bindings.session-adapter.ts +0 -229
- package/src/monitor/thread-bindings.session-shared.ts +0 -59
- package/src/monitor/thread-bindings.session-updates.ts +0 -35
- package/src/monitor/thread-bindings.shared-state.test.ts +0 -36
- package/src/monitor/thread-bindings.state.ts +0 -540
- package/src/monitor/thread-bindings.ts +0 -48
- package/src/monitor/thread-bindings.types.ts +0 -83
- package/src/monitor/thread-channel-context.ts +0 -112
- package/src/monitor/thread-session-close.test.ts +0 -180
- package/src/monitor/thread-session-close.ts +0 -63
- package/src/monitor/thread-title.generate.test.ts +0 -197
- package/src/monitor/thread-title.test.ts +0 -31
- package/src/monitor/thread-title.ts +0 -181
- package/src/monitor/threading.auto-thread.test.ts +0 -327
- package/src/monitor/threading.auto-thread.ts +0 -287
- package/src/monitor/threading.cache.ts +0 -45
- package/src/monitor/threading.parent-info.test.ts +0 -156
- package/src/monitor/threading.starter.test.ts +0 -260
- package/src/monitor/threading.starter.ts +0 -287
- package/src/monitor/threading.ts +0 -20
- package/src/monitor/threading.types.ts +0 -102
- package/src/monitor/timeouts.ts +0 -84
- package/src/monitor/typing.test.ts +0 -42
- package/src/monitor/typing.ts +0 -17
- package/src/monitor.gateway.test.ts +0 -187
- package/src/monitor.gateway.ts +0 -75
- package/src/monitor.test.ts +0 -1397
- package/src/monitor.ts +0 -28
- package/src/normalize.test.ts +0 -56
- package/src/normalize.ts +0 -86
- package/src/outbound-adapter.interactive-order.test.ts +0 -64
- package/src/outbound-adapter.test-harness.ts +0 -207
- package/src/outbound-adapter.test.ts +0 -696
- package/src/outbound-adapter.ts +0 -291
- package/src/outbound-approval.ts +0 -29
- package/src/outbound-components.ts +0 -81
- package/src/outbound-payload.contract.test.ts +0 -38
- package/src/outbound-payload.ts +0 -134
- package/src/outbound-send-context.ts +0 -92
- package/src/outbound-session-route.test.ts +0 -34
- package/src/outbound-session-route.ts +0 -72
- package/src/pluralkit.test.ts +0 -67
- package/src/pluralkit.ts +0 -58
- package/src/preview-streaming.ts +0 -32
- package/src/probe.intents.test.ts +0 -94
- package/src/probe.parse-token.test.ts +0 -43
- package/src/probe.runtime.ts +0 -1
- package/src/probe.ts +0 -237
- package/src/proxy-fetch.ts +0 -92
- package/src/proxy-request-client.test.ts +0 -78
- package/src/proxy-request-client.ts +0 -21
- package/src/recipient-resolution.ts +0 -39
- package/src/resolve-allowlist-common.test.ts +0 -36
- package/src/resolve-allowlist-common.ts +0 -39
- package/src/resolve-channels.test.ts +0 -340
- package/src/resolve-channels.ts +0 -369
- package/src/resolve-users.test.ts +0 -222
- package/src/resolve-users.ts +0 -184
- package/src/retry.test.ts +0 -83
- package/src/retry.ts +0 -98
- package/src/runtime-api.ts +0 -64
- package/src/runtime.ts +0 -23
- package/src/secret-config-contract.ts +0 -140
- package/src/security-audit.runtime.ts +0 -1
- package/src/security-audit.test.ts +0 -246
- package/src/security-audit.ts +0 -208
- package/src/security-contract.ts +0 -47
- package/src/security-doctor.test.ts +0 -25
- package/src/security-doctor.ts +0 -20
- package/src/security.ts +0 -60
- package/src/send-target-parsing.ts +0 -14
- package/src/send.channels.ts +0 -139
- package/src/send.components.test.ts +0 -275
- package/src/send.components.ts +0 -381
- package/src/send.creates-thread.test.ts +0 -643
- package/src/send.emojis-stickers.ts +0 -57
- package/src/send.guild.ts +0 -170
- package/src/send.message-request.ts +0 -97
- package/src/send.messages.test.ts +0 -53
- package/src/send.messages.ts +0 -225
- package/src/send.outbound.ts +0 -413
- package/src/send.permissions.authz.test.ts +0 -188
- package/src/send.permissions.ts +0 -283
- package/src/send.reactions.ts +0 -155
- package/src/send.sends-basic-channel-messages.test.ts +0 -941
- package/src/send.shared.ts +0 -447
- package/src/send.test-harness.ts +0 -56
- package/src/send.ts +0 -82
- package/src/send.types.ts +0 -188
- package/src/send.typing.test.ts +0 -41
- package/src/send.typing.ts +0 -9
- package/src/send.voice.ts +0 -134
- package/src/send.webhook-activity.test.ts +0 -105
- package/src/send.webhook.proxy.test.ts +0 -191
- package/src/send.webhook.ts +0 -133
- package/src/session-contract.ts +0 -3
- package/src/session-key-normalization.test.ts +0 -44
- package/src/session-key-normalization.ts +0 -47
- package/src/setup-account-state.test.ts +0 -91
- package/src/setup-account-state.ts +0 -144
- package/src/setup-adapter.ts +0 -12
- package/src/setup-core.ts +0 -212
- package/src/setup-runtime-helpers.ts +0 -10
- package/src/setup-surface.test.ts +0 -137
- package/src/setup-surface.ts +0 -129
- package/src/shared-interactive.test.ts +0 -153
- package/src/shared-interactive.ts +0 -124
- package/src/shared.test.ts +0 -165
- package/src/shared.ts +0 -190
- package/src/status-issues.test.ts +0 -70
- package/src/status-issues.ts +0 -169
- package/src/subagent-hooks.test.ts +0 -432
- package/src/subagent-hooks.ts +0 -214
- package/src/target-parsing.ts +0 -53
- package/src/target-resolver.ts +0 -129
- package/src/targets.test.ts +0 -367
- package/src/targets.ts +0 -12
- package/src/test-http-helpers.ts +0 -10
- package/src/test-support/component-runtime.ts +0 -190
- package/src/test-support/config.ts +0 -7
- package/src/test-support/configured-binding-runtime.ts +0 -29
- package/src/test-support/partial-channel.ts +0 -26
- package/src/test-support/provider.test-support.ts +0 -545
- package/src/token.test.ts +0 -107
- package/src/token.ts +0 -60
- package/src/ui-colors.ts +0 -27
- package/src/ui.ts +0 -20
- package/src/voice/access.test.ts +0 -217
- package/src/voice/access.ts +0 -124
- package/src/voice/audio.ts +0 -173
- package/src/voice/capture-state.test.ts +0 -48
- package/src/voice/capture-state.ts +0 -120
- package/src/voice/command.test.ts +0 -164
- package/src/voice/command.ts +0 -283
- package/src/voice/config.ts +0 -8
- package/src/voice/manager.e2e.test.ts +0 -928
- package/src/voice/manager.ready-listener.test.ts +0 -37
- package/src/voice/manager.runtime.ts +0 -11
- package/src/voice/manager.ts +0 -691
- package/src/voice/prompt.test.ts +0 -16
- package/src/voice/prompt.ts +0 -17
- package/src/voice/receive-recovery.test.ts +0 -79
- package/src/voice/receive-recovery.ts +0 -159
- package/src/voice/sanitize.test.ts +0 -34
- package/src/voice/sanitize.ts +0 -32
- package/src/voice/sdk-runtime.ts +0 -14
- package/src/voice/segment.ts +0 -156
- package/src/voice/session.ts +0 -50
- package/src/voice/speaker-context.ts +0 -127
- package/src/voice/tts.ts +0 -125
- package/src/voice-message.test.ts +0 -234
- package/src/voice-message.ts +0 -444
- package/subagent-hooks-api.ts +0 -27
- package/test-api.ts +0 -4
- package/thread-binding-api.ts +0 -1
- package/timeouts.ts +0 -6
- package/tsconfig.json +0 -16
|
@@ -0,0 +1,512 @@
|
|
|
1
|
+
import { n as resolveDiscordChannelInfoSafe } from "./channel-access-ewDxhd9q.js";
|
|
2
|
+
import { a as mergeAbortSignals } from "./timeouts-C7jeTtGs.js";
|
|
3
|
+
import { normalizeLowercaseStringOrEmpty, normalizeOptionalString, normalizeOptionalStringifiedId } from "openclaw/plugin-sdk/text-runtime";
|
|
4
|
+
import { ComponentType, StickerFormatType } from "discord-api-types/v10";
|
|
5
|
+
import { fetchRemoteMedia, saveMediaBuffer } from "openclaw/plugin-sdk/media-runtime";
|
|
6
|
+
import { buildMediaPayload } from "openclaw/plugin-sdk/reply-payload";
|
|
7
|
+
import { logVerbose } from "openclaw/plugin-sdk/runtime-env";
|
|
8
|
+
import { getFileExtension } from "openclaw/plugin-sdk/media-mime";
|
|
9
|
+
//#region extensions/discord/src/monitor/message-channel-info.ts
|
|
10
|
+
const DISCORD_CHANNEL_INFO_CACHE_TTL_MS = 300 * 1e3;
|
|
11
|
+
const DISCORD_CHANNEL_INFO_NEGATIVE_CACHE_TTL_MS = 30 * 1e3;
|
|
12
|
+
const DISCORD_CHANNEL_INFO_CACHE = /* @__PURE__ */ new Map();
|
|
13
|
+
function normalizeDiscordChannelId(value) {
|
|
14
|
+
return normalizeOptionalStringifiedId(value) ?? "";
|
|
15
|
+
}
|
|
16
|
+
function resolveDiscordMessageChannelId(params) {
|
|
17
|
+
const message = params.message;
|
|
18
|
+
return normalizeDiscordChannelId(message.channelId) || normalizeDiscordChannelId(message.channel_id) || normalizeDiscordChannelId(message.rawData?.channel_id) || normalizeDiscordChannelId(params.eventChannelId);
|
|
19
|
+
}
|
|
20
|
+
async function resolveDiscordChannelInfo(client, channelId) {
|
|
21
|
+
const cached = DISCORD_CHANNEL_INFO_CACHE.get(channelId);
|
|
22
|
+
if (cached) {
|
|
23
|
+
if (cached.expiresAt > Date.now()) return cached.value;
|
|
24
|
+
DISCORD_CHANNEL_INFO_CACHE.delete(channelId);
|
|
25
|
+
}
|
|
26
|
+
try {
|
|
27
|
+
const channel = await client.fetchChannel(channelId);
|
|
28
|
+
if (!channel) {
|
|
29
|
+
DISCORD_CHANNEL_INFO_CACHE.set(channelId, {
|
|
30
|
+
value: null,
|
|
31
|
+
expiresAt: Date.now() + DISCORD_CHANNEL_INFO_NEGATIVE_CACHE_TTL_MS
|
|
32
|
+
});
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
const channelInfo = resolveDiscordChannelInfoSafe(channel);
|
|
36
|
+
const rawChannel = channel;
|
|
37
|
+
const type = channelInfo.type ?? rawChannel.type;
|
|
38
|
+
if (type === void 0) return null;
|
|
39
|
+
const payload = {
|
|
40
|
+
type,
|
|
41
|
+
name: channelInfo.name,
|
|
42
|
+
topic: channelInfo.topic,
|
|
43
|
+
parentId: channelInfo.parentId,
|
|
44
|
+
ownerId: channelInfo.ownerId
|
|
45
|
+
};
|
|
46
|
+
DISCORD_CHANNEL_INFO_CACHE.set(channelId, {
|
|
47
|
+
value: payload,
|
|
48
|
+
expiresAt: Date.now() + DISCORD_CHANNEL_INFO_CACHE_TTL_MS
|
|
49
|
+
});
|
|
50
|
+
return payload;
|
|
51
|
+
} catch (err) {
|
|
52
|
+
logVerbose(`discord: failed to fetch channel ${channelId}: ${String(err)}`);
|
|
53
|
+
DISCORD_CHANNEL_INFO_CACHE.set(channelId, {
|
|
54
|
+
value: null,
|
|
55
|
+
expiresAt: Date.now() + DISCORD_CHANNEL_INFO_NEGATIVE_CACHE_TTL_MS
|
|
56
|
+
});
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//#endregion
|
|
61
|
+
//#region extensions/discord/src/monitor/message-forwarded.ts
|
|
62
|
+
const FORWARD_MESSAGE_REFERENCE_TYPE = 1;
|
|
63
|
+
function normalizeDiscordStickerItems(value) {
|
|
64
|
+
if (!Array.isArray(value)) return [];
|
|
65
|
+
return value.filter((entry) => Boolean(entry) && typeof entry === "object" && typeof entry.id === "string" && typeof entry.name === "string");
|
|
66
|
+
}
|
|
67
|
+
function resolveDiscordMessageStickers(message) {
|
|
68
|
+
const stickers = message.stickers;
|
|
69
|
+
const normalized = normalizeDiscordStickerItems(stickers);
|
|
70
|
+
if (normalized.length > 0) return normalized;
|
|
71
|
+
const rawData = message.rawData;
|
|
72
|
+
return normalizeDiscordStickerItems(rawData?.sticker_items ?? rawData?.stickers);
|
|
73
|
+
}
|
|
74
|
+
function resolveDiscordSnapshotStickers(snapshot) {
|
|
75
|
+
return normalizeDiscordStickerItems(snapshot.stickers ?? snapshot.sticker_items);
|
|
76
|
+
}
|
|
77
|
+
function hasDiscordMessageStickers(message) {
|
|
78
|
+
return resolveDiscordMessageStickers(message).length > 0;
|
|
79
|
+
}
|
|
80
|
+
function resolveDiscordMessageSnapshots(message) {
|
|
81
|
+
const rawData = message.rawData;
|
|
82
|
+
return normalizeDiscordMessageSnapshots(rawData?.message_snapshots ?? message.message_snapshots ?? message.messageSnapshots);
|
|
83
|
+
}
|
|
84
|
+
function normalizeDiscordMessageSnapshots(snapshots) {
|
|
85
|
+
if (!Array.isArray(snapshots)) return [];
|
|
86
|
+
return snapshots.filter((entry) => Boolean(entry) && typeof entry === "object");
|
|
87
|
+
}
|
|
88
|
+
function resolveDiscordReferencedForwardMessage(message) {
|
|
89
|
+
const referenceType = message.messageReference?.type;
|
|
90
|
+
return Number(referenceType) === FORWARD_MESSAGE_REFERENCE_TYPE ? message.referencedMessage : null;
|
|
91
|
+
}
|
|
92
|
+
function formatDiscordSnapshotAuthor(author) {
|
|
93
|
+
if (!author) return;
|
|
94
|
+
const globalName = normalizeOptionalString(author.global_name) ?? void 0;
|
|
95
|
+
const username = normalizeOptionalString(author.username) ?? void 0;
|
|
96
|
+
const name = normalizeOptionalString(author.name) ?? void 0;
|
|
97
|
+
const discriminator = normalizeOptionalString(author.discriminator) ?? void 0;
|
|
98
|
+
const base = globalName || username || name;
|
|
99
|
+
if (username && discriminator && discriminator !== "0") return `@${username}#${discriminator}`;
|
|
100
|
+
if (base) return `@${base}`;
|
|
101
|
+
if (author.id) return `@${author.id}`;
|
|
102
|
+
}
|
|
103
|
+
//#endregion
|
|
104
|
+
//#region extensions/discord/src/monitor/message-media.ts
|
|
105
|
+
const DISCORD_MEDIA_SSRF_POLICY = {
|
|
106
|
+
hostnameAllowlist: [
|
|
107
|
+
"cdn.discordapp.com",
|
|
108
|
+
"media.discordapp.net",
|
|
109
|
+
"*.discordapp.com",
|
|
110
|
+
"*.discordapp.net"
|
|
111
|
+
],
|
|
112
|
+
allowRfc2544BenchmarkRange: true
|
|
113
|
+
};
|
|
114
|
+
const AUDIO_ATTACHMENT_EXTENSIONS = new Set([
|
|
115
|
+
".aac",
|
|
116
|
+
".caf",
|
|
117
|
+
".flac",
|
|
118
|
+
".m4a",
|
|
119
|
+
".mp3",
|
|
120
|
+
".oga",
|
|
121
|
+
".ogg",
|
|
122
|
+
".opus",
|
|
123
|
+
".wav"
|
|
124
|
+
]);
|
|
125
|
+
const DISCORD_STICKER_ASSET_BASE_URL = "https://media.discordapp.net/stickers";
|
|
126
|
+
function isDiscordAudioAttachmentFileName(fileName) {
|
|
127
|
+
const ext = getFileExtension(fileName);
|
|
128
|
+
return Boolean(ext && AUDIO_ATTACHMENT_EXTENSIONS.has(ext));
|
|
129
|
+
}
|
|
130
|
+
function hasDiscordVoiceAttachmentFields(attachment) {
|
|
131
|
+
return typeof attachment.duration_secs === "number" || typeof attachment.waveform === "string";
|
|
132
|
+
}
|
|
133
|
+
function mergeHostnameList(...lists) {
|
|
134
|
+
const merged = lists.flatMap((list) => list ?? []).map((value) => value.trim()).filter((value) => value.length > 0);
|
|
135
|
+
if (merged.length === 0) return;
|
|
136
|
+
return Array.from(new Set(merged));
|
|
137
|
+
}
|
|
138
|
+
function resolveDiscordMediaSsrFPolicy(policy) {
|
|
139
|
+
if (!policy) return DISCORD_MEDIA_SSRF_POLICY;
|
|
140
|
+
const hostnameAllowlist = mergeHostnameList(DISCORD_MEDIA_SSRF_POLICY.hostnameAllowlist, policy.hostnameAllowlist);
|
|
141
|
+
const allowedHostnames = mergeHostnameList(DISCORD_MEDIA_SSRF_POLICY.allowedHostnames, policy.allowedHostnames);
|
|
142
|
+
return {
|
|
143
|
+
...DISCORD_MEDIA_SSRF_POLICY,
|
|
144
|
+
...policy,
|
|
145
|
+
...allowedHostnames ? { allowedHostnames } : {},
|
|
146
|
+
...hostnameAllowlist ? { hostnameAllowlist } : {},
|
|
147
|
+
allowRfc2544BenchmarkRange: Boolean(DISCORD_MEDIA_SSRF_POLICY.allowRfc2544BenchmarkRange) || Boolean(policy.allowRfc2544BenchmarkRange)
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
async function resolveMediaList(message, maxBytes, options) {
|
|
151
|
+
const out = [];
|
|
152
|
+
const resolvedSsrFPolicy = resolveDiscordMediaSsrFPolicy(options?.ssrfPolicy);
|
|
153
|
+
await appendResolvedMediaFromAttachments({
|
|
154
|
+
attachments: message.attachments ?? [],
|
|
155
|
+
maxBytes,
|
|
156
|
+
out,
|
|
157
|
+
errorPrefix: "discord: failed to download attachment",
|
|
158
|
+
fetchImpl: options?.fetchImpl,
|
|
159
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
160
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
161
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
162
|
+
abortSignal: options?.abortSignal
|
|
163
|
+
});
|
|
164
|
+
await appendResolvedMediaFromStickers({
|
|
165
|
+
stickers: resolveDiscordMessageStickers(message),
|
|
166
|
+
maxBytes,
|
|
167
|
+
out,
|
|
168
|
+
errorPrefix: "discord: failed to download sticker",
|
|
169
|
+
fetchImpl: options?.fetchImpl,
|
|
170
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
171
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
172
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
173
|
+
abortSignal: options?.abortSignal
|
|
174
|
+
});
|
|
175
|
+
return out;
|
|
176
|
+
}
|
|
177
|
+
async function resolveForwardedMediaList(message, maxBytes, options) {
|
|
178
|
+
const snapshots = resolveDiscordMessageSnapshots(message);
|
|
179
|
+
const out = [];
|
|
180
|
+
const resolvedSsrFPolicy = resolveDiscordMediaSsrFPolicy(options?.ssrfPolicy);
|
|
181
|
+
if (snapshots.length > 0) {
|
|
182
|
+
for (const snapshot of snapshots) {
|
|
183
|
+
await appendResolvedMediaFromAttachments({
|
|
184
|
+
attachments: snapshot.message?.attachments,
|
|
185
|
+
maxBytes,
|
|
186
|
+
out,
|
|
187
|
+
errorPrefix: "discord: failed to download forwarded attachment",
|
|
188
|
+
fetchImpl: options?.fetchImpl,
|
|
189
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
190
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
191
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
192
|
+
abortSignal: options?.abortSignal
|
|
193
|
+
});
|
|
194
|
+
await appendResolvedMediaFromStickers({
|
|
195
|
+
stickers: snapshot.message ? resolveDiscordSnapshotStickers(snapshot.message) : [],
|
|
196
|
+
maxBytes,
|
|
197
|
+
out,
|
|
198
|
+
errorPrefix: "discord: failed to download forwarded sticker",
|
|
199
|
+
fetchImpl: options?.fetchImpl,
|
|
200
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
201
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
202
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
203
|
+
abortSignal: options?.abortSignal
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
return out;
|
|
207
|
+
}
|
|
208
|
+
const referencedForward = resolveDiscordReferencedForwardMessage(message);
|
|
209
|
+
if (!referencedForward) return out;
|
|
210
|
+
await appendResolvedMediaFromAttachments({
|
|
211
|
+
attachments: referencedForward.attachments,
|
|
212
|
+
maxBytes,
|
|
213
|
+
out,
|
|
214
|
+
errorPrefix: "discord: failed to download forwarded attachment",
|
|
215
|
+
fetchImpl: options?.fetchImpl,
|
|
216
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
217
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
218
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
219
|
+
abortSignal: options?.abortSignal
|
|
220
|
+
});
|
|
221
|
+
await appendResolvedMediaFromStickers({
|
|
222
|
+
stickers: resolveDiscordMessageStickers(referencedForward),
|
|
223
|
+
maxBytes,
|
|
224
|
+
out,
|
|
225
|
+
errorPrefix: "discord: failed to download forwarded sticker",
|
|
226
|
+
fetchImpl: options?.fetchImpl,
|
|
227
|
+
ssrfPolicy: resolvedSsrFPolicy,
|
|
228
|
+
readIdleTimeoutMs: options?.readIdleTimeoutMs,
|
|
229
|
+
totalTimeoutMs: options?.totalTimeoutMs,
|
|
230
|
+
abortSignal: options?.abortSignal
|
|
231
|
+
});
|
|
232
|
+
return out;
|
|
233
|
+
}
|
|
234
|
+
async function fetchDiscordMedia(params) {
|
|
235
|
+
const timeoutAbortController = params.totalTimeoutMs ? new AbortController() : void 0;
|
|
236
|
+
const signal = mergeAbortSignals([params.abortSignal, timeoutAbortController?.signal]);
|
|
237
|
+
let timedOut = false;
|
|
238
|
+
let timeoutHandle = null;
|
|
239
|
+
const fetchPromise = fetchRemoteMedia({
|
|
240
|
+
url: params.url,
|
|
241
|
+
filePathHint: params.filePathHint,
|
|
242
|
+
maxBytes: params.maxBytes,
|
|
243
|
+
fetchImpl: params.fetchImpl,
|
|
244
|
+
ssrfPolicy: params.ssrfPolicy,
|
|
245
|
+
readIdleTimeoutMs: params.readIdleTimeoutMs,
|
|
246
|
+
...signal ? { requestInit: { signal } } : {}
|
|
247
|
+
}).catch((error) => {
|
|
248
|
+
if (timedOut) return new Promise(() => {});
|
|
249
|
+
throw error;
|
|
250
|
+
});
|
|
251
|
+
try {
|
|
252
|
+
if (!params.totalTimeoutMs) return await fetchPromise;
|
|
253
|
+
const timeoutPromise = new Promise((_, reject) => {
|
|
254
|
+
timeoutHandle = setTimeout(() => {
|
|
255
|
+
timedOut = true;
|
|
256
|
+
timeoutAbortController?.abort();
|
|
257
|
+
reject(/* @__PURE__ */ new Error(`discord media download timed out after ${params.totalTimeoutMs}ms`));
|
|
258
|
+
}, params.totalTimeoutMs);
|
|
259
|
+
timeoutHandle.unref?.();
|
|
260
|
+
});
|
|
261
|
+
return await Promise.race([fetchPromise, timeoutPromise]);
|
|
262
|
+
} finally {
|
|
263
|
+
if (timeoutHandle) clearTimeout(timeoutHandle);
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
async function appendResolvedMediaFromAttachments(params) {
|
|
267
|
+
const attachments = params.attachments;
|
|
268
|
+
if (!attachments || attachments.length === 0) return;
|
|
269
|
+
for (const attachment of attachments) {
|
|
270
|
+
const attachmentUrl = normalizeOptionalString(attachment.url);
|
|
271
|
+
if (!attachmentUrl) {
|
|
272
|
+
logVerbose(`${params.errorPrefix} ${attachment.id ?? attachment.filename ?? "attachment"}: missing url`);
|
|
273
|
+
continue;
|
|
274
|
+
}
|
|
275
|
+
try {
|
|
276
|
+
const fetched = await fetchDiscordMedia({
|
|
277
|
+
url: attachmentUrl,
|
|
278
|
+
filePathHint: attachment.filename ?? attachmentUrl,
|
|
279
|
+
maxBytes: params.maxBytes,
|
|
280
|
+
fetchImpl: params.fetchImpl,
|
|
281
|
+
ssrfPolicy: params.ssrfPolicy,
|
|
282
|
+
readIdleTimeoutMs: params.readIdleTimeoutMs,
|
|
283
|
+
totalTimeoutMs: params.totalTimeoutMs,
|
|
284
|
+
abortSignal: params.abortSignal
|
|
285
|
+
});
|
|
286
|
+
const saved = await saveMediaBuffer(fetched.buffer, fetched.contentType ?? attachment.content_type, "inbound", params.maxBytes, attachment.filename);
|
|
287
|
+
params.out.push({
|
|
288
|
+
path: saved.path,
|
|
289
|
+
contentType: saved.contentType,
|
|
290
|
+
placeholder: inferPlaceholder(attachment)
|
|
291
|
+
});
|
|
292
|
+
} catch (err) {
|
|
293
|
+
const id = attachment.id ?? attachmentUrl;
|
|
294
|
+
logVerbose(`${params.errorPrefix} ${id}: ${String(err)}`);
|
|
295
|
+
params.out.push({
|
|
296
|
+
path: attachmentUrl,
|
|
297
|
+
contentType: attachment.content_type,
|
|
298
|
+
placeholder: inferPlaceholder(attachment)
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
function resolveStickerAssetCandidates(sticker) {
|
|
304
|
+
const baseName = sticker.name?.trim() || `sticker-${sticker.id}`;
|
|
305
|
+
switch (sticker.format_type) {
|
|
306
|
+
case StickerFormatType.GIF: return [{
|
|
307
|
+
url: `${DISCORD_STICKER_ASSET_BASE_URL}/${sticker.id}.gif`,
|
|
308
|
+
fileName: `${baseName}.gif`
|
|
309
|
+
}];
|
|
310
|
+
case StickerFormatType.Lottie: return [{
|
|
311
|
+
url: `${DISCORD_STICKER_ASSET_BASE_URL}/${sticker.id}.png?size=160`,
|
|
312
|
+
fileName: `${baseName}.png`
|
|
313
|
+
}, {
|
|
314
|
+
url: `${DISCORD_STICKER_ASSET_BASE_URL}/${sticker.id}.json`,
|
|
315
|
+
fileName: `${baseName}.json`
|
|
316
|
+
}];
|
|
317
|
+
case StickerFormatType.APNG:
|
|
318
|
+
case StickerFormatType.PNG:
|
|
319
|
+
default: return [{
|
|
320
|
+
url: `${DISCORD_STICKER_ASSET_BASE_URL}/${sticker.id}.png`,
|
|
321
|
+
fileName: `${baseName}.png`
|
|
322
|
+
}];
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
function formatStickerError(err) {
|
|
326
|
+
if (err instanceof Error) return err.message;
|
|
327
|
+
if (typeof err === "string") return err;
|
|
328
|
+
try {
|
|
329
|
+
return JSON.stringify(err) ?? "unknown error";
|
|
330
|
+
} catch {
|
|
331
|
+
return "unknown error";
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
function inferStickerContentType(sticker) {
|
|
335
|
+
switch (sticker.format_type) {
|
|
336
|
+
case StickerFormatType.GIF: return "image/gif";
|
|
337
|
+
case StickerFormatType.APNG:
|
|
338
|
+
case StickerFormatType.Lottie:
|
|
339
|
+
case StickerFormatType.PNG: return "image/png";
|
|
340
|
+
default: return;
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
async function appendResolvedMediaFromStickers(params) {
|
|
344
|
+
const stickers = params.stickers;
|
|
345
|
+
if (!stickers || stickers.length === 0) return;
|
|
346
|
+
for (const sticker of stickers) {
|
|
347
|
+
const candidates = resolveStickerAssetCandidates(sticker);
|
|
348
|
+
let lastError;
|
|
349
|
+
for (const candidate of candidates) try {
|
|
350
|
+
const fetched = await fetchDiscordMedia({
|
|
351
|
+
url: candidate.url,
|
|
352
|
+
filePathHint: candidate.fileName,
|
|
353
|
+
maxBytes: params.maxBytes,
|
|
354
|
+
fetchImpl: params.fetchImpl,
|
|
355
|
+
ssrfPolicy: params.ssrfPolicy,
|
|
356
|
+
readIdleTimeoutMs: params.readIdleTimeoutMs,
|
|
357
|
+
totalTimeoutMs: params.totalTimeoutMs,
|
|
358
|
+
abortSignal: params.abortSignal
|
|
359
|
+
});
|
|
360
|
+
const saved = await saveMediaBuffer(fetched.buffer, fetched.contentType, "inbound", params.maxBytes, candidate.fileName);
|
|
361
|
+
params.out.push({
|
|
362
|
+
path: saved.path,
|
|
363
|
+
contentType: saved.contentType,
|
|
364
|
+
placeholder: "<media:sticker>"
|
|
365
|
+
});
|
|
366
|
+
lastError = null;
|
|
367
|
+
break;
|
|
368
|
+
} catch (err) {
|
|
369
|
+
lastError = err;
|
|
370
|
+
}
|
|
371
|
+
if (lastError) {
|
|
372
|
+
logVerbose(`${params.errorPrefix} ${sticker.id}: ${formatStickerError(lastError)}`);
|
|
373
|
+
const fallback = candidates[0];
|
|
374
|
+
if (fallback) params.out.push({
|
|
375
|
+
path: fallback.url,
|
|
376
|
+
contentType: inferStickerContentType(sticker),
|
|
377
|
+
placeholder: "<media:sticker>"
|
|
378
|
+
});
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
function inferPlaceholder(attachment) {
|
|
383
|
+
const mime = attachment.content_type ?? "";
|
|
384
|
+
if (mime.startsWith("image/")) return "<media:image>";
|
|
385
|
+
if (mime.startsWith("video/")) return "<media:video>";
|
|
386
|
+
if (mime.startsWith("audio/")) return "<media:audio>";
|
|
387
|
+
if (hasDiscordVoiceAttachmentFields(attachment)) return "<media:audio>";
|
|
388
|
+
if (isDiscordAudioAttachmentFileName(attachment.filename ?? attachment.url)) return "<media:audio>";
|
|
389
|
+
return "<media:document>";
|
|
390
|
+
}
|
|
391
|
+
function isImageAttachment(attachment) {
|
|
392
|
+
if ((attachment.content_type ?? "").startsWith("image/")) return true;
|
|
393
|
+
const name = normalizeLowercaseStringOrEmpty(attachment.filename);
|
|
394
|
+
if (!name) return false;
|
|
395
|
+
return /\.(avif|bmp|gif|heic|heif|jpe?g|png|tiff?|webp)$/.test(name);
|
|
396
|
+
}
|
|
397
|
+
function buildDiscordAttachmentPlaceholder(attachments) {
|
|
398
|
+
if (!attachments || attachments.length === 0) return "";
|
|
399
|
+
const count = attachments.length;
|
|
400
|
+
const allImages = attachments.every(isImageAttachment);
|
|
401
|
+
const label = allImages ? "image" : "file";
|
|
402
|
+
const suffix = count === 1 ? label : `${label}s`;
|
|
403
|
+
return `${allImages ? "<media:image>" : "<media:document>"} (${count} ${suffix})`;
|
|
404
|
+
}
|
|
405
|
+
function buildDiscordStickerPlaceholder(stickers) {
|
|
406
|
+
if (!stickers || stickers.length === 0) return "";
|
|
407
|
+
const count = stickers.length;
|
|
408
|
+
return `<media:sticker> (${count} ${count === 1 ? "sticker" : "stickers"})`;
|
|
409
|
+
}
|
|
410
|
+
function buildDiscordMediaPlaceholder(params) {
|
|
411
|
+
const attachmentText = buildDiscordAttachmentPlaceholder(params.attachments);
|
|
412
|
+
const stickerText = buildDiscordStickerPlaceholder(params.stickers);
|
|
413
|
+
if (attachmentText && stickerText) return `${attachmentText}\n${stickerText}`;
|
|
414
|
+
return attachmentText || stickerText || "";
|
|
415
|
+
}
|
|
416
|
+
function buildDiscordMediaPayload(mediaList) {
|
|
417
|
+
return buildMediaPayload(mediaList);
|
|
418
|
+
}
|
|
419
|
+
//#endregion
|
|
420
|
+
//#region extensions/discord/src/monitor/message-text.ts
|
|
421
|
+
function resolveDiscordEmbedText(embed) {
|
|
422
|
+
const title = normalizeOptionalString(embed?.title) ?? "";
|
|
423
|
+
const description = normalizeOptionalString(embed?.description) ?? "";
|
|
424
|
+
if (title && description) return `${title}\n${description}`;
|
|
425
|
+
return title || description || "";
|
|
426
|
+
}
|
|
427
|
+
function resolveDiscordMessageText(message, options) {
|
|
428
|
+
const embedText = resolveDiscordEmbedText(message.embeds?.[0] ?? null);
|
|
429
|
+
const componentText = extractDiscordComponentsV2Text(resolveDiscordMessageComponents(message));
|
|
430
|
+
const baseText = resolveDiscordMentions(normalizeOptionalString(message.content) || buildDiscordMediaPlaceholder({
|
|
431
|
+
attachments: message.attachments ?? void 0,
|
|
432
|
+
stickers: resolveDiscordMessageStickers(message)
|
|
433
|
+
}) || embedText || componentText || normalizeOptionalString(options?.fallbackText) || "", message);
|
|
434
|
+
if (!options?.includeForwarded) return baseText;
|
|
435
|
+
const forwardedText = resolveDiscordForwardedMessagesText(message);
|
|
436
|
+
if (!forwardedText) return baseText;
|
|
437
|
+
if (!baseText) return forwardedText;
|
|
438
|
+
return `${baseText}\n${forwardedText}`;
|
|
439
|
+
}
|
|
440
|
+
function resolveDiscordMentions(text, message) {
|
|
441
|
+
if (!text.includes("<")) return text;
|
|
442
|
+
const mentions = message.mentionedUsers ?? [];
|
|
443
|
+
if (!Array.isArray(mentions) || mentions.length === 0) return text;
|
|
444
|
+
let out = text;
|
|
445
|
+
for (const user of mentions) {
|
|
446
|
+
const label = user.globalName || user.username;
|
|
447
|
+
out = out.replace(new RegExp(`<@!?${user.id}>`, "g"), `@${label}`);
|
|
448
|
+
}
|
|
449
|
+
return out;
|
|
450
|
+
}
|
|
451
|
+
function resolveDiscordForwardedMessagesText(message) {
|
|
452
|
+
const snapshots = resolveDiscordMessageSnapshots(message);
|
|
453
|
+
if (snapshots.length > 0) return resolveDiscordForwardedMessagesTextFromSnapshots(snapshots);
|
|
454
|
+
const referencedForward = resolveDiscordReferencedForwardMessage(message);
|
|
455
|
+
if (!referencedForward) return "";
|
|
456
|
+
const referencedText = resolveDiscordMessageText(referencedForward);
|
|
457
|
+
if (!referencedText) return "";
|
|
458
|
+
const authorLabel = formatDiscordSnapshotAuthor(referencedForward.author);
|
|
459
|
+
return `${authorLabel ? `[Forwarded message from ${authorLabel}]` : "[Forwarded message]"}\n${referencedText}`;
|
|
460
|
+
}
|
|
461
|
+
function resolveDiscordMessageComponents(message) {
|
|
462
|
+
const components = message.components;
|
|
463
|
+
if (components !== void 0) return components;
|
|
464
|
+
try {
|
|
465
|
+
return message.rawData?.components;
|
|
466
|
+
} catch {
|
|
467
|
+
return;
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
function extractDiscordComponentsV2Text(components) {
|
|
471
|
+
const parts = [];
|
|
472
|
+
collectDiscordTextDisplayContent(components, parts);
|
|
473
|
+
return parts.join("\n");
|
|
474
|
+
}
|
|
475
|
+
function collectDiscordTextDisplayContent(value, parts) {
|
|
476
|
+
if (Array.isArray(value)) {
|
|
477
|
+
for (const entry of value) collectDiscordTextDisplayContent(entry, parts);
|
|
478
|
+
return;
|
|
479
|
+
}
|
|
480
|
+
if (!value || typeof value !== "object") return;
|
|
481
|
+
const component = value;
|
|
482
|
+
if (component.type === ComponentType.TextDisplay) {
|
|
483
|
+
const content = normalizeOptionalString(component.content);
|
|
484
|
+
if (content) parts.push(content);
|
|
485
|
+
}
|
|
486
|
+
collectDiscordTextDisplayContent(component.components, parts);
|
|
487
|
+
collectDiscordTextDisplayContent(component.component, parts);
|
|
488
|
+
}
|
|
489
|
+
function resolveDiscordForwardedMessagesTextFromSnapshots(snapshots) {
|
|
490
|
+
const forwardedBlocks = normalizeDiscordMessageSnapshots(snapshots).map((snapshot) => buildDiscordForwardedMessageBlock(snapshot.message)).filter((entry) => Boolean(entry));
|
|
491
|
+
if (forwardedBlocks.length === 0) return "";
|
|
492
|
+
return forwardedBlocks.join("\n\n");
|
|
493
|
+
}
|
|
494
|
+
function buildDiscordForwardedMessageBlock(snapshotMessage) {
|
|
495
|
+
if (!snapshotMessage) return null;
|
|
496
|
+
const text = resolveDiscordSnapshotMessageText(snapshotMessage);
|
|
497
|
+
if (!text) return null;
|
|
498
|
+
const authorLabel = formatDiscordSnapshotAuthor(snapshotMessage.author);
|
|
499
|
+
return `${authorLabel ? `[Forwarded message from ${authorLabel}]` : "[Forwarded message]"}\n${text}`;
|
|
500
|
+
}
|
|
501
|
+
function resolveDiscordSnapshotMessageText(snapshot) {
|
|
502
|
+
const content = normalizeOptionalString(snapshot.content) ?? "";
|
|
503
|
+
const attachmentText = buildDiscordMediaPlaceholder({
|
|
504
|
+
attachments: snapshot.attachments ?? void 0,
|
|
505
|
+
stickers: resolveDiscordSnapshotStickers(snapshot)
|
|
506
|
+
});
|
|
507
|
+
const embedText = resolveDiscordEmbedText(snapshot.embeds?.[0]);
|
|
508
|
+
const componentText = extractDiscordComponentsV2Text(snapshot.components);
|
|
509
|
+
return content || attachmentText || embedText || componentText || "";
|
|
510
|
+
}
|
|
511
|
+
//#endregion
|
|
512
|
+
export { resolveForwardedMediaList as a, resolveDiscordChannelInfo as c, buildDiscordMediaPayload as i, resolveDiscordMessageChannelId as l, resolveDiscordForwardedMessagesTextFromSnapshots as n, resolveMediaList as o, resolveDiscordMessageText as r, hasDiscordMessageStickers as s, resolveDiscordEmbedText as t };
|