Compare commits
23 Commits
3.0.1-e+1
...
3.2.0-alph
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b07d104799 | ||
|
|
207e0807e9 | ||
|
|
373e4ddc82 | ||
|
|
b3c0b16092 | ||
|
|
8c50207f7c | ||
|
|
3bf9570d8d | ||
|
|
2a8a6ff7d9 | ||
|
|
9c8b9990c9 | ||
|
|
705863ba66 | ||
|
|
fd39b328bc | ||
|
|
90b96cb413 | ||
|
|
7894327b2c | ||
|
|
96e90d3c0a | ||
|
|
8cc844a408 | ||
|
|
9856ac8281 | ||
|
|
c9fd5d6dfb | ||
|
|
056581f52e | ||
|
|
af0ca0932f | ||
|
|
c0618458fa | ||
|
|
27eb0f78d2 | ||
|
|
169da36d0b | ||
|
|
6bd36c424a | ||
|
|
7995c4af1d |
@@ -1,5 +1,6 @@
|
|||||||
# flutter_openim_sdk
|
# flutter_openim_sdk
|
||||||

|
<img src="https://openim-1253691595.cos.ap-nanjing.myqcloud.com/WechatIMG20.jpeg" alt="image" style="width: 200px; " />
|
||||||
|
|
||||||
[](https://pub.flutter-io.cn/packages/flutter_openim_sdk)
|
[](https://pub.flutter-io.cn/packages/flutter_openim_sdk)
|
||||||
[](https://pub.dev/packages/flutter_openim_sdk)
|
[](https://pub.dev/packages/flutter_openim_sdk)
|
||||||
[](https://github.com/OpenIMSDK/Open-IM-SDK-Flutter/blob/main/LICENSE)
|
[](https://github.com/OpenIMSDK/Open-IM-SDK-Flutter/blob/main/LICENSE)
|
||||||
@@ -10,7 +11,7 @@ A flutter im plugin for android and ios.
|
|||||||
|
|
||||||
扫描下方二维码即可体验SDK调用示例 Demo
|
扫描下方二维码即可体验SDK调用示例 Demo
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -52,5 +52,5 @@ android {
|
|||||||
dependencies {
|
dependencies {
|
||||||
// 本地依赖,现将aar复制到libs/io/openim/core-sdk/0.0.1/ 下,命名core-sdk-0.0.1.aar
|
// 本地依赖,现将aar复制到libs/io/openim/core-sdk/0.0.1/ 下,命名core-sdk-0.0.1.aar
|
||||||
// implementation 'io.openim:core-sdk:0.0.1@aar'
|
// implementation 'io.openim:core-sdk:0.0.1@aar'
|
||||||
implementation 'io.openim:core-sdk:3.0.1-e+1@aar'
|
implementation 'io.openim:core-sdk:3.2.0-alpha.0@aar'
|
||||||
}
|
}
|
||||||
@@ -23,7 +23,6 @@ import io.openim.flutter_openim_sdk.manager.FriendshipManager;
|
|||||||
import io.openim.flutter_openim_sdk.manager.GroupManager;
|
import io.openim.flutter_openim_sdk.manager.GroupManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.IMManager;
|
import io.openim.flutter_openim_sdk.manager.IMManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.SignalingManager;
|
|
||||||
import io.openim.flutter_openim_sdk.manager.UserManager;
|
import io.openim.flutter_openim_sdk.manager.UserManager;
|
||||||
|
|
||||||
|
|
||||||
@@ -43,7 +42,6 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
private static MessageManager messageManager;
|
private static MessageManager messageManager;
|
||||||
private static ConversationManager conversationManager;
|
private static ConversationManager conversationManager;
|
||||||
private static GroupManager groupManager;
|
private static GroupManager groupManager;
|
||||||
private static SignalingManager signalingManager;
|
|
||||||
private static Activity activity;
|
private static Activity activity;
|
||||||
private static Context context;
|
private static Context context;
|
||||||
private ConnectivityListener connectivityListener;
|
private ConnectivityListener connectivityListener;
|
||||||
@@ -57,7 +55,6 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
||||||
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
||||||
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
||||||
FlutterOpenimSdkPlugin.signalingManager = new SignalingManager();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -19,15 +19,13 @@ public class OnBaseListener implements Base {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onError(int l, String s) {
|
public void onError(int l, String s) {
|
||||||
String threadName = Thread.currentThread().getName();
|
Log.i("F-OpenIMSDK(native call flutter)", "method: 【 " + call.method + " 】, onError: { code:" + l + ", message:" + s + "}");
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " method: 【 " + call.method + " 】, onError: { code:" + l + ", message:" + s + "}");
|
|
||||||
CommonUtil.runMainThreadReturnError(result, l, s, null);
|
CommonUtil.runMainThreadReturnError(result, l, s, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSuccess(String s) {
|
public void onSuccess(String s) {
|
||||||
String threadName = Thread.currentThread().getName();
|
Log.i("F-OpenIMSDK(native call flutter)", "method: 【 " + call.method + " 】, onSuccess: " + s);
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " method: 【 " + call.method + " 】, onSuccess: " + s);
|
|
||||||
CommonUtil.runMainThreadReturn(result, s);
|
CommonUtil.runMainThreadReturn(result, s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,66 +0,0 @@
|
|||||||
package io.openim.flutter_openim_sdk.listener;
|
|
||||||
|
|
||||||
import io.openim.flutter_openim_sdk.util.CommonUtil;
|
|
||||||
|
|
||||||
public class OnSignalingListener implements open_im_sdk_callback.OnSignalingListener {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInvitationCancelled(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInvitationCancelled", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInvitationTimeout(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInvitationTimeout", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInviteeAccepted(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInviteeAccepted", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInviteeAcceptedByOtherDevice(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInviteeAcceptedByOtherDevice", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInviteeRejected(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInviteeRejected", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInviteeRejectedByOtherDevice(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onInviteeRejectedByOtherDevice", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onReceiveCustomSignal(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onReceiveCustomSignal", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onReceiveNewInvitation(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onReceiveNewInvitation", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onRoomParticipantConnected(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onRoomParticipantConnected", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onRoomParticipantDisconnected(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onRoomParticipantDisconnected", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onStreamChange(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onStreamChange", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onHangUp(String s) {
|
|
||||||
CommonUtil.emitEvent("signalingListener", "onHangUp", s);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -20,6 +20,10 @@ public class IMManager extends BaseManager {
|
|||||||
CommonUtil.runMainThreadReturn(result, initialized);
|
CommonUtil.runMainThreadReturn(result, initialized);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void unInitSDK(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.unInitSDK(value(methodCall, "operationID"));
|
||||||
|
}
|
||||||
|
|
||||||
public void login(MethodCall methodCall, MethodChannel.Result result) {
|
public void login(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.login(
|
Open_im_sdk.login(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
|
|||||||
@@ -1,131 +0,0 @@
|
|||||||
package io.openim.flutter_openim_sdk.manager;
|
|
||||||
|
|
||||||
import io.flutter.plugin.common.MethodCall;
|
|
||||||
import io.flutter.plugin.common.MethodChannel;
|
|
||||||
import io.openim.flutter_openim_sdk.listener.OnBaseListener;
|
|
||||||
import io.openim.flutter_openim_sdk.listener.OnSignalingListener;
|
|
||||||
import open_im_sdk.Open_im_sdk;
|
|
||||||
|
|
||||||
public class SignalingManager extends BaseManager {
|
|
||||||
|
|
||||||
public void setSignalingListener(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.setSignalingListener(new OnSignalingListener());
|
|
||||||
|
|
||||||
result.success(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingInvite(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingInvite(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingInviteInGroup(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingInviteInGroup(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingAccept(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingAccept(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingReject(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingReject(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingCancel(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingCancel(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingHungUp(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingHungUp(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "signalingInfo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingGetRoomByGroupID(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingGetRoomByGroupID(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "groupID"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingGetTokenByRoomID(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingGetTokenByRoomID(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "roomID"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingUpdateMeetingInfo(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingUpdateMeetingInfo(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "info"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingCreateMeeting(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingCreateMeeting(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "info"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingJoinMeeting(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingJoinMeeting(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "info"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingOperateStream(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingOperateStream(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "streamType"),
|
|
||||||
value(methodCall, "roomID"),
|
|
||||||
value(methodCall, "userID"),
|
|
||||||
value(methodCall, "mute"),
|
|
||||||
value(methodCall, "muteAll"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingGetMeetings(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingGetMeetings(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingCloseRoom(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingCloseRoom(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "roomID"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void signalingSendCustomSignal(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.signalingSendCustomSignal(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "customInfo"),
|
|
||||||
value(methodCall, "roomID"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void getSignalingInvitationInfoStartApp(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.getSignalingInvitationInfoStartApp(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -33,7 +33,6 @@ public class CommonUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public synchronized static <T> void emitEvent(String method, String type, Object errCode, String errMsg, T data) {
|
public synchronized static <T> void emitEvent(String method, String type, Object errCode, String errMsg, T data) {
|
||||||
String threadName = Thread.currentThread().getName();
|
|
||||||
runMainThread(() -> {
|
runMainThread(() -> {
|
||||||
Map<String, Object> res = new ArrayMap<>();
|
Map<String, Object> res = new ArrayMap<>();
|
||||||
if (null != type) {
|
if (null != type) {
|
||||||
@@ -48,7 +47,7 @@ public class CommonUtil {
|
|||||||
if (null != errMsg) {
|
if (null != errMsg) {
|
||||||
res.put("errMsg", errMsg);
|
res.put("errMsg", errMsg);
|
||||||
}
|
}
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " { method:" + method + ", type:" + type + " }");
|
Log.i("F-OpenIMSDK(native call flutter)", "{ method:" + method + ", type:" + type + " }");
|
||||||
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res);
|
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,8 +2,8 @@ PODS:
|
|||||||
- Flutter (1.0.0)
|
- Flutter (1.0.0)
|
||||||
- flutter_openim_sdk (0.0.1):
|
- flutter_openim_sdk (0.0.1):
|
||||||
- Flutter
|
- Flutter
|
||||||
- OpenIMSDKCore (= 3.0.0-e)
|
- OpenIMSDKCore (= 3.0.0)
|
||||||
- OpenIMSDKCore (3.0.0-e)
|
- "OpenIMSDKCore (3.0.0+1)"
|
||||||
|
|
||||||
DEPENDENCIES:
|
DEPENDENCIES:
|
||||||
- Flutter (from `Flutter`)
|
- Flutter (from `Flutter`)
|
||||||
@@ -21,8 +21,8 @@ EXTERNAL SOURCES:
|
|||||||
|
|
||||||
SPEC CHECKSUMS:
|
SPEC CHECKSUMS:
|
||||||
Flutter: f04841e97a9d0b0a8025694d0796dd46242b2854
|
Flutter: f04841e97a9d0b0a8025694d0796dd46242b2854
|
||||||
flutter_openim_sdk: 9b4a8c3f8bc581249d074c4090b32d743adee0e0
|
flutter_openim_sdk: 12daf3769f8bf40001970304445b6155c146b7eb
|
||||||
OpenIMSDKCore: b6b5620eb31da76b9c0142e703dff2924341871a
|
OpenIMSDKCore: 2e38a5b9be23e588b5049ebd378161cf277e41a0
|
||||||
|
|
||||||
PODFILE CHECKSUM: 7368163408c647b7eb699d0d788ba6718e18fb8d
|
PODFILE CHECKSUM: 7368163408c647b7eb699d0d788ba6718e18fb8d
|
||||||
|
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ public class IMMananger: BaseServiceManager {
|
|||||||
public override func registerHandlers() {
|
public override func registerHandlers() {
|
||||||
super.registerHandlers()
|
super.registerHandlers()
|
||||||
self["initSDK"] = initSDK
|
self["initSDK"] = initSDK
|
||||||
|
self["unInitSDK"] = unInitSDK
|
||||||
self["login"] = login
|
self["login"] = login
|
||||||
self["logout"] = logout
|
self["logout"] = logout
|
||||||
self["getLoginStatus"] = getLoginStatus
|
self["getLoginStatus"] = getLoginStatus
|
||||||
@@ -59,9 +60,13 @@ public class IMMananger: BaseServiceManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func initSDK(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func initSDK(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
callBack(result,Open_im_sdkInitSDK(ConnListener(channel: self.channel), methodCall[string: "operationID"], methodCall.toJsonString()))
|
callBack(result, Open_im_sdkInitSDK(ConnListener(channel: self.channel), methodCall[string: "operationID"], methodCall.toJsonString()))
|
||||||
addObservers()
|
addObservers()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func unInitSDK(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
Open_im_sdkUnInitSDK(methodCall[string: "operationID"])
|
||||||
|
}
|
||||||
|
|
||||||
func login(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func login(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
Open_im_sdkLogin(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "userID"], methodCall[string: "token"])
|
Open_im_sdkLogin(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "userID"], methodCall[string: "token"])
|
||||||
|
|||||||
@@ -1,149 +1,148 @@
|
|||||||
import Foundation
|
//import Foundation
|
||||||
import OpenIMCore
|
//import OpenIMCore
|
||||||
|
//
|
||||||
public class SignalingManager: BaseServiceManager {
|
//public class SignalingManager: BaseServiceManager {
|
||||||
|
//
|
||||||
public override func registerHandlers() {
|
// public override func registerHandlers() {
|
||||||
super.registerHandlers()
|
// super.registerHandlers()
|
||||||
self["setSignalingListener"] = setSignalingListener
|
// self["setSignalingListener"] = setSignalingListener
|
||||||
self["signalingInvite"] = signalingInvite
|
// self["signalingInvite"] = signalingInvite
|
||||||
self["signalingInviteInGroup"] = signalingInviteInGroup
|
// self["signalingInviteInGroup"] = signalingInviteInGroup
|
||||||
self["signalingAccept"] = signalingAccept
|
// self["signalingAccept"] = signalingAccept
|
||||||
self["signalingReject"] = signalingReject
|
// self["signalingReject"] = signalingReject
|
||||||
self["signalingCancel"] = signalingCancel
|
// self["signalingCancel"] = signalingCancel
|
||||||
self["signalingHungUp"] = signalingHungUp
|
// self["signalingHungUp"] = signalingHungUp
|
||||||
self["signalingGetRoomByGroupID"] = signalingGetRoomByGroupID
|
// self["signalingGetRoomByGroupID"] = signalingGetRoomByGroupID
|
||||||
self["signalingGetTokenByRoomID"] = signalingGetTokenByRoomID
|
// self["signalingGetTokenByRoomID"] = signalingGetTokenByRoomID
|
||||||
self["signalingUpdateMeetingInfo"] = signalingUpdateMeetingInfo
|
// self["signalingUpdateMeetingInfo"] = signalingUpdateMeetingInfo
|
||||||
self["signalingCreateMeeting"] = signalingCreateMeeting
|
// self["signalingCreateMeeting"] = signalingCreateMeeting
|
||||||
self["signalingJoinMeeting"] = signalingJoinMeeting
|
// self["signalingJoinMeeting"] = signalingJoinMeeting
|
||||||
self["signalingOperateStream"] = signalingOperateStream
|
// self["signalingOperateStream"] = signalingOperateStream
|
||||||
self["signalingGetMeetings"] = signalingGetMeetings
|
// self["signalingGetMeetings"] = signalingGetMeetings
|
||||||
self["signalingCloseRoom"] = signalingCloseRoom
|
// self["signalingCloseRoom"] = signalingCloseRoom
|
||||||
self["signalingSendCustomSignal"] = signalingSendCustomSignal
|
// self["signalingSendCustomSignal"] = signalingSendCustomSignal
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func setSignalingListener(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func setSignalingListener(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSetSignalingListener(SignalingListener(channel: channel))
|
// Open_im_sdkSetSignalingListener(SignalingListener(channel: channel))
|
||||||
callBack(result)
|
// callBack(result)
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingInvite(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingInvite(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingInvite(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingInvite(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingInviteInGroup(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingInviteInGroup(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingInviteInGroup(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingInviteInGroup(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingAccept(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingAccept(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingAccept(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingAccept(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingReject(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingReject(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingReject(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingReject(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingCancel(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingCancel(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingCancel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingCancel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingHungUp(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingHungUp(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingHungUp(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
// Open_im_sdkSignalingHungUp(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "signalingInfo"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingGetRoomByGroupID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingGetRoomByGroupID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingGetRoomByGroupID(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "groupID"])
|
// Open_im_sdkSignalingGetRoomByGroupID(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "groupID"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingGetTokenByRoomID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingGetTokenByRoomID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingGetTokenByRoomID(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "roomID"])
|
// Open_im_sdkSignalingGetTokenByRoomID(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "roomID"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingUpdateMeetingInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingUpdateMeetingInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingUpdateMeetingInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
// Open_im_sdkSignalingUpdateMeetingInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingCreateMeeting(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingCreateMeeting(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingCreateMeeting(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
// Open_im_sdkSignalingCreateMeeting(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingJoinMeeting(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingJoinMeeting(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingJoinMeeting(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
// Open_im_sdkSignalingJoinMeeting(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "info"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingOperateStream(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingOperateStream(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingOperateStream(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "streamType"], methodCall[string: "roomID"], methodCall[string: "userID"], methodCall[bool: "mute"], methodCall[bool: "muteAll"])
|
// Open_im_sdkSignalingOperateStream(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "streamType"], methodCall[string: "roomID"], methodCall[string: "userID"], methodCall[bool: "mute"], methodCall[bool: "muteAll"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingGetMeetings(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingGetMeetings(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingGetMeetings(BaseCallback(result: result), methodCall[string: "operationID"])
|
// Open_im_sdkSignalingGetMeetings(BaseCallback(result: result), methodCall[string: "operationID"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingCloseRoom(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingCloseRoom(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingCloseRoom(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "roomID"])
|
// Open_im_sdkSignalingCloseRoom(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "roomID"])
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
func signalingSendCustomSignal(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
// func signalingSendCustomSignal(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkSignalingSendCustomSignal(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "customInfo"], methodCall[string: "roomID"])
|
// Open_im_sdkSignalingSendCustomSignal(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "customInfo"], methodCall[string: "roomID"])
|
||||||
}
|
// }
|
||||||
}
|
//}
|
||||||
|
//public class SignalingListener: NSObject, Open_im_sdk_callbackOnSignalingListenerProtocol {
|
||||||
public class SignalingListener: NSObject, Open_im_sdk_callbackOnSignalingListenerProtocol {
|
//
|
||||||
|
//
|
||||||
|
// private let channel:FlutterMethodChannel
|
||||||
private let channel:FlutterMethodChannel
|
//
|
||||||
|
// init(channel:FlutterMethodChannel) {
|
||||||
init(channel:FlutterMethodChannel) {
|
// self.channel = channel
|
||||||
self.channel = channel
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInvitationCancelled(_ s: String?) {
|
||||||
public func onInvitationCancelled(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInvitationCancelled", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInvitationCancelled", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInvitationTimeout(_ s: String?) {
|
||||||
public func onInvitationTimeout(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInvitationTimeout", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInvitationTimeout", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInviteeAccepted(_ s: String?) {
|
||||||
public func onInviteeAccepted(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeAccepted", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeAccepted", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInviteeAccepted(byOtherDevice s: String?) {
|
||||||
public func onInviteeAccepted(byOtherDevice s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeAcceptedByOtherDevice", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeAcceptedByOtherDevice", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInviteeRejected(_ s: String?) {
|
||||||
public func onInviteeRejected(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeRejected", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeRejected", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onInviteeRejected(byOtherDevice s: String?) {
|
||||||
public func onInviteeRejected(byOtherDevice s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeRejectedByOtherDevice", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onInviteeRejectedByOtherDevice", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onReceiveNewInvitation(_ s: String?) {
|
||||||
public func onReceiveNewInvitation(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onReceiveNewInvitation", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onReceiveNewInvitation", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onHangUp(_ s: String?) {
|
||||||
public func onHangUp(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onHangUp", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onHangUp", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onRoomParticipantConnected(_ s: String?) {
|
||||||
public func onRoomParticipantConnected(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onRoomParticipantConnected", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onRoomParticipantConnected", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onRoomParticipantDisconnected(_ s: String?) {
|
||||||
public func onRoomParticipantDisconnected(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onRoomParticipantDisconnected", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onRoomParticipantDisconnected", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onStreamChange(_ s: String?) {
|
||||||
public func onStreamChange(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onStreamChange", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onStreamChange", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
// public func onReceiveCustomSignal(_ s: String?) {
|
||||||
public func onReceiveCustomSignal(_ s: String?) {
|
// CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onReceiveCustomSignal", errCode: nil, errMsg: nil, data: s)
|
||||||
CommonUtil.emitEvent(channel: channel, method: "signalingListener", type: "onReceiveCustomSignal", errCode: nil, errMsg: nil, data: s)
|
// }
|
||||||
}
|
//
|
||||||
|
//}
|
||||||
}
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
let messageManager: MessageManager
|
let messageManager: MessageManager
|
||||||
let groupManager: GroupManager
|
let groupManager: GroupManager
|
||||||
let userManger: UserManager
|
let userManger: UserManager
|
||||||
let signalingManager: SignalingManager
|
// let signalingManager: SignalingManager
|
||||||
// let workMomentsManager: WorkMomentsManager
|
// let workMomentsManager: WorkMomentsManager
|
||||||
// let organizationManager: OrganizationManager
|
// let organizationManager: OrganizationManager
|
||||||
|
|
||||||
@@ -19,7 +19,7 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
self.messageManager = MessageManager(channel: channel)
|
self.messageManager = MessageManager(channel: channel)
|
||||||
self.groupManager = GroupManager(channel: channel)
|
self.groupManager = GroupManager(channel: channel)
|
||||||
self.userManger = UserManager(channel: channel)
|
self.userManger = UserManager(channel: channel)
|
||||||
self.signalingManager = SignalingManager(channel: channel)
|
// self.signalingManager = SignalingManager(channel: channel)
|
||||||
// self.workMomentsManager = WorkMomentsManager(channel: channel)
|
// self.workMomentsManager = WorkMomentsManager(channel: channel)
|
||||||
// self.organizationManager = OrganizationManager(channel: channel)
|
// self.organizationManager = OrganizationManager(channel: channel)
|
||||||
}
|
}
|
||||||
@@ -45,8 +45,8 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
groupManager.handleMethod(call: call, result: result)
|
groupManager.handleMethod(call: call, result: result)
|
||||||
case "userManager":
|
case "userManager":
|
||||||
userManger.handleMethod(call: call, result: result)
|
userManger.handleMethod(call: call, result: result)
|
||||||
case "signalingManager":
|
// case "signalingManager":
|
||||||
signalingManager.handleMethod(call: call, result: result)
|
// signalingManager.handleMethod(call: call, result: result)
|
||||||
// case "workMomentsManager":
|
// case "workMomentsManager":
|
||||||
// workMomentsManager.handleMethod(call: call, result: result)
|
// workMomentsManager.handleMethod(call: call, result: result)
|
||||||
// case "organizationManager":
|
// case "organizationManager":
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ A new Flutter project.
|
|||||||
s.dependency 'Flutter'
|
s.dependency 'Flutter'
|
||||||
s.platform = :ios, '11.0'
|
s.platform = :ios, '11.0'
|
||||||
|
|
||||||
s.dependency 'OpenIMSDKCore','3.0.1-e'
|
s.dependency 'OpenIMSDKCore','3.2.0-alpha.0'
|
||||||
s.static_framework = true
|
s.static_framework = true
|
||||||
# s.vendored_frameworks = 'Framework/*.framework'
|
# s.vendored_frameworks = 'Framework/*.framework'
|
||||||
# Flutter.framework does not contain a i386 slice.
|
# Flutter.framework does not contain a i386 slice.
|
||||||
|
|||||||
@@ -21,14 +21,12 @@ export 'src/listener/listener_for_service.dart';
|
|||||||
export 'src/listener/message_kv_info_listener.dart';
|
export 'src/listener/message_kv_info_listener.dart';
|
||||||
export 'src/listener/msg_send_progress_listener.dart';
|
export 'src/listener/msg_send_progress_listener.dart';
|
||||||
export 'src/listener/upload_file_listener.dart';
|
export 'src/listener/upload_file_listener.dart';
|
||||||
export 'src/listener/signaling_listener.dart';
|
|
||||||
export 'src/listener/user_listener.dart';
|
export 'src/listener/user_listener.dart';
|
||||||
export 'src/manager/im_conversation_manager.dart';
|
export 'src/manager/im_conversation_manager.dart';
|
||||||
export 'src/manager/im_friendship_manager.dart';
|
export 'src/manager/im_friendship_manager.dart';
|
||||||
export 'src/manager/im_group_manager.dart';
|
export 'src/manager/im_group_manager.dart';
|
||||||
export 'src/manager/im_manager.dart';
|
export 'src/manager/im_manager.dart';
|
||||||
export 'src/manager/im_message_manager.dart';
|
export 'src/manager/im_message_manager.dart';
|
||||||
export 'src/manager/im_signaling_manager.dart';
|
|
||||||
export 'src/manager/im_user_manager.dart';
|
export 'src/manager/im_user_manager.dart';
|
||||||
export 'src/models/conversation_info.dart';
|
export 'src/models/conversation_info.dart';
|
||||||
export 'src/models/group_info.dart';
|
export 'src/models/group_info.dart';
|
||||||
|
|||||||
@@ -1,88 +0,0 @@
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|
||||||
|
|
||||||
/// 信令监听
|
|
||||||
class OnSignalingListener {
|
|
||||||
final Function(SignalingInfo info)? onInvitationCancelled;
|
|
||||||
final Function(SignalingInfo info)? onInvitationTimeout;
|
|
||||||
final Function(SignalingInfo info)? onInviteeAccepted;
|
|
||||||
final Function(SignalingInfo info)? onInviteeRejected;
|
|
||||||
final Function(SignalingInfo info)? onReceiveNewInvitation;
|
|
||||||
final Function(SignalingInfo info)? onInviteeRejectedByOtherDevice;
|
|
||||||
final Function(SignalingInfo info)? onInviteeAcceptedByOtherDevice;
|
|
||||||
final Function(SignalingInfo info)? onHangup;
|
|
||||||
final Function(RoomCallingInfo info)? onRoomParticipantConnected;
|
|
||||||
final Function(RoomCallingInfo info)? onRoomParticipantDisconnected;
|
|
||||||
final Function(MeetingStreamEvent event)? onMeetingStreamChanged;
|
|
||||||
final Function(CustomSignaling info)? onReceiveCustomSignal;
|
|
||||||
|
|
||||||
OnSignalingListener({
|
|
||||||
this.onInvitationCancelled,
|
|
||||||
this.onInvitationTimeout,
|
|
||||||
this.onInviteeAccepted,
|
|
||||||
this.onInviteeRejected,
|
|
||||||
this.onReceiveNewInvitation,
|
|
||||||
this.onInviteeAcceptedByOtherDevice,
|
|
||||||
this.onInviteeRejectedByOtherDevice,
|
|
||||||
this.onHangup,
|
|
||||||
this.onRoomParticipantConnected,
|
|
||||||
this.onRoomParticipantDisconnected,
|
|
||||||
this.onMeetingStreamChanged,
|
|
||||||
this.onReceiveCustomSignal,
|
|
||||||
});
|
|
||||||
|
|
||||||
/// 被邀请者收到:邀请者取消音视频通话
|
|
||||||
void invitationCancelled(SignalingInfo info) {
|
|
||||||
onInvitationCancelled?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 邀请者收到:被邀请者超时未接通
|
|
||||||
void invitationTimeout(SignalingInfo info) {
|
|
||||||
onInvitationTimeout?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 邀请者收到:被邀请者同意音视频通话
|
|
||||||
void inviteeAccepted(SignalingInfo info) {
|
|
||||||
onInviteeAccepted?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 邀请者收到:被邀请者拒绝音视频通话
|
|
||||||
void inviteeRejected(SignalingInfo info) {
|
|
||||||
onInviteeRejected?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 被邀请者收到:音视频通话邀请
|
|
||||||
void receiveNewInvitation(SignalingInfo info) {
|
|
||||||
onReceiveNewInvitation?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 被邀请者(其他端)收到:比如被邀请者在手机拒接,在pc上会收到此回调
|
|
||||||
void inviteeAcceptedByOtherDevice(SignalingInfo info) {
|
|
||||||
onInviteeAcceptedByOtherDevice?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 被邀请者(其他端)收到:比如被邀请者在手机拒接,在pc上会收到此回调
|
|
||||||
void inviteeRejectedByOtherDevice(SignalingInfo info) {
|
|
||||||
onInviteeRejectedByOtherDevice?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 被挂断
|
|
||||||
void hangup(SignalingInfo info) {
|
|
||||||
onHangup?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
void roomParticipantConnected(RoomCallingInfo info) {
|
|
||||||
onRoomParticipantConnected?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
void roomParticipantDisconnected(RoomCallingInfo info) {
|
|
||||||
onRoomParticipantDisconnected?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
void streamChangedEvent(MeetingStreamEvent event) {
|
|
||||||
onMeetingStreamChanged?.call(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void receiveCustomSignal(CustomSignaling info) {
|
|
||||||
onReceiveCustomSignal?.call(info);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -12,7 +12,6 @@ class IMManager {
|
|||||||
late MessageManager messageManager;
|
late MessageManager messageManager;
|
||||||
late GroupManager groupManager;
|
late GroupManager groupManager;
|
||||||
late UserManager userManager;
|
late UserManager userManager;
|
||||||
late SignalingManager signalingManager;
|
|
||||||
|
|
||||||
late OnConnectListener _connectListener;
|
late OnConnectListener _connectListener;
|
||||||
OnListenerForService? _listenerForService;
|
OnListenerForService? _listenerForService;
|
||||||
@@ -21,7 +20,6 @@ class IMManager {
|
|||||||
late UserInfo userInfo;
|
late UserInfo userInfo;
|
||||||
bool isLogined = false;
|
bool isLogined = false;
|
||||||
String? token;
|
String? token;
|
||||||
String? _objectStorage;
|
|
||||||
|
|
||||||
IMManager(this._channel) {
|
IMManager(this._channel) {
|
||||||
conversationManager = ConversationManager(_channel);
|
conversationManager = ConversationManager(_channel);
|
||||||
@@ -29,7 +27,6 @@ class IMManager {
|
|||||||
messageManager = MessageManager(_channel);
|
messageManager = MessageManager(_channel);
|
||||||
groupManager = GroupManager(_channel);
|
groupManager = GroupManager(_channel);
|
||||||
userManager = UserManager(_channel);
|
userManager = UserManager(_channel);
|
||||||
signalingManager = SignalingManager(_channel);
|
|
||||||
_addNativeCallback(_channel);
|
_addNativeCallback(_channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -270,64 +267,6 @@ class IMManager {
|
|||||||
friendshipManager.listener.friendInfoChanged(u);
|
friendshipManager.listener.friendInfoChanged(u);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (call.method == ListenerType.signalingListener) {
|
|
||||||
String type = call.arguments['type'];
|
|
||||||
dynamic data = call.arguments['data'];
|
|
||||||
dynamic info;
|
|
||||||
switch (type) {
|
|
||||||
case 'onRoomParticipantConnected':
|
|
||||||
case 'onRoomParticipantDisconnected':
|
|
||||||
info = Utils.toObj(data, (map) => RoomCallingInfo.fromJson(map));
|
|
||||||
break;
|
|
||||||
case 'onStreamChange':
|
|
||||||
info =
|
|
||||||
Utils.toObj(data, (map) => MeetingStreamEvent.fromJson(map));
|
|
||||||
break;
|
|
||||||
case 'onReceiveCustomSignal':
|
|
||||||
info = Utils.toObj(data, (map) => CustomSignaling.fromJson(map));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
info = Utils.toObj(data, (map) => SignalingInfo.fromJson(map));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
switch (type) {
|
|
||||||
case 'onInvitationCancelled':
|
|
||||||
signalingManager.listener.invitationCancelled(info);
|
|
||||||
break;
|
|
||||||
case 'onInvitationTimeout':
|
|
||||||
signalingManager.listener.invitationTimeout(info);
|
|
||||||
break;
|
|
||||||
case 'onInviteeAccepted':
|
|
||||||
signalingManager.listener.inviteeAccepted(info);
|
|
||||||
break;
|
|
||||||
case 'onInviteeRejected':
|
|
||||||
signalingManager.listener.inviteeRejected(info);
|
|
||||||
break;
|
|
||||||
case 'onReceiveNewInvitation':
|
|
||||||
signalingManager.listener.receiveNewInvitation(info);
|
|
||||||
break;
|
|
||||||
case 'onInviteeAcceptedByOtherDevice':
|
|
||||||
signalingManager.listener.inviteeAcceptedByOtherDevice(info);
|
|
||||||
break;
|
|
||||||
case 'onInviteeRejectedByOtherDevice':
|
|
||||||
signalingManager.listener.inviteeRejectedByOtherDevice(info);
|
|
||||||
break;
|
|
||||||
case 'onHangUp':
|
|
||||||
signalingManager.listener.hangup(info);
|
|
||||||
break;
|
|
||||||
case 'onRoomParticipantConnected':
|
|
||||||
signalingManager.listener.roomParticipantConnected(info);
|
|
||||||
break;
|
|
||||||
case 'onRoomParticipantDisconnected':
|
|
||||||
signalingManager.listener.roomParticipantDisconnected(info);
|
|
||||||
break;
|
|
||||||
case 'onStreamChange':
|
|
||||||
signalingManager.listener.streamChangedEvent(info);
|
|
||||||
break;
|
|
||||||
case 'onReceiveCustomSignal':
|
|
||||||
signalingManager.listener.receiveCustomSignal(info);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} else if (call.method == ListenerType.customBusinessListener) {
|
} else if (call.method == ListenerType.customBusinessListener) {
|
||||||
String type = call.arguments['type'];
|
String type = call.arguments['type'];
|
||||||
String data = call.arguments['data'];
|
String data = call.arguments['data'];
|
||||||
@@ -459,16 +398,15 @@ class IMManager {
|
|||||||
required OnConnectListener listener,
|
required OnConnectListener listener,
|
||||||
int logLevel = 6,
|
int logLevel = 6,
|
||||||
String objectStorage = 'cos',
|
String objectStorage = 'cos',
|
||||||
String? encryptionKey,
|
// String? encryptionKey,
|
||||||
bool isNeedEncryption = false,
|
// bool isNeedEncryption = false,
|
||||||
bool isCompression = false,
|
// bool isCompression = false,
|
||||||
bool isExternalExtensions = false,
|
// bool isExternalExtensions = false,
|
||||||
bool isLogStandardOutput = true,
|
bool isLogStandardOutput = true,
|
||||||
String? logFilePath,
|
String? logFilePath,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) {
|
}) {
|
||||||
this._connectListener = listener;
|
this._connectListener = listener;
|
||||||
this._objectStorage = objectStorage;
|
|
||||||
return _channel.invokeMethod(
|
return _channel.invokeMethod(
|
||||||
'initSDK',
|
'initSDK',
|
||||||
_buildParam(
|
_buildParam(
|
||||||
@@ -479,10 +417,10 @@ class IMManager {
|
|||||||
"dataDir": dataDir,
|
"dataDir": dataDir,
|
||||||
"logLevel": logLevel,
|
"logLevel": logLevel,
|
||||||
"objectStorage": objectStorage,
|
"objectStorage": objectStorage,
|
||||||
"encryptionKey": encryptionKey,
|
// "encryptionKey": encryptionKey,
|
||||||
"isNeedEncryption": isNeedEncryption,
|
// "isNeedEncryption": isNeedEncryption,
|
||||||
"isCompression": isCompression,
|
// "isCompression": isCompression,
|
||||||
"isExternalExtensions": isExternalExtensions,
|
// "isExternalExtensions": isExternalExtensions,
|
||||||
"isLogStandardOutput": isLogStandardOutput,
|
"isLogStandardOutput": isLogStandardOutput,
|
||||||
"logFilePath": logFilePath,
|
"logFilePath": logFilePath,
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
@@ -490,6 +428,11 @@ class IMManager {
|
|||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// 反初始化SDK
|
||||||
|
Future<dynamic> unInitSDK() {
|
||||||
|
return _channel.invokeMethod('unInitSDK', _buildParam({}));
|
||||||
|
}
|
||||||
|
|
||||||
/// 登录
|
/// 登录
|
||||||
/// [userID] 用户id
|
/// [userID] 用户id
|
||||||
/// [token] 登录token,从业务服务器上获取
|
/// [token] 登录token,从业务服务器上获取
|
||||||
|
|||||||
@@ -1,319 +0,0 @@
|
|||||||
import 'package:flutter/services.dart';
|
|
||||||
|
|
||||||
import '../../flutter_openim_sdk.dart';
|
|
||||||
|
|
||||||
class SignalingManager {
|
|
||||||
MethodChannel _channel;
|
|
||||||
late OnSignalingListener listener;
|
|
||||||
|
|
||||||
SignalingManager(this._channel);
|
|
||||||
|
|
||||||
/// 信令监听
|
|
||||||
Future setSignalingListener(OnSignalingListener listener) {
|
|
||||||
this.listener = listener;
|
|
||||||
return _channel.invokeMethod('setSignalingListener', _buildParam({}));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 邀请个人加入音视频
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<SignalingCertificate> signalingInvite({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingInvite',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
|
|
||||||
|
|
||||||
/// 邀请群里某些人加入音视频
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<SignalingCertificate> signalingInviteInGroup({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingInviteInGroup',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
|
|
||||||
|
|
||||||
/// 同意某人音视频邀请
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<SignalingCertificate> signalingAccept({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingAccept',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
|
|
||||||
|
|
||||||
/// 拒绝某人音视频邀请
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<dynamic> signalingReject({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingReject',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// 邀请者取消音视频通话
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<dynamic> signalingCancel({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingCancel',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// 挂断
|
|
||||||
/// [info] 信令对象[SignalingInfo]
|
|
||||||
Future<dynamic> signalingHungUp({
|
|
||||||
required SignalingInfo info,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingHungUp',
|
|
||||||
_buildParam({
|
|
||||||
'signalingInfo': info.toJson(),
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// 获取当前群通话信息
|
|
||||||
/// [groupID] 当前群ID
|
|
||||||
Future<RoomCallingInfo> signalingGetRoomByGroupID({
|
|
||||||
required String groupID,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingGetRoomByGroupID',
|
|
||||||
_buildParam({
|
|
||||||
'groupID': groupID,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => RoomCallingInfo.fromJson(map)));
|
|
||||||
|
|
||||||
/// 获取进入房间的信息
|
|
||||||
/// [roomID] 当前房间ID
|
|
||||||
Future<SignalingCertificate> signalingGetTokenByRoomID({
|
|
||||||
required String roomID,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingGetTokenByRoomID',
|
|
||||||
_buildParam({
|
|
||||||
'roomID': roomID,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) => Utils.toObj(
|
|
||||||
value,
|
|
||||||
(map) => SignalingCertificate.fromJson(
|
|
||||||
map..addAll({'roomID': roomID}))));
|
|
||||||
|
|
||||||
/// 会议设置
|
|
||||||
/// required String roomID,
|
|
||||||
/// String? meetingName,
|
|
||||||
/// String? ex,
|
|
||||||
/// int startTime = 0,
|
|
||||||
/// int endTime = 0,
|
|
||||||
/// bool participantCanUnmuteSelf = true,
|
|
||||||
/// bool participantCanEnableVideo = true,
|
|
||||||
/// bool onlyHostInviteUser = true,
|
|
||||||
/// bool onlyHostShareScreen = true,
|
|
||||||
/// bool joinDisableMicrophone = true,
|
|
||||||
/// bool joinDisableVideo = true,
|
|
||||||
/// bool isMuteAllVideo = true,
|
|
||||||
/// bool isMuteAllMicrophone = true,
|
|
||||||
/// List<String> addCanScreenUserIDList = const [],
|
|
||||||
/// List<String> reduceCanScreenUserIDList = const [],
|
|
||||||
/// List<String> addDisableMicrophoneUserIDList = const [],
|
|
||||||
/// List<String> reduceDisableMicrophoneUserIDList = const [],
|
|
||||||
/// List<String> addDisableVideoUserIDList = const [],
|
|
||||||
/// List<String> reduceDisableVideoUserIDList = const [],
|
|
||||||
/// List<String> addPinedUserIDList = const [],
|
|
||||||
/// List<String> reducePinedUserIDList = const [],
|
|
||||||
/// List<String> addBeWatchedUserIDList = const [],
|
|
||||||
/// List<String> reduceBeWatchedUserIDList = const [],
|
|
||||||
Future<dynamic> signalingUpdateMeetingInfo({
|
|
||||||
required Map info,
|
|
||||||
String? operationID,
|
|
||||||
}) {
|
|
||||||
if (info['meetingID'] != null) {
|
|
||||||
info['roomID'] = info['meetingID'];
|
|
||||||
}
|
|
||||||
assert(info['roomID'] != null);
|
|
||||||
return _channel.invokeMethod(
|
|
||||||
'signalingUpdateMeetingInfo',
|
|
||||||
_buildParam({
|
|
||||||
'info': info,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 创建会议室
|
|
||||||
/// [meetingName] 会议主题
|
|
||||||
/// [meetingHostUserID] 会议主持人ID
|
|
||||||
/// [startTime] 开始时间s
|
|
||||||
/// [meetingDuration] 会议时长s
|
|
||||||
/// [inviteeUserIDList] 被邀请人ID列表
|
|
||||||
/// [ex] 其他
|
|
||||||
Future<SignalingCertificate> signalingCreateMeeting({
|
|
||||||
required String meetingName,
|
|
||||||
String? meetingHostUserID,
|
|
||||||
int? startTime,
|
|
||||||
int? meetingDuration,
|
|
||||||
List<String> inviteeUserIDList = const [],
|
|
||||||
String? ex,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingCreateMeeting',
|
|
||||||
_buildParam({
|
|
||||||
'info': {
|
|
||||||
'meetingName': meetingName,
|
|
||||||
'meetingHostUserID': meetingHostUserID,
|
|
||||||
'startTime': startTime,
|
|
||||||
'meetingDuration': meetingDuration,
|
|
||||||
'inviteeUserIDList': inviteeUserIDList,
|
|
||||||
'ex': ex,
|
|
||||||
},
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
|
|
||||||
|
|
||||||
/// 加入会议室
|
|
||||||
/// [roomID] 会议ID
|
|
||||||
/// [meetingName] 会议主题
|
|
||||||
/// [participantNickname] 加入房间显示的名称
|
|
||||||
Future<SignalingCertificate> signalingJoinMeeting({
|
|
||||||
required String roomID,
|
|
||||||
String? meetingName,
|
|
||||||
String? participantNickname,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingJoinMeeting',
|
|
||||||
_buildParam({
|
|
||||||
'info': {
|
|
||||||
'roomID': roomID,
|
|
||||||
'meetingName': meetingName,
|
|
||||||
'participantNickname': participantNickname,
|
|
||||||
},
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingCertificate.fromJson(map)));
|
|
||||||
|
|
||||||
/// 会议室 管理员对指定的某一个入会人员设置禁言
|
|
||||||
/// [roomID] 会议ID
|
|
||||||
/// [streamType] video/audio
|
|
||||||
/// [userID] 被禁言的用户ID
|
|
||||||
/// [mute] true:禁言
|
|
||||||
/// [muteAll] true:video/audio 一起设置
|
|
||||||
Future<dynamic> signalingOperateStream({
|
|
||||||
required String roomID,
|
|
||||||
String? streamType,
|
|
||||||
required String userID,
|
|
||||||
bool mute = false,
|
|
||||||
bool muteAll = false,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingOperateStream',
|
|
||||||
_buildParam({
|
|
||||||
'roomID': roomID,
|
|
||||||
'streamType': streamType,
|
|
||||||
'userID': userID,
|
|
||||||
'mute': mute,
|
|
||||||
'muteAll': muteAll,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// 获取所有的未完成会议
|
|
||||||
/// [roomID] 会议ID
|
|
||||||
Future<MeetingInfoList> signalingGetMeetings({
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'signalingGetMeetings',
|
|
||||||
_buildParam({
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => MeetingInfoList.fromJson(map)));
|
|
||||||
|
|
||||||
/// 结束会议
|
|
||||||
/// [roomID] 会议ID
|
|
||||||
Future<dynamic> signalingCloseRoom({
|
|
||||||
required String roomID,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingCloseRoom',
|
|
||||||
_buildParam({
|
|
||||||
'roomID': roomID,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// 自定义信令
|
|
||||||
/// [roomID] 会议ID
|
|
||||||
/// [customInfo] 自定义信令
|
|
||||||
Future<dynamic> signalingSendCustomSignal({
|
|
||||||
required String roomID,
|
|
||||||
required String customInfo,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'signalingSendCustomSignal',
|
|
||||||
_buildParam({
|
|
||||||
'roomID': roomID,
|
|
||||||
'customInfo': customInfo,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
Future<SignalingInfo> getSignalingInvitationInfoStartApp({
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'getSignalingInvitationInfoStartApp',
|
|
||||||
_buildParam({
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toObj(value, (map) => SignalingInfo.fromJson(map)));
|
|
||||||
|
|
||||||
static Map _buildParam(Map param) {
|
|
||||||
param["ManagerName"] = "signalingManager";
|
|
||||||
return param;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -188,8 +188,6 @@ class UserInfo {
|
|||||||
|
|
||||||
int? get _birth => friendInfo?.birth;
|
int? get _birth => friendInfo?.birth;
|
||||||
|
|
||||||
String? get _birthTime => friendInfo?.birthTime;
|
|
||||||
|
|
||||||
String? get _email => friendInfo?.email;
|
String? get _email => friendInfo?.email;
|
||||||
|
|
||||||
String? get _remark => friendInfo?.remark;
|
String? get _remark => friendInfo?.remark;
|
||||||
@@ -280,9 +278,6 @@ class FriendInfo {
|
|||||||
String? phoneNumber;
|
String? phoneNumber;
|
||||||
|
|
||||||
/// 出生日期
|
/// 出生日期
|
||||||
String? birthTime;
|
|
||||||
|
|
||||||
/// 使用[birthTime]
|
|
||||||
int? birth;
|
int? birth;
|
||||||
|
|
||||||
/// 邮箱
|
/// 邮箱
|
||||||
@@ -310,7 +305,6 @@ class FriendInfo {
|
|||||||
this.gender,
|
this.gender,
|
||||||
this.phoneNumber,
|
this.phoneNumber,
|
||||||
this.birth,
|
this.birth,
|
||||||
this.birthTime,
|
|
||||||
this.email,
|
this.email,
|
||||||
this.remark,
|
this.remark,
|
||||||
this.ex,
|
this.ex,
|
||||||
@@ -331,7 +325,6 @@ class FriendInfo {
|
|||||||
gender = json['gender'];
|
gender = json['gender'];
|
||||||
phoneNumber = json['phoneNumber'];
|
phoneNumber = json['phoneNumber'];
|
||||||
birth = json['birth'];
|
birth = json['birth'];
|
||||||
birthTime = json['birthTime'];
|
|
||||||
email = json['email'];
|
email = json['email'];
|
||||||
ex = json['ex'];
|
ex = json['ex'];
|
||||||
}
|
}
|
||||||
@@ -349,7 +342,6 @@ class FriendInfo {
|
|||||||
data['gender'] = this.gender;
|
data['gender'] = this.gender;
|
||||||
data['phoneNumber'] = this.phoneNumber;
|
data['phoneNumber'] = this.phoneNumber;
|
||||||
data['birth'] = this.birth;
|
data['birth'] = this.birth;
|
||||||
data['birthTime'] = this.birthTime;
|
|
||||||
data['email'] = this.email;
|
data['email'] = this.email;
|
||||||
data['ex'] = this.ex;
|
data['ex'] = this.ex;
|
||||||
return data;
|
return data;
|
||||||
|
|||||||
@@ -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: 3.0.0
|
version: 3.2.0-alpha.0
|
||||||
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
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user