mirror of
https://github.com/qwibitai/nanoclaw.git
synced 2026-06-04 10:14:47 +08:00
fix(migrate-v2): infer is_group from JID format
v1 didn't track is_group separately; db.ts hardcoded `is_group: 1` for
every messaging_group. v2 uses is_group=0 to collapse DM sub-thread
sessions and to drive routing decisions, so getting it wrong is latent
risk on otherwise-working installs.
New helper inferIsGroup(channelType, platformId) lives in shared.ts so
tasks.ts and any future migration step can reuse it. Inferred per
channel:
- whatsapp: `<id>@g.us` is a group, anything else is a DM
- telegram: negative chat IDs are groups, positive are DMs
- everything else: default to 1 (least surprising for chats v1 chose
to register, where DM auto-create paths weren't used)
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -29,6 +29,7 @@ import { readEnvFile } from '../../src/env.js';
|
||||
import { buildDiscordResolver, type DiscordResolver } from './discord-resolver.js';
|
||||
import {
|
||||
generateId,
|
||||
inferIsGroup,
|
||||
parseJid,
|
||||
triggerToEngage,
|
||||
v2PlatformId,
|
||||
@@ -148,7 +149,7 @@ async function main(): Promise<void> {
|
||||
channel_type: channelType,
|
||||
platform_id: platformId,
|
||||
name: g.name || null,
|
||||
is_group: 1,
|
||||
is_group: inferIsGroup(channelType, platformId),
|
||||
unknown_sender_policy: 'public',
|
||||
created_at: createdAt,
|
||||
});
|
||||
|
||||
@@ -74,6 +74,27 @@ export function v2PlatformId(channelType: string, jid: string): string {
|
||||
return id.startsWith(`${channelType}:`) ? id : `${channelType}:${id}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* Infer messaging_groups.is_group from a v2 platform_id, given a channel type.
|
||||
*
|
||||
* v1 didn't track is_group, but most channels encode it in the JID/id format:
|
||||
* - whatsapp: `<id>@g.us` is a group, `<id>@s.whatsapp.net` / `@lid` is a DM
|
||||
* - telegram: negative chat IDs are groups, positive are DMs
|
||||
* - everything else: default to 1 (group/channel) — least-surprising guess
|
||||
* for chats v1 chose to register, where DM auto-create paths weren't used
|
||||
*/
|
||||
export function inferIsGroup(channelType: string, platformId: string): number {
|
||||
if (channelType === 'whatsapp') {
|
||||
return platformId.endsWith('@g.us') ? 1 : 0;
|
||||
}
|
||||
if (channelType === 'telegram') {
|
||||
// platform_id is `telegram:<chatId>` — negative chatId means group/channel.
|
||||
const chatId = platformId.replace(/^telegram:/, '');
|
||||
return chatId.startsWith('-') ? 1 : 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
// ── Trigger mapping ─────────────────────────────────────────────────────
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user