Notificações push push-notifications
Ser capaz de alertar instantaneamente seus usuários de aplicativo móvel Adobe Experience Manager (AEM) com notificações importantes é fundamental para o valor de um aplicativo móvel e suas campanhas de marketing. Aqui, as etapas são descritas para permitir que seu aplicativo receba notificações por push. Você também aprenderá a configurar e enviar mensagens de push do AEM Mobile para o aplicativo instalado no telefone. Além disso, esta seção descreve como configurar o recurso de Deep Linking para suas notificações por push.
O uso de notificações por push com AEM requer algumas tecnologias diferentes. Primeiro, um provedor de serviços de notificação por push deve ser usado para gerenciar notificações e dispositivos (o AEM ainda não faz isso). Dois provedores estão configurados com AEM: Amazon Simple Notification Service (ou SNS) e Pushwoosh. Em segundo lugar, a tecnologia de push para determinado SO móvel deve passar pelo serviço apropriado — Serviço de notificação por push (ou APNS) da Apple para dispositivos iOS e Google Cloud Messaging (ou GCM) para dispositivos Android™. Embora o AEM não se comunique diretamente com esses serviços específicos da plataforma, algumas informações de configuração relacionadas devem ser fornecidas pelo AEM junto com as notificações para que esses serviços executem o push.
Depois de instalado e configurado (conforme explicado abaixo), ele funciona assim:
- Uma notificação por push é criada no AEM e enviada ao provedor de serviços (Amazon SNS ou Pushwoosh).
- O provedor de serviços o recebe e o envia para o provedor principal (APNS ou GCM).
- O provedor principal envia a notificação para todos os dispositivos registrados para esse envio. Para cada dispositivo, ele usa a rede de dados celular ou WiFi, o que estiver disponível no dispositivo.
- A notificação é exibida no dispositivo se o aplicativo para o qual ele está registrado não estiver em execução. Um usuário que tocar na notificação inicia o aplicativo e exibe a notificação no aplicativo. No caso de o aplicativo já estar em execução, somente a notificação no aplicativo é exibida.
Essa versão do AEM é compatível com dispositivos móveis iOS e Android™.
Visão geral e procedimento overview-and-procedure
Para usar notificações por push em um aplicativo AEM Mobile, as seguintes etapas de alto nível devem ser executadas.
Normalmente, um desenvolvedor de Experience Manager faz o seguinte:
- Registre-se nos serviços de mensagens da Apple e da Google
- Registrar com um serviço de mensagens por push e configurá-lo
- Adicionar suporte de push ao aplicativo
- Preparar um telefone para teste
Enquanto um Administrador de Experience Manager faz o seguinte:
- Configurar push em aplicativos AEM
- Criar e implantar o aplicativo
- Enviar uma notificação por push
- Configurar deep linking (opcional)
Etapa 1: Registrar-se nos serviços de mensagens do Apple e Google step-register-with-apple-and-google-messaging-services
Uso do Serviço de notificação por push da Apple (APNS) using-the-apple-push-notification-service-apns
Acesse a página do Apple aqui para se familiarizar com o Serviço de Notificação por Push da Apple.
Para usar APNs, você precisa de um arquivo Certificado (um arquivo .cer), um push Chave privada (um arquivo .p12) e uma Senha de Chave Privada da Apple. As instruções sobre como fazer isso podem ser encontradas aqui.
Uso do serviço Google Cloud Messaging (GCM) using-the-google-cloud-messaging-gcm-service
Acesse a página do Google aqui para se familiarizar com o Google Cloud Messaging for Android™.
Siga estas etapas para Criar um projeto de API do Google, Habilitar o Serviço GCM e Obter uma Chave de API. Você precisa da Chave de API para enviar notificações por push para dispositivos Android™. Além disso, registre seu Número do Projeto, que às vezes também é chamado de ID de Remetente do GCM.
As etapas a seguir mostram um método diferente de criação de chaves de API do GCM:
- Faça logon no google e acesse a página Desenvolvedor da Google.
- Escolha seu aplicativo na lista (ou crie um).
- Em Nome do Pacote da Android™, digite a ID do aplicativo, ou seja,
com.adobe.cq.mobile.weretail.outdoorsapp
. (Se isso não funcionar, tente novamente com "test.test".) - Clique em Continuar para Escolher e configurar serviços
- Selecione Cloud Messaging e clique em Habilitar o Google Cloud Messaging.
- A nova Chave da API do servidor e a ID do remetente (nova ou existente) serão exibidas.
Etapa 2: Registrar e configurar um serviço de mensagens por push step-register-and-configure-a-push-messaging-service
O AEM está configurado para usar um dos três serviços para notificações por push:
- Amazon SNS
- Pushwoosh
- Adobe Mobile Services
As configurações do Amazon SNS e do Pushwoosh permitem enviar mensagens enviadas por push de dentro das telas AEM.
A configuração do Adobe Mobile Services permite configurar e enviar notificações por push de dentro do Adobe Mobile Services usando uma conta Adobe Analytics (mas o aplicativo deve ser criado com esse conjunto de configurações para habilitar notificações por push do AMS).
Uso do serviço de mensagens Amazon SNS using-the-amazon-sns-messaging-service
Se você não quiser usar o Amazon SNS, ignore essas etapas.
Siga estas etapas para configurar o Amazon SNS para notificações por push:
-
Registrar-se no Amazon SNS
- Registre sua ID de conta. O formato deve ser de 12 dígitos sem espaços ou traços, ou seja, "123456789012".
- Verifique se você está na região "us-east" ou "eu", pois uma etapa posterior (Criação do pool de identidade) exigirá uma dessas.
- Depois de se registrar, faça logon no console de gerenciamento e selecione SNS (Serviço de Notificação por Push). Clique em "Introdução" se for exibido.
-
Criar Chave e ID de Acesso
- Clique no nome de login no canto superior direito da tela e escolha Credenciais de segurança no menu.
- Clique em Teclas de Acesso e, no espaço abaixo, clique em Criar Nova Tecla de Acesso.
- Clique em Mostrar Chave de Acesso, copie e salve a ID da Chave de Acesso e a Chave de Acesso Secreta exibidas. Se você escolher a opção para baixar as chaves, obterá um arquivo csv que contém esses mesmos valores.
- Outros certificados relacionados à segurança e alguns outros, podem ser gerenciados nesta página.
note note NOTE Uma Chave de Acesso pode ser usada para vários aplicativos. Para organizações que usam uma conta "AWS Sandbox", as etapas são semelhantes e descritas aqui:
- Clique no nome de login no canto superior direito da tela e escolha Minhas credenciais de segurança no menu.
- Clique em Usuários na lista de ações à esquerda e escolha seu nome de usuário.
- Clique na guia Credenciais de segurança.
- Aqui, você verá suas chaves e criará novas chaves. Salve as chaves para uso posterior.
-
Criar um Tópico
- Clique em Criar tópico e escolha um nome de tópico. Registre todos os campos, como Tópico ARN, Proprietário do tópico, Região, Nome de exibição.
- Clique em Outras ações de tópico > Editar política de tópico. Em Permitir que esses usuários assinem este tópico, selecione Todos.
- Clique em Atualizar Política.
note note NOTE Você pode criar vários tópicos para diferentes cenários, como desenvolvimento, teste e demonstração. O restante da configuração do SNS pode permanecer o mesmo. Crie o aplicativo com um tópico diferente; as notificações por push enviadas para esse tópico serão recebidas somente pelo aplicativo criado com esse tópico. -
Criar Aplicativos de Plataforma
-
Clique em Aplicativos e, em seguida, em Criar Aplicativo de Plataforma. Escolha um nome e selecione uma plataforma (APNS para iOS, GCM para Android™). Dependendo da plataforma. outros campos devem ser preenchidos:
- Para APNS, um arquivo P12, uma Senha, um Certificado e uma Chave privada devem ser inseridos. Estes devem ter sido obtidos na etapa Usando o Serviço de Notificação por Push (APNS) da Apple acima.
- Para o GCM, uma chave de API deve ser inserida. Isso deveria ter sido obtido na etapa Uso do serviço Google Cloud Messaging (GCM) acima.
-
Repita a etapa acima uma vez para cada plataforma que você estiver suportando. Para enviar para o iOS e o Android™, dois aplicativos de plataforma devem ser criados.
-
-
Criar um Pool de Identidade
- Use o Conector para criar um Pool de Identidade, que armazenará dados básicos de usuários não autenticados. No momento, somente as regiões "us-east" e "eu" são compatíveis com o Amazon Cognito.
- Nomeie-o e marque a caixa "Habilitar acesso a identidades não autenticadas".
- Na próxima página ("Suas identidades Cognito exigem acesso aos seus recursos") clique em Permitir.
- Na parte superior direita da página, clique no link "Editar pool de identidades". A ID do pool de identidade é exibida. Salvar este texto para mais tarde.
- Na mesma página, escolha a lista suspensa ao lado de "Função não autenticada" e verifique se ela tem a função Cognito_<pool name>UnauthRole selecionada. Salve as alterações.
-
Configurar Acesso
- Faça logon no Identity and Access Management (IAM).
- Selecione Funções.
- Clique na função criada na etapa anterior, chamada Cognito_<yourIdentityPoolName>Unauth_Role. Registre o "Role ARN" exibido.
- Abra "Políticas em linha" se ainda não estiver aberto. Você deve ver uma política com um nome como oneClick_Cognito_<yourIdentityPoolName>Unauth_Role_1234567890123.
- Clique em "Editar política". Substitua o conteúdo do Documento de política por este trecho de JSON:
table 0-row-1 html-authored no-header {
"Version": "10-17-2012",
"Declaração": [
{
"Ação": [
"mobileanalytics:PutEvents",
"cognito-sync:*",
"SNS:CreatePlatformEndpoint",
"SNS:Assinar"
],
"Effect": "Allow",
"Resource": [
"*"
]
}
]
}
- Clique em Aplicar política.
Uso do serviço de mensagens Pushwoosh using-the-pushwoosh-messaging-service
Se você não quiser usar o Pushwoosh, ignore esta etapa.
Para usar Pushwoosh:
-
Registrar-se no Pushwoosh
- Acesse pushwoosh.com e crie uma conta.
-
Criar um token de acesso de API
- No site Pushwoosh, acesse o item de menu Acesso à API para gerar um Token de acesso à API. Grave este token com segurança.
-
Criar um aplicativo
- Para obter suporte da Android™, você deve fornecer sua chave de API GCM.
- Ao configurar o aplicativo, escolha Cordova como a estrutura.
- Para obter suporte ao iOS, você deve fornecer o arquivo de certificado (.cer), o certificado push (.p12) e a senha da chave privada; eles devem ter sido obtidos no site APNS da Apple. Para Estrutura, escolha Cordova.
- O Pushwoosh gerará uma ID do aplicativo para ele, no formato "XXXXX-XXXXX", em que cada X é um valor hexadecimal (0 a F).
Etapa 3: adicionar suporte por push ao aplicativo step-add-push-support-to-the-app
Adicionar configuração ContentSync add-contentsync-configuration
Crie dois nós de conteúdo (um no app-config e um no app-config-dev) chamados notificationsConfig:
- /content/
<your app>
/shell/jcr:content/page-app/app-config-dev/notificationsConfig - /content/
<your app>
/shell/jcr:content/page-app/app-config/notificationsConfig
Com estas propriedades (arquivos .content.xml) :
<jcr:root xmlns:jcr=" https://developer.adobe.com/experience-manager/reference-materials/spec/jcr/1.0/index.html" xmlns:nt=" https://developer.adobe.com/experience-manager/reference-materials/spec/jcr/1.0/index.html"
jcr:primaryType="nt:unstructured"
excludeProperties="[appAPIAccessToken]"
path="…/…/…/…"
targetRootDirectory="www"
type="notificationsconfig"/>
Adicionar bibliotecas de clientes add-client-libraries
As bibliotecas de clientes de notificação por push devem ser adicionadas ao aplicativo seguindo estas etapas:
CRXDE Lite:
- Navegue até /etc/designs/phonegap/<app name>/clientlibsall.
- Clique duas vezes na seção incorporada no painel de propriedades.
- Na caixa de diálogo exibida, adicione uma biblioteca do cliente clicando no botão +.
- No novo campo de texto, adicione "cq.mobile.push" e clique em OK.
- Adicione mais um chamado cq.mobile.push.amazon e clique em OK.
- Salve as alterações.
Etapa 4: Preparar um telefone para teste step-prepare-a-phone-for-testing
IOS ios
Para o iOS, use um computador macOS e participe do iOS Developer Program. Algumas corporações têm licenças corporativas que podem estar disponíveis para todos os desenvolvedores.
Com o XCode 8.1, antes de usar notificações por push, você deve ir para a guia Recursos em seu projeto e ativar ou desativar as notificações por push.
Android™ android
Para instalar o aplicativo em um telefone Android™ usando a CLI (veja abaixo: Etapa 6 - Criar e implantar o aplicativo), primeiro coloque o telefone no "modo de desenvolvedor". Consulte Habilitando opções de desenvolvedor no dispositivo para obter detalhes sobre como fazer isso.
Etapa 5: configurar o push em aplicativos AEM step-configure-push-on-aem-apps
Antes de criar e implantar em seu dispositivo móvel configurado, você deve definir as configurações de notificação para o serviço de mensagens que decidiu usar.
- Crie os grupos de autorização apropriados para notificações por push.
- Faça logon no AEM como o usuário apropriado, clique na guia Aplicativos.
- Clique no aplicativo.
- Localize o bloco Gerenciar Cloud Service e clique no lápis para modificar as configurações de nuvem.
- Selecione Amazon SNS Connection, Pushwoosh Connection ou Adobe Mobile Services, como a configuração de notificação.
- Insira as propriedades do provedor e clique em Enviar para salvá-las e em Concluído. Eles não são verificados remotamente nesse estágio, exceto se houver AMS.
- Agora você deve ver a configuração inserida no bloco Gerenciar Cloud Service.
Etapa 6: criar e implantar o aplicativo step-build-and-deploy-the-app
Observação: veja as instruções aqui sobre como criar aplicativos PhoneGap.
Há duas maneiras de criar e implantar seu aplicativo usando o PhoneGap.
Observação: para testes de notificação por push, os emuladores não serão suficientes porque as notificações por push usam um protocolo distinto entre o provedor de push (Apple ou Google) e o dispositivo. Os emuladores e o hardware atuais do Mac/PC não suportam esse recurso.
-
O PhoneGap Build é um serviço oferecido pelo PhoneGap que criará seu aplicativo nos servidores deles e permitirá que você o baixe diretamente no seu dispositivo. Consulte a documentação de PhoneGap Build em
https://build.phonegap.com/
para saber como configurar e usar o PhoneGap Build. -
A Interface de Linha de Comando do PhoneGap (CLI) permite usar um conjunto avançado de comandos do PhoneGap na linha de comando para compilar, depurar e implantar seu aplicativo. Consulte a documentação do desenvolvedor do PhoneGap (
https://docs.phonegap.com/en/edge/guide_cli_index.md.html#The%20Command-Line%20Interface
) para saber como configurar e usar a CLI do PhoneGap.
Etapa 7: enviar uma notificação por push step-send-a-push-notification
Para criar uma notificação e enviá-la, siga estas etapas.
-
Criar uma notificação
- No painel do aplicativo AEM Mobile, localize o bloco Notificações por push.
- No menu no canto superior direito, escolha "Criar". Esse botão não estará disponível até que a configuração na nuvem seja definida pela primeira vez.
- No Assistente de criação de notificações, digite um título e uma mensagem e clique no botão "Criar". Sua notificação agora está pronta para ser enviada imediatamente ou mais tarde. Ele pode ser editado e a mensagem e/ou o título podem ser alterados e salvos.
-
Enviar a notificação
- No painel Aplicativos, localize o bloco Notificações por push.
- Selecione a notificação ou clique no botão de detalhes na parte inferior direita (. . .), para mostrar a lista de notificações. Essa lista também indica se uma notificação está pronta para ser enviada, se já foi enviada ou se ocorreu um erro durante o envio.
- Marque a caixa de seleção de uma notificação (apenas) e clique no botão "Enviar notificação" acima da lista. Você tem uma chance de "Cancelar" ou "Enviar" a notificação na caixa de diálogo exibida.
-
Tratamento dos resultados
-
Se o serviço de notificação por push (Amazon SNS ou Pushwoosh) receber a solicitação de envio, confirmá-la como válida e enviá-la aos provedores nativos (APNS e GCM) com êxito, a caixa de diálogo de envio será fechada sem nenhuma mensagem. Na lista de notificações, o status dessa notificação é listado como Enviado.
-
Se o envio por push falhar, a caixa de diálogo mostrará uma mensagem indicando o problema. Na lista de notificações, o status dessa notificação é listado como Erro, mas se o problema for retificado, a notificação poderá ser enviada novamente. Se houver um erro, informações adicionais sobre o erro deverão aparecer no log de erros do servidor.
-
Observe que há algumas diferenças de plataforma entre as notificações por push do iOS e do Android™. Entre eles:
- A compilação com CLI iniciará o aplicativo após a implantação no Android™. No iOS, é necessário iniciá-lo manualmente. Como a etapa de registro por push ocorre na inicialização, os aplicativos Android™ podem receber notificações por push imediatamente (porque já foram iniciados e registrados), enquanto os aplicativos iOS não podem.
- No Android™, o texto do botão OK está em maiúsculas (e em qualquer outro botão adicionado à notificação no aplicativo), enquanto no iOS não está.
-
Para notificações por push do AMS, as notificações devem ser compostas e enviadas do servidor AMS. O AMS fornece recursos adicionais de notificação por push além daqueles fornecidos pelas notificações do AEM com o AWS e o Pushwoosh.
Configuração de deep linking com notificações por push configuring-deep-linking-with-push-notifications
O que é Deep Linking? No contexto de uma notificação por push, é um meio de permitir que um aplicativo seja aberto ou direcionado (se estiver aberto) para um local especificado dentro do aplicativo.
Como funciona? O autor de uma notificação por push adiciona opcionalmente um rótulo de botão (ou seja, "Mostre-me!") à notificação e escolhe a página que gostaria de vincular na notificação, por meio de um navegador de caminho visual. Quando enviado, o push ocorre normalmente, exceto que na mensagem no aplicativo, o botão OK é substituído por um botão "Dispensar" e o novo botão é especificado ("Mostrar-me!") também é exibida. Clicar no botão new faz com que o aplicativo vá para a página especificada no aplicativo. Clicar em Dispensar elimina a mensagem.
Se o aplicativo não estiver aberto, a sombra será exibida normalmente. Realizar uma ação na notificação na sombra abre o aplicativo e, em seguida, apresenta ao usuário os botões de deep link com base no que foi configurado na notificação por push.
Crie a notificação, adicione um texto de botão e um caminho de link para o deep link opcional:
-
Clique na edição no canto superior direito do bloco Gerenciar Cloud Service.
-
Selecione a Conexão Pushwoosh. Clique em Avançar.
-
Insira os detalhes das propriedades e clique em Enviar.
Depois de enviar a configuração, o bloco Notificações por push será exibido no painel.
Criar assistente de notificação create-notification-wizard
Depois que o bloco Notificações por push for exibido no painel, use o assistente de criação de notificações para adicionar o conteúdo:
-
Clique no símbolo de adição no canto superior direito do bloco Notificações por push para abrir o Assistente de Criação de Notificações.
-
Clicar no ícone de navegação no caminho do link apresenta ao usuário a estrutura de conteúdo do aplicativo.
Depois de selecionar o caminho, clique no ícone de verificação.
note note NOTE O texto do botão Link é limitado a 20 caracteres. Se o usuário final não tiver a versão mais recente do aplicativo e o caminho vinculado não estiver disponível, confirmar a ação do deep link levará o usuário para a página principal do aplicativo. -
Insira os Detalhes do Texto no Assistente de Criação de Notificações e clique em Criar.
Abra os detalhes clicando na notificação por push criada a partir do bloco Notificações por push.
Você pode editar propriedades, enviar notificações ou excluir a notificação.
Próximas etapas the-next-steps
Assim que você entender os detalhes sobre notificações por push para seu aplicativo, consulte AEM Mobile Content Personalization.