Unity IM SDK 更新日志

大约 18 分钟

Unity IM SDK 更新日志

版本 V1.3.2 2025-1-17

新增特性

  • 新增 Conversation#LoadMessagesWithMsgTypeList 方法,根据单个或多个消息类型,搜索本地数据库中当前会话的消息
  • 新增 RoomManager#JoinRoom方法,支持设置加入聊天室时携带的扩展信息,并指定是否退出所有其他聊天室
  • 新增 Conversion#MessagesCount 方法,用于获取 SDK 本地数据库中会话某个时间段内的全部消息数
  • 新增从服务器拉取离线消息的开始和结束的事件回调IConnectionDelegate#OnOfflineMessageSyncStartIConnectionDelegate#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] 修复服务端获取好友列表(包含好友备注)时,在好友列表无变化时,第二次请求获取不到数据的问题。
  • [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 中新增 applicantdecliner 参数表示申请者和拒绝者的用户 ID。
  • 新增 Options#IncludeSendMessageInMessageListener 开关。开启后,在 MessageListener#onMessageReceived 回调里增加发送成功的消息。
  • 新增 SDKClient#LoginWithToken 方法,用于通过用户 ID 和用户 token 登录。
  • 新增 SDKClient#RenewToken 方法,用于更新用户 token。
  • 消息修改回调 IChatManagerDelegate#OnMessageContentChanged 中支持返回通过 RESTful API 修改的自定义消息

优化

  • 废弃 SDKClient#LoginWithAgoraTokenSDKClient#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

修复

  1. 修复 ChatManager#FetchHistoryMessageFromServer 方法在安卓环境下调用失败的问题。
  2. 修复在安卓环境下发送视频消息没有回调的问题。

版本 V1.1.0 Dev 2023-2-25

新增特性

  • 依赖的原生平台 iOSAndroid 的 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(开发版)

新增特性

  1. SDKClient 类中新增以下方法:
  • GetLoggedInDevicesFromServer:获取通过指定账号登录的在线设备列表。
  • KickDevice:将指定账号登录的指定设备踢下线。
  • kickAllDevices:将指定账号登录的所有设备都踢下线。
  1. RoomManager 类中新增以下方法:
  • FetchAllowListFromServer:从服务器获取聊天室白名单列表。
  • CheckIfInRoomAllowList:检查当前用户是否在聊天室白名单中。
  • GetChatRoom:从内存中获取指定聊天室的详情。
  • UnMuteAllRoomMembers:解除对所有聊天室成员的禁言。
  1. IRoomManagerDelegate 类中新增以下回调方法:
  • OnSpecificationChangedFromRoom:聊天室信息有更新。
  • OnAddAllowListMembersFromChatroom:有成员加入聊天室白名单。
  • OnRemoveAllowListMembersFromChatroom:有成员被移出聊天室白名单。
  • OnRemoveFromRoomByOffline:成员因为离线被移出聊天室。
  1. IConnectionDelegate 类中新增以下回调方法:
  • OnLoggedOtherDevice:当前登录账号在其它设备登录时会收到此回调。
  • OnRemovedFromServer:当前登录账号已经被从服务器端删除时会收到该回调。
  • OnForbidByServer:当前用户账号被禁用时会收到该回调。
  • OnChangedIMPwd:当前登录账号因密码被修改被强制退出。
  • OnLoginTooManyDevice:当前登录账号因达到登录设备数量上限被强制退出。
  • OnKickedByOtherDevice:当前登录设备账号被登录其他设备的同账号踢下线。
  • OnAuthFailed:当前登录设备账号因鉴权失败强制退出。
  1. Group 类中新增以下属性:
  • IsMemberOnly:表示群组不能自由加入,需要申请或者被邀请。
  • IsMemberAllowToInvite:群组是否允许成员邀请。
  • MaxUserCount:群允许加入的最大成员数。
  • Ext:自定义群组扩展信息。
  • IsDisabled:群组是否禁用。

优化

  1. 命名空间由 ChatSDK 修改为 AgoraChat。
  2. 各方法中的 handle 参数重命名为 callback
  3. 移除了 pushmanager 类。
  4. UserInfo 类中的字段名均改为首字母大写。
  5. Message 类中的 AttributeValue 子类移除了 UINT32JSONSTRING 类型。
  6. OnDisconnected 方法中移除整型参数 i
  7. 以下方法的返回结果进行了调整:
  • importmessage 的返回结果由直接返回调整为异步回调。
  • GetGroupMuteListFromServer 的返回结果的数据类型由 List<string> 调整为 Dictionary<string, string>
  • FetchRoomMuteList 的返回结果的数据类型由 List<string> 调整为 Dictionary<string, string>
  1. GroupManager 类中的以下方法进行了重命名:
  • AddGroupWhiteList 重命名为 AddGroupAllowList
  • CheckIfInGroupWhiteList 重命名为 CheckIfInGroupAllowList
  • GetGroupWhiteListFromServer 重命名为 GetGroupAllowListFromServer
  • RemoveGroupWhiteList 重命名为 RemoveGroupAllowList
  1. RoomManager 类中的以下方法进行了重命名:
  • AddWhiteListMembers 重命名为 AddAllowListMembers
  • RemoveWhiteListMembers 重命名为 RemoveAllowListMembers
  1. Message 类中的 ReactionList 由属性调整为了方法。
  2. Group 类的 Options 中的属性仅对内开放,不对外开放。
  3. IGroupManagerDelegate 类中进行了以下调整:
  • OnAddWhiteListMembersFromGroup 方法重命名为 OnAddAllowListMembersFromGroup
  • OnRemoveWhiteListMembersFromGroup 方法重命名为 OnRemoveAllowListMembersFromGroup
  • OnInvitationAcceptedFromGroup 方法中移除了 reason 参数。
  • OnRequestToJoinDeclinedFromGroup 方法中移除了 groupNamedecliner 参数。

版本 V1.0.8 Dev 2022-9-30(开发版)

新增特性

  • 新增聊天室自定义属性功能。
  • ChatGroup 中增加 isDisabled 属性显示群组禁用状态,需要开发者在服务端设置。该属性在调用 IGroupManager 中的 GetGroupSpecificationFromServer 方法获取群组详情时返回。

优化

  • 移除 SDK 一部分冗余日志;
  • 将命名空间由 ChatSDK 改为 AgoraChat。

修复

  1. 修复极少数场景下,从服务器获取较大数量的消息时失败的问题。
  2. 修复数据统计不正确的问题。
  3. 修复极少数场景下打印日志导致的崩溃。
  4. 修复连接监听器有时无法接收到连接回调的问题。

版本 V1.0.5 2022-08-12

这是环信即时通讯 IM Unity SDK 第一个正式发布的版本,包含以下功能:

  • 在单聊、群聊、聊天室和子区中发送和接收消息;
  • 管理会话和消息;
  • 管理群组和聊天室;
  • 用户在线状态订阅;
  • 消息表情回复;
  • 管理子区等。

关于详细功能概述,请参见产品概述open in new window

具体集成请参考以下文档: