1. Visão geral
Neste codelab, você aprenderá a usar o AngularFire (em inglês) para criar aplicativos da Web implementando e implantando um cliente de chat com produtos e serviços do Firebase.
O que você vai aprender
- Criar um app da Web usando o Angular e o Firebase.
- Sincronizar dados usando o Cloud Firestore e o Cloud Storage para Firebase.
- Autentique seus usuários usando o Firebase Authentication.
- Implantar seu app da Web no Firebase App Hosting.
- Enviar notificações com o Firebase Cloud Messaging
- Colete os dados de desempenho do seu app da Web.
Pré-requisitos
- Uma conta no GitHub
- A capacidade de fazer upgrade do seu projeto do Firebase para o plano de preços Blaze
- O ambiente de desenvolvimento integrado/editor de texto que você preferir, como WebStorm, Sublime ou VS Code
- O npm do gerenciador de pacotes, que normalmente acompanha o Node.js
- Um terminal/console
- Um navegador de sua escolha, como o Chrome
- O exemplo de código do codelab. Consulte a próxima etapa para saber como acessar o código.
2. Acessar o exemplo de código
Crie um repositório do GitHub
A origem do codelab pode ser encontrada em https://github.com/firebase/codelab-friendlychat-web. O repositório contém projetos de amostra para várias plataformas. No entanto, este codelab usa apenas o diretório angularfire-start
.
Copie a pasta angularfire-start
para seu próprio repositório:
- Usando um terminal, crie uma pasta no computador e acesse o novo diretório:
mkdir codelab-friendlyeats-web cd codelab-friendlyeats-web
- Use o pacote npm giget para buscar apenas a pasta
angularfire-start
:npx giget@latest gh:firebase/codelab-friendlychat-web/angularfire-start#master . --install
- Rastreie as alterações localmente com o git:
git init git add . git commit -m "codelab starting point" git branch -M main
- Crie um novo repositório do GitHub: https://github.com/new. Dê o nome que quiser a ele.
- O GitHub fornecerá um novo URL do repositório que se parece com
https://github.com/[user-name]/[repository-name].git
ougit@github.com:[user-name]/[repository-name].git
. Copie este URL.
- O GitHub fornecerá um novo URL do repositório que se parece com
- Envie as alterações locais para o novo repositório do GitHub. Execute o comando a seguir, substituindo o URL do repositório pelo marcador de posição
your-repository-url
.git remote add origin your-repository-url git push -u origin main
- Agora você verá o código inicial no seu repositório do GitHub.
3. Criar e configurar um projeto do Firebase
Criar um projeto do Firebase
- Faça login no Console do Firebase.
- No Console do Firebase, clique em Adicionar projeto e nomeie seu projeto do Firebase como FriendlyChat. Lembre-se do ID do seu projeto do Firebase.
- Desmarque a opção Ativar o Google Analytics para este projeto.
- Clique em Criar projeto.
O aplicativo que você vai criar usa produtos do Firebase disponíveis para apps da Web:
- Firebase Authentication para permitir que os usuários façam login no seu app com facilidade.
- Cloud Firestore: é usado para salvar dados estruturados na nuvem e receber notificações instantâneas quando os dados são alterados.
- Cloud Storage para Firebase: é usado para salvar arquivos na nuvem.
- Firebase App Hosting para criar, hospedar e exibir o app.
- Firebase Cloud Messaging: é usado para enviar notificações push e exibir notificações pop-up do navegador.
- Monitoramento de desempenho do Firebase para coletar dados de desempenho do usuário sobre seu app.
Alguns desses produtos precisam de configuração especial ou precisam ser ativados usando o Console do Firebase.
Fazer upgrade do plano de preços do Firebase
Para usar o App Hosting, seu projeto do Firebase precisa estar no plano de preços Blaze, o que significa que ele está associado a uma conta do Cloud Billing.
- Uma conta do Cloud Billing exige uma forma de pagamento, como cartão de crédito.
- Se você ainda não conhece o Firebase e o Google Cloud, confira se tem qualificação para receber um crédito de US $300 e uma conta de teste gratuito do Cloud Billing.
Para fazer upgrade do seu projeto para o plano Blaze, siga estas etapas:
- No console do Firebase, selecione Fazer upgrade do seu plano.
- Na caixa de diálogo, selecione o plano Blaze e siga as instruções na tela para associar seu projeto a uma conta do Cloud Billing.
Se precisar criar uma conta do Cloud Billing, talvez seja necessário voltar para o upgrade no console do Firebase para concluir o upgrade.
Adicionar um app da Web do Firebase ao projeto
- Clique no ícone da Web para criar um novo app da Web do Firebase.
- Registre o app com o apelido Friendly Chat. Não marque a caixa ao lado de Também configurar o Firebase Hosting para este app. Clique em Registrar app.
- Na próxima etapa, você verá um objeto de configuração. Você não precisa dele no momento. Clique em Continuar para o Console.
Configurar o Authentication
Para permitir que os usuários façam login no app da Web com as Contas do Google deles, você usará o método de login do Google.
- No console do Firebase, navegue até Autenticação.
- Clique em Começar.
- Na coluna Outros provedores, clique em Google > Ativar.
- Na caixa de texto Nome voltado ao público do projeto, digite um nome fácil de lembrar, como
My Next.js app
. - No menu suspenso E-mail de suporte do projeto, selecione seu endereço de e-mail.
- Clique em Salvar.
Ativar o Cloud Firestore
O app da Web usa o Cloud Firestore para salvar e receber novas mensagens de chat.
Você precisará ativar o Cloud Firestore:
- No console do Firebase, navegue até o Firestore.
- Clique em Criar banco de dados > Próximo > Iniciar no modo de teste > Próxima.
Mais adiante neste codelab, você vai adicionar regras de segurança para proteger seus dados. Não distribua ou exponha um aplicativo publicamente sem adicionar regras de segurança ao seu banco de dados. - Use o local padrão ou selecione um local de sua escolha.
No caso de apps reais, escolha um local próximo aos usuários. Não é possível alterar o local depois. Ele também será automaticamente o local do seu bucket padrão do Cloud Storage (próxima etapa). - Clique em Concluído.
Ativar o Cloud Storage
O app da Web usa o Cloud Storage para Firebase para armazenar, fazer upload e compartilhar imagens.
É necessário ativar o Cloud Storage:
- No console do Firebase, navegue até Armazenamento.
- Clique em Primeiros passos > Iniciar no modo de teste > Próxima.
Mais adiante neste codelab, você vai adicionar regras de segurança para proteger seus dados. Não distribua ou exponha um aplicativo publicamente sem adicionar regras de segurança ao bucket do Storage. - O local do seu bucket já deve estar selecionado (devido à configuração do Firestore na etapa anterior).
- Clique em Concluído.
4. Instalar a interface de linha de comando do Firebase
A interface de linha de comando (CLI) do Firebase permite que você use o Firebase Hosting para disponibilizar seu app da Web localmente e implantá-lo no seu projeto do Firebase.
- Execute o seguinte comando npm para instalar a CLI:
npm -g install firebase-tools@latest
- Execute o comando a seguir para verificar se a CLI foi instalada corretamente:
firebase --version
Verifique se a versão da CLI do Firebase é a v13.9.0 ou mais recente.
- Autorize a CLI do Firebase executando o seguinte comando:
firebase login
Você definiu o modelo de app da Web para receber a configuração do seu app para o Firebase Hosting do diretório local do app (o repositório que você clonou anteriormente no codelab). No entanto, para receber a configuração, você precisa associar seu app ao projeto do Firebase.
- Verifique se a linha de comando está acessando o diretório local
angularfire-start
do app. - Associe o app ao projeto do Firebase executando o seguinte comando:
firebase use --add
- Quando solicitado, selecione o ID do projeto e atribua um alias ao projeto do Firebase.
Um alias será útil se você tiver vários ambientes (produção, preparo etc.). No entanto, neste codelab, vamos usar apenas o alias de default
.
- Siga as instruções restantes na linha de comando.
5. Instalar o AngularFire
Antes de executar o projeto, verifique se você configurou a CLI do Angular e o AngularFire.
- Em um console, execute o seguinte comando:
npm install -g @angular/cli
- Em seguida, em um console do diretório
angularfire-start
, execute o seguinte comando da CLI do Angular:
ng add @angular/fire
Isso vai instalar todas as dependências necessárias para o projeto.
- Quando solicitado, desmarque
ng deploy -- hosting
com a barra de espaço. Selecione os seguintes recursos com as teclas de seta e a barra de espaço:Authentication
Firestore
Cloud Messaging
Cloud Storage
- Pressione
enter
e siga as outras instruções. - Criar um commit com a mensagem "Install AngularFire" e enviá-lo para o repositório do GitHub.
6. Criar um back-end do App Hosting
Nesta seção, você vai configurar um back-end do App Hosting para monitorar uma ramificação no seu repositório git.
Ao final desta seção, você terá um back-end de hospedagem de apps conectado ao seu repositório no GitHub. Ele vai recriar e lançar automaticamente uma nova versão do app sempre que você enviar uma nova confirmação para a ramificação main
.
- Navegue até a página "App Hosting" no Console do Firebase:
- Clique em "Começar" para iniciar o fluxo de criação de back-end. Configure seu back-end da seguinte maneira:
- Siga as instruções da primeira etapa para conectar o repositório do GitHub criado anteriormente.
- Defina as configurações de implantação:
- Mantenha o diretório raiz como
/
- Defina a ramificação ativa como
main
- Ativar os lançamentos automáticos
- Mantenha o diretório raiz como
- Nomeie seu back-end como
friendlychat-codelab
. - Em "Criar ou associar um app da Web do Firebase", escolha o app da Web que você configurou anteriormente em "Selecionar um app da Web atual do Firebase". no menu suspenso.
- Clique em "Concluir e implantar". Depois de um momento, você será direcionado para uma nova página onde poderá ver o status do seu novo back-end do App Hosting.
- Quando o lançamento for concluído, clique no seu domínio gratuito em "Domínios". Pode levar alguns minutos para começar a funcionar devido à propagação do DNS.
Você implantou o app da Web inicial. Toda vez que você enviar uma nova confirmação para a ramificação main
do repositório do GitHub, uma nova versão e o lançamento serão iniciados no Console do Firebase, e seu site será atualizado automaticamente assim que o lançamento for concluído.
Você verá a tela de login do app FriendlyChat, que (ainda) não está funcionando.
No momento, o app não pode fazer nada, mas com sua ajuda, isso vai mudar em breve.
Agora, vamos criar um aplicativo de chat em tempo real.
7. Importar e configurar o Firebase
Configurar o Firebase
É necessário configurar o SDK do Firebase para informar qual projeto do Firebase você está usando.
- Acesse as Configurações do projeto no Console do Firebase.
- Na janela cartão, selecione o apelido do aplicativo para o qual você precisa de um objeto de configuração.
- Selecione "Configuração". no painel de snippets do SDK do Firebase.
Você verá que um arquivo de ambiente /angularfire-start/src/environments/environment.ts
foi gerado.
- Copie o snippet do objeto de configuração e adicione-o a
angularfire-start/src/firebase-config.js
.
environment.ts
export const environment = {
firebase: {
apiKey: "API_KEY",
authDomain: "PROJECT_ID.firebaseapp.com",
projectId: "PROJECT_ID",
storageBucket: "PROJECT_ID.appspot.com",
messagingSenderId: "SENDER_ID",
appId: "APP_ID",
},
};
Ver a configuração do AngularFire
Você vai notar que os recursos selecionados no console foram adicionados automaticamente ao arquivo /angularfire-start/src/app/app.config.ts
. Isso permite que o app use os recursos e as funcionalidades do Firebase.
8. Configurar o login do usuário
O AngularFire agora está pronto para uso, porque foi importado e inicializado em app.config.ts
. Agora você vai implementar o login do usuário com o Firebase Authentication.
Adicione um domínio autorizado
O Firebase Authentication só permite logins de uma lista definida de domínios controlados por você. Adicione seu domínio sem custo financeiro de hospedagem de apps à lista de domínios:
- Navegue até App Hosting.
- Copie o domínio do back-end.
- Acesse Configurações de autenticação.
- Escolha a guia Domínios autorizados.
- Clique em Adicionar domínio e cole o domínio do back-end do App Hosting.
Autenticar seus usuários com o Login do Google
No app, quando um usuário clica no botão Fazer login com o Google, a função login
é acionada. Neste codelab, você quer autorizar o Firebase a usar o Google como provedor de identidade. Você usará um pop-up, mas vários outros métodos estão disponíveis no Firebase.
- No subdiretório
/src/app/services/
, abrachat.service.ts
. - Encontre a função
login
. - Substitua a função inteira pelo código a seguir.
chat.service.ts
// Signs-in Friendly Chat.
login() {
signInWithPopup(this.auth, this.provider).then((result) => {
const credential = GoogleAuthProvider.credentialFromResult(result);
this.router.navigate(['/', 'chat']);
return credential;
})
}
A função logout
é acionada quando o usuário clica no botão Sair.
- Volte para o arquivo
src/app/services/chat.service.ts
. - Encontre a função
logout
. - Substitua a função inteira por este código:
chat.service.ts
// Logout of Friendly Chat.
logout() {
signOut(this.auth).then(() => {
this.router.navigate(['/', 'login'])
console.log('signed out');
}).catch((error) => {
console.log('sign out error: ' + error);
})
}
Acompanhar o estado de autenticação
Para atualizar nossa IU de acordo com isso, você precisa de uma maneira de verificar se o usuário está ou não conectado. O AngularFire oferece uma função para gerar um observável que é atualizado sempre que o estado de autenticação muda. Isso já foi implementado, mas vale a pena conferir.
- Volte para o arquivo
src/app/services/chat.service.ts
. - Encontre a atribuição de variável
user$
.
chat.service.ts
// observable that is updated when the auth state changes
user$ = user(this.auth);
O código acima chama a função user
do AngularFire, que retorna um usuário observável. Ele será acionado sempre que o estado de autenticação mudar (quando o usuário fizer login ou sair). Os componentes de modelos do Angular no FriendlyChat usam esse observável para atualizar a interface para redirecionar, exibir o usuário na navegação do cabeçalho e assim por diante.
Testar o login no app
- Criar uma confirmação com a mensagem de confirmação "Adicionar uma autenticação do Google" e enviá-lo para o repositório do GitHub.
- Abra a página "App Hosting" no Console do Firebase e aguarde a conclusão do novo lançamento.
- No aplicativo da Web, atualize a página e faça login no aplicativo usando o botão de login e sua Conta do Google. Se você receber uma mensagem de erro com a informação
auth/operation-not-allowed
, verifique se ativou o Login do Google como um provedor de autenticação no Console do Firebase. - Depois de fazer login, sua foto do perfil e seu nome de usuário serão exibidos:
9. Grave mensagens no Cloud Firestore
Nesta seção, você vai gravar alguns dados no Cloud Firestore para preencher a interface do app. Isso pode ser feito manualmente com o Console do Firebase, mas você vai fazer isso no próprio app para demonstrar uma gravação básica do Cloud Firestore.
Modelo de dados
Os dados do Cloud Firestore são divididos em coleções, documentos, campos e subcoleções. Você armazenará cada mensagem do chat como um documento em uma coleção de nível superior chamada messages
.
Adicionar mensagens ao Cloud Firestore
Para armazenar as mensagens de chat escritas pelos usuários, use o Cloud Firestore.
Nesta seção, você vai adicionar a funcionalidade que permite que os usuários escrevam novas mensagens no banco de dados. Quando o usuário clica no botão ENVIAR, o snippet de código abaixo é acionado. Ele adiciona um objeto de mensagem com o conteúdo dos campos de mensagem à sua instância do Cloud Firestore na coleção messages
. O método add()
adiciona à coleção um novo documento com um ID gerado automaticamente.
- Volte para o arquivo
src/app/services/chat.service.ts
. - Encontre a função
addMessage
. - Substitua a função inteira pelo código a seguir.
chat.service.ts
// Adds a text or image message to Cloud Firestore.
addMessage = async (
textMessage: string | null,
imageUrl: string | null,
): Promise<void | DocumentReference<DocumentData>> => {
// ignore empty messages
if (!textMessage && !imageUrl) {
console.log(
"addMessage was called without a message",
textMessage,
imageUrl,
);
return;
}
if (this.currentUser === null) {
console.log("addMessage requires a signed-in user");
return;
}
const message: ChatMessage = {
name: this.currentUser.displayName,
profilePicUrl: this.currentUser.photoURL,
timestamp: serverTimestamp(),
uid: this.currentUser?.uid,
};
textMessage && (message.text = textMessage);
imageUrl && (message.imageUrl = imageUrl);
try {
const newMessageRef = await addDoc(
collection(this.firestore, "messages"),
message,
);
return newMessageRef;
} catch (error) {
console.error("Error writing new message to Firebase Database", error);
return;
}
};
Testar o envio de mensagens
- Criar um commit com a mensagem "Post new chats to Firestore" e enviá-lo para o repositório do GitHub.
- Abra a página "Hospedagem de apps" no Console do Firebase e aguarde a conclusão do novo lançamento.
- Atualize o FriendlyChat. Depois de fazer login, digite uma mensagem como "Olá!" e clique em ENVIAR. Isso vai gravar a mensagem no Cloud Firestore. No entanto, você ainda não verá os dados no seu app da Web real porque ainda será necessário implementar a recuperação dos dados (a próxima seção do codelab).
- Você pode ver a mensagem recém-adicionada no Console do Firebase. Abra a interface do Pacote de emuladores. Na seção Build, clique em Banco de dados do Firestore (ou clique aqui). Você vai encontrar a coleção messages com a mensagem recém-adicionada:
10. Leia mensagens
Sincronizar mensagens
Para ler mensagens no app, adicione um observável que será acionado quando os dados mudarem e, em seguida, crie um elemento da interface que mostre novas mensagens.
Você vai adicionar um código que detecta mensagens recém-adicionadas do app. Neste código, você vai recuperar o snapshot da coleção messages
. Exibirá apenas as últimas 12 mensagens do bate-papo para evitar a exibição de um histórico muito longo após o carregamento.
- Volte para o arquivo
src/app/services/chat.service.ts
. - Encontre a função
loadMessages
. - Substitua a função inteira pelo código a seguir.
chat.service.ts
// Loads chat message history and listens for upcoming ones.
loadMessages = () => {
// Create the query to load the last 12 messages and listen for new ones.
const recentMessagesQuery = query(collection(this.firestore, 'messages'), orderBy('timestamp', 'desc'), limit(12));
// Start listening to the query.
return collectionData(recentMessagesQuery);
}
Para detectar mensagens no banco de dados, crie uma consulta em uma coleção usando a função collection
para especificar em qual coleção os dados que você quer detectar estão. No código acima, você está ouvindo as mudanças na coleção messages
, que é onde as mensagens de chat são armazenadas. Você também está aplicando um limite detectando apenas as últimas 12 mensagens usando limit(12)
e ordenando as mensagens por data usando orderBy('timestamp', 'desc')
para receber as 12 mensagens mais recentes.
A função collectionData
usa snapshots em segundo plano. A função de retorno de chamada será acionada quando houver alterações nos documentos que correspondam à consulta. Isso pode acontecer se uma mensagem for excluída, modificada ou adicionada. Leia mais sobre isso na documentação do Cloud Firestore.
Teste a sincronização de mensagens
- Criar um commit com a mensagem "Show new chats in the UI" e enviá-lo para o repositório do GitHub.
- Abra a página "Hospedagem de apps" no Console do Firebase e aguarde a conclusão do novo lançamento.
- Atualize o FriendlyChat. As mensagens que você criou anteriormente no banco de dados vão aparecer na interface do FriendlyChat (veja abaixo). Sinta-se à vontade para escrever novas mensagens. elas devem aparecer instantaneamente.
- (Opcional) Tente excluir, modificar ou adicionar manualmente novas mensagens diretamente na seção Firestore do Pacote de emuladores. todas as mudanças devem ser refletidas na interface.
Parabéns! Você está lendo documentos do Cloud Firestore no seu app.
11. Adicionar recursos de IA
Você vai usar a IA do Google para adicionar recursos de assistência úteis ao app de chat.
Gerar uma chave de API da IA do Google
- Acesse o Google AI Studio e clique em Criar chave de API.
- Selecione o projeto do Firebase que você criou para este codelab. O comando é referente a um projeto do Google Cloud, mas todo projeto do Firebase é um projeto do Google Cloud.
- Clique em Criar chave de API em um projeto atual.
- Copie a chave de API resultante
Instalar uma extensão
Esta extensão implantará uma função do Cloud que é acionada sempre que um novo documento for adicionado à coleção messages
no Firestore. A função vai chamar o Gemini e gravar a resposta no campo response
do documento.
- Clique em Instalar no console do Firebase na página da extensão Criar um chatbot com a API Gemini.
- Siga as instruções. Na etapa Configurar extensão, defina os seguintes valores de parâmetro:
- Provedor da API Gemini:
Google AI
- Chave da API Google AI: cole a chave criada anteriormente e clique em Criar secret.
- Caminho da coleção do Firestore:
messages
- Campo de comando:
text
- Campo de resposta:
response
- Campo do pedido:
timestamp
- Contexto:
Keep your answers short, informal, and helpful. Use emojis when possible.
- Provedor da API Gemini:
- Clique em Instalar extensão.
- Aguarde a conclusão da instalação da extensão
Testar recurso de IA
O FriendlyChat já tem um código para ler as respostas da extensão de IA. Você só precisa enviar uma nova mensagem no chat para testar.
- Abra o FriendlyChat e envie uma mensagem.
- Depois de alguns instantes, você verá uma resposta pop-up ao lado da mensagem. Ele tem uma observação
✨ ai generated
no final para deixar claro que foi criado com IA generativa, não um usuário real.
12. Enviar imagens
Agora você vai adicionar um recurso que compartilha imagens.
Embora o Cloud Firestore seja bom para armazenar dados estruturados, o Cloud Storage é mais adequado para armazenar arquivos. O Cloud Storage para Firebase é um serviço de armazenamento de arquivos/blobs para armazenar todas as imagens compartilhadas por um usuário com o app.
Salve imagens no Cloud Storage
Neste codelab, você já adicionou um botão que aciona uma caixa de diálogo do seletor de arquivos. Depois de selecionar um arquivo, a função saveImageMessage
é chamada e você pode acessar uma referência ao arquivo selecionado. A função saveImageMessage
faz o seguinte:
- Cria um "marcador de posição" de chat no feed de chat, para que os usuários vejam uma mensagem "Carregando" durante o upload da imagem.
- Faz o upload do arquivo de imagem no Cloud Storage para este caminho:
/<uid>/<file_name>
- Gera um URL legível publicamente para o arquivo de imagem.
- Atualiza a mensagem de chat com o URL do arquivo de imagem recém-enviado em vez da imagem de carregamento temporária.
Agora você vai adicionar a funcionalidade de enviar uma imagem:
- Volte para o arquivo
src/chat.service.ts
. - Encontre a função
saveImageMessage
. - Substitua a função inteira por este código:
chat.service.ts (link em inglês)
// Saves a new message containing an image in Firestore.
// This first saves the image in Firebase storage.
saveImageMessage = async(file: any) => {
try {
// 1 - Add a message with a loading icon that will get updated with the shared image.
const messageRef = await this.addMessage(null, this.LOADING_IMAGE_URL);
// 2 - Upload the image to Cloud Storage.
const filePath = `${this.auth.currentUser?.uid}/${file.name}`;
const newImageRef = ref(this.storage, filePath);
const fileSnapshot = await uploadBytesResumable(newImageRef, file);
// 3 - Generate a public URL for the file.
const publicImageUrl = await getDownloadURL(newImageRef);
// 4 - Update the chat message placeholder with the image's URL.
messageRef ?
await updateDoc(messageRef, {
imageUrl: publicImageUrl,
storageUri: fileSnapshot.metadata.fullPath
}): null;
} catch (error) {
console.error('There was an error uploading a file to Cloud Storage:', error);
}
}
Teste o envio de imagens
- Criar um commit com a mensagem "Adicione a capacidade de postar imagens" e enviá-lo para o repositório do GitHub.
- Abra a página "Hospedagem de apps" no Console do Firebase e aguarde a conclusão do novo lançamento.
- Atualize o FriendlyChat. Depois de fazer login, clique no botão de upload de imagem no canto inferior esquerdo e selecione um arquivo de imagem usando o seletor de arquivos. Se você está procurando uma imagem, sinta-se à vontade para usar esta boa foto de uma xícara de café.
- Uma nova mensagem vai aparecer na interface do app com a imagem selecionada:
Se você tentar adicionar uma imagem sem fazer login, vai aparecer um erro informando que é necessário fazer login para adicionar imagens.
13. Mostrar notificações
Agora você vai adicionar suporte às notificações do navegador. O app notificará os usuários quando novas mensagens forem postadas no chat. O Firebase Cloud Messaging (FCM) é uma solução de mensagens entre plataformas que permite a entrega confiável de mensagens e notificações sem custos.
Adicionar o service worker do FCM
O app da Web precisa de um service worker que receba e mostre notificações da Web.
O provedor de mensagens já deveria ter sido configurado quando o AngularFire foi adicionado. Verifique se o código a seguir existe na seção de importações do /angularfire-start/src/app/app.config.ts
.
provideMessaging(() => {
return getMessaging();
}),
app/app.config.ts
O service worker só precisa carregar e inicializar o SDK do Firebase Cloud Messaging, que vai se encarregar da exibição de notificações.
Acessar tokens de dispositivo do FCM
Quando as notificações são ativadas em um dispositivo ou navegador, você recebe um token de dispositivo. Esse token de dispositivo é o que você usa para enviar uma notificação a um dispositivo ou navegador específico.
Quando o usuário faz login, você chama a função saveMessagingDeviceToken
. É para isso que você receberá o token do dispositivo do FCM do navegador e o salvará no Cloud Firestore.
chat.service.ts
- Encontre a função
saveMessagingDeviceToken
. - Substitua a função inteira pelo código a seguir.
chat.service.ts
// Saves the messaging device token to Cloud Firestore.
saveMessagingDeviceToken= async () => {
try {
const currentToken = await getToken(this.messaging);
if (currentToken) {
console.log('Got FCM device token:', currentToken);
// Saving the Device Token to Cloud Firestore.
const tokenRef = doc(this.firestore, 'fcmTokens', currentToken);
await setDoc(tokenRef, { uid: this.auth.currentUser?.uid });
// This will fire when a message is received while the app is in the foreground.
// When the app is in the background, firebase-messaging-sw.js will receive the message instead.
onMessage(this.messaging, (message) => {
console.log(
'New foreground notification from Firebase Messaging!',
message.notification
);
});
} else {
// Need to request permissions to show notifications.
this.requestNotificationsPermissions();
}
} catch(error) {
console.error('Unable to get messaging token.', error);
};
}
No entanto, esse código não vai funcionar inicialmente. Para que o app possa recuperar o token do dispositivo, o usuário precisa conceder permissão ao app para mostrar notificações (a próxima etapa do codelab).
Solicitar permissão para mostrar notificações
Quando o usuário ainda não concedeu ao app a permissão para mostrar notificações, você não vai receber um token do dispositivo. Nesse caso, você chama o método requestPermission()
, que exibe uma caixa de diálogo do navegador solicitando essa permissão ( em navegadores compatíveis).
- Volte para o arquivo
src/app/services/chat.service.ts
. - Encontre a função
requestNotificationsPermissions
. - Substitua a função inteira por este código:
chat.service.ts
// Requests permissions to show notifications.
requestNotificationsPermissions = async () => {
console.log('Requesting notifications permission...');
const permission = await Notification.requestPermission();
if (permission === 'granted') {
console.log('Notification permission granted.');
// Notification permission granted.
await this.saveMessagingDeviceToken();
} else {
console.log('Unable to get permission to notify.');
}
}
Acessar o token do dispositivo
- Criar um commit com a mensagem "Adicione a capacidade de postar imagens" e enviá-lo para o repositório do GitHub.
- Abra a página "App Hosting" no Console do Firebase e aguarde a conclusão do novo lançamento.
- Atualize o FriendlyChat. Depois de fazer login, a caixa de diálogo de permissão de notificações será exibida:
- Clique em Permitir.
- Abra o console JavaScript do seu navegador. A seguinte mensagem será exibida:
Got FCM device token: cWL6w:APA91bHP...4jDPL_A-wPP06GJp1OuekTaTZI5K2Tu
- Copie o token do dispositivo. Você vai precisar dele na próxima etapa do codelab.
Enviar uma notificação para seu dispositivo
Agora que você tem o token do dispositivo, pode enviar uma notificação.
- Abra a guia Cloud Messaging do Console do Firebase.
- Clique em "Nova notificação"
- Insira um título e um texto para a notificação.
- No lado direito da tela, clique em "Enviar uma mensagem de teste".
- Insira o token do dispositivo que você copiou do Console JavaScript do seu navegador e clique no sinal de adição ("+").
- Clique em "Testar".
Se o app estiver em primeiro plano, você verá a notificação no Console JavaScript.
Se o app estiver em segundo plano, uma notificação vai aparecer no navegador, como neste exemplo:
14. Regras de segurança do Cloud Firestore
Confira as regras de segurança do banco de dados
O Cloud Firestore usa uma linguagem de regras específica para definir direitos de acesso, segurança e validações de dados.
Ao configurar o projeto do Firebase no início deste codelab, você escolheu usar o "modo de teste" regras de segurança padrão para não restringir o acesso ao repositório de dados. No Console do Firebase, na guia Regras da seção Banco de dados, é possível visualizar e modificar essas regras.
No momento, você vai ver as regras padrão, que não restringem o acesso ao repositório de dados. Isso significa que qualquer usuário pode ler e gravar em qualquer coleção do seu repositório de dados.
rules_version = '2';
service cloud.firestore {
match /databases/{database}/documents {
match /{document=**} {
allow read, write;
}
}
}
Você vai atualizar as regras para restringir as coisas usando as seguintes regras:
firestore.rules
rules_version = '2';
service cloud.firestore {
match /databases/{database}/documents {
// Messages:
// - Anyone can read.
// - Authenticated users can add and edit messages.
// - Validation: Check name is same as auth token and text length below 300 char or that imageUrl is a URL.
// - Deletes are not allowed.
match /messages/{messageId} {
allow read;
allow create, update: if request.auth != null
&& request.resource.data.name == request.auth.token.name
&& (request.resource.data.text is string
&& request.resource.data.text.size() <= 300
|| request.resource.data.imageUrl is string
&& request.resource.data.imageUrl.matches('https?://.*'));
allow delete: if false;
}
// FCM Tokens:
// - Anyone can write their token.
// - Reading list of tokens is not allowed.
match /fcmTokens/{token} {
allow read: if false;
allow write;
}
}
}
As regras de segurança serão atualizadas automaticamente no pacote do emulador.
Conferir as regras de segurança do Cloud Storage
O Cloud Storage para Firebase usa uma linguagem de regras específica para definir direitos de acesso, segurança e validações de dados.
Ao configurar o projeto do Firebase no início deste codelab, você escolheu usar a regra de segurança padrão do Cloud Storage que permite que apenas usuários autenticados usem o Cloud Storage. No Console do Firebase, na guia Regras da seção Armazenamento, é possível ver e modificar regras. Você verá a regra padrão que permite que qualquer usuário conectado leia e grave qualquer arquivo no seu bucket de armazenamento.
rules_version = '2';
service firebase.storage {
match /b/{bucket}/o {
match /{allPaths=**} {
allow read, write: if request.auth != null;
}
}
}
Você atualizará as regras para fazer o seguinte:
- permitir que cada usuário grave somente nas pastas específicas deles;
- Permitir que qualquer pessoa faça leituras no Cloud Storage
- Verifique se os arquivos enviados são imagens
- Restringir o tamanho das imagens que podem ser enviadas a, no máximo, 5 MB.
Isso pode ser implementado usando as seguintes regras:
storage.rules
rules_version = '2';
// Returns true if the uploaded file is an image and its size is below the given number of MB.
function isImageBelowMaxSize(maxSizeMB) {
return request.resource.size < maxSizeMB * 1024 * 1024
&& request.resource.contentType.matches('image/.*');
}
service firebase.storage {
match /b/{bucket}/o {
match /{userId}/{messageId}/{fileName} {
allow write: if request.auth != null && request.auth.uid == userId && isImageBelowMaxSize(5);
allow read;
}
}
}
15. Parabéns!
Você usou o Firebase para criar um aplicativo da Web para bate-papo em tempo real.
Conteúdo abordado
- Firebase App Hosting
- Firebase Authentication
- Cloud Firestore
- Firebase SDK para Cloud Storage
- Firebase Cloud Messaging
- Monitoramento de desempenho do Firebase
Próximas etapas
Saiba mais
16. [Opcional] Aplicar com o App Check
O App Check do Firebase ajuda a proteger seus serviços contra tráfego indesejado e protege seu back-end contra abuso. Nesta etapa, você vai adicionar a validação de credenciais e bloquear clientes não autorizados com o App Check e o reCAPTCHA Enterprise.
Primeiro, ative o App Check e o reCAPTCHA.
Como ativar o reCAPTCHA Enterprise
- No console do Cloud, localize e selecione reCaptcha Enterprise em Segurança.
- Ative o serviço conforme solicitado e clique em Criar chave.
- Insira um nome de exibição, conforme solicitado, e selecione Site como o tipo de plataforma.
- Adicione os URLs implantados à lista de domínios e confirme se a opção "Usar desafio da caixa de seleção" estiver desmarcada.
- Clique em Criar chave e armazene a chave gerada em algum lugar para protegê-la. Você vai precisar dele mais adiante nesta etapa.
Como ativar o App Check
- No Console do Firebase, localize a seção Criar no painel esquerdo.
- Clique em App Check e, em seguida, na guia Método de login para acessar o App Check.
- Clique em Register e digite sua chave reCAPTCHA Enterprise quando solicitado e clique em Save.
- Na visualização de APIs, selecione Armazenamento e clique em Aplicar. Faça o mesmo para o Cloud Firestore.
O App Check agora é obrigatório. Atualize o app e tente ver ou enviar mensagens de chat. Você vai receber esta mensagem de erro:
Uncaught Error in snapshot listener: FirebaseError: [code=permission-denied]: Missing or insufficient permissions.
Isso significa que o App Check está bloqueando solicitações não validadas por padrão. Agora, vamos adicionar a validação ao app.
Navegue até o arquivo environment.ts
e adicione reCAPTCHAEnterpriseKey
ao objeto environment
.
export const environment = {
firebase: {
apiKey: 'API_KEY',
authDomain: 'PROJECT_ID.firebaseapp.com',
databaseURL: 'https://PROJECT_ID.firebaseio.com',
projectId: 'PROJECT_ID',
storageBucket: 'PROJECT_ID.appspot.com',
messagingSenderId: 'SENDER_ID',
appId: 'APP_ID',
measurementId: 'G-MEASUREMENT_ID',
},
reCAPTCHAEnterpriseKey: {
key: "Replace with your recaptcha enterprise site key"
},
};
Substitua o valor de key
pelo seu token reCAPTCHA Enterprise.
Em seguida, navegue até o arquivo app.config.ts
e adicione as seguintes importações:
import { getApp } from '@angular/fire/app';
import {
ReCaptchaEnterpriseProvider,
initializeAppCheck,
provideAppCheck,
} from '@angular/fire/app-check';
No mesmo arquivo app.config.ts
, adicione a seguinte declaração de variável global:
declare global {
var FIREBASE_APPCHECK_DEBUG_TOKEN: boolean;
}
@NgModule({ ...
Nas importações, adicione a inicialização do App Check com ReCaptchaEnterpriseProvider
e defina isTokenAutoRefreshEnabled
como true
para permitir que os tokens sejam atualizados automaticamente.
imports: [
BrowserModule,
AppRoutingModule,
CommonModule,
FormsModule,
provideFirebaseApp(() => initializeApp(environment.firebase)),
provideAppCheck(() => {
const appCheck = initializeAppCheck(getApp(), {
provider: new ReCaptchaEnterpriseProvider(
environment.reCAPTCHAEnterpriseKey.key
),
isTokenAutoRefreshEnabled: true,
});
if (location.hostname === 'localhost') {
self.FIREBASE_APPCHECK_DEBUG_TOKEN = true;
}
return appCheck;
}),
Para permitir testes locais, defina self.FIREBASE_APPCHECK_DEBUG_TOKEN
como true
. Quando você atualizar seu app no localhost
, isso vai registrar um token de depuração no console semelhante a este:
App Check debug token: CEFC0C76-7891-494B-B764-349BDFD00D00. You will need to add it to your app's App Check settings in the Firebase console for it to work.
Agora acesse a Visualização de apps do App Check no Console do Firebase.
Clique no menu flutuante e selecione Gerenciar tokens de depuração.
Em seguida, clique em Adicionar token de depuração e cole o token de depuração do console conforme solicitado.
Navegue até o arquivo chat.service.ts
e adicione a seguinte importação:
import { AppCheck } from '@angular/fire/app-check';
No mesmo arquivo chat.service.ts
, injete o App Check com os outros serviços do Firebase.
export class ChatService {
appCheck: AppCheck = inject(AppCheck);
...
- Crie uma confirmação com a mensagem de confirmação "Bloquear clientes não autorizados com o App Check" e enviá-lo para o repositório do GitHub.
- Abra a página "Hospedagem de apps" no Console do Firebase e aguarde a conclusão do novo lançamento.
Parabéns! Agora, o App Check deve estar funcionando no seu app.