mirror of
https://github.com/hicccc77/WeFlow.git
synced 2026-04-25 07:26:47 +00:00
chatlab会话新增消息类型
This commit is contained in:
@@ -26,7 +26,7 @@ interface ChatLabHeader {
|
|||||||
interface ChatLabMeta {
|
interface ChatLabMeta {
|
||||||
name: string
|
name: string
|
||||||
platform: string
|
platform: string
|
||||||
type: 'group' | 'private'
|
type: ApiSessionType
|
||||||
groupId?: string
|
groupId?: string
|
||||||
groupAvatar?: string
|
groupAvatar?: string
|
||||||
ownerId?: string
|
ownerId?: string
|
||||||
@@ -68,6 +68,7 @@ interface ApiMediaOptions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type MediaKind = 'image' | 'voice' | 'video' | 'emoji'
|
type MediaKind = 'image' | 'voice' | 'video' | 'emoji'
|
||||||
|
type ApiSessionType = 'group' | 'private' | 'channel' | 'other'
|
||||||
|
|
||||||
interface ApiExportedMedia {
|
interface ApiExportedMedia {
|
||||||
kind: MediaKind
|
kind: MediaKind
|
||||||
@@ -781,6 +782,17 @@ class HttpService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private getApiSessionType(username: string): ApiSessionType {
|
||||||
|
const normalized = String(username || '').trim()
|
||||||
|
const lowered = normalized.toLowerCase()
|
||||||
|
if (!normalized) return 'other'
|
||||||
|
if (lowered.endsWith('@chatroom')) return 'group'
|
||||||
|
if (lowered.startsWith('gh_')) return 'channel'
|
||||||
|
if (lowered.includes('@openim')) return 'channel'
|
||||||
|
if (lowered.startsWith('weixin') && lowered !== 'weixin') return 'channel'
|
||||||
|
return 'private'
|
||||||
|
}
|
||||||
|
|
||||||
private async handleMessages(url: URL, res: http.ServerResponse): Promise<void> {
|
private async handleMessages(url: URL, res: http.ServerResponse): Promise<void> {
|
||||||
const talker = (url.searchParams.get('talker') || '').trim()
|
const talker = (url.searchParams.get('talker') || '').trim()
|
||||||
const limit = this.parseIntParam(url.searchParams.get('limit'), 100, 1, 10000)
|
const limit = this.parseIntParam(url.searchParams.get('limit'), 100, 1, 10000)
|
||||||
@@ -910,7 +922,7 @@ class HttpService {
|
|||||||
id: s.username,
|
id: s.username,
|
||||||
name: s.displayName || s.username,
|
name: s.displayName || s.username,
|
||||||
platform: 'wechat',
|
platform: 'wechat',
|
||||||
type: s.username.endsWith('@chatroom') ? 'group' : 'private',
|
type: this.getApiSessionType(s.username),
|
||||||
messageCount: s.messageCountHint || undefined,
|
messageCount: s.messageCountHint || undefined,
|
||||||
lastMessageAt: s.lastTimestamp
|
lastMessageAt: s.lastTimestamp
|
||||||
}))
|
}))
|
||||||
@@ -925,6 +937,7 @@ class HttpService {
|
|||||||
username: s.username,
|
username: s.username,
|
||||||
displayName: s.displayName,
|
displayName: s.displayName,
|
||||||
type: s.type,
|
type: s.type,
|
||||||
|
sessionType: this.getApiSessionType(s.username),
|
||||||
lastTimestamp: s.lastTimestamp,
|
lastTimestamp: s.lastTimestamp,
|
||||||
unreadCount: s.unreadCount
|
unreadCount: s.unreadCount
|
||||||
}))
|
}))
|
||||||
@@ -1882,7 +1895,7 @@ class HttpService {
|
|||||||
meta: {
|
meta: {
|
||||||
name: talkerName,
|
name: talkerName,
|
||||||
platform: 'wechat',
|
platform: 'wechat',
|
||||||
type: isGroup ? 'group' : 'private',
|
type: this.getApiSessionType(talkerId),
|
||||||
groupId: isGroup ? talkerId : undefined,
|
groupId: isGroup ? talkerId : undefined,
|
||||||
groupAvatar: isGroup ? sessionAvatarInfo?.avatarUrl : undefined,
|
groupAvatar: isGroup ? sessionAvatarInfo?.avatarUrl : undefined,
|
||||||
ownerId: myWxid || undefined
|
ownerId: myWxid || undefined
|
||||||
|
|||||||
Reference in New Issue
Block a user