main
hrxiang 3 years ago
parent 7247f6b982
commit 6ad47216fb
  1. 4
      CHANGELOG.md
  2. 1
      lib/flutter_openim_sdk.dart
  3. 6
      lib/src/enum/conversation_type.dart
  4. 10
      lib/src/enum/group_at_type.dart
  5. 8
      lib/src/enum/group_role_level.dart
  6. 11
      lib/src/enum/group_verification.dart
  7. 3
      lib/src/enum/im_platform.dart
  8. 8
      lib/src/enum/message_status.dart
  9. 88
      lib/src/enum/message_type.dart
  10. 11
      lib/src/listener/advanced_msg_listener.dart
  11. 17
      lib/src/listener/connect_listener.dart
  12. 4
      lib/src/listener/conversation_listener.dart
  13. 10
      lib/src/listener/friendship_listener.dart
  14. 11
      lib/src/listener/group_listener.dart
  15. 1
      lib/src/listener/msg_send_progress_listener.dart
  16. 1
      lib/src/listener/organization_listener.dart
  17. 1
      lib/src/listener/user_listener.dart
  18. 1
      lib/src/listener/workmoments_listener.dart
  19. 65
      lib/src/manager/im_conversation_manager.dart
  20. 33
      lib/src/manager/im_friendship_manager.dart
  21. 57
      lib/src/manager/im_group_manager.dart
  22. 24
      lib/src/manager/im_manager.dart
  23. 99
      lib/src/manager/im_message_manager.dart
  24. 30
      lib/src/manager/im_organization_manager.dart
  25. 6
      lib/src/manager/im_signaling_manager.dart
  26. 13
      lib/src/manager/im_user_manager.dart
  27. 10
      lib/src/manager/im_workmoments_manager.dart
  28. 33
      lib/src/models/conversation_info.dart
  29. 110
      lib/src/models/group_info.dart
  30. 217
      lib/src/models/message.dart
  31. 82
      lib/src/models/notification_info.dart
  32. 70
      lib/src/models/organization_info.dart
  33. 6
      lib/src/models/search_info.dart
  34. 46
      lib/src/models/signaling_info.dart
  35. 120
      lib/src/models/user_info.dart
  36. 7
      lib/src/openim.dart
  37. 2
      pubspec.yaml

@ -1,3 +1,7 @@
## 2.1.0+1
1.Add join group verification set </br>
## 2.1.0 ## 2.1.0
1.Fix bug </br> 1.Fix bug </br>

@ -3,6 +3,7 @@ library flutter_openim_sdk;
export 'src/enum/conversation_type.dart'; export 'src/enum/conversation_type.dart';
export 'src/enum/group_at_type.dart'; export 'src/enum/group_at_type.dart';
export 'src/enum/group_role_level.dart'; export 'src/enum/group_role_level.dart';
export 'src/enum/group_verification.dart';
export 'src/enum/im_platform.dart'; export 'src/enum/im_platform.dart';
export 'src/enum/listener_type.dart'; export 'src/enum/listener_type.dart';
export 'src/enum/message_status.dart'; export 'src/enum/message_status.dart';

@ -1,5 +1,11 @@
///
class ConversationType { class ConversationType {
///
static const single = 1; static const single = 1;
///
static const group = 2; static const group = 2;
///
static const notification = 4; static const notification = 4;
} }

@ -1,7 +1,17 @@
///
class GroupAtType { class GroupAtType {
///
static const atNormal = 0; static const atNormal = 0;
/// @
static const atMe = 1; static const atMe = 1;
/// @
static const atAll = 2; static const atAll = 2;
/// @@
static const atAllAtMe = 3; static const atAllAtMe = 3;
///
static const groupNotification = 4; static const groupNotification = 4;
} }

@ -1,7 +1,11 @@
/// 1 ordinary member, 2 group owners, 3 administrators ///
/// 1, 23
class GroupRoleLevel { class GroupRoleLevel {
///
static const member = 1; static const member = 1;
///
static const owner = 2; static const owner = 2;
///
static const admin = 3; static const admin = 3;
} }

@ -0,0 +1,11 @@
///
class GroupVerification {
///
static const int applyNeedVerificationInviteDirectly = 0;
///
static const int allNeedVerification = 1;
///
static const int directly = 2;
}

@ -1,5 +1,8 @@
class IMPlatform { class IMPlatform {
/// IOS
static const ios = 1; static const ios = 1;
/// Android
static const android = 2; static const android = 2;
static const windows = 3; static const windows = 3;
static const xos = 4; static const xos = 4;

@ -1,6 +1,14 @@
///
class MessageStatus { class MessageStatus {
///
static const sending = 1; static const sending = 1;
///
static const succeeded = 2; static const succeeded = 2;
///
static const failed = 3; static const failed = 3;
///
static const deleted = 4; static const deleted = 4;
} }

@ -1,67 +1,151 @@
///
class MessageType { class MessageType {
/// ///
static const text = 101; static const text = 101;
///
static const picture = 102; static const picture = 102;
///
static const voice = 103; static const voice = 103;
///
static const video = 104; static const video = 104;
///
static const file = 105; static const file = 105;
/// @
static const at_text = 106; static const at_text = 106;
///
static const merger = 107; static const merger = 107;
///
static const card = 108; static const card = 108;
///
static const location = 109; static const location = 109;
///
static const custom = 110; static const custom = 110;
///
static const revoke = 111; static const revoke = 111;
///
static const has_read_receipt = 112; static const has_read_receipt = 112;
///
static const typing = 113; static const typing = 113;
///
static const quote = 114; static const quote = 114;
///
static const custom_face = 115; static const custom_face = 115;
/// ///
static const notificationBegin = 1000; static const notificationBegin = 1000;
static const friendNotificationBegin = 1200; static const friendNotificationBegin = 1200;
///
static const friendApplicationApprovedNotification = 1201; static const friendApplicationApprovedNotification = 1201;
///
static const friendApplicationRejectedNotification = 1202; static const friendApplicationRejectedNotification = 1202;
///
static const friendApplicationNotification = 1203; static const friendApplicationNotification = 1203;
///
static const friendAddedNotification = 1204; static const friendAddedNotification = 1204;
///
static const friendDeletedNotification = 1205; static const friendDeletedNotification = 1205;
///
static const friendRemarkSetNotification = 1206; static const friendRemarkSetNotification = 1206;
///
static const blackAddedNotification = 1207; static const blackAddedNotification = 1207;
///
static const blackDeletedNotification = 1208; static const blackDeletedNotification = 1208;
static const friendNotificationEnd = 1299; static const friendNotificationEnd = 1299;
///
static const conversationChangeNotification = 1300; static const conversationChangeNotification = 1300;
static const userNotificationBegin = 1301; static const userNotificationBegin = 1301;
///
static const userInfoUpdatedNotification = 1303; static const userInfoUpdatedNotification = 1303;
static const userNotificationEnd = 1399; static const userNotificationEnd = 1399;
/// OA通知
static const oaNotification = 1400; static const oaNotification = 1400;
static const groupNotificationBegin = 1500; static const groupNotificationBegin = 1500;
///
static const groupCreatedNotification = 1501; static const groupCreatedNotification = 1501;
///
static const groupInfoSetNotification = 1502; static const groupInfoSetNotification = 1502;
///
static const joinGroupApplicationNotification = 1503; static const joinGroupApplicationNotification = 1503;
/// 退
static const memberQuitNotification = 1504; static const memberQuitNotification = 1504;
///
static const groupApplicationAcceptedNotification = 1505; static const groupApplicationAcceptedNotification = 1505;
///
static const groupApplicationRejectedNotification = 1506; static const groupApplicationRejectedNotification = 1506;
///
static const groupOwnerTransferredNotification = 1507; static const groupOwnerTransferredNotification = 1507;
///
static const memberKickedNotification = 1508; static const memberKickedNotification = 1508;
///
static const memberInvitedNotification = 1509; static const memberInvitedNotification = 1509;
///
static const memberEnterNotification = 1510; static const memberEnterNotification = 1510;
///
static const dismissGroupNotification = 1511; static const dismissGroupNotification = 1511;
static const groupNotificationEnd = 1599; static const groupNotificationEnd = 1599;
///
static const groupMemberMutedNotification = 1512; static const groupMemberMutedNotification = 1512;
///
static const groupMemberCancelMutedNotification = 1513; static const groupMemberCancelMutedNotification = 1513;
///
static const groupMutedNotification = 1514; static const groupMutedNotification = 1514;
///
static const groupCancelMutedNotification = 1515; static const groupCancelMutedNotification = 1515;
///
static const groupMemberInfoChangedNotification = 1516; static const groupMemberInfoChangedNotification = 1516;
static const signalingNotificationBegin = 1600; static const signalingNotificationBegin = 1600;
///
static const signalingNotification = 1601; static const signalingNotification = 1601;
static const signalingNotificationEnd = 1699; static const signalingNotificationEnd = 1699;
///
static const burnAfterReadingNotification = 1701; static const burnAfterReadingNotification = 1701;
static const notificationEnd = 2000; static const notificationEnd = 2000;

@ -1,15 +1,10 @@
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
///
class OnAdvancedMsgListener { class OnAdvancedMsgListener {
/// Message read receipt
Function(List<ReadReceiptInfo> list)? onRecvC2CMessageReadReceipt; Function(List<ReadReceiptInfo> list)? onRecvC2CMessageReadReceipt;
Function(List<ReadReceiptInfo> list)? onRecvGroupMessageReadReceipt; Function(List<ReadReceiptInfo> list)? onRecvGroupMessageReadReceipt;
/// A friend revoked a message
Function(String msgId)? onRecvMessageRevoked; Function(String msgId)? onRecvMessageRevoked;
/// Receive new message
Function(Message msg)? onRecvNewMessage; Function(Message msg)? onRecvNewMessage;
/// Uniquely identifies /// Uniquely identifies
@ -22,18 +17,22 @@ class OnAdvancedMsgListener {
this.onRecvNewMessage, this.onRecvNewMessage,
}) : id = "id_${DateTime.now().microsecondsSinceEpoch}"; }) : id = "id_${DateTime.now().microsecondsSinceEpoch}";
/// C2C消息已读回执
void recvC2CMessageReadReceipt(List<ReadReceiptInfo> list) { void recvC2CMessageReadReceipt(List<ReadReceiptInfo> list) {
onRecvC2CMessageReadReceipt?.call(list); onRecvC2CMessageReadReceipt?.call(list);
} }
///
void recvGroupMessageReadReceipt(List<ReadReceiptInfo> list) { void recvGroupMessageReadReceipt(List<ReadReceiptInfo> list) {
onRecvGroupMessageReadReceipt?.call(list); onRecvGroupMessageReadReceipt?.call(list);
} }
///
void recvMessageRevoked(String msgId) { void recvMessageRevoked(String msgId) {
onRecvMessageRevoked?.call(msgId); onRecvMessageRevoked?.call(msgId);
} }
///
void recvNewMessage(Message msg) { void recvNewMessage(Message msg) {
onRecvNewMessage?.call(msg); onRecvNewMessage?.call(msg);
} }

@ -1,19 +1,9 @@
/// SDK
class OnConnectListener { class OnConnectListener {
/// SDK failed to connect to the server
Function(int? code, String? errorMsg)? onConnectFailed; Function(int? code, String? errorMsg)? onConnectFailed;
/// SDK has successfully connected to the server
Function()? onConnectSuccess; Function()? onConnectSuccess;
/// SDK is connecting to the server
Function()? onConnecting; Function()? onConnecting;
/// The current user is kicked offline.
/// At this time, the UI can prompt the user and call IMManager's login() function to log in again.
Function()? onKickedOffline; Function()? onKickedOffline;
/// Ticket expired when online.
/// At this time, you need to generate a new userSig and call IMManager's login() function to log in again
Function()? onUserSigExpired; Function()? onUserSigExpired;
OnConnectListener({ OnConnectListener({
@ -24,22 +14,27 @@ class OnConnectListener {
this.onUserSigExpired, this.onUserSigExpired,
}); });
/// SDK连接服务器失败
void connectFailed(int? code, String? errorMsg) { void connectFailed(int? code, String? errorMsg) {
if (null != onConnectFailed) onConnectFailed!(code, errorMsg); if (null != onConnectFailed) onConnectFailed!(code, errorMsg);
} }
/// SDK连接服务器成功
void connectSuccess() { void connectSuccess() {
if (null != onConnectSuccess) onConnectSuccess!(); if (null != onConnectSuccess) onConnectSuccess!();
} }
/// SDK正在连接服务器
void connecting() { void connecting() {
if (null != onConnecting) onConnecting!.call(); if (null != onConnecting) onConnecting!.call();
} }
/// 线
void kickedOffline() { void kickedOffline() {
if (null != onKickedOffline) onKickedOffline!(); if (null != onKickedOffline) onKickedOffline!();
} }
///
void userSigExpired() { void userSigExpired() {
if (null != onUserSigExpired) onUserSigExpired!(); if (null != onUserSigExpired) onUserSigExpired!();
} }

@ -1,5 +1,6 @@
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
///
class OnConversationListener { class OnConversationListener {
Function(List<ConversationInfo> list)? onConversationChanged; Function(List<ConversationInfo> list)? onConversationChanged;
Function(List<ConversationInfo> list)? onNewConversation; Function(List<ConversationInfo> list)? onNewConversation;
@ -17,10 +18,12 @@ class OnConversationListener {
this.onSyncServerStart, this.onSyncServerStart,
}); });
///
void conversationChanged(List<ConversationInfo> list) { void conversationChanged(List<ConversationInfo> list) {
if (onConversationChanged != null) onConversationChanged!(list); if (onConversationChanged != null) onConversationChanged!(list);
} }
///
void newConversation(List<ConversationInfo> list) { void newConversation(List<ConversationInfo> list) {
if (onNewConversation != null) onNewConversation!(list); if (onNewConversation != null) onNewConversation!(list);
} }
@ -37,6 +40,7 @@ class OnConversationListener {
if (onSyncServerStart != null) onSyncServerStart!(); if (onSyncServerStart != null) onSyncServerStart!();
} }
///
void totalUnreadMessageCountChanged(int i) { void totalUnreadMessageCountChanged(int i) {
if (onTotalUnreadMessageCountChanged != null) if (onTotalUnreadMessageCountChanged != null)
onTotalUnreadMessageCountChanged!(i); onTotalUnreadMessageCountChanged!(i);

@ -1,5 +1,6 @@
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
///
class OnFriendshipListener { class OnFriendshipListener {
Function(FriendApplicationInfo i)? onFriendApplicationAdded; Function(FriendApplicationInfo i)? onFriendApplicationAdded;
Function(FriendApplicationInfo i)? onFriendApplicationDeleted; Function(FriendApplicationInfo i)? onFriendApplicationDeleted;
@ -23,38 +24,47 @@ class OnFriendshipListener {
this.onFriendInfoChanged, this.onFriendInfoChanged,
}); });
///
void blacklistAdded(BlacklistInfo u) { void blacklistAdded(BlacklistInfo u) {
onBlacklistAdded?.call(u); onBlacklistAdded?.call(u);
} }
///
void blacklistDeleted(BlacklistInfo u) { void blacklistDeleted(BlacklistInfo u) {
onBlacklistDeleted?.call(u); onBlacklistDeleted?.call(u);
} }
///
void friendAdded(FriendInfo u) { void friendAdded(FriendInfo u) {
onFriendAdded?.call(u); onFriendAdded?.call(u);
} }
///
void friendApplicationAccepted(FriendApplicationInfo u) { void friendApplicationAccepted(FriendApplicationInfo u) {
onFriendApplicationAccepted?.call(u); onFriendApplicationAccepted?.call(u);
} }
///
void friendApplicationAdded(FriendApplicationInfo u) { void friendApplicationAdded(FriendApplicationInfo u) {
onFriendApplicationAdded?.call(u); onFriendApplicationAdded?.call(u);
} }
///
void friendApplicationDeleted(FriendApplicationInfo u) { void friendApplicationDeleted(FriendApplicationInfo u) {
onFriendApplicationDeleted?.call(u); onFriendApplicationDeleted?.call(u);
} }
///
void friendApplicationRejected(FriendApplicationInfo u) { void friendApplicationRejected(FriendApplicationInfo u) {
onFriendApplicationRejected?.call(u); onFriendApplicationRejected?.call(u);
} }
///
void friendDeleted(FriendInfo u) { void friendDeleted(FriendInfo u) {
onFriendDeleted?.call(u); onFriendDeleted?.call(u);
} }
///
void friendInfoChanged(FriendInfo u) { void friendInfoChanged(FriendInfo u) {
onFriendInfoChanged?.call(u); onFriendInfoChanged?.call(u);
} }

@ -1,5 +1,6 @@
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
///
class OnGroupListener { class OnGroupListener {
Function(GroupApplicationInfo info)? onGroupApplicationAccepted; Function(GroupApplicationInfo info)? onGroupApplicationAccepted;
Function(GroupApplicationInfo info)? onGroupApplicationAdded; Function(GroupApplicationInfo info)? onGroupApplicationAdded;
@ -25,42 +26,52 @@ class OnGroupListener {
this.onJoinedGroupDeleted, this.onJoinedGroupDeleted,
}); });
///
void groupApplicationAccepted(GroupApplicationInfo info) { void groupApplicationAccepted(GroupApplicationInfo info) {
onGroupApplicationAccepted?.call(info); onGroupApplicationAccepted?.call(info);
} }
///
void groupApplicationAdded(GroupApplicationInfo info) { void groupApplicationAdded(GroupApplicationInfo info) {
onGroupApplicationAdded?.call(info); onGroupApplicationAdded?.call(info);
} }
///
void groupApplicationDeleted(GroupApplicationInfo info) { void groupApplicationDeleted(GroupApplicationInfo info) {
onGroupApplicationDeleted?.call(info); onGroupApplicationDeleted?.call(info);
} }
///
void groupApplicationRejected(GroupApplicationInfo info) { void groupApplicationRejected(GroupApplicationInfo info) {
onGroupApplicationRejected?.call(info); onGroupApplicationRejected?.call(info);
} }
///
void groupInfoChanged(GroupInfo info) { void groupInfoChanged(GroupInfo info) {
onGroupInfoChanged?.call(info); onGroupInfoChanged?.call(info);
} }
///
void groupMemberAdded(GroupMembersInfo info) { void groupMemberAdded(GroupMembersInfo info) {
onGroupMemberAdded?.call(info); onGroupMemberAdded?.call(info);
} }
///
void groupMemberDeleted(GroupMembersInfo info) { void groupMemberDeleted(GroupMembersInfo info) {
onGroupMemberDeleted?.call(info); onGroupMemberDeleted?.call(info);
} }
///
void groupMemberInfoChanged(GroupMembersInfo info) { void groupMemberInfoChanged(GroupMembersInfo info) {
onGroupMemberInfoChanged?.call(info); onGroupMemberInfoChanged?.call(info);
} }
///
void joinedGroupAdded(GroupInfo info) { void joinedGroupAdded(GroupInfo info) {
onJoinedGroupAdded?.call(info); onJoinedGroupAdded?.call(info);
} }
///
void joinedGroupDeleted(GroupInfo info) { void joinedGroupDeleted(GroupInfo info) {
onJoinedGroupDeleted?.call(info); onJoinedGroupDeleted?.call(info);
} }

@ -1,3 +1,4 @@
///
class OnMsgSendProgressListener { class OnMsgSendProgressListener {
Function(String clientMsgID, int progress)? onProgress; Function(String clientMsgID, int progress)? onProgress;

@ -3,6 +3,7 @@ class OnOrganizationListener {
OnOrganizationListener({this.onOrganizationUpdated}); OnOrganizationListener({this.onOrganizationUpdated});
///
void organizationUpdated() { void organizationUpdated() {
onOrganizationUpdated?.call(); onOrganizationUpdated?.call();
} }

@ -6,6 +6,7 @@ class OnUserListener {
OnUserListener({this.onSelfInfoUpdated}); OnUserListener({this.onSelfInfoUpdated});
///
void selfInfoUpdated(UserInfo info) { void selfInfoUpdated(UserInfo info) {
onSelfInfoUpdated?.call(info); onSelfInfoUpdated?.call(info);
} }

@ -3,6 +3,7 @@ class OnWorkMomentsListener {
OnWorkMomentsListener({this.onRecvNewNotification}); OnWorkMomentsListener({this.onRecvNewNotification});
///
void recvNewNotification() { void recvNewNotification() {
onRecvNewNotification?.call(); onRecvNewNotification?.call();
} }

@ -7,14 +7,12 @@ class ConversationManager {
ConversationManager(this._channel); ConversationManager(this._channel);
/// Observe conversation changes
/// ///
Future setConversationListener(OnConversationListener listener) { Future setConversationListener(OnConversationListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setConversationListener', _buildParam({})); return _channel.invokeMethod('setConversationListener', _buildParam({}));
} }
/// Get all conversations
/// ///
Future<List<ConversationInfo>> getAllConversationList( Future<List<ConversationInfo>> getAllConversationList(
{String? operationID}) => {String? operationID}) =>
@ -27,8 +25,9 @@ class ConversationManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => ConversationInfo.fromJson(map))); Utils.toList(value, (map) => ConversationInfo.fromJson(map)));
/// Paging to get conversation
/// ///
/// [offset]
/// [count]
Future<List<ConversationInfo>> getConversationListSplit({ Future<List<ConversationInfo>> getConversationListSplit({
int offset = 0, int offset = 0,
int count = 20, int count = 20,
@ -45,12 +44,9 @@ class ConversationManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => ConversationInfo.fromJson(map))); Utils.toList(value, (map) => ConversationInfo.fromJson(map)));
/// Get a conversation, if it doesn't exist it will be created automatically ///
/// [sourceID] if it is a single chat, Its value is userID. if it is a group chat, Its value is groupID /// [sourceID] userIDGroupID
/// [sessionType] if it is a single chat, it value is 1. if it is a group chat, it value is 2 /// [sessionType] 12
///
/// [sourceID] IDID
/// [sessionType] 12
Future<ConversationInfo> getOneConversation({ Future<ConversationInfo> getOneConversation({
required String sourceID, required String sourceID,
required int sessionType, required int sessionType,
@ -67,8 +63,8 @@ class ConversationManager {
.then((value) => .then((value) =>
Utils.toObj(value, (map) => ConversationInfo.fromJson(map))); Utils.toObj(value, (map) => ConversationInfo.fromJson(map)));
/// Get conversation list by id list /// id获取多个会话
/// /// [conversationIDList] id列表
Future<List<ConversationInfo>> getMultipleConversation({ Future<List<ConversationInfo>> getMultipleConversation({
required List<String> conversationIDList, required List<String> conversationIDList,
String? operationID, String? operationID,
@ -83,8 +79,8 @@ class ConversationManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => ConversationInfo.fromJson(map))); Utils.toList(value, (map) => ConversationInfo.fromJson(map)));
/// Delete conversation by id /// id删除指定会话
/// /// [conversationID] id
Future deleteConversation({ Future deleteConversation({
required String conversationID, required String conversationID,
String? operationID, String? operationID,
@ -96,8 +92,9 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Set draft
/// 稿 /// 稿
/// [conversationID] id
/// [draftText] 稿
Future setConversationDraft({ Future setConversationDraft({
required String conversationID, required String conversationID,
required String draftText, required String draftText,
@ -111,8 +108,9 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Pinned conversation
/// ///
/// [conversationID] id
/// [isPinned] truefalse
Future pinConversation({ Future pinConversation({
required String conversationID, required String conversationID,
required bool isPinned, required bool isPinned,
@ -126,12 +124,8 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
// Future<dynamic> markSingleMessageHasRead({required String userID}) =>
// _channel.invokeMethod(
// 'markSingleMessageHasRead', _buildParam({'userID': userID}));
/// Mark group chat all messages as read
/// ///
/// [groupID] id
Future<dynamic> markGroupMessageHasRead({ Future<dynamic> markGroupMessageHasRead({
required String groupID, required String groupID,
String? operationID, String? operationID,
@ -143,7 +137,6 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Get the total number of unread messages
/// ///
Future<dynamic> getTotalUnreadMsgCount({ Future<dynamic> getTotalUnreadMsgCount({
String? operationID, String? operationID,
@ -154,9 +147,6 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Query conversation id
/// [sourceID] if it is a single chat, Its value is userID. if it is a group chat, Its value is groupID
/// [sessionType] if it is a single chat, it value is 1. if it is a group chat, it value is 2
/// id /// id
/// [sourceID] IDID /// [sourceID] IDID
/// [sessionType] 12 /// [sessionType] 12
@ -171,9 +161,8 @@ class ConversationManager {
"sessionType": sessionType, "sessionType": sessionType,
})); }));
/// Message Do Not Disturb
/// [status] 0: Normal. 1: Do not receive messages. 2: Do not notify when messages are received.
/// ///
/// [conversationIDList] id列表
/// [status] 012线线 /// [status] 012线线
Future<dynamic> setConversationRecvMessageOpt({ Future<dynamic> setConversationRecvMessageOpt({
required List<String> conversationIDList, required List<String> conversationIDList,
@ -188,9 +177,9 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Message Do Not Disturb
/// [{"conversationId":"single_13922222222","result":0}]
/// ///
/// [conversationIDList] id列表
/// [{"conversationId":"single_13922222222","result":0}]result值012线线
Future<List<dynamic>> getConversationRecvMessageOpt({ Future<List<dynamic>> getConversationRecvMessageOpt({
required List<String> conversationIDList, required List<String> conversationIDList,
String? operationID, String? operationID,
@ -204,8 +193,9 @@ class ConversationManager {
})) }))
.then((value) => Utils.toListMap(value)); .then((value) => Utils.toListMap(value));
/// burn after reading
/// ///
/// [conversationID] id
/// [isPrivate] truefalse
Future<dynamic> setOneConversationPrivateChat({ Future<dynamic> setOneConversationPrivateChat({
required String conversationID, required String conversationID,
required bool isPrivate, required bool isPrivate,
@ -219,8 +209,8 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Delete conversation from local and service ///
/// /// [conversationID] ID
Future<dynamic> deleteConversationFromLocalAndSvr({ Future<dynamic> deleteConversationFromLocalAndSvr({
required String conversationID, required String conversationID,
String? operationID, String? operationID,
@ -232,8 +222,7 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Delete conversation from local ///
///
Future<dynamic> deleteAllConversationFromLocal({ Future<dynamic> deleteAllConversationFromLocal({
String? operationID, String? operationID,
}) => }) =>
@ -243,8 +232,8 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Reset group converstaion at type /// [GroupAtType]
/// at标准位 /// [conversationID] id
Future<dynamic> resetConversationGroupAtType({ Future<dynamic> resetConversationGroupAtType({
required String conversationID, required String conversationID,
String? operationID, String? operationID,
@ -256,13 +245,10 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Get @ all member tag /// @
/// at所有人标识
Future<dynamic> getAtAllTag() => Future<dynamic> getAtAllTag() =>
_channel.invokeMethod('getAtAllTag', _buildParam({})); _channel.invokeMethod('getAtAllTag', _buildParam({}));
/// Global Do Not Disturb
/// [status] 0: Normal. 1: Do not receive messages. 2: Do not notify when messages are received.
/// ///
/// [status] 012线线 /// [status] 012线线
Future<dynamic> setGlobalRecvMessageOpt({ Future<dynamic> setGlobalRecvMessageOpt({
@ -276,7 +262,6 @@ class ConversationManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Custom sort for conversation list
/// ///
List<ConversationInfo> simpleSort(List<ConversationInfo> list) => list List<ConversationInfo> simpleSort(List<ConversationInfo> list) => list
..sort((a, b) { ..sort((a, b) {

@ -7,16 +7,14 @@ class FriendshipManager {
FriendshipManager(this._channel); FriendshipManager(this._channel);
/// Set up a friend relationship listener
/// ///
Future setFriendshipListener(OnFriendshipListener listener) { Future setFriendshipListener(OnFriendshipListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setFriendListener', _buildParam({})); return _channel.invokeMethod('setFriendListener', _buildParam({}));
} }
/// Get friend info by user id
/// ///
/// [uidList] userID集合 /// [uidList] userID集合
Future<List<UserInfo>> getFriendsInfo({ Future<List<UserInfo>> getFriendsInfo({
required List<String> uidList, required List<String> uidList,
String? operationID, String? operationID,
@ -30,10 +28,9 @@ class FriendshipManager {
})) }))
.then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v))); .then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v)));
/// Send an friend application
/// ///
/// [uid] ID /// [uid] ID
/// [reason] /// [reason]
Future<dynamic> addFriend({ Future<dynamic> addFriend({
required String uid, required String uid,
String? reason, String? reason,
@ -47,7 +44,6 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Get someone's request to add me as a friend
/// ///
Future<List<FriendApplicationInfo>> getRecvFriendApplicationList( Future<List<FriendApplicationInfo>> getRecvFriendApplicationList(
{String? operationID}) => {String? operationID}) =>
@ -60,7 +56,6 @@ class FriendshipManager {
.then((value) => .then((value) =>
Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v))); Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
/// Get friend requests from me
/// ///
Future<List<FriendApplicationInfo>> getSendFriendApplicationList( Future<List<FriendApplicationInfo>> getSendFriendApplicationList(
{String? operationID}) => {String? operationID}) =>
@ -73,8 +68,7 @@ class FriendshipManager {
.then((value) => .then((value) =>
Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v))); Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
/// Find all friends including those who have been added to the blacklist ///
///
Future<List<UserInfo>> getFriendList({String? operationID}) => _channel Future<List<UserInfo>> getFriendList({String? operationID}) => _channel
.invokeMethod( .invokeMethod(
'getFriendList', 'getFriendList',
@ -83,8 +77,7 @@ class FriendshipManager {
})) }))
.then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v))); .then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v)));
/// Find all friends including those who have been added to the blacklist ///
///
Future<List<dynamic>> getFriendListMap({String? operationID}) => _channel Future<List<dynamic>> getFriendListMap({String? operationID}) => _channel
.invokeMethod( .invokeMethod(
'getFriendList', 'getFriendList',
@ -93,7 +86,6 @@ class FriendshipManager {
})) }))
.then((value) => Utils.toListMap(value)); .then((value) => Utils.toListMap(value));
/// Modify friend remark name
/// ///
/// [uid] userID /// [uid] userID
/// [remark] /// [remark]
@ -110,9 +102,8 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Add friends to blacklist
/// ///
/// [uid]ID /// [uid] ID
Future<dynamic> addBlacklist({ Future<dynamic> addBlacklist({
required String uid, required String uid,
String? operationID, String? operationID,
@ -124,7 +115,6 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Find all blacklist
/// ///
Future<List<UserInfo>> getBlacklist({String? operationID}) => _channel Future<List<UserInfo>> getBlacklist({String? operationID}) => _channel
.invokeMethod( .invokeMethod(
@ -134,8 +124,8 @@ class FriendshipManager {
})) }))
.then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v))); .then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v)));
/// Remove from blacklist
/// ///
/// [uid] ID
Future<dynamic> removeBlacklist({ Future<dynamic> removeBlacklist({
required String uid, required String uid,
String? operationID, String? operationID,
@ -147,8 +137,8 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Determine if there is a friendship by userId
/// ///
/// [uidList] userID列表
Future<List<FriendshipInfo>> checkFriend({ Future<List<FriendshipInfo>> checkFriend({
required List<String> uidList, required List<String> uidList,
String? operationID, String? operationID,
@ -163,8 +153,8 @@ class FriendshipManager {
.then((value) => .then((value) =>
Utils.toList(value, (v) => FriendshipInfo.fromJson(v))); Utils.toList(value, (v) => FriendshipInfo.fromJson(v)));
/// Dissolve friendship from friend list
/// ///
/// [uid] ID
Future<dynamic> deleteFriend({ Future<dynamic> deleteFriend({
required String uid, required String uid,
String? operationID, String? operationID,
@ -176,8 +166,9 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Accept application of be friend
/// ///
/// [uid] ID
/// [handleMsg]
Future<dynamic> acceptFriendApplication({ Future<dynamic> acceptFriendApplication({
required String uid, required String uid,
String? handleMsg, String? handleMsg,
@ -191,8 +182,9 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Refuse application of be friend
/// ///
/// [uid] ID
/// [handleMsg]
Future<dynamic> refuseFriendApplication({ Future<dynamic> refuseFriendApplication({
required String uid, required String uid,
String? handleMsg, String? handleMsg,
@ -206,7 +198,6 @@ class FriendshipManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Search friends
/// ///
/// [keywordList] /// [keywordList]
/// [isSearchUserID] ID(false)false /// [isSearchUserID] ID(false)false

@ -7,15 +7,15 @@ class GroupManager {
GroupManager(this._channel); GroupManager(this._channel);
/// Set up group relationship monitoring
/// ///
Future setGroupListener(OnGroupListener listener) { Future setGroupListener(OnGroupListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setGroupListener', _buildParam({})); return _channel.invokeMethod('setGroupListener', _buildParam({}));
} }
/// Invite friends into the group
/// ///
/// [groupId] ID
/// [uidList] ID列表
Future<List<GroupInviteResult>> inviteUserToGroup({ Future<List<GroupInviteResult>> inviteUserToGroup({
required String groupId, required String groupId,
required List<String> uidList, required List<String> uidList,
@ -34,8 +34,10 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupInviteResult.fromJson(map))); Utils.toList(value, (map) => GroupInviteResult.fromJson(map)));
/// Remove member from group
/// ///
/// [groupId] ID
/// [uidList] ID列表
/// [reason]
Future<List<GroupInviteResult>> kickGroupMember({ Future<List<GroupInviteResult>> kickGroupMember({
required String groupId, required String groupId,
required List<String> uidList, required List<String> uidList,
@ -54,8 +56,9 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupInviteResult.fromJson(map))); Utils.toList(value, (map) => GroupInviteResult.fromJson(map)));
/// Get group member's info
/// ///
/// [groupId] ID
/// [uidList] ID列表
Future<List<GroupMembersInfo>> getGroupMembersInfo({ Future<List<GroupMembersInfo>> getGroupMembersInfo({
required String groupId, required String groupId,
required List<String> uidList, required List<String> uidList,
@ -72,10 +75,9 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupMembersInfo.fromJson(map))); Utils.toList(value, (map) => GroupMembersInfo.fromJson(map)));
/// Get the list of group members
/// ///
/// [groupId] ID /// [groupId] ID
/// [filter] 1, 230 /// [filter] 1, 230
/// [offset] /// [offset]
/// [count] /// [count]
Future<List<GroupMembersInfo>> getGroupMemberList({ Future<List<GroupMembersInfo>> getGroupMemberList({
@ -98,7 +100,6 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupMembersInfo.fromJson(map))); Utils.toList(value, (map) => GroupMembersInfo.fromJson(map)));
/// Get the list of group members
/// ///
/// [groupId] ID /// [groupId] ID
/// [filter] 1, 230 /// [filter] 1, 230
@ -123,7 +124,6 @@ class GroupManager {
})) }))
.then((value) => Utils.toListMap(value)); .then((value) => Utils.toListMap(value));
/// Find all groups you have joined
/// ///
Future<List<GroupInfo>> getJoinedGroupList({String? operationID}) => _channel Future<List<GroupInfo>> getJoinedGroupList({String? operationID}) => _channel
.invokeMethod( .invokeMethod(
@ -133,7 +133,6 @@ class GroupManager {
})) }))
.then((value) => Utils.toList(value, (map) => GroupInfo.fromJson(map))); .then((value) => Utils.toList(value, (map) => GroupInfo.fromJson(map)));
/// Find all groups you have joined
/// ///
Future<List<dynamic>> getJoinedGroupListMap({String? operationID}) => _channel Future<List<dynamic>> getJoinedGroupListMap({String? operationID}) => _channel
.invokeMethod( .invokeMethod(
@ -143,8 +142,8 @@ class GroupManager {
})) }))
.then((value) => Utils.toListMap(value)); .then((value) => Utils.toListMap(value));
/// Check if you are a member of the group
/// ///
/// [gid] ID
Future<bool> isJoinedGroup({ Future<bool> isJoinedGroup({
required String gid, required String gid,
String? operationID, String? operationID,
@ -153,14 +152,14 @@ class GroupManager {
operationID: Utils.checkOperationID(operationID), operationID: Utils.checkOperationID(operationID),
).then((list) => list.where((e) => e.groupID == gid).length > 0); ).then((list) => list.where((e) => e.groupID == gid).length > 0);
/// Create a group
/// ///
/// [groupName] /// [groupName]
/// [notification] /// [notification]
/// [introduction] /// [introduction]
/// [faceUrl] /// [faceUrl]
/// [groupType]
/// [ex] /// [ex]
/// [list] /// [list] [GroupRoleLevel]
Future<GroupInfo> createGroup({ Future<GroupInfo> createGroup({
String? groupName, String? groupName,
String? notification, String? notification,
@ -189,7 +188,6 @@ class GroupManager {
.then( .then(
(value) => Utils.toObj(value, (map) => GroupInfo.fromJson(map))); (value) => Utils.toObj(value, (map) => GroupInfo.fromJson(map)));
/// Edit group information
/// ///
/// [groupID] ID /// [groupID] ID
/// [groupName] /// [groupName]
@ -197,6 +195,7 @@ class GroupManager {
/// [introduction] /// [introduction]
/// [faceUrl] /// [faceUrl]
/// [ex] /// [ex]
/// [needVerification] [GroupVerification]
Future<dynamic> setGroupInfo({ Future<dynamic> setGroupInfo({
required String groupID, required String groupID,
String? groupName, String? groupName,
@ -204,6 +203,7 @@ class GroupManager {
String? introduction, String? introduction,
String? faceUrl, String? faceUrl,
String? ex, String? ex,
int needVerification = 0,
String? operationID, String? operationID,
}) => }) =>
_channel.invokeMethod( _channel.invokeMethod(
@ -217,12 +217,13 @@ class GroupManager {
"introduction": introduction, "introduction": introduction,
"faceURL": faceUrl, "faceURL": faceUrl,
"ex": ex, "ex": ex,
"needVerification": needVerification,
}, },
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Find group information by group id
/// ///
/// [gidList] ID列表
Future<List<GroupInfo>> getGroupsInfo({ Future<List<GroupInfo>> getGroupsInfo({
required List<String> gidList, required List<String> gidList,
String? operationID, String? operationID,
@ -237,7 +238,6 @@ class GroupManager {
.then( .then(
(value) => Utils.toList(value, (map) => GroupInfo.fromJson(map))); (value) => Utils.toList(value, (map) => GroupInfo.fromJson(map)));
/// Apply to join the group
/// / /// /
Future<dynamic> joinGroup({ Future<dynamic> joinGroup({
required String gid, required String gid,
@ -252,7 +252,6 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Leave group
/// 退 /// 退
Future<dynamic> quitGroup({ Future<dynamic> quitGroup({
required String gid, required String gid,
@ -265,8 +264,9 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Give group permissions to others
/// ///
/// [gid] ID
/// [uid] ID
Future<dynamic> transferGroupOwner({ Future<dynamic> transferGroupOwner({
required String gid, required String gid,
required String uid, required String uid,
@ -280,7 +280,6 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// As the group owner or administrator, the group member's application to join the group received
/// ///
Future<List<GroupApplicationInfo>> getRecvGroupApplicationList( Future<List<GroupApplicationInfo>> getRecvGroupApplicationList(
{String? operationID}) => {String? operationID}) =>
@ -293,7 +292,6 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map))); Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
/// Get the record of the group membership application issued by yourself
/// ///
Future<List<GroupApplicationInfo>> getSendGroupApplicationList( Future<List<GroupApplicationInfo>> getSendGroupApplicationList(
{String? operationID}) => {String? operationID}) =>
@ -306,9 +304,10 @@ class GroupManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map))); Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
/// Accept group application
/// ///
/// // /// //
/// [gid] id
/// [uid] ID
Future<dynamic> acceptGroupApplication({ Future<dynamic> acceptGroupApplication({
required String gid, required String gid,
required String uid, required String uid,
@ -324,9 +323,11 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Refuse group application
/// ///
/// // /// //
/// [gid] id
/// [uid] ID
/// [handleMsg]
Future<dynamic> refuseGroupApplication({ Future<dynamic> refuseGroupApplication({
required String gid, required String gid,
required String uid, required String uid,
@ -342,8 +343,8 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Dissmiss group
/// ///
/// [groupID] ID
Future<dynamic> dismissGroup({ Future<dynamic> dismissGroup({
required String groupID, required String groupID,
String? operationID, String? operationID,
@ -355,7 +356,6 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Enable group mute
/// ///
/// [groupID] ID /// [groupID] ID
/// [mute] truefalse /// [mute] truefalse
@ -372,11 +372,10 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Mute group members
/// ///
/// [groupID] ID /// [groupID] ID
/// [userID] ID /// [userID] ID
/// [seconds] s0 /// [seconds] s0
Future<dynamic> changeGroupMemberMute({ Future<dynamic> changeGroupMemberMute({
required String groupID, required String groupID,
required String userID, required String userID,
@ -392,7 +391,6 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Set group user nickname
/// ///
/// [groupID] ID /// [groupID] ID
/// [userID] ID /// [userID] ID
@ -412,7 +410,6 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Search group
/// ///
/// [keywordList] /// [keywordList]
/// [isSearchGroupID] ID(false)false /// [isSearchGroupID] ID(false)false
@ -437,11 +434,10 @@ class GroupManager {
.then( .then(
(value) => Utils.toList(value, (map) => GroupInfo.fromJson(map))); (value) => Utils.toList(value, (map) => GroupInfo.fromJson(map)));
/// Set group user role
/// ///
/// [groupID] ID /// [groupID] ID
/// [userID] ID /// [userID] ID
/// [roleLevel] /// [roleLevel] [GroupRoleLevel]
Future<dynamic> setGroupMemberRoleLevel({ Future<dynamic> setGroupMemberRoleLevel({
required String groupID, required String groupID,
required String userID, required String userID,
@ -457,8 +453,7 @@ class GroupManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// Get the list of group members ///
///
/// [groupID] ID /// [groupID] ID
/// [joinTimeBegin] /// [joinTimeBegin]
/// [joinTimeEnd] /// [joinTimeEnd]

@ -289,23 +289,13 @@ class IMManager {
}); });
} }
/// Initialize SDK
///
/// [platform] platform number [IMPlatform]
/// [apiAddr] api server ip address
/// [wsAddr] webSocket ip address
/// [dataDir] data storage directory
/// [objectStorage] storage object: cos/minio
/// [logLevel] log level: 1-not print
///
/// SDK /// SDK
///
/// [platform] [IMPlatform] /// [platform] [IMPlatform]
/// [apiAddr] SDK api地址 /// [apiAddr] SDK api地址
/// [wsAddr] SDK websocket地址 /// [wsAddr] SDK websocket地址
/// [dataDir] SDK数据库存储目录 /// [dataDir] SDK数据库存储目录
/// [objectStorage] cos/minio /// [objectStorage] cos/minio
/// [logLevel] 1- /// [logLevel] 1
Future<dynamic> initSDK({ Future<dynamic> initSDK({
required int platform, required int platform,
required String apiAddr, required String apiAddr,
@ -338,10 +328,9 @@ class IMManager {
return _channel.invokeMethod('unInitSDK', _buildParam({})); return _channel.invokeMethod('unInitSDK', _buildParam({}));
} }
/// Login sdk
/// ///
/// [uid]id /// [uid] id
/// [token]token /// [token] token
Future<UserInfo> login({ Future<UserInfo> login({
required String uid, required String uid,
required String token, required String token,
@ -362,7 +351,6 @@ class IMManager {
return uInfo; return uInfo;
} }
/// Logout sdk
/// ///
Future<dynamic> logout({String? operationID}) async { Future<dynamic> logout({String? operationID}) async {
var value = await _channel.invokeMethod( var value = await _channel.invokeMethod(
@ -375,19 +363,16 @@ class IMManager {
return value; return value;
} }
/// ///
Future<int?> getLoginStatus() => Future<int?> getLoginStatus() =>
_channel.invokeMethod<int>('getLoginStatus', _buildParam({})); _channel.invokeMethod<int>('getLoginStatus', _buildParam({}));
/// Current user id
/// id /// id
Future<String> getLoginUserID() async => uid; Future<String> getLoginUserID() async => uid;
/// Current user info
/// ///
Future<UserInfo> getLoginUserInfo() async => uInfo; Future<UserInfo> getLoginUserInfo() async => uInfo;
/// wakeup
/// ///
Future wakeUp({String? operationID}) => _channel.invokeMethod( Future wakeUp({String? operationID}) => _channel.invokeMethod(
'wakeUp', 'wakeUp',
@ -395,7 +380,6 @@ class IMManager {
'operationID': Utils.checkOperationID(operationID), 'operationID': Utils.checkOperationID(operationID),
})); }));
/// upload image to server
/// ///
/// [path] /// [path]
/// [token] im token /// [token] im token

@ -10,7 +10,6 @@ class MessageManager {
MessageManager(this._channel); MessageManager(this._channel);
/// Set a message listener
/// ///
Future setAdvancedMsgListener(OnAdvancedMsgListener listener) { Future setAdvancedMsgListener(OnAdvancedMsgListener listener) {
this.msgListener = listener; this.msgListener = listener;
@ -22,18 +21,16 @@ class MessageManager {
})); }));
} }
/// Set up message sending progress monitoring
/// ///
void setMsgSendProgressListener(OnMsgSendProgressListener listener) { void setMsgSendProgressListener(OnMsgSendProgressListener listener) {
msgSendProgressListener = listener; msgSendProgressListener = listener;
} }
/// Send a message to user or to group
/// [userID] receiver's user ID
/// ///
/// [userID]id /// [message]
/// [groupID]id /// [userID] id
/// [offlinePushInfo]线 /// [groupID] id
/// [offlinePushInfo] 线
Future<Message> sendMessage({ Future<Message> sendMessage({
required Message message, required Message message,
required OfflinePushInfo offlinePushInfo, required OfflinePushInfo offlinePushInfo,
@ -53,7 +50,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Find all history message
/// (startMsg为节点) /// (startMsg为节点)
/// [userID] id /// [userID] id
/// [conversationID] id /// [conversationID] id
@ -81,8 +77,8 @@ class MessageManager {
})) }))
.then((value) => Utils.toList(value, (map) => Message.fromJson(map))); .then((value) => Utils.toList(value, (map) => Message.fromJson(map)));
/// Revoke the sent information
/// ///
/// [message]
Future revokeMessage({ Future revokeMessage({
required Message message, required Message message,
String? operationID, String? operationID,
@ -94,8 +90,8 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
}))); })));
/// Delete message
/// ///
/// [message]
Future deleteMessageFromLocalStorage({ Future deleteMessageFromLocalStorage({
required Message message, required Message message,
String? operationID, String? operationID,
@ -107,12 +103,10 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
}))); })));
///
// Future deleteMessages({required List<Message> msgList}) =>
// _channel.invokeMethod('deleteMessages',
// _buildParam({"msgList": msgList.map((e) => e.toJson()).toList()}));
/// ///
/// [receiverID] id
/// [senderID] id
/// [message]
Future<Message> insertSingleMessageToLocalStorage({ Future<Message> insertSingleMessageToLocalStorage({
String? receiverID, String? receiverID,
String? senderID, String? senderID,
@ -131,6 +125,9 @@ class MessageManager {
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// ///
/// [groupID] id
/// [senderID] id
/// [message]
Future<Message> insertGroupMessageToLocalStorage({ Future<Message> insertGroupMessageToLocalStorage({
String? groupID, String? groupID,
String? senderID, String? senderID,
@ -148,8 +145,9 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Mark c2c message as read /// c2c单条消息已读
/// c2c消息已读 /// [userID] userID
/// [messageIDList] clientMsgID集合
Future markC2CMessageAsRead({ Future markC2CMessageAsRead({
required String userID, required String userID,
required List<String> messageIDList, required List<String> messageIDList,
@ -163,8 +161,9 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Mark group message as read
/// ///
/// [groupID] id
/// [messageIDList] clientMsgID集合
Future markGroupMessageAsRead({ Future markGroupMessageAsRead({
required String groupID, required String groupID,
required List<String> messageIDList, required List<String> messageIDList,
@ -178,7 +177,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Typing
/// ///
/// [msgTip] /// [msgTip]
Future typingStatusUpdate({ Future typingStatusUpdate({
@ -194,7 +192,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Create text message
/// ///
Future<Message> createTextMessage({ Future<Message> createTextMessage({
required String text, required String text,
@ -209,7 +206,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create @ message
/// @ /// @
/// [text] /// [text]
/// [atUserIDList] @userID集合 /// [atUserIDList] @userID集合
@ -235,8 +231,8 @@ class MessageManager {
) )
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create picture message
/// ///
/// [imagePath]
Future<Message> createImageMessage({ Future<Message> createImageMessage({
required String imagePath, required String imagePath,
String? operationID, String? operationID,
@ -251,7 +247,6 @@ class MessageManager {
) )
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create picture message
/// ///
/// [imagePath] /// [imagePath]
Future<Message> createImageMessageFromFullPath({ Future<Message> createImageMessageFromFullPath({
@ -268,8 +263,9 @@ class MessageManager {
) )
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create sound message
/// ///
/// [soundPath]
/// [duration] s
Future<Message> createSoundMessage({ Future<Message> createSoundMessage({
required String soundPath, required String soundPath,
required int duration, required int duration,
@ -286,7 +282,6 @@ class MessageManager {
) )
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create sound message
/// ///
/// [soundPath] /// [soundPath]
/// [duration] s /// [duration] s
@ -306,8 +301,11 @@ class MessageManager {
) )
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create video message
/// ///
/// [videoPath]
/// [videoType] mime类型
/// [duration] s
/// [snapshotPath]
Future<Message> createVideoMessage({ Future<Message> createVideoMessage({
required String videoPath, required String videoPath,
required String videoType, required String videoType,
@ -327,7 +325,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create video message
/// ///
/// [videoPath] /// [videoPath]
/// [videoType] mime类型 /// [videoType] mime类型
@ -352,8 +349,9 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create file message
/// ///
/// [filePath]
/// [fileName]
Future<Message> createFileMessage({ Future<Message> createFileMessage({
required String filePath, required String filePath,
required String fileName, required String fileName,
@ -370,7 +368,6 @@ class MessageManager {
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
} }
/// Create file message
/// ///
/// [filePath] /// [filePath]
/// [fileName] /// [fileName]
@ -389,7 +386,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create merger message
/// ///
/// [messageList] /// [messageList]
/// [title] /// [title]
@ -411,7 +407,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create forward message
/// ///
/// [message] /// [message]
Future<Message> createForwardMessage({ Future<Message> createForwardMessage({
@ -428,7 +423,6 @@ class MessageManager {
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
} }
/// Create location message
/// ///
/// [latitude] /// [latitude]
/// [longitude] /// [longitude]
@ -450,8 +444,10 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create custom message
/// ///
/// [data]
/// [extension]
/// [description]
Future<Message> createCustomMessage({ Future<Message> createCustomMessage({
required String data, required String data,
required String extension, required String extension,
@ -469,7 +465,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create quote message
/// ///
/// [text] /// [text]
/// [quoteMsg] /// [quoteMsg]
@ -488,8 +483,8 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create card message
/// ///
/// [data]
Future<Message> createCardMessage({ Future<Message> createCardMessage({
required Map<String, dynamic> data, required Map<String, dynamic> data,
String? operationID, String? operationID,
@ -503,9 +498,6 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Create custom emoji message
/// [index] The position of the emoji, such as the position emoji
/// [data] Other data, such as url expressions
/// ///
/// [index] index匹配 /// [index] index匹配
/// [data] url表情使url显示 /// [data] url表情使url显示
@ -524,8 +516,8 @@ class MessageManager {
})) }))
.then((value) => Utils.toObj(value, (map) => Message.fromJson(map))); .then((value) => Utils.toObj(value, (map) => Message.fromJson(map)));
/// Clear all c2c history message
/// ///
/// [uid] id
Future<dynamic> clearC2CHistoryMessage({ Future<dynamic> clearC2CHistoryMessage({
required String uid, required String uid,
String? operationID, String? operationID,
@ -537,8 +529,8 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Clear all group history
/// ///
/// [gid] id
Future<dynamic> clearGroupHistoryMessage({ Future<dynamic> clearGroupHistoryMessage({
required String gid, required String gid,
String? operationID, String? operationID,
@ -550,17 +542,16 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Search local message
/// ///
/// [conversationID] null /// [conversationID] null
/// [keywordList] /// [keywordList]
/// [keywordListMatchType]12 /// [keywordListMatchType] 12
/// [senderUserIDList]uid列表 /// [senderUserIDList] uid列表
/// [messageTypeList] /// [messageTypeList]
/// [searchTimePosition]0UTC /// [searchTimePosition] 0UTC
/// [searchTimePeriod]024x60x60代表过去一天 /// [searchTimePeriod] 024x60x60代表过去一天
/// [pageIndex] /// [pageIndex]
/// [count] /// [count]
Future<SearchResult> searchLocalMessages({ Future<SearchResult> searchLocalMessages({
String? conversationID, String? conversationID,
List<String> keywordList = const [], List<String> keywordList = const [],
@ -593,8 +584,8 @@ class MessageManager {
.then((value) => .then((value) =>
Utils.toObj(value, (map) => SearchResult.fromJson(map))); Utils.toObj(value, (map) => SearchResult.fromJson(map)));
/// Delete message from local and service
/// ///
/// [message]
Future<dynamic> deleteMessageFromLocalAndSvr({ Future<dynamic> deleteMessageFromLocalAndSvr({
required Message message, required Message message,
String? operationID, String? operationID,
@ -606,7 +597,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
}))); })));
/// Delete all message from local
/// ///
Future<dynamic> deleteAllMsgFromLocal({ Future<dynamic> deleteAllMsgFromLocal({
String? operationID, String? operationID,
@ -617,7 +607,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Delete all message from service
/// ///
Future<dynamic> deleteAllMsgFromLocalAndSvr({ Future<dynamic> deleteAllMsgFromLocalAndSvr({
String? operationID, String? operationID,
@ -628,7 +617,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Mark conversation message as read
/// ///
/// [conversationID] ID /// [conversationID] ID
/// [messageIDList] clientMsgID /// [messageIDList] clientMsgID
@ -645,8 +633,8 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Clear all c2c history message
/// ///
/// [uid] userID
Future<dynamic> clearC2CHistoryMessageFromLocalAndSvr({ Future<dynamic> clearC2CHistoryMessageFromLocalAndSvr({
required String uid, required String uid,
String? operationID, String? operationID,
@ -658,8 +646,8 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Clear all group history
/// ///
/// [gid] id
Future<dynamic> clearGroupHistoryMessageFromLocalAndSvr({ Future<dynamic> clearGroupHistoryMessageFromLocalAndSvr({
required String gid, required String gid,
String? operationID, String? operationID,
@ -671,7 +659,6 @@ class MessageManager {
"operationID": Utils.checkOperationID(operationID), "operationID": Utils.checkOperationID(operationID),
})); }));
/// Find all history message
/// (startMsg为节点) /// (startMsg为节点)
/// [userID] id /// [userID] id
/// [conversationID] id /// [conversationID] id

@ -7,15 +7,16 @@ class OrganizationManager {
OrganizationManager(this._channel); OrganizationManager(this._channel);
/// Observe organization info changes
/// ///
Future setOrganizationListener(OnOrganizationListener listener) { Future setOrganizationListener(OnOrganizationListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setOrganizationListener', _buildParam({})); return _channel.invokeMethod('setOrganizationListener', _buildParam({}));
} }
/// Query sub department ///
/// /// [departmentID] id
/// [offset]
/// [count]
Future<List<DeptInfo>> getSubDept({ Future<List<DeptInfo>> getSubDept({
required String departmentID, required String departmentID,
int offset = 0, int offset = 0,
@ -33,8 +34,10 @@ class OrganizationManager {
})) }))
.then((value) => Utils.toList(value, (v) => DeptInfo.fromJson(v))); .then((value) => Utils.toList(value, (v) => DeptInfo.fromJson(v)));
/// Get member under a department ///
/// /// [departmentID] id
/// [offset]
/// [count]
Future<List<DeptMemberInfo>> getDeptMember({ Future<List<DeptMemberInfo>> getDeptMember({
required String departmentID, required String departmentID,
int offset = 0, int offset = 0,
@ -53,8 +56,8 @@ class OrganizationManager {
.then((value) => .then((value) =>
Utils.toList(value, (v) => DeptMemberInfo.fromJson(v))); Utils.toList(value, (v) => DeptMemberInfo.fromJson(v)));
/// Get member's department
/// ///
/// [userID] ID
Future<List<UserInDept>> getUserInDept({ Future<List<UserInDept>> getUserInDept({
required String userID, required String userID,
String? operationID, String? operationID,
@ -68,8 +71,8 @@ class OrganizationManager {
})) }))
.then((value) => Utils.toList(value, (v) => UserInDept.fromJson(v))); .then((value) => Utils.toList(value, (v) => UserInDept.fromJson(v)));
/// Get the sub-departments and employees under the department
/// ///
/// [departmentID] id
Future<DeptMemberAndSubDept> getDeptMemberAndSubDept({ Future<DeptMemberAndSubDept> getDeptMemberAndSubDept({
required String departmentID, required String departmentID,
// int departmentOffset = 0, // int departmentOffset = 0,
@ -92,8 +95,8 @@ class OrganizationManager {
.then((value) => .then((value) =>
Utils.toObj(value, (v) => DeptMemberAndSubDept.fromJson(v))); Utils.toObj(value, (v) => DeptMemberAndSubDept.fromJson(v)));
/// Query department info
/// ///
/// [departmentID] ID
Future<DeptInfo> getDeptInfo({ Future<DeptInfo> getDeptInfo({
required String departmentID, required String departmentID,
String? operationID, String? operationID,
@ -107,8 +110,17 @@ class OrganizationManager {
})) }))
.then((value) => Utils.toObj(value, (v) => DeptInfo.fromJson(v))); .then((value) => Utils.toObj(value, (v) => DeptInfo.fromJson(v)));
/// Search
/// ///
/// [keyWord]
/// [isSearchUserName]
/// [isSearchEnglishName]
/// [isSearchPosition]
/// [isSearchUserID] ID
/// [isSearchMobile]
/// [isSearchEmail]
/// [isSearchTelephone]
/// [offset]
/// [count]
Future<OrganizationSearchResult> searchOrganization({ Future<OrganizationSearchResult> searchOrganization({
required String keyWord, required String keyWord,
bool isSearchUserName = false, bool isSearchUserName = false,

@ -15,6 +15,7 @@ class SignalingManager {
} }
/// ///
/// [info] [SignalingInfo]
Future<SignalingCertificate> signalingInvite({ Future<SignalingCertificate> signalingInvite({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,
@ -30,6 +31,7 @@ class SignalingManager {
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map))); Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
/// ///
/// [info] [SignalingInfo]
Future<SignalingCertificate> signalingInviteInGroup({ Future<SignalingCertificate> signalingInviteInGroup({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,
@ -45,6 +47,7 @@ class SignalingManager {
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map))); Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
/// ///
/// [info] [SignalingInfo]
Future<SignalingCertificate> signalingAccept({ Future<SignalingCertificate> signalingAccept({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,
@ -60,6 +63,7 @@ class SignalingManager {
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map))); Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
/// ///
/// [info] [SignalingInfo]
Future<dynamic> signalingReject({ Future<dynamic> signalingReject({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,
@ -72,6 +76,7 @@ class SignalingManager {
})); }));
/// ///
/// [info] [SignalingInfo]
Future<dynamic> signalingCancel({ Future<dynamic> signalingCancel({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,
@ -84,6 +89,7 @@ class SignalingManager {
})); }));
/// ///
/// [info] [SignalingInfo]
Future<dynamic> signalingHungUp({ Future<dynamic> signalingHungUp({
required SignalingInfo info, required SignalingInfo info,
String? operationID, String? operationID,

@ -7,15 +7,14 @@ class UserManager {
UserManager(this._channel); UserManager(this._channel);
/// Observe user info changes
/// ///
Future setUserListener(OnUserListener listener) { Future setUserListener(OnUserListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setUserListener', _buildParam({})); return _channel.invokeMethod('setUserListener', _buildParam({}));
} }
/// Query user information
/// ///
/// [uidList] ID列表
Future<List<UserInfo>> getUsersInfo({ Future<List<UserInfo>> getUsersInfo({
required List<String> uidList, required List<String> uidList,
String? operationID, String? operationID,
@ -29,7 +28,6 @@ class UserManager {
})) }))
.then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v))); .then((value) => Utils.toList(value, (v) => UserInfo.fromJson(v)));
/// Get the information of the currently logged in user
/// ///
Future<UserInfo> getSelfUserInfo({ Future<UserInfo> getSelfUserInfo({
String? operationID, String? operationID,
@ -42,8 +40,15 @@ class UserManager {
})) }))
.then((value) => Utils.toObj(value, (map) => UserInfo.fromJson(map))); .then((value) => Utils.toObj(value, (map) => UserInfo.fromJson(map)));
/// Modify current user info
/// ///
/// [nickname]
/// [faceURL]
/// [gender]
/// [appMangerLevel]
/// [phoneNumber]
/// [birth]
/// [email]
/// [ex]
Future<String?> setSelfInfo({ Future<String?> setSelfInfo({
String? nickname, String? nickname,
String? faceURL, String? faceURL,

@ -7,13 +7,13 @@ class WorkMomentsManager {
WorkMomentsManager(this._channel); WorkMomentsManager(this._channel);
/// Observe work moments changes ///
Future setWorkMomentsListener(OnWorkMomentsListener listener) { Future setWorkMomentsListener(OnWorkMomentsListener listener) {
this.listener = listener; this.listener = listener;
return _channel.invokeMethod('setWorkMomentsListener', _buildParam({})); return _channel.invokeMethod('setWorkMomentsListener', _buildParam({}));
} }
/// Get work moments unread count ///
Future<int> getWorkMomentsUnReadCount({ Future<int> getWorkMomentsUnReadCount({
String? operationID, String? operationID,
}) => }) =>
@ -25,7 +25,9 @@ class WorkMomentsManager {
})) }))
.then((value) => Utils.toObj(value, (map) => map['unreadCount'])); .then((value) => Utils.toObj(value, (map) => map['unreadCount']));
/// Get work moments notification list ///
/// [offset]
/// [count]
Future<List<WorkMomentsInfo>> getWorkMomentsNotification({ Future<List<WorkMomentsInfo>> getWorkMomentsNotification({
required int offset, required int offset,
required int count, required int count,
@ -42,7 +44,7 @@ class WorkMomentsManager {
.then((value) => .then((value) =>
Utils.toList(value, (map) => WorkMomentsInfo.fromJson(map))); Utils.toList(value, (map) => WorkMomentsInfo.fromJson(map)));
/// Clear work moments notification ///
Future clearWorkMomentsNotification({ Future clearWorkMomentsNotification({
String? operationID, String? operationID,
}) => }) =>

@ -3,24 +3,55 @@ import 'dart:convert';
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
class ConversationInfo { class ConversationInfo {
/// ID
String conversationID; String conversationID;
/// [ConversationType] /// [ConversationType]
int? conversationType; int? conversationType;
/// userID
String? userID; String? userID;
/// groupID
String? groupID; String? groupID;
///
String? showName; String? showName;
///
String? faceURL; String? faceURL;
/// 012线线
int? recvMsgOpt; int? recvMsgOpt;
///
int? unreadCount; int? unreadCount;
/// [GroupAtType]@@
int? groupAtType; int? groupAtType;
///
Message? latestMsg; Message? latestMsg;
///
int? latestMsgSendTime; int? latestMsgSendTime;
/// 稿
String? draftText; String? draftText;
/// 稿
int? draftTextTime; int? draftTextTime;
///
bool? isPinned; bool? isPinned;
///
bool? isPrivateChat; bool? isPrivateChat;
///
String? ext; String? ext;
/// 退true
bool? isNotInGroup; bool? isNotInGroup;
ConversationInfo({ ConversationInfo({

@ -1,19 +1,46 @@
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
///
class GroupInfo { class GroupInfo {
/// ID
String groupID; String groupID;
///
String? groupName; String? groupName;
///
String? notification; String? notification;
///
String? introduction; String? introduction;
///
String? faceURL; String? faceURL;
/// ID
String? ownerUserID; String? ownerUserID;
///
int? createTime; int? createTime;
///
int? memberCount; int? memberCount;
/// ok = 0 blocked = 1 Dismissed = 2 Muted = 3 /// 0123
int? status; int? status;
/// ID
String? creatorUserID; String? creatorUserID;
///
int? groupType; int? groupType;
///
String? ex; String? ex;
/// [GroupVerification]
int? needVerification;
GroupInfo({ GroupInfo({
required this.groupID, required this.groupID,
this.groupName, this.groupName,
@ -27,6 +54,7 @@ class GroupInfo {
this.creatorUserID, this.creatorUserID,
this.groupType, this.groupType,
this.ex, this.ex,
this.needVerification,
}); });
GroupInfo.fromJson(Map<String, dynamic> json) : groupID = json['groupID'] { GroupInfo.fromJson(Map<String, dynamic> json) : groupID = json['groupID'] {
@ -42,6 +70,7 @@ class GroupInfo {
creatorUserID = json['creatorUserID']; creatorUserID = json['creatorUserID'];
groupType = json['groupType']; groupType = json['groupType'];
ex = json['ex']; ex = json['ex'];
needVerification = json['needVerification'];
} }
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
@ -58,20 +87,41 @@ class GroupInfo {
data['creatorUserID'] = this.creatorUserID; data['creatorUserID'] = this.creatorUserID;
data['groupType'] = this.groupType; data['groupType'] = this.groupType;
data['ex'] = this.ex; data['ex'] = this.ex;
data['needVerification'] = this.needVerification;
return data; return data;
} }
} }
///
class GroupMembersInfo { class GroupMembersInfo {
/// id
String? groupID; String? groupID;
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? faceURL; String? faceURL;
/// [GroupRoleLevel]
int? roleLevel; int? roleLevel;
///
int? joinTime; int? joinTime;
///
int? joinSource; int? joinSource;
/// id
String? operatorUserID; String? operatorUserID;
String? ext;
///
String? ex;
/// s
int? muteEndTime; int? muteEndTime;
int? appMangerLevel; int? appMangerLevel;
@ -82,7 +132,7 @@ class GroupMembersInfo {
this.joinTime, this.joinTime,
this.nickname, this.nickname,
this.faceURL, this.faceURL,
this.ext, this.ex,
this.joinSource, this.joinSource,
this.operatorUserID, this.operatorUserID,
this.muteEndTime, this.muteEndTime,
@ -96,7 +146,7 @@ class GroupMembersInfo {
joinTime = json['joinTime']; joinTime = json['joinTime'];
nickname = json['nickname']; nickname = json['nickname'];
faceURL = json['faceURL']; faceURL = json['faceURL'];
ext = json['ext']; ex = json['ex'];
joinSource = json['joinSource']; joinSource = json['joinSource'];
operatorUserID = json['operatorUserID']; operatorUserID = json['operatorUserID'];
muteEndTime = json['muteEndTime']; muteEndTime = json['muteEndTime'];
@ -111,7 +161,7 @@ class GroupMembersInfo {
data['joinTime'] = this.joinTime; data['joinTime'] = this.joinTime;
data['nickname'] = this.nickname; data['nickname'] = this.nickname;
data['faceURL'] = this.faceURL; data['faceURL'] = this.faceURL;
data['ext'] = this.ext; data['ex'] = this.ex;
data['joinSource'] = this.joinSource; data['joinSource'] = this.joinSource;
data['operatorUserID'] = this.operatorUserID; data['operatorUserID'] = this.operatorUserID;
data['muteEndTime'] = this.muteEndTime; data['muteEndTime'] = this.muteEndTime;
@ -120,11 +170,12 @@ class GroupMembersInfo {
} }
} }
///
class GroupMemberRole { class GroupMemberRole {
/// ID
String? userID; String? userID;
/// 1 ordinary member, 2 group owners, 3 administrators /// [GroupRoleLevel] 1, 23
/// 1, 23
int? roleLevel; int? roleLevel;
GroupMemberRole({this.userID, this.roleLevel = 1}); GroupMemberRole({this.userID, this.roleLevel = 1});
@ -142,31 +193,72 @@ class GroupMemberRole {
} }
} }
///
class GroupApplicationInfo { class GroupApplicationInfo {
/// ID
String? groupID; String? groupID;
///
String? groupName; String? groupName;
///
String? notification; String? notification;
///
String? introduction; String? introduction;
///
String? groupFaceURL; String? groupFaceURL;
///
int? createTime; int? createTime;
///
int? status; int? status;
/// id
String? creatorUserID; String? creatorUserID;
///
int? groupType; int? groupType;
/// id
String? ownerUserID; String? ownerUserID;
///
int? memberCount; int? memberCount;
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? userFaceURL; String? userFaceURL;
///
int? gender; int? gender;
/// REFUSE = -1, AGREE = 1 /// -11
/// -11
int? handleResult; int? handleResult;
///
String? reqMsg; String? reqMsg;
///
String? handledMsg; String? handledMsg;
///
int? reqTime; int? reqTime;
/// ID
String? handleUserID; String? handleUserID;
///
int? handledTime; int? handledTime;
///
String? ex; String? ex;
GroupApplicationInfo({ GroupApplicationInfo({

@ -1,43 +1,108 @@
import 'dart:io';
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
class Message { class Message {
/// id
String? clientMsgID; String? clientMsgID;
/// id
String? serverMsgID; String? serverMsgID;
///
int? createTime; int? createTime;
///
int? sendTime; int? sendTime;
/// [ConversationType] /// [ConversationType]
int? sessionType; int? sessionType;
/// id
String? sendID; String? sendID;
/// id
String? recvID; String? recvID;
///
int? msgFrom; int? msgFrom;
/// [MessageType] /// [MessageType]
int? contentType; int? contentType;
/// [Platform]
int? platformID; int? platformID;
///
String? senderNickname; String? senderNickname;
///
String? senderFaceUrl; String? senderFaceUrl;
/// ID
String? groupID; String? groupID;
///
String? content; String? content;
/// seq
int? seq; int? seq;
///
bool? isRead; bool? isRead;
///
int? hasReadTime; int? hasReadTime;
/// [MessageStatus] /// [MessageStatus]
int? status; int? status;
/// 线
OfflinePushInfo? offlinePush; OfflinePushInfo? offlinePush;
///
String? attachedInfo; String? attachedInfo;
///
String? ex; String? ex;
///
dynamic ext; dynamic ext;
///
PictureElem? pictureElem; PictureElem? pictureElem;
///
SoundElem? soundElem; SoundElem? soundElem;
///
VideoElem? videoElem; VideoElem? videoElem;
///
FileElem? fileElem; FileElem? fileElem;
/// @
AtElem? atElem; AtElem? atElem;
///
LocationElem? locationElem; LocationElem? locationElem;
///
CustomElem? customElem; CustomElem? customElem;
///
QuoteElem? quoteElem; QuoteElem? quoteElem;
///
MergeElem? mergeElem; MergeElem? mergeElem;
///
NotificationElem? notificationElem; NotificationElem? notificationElem;
///
FaceElem? faceElem; FaceElem? faceElem;
///
AttachedInfoElem? attachedInfoElem; AttachedInfoElem? attachedInfoElem;
Message({ Message({
@ -224,10 +289,18 @@ class Message {
} }
} }
///
class PictureElem { class PictureElem {
///
String? sourcePath; String? sourcePath;
///
PictureInfo? sourcePicture; PictureInfo? sourcePicture;
///
PictureInfo? bigPicture; PictureInfo? bigPicture;
///
PictureInfo? snapshotPicture; PictureInfo? snapshotPicture;
PictureElem( PictureElem(
@ -265,12 +338,24 @@ class PictureElem {
} }
} }
///
class PictureInfo { class PictureInfo {
/// id
String? uuid; String? uuid;
/// mime类型
String? type; String? type;
///
int? size; int? size;
///
int? width; int? width;
///
int? height; int? height;
/// URL地址
String? url; String? url;
PictureInfo( PictureInfo(
@ -297,11 +382,21 @@ class PictureInfo {
} }
} }
///
class SoundElem { class SoundElem {
/// id
String? uuid; String? uuid;
///
String? soundPath; String? soundPath;
/// url地址
String? sourceUrl; String? sourceUrl;
///
int? dataSize; int? dataSize;
/// s
int? duration; int? duration;
SoundElem( SoundElem(
@ -330,18 +425,42 @@ class SoundElem {
} }
} }
///
class VideoElem { class VideoElem {
///
String? videoPath; String? videoPath;
/// uuid
String? videoUUID; String? videoUUID;
/// url地址
String? videoUrl; String? videoUrl;
/// mime类型
String? videoType; String? videoType;
///
int? videoSize; int? videoSize;
/// s
int? duration; int? duration;
///
String? snapshotPath; String? snapshotPath;
/// uuid
String? snapshotUUID; String? snapshotUUID;
///
int? snapshotSize; int? snapshotSize;
/// URL地址
String? snapshotUrl; String? snapshotUrl;
///
int? snapshotWidth; int? snapshotWidth;
///
int? snapshotHeight; int? snapshotHeight;
VideoElem( VideoElem(
@ -391,11 +510,21 @@ class VideoElem {
} }
} }
///
class FileElem { class FileElem {
///
String? filePath; String? filePath;
/// uuid
String? uuid; String? uuid;
/// URL地址
String? sourceUrl; String? sourceUrl;
///
String? fileName; String? fileName;
///
int? fileSize; int? fileSize;
FileElem( FileElem(
@ -420,11 +549,21 @@ class FileElem {
} }
} }
/// @
class AtElem { class AtElem {
///
String? text; String? text;
/// @ID列表
List<String>? atUserList; List<String>? atUserList;
///
bool? isAtSelf; bool? isAtSelf;
/// @ID跟昵称关系列表id替换为昵称显示
List<AtUserInfo>? atUsersInfo; List<AtUserInfo>? atUsersInfo;
/// @
Message? quoteMessage; Message? quoteMessage;
AtElem({ AtElem({
@ -462,9 +601,15 @@ class AtElem {
} }
} }
///
class LocationElem { class LocationElem {
///
String? description; String? description;
///
double? longitude; double? longitude;
///
double? latitude; double? latitude;
LocationElem({this.description, this.longitude, this.latitude}); LocationElem({this.description, this.longitude, this.latitude});
@ -493,9 +638,15 @@ class LocationElem {
} }
} }
///
class CustomElem { class CustomElem {
///
String? data; String? data;
///
String? extension; String? extension;
///
String? description; String? description;
CustomElem({this.data, this.extension, this.description}); CustomElem({this.data, this.extension, this.description});
@ -515,8 +666,12 @@ class CustomElem {
} }
} }
///
class QuoteElem { class QuoteElem {
///
String? text; String? text;
///
Message? quoteMessage; Message? quoteMessage;
QuoteElem({this.text, this.quoteMessage}); QuoteElem({this.text, this.quoteMessage});
@ -536,9 +691,15 @@ class QuoteElem {
} }
} }
///
class MergeElem { class MergeElem {
///
String? title; String? title;
///
List<String>? abstractList; List<String>? abstractList;
///
List<Message>? multiMessage; List<Message>? multiMessage;
MergeElem({this.title, this.abstractList, this.multiMessage}); MergeElem({this.title, this.abstractList, this.multiMessage});
@ -564,8 +725,12 @@ class MergeElem {
} }
} }
///
class NotificationElem { class NotificationElem {
///
String? detail; String? detail;
///
String? defaultTips; String? defaultTips;
NotificationElem({this.detail, this.defaultTips}); NotificationElem({this.detail, this.defaultTips});
@ -583,8 +748,12 @@ class NotificationElem {
} }
} }
///
class FaceElem { class FaceElem {
///
int? index; int? index;
/// URL表情直接返回url
String? data; String? data;
FaceElem({this.index, this.data}); FaceElem({this.index, this.data});
@ -602,12 +771,18 @@ class FaceElem {
} }
} }
///
class AttachedInfoElem { class AttachedInfoElem {
///
GroupHasReadInfo? groupHasReadInfo; GroupHasReadInfo? groupHasReadInfo;
/// ///
bool? isPrivateChat; bool? isPrivateChat;
///
int? hasReadTime; int? hasReadTime;
/// 线
bool? notSenderNotificationPush; bool? notSenderNotificationPush;
AttachedInfoElem({ AttachedInfoElem({
@ -636,9 +811,15 @@ class AttachedInfoElem {
} }
} }
///
class GroupHasReadInfo { class GroupHasReadInfo {
/// id列表
List<String>? hasReadUserIDList; List<String>? hasReadUserIDList;
///
int? hasReadCount; int? hasReadCount;
///
int? groupMemberCount; int? groupMemberCount;
GroupHasReadInfo.fromJson(Map<String, dynamic> json) { GroupHasReadInfo.fromJson(Map<String, dynamic> json) {
@ -660,13 +841,27 @@ class GroupHasReadInfo {
} }
} }
///
class ReadReceiptInfo { class ReadReceiptInfo {
/// id
String? userID; String? userID;
/// id
String? groupID; String? groupID;
/// clientMsgID集合
List<String>? msgIDList; List<String>? msgIDList;
///
int? readTime; int? readTime;
///
int? msgFrom; int? msgFrom;
/// [MessageType]
int? contentType; int? contentType;
/// [ConversationType]
int? sessionType; int? sessionType;
ReadReceiptInfo( ReadReceiptInfo(
@ -702,11 +897,21 @@ class ReadReceiptInfo {
} }
} }
/// 线
class OfflinePushInfo { class OfflinePushInfo {
///
String? title; String? title;
///
String? desc; String? desc;
///
String? ex; String? ex;
/// ios有效
String? iOSPushSound; String? iOSPushSound;
/// ios有效
bool? iOSBadgeCount; bool? iOSBadgeCount;
OfflinePushInfo( OfflinePushInfo(
@ -731,8 +936,12 @@ class OfflinePushInfo {
} }
} }
/// @id跟昵称关系对象
class AtUserInfo { class AtUserInfo {
/// @id
String? atUserID; String? atUserID;
/// @
String? groupNickname; String? groupNickname;
AtUserInfo({this.atUserID, this.groupNickname}); AtUserInfo({this.atUserID, this.groupNickname});

@ -1,25 +1,38 @@
import '../../flutter_openim_sdk.dart'; import '../../flutter_openim_sdk.dart';
/// OA notification
/// oa /// oa
class OANotification { class OANotification {
///
String? notificationName; String? notificationName;
///
String? notificationFaceURL; String? notificationFaceURL;
///
int? notificationType; int? notificationType;
///
String? text; String? text;
///
String? externalUrl; String? externalUrl;
/// Notification Mix Type
/// 0: Plain text notification
/// 1: Text+picture notification
/// 2: Text+video notification
/// 3: Text+file notification
/// 0 1+ 2+ 3+ /// 0 1+ 2+ 3+
int? mixType; int? mixType;
///
PictureElem? pictureElem; PictureElem? pictureElem;
///
SoundElem? soundElem; SoundElem? soundElem;
///
VideoElem? videoElem; VideoElem? videoElem;
///
FileElem? fileElem; FileElem? fileElem;
///
String? ex; String? ex;
OANotification( OANotification(
@ -81,11 +94,18 @@ class OANotification {
} }
} }
/// Group common notification ///
class GroupNotification { class GroupNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
GroupMembersInfo? groupOwnerUser; GroupMembersInfo? groupOwnerUser;
///
List<GroupMembersInfo>? memberList; List<GroupMembersInfo>? memberList;
GroupNotification({ GroupNotification({
@ -129,11 +149,15 @@ class GroupNotification {
} }
} }
/// User is invited to the group notification
/// ///
class InvitedJoinGroupNotification { class InvitedJoinGroupNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
List<GroupMembersInfo>? invitedUserList; List<GroupMembersInfo>? invitedUserList;
InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList}); InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList});
@ -167,11 +191,15 @@ class InvitedJoinGroupNotification {
} }
} }
/// Group kicked member notification
/// ///
class KickedGroupMemeberNotification { class KickedGroupMemeberNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
List<GroupMembersInfo>? kickedUserList; List<GroupMembersInfo>? kickedUserList;
KickedGroupMemeberNotification( KickedGroupMemeberNotification(
@ -206,10 +234,12 @@ class KickedGroupMemeberNotification {
} }
} }
/// Exit group notification
/// 退 /// 退
class QuitGroupNotification { class QuitGroupNotification {
///
GroupInfo? group; GroupInfo? group;
/// 退
GroupMembersInfo? quitUser; GroupMembersInfo? quitUser;
QuitGroupNotification({this.group, this.quitUser}); QuitGroupNotification({this.group, this.quitUser});
@ -233,10 +263,12 @@ class QuitGroupNotification {
} }
} }
/// Enter group notification
/// ///
class EnterGroupNotification { class EnterGroupNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? entrantUser; GroupMembersInfo? entrantUser;
EnterGroupNotification({this.group, this.entrantUser}); EnterGroupNotification({this.group, this.entrantUser});
@ -260,11 +292,15 @@ class EnterGroupNotification {
} }
} }
/// Group rights transfer noticication
/// ///
class GroupRightsTransferNoticication { class GroupRightsTransferNoticication {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
GroupMembersInfo? newGroupOwner; GroupMembersInfo? newGroupOwner;
GroupRightsTransferNoticication({ GroupRightsTransferNoticication({
@ -298,12 +334,18 @@ class GroupRightsTransferNoticication {
} }
} }
/// Mute member notification
/// ///
class MuteMemberNotification { class MuteMemberNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
GroupMembersInfo? mutedUser; GroupMembersInfo? mutedUser;
/// s
int? mutedSeconds; int? mutedSeconds;
MuteMemberNotification({ MuteMemberNotification({
@ -340,11 +382,15 @@ class MuteMemberNotification {
} }
} }
/// Burn after reading notification
/// ///
class BurnAfterReadingNotification { class BurnAfterReadingNotification {
///
String? recvID; String? recvID;
///
String? sendID; String? sendID;
///
bool? isPrivate; bool? isPrivate;
BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate}); BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate});
@ -364,11 +410,15 @@ class BurnAfterReadingNotification {
} }
} }
/// Group member info changed notification ///
///
class GroupMemberInfoChangedNotification { class GroupMemberInfoChangedNotification {
///
GroupInfo? group; GroupInfo? group;
///
GroupMembersInfo? opUser; GroupMembersInfo? opUser;
///
GroupMembersInfo? changedUser; GroupMembersInfo? changedUser;
GroupMemberInfoChangedNotification({ GroupMemberInfoChangedNotification({

@ -1,14 +1,36 @@
///
class DeptInfo { class DeptInfo {
/// id
String? departmentID; String? departmentID;
///
String? faceURL; String? faceURL;
///
String? name; String? name;
/// id
String? parentID; String? parentID;
///
int? order; int? order;
///
int? departmentType; int? departmentType;
///
int? createTime; int? createTime;
///
int? subDepartmentNum; int? subDepartmentNum;
///
int? memberNum; int? memberNum;
///
String? ex; String? ex;
///
String? attachedInfo; String? attachedInfo;
DeptInfo( DeptInfo(
@ -65,27 +87,63 @@ class DeptInfo {
int get hashCode => departmentID.hashCode; int get hashCode => departmentID.hashCode;
} }
///
class DeptMemberInfo { class DeptMemberInfo {
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? englishName; String? englishName;
///
String? faceURL; String? faceURL;
///
int? gender; int? gender;
///
String? mobile; String? mobile;
///
String? telephone; String? telephone;
///
int? birth; int? birth;
///
String? email; String? email;
/// id
String? departmentID; String? departmentID;
///
int? order; int? order;
///
String? position; String? position;
///
int? leader; int? leader;
///
int? status; int? status;
///
int? createTime; int? createTime;
///
String? ex; String? ex;
///
String? attachedInfo; String? attachedInfo;
/// 使 /// 使
String? departmentName; String? departmentName;
///
List<DeptInfo>? parentDepartmentList; List<DeptInfo>? parentDepartmentList;
DeptMemberInfo({ DeptMemberInfo({
@ -177,7 +235,10 @@ class DeptMemberInfo {
/// ///
class UserInDept { class UserInDept {
///
DeptInfo? department; DeptInfo? department;
///
DeptMemberInfo? member; DeptMemberInfo? member;
UserInDept({this.department, this.member}); UserInDept({this.department, this.member});
@ -204,8 +265,13 @@ class UserInDept {
/// ///
class DeptMemberAndSubDept { class DeptMemberAndSubDept {
///
List<DeptInfo>? departmentList; List<DeptInfo>? departmentList;
///
List<DeptMemberInfo>? departmentMemberList; List<DeptMemberInfo>? departmentMemberList;
///
List<DeptInfo>? parentDepartmentList; List<DeptInfo>? parentDepartmentList;
DeptMemberAndSubDept({ DeptMemberAndSubDept({
@ -253,8 +319,12 @@ class DeptMemberAndSubDept {
} }
} }
///
class OrganizationSearchResult { class OrganizationSearchResult {
///
List<DeptInfo>? departmentList; List<DeptInfo>? departmentList;
///
List<DeptMemberInfo>? departmentMemberList; List<DeptMemberInfo>? departmentMemberList;
OrganizationSearchResult({ OrganizationSearchResult({

@ -3,6 +3,8 @@ import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
class SearchResult { class SearchResult {
/// ///
int? totalCount; int? totalCount;
///
List<SearchResultItems>? searchResultItems; List<SearchResultItems>? searchResultItems;
SearchResult({this.totalCount, this.searchResultItems}); SearchResult({this.totalCount, this.searchResultItems});
@ -34,7 +36,11 @@ class SearchResultItems {
/// 1234 /// 1234
int? conversationType; int? conversationType;
///
String? showName; String? showName;
///
String? faceURL; String? faceURL;
/// ///

@ -1,8 +1,15 @@
import 'dart:io';
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
class SignalingInfo { class SignalingInfo {
///
String? opUserID; String? opUserID;
///
InvitationInfo? invitation; InvitationInfo? invitation;
/// 线
OfflinePushInfo? offlinePushInfo; OfflinePushInfo? offlinePushInfo;
SignalingInfo({ SignalingInfo({
@ -31,15 +38,32 @@ class SignalingInfo {
} }
class InvitationInfo { class InvitationInfo {
String? inviterUserID; //UserID /// UserID
List<String>? inviteeUserIDList; //UserID列表 String? inviterUserID;
String? groupID; //""
String? roomID; //ID /// UserID列表
int? timeout; // List<String>? inviteeUserIDList;
/// ""
String? groupID;
/// ID
String? roomID;
///
int? timeout;
///
int? initiateTime; int? initiateTime;
String? mediaType; //video audio
int? sessionType; //12 /// video audio
int? platformID; // String? mediaType;
/// [ConversationType]12
int? sessionType;
/// [Platform]
int? platformID;
InvitationInfo( InvitationInfo(
{this.inviterUserID, {this.inviterUserID,
@ -79,9 +103,15 @@ class InvitationInfo {
} }
} }
///
class SignalingCertificate { class SignalingCertificate {
/// token
String? token; String? token;
/// id
String? roomID; String? roomID;
///
String? liveURL; String? liveURL;
SignalingCertificate({this.token, this.roomID, this.liveURL}); SignalingCertificate({this.token, this.roomID, this.liveURL});

@ -5,31 +5,52 @@
/// Not a friend is not on the blacklist /// Not a friend is not on the blacklist
/// ///
class UserInfo { class UserInfo {
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? faceURL; String? faceURL;
///
int? gender; int? gender;
///
String? phoneNumber; String? phoneNumber;
///
int? birth; int? birth;
///
String? email; String? email;
///
String? ex; String? ex;
///
int? createTime; int? createTime;
///
String? remark; String? remark;
/// User's public profile(用户公开的资料) ///
PublicUserInfo? publicInfo; PublicUserInfo? publicInfo;
/// Only friends can view information ///
FriendInfo? friendInfo; FriendInfo? friendInfo;
/// blacklist information ///
BlacklistInfo? blackInfo; BlacklistInfo? blackInfo;
///
bool? isFriendship; bool? isFriendship;
///
bool? isBlacklist; bool? isBlacklist;
/// /// 012线线
int? globalRecvMsgOpt; int? globalRecvMsgOpt;
UserInfo({ UserInfo({
@ -165,12 +186,24 @@ class UserInfo {
int get hashCode => userID.hashCode; int get hashCode => userID.hashCode;
} }
///
class PublicUserInfo { class PublicUserInfo {
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? faceURL; String? faceURL;
///
int? gender; int? gender;
///
int? appMangerLevel; int? appMangerLevel;
///
String? ex; String? ex;
PublicUserInfo({ PublicUserInfo({
@ -203,18 +236,42 @@ class PublicUserInfo {
} }
} }
///
class FriendInfo { class FriendInfo {
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? faceURL; String? faceURL;
///
int? gender; int? gender;
///
String? phoneNumber; String? phoneNumber;
///
int? birth; int? birth;
///
String? email; String? email;
///
String? remark; String? remark;
///
String? ex; String? ex;
///
int? createTime; int? createTime;
///
int? addSource; int? addSource;
/// id
String? operatorUserID; String? operatorUserID;
FriendInfo({ FriendInfo({
@ -267,14 +324,30 @@ class FriendInfo {
} }
} }
///
class BlacklistInfo { class BlacklistInfo {
/// id
String? userID; String? userID;
///
String? nickname; String? nickname;
///
String? faceURL; String? faceURL;
///
int? gender; int? gender;
///
int? createTime; int? createTime;
///
int? addSource; int? addSource;
///
String? operatorUserID; String? operatorUserID;
///
String? ex; String? ex;
BlacklistInfo({ BlacklistInfo({
@ -313,10 +386,11 @@ class BlacklistInfo {
} }
} }
///
class FriendshipInfo { class FriendshipInfo {
/// id
String? userID; String? userID;
/// 1 means friend (and not blacklist)
/// 1 /// 1
int? result; int? result;
@ -335,21 +409,51 @@ class FriendshipInfo {
} }
} }
///
class FriendApplicationInfo { class FriendApplicationInfo {
/// id
String? fromUserID; String? fromUserID;
///
String? fromNickname; String? fromNickname;
///
String? fromFaceURL; String? fromFaceURL;
///
int? fromGender; int? fromGender;
/// id
String? toUserID; String? toUserID;
///
String? toNickname; String? toNickname;
///
String? toFaceURL; String? toFaceURL;
///
int? toGender; int? toGender;
///
int? handleResult; int? handleResult;
///
String? reqMsg; String? reqMsg;
///
int? createTime; int? createTime;
/// id
String? handlerUserID; String? handlerUserID;
///
String? handleMsg; String? handleMsg;
///
int? handleTime; int? handleTime;
///
String? ex; String? ex;
FriendApplicationInfo( FriendApplicationInfo(
@ -407,12 +511,12 @@ class FriendApplicationInfo {
return data; return data;
} }
/// friend application waiting handle ///
bool get isWaitingHandle => handleResult == 0; bool get isWaitingHandle => handleResult == 0;
/// friend application agreed ///
bool get isAgreed => handleResult == 1; bool get isAgreed => handleResult == 1;
/// friend application rejected ///
bool get isRejected => handleResult == -1; bool get isRejected => handleResult == -1;
} }

@ -2,10 +2,11 @@ import 'package:flutter/services.dart';
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart'; import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
class OpenIM { class OpenIM {
static const MethodChannel _channel = static const version = '2.1.0';
const MethodChannel('flutter_openim_sdk');
static IMManager iMManager = IMManager(_channel); static const _channel = const MethodChannel('flutter_openim_sdk');
static final iMManager = IMManager(_channel);
OpenIM._(); OpenIM._();
} }

@ -1,6 +1,6 @@
name: flutter_openim_sdk name: flutter_openim_sdk
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source. description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
version: 2.1.0 version: 2.1.0+1
homepage: https://www.rentsoft.cn homepage: https://www.rentsoft.cn
repository: https://github.com/OpenIMSDK/Open-IM-SDK-Flutter repository: https://github.com/OpenIMSDK/Open-IM-SDK-Flutter

Loading…
Cancel
Save