mirror of
https://github.com/HKUDS/nanobot.git
synced 2026-05-21 17:12:32 +00:00
fix(signal): route denied DMs through _handle_message for pairing code
Previously _check_inbound_policy returned (False, chat_id) for DMs that failed the allowlist and the caller dropped them — so unapproved DM senders never saw a pairing code. Mirror Slack: when the policy gate denies a DM but dm.enabled is true, still call _handle_message(content="", is_dm=True) so BaseChannel can issue the pairing reply. Group denials stay a hard drop. Combined with the previous is_dm forwarding, unapproved DM senders now receive a pairing code through the standard flow. Addresses review comment on PR #3852.
This commit is contained in:
parent
a9a8bdcef6
commit
b647aa5f47
@ -704,6 +704,15 @@ class SignalChannel(BaseChannel):
|
||||
timestamp=timestamp,
|
||||
)
|
||||
if not allowed:
|
||||
# Mirror Slack: let denied DMs reach _handle_message so the base
|
||||
# class can reply with a pairing code. Group denials stay dropped.
|
||||
if not is_group_message and self.config.dm.enabled:
|
||||
await self._handle_message(
|
||||
sender_id=sender_id,
|
||||
chat_id=chat_id,
|
||||
content="",
|
||||
is_dm=True,
|
||||
)
|
||||
return
|
||||
|
||||
content, media_paths = self._assemble_inbound_content(
|
||||
|
||||
@ -670,11 +670,16 @@ class TestHandleDataMessageDM:
|
||||
assert len(handled) == 1
|
||||
|
||||
@pytest.mark.asyncio
|
||||
async def test_dm_allowlist_rejected(self):
|
||||
async def test_dm_allowlist_rejected_triggers_pairing(self):
|
||||
# Denied DM senders are routed to _handle_message with empty content
|
||||
# and is_dm=True so BaseChannel issues a pairing code (mirrors Slack).
|
||||
ch, handled = self._make_dm_channel(policy="allowlist", allow_from=["+10000000001"])
|
||||
params = _dm_envelope(source_number="+19995550002")
|
||||
await ch._handle_receive_notification(params)
|
||||
assert handled == []
|
||||
assert len(handled) == 1
|
||||
assert handled[0]["content"] == ""
|
||||
assert handled[0]["is_dm"] is True
|
||||
assert handled[0]["chat_id"] == "+19995550002"
|
||||
|
||||
@pytest.mark.asyncio
|
||||
async def test_dm_allowlist_matches_without_plus_prefix(self):
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user