iOS 11中的VOIP Sinch无法在后台运行

时间:2017-11-26 20:37:10

标签: ios objective-c ios11 sinch pushkit

我使用Sinch VOIP在iOS 11.1.2中的App-To-App之间进行呼叫 当应用程序状态为前台但在后台并且在打开应用程序控制台打印

后没有发生任何事情时运行良好
Pubnub request SCHEDULED (ID=081E49C2-C30A-4B4B-840C-E6A6051E6F44, URL=https://rebtelsdk.pubnub.com/subscribe/sub-c-c5e52f20-d446-11e3-b488-02ee2ddab7fe/5e1e1309-136a-40d4-935f-2627ebe4e8f2B/0/0, NST-VoIP: NO)


Pubnub request STARTED (ID=081E49C2-C30A-4B4B-840C-E6A6051E6F44)
Pubnub request SUCCESS (ID=081E49C2-C30A-4B4B-840C-E6A6051E6F44):
(
        (
    ),
    15117251992031337
)

onPubSubSubscriptionSuccess: userInfo: {
    channel = "5e1e1309-136a-40d4-935f-2627ebe4e8f2B";
    subscribeSequence = 1;
    timetoken = 0;
    useVoIPNetworkServiceType = 0;
}

我上传VOIP& APNS证书到Sinch仪表板,我使用了SINManagedPush& PushKit我的代码是

  
      
  1. 设置Push Manager& SINFient in didFinishLaunchingWithOptions
  2.   
    self.push = [Sinch managedPushWithAPSEnvironment:SINAPSEnvironmentAutomatic];
    self.push.delegate = self;
    [self.push setDesiredPushTypeAutomatically];
    void (^onUserDidLogin)(NSString *) = ^(NSString *userId) {
    [self.push registerUserNotificationSettings];
    [self initSinchClientWithUserId:userId];
    };
    [[NSNotificationCenter defaultCenter]
    addObserverForName:@"UserDidLoginNotification"
    object:nil
    queue:nil
    usingBlock:^(NSNotification *note) {
     NSString *userId = note.userInfo[@"userId"];

     [[NSUserDefaults standardUserDefaults] setObject:userId     forKey:@"userId"];
     [[NSUserDefaults standardUserDefaults] synchronize];
     onUserDidLogin(userId);
     }];


     - (void)initSinchClientWithUserId:(NSString *)userId {
    if (!_client) {
    _client = [Sinch clientWithApplicationKey:@"APP-Key"
                            applicationSecret:@"APP-Secret"
                              environmentHost:@"sandbox.sinch.com"
                                       userId:userId];

    _client.delegate = self;
    _client.callClient.delegate = self;
    [_client setSupportCalling:YES];
    [_client enableManagedPushNotifications];

    [_client start];
    [_client startListeningOnActiveConnection];
    _callKitProvider = [[SINCallKitProvider alloc] initWithClient:_client];


    }
    }
  
      
  1. 获取设备令牌
  2.   
- (void)application:(UIApplication*)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{


[self.push application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
}

-(void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions options))completionHandler{
NSLog(@"User Info : %@",notification.request.content.userInfo);
completionHandler(UNAuthorizationOptionSound | UNAuthorizationOptionAlert | UNAuthorizationOptionBadge);

[self.push application:[UIApplication sharedApplication] didReceiveRemoteNotification:notification.request.content.userInfo];
}


-(void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler{
NSLog(@"User Info : %@",response.notification.request.content.userInfo);
completionHandler();
[self.push application:[UIApplication sharedApplication] didReceiveRemoteNotification:response.notification.request.content.userInfo];
}


- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
[self.push application:application didReceiveRemoteNotification:userInfo];
}
  
      
  1. PushKit
  2.   
-(void)voipRegistration
{
PKPushRegistry* voipRegistry = [[PKPushRegistry alloc] initWithQueue:dispatch_get_main_queue()];
voipRegistry.delegate = self;
voipRegistry.desiredPushTypes = [NSSet setWithObject:PKPushTypeVoIP];
}

 -(void)pushRegistry:(PKPushRegistry *)registry didUpdatePushCredentials:(PKPushCredentials *)credentials forType:(NSString *)type
{

[_client registerPushNotificationData:credentials.token];
 }
 -(void)pushRegistry:(PKPushRegistry *)registry   didInvalidatePushTokenForType:(PKPushType)type{


NSLog(@"invalidated");

 }
  

4. SINClient启动时呼叫voipRegistration

- (void)clientDidStart:(id<SINClient>)client {
NSLog(@"Sinch client started successfully (version: %@)", [Sinch version]);
[self voipRegistration];
}
  

5.实施SINManagedPushDelegate&amp; SINCallClientDelegate

- (void)client:(id<SINCallClient>)client didReceiveIncomingCall:(id<SINCall>)call {

UIViewController *top = self.window.rootViewController;
while (top.presentedViewController) {
    top = top.presentedViewController;
}
[top performSegueWithIdentifier:@"callView" sender:call];
}

- (SINLocalNotification *)client:(id<SINClient>)client localNotificationForIncomingCall:(id<SINCall>)call {
SINLocalNotification *notification = [[SINLocalNotification alloc] init];
NSArray * ansAr = @[@"رد",@"Answer"];
NSArray * MsgAr = @[[NSString stringWithFormat:@"مكالمة لم يرد عليها من %@", [call remoteUserId]],[NSString stringWithFormat:@"Incoming call from %@", [call remoteUserId]]];
notification.alertAction = ansAr[self.languageID];
notification.alertBody = MsgAr[self.languageID];
return notification;
}
- (void)client:(id<SINClient>)client willReceiveIncomingCall:(id<SINCall>)call {

[self.callKitProvider reportNewIncomingCall:call];
}

这些是代码,如果我忘了什么,请帮帮我 我查了credentials.token不是空的。
谢谢你的帮助。

2 个答案:

答案 0 :(得分:2)

使用以下代码设置Sinch托管推送时:

self.push = [Sinch managedPushWithAPSEnvironment:SINAPSEnvironmentAutomatic];
self.push.delegate = self;
[self.push setDesiredPushTypeAutomatically];

Sinch SDK将自动为您执行所有PushKit注册。因此,您的描述中的步骤3和4不是必需的,不应该存在。不需要步骤2中的部分代码。请从SDK下载包中查看Sinch CallKit示例应用程序,并参考该应用程序的实现。

以下是使用3.12.4 Sinch SDK CallKit示例应用程序制作的演示视频,没有任何调整,演示中使用的设备是运行iOS 11的iPhone7,它在后台获取来电,死机和锁屏模式:< / p>

Sinch CallKit Sample App Demo Video

另外,请注意,callKit仅适用于VoIP推送,您是否已将正确类型的推送证书上传到Sinch Portal?enter image description here

答案 1 :(得分:0)

当你强行杀死一个应用程序苹果不会唤醒应用程序的VoIP推送,如果你只是在后台或重新启动手机苹果将唤醒它。很讨厌,但那是苹果