NowPushService クラス: iOS
NowPushService クラスは、プッシュ通知サービスとの対話を可能にする関数を提供します。
| 名前 | 説明 |
|---|---|
| 構成 | サービスの初期化時に指定された構成設定。 データタイプ: NowServiceConfiguration |
NowPushService - registerPushToken(_token: Data, pushAppName: String, environment: NowPushEnvironment, completion: @escaping (Result<Data, NowPushError>) -> Void)
現在のiOSデバイスと指定されたアプリケーションのプッシュ通知を識別するために使用するServiceNowインスタンスに一意のトークンを登録します。
| 名前 | タイプ | 説明 |
|---|---|---|
| _トークン | データ | 登録するプッシュトークンのデータオブジェクト。これは、 Apple Developer サイトから取得したトークンです。詳細については、『 Mobile SDK 開発者ガイド - iOS』を参照してください。 |
| プッシュアプリ名 | 文字列 | このトークンが登録されているプッシュアプリケーションの名前。 |
| 環境 | NowPush環境 | トークンが登録されている環境。 有効な値:
|
| 完了 | @escaping (result<data, NowPushError>) → void | トークンの登録が試行された後に実行される補完ハンドラー。
|
| タイプ | 説明 |
|---|---|
| なし |
この例では、TestPushApp アプリケーションのプッシュ通知トークンを登録する方法を示します。
func registerForPushNotifications(deviceToken: Data) {
pushService.registerPushToken(deviceToken,
pushAppName: "TestPushApp",
environment: environment) { [weak self] result in
guard let self = self else { return }
switch result {
case .success:
UserDefaults.standard.set(true, forKey: "pushNotificationsRegistered")
self.pushRegistrationState = .registrationSuccess
case .failure:
UserDefaults.standard.set(false, forKey: "pushNotificationsRegistered")
self.pushRegistrationState = .registrationFailed
}
}
}
NowPushService - unregisterPushToken(_token: Data, pushAppName: String, environment: NowPushEnvironment, completion: @escaping (Result<Data, NowPushError>) -> Void)
以前に登録したプッシュトークンを登録解除します。
| 名前 | タイプ | 説明 |
|---|---|---|
| _トークン | データ | 登録解除するプッシュトークンのデータオブジェクト。 |
| プッシュアプリ名 | 文字列 | このトークンが登録解除されるプッシュ アプリケーションの名前。 |
| 環境 | NowPush環境 | トークンが登録されている環境。 有効な値:
|
| 完了 | @escaping (result<data, NowPushError>) → void | トークンの登録解除が試行された後で実行する補完ハンドラー。
|
| タイプ | 説明 |
|---|---|
| なし |
この例では、TestPushApp アプリケーションに関連付けられたプッシュ通知トークンの登録を解除する方法を示します。
func unregisterFromPushNotifications(deviceToken: Data) {
pushService.unregisterPushToken(deviceToken, pushAppName: "TestPushApp", environment: environment) { [weak self] result in
guard let self = self else { return }
switch result {
case .success:
UserDefaults.standard.set(false, forKey: "pushNotificationsRegistered")
self.pushRegistrationState = .unregisterSuccess
case .failure:
self.pushRegistrationState = .unregisterFailed
}
}
}
NowPushService:payloadFromUserInfo(_userInfo: [AnyHashable: Any])
userInfo キーと値のペアを解析して NowPushPayload オブジェクトにします。
| 名前 | タイプ | 説明 |
|---|---|---|
| _userInfo | [AnyHashable:任意] | プッシュ通知の一部として受信したプッシュペイロードコンテンツ。 |
| タイプ | 説明 |
|---|---|
| 結果<NowPushPayload、NowPushError> | ペイロード解析の結果を返します。
|
この例では、ユーザーペイロードをパーサーする方法を示します。
func userNotificationCenter(_ center: UNUserNotificationCenter,
didReceive response: UNNotificationResponse,
withCompletionHandler completionHandler: @escaping () -> Void) {
guard let pushService = pushService else {
completionHandler()
return
}
let userInfo = response.notification.request.content.userInfo
_ = pushService.payloadFromUserInfo(userInfo)
.flatMap(handleNowPushPayload)
}
func handleNowPushPayload(_ payload: NowPushPayload) -> Result<Void, NowPushError> {
guard payload is NowPushVirtualAgent else {
return .failure(NowPushError.unsupportedData)
}
launchVirtualAgent()
return .success(())
}