Вывод приложения iOS из фонового режима с уведомлением

#ios #swift #firebase #webrtc #firebase-notifications

#iOS #swift #firebase #webrtc #firebase-уведомления

Вопрос:

У меня есть приложение для iOS с Firebase Cloud Messaging для управления моими push-уведомлениями. Это работает хорошо, но я бы хотел открыть свое приложение (находясь в фоновом режиме), когда получу push-уведомление. Немного похоже на WhatsApp, с пользовательским представлением вызовов (WebRTC).

Есть идеи?

По-видимому, я должен использовать PushKit, чтобы делать то, что я хочу делать.

Есть ли другой способ сделать это… нравится Signal приложение. Уведомление о звонке (push?), А Затем пользователь нажимает, чтобы открыть приложение.

Комментарии:

1. Вам необходимо внедрить Apple PushKit вместо APNS.

2. Спасибо. Как я мог бы реализовать PushKit?

3. developer.apple.com/reference/pushkit

4. Хорошо, спасибо. Я понятия не имею, как это реализовать. У вас есть несколько хороших статей?

Ответ №1:

Till FCM не поддерживает автоматическое push-уведомление (Push kit).

Использование Pushkit — это единственный текущий метод отправки беззвучного push-уведомления на устройство.

Сначала вы получаете полезную нагрузку push-уведомлений в режиме молчания, затем вам нужно запланировать локальное уведомление, потому что тихое push-уведомление не поступает в центр уведомлений. до воспроизведения локального звукового файла уведомления (максимум 30 секунд) ваше приложение будет вызываться в фоновом режиме или в состоянии завершения работы. здесь можно выполнить требуемую активность, но не активность пользовательского интерфейса.

Нажимая на интерактивное локальное уведомление, вы можете выполнять дальнейшие действия в пользовательском интерфейсе.

Используйте приведенную ниже структуру для достижения своей задачи.

Используйте это simplepush.php файл

 <?php

// Put your device token here (without spaces):

    
      $deviceToken = '1234567890123456789';
//

    
// Put your private key's passphrase here:
$passphrase = 'ProjectName';

// Put your alert message here:
$message = 'My first push notification!';



$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', 'PemFileName.pem');
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);

// Open a connection to the APNS server
$fp = stream_socket_client(
//  'ssl://gateway.push.apple.com:2195', $err,
    'ssl://gateway.sandbox.push.apple.com:2195', $err,
    $errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx);

if (!$fp)
    exit("Failed to connect: $err $errstr" . PHP_EOL);

echo 'Connected to APNS' . PHP_EOL;

// Create the payload body

$body['aps'] = array(
                     'content-available'=> 1,
                     'alert' => $message,
                     'sound' => 'default',
                     'badge' => 0,
                     );

    

// Encode the payload as JSON
    
$payload = json_encode($body);

// Build the binary notification
$msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;

// Send it to the server
$result = fwrite($fp, $msg, strlen($msg));

if (!$result)
    echo 'Message not delivered' . PHP_EOL;
else
    echo 'Message successfully delivered' . PHP_EOL;

// Close the connection to the server
fclose($fp);
  

Используйте приведенные ниже команды для создания файла pem и использования его в приведенном выше коде

 $ openssl x509 -in aps_development.cer -inform der -out PushCert.pem

# Convert .p12 to .pem. Enter your pass pharse which is the same pwd that you have given while creating the .p12 certificate. PEM pass phrase also same as .p12 cert.  
$ openssl pkcs12 -nocerts -out PushKey1.pem -in pushkey.p12

Enter Import Password:

MAC verified OK

Enter PEM pass phrase:

Verifying - Enter PEM pass phrase:

# To remove passpharse for the key to access globally. This only solved my stream_socket_client() amp; certificate capath warnings.
$ openssl rsa -in PushKey1.pem -out PushKey1_Rmv.pem

Enter pass phrase for PushChatKey1.pem:

writing RSA key

# To join the two .pem file into one file:
$ cat PushCert.pem PushKey1_Rmv.pem > ApnsDev.pem
  

После этого перейдите к simplepush.php расположение и команда огня -> php simplepush.php

Таким образом, вы можете протестировать архитектуру настройки уведомлений push kit.

https://www.raywenderlich.com/123862/push-notifications-tutorial

Скачать

 import UIKit
import PushKit


class AppDelegate: UIResponder, UIApplicationDelegate,PKPushRegistryDelegate{



func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {


    let types: UIRemoteNotificationType = [.Alert, .Badge, .Sound]
    application.registerForRemoteNotificationTypes(types)

    self. PushKitRegistration()

    return true
}



//MARK: - PushKitRegistration

func PushKitRegistration()
{

    let mainQueue = dispatch_get_main_queue()
    // Create a push registry object
    if #available(iOS 8.0, *) {

        let voipRegistry: PKPushRegistry = PKPushRegistry(queue: mainQueue)

        // Set the registry's delegate to self

        voipRegistry.delegate = self

        // Set the push type to VoIP

        voipRegistry.desiredPushTypes = [PKPushTypeVoIP]

    } else {
        // Fallback on earlier versions
    }


}


@available(iOS 8.0, *)
func pushRegistry(registry: PKPushRegistry!, didUpdatePushCredentials credentials: PKPushCredentials!, forType type: String!) {
    // Register VoIP push token (a property of PKPushCredentials) with server

    let hexString : String = UnsafeBufferPointer<UInt8>(start: UnsafePointer(credentials.token.bytes),
        count: credentials.token.length).map { String(format: "x", $0) }.joinWithSeparator("")

    print(hexString)


}


@available(iOS 8.0, *)
func pushRegistry(registry: PKPushRegistry!, didReceiveIncomingPushWithPayload payload: PKPushPayload!, forType type: String!) {
    // Process the received push
    // From here you have to schedule your local notification

}

}
  

введите описание изображения здесь

введите описание изображения здесь

Параллельно, если вы настраиваете архитектуру сокетов. Затем сокет используется для трансляции данных, например, какие пользователи подключены / отключены, и вам нужно знать, не вызывая API, тогда вы можете использовать сокет, архитектура сокетов на сервере будет отправлять данные о пользователях онлайн / оффлайн на устройства без запроса с устройства.

Комментарии:

1. Привет, спасибо. Поэтому я должен реализовать PushKit вместо push-уведомлений. Фактически, это именно то, что я хочу для своего приложения… но у меня нет никаких идей, как это реализовать. Я уже прочитал ссылку на Apple PushKit, но я немного заблудился. Не могли бы вы мне помочь? Спасибо.

2. Спасибо за ваш ответ. Я скоро попробую ваш код и вернусь к вам, если потребуется. Просто еще один вопрос… должен ли я создать сертификат разработчика Apple для этого?

3. Добро пожаловать, вы можете связаться со мной в любое время для консультаций, связанных с VOIP.

4. Привет, я пробовал ваш код, но без какого-либо успеха. У меня нет токена, напечатанного на консоли. Не могли бы вы мне помочь? Может быть, для создания сертификата и профиля подготовки?

5. Да, если вы не получаете токен. тогда должна быть какая-то проблема с сертификатом. не могли бы вы подтвердить это zeropush.com/guide/guide-to-pushkit-and-voip