Classe NowPushService - iOS
. NowPushService A classe fornece funções que permitem a interação com o serviço de Notificação por push.
| Nome | Descrição |
|---|---|
| configuração | Definições de configuração fornecidas quando o serviço foi inicializado. Tipo de dados: NowServiceConfiguration |
NowPushService - registerPushToken(_token: Dados, pushAppName: Cadeia de caracteres, ambiente: NowPushEnvironment, conclusão: Escape (<Data, NowPushError>) -> Vazio)
Registra um token exclusivo com ServiceNow instância usada para identificar as notificações por push do atual iOS dispositivo e aplicação especificada.
| Nome | Tipo | Descrição |
|---|---|---|
| _token | Dados | Objeto de dados do token de push a ser registrado. Este é o token obtido do Apple Site do desenvolvedor. Para obter mais informações, consulte Mobile SDK Guia do desenvolvedor - iOS. |
| PushAppName | Cadeia de caracteres | Nome da aplicação de envio para a qual este token está sendo registrado. |
| ambiente | NowPushEnvironment | Ambiente para o qual o token está sendo registrado. Valores válidos:
|
| conclusão | Escaping (Result<Data, NowPushError>) → Vazio | Manipulador de conclusão a ser executado após a tentativa de registro do token.
|
| Tipo | Descrição |
|---|---|
| Nenhum(a) |
Este exemplo mostra como registrar um token de notificação por push para a aplicação 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: Cadeia de caracteres, ambiente: NowPushEnvironment, conclusão: Escape (<Data, NowPushError>) -> Vazio)
Cancela o registro de um token de push registrado anteriormente.
| Nome | Tipo | Descrição |
|---|---|---|
| _token | Dados | Objeto de dados do token de push para cancelar o registro. |
| PushAppName | Cadeia de caracteres | Nome da aplicação de push para a qual este token está sendo cancelado. |
| ambiente | NowPushEnvironment | Ambiente para o qual o token está sendo registrado. Valores válidos:
|
| conclusão | Escaping (Result<Data, NowPushError>) → Vazio | Manipulador de conclusão a ser executado após a tentativa de cancelar o registro do token.
|
| Tipo | Descrição |
|---|---|
| Nenhum(a) |
Este exemplo mostra como cancelar o registro do token de notificação por push associado à aplicação 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])
Analisa o. Userinfo pares de chave-valor em um NowPushPayload objeto.
| Nome | Tipo | Descrição |
|---|---|---|
| _Userinfo | [AnyHashable: Qualquer] | Conteúdo de carga de push recebido como parte da notificação por push. |
| Tipo | Descrição |
|---|---|
| <NowPushPayload, NowPushError> | Retorna os resultados da análise de carga.
|
Este exemplo mostra como analisar a carga útil de um usuário.
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(())
}