Как подключить push-уведомления для iOS
Выберите канал push-уведомлений
-
Перейдите в раздел Настройки → Каналы в личном кабинете edna Pulse.
-
Выберите существующий канал push-уведомлений, в котором вы хотите разместить приложение, или подключите новый.
Как подключить канал Pushк сведениюВ одном канале вы можете объединить несколько приложений, пользователям которых вы хотите отправлять push-уведомления в рамках одной рассылки
-
Убедитесь, что у вас есть:
- приложение iOS с минимальной поддерживаемой версией не ниже iOS 11;
- устройство iOS (iPhone, iPad, iPod Touch) для тестирования;
- компьютер Мас с последней версией Xcode;
- push-сертификат Production Apple Push Certificate;
- утилита CocoaPods или Swift Package Manage.
Создайте AppGroup и добавьте production-сертификат Apple
-
Авторизуйтесь в своём аккаунте Apple developer и выберите Certificates, Identifiers & Profiles.
-
Откройте вкладку Identifiers в левом меню и проверьте, зарегистрирована ли AppGroup для вашего приложения.
Идентификатор группы должен соответствовать идентификатору приложения. Например для приложения com.edna.push.demoapp группа должна называться group.com.edna.push.demoapp.
-
Если группы ещё нет, нажмите
справа от заголовка Identifiers и зарегистрируйте новую AppGroup. Запишите или запомните идентификатор — он потребуется в дальнейшем. -
Получите в Apple сертификат Production Push Certificate.
Как получить пуш-сертификат в Apple и выгрузить его в форм ате P12 -
Перейдите в раздел Настройки → Каналы → Настройка приложения iOS в личном кабинете edna Pulse.
-
Введите идентификатор приложения Bundle ID.
-
Прикрепите файл
production
пуш-сертификата в формате .p12 и введите пароль от него.
Как получить пуш-сертификат в Apple и выгрузить его в формате P12 -
Нажмите Сохранить и продолжить.
Создайте расширение Notification Service Extension
-
В проекте приложения в Xcode добавьте новый target (File → New → Target):
-
В окне Choose a template for your new target на вкладке iOS выберите тип расширения Notification Service Extension.
-
Для основного приложения на вкладке Signing & Capabilities подключите созданную на предыдущем шаге AppGroup: добавьте capability Push Notifications и Background Modes → Remote notification.
-
Для расширения Notification Service Extension на вкладке Signing & Capabilities подключите AppGroup и добавьте capability Push Notifications.
-
В файлах Info.plist в параметре
edna_app_group
для приложения и расширения укажите имя AppGroup.
Подключите библиотеки edna к проекту
Подключите библиотеки edna с помощью CocoaPods или SwiftPackageManager
Подключение библиотеки для основного приложения
- SwiftPackageManager
- CocoaPods
https://github.com/edna-ru/push-x-ios
pod ednaPushX
Подключение библиотеки для расшире ния Notification Service Extension
- SwiftPackageManager
- CocoaPods
https://github.com/edna-ru/push-x-ne-ios
pod ednaPushXNE
Интегрируйте библиотеку в коде приложения
-
В файле AppDelegate проекта добавьте следующую строку для подключения библиотеки:
- AppDelegate.swift
- AppDelegate.m
import EDNAPushX
#import <EDNAPushX/EDNAPushX.h>
-
Вставьте уникальный ключ приложения appId и инициализируйте библиотеку в методе AppDelegate
applicationDidFinishLaunchingWithOptions
. Ваш ключ appId будет находиться в блоке кода на шаге 4.2 интерактивной инстру кции по настройке приложения.- AppDelegate.swift
- AppDelegate.m
func application(_ application: UIApplication,
didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// appId – Уникальный ключ приложения
let appId =
"Вставьте appId вашего приложения из edna Pulse"
// auto_register - Автоматически показывать диалог с запросом на показ пуш-уведомлений
let pushXSettings = ["auto_register": true]
EDNAPushX.initWithLaunchOptions(options: launchOptions, appId: appId, settings: pushXSettings)
return true
}- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// appId – Уникальный ключ приложения
NSString *appId = @"Вставьте appId вашего приложения из edna Pulse";
// auto_register - Автоматически показывать диалог с запросом на показ пуш-уведомлений
NSDictionary<NSString *, id> *options = @{@"auto_register": @YES};
[EDNAPushX initWithLaunchOptionsWithOptions: launchOptions appId: appId settings: options];
return YES;
} -
Передайте в библиотеку системные вызовы в методах AppDelegate
didRegisterForRemoteNotificationsWithDeviceToken
иdidReceiveRemoteNotification
:- AppDelegate.swift
- AppDelegate.m
func application(_ application: UIApplication,
didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
EDNAPushX.setNotificationDeviceToken(deviceToken)
}
func application(_ application: UIApplication, userInfo: [AnyHashable : Any],
fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
EDNAPushX.didReceiveRemoteNotification(userInfo: userInfo, fetchCompletionHandler: completionHandler)
}- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken{
[EDNAPushX setNotificationDeviceToken: deviceToken];
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult result))completionHandler{
[EDNAPushX didReceiveRemoteNotificationWithUserInfo: userInfo fetchCompletionHandler: completionHandler];
} -
Замените код основного класса Notification Service Extension на следующий:
- NotificationService.swift
- NotificationService.m
import UserNotifications
import EDNAPushXNE
class NotificationService: UNNotificationServiceExtension {
override func didReceive(_ request: UNNotificationRequest, withContentHandler contentHandler:
@escaping (UNNotificationContent) -> Void) {
EDNAPushXNE.didReceive(request, withContentHandler: contentHandler)
}
override func serviceExtensionTimeWillExpire() {
EDNAPushXNE.serviceExtensionTimeWillExpire()
}
}#import <UserNotifications/UserNotifications.h>
#import <EDNAPushXNE/EDNAPushXNE.h>
@implementation NotificationService
- (void)didReceiveNotificationRequest:(UNNotificationRequest *)request withContentHandler:(void (^)(UNNotificationContent * _Nonnull))contentHandler {
[EDNAPushXNE didReceiveNotificationRequest: request withContentHandler: contentHandler];
}
- (void)serviceExtensionTimeWillExpire {
[EDNAPushXNE serviceExtensionTimeWillExpire];
} -
Если пользователь нажмёт на область или кнопки уведомления, будет запущено приложение. Чтобы получить от библиотеки информацию о том, что приложение было запущено по нажатию на уведомление, в метод
EDNAPushX.setOnPushAction
передайте замыкание:- AppDelegate.swift
- AppDelegate.m
EDNAPushX.setOnPushAction(block: { (action) in
...
})[EDNAPushX setOnPushActionWithBlock:^(EDNAPushXAction *action) {
...
}];
Метод EDNAPushX.setOnPushAction
нужно вызвать до инициализации библиотеки — до вызова метода EDNAPushX.initWithLaunchOptions
.