Unity IM SDK 更新日志
大约 18 分钟
Unity 集成文档
Unity IM SDK 更新日志
版本 V1.3.2 2025-1-17
新增特性
- 新增
Conversation#LoadMessagesWithMsgTypeList
方法,根据单个或多个消息类型,搜索本地数据库中当前会话的消息。 - 新增
RoomManager#JoinRoom
方法,支持设置加入聊天室时携带的扩展信息,并指定是否退出所有其他聊天室。 - 新增
Conversion#MessagesCount
方法,用于获取 SDK 本地数据库中会话某个时间段内的全部消息数。 - 新增从服务器拉取离线消息的开始和结束的事件回调:
IConnectionDelegate#OnOfflineMessageSyncStart
和IConnectionDelegate#OnOfflineMessageSyncFinish
。 - 新增
GroupManager#CheckIfInGroupMuteList
接口,可以查看当前用户是否在群组禁言名单中。 - 原消息置顶接口
ChatManager#PinMessage
增加对单聊会话中置顶消息的支持。接口参数无变化。 - 新增
RecallMessageInfo#ConversationId
属性,在撤回消息的OnMessagesRecalled
事件中返回被撤回的消息所属的会话 ID。 - 新增
ChatManager#GetMessageCount
: 方法,用于获取数据库中的消息总数。 - [IM SDK] 新增两个错误码:
GROUP_USER_IN_BLOCKLIST
(613):该用户在群组黑名单中。例如,群组黑名单中的用户进行某些操作时,例如,加入群组,会提示该错误。CHATROOM_USER_IN_BLOCKLIST
(707):该用户在聊天室黑名单中。聊天室黑名单中的用户进行某些操作时,例如,加入聊天室,会提示该错误。
- 支持 AUT 协议,优化弱网环境下的服务连接成功率。
- 新增拉取服务器漫游消息时会读取服务端的消息已读和送达状态。该功能只适用于单聊消息,默认关闭,如果需要,请联系环信商务开通。
- 新增聊天室禁言回调
IRoomManagerDelegate#OnMuteListAddedFromRoom(string roomId, Dictionary<string, long> mutes)
:,在回调中使用Dictionary<string, long> mutes
参数表示禁言到期时间戳。 - 新增 Crash 上报能力:当 SDK 发生 Crash 时,会在下次启动后上报 Crash 信息。
- 用户加入聊天室后会收到如下信息,即调用
JoinRoom
方法后的成功回调中 Room 对象可以获取到如下信息:- 聊天室当前人数
Room#MemberCount
。有用户加入或离开聊天室时,当前聊天室人数会更新。 - 聊天室全体禁言状态
Room#IsAllMemberMuted
。该属性的值在收到全体禁言状态变更时更新。 - 聊天室创建时间戳
Room#CreateTimeStamp
,新增属性。 - 当前用户是否在聊天室白名单中
Room#IsInAllowList
。该属性为新增属性,成员收到白名单变更回调时更新。 - 当前用户被禁言截止时间戳
Room#MuteUntilTimeStamp
。该属性为新增属性,成员收到禁言变更回调时更新。
- 聊天室当前人数
优化
- 调整
IRoomManagerDelegate#OnMemberJoinedFromRoom
回调,当用户加入聊天室携带了扩展信息时,聊天室内其他人可以在用户加入聊天室的回调中,获取到扩展信息。 - 设置和获取用户属性的接口,包括设置当前用户的属性,获取单个或多个用户属性,超过调用频率限制时,会上报错误码 4
EXCEED_SERVICE_LIMIT
。 - 支持聊天室消息聚合功能。
- 发送前回调时修改的消息扩展字段,会同步到发送方。
- 调用删除服务端会话 API,成功后会删除本地会话。之前版本调用该接口可设置删除会话的本地消息,不能删除本地会话。
- 群组和聊天室操作的默认错误码提示由
GROUP_MEMBERS_FULL
(604)和CHATROOM_MEMBERS_FULL
(704)调整为GROUP_PERMISSION_DENIED
(603)和CHATROOM_PERMISSION_DENIED
(703)。例如,群组普通成员设置群组管理员时,由于缺乏权限,会提示 603 错误。 - 将 1.3.1 版本之前部分标为废弃的 API 删除。
- 优化部分数据库操作。
修复
- 从服务端拉取群组时,不再先清除本地群组,而是将拉取的群组与本地对比,将本地现有群组进行更新,将新增部分在本地插入。若要清除本地群组信息,可以调用
GroupManager#CleanAllGroupsFromDB
方法。 - 修复拉黑联系人时缓存未及时更新的问题。
- 修复多线程同时调用获取会话列表时,偶现会话未读数不正确的问题。
- 修复调用 RESTful API 转让群主后,SDK 上原群主离开群失败的问题。
- 修复开启多设备登录后,偶现的收到会话已读多设备同步事件,导致未读数不同步的问题。
- 修复发送图片消息时指定缩略图尺寸未生效的问题。
- 修复未拉取好友时收到好友事件,导致好友列表不能更新的问题。
- 修复置顶的单聊消息被撤回后,该消息未能及时地从置顶消息缓存(
Conversation#PinnedMessages
)中移除的问题。 - 修复极端情况下因网络异常导致的 Crash。
版本 V1.3.1 Dev 2024-7-9 (开发版)
新增特性
- [IM SDK] 撤回消息的方法
RecallMessage
中新增ext
参数(字符串类型),支持消息撤回时携带自定义信息。 - [IM SDK] 消息撤回事件
OnMessagesRecalled
的返回参数由List<Message>
变更为List<RecallMessageInfo>
。
修复
- [IM SDK] 修复服务端获取好友列表(包含好友备注)时,在好友列表无变化时,第二次请求获取不到数据的问题。
- [IM SDK] 修复特殊情况下附件发送失败,消息仍然成功发送的问题。
- [IM SDK] 修复拉取漫游消息时 nextkey 错误的问题。
版本 V1.3.0 Dev 2024-5-7 (开发版)
新增特性
- 新增
ChatManager#DeleteAllMessagesAndConversations
方法,用于清空当前用户的聊天记录,包括消息和会话,同时可以选择是否清除服务端的聊天记录。 - 新增根据搜索范围搜索消息:根据关键字搜索消息时,可以选择
MessageSearchScope
中的搜索范围。MessageSearchScope
:包含三个消息搜索范围,即搜索消息内容、只搜索消息扩展信息以及同时搜索消息内容以及扩展信息。ChatManager#SearchMsgFromDB(string, long, in, string, MessageSearchDirection, MessageSearchScope, ValueCallBack<List<Message>>)
:根据搜索范围搜索所有会话中的消息。Conversation#LoadMessagesWithScope(string, MessageSearchScope, long, int, string, MessageSearchDirection, ValueCallBack<List<Message>>)
:根据搜索范围搜索当前会话中的消息。
- 支持会话标记功能。
ChatManager#MarkConversations
:标记会话或取消标记会话。ChatManager#GetConversationsFromServerWithCursor
:根据会话标记从服务器分页查询会话列表。Conversation#Marks
:获取本地单个会话的所有标记。MultiDevicesOperation#CONVERSATION_MARK
:多设备场景下的会话标记事件。当前用户在一台登录设备上更新了会话标记,包括添加和移除会话标记,其他登录设备会收到该事件。
- 新增
Message#Broadcast
属性用于判断该消息是否为聊天室全局广播消息。可通过调用 REST API 发送聊天室全局广播消息。 - 新增
GroupManager#FetchMyGroupsCount
方法用于从服务器获取当前用户已加入的群组数量。 - 新增错误码 706
CHATROOM_OWNER_NOT_ALLOW_LEAVE
,表示聊天室所有者不允许离开聊天室。若初始化时,Options#IsRoomOwnerLeaveAllowed
参数设置为false
,聊天室所有者调用LeaveRoom
方法离开聊天室时会提示该错误。 - 支持聊天室漫游消息。
- 新增
Options#UseReplacedMessageContents
开关。开启后,发送消息时如果被内容审核进行了内容替换,发送方可以收到替换后的内容。 - 新增
Message#IsContentReplaced
属性判断文本消息的内容是否在文本审核过程中进行了替换。 - 新增置顶消息功能。
- 新增
ChatManager#PinMessage
方法,用于置顶消息或取消置顶消息。 - 新增
ChatManager#GetPinnedMessagesFromServer
方法,从服务器获取指定会话的置顶消息。 - 新增
Conversation#PinnedMessages
方法,返回本地会话下的所有置顶消息。 - 新增
Message#PinnedInfo
方法,展示消息的置顶详情。 - 新增
PinnedInfo
类,包含消息置顶的操作者以及置顶时间。 - 新增
IChatManagerDelegate#OnMessagePinChanged
事件。当用户在群组或聊天室会话进行置顶操作时,群组或聊天室中的其他成员会收到该回调。
- 新增
- 新增
Options#EnableEmptyConversation
开关用于在初始化时配置获取会话列表时是否允许返回空会话。 - 申请入群被拒绝的回调
IGroupManagerDelegate#OnRequestToJoinDeclinedFromGroup
中新增applicant
和decliner
参数表示申请者和拒绝者的用户 ID。 - 新增
Options#IncludeSendMessageInMessageListener
开关。开启后,在MessageListener#onMessageReceived
回调里增加发送成功的消息。 - 新增
SDKClient#LoginWithToken
方法,用于通过用户 ID 和用户 token 登录。 - 新增
SDKClient#RenewToken
方法,用于更新用户 token。 - 消息修改回调
IChatManagerDelegate#OnMessageContentChanged
中支持返回通过 RESTful API 修改的自定义消息。
优化
- 废弃
SDKClient#LoginWithAgoraToken
和SDKClient#Login
方法,使用LoginWithToken
方法替代。 - 废弃
SDKClient#RenewAgoraToken
方法,使用RenewToken
替代。 - 添加
Facility
库,优化 DNS 获取逻辑,并支持数据上报。 - 将
ChatManager#SearchMsgFromDB(string, long, int, string, MessageSearchDirection, ValueCallBack<List<Message>>)
方法从同步方式转换为异步方式。 - 将 TCP 套接字从阻断模式转换为非阻断模式。该问题只存在于 Windows 平台的 Unity SDK 中。
- 支持使用消息 body 完成单条转发,无需重新上传附件。
- 在部分场景下,降低接收到大量群成员事件通知时获取群组详情的次数。
- 在聊天室成员进出时更新聊天室成员人数,使人数更新更及时准确。
- 优化 token 登录时的错误提示信息,使错误提示更精细。
- 优化将所有会话置为已读的时间。
- 优化 SDK 内部随机取服务器地址的逻辑,提升请求成功率。
- 优化进出聊天室超时时间。
- 优化部分场景下连接失败后重连的逻辑。
- 优化附件类型消息发送时中的附件上传,支持分片上传。
- 优化发消息时重试的逻辑。
- 移除网络请求时对
NetworkOnMainThreadException
异常的捕获。 - 数据库升级逻辑优化。
- 单个日志文件大小由 2 MB 提升到 5 MB。
- iOS 平台增加了隐私协议
PrivacyInfo.xcprivacy
。
修复
- 数据库名称加密,但数据库中的内容仍为明文。该问题只存在于 Windows 平台的 Unity SDK 中。
- 修复修改消息后,离线用户上线后拉取历史消息,消息体中缺乏
from
属性的问题。 - 特殊场景下,SDK 退出后再登录会丢失聊天室监听事件问题。
- 修复网络恢复时重连 2 次的问题。
- 修复未登录时调用
LeaveRoom
方法返回的错误提示不准确。 - 部分场景下群成员人数计算重复问题。
- 修复数据上报模块偶现的崩溃问题。
- 修复部分场景下调用
ChatManager#UpdateMessage
方法更新消息时导致的崩溃问题。
版本 V1.2.0 Dev 2023-8-30 (开发版)
新增特性
- [IM SDK] 新增合并转发消息功能:
MessageBodyType#COMBINE
:合并消息类型;CombineBody
:消息体类 ;Message#CreateCombineSendMessage
:创建合并消息;ChatManager#FetchCombineMessageDetail
:下载并解析合并消息。
- [IM SDK] 新增消息修改功能:
ChatManager#ModifyMessage
:修改消息;IChatManagerDelegate#OnMessageContentChanged
:消息修改回调,接收方会收到该回调。IMessageBody#OperationTime
:修改消息中内容修改的时间。IMessageBody#OperatorId
:修改消息中的操作人的用户 ID。IMessageBody#OperationCount
:发送后消息修改的次数。
- [IM SDK] 调整
IConnectionDelegate#OnLoggedOtherDevice(intString)
回调,新增当前设备踢下线的设备名称。 - [IM SDK] 新增
IConnectionDelegate#OnAppActiveNumberReachLimitation
回调,App 激活数量已达限制值。 - [IM SDK] 新增
IMultiDeviceDelegate#OnRoamDeleteMultiDevicesEvent
回调,多端多设备单个会话删除漫游消息事件。 - [IM SDK] 新增
IMultiDeviceDelegate#OnConversationMultiDevicesEvent
回调,多端多设备会话操作事件。 - [IM SDK] 新增以下方法支持用户 token:
SDKClient#GetLoggedInDevicesFromServerWithToken
:获取指定账号下登录的在线设备列表;SDKClient#KickDeviceWithToken
:将指定账号登录的指定设备踢下线;SDKClient#KickAllDevicesWithToken
:将指定账号登录的所有设备都踢下线。
- [IM SDK] 新增会话置顶功能:
IChatManager#PinConversation
:置顶或取消置顶会话;Conversation#IsPinned
:判断该会话是否被置顶;Conversation#PinnedTime
:会话置顶时间戳。
- [IM SDK] 新增
ChatManager#FetchHistoryMessagesFromServerBy
方法根据消息拉取参数配置类FetchServerMessagesOption
从服务器获取历史消息。
作废ChatManager#GetConversationsFromServer
。 - [IM SDK] 新增消息拉取参数配置类
FetchServerMessagesOption
:FetchServerMessagesOption#IsSave
:获取的消息是否保存到数据库;FetchServerMessagesOption#Direction
:消息搜索方向;FetchServerMessagesOption#From
:消息发送方的用户 ID;FetchServerMessagesOption#MsgTypes
:要查询的消息类型列表;FetchServerMessagesOption#StartTime
:消息查询的起始时间;FetchServerMessagesOption#EndTime
:消息查询的结束时间。
- [IM SDK] 新增
GetConversationsFromServerWithCursor
方法从服务端分页获取会话列表。 - [IM SDK] 新增在群组或聊天室中发送定向消息功能:
Message#ReceiverList
:设置群组或聊天室消息接收列表。
- [IM SDK] 新增
Conversation#DeleteMessages
方法删除本地数据库中指定时间段的消息。 - [IM SDK] 新增群组成员自定义属性管理功能:
GroupManager#FetchMemberAttributes
:获取群组成员自定义属性;GroupManager#SetMemberAttributes
:设置群组用户自定义属性;IGroupManagerDelegate#OnUpdateMemberAttributesFromGroup
:群成员自定义属性发生改变。
- [IM SDK] 新增多设备操作事件:
MultiDevicesOperation#SET_METADATA
:在其他设备上设置了群组成员自定义属性;MultiDevicesOperation#DELETE_METADATA
:在其他设备上删除了群组成员自定义属性;MultiDevicesOperation#GROUP_MEMBER_METADATA_CHANGED
:群组成员自定义属性发生改变;MultiDevicesOperation#CONVERSATION_PINNED
:会话被置顶;MultiDevicesOperation#CONVERSATION_UNPINNED
:会话被取消置顶;MultiDevicesOperation#CONVERSATION_DELETED
:会话被删除。
- [IM SDK] 新增 Reaction 操作类
MessageReactionOperation
:MessageReactionOperation#UserId
:操作者;MessageReactionOperation#Reaction
:发生变化的 Reaction。
- [IM SDK] 新增自定义设备的平台和名称功能:
Options#CustomOSType
:设置自定义平台代号;Options#CustomDeviceName
:设置当前设备自定义设备名称。
- [IM SDK] 新增
Message#DeliverOnlineOnly
字段设置消息是否只投递给在线用户; - [IM SDK] 新增以下
Options
选项:Options#SDKDataPath
:设置 SDK 数据的底层存储路径;Options#MyUUID
:设置自定义设备 UUID;Options#EnableEmptyConversation
:从数据库加载会话时,是否允许加载空会话。
优化
- [IM SDK] 支持 masOS 上 ARM64 模式。
- [IM SDK]
kickAllDevice
重命名为KickAllDevice
。 - [IM SDK] 修改
MessageReaction
中拼写错误:Rection
修改为Reaction
。 - [IM SDK] 修改
MessageBody
中以下属性名称中的拼写错误:ThumbnaiRemotePath
修改为ThumbnailRemotePath
;ThumbnaiSecret
修改为ThumbnailSecret
;ThumbnaiDownStatus
修改为ThumbnailDownStatus
。
修复
- [IM SDK] 修复 SDK 回调时找不到回调句柄的问题;
- [IM SDK] 修复 SDK 在未初始化时对底层资源的释放;
- [IM SDK] 修复安卓、IOS 在更新用户属性时的一些问题;
版本 V1.1.1 Dev 2023-5-29
修复
- 修复
ChatManager#FetchHistoryMessageFromServer
方法在安卓环境下调用失败的问题。 - 修复在安卓环境下发送视频消息没有回调的问题。
版本 V1.1.0 Dev 2023-2-25
新增特性
- 依赖的原生平台
iOS
和Android
的 SDK 升级为 v4.0.0 版本。 - 新增
ChatManager#GetConversationsFromServerWithPage
方法实现从服务器分页获取会话列表。 - 新增
Message#Priority
属性实现聊天室消息优先级功能,确保高优先级消息优先处理。
优化
调整 SDKClient#InitWithOptions
方法,增加返回结果,检查 App Key 格式。
修复
- 修复登录时的部分 bug。
- 修复发送的消息的已读标识为
false
的问题。修复后,发送消息时将已读标识设置为true
。 - 数据库加密文件名生成错误问题。该问题只发生在 Unity 框架下的 Window 和 Mac 平台。建议升级到 v1.1.0 后,使用历史数据时首先从服务端拉取数据。
版本 V1.0.9 Dev 2022-12-30(开发版)
新增特性
SDKClient
类中新增以下方法:
GetLoggedInDevicesFromServer
:获取通过指定账号登录的在线设备列表。KickDevice
:将指定账号登录的指定设备踢下线。kickAllDevices
:将指定账号登录的所有设备都踢下线。
RoomManager
类中新增以下方法:
FetchAllowListFromServer
:从服务器获取聊天室白名单列表。CheckIfInRoomAllowList
:检查当前用户是否在聊天室白名单中。GetChatRoom
:从内存中获取指定聊天室的详情。UnMuteAllRoomMembers
:解除对所有聊天室成员的禁言。
IRoomManagerDelegate
类中新增以下回调方法:
OnSpecificationChangedFromRoom
:聊天室信息有更新。OnAddAllowListMembersFromChatroom
:有成员加入聊天室白名单。OnRemoveAllowListMembersFromChatroom
:有成员被移出聊天室白名单。OnRemoveFromRoomByOffline
:成员因为离线被移出聊天室。
IConnectionDelegate
类中新增以下回调方法:
OnLoggedOtherDevice
:当前登录账号在其它设备登录时会收到此回调。OnRemovedFromServer
:当前登录账号已经被从服务器端删除时会收到该回调。OnForbidByServer
:当前用户账号被禁用时会收到该回调。OnChangedIMPwd
:当前登录账号因密码被修改被强制退出。OnLoginTooManyDevice
:当前登录账号因达到登录设备数量上限被强制退出。OnKickedByOtherDevice
:当前登录设备账号被登录其他设备的同账号踢下线。OnAuthFailed
:当前登录设备账号因鉴权失败强制退出。
Group
类中新增以下属性:
IsMemberOnly
:表示群组不能自由加入,需要申请或者被邀请。IsMemberAllowToInvite
:群组是否允许成员邀请。MaxUserCount
:群允许加入的最大成员数。Ext
:自定义群组扩展信息。IsDisabled
:群组是否禁用。
优化
- 命名空间由 ChatSDK 修改为 AgoraChat。
- 各方法中的
handle
参数重命名为callback
。 - 移除了
pushmanager
类。 UserInfo
类中的字段名均改为首字母大写。Message
类中的AttributeValue
子类移除了UINT32
和JSONSTRING
类型。OnDisconnected
方法中移除整型参数i
。- 以下方法的返回结果进行了调整:
importmessage
的返回结果由直接返回调整为异步回调。GetGroupMuteListFromServer
的返回结果的数据类型由List<string>
调整为Dictionary<string, string>
。FetchRoomMuteList
的返回结果的数据类型由List<string>
调整为Dictionary<string, string>
。
GroupManager
类中的以下方法进行了重命名:
AddGroupWhiteList
重命名为AddGroupAllowList
。CheckIfInGroupWhiteList
重命名为CheckIfInGroupAllowList
。GetGroupWhiteListFromServer
重命名为GetGroupAllowListFromServer
。RemoveGroupWhiteList
重命名为RemoveGroupAllowList
。
RoomManager
类中的以下方法进行了重命名:
AddWhiteListMembers
重命名为AddAllowListMembers
。RemoveWhiteListMembers
重命名为RemoveAllowListMembers
。
Message
类中的ReactionList
由属性调整为了方法。Group
类的Options
中的属性仅对内开放,不对外开放。IGroupManagerDelegate
类中进行了以下调整:
OnAddWhiteListMembersFromGroup
方法重命名为OnAddAllowListMembersFromGroup
。OnRemoveWhiteListMembersFromGroup
方法重命名为OnRemoveAllowListMembersFromGroup
。OnInvitationAcceptedFromGroup
方法中移除了reason
参数。OnRequestToJoinDeclinedFromGroup
方法中移除了groupName
和decliner
参数。
版本 V1.0.8 Dev 2022-9-30(开发版)
新增特性
- 新增聊天室自定义属性功能。
ChatGroup
中增加isDisabled
属性显示群组禁用状态,需要开发者在服务端设置。该属性在调用IGroupManager
中的GetGroupSpecificationFromServer
方法获取群组详情时返回。
优化
- 移除 SDK 一部分冗余日志;
- 将命名空间由 ChatSDK 改为 AgoraChat。
修复
- 修复极少数场景下,从服务器获取较大数量的消息时失败的问题。
- 修复数据统计不正确的问题。
- 修复极少数场景下打印日志导致的崩溃。
- 修复连接监听器有时无法接收到连接回调的问题。
版本 V1.0.5 2022-08-12
这是环信即时通讯 IM Unity SDK 第一个正式发布的版本,包含以下功能:
- 在单聊、群聊、聊天室和子区中发送和接收消息;
- 管理会话和消息;
- 管理群组和聊天室;
- 用户在线状态订阅;
- 消息表情回复;
- 管理子区等。
关于详细功能概述,请参见产品概述。
具体集成请参考以下文档: