Última modificação: 28 de agosto de 2025
Run in Postman
- Você deve configurar um aplicativo da HubSpot para usar webhooks, inscrevendo-se nos eventos sobre os quais deseja ser notificado e especificando um URL para envio dessas notificações. Consulte a documentação dos pré-requisitos para obter mais informações sobre como criar um aplicativo.
- Você deve implantar um ponto de extremidade seguro (HTTPS) e disponível publicamente para esse URL que seja capaz de lidar com as cargas do webhook especificadas nesta documentação.
Observação:
- Você também pode gerenciar webhooks em um aplicativo privado. Nos aplicativos privados, as configurações de webhook só podem ser editadas nas configurações do aplicativo privado; elas não podem ser editadas por meio da API.
- Para se inscrever em webhooks de conversas, você precisa acessar a caixa de entrada de conversas e as APIs de mensagens, que estão atualmente em versão beta.
Escopos
Para usar webhooks para assinar os eventos do CRM, o aplicativo precisará ser configurado para exigir o escopo associado que corresponde ao tipo de objeto do CRM no qual você deseja se inscrever. Por exemplo, se quiser se inscrever em eventos de contatos, você terá que solicitar o escopocrm.objects.contacts.read
.
- Ao criar assinaturas na interface de configurações do seu aplicativo público, você será solicitado a adicionar o escopo necessário no painel Criar novas assinaturas do webhook antes de terminar de criar a assinatura.
- Se você estiver criando uma assinatura ao fazer uma solicitação
POST
para o ponto de extremidade/webhooks/v3/{appId}/subscriptions
, a resposta incluirá um erro contendo o nome do escopo que você precisará definir nas configurações da interface do usuário do seu aplicativo público. - Se o seu aplicativo já estiver usando webhooks, você não poderá remover nenhum escopo exigido pelas assinaturas de webhooks ativas sem primeiro pausar e remover as assinaturas.
- Você pode revisar os escopos necessários para cada tipo de assinatura de webhook na tabela abaixo.
Configurações de webhooks
Antes de configurar suas assinaturas de Webhook, você precisa especificar um URL para o qual essas notificações serão enviadas. Siga as instruções nas secções abaixo para saber como configurar totalmente as assinaturas do seu aplicativo.Observação:
- As configurações de Webhooks podem ser armazenadas no cache por até cinco minutos. Quando você altera o URL do webhook, os limites de simultaneidade ou as configurações de assinatura, essas alterações podem levar até cinco minutos para entrarem em vigor.
- O HubSpot define um limite de simultaneidade de 10 solicitações ao enviar dados de eventos de assinatura associados a uma conta que instalou seu aplicativo. Esse limite de simultaneidade é o número máximo de solicitações em andamento que o HubSpot tentará por vez. Cada solicitação pode conter até 100 eventos.
Gerenciar configurações em sua conta de desenvolvedor
Você pode gerenciar a URL e o limite de acúmulo de eventos na página de configuração do aplicativo em sua conta de desenvolvedor:- Na sua conta de desenvolvedor, acesse o painel Aplicativo.
- Clique no nome do aplicativo para o qual deseja configurar os webhooks.

- No menu da barra lateral esquerda, acesse Webhooks.
- No campo URL de destino, insira a URL para a qual o HubSpot fará uma solicitação POST quando os eventos forem disparados.
- Use a configuração Acúmulo de eventos para ajustar o número máximo de eventos que o HubSpot tentará enviar.

- Clique em Salvar.
Gerenciar configurações por meio da API
Você pode usar os seguintes pontos de extremidade e sua chave de API de desenvolvedor para configurar programaticamente as configurações do webhook para um aplicativo. Para exibir as configurações de webhooks definidas para um aplicativo, faça uma solicitaçãoGET
para webhooks/v3/{appId}/settings
.
Você precisará incluir o ID do aplicativo na solicitação, que pode ser encontrado abaixo do nome do aplicativo no painel Aplicativos ou na guia Autenticação nas configurações do aplicativo.
O objeto de configuração contém os seguintes campos:
Campo | Description |
---|---|
webhookUrl | A URL para a qual o HubSpot enviará notificações de webhook. A URL deve ser atendida por HTTPS. |
maxConcurrentRequests | O limite de concorrência para a URL do webhook. Este valor deve ser um número maior que cinco. |
PUT
para webhooks/v3/{appId}/settings
e inclua os seguintes campos no corpo da solicitação:
Campo | Description |
---|---|
targetUrl | A URL disponível publicamente para que o HubSpot indique onde as payloads do evento serão entregues. |
acúmulo | Configure os detalhes de acúmulo do webhook neste objeto. O objeto de acúmulo inclui os campos period e maxConcurrentRequests . |
período | Escala de tempo para esta configuração. Pode ser SECONDLY (por segundo) ou ROLLING_MINUTE (por minuto). |
maxConcurrentRequests | O número máximo de solicitações HTTP que o HubSpot tentará fazer para o seu aplicativo em um período de tempo determinado por period . |
Assinaturas de Webhook
Depois de definir a URL do Webhook e o limite de acúmulo de eventos, será necessário criar uma ou mais assinaturas. As assinaturas do Webhook informam ao HubSpot quais eventos seu aplicativo específico gostaria de receber. As assinaturas se aplicam a todos os clientes que instalaram sua integração. Isso significa que basta você especificar uma vez as assinaturas de que precisa. Depois que uma assinatura for ativada para um aplicativo, ele começará a receber webhooks automaticamente de todos os clientes que instalaram seu aplicativo, e sua integração começará a receber gatilhos de webhook de qualquer novo cliente. Para todas as assinaturas de webhookassociationChange
, o webhook disparará dois eventos para ambos os lados da associação.
- Ao associar dois contatos, uma assinatura de
contact.associationChange
disparará dois eventos, representandocontact 1 to contact 2
econtact 2 to contact 1
. - Ao associar uma empresa, se você tiver duas assinaturas de webhook,
contact.associationChange
ecompany.associationChange
, receberá dois eventos. Estes representarãocontact 1 to company 1
ecompany 1 to contact 1
.
eventType
ao criar assinaturas por meio da API:
Tipo de assinatura | Escopo obrigatório | Descrição |
---|---|---|
contact.creation | crm.objects.contacts.read | Receba uma notificação se um contato for criado na conta de um cliente. |
contact.deletion | Receba uma notificação se um contato for excluído na conta de um cliente. | |
contact.merge | Receba uma notificação se um contato for mesclado com outro. | |
contact.associationChange | Receba uma notificação se um contato tiver uma associação adicionada ou removida entre ele e outro objeto de webhook suportado (contato, empresa, negócio, ticket, item de linha ou produto). | |
contact.restore | Receba uma notificação se um contato for restaurado da exclusão. | |
contact.privacyDeletion | Receba uma notificação se um contato for excluído por motivos de conformidade com a privacidade. | |
contact.propertyChange | Receba uma notificação se uma propriedade específica for alterada para um contato em uma conta. | |
company.creation | crm.objects.companies.read | Receba uma notificação se uma empresa for criada na conta de um cliente. |
company.deletion | Receba uma notificação se uma empresa for excluída na conta de um cliente. | |
company.propertyChange | Receba uma notificação se uma propriedade específica for alterada para uma empresa na conta de um cliente. | |
company.associationChange | Receba uma notificação se uma empresa tiver uma associação adicionada ou removida entre ela e outro objeto de webhook suportado (contato, empresa, negócio, ticket, item de linha ou produto). | |
company.restore | Receba uma notificação se uma empresa for restaurada da exclusão. | |
company.merge | Receba uma notificação se uma empresa for mesclada com outra. | |
deal.creation | crm.objects.deals.read | Receba uma notificação se um negócio for criado na conta de um cliente. |
deal.deletion | Receba uma notificação se um negócio for excluído na conta de um cliente. | |
deal.associationChange | Receba uma notificação se um negócio tiver uma associação adicionada ou removida entre ele e outro objeto de webhook suportado (contato, empresa, negócio, ticket, item de linha ou produto). | |
deal.restore | Receba uma notificação se um negócio for restaurado da exclusão. | |
deal.merge | Receba uma notificação se um negócio for mesclado com outro. | |
deal.propertyChange | Receba uma notificação se uma propriedade específica for alterada para um negócio na conta de um cliente. | |
ticket.creation | tickets | Receba uma notificação se um ticket for criado na conta de um cliente. |
ticket.deletion | Receba uma notificação se um ticket for excluído na conta de um cliente. | |
ticket.propertyChange | Receba uma notificação se uma propriedade específica for alterada para um ticket na conta de um cliente. | |
ticket.associationChange | Receba uma notificação se um ticket tiver uma associação adicionada ou removida entre ele e outro objeto de webhook suportado (contato, empresa, negócio, ticket, item de linha ou produto). | |
ticket.restore | Receba uma notificação se um tíquete for restaurado da exclusão. | |
ticket.merge | Receba uma notificação se um ticket for mesclado com outro. | |
product.creation | e-commerce | Receba uma notificação se um produto for criado na conta de um cliente. |
product.deletion | Receba uma notificação se um produto for excluído na conta de um cliente. | |
product.restore | Receba uma notificação se um produto for restaurado da exclusão. | |
product.merge | Receba uma notificação se um produto for mesclado com outro. | |
product.propertyChange | Receba uma notificação se um produto específico for alterado para um produto na conta de um cliente. | |
line_item.creation | Receba uma notificação se um item de linha for criado na conta de um cliente. | |
line_item.deletion | Receba uma notificação se um item de linha for excluído na conta de um cliente. | |
line_item.associationChange | Receba uma notificação se um item de linha tiver uma associação adicionada ou removida entre ele e outro objeto de webhook suportado (contato, empresa, negócio, ticket, item de linha ou produto). | |
line_item.restore | Receba uma notificação se um item de linha for restaurado da exclusão. | |
line_item.merge | Receba uma notificação se um item de linha for mesclado com outro. | |
line_item.propertyChange | Receba uma notificação se uma propriedade específica for alterada para um item de linha na conta de um cliente. |
Tipo de assinatura | Scope | Descrição |
---|---|---|
conversation.creation | conversations.read | Receba uma notificação se um novo thread for criado em uma conta. |
conversation.deletion | Receba uma notificação se um thread for arquivado ou excluído de forma reversível em uma conta. | |
conversation.privacyDeletion | Receba uma notificação se um thread for excluído permanentemente em uma conta. | |
conversation.propertyChange | Receba uma notificação se uma propriedade em um thread for alterada. | |
conversation.newMessage | Receba uma notificação se uma nova mensagem for recebida em um thread. |
num_unique_conversion_events
hs_lastmodifieddate
assignedTo
: o thread da conversa foi reatribuído ou teve sua atribuição cancelada. Se o thread foi reatribuído,propertyValue
será um ID de ator na payload dos webhooks; se teve sua atribuição cancelada, a propriedade estará vazia.status
: o status do thread de conversas foi alterado. Na carga útil dos webhooks,propertyValue
seráOPEN
ouCLOSED
.isArchived
: o thread da conversa foi restaurado. OpropertyValue
na payload dos webhooks sempre seráFALSE
.
Criar assinaturas em sua conta de desenvolvedor
Você pode criar assinaturas de webhook em sua conta de desenvolvedor da HubSpot.- Na sua conta de desenvolvedor da HubSpot, acesse o painel Aplicativos.
- Clique no nome de um aplicativo.
- No menu da barra lateral esquerda, acesse Webhooks.
- Clique em Criar assinatura.
- No painel direito, clique no menu suspenso Quais tipos de objeto? e selecione os objetos para os quais você deseja criar uma assinatura.
- Clique no menu suspenso Monitorar quais eventos? e selecione os tipos de eventos.

- Se você estiver criando uma assinatura para eventos de alteração de propriedade, clique no menu suspenso Quais propriedades? e selecione as propriedades que devem ser monitoradas.

- Clique em Assinar.
- Na seção Assinaturas de eventos, passe o mouse sobre o tipo de objeto e clique em Exibir assinaturas.
- Marque a caixa de seleção ao lado do evento e, no cabeçalho da tabela, clique em Ativar.

Criar assinaturas por meio da API
Você pode criar assinaturas de forma programática usando os pontos de extremidade a seguir. Você precisará usar sua chave de API de desenvolvedor ao fazer solicitações para esses pontos de extremidade. O objeto de assinatura pode incluir os seguintes campos:Campo | Description |
---|---|
id | Um número que representa o ID exclusivo de uma assinatura. |
createdAt | A hora em milissegundos em que essa assinatura foi criada. |
createdBy | O ID associado ao usuário que criou a assinatura. |
inteligente | Indica se a assinatura está ativada e disparando notificações de forma ativa. O valor pode ser true ou false . |
eventType | O tipo de assinatura. A tabela no início desta seção inclui os tipos de assinatura disponíveis. |
propertyName | O nome da propriedade em que a assinatura monitorará as alterações. Isso é necessário apenas para tipos de assinatura de alteração de propriedade. |
Obter assinaturas
Para recuperar a lista de assinaturas, faça uma solicitaçãoGET
para webhooks/v3/{appId}/subscriptions
.
A resposta será um conjunto de objetos que representam suas assinaturas. Cada objeto conterá informações sobre a assinatura, como o ID, a data de criação, o tipo e se a assinatura está ou não ativa no momento. Veja a seguir o exemplo de uma resposta:
Criar uma nova assinatura
Para criar uma nova assinatura, faça uma solicitaçãoPOST
para webhooks/v3/{appId}/subscriptions
.
No corpo da solicitação, você pode incluir os seguintes campos:
Campo | Description |
---|---|
eventType | O tipo de assinatura. |
propertyName | O nome da propriedade em que a assinatura monitorará as alterações. Isso é necessário apenas para tipos de assinatura de alteração de propriedade. |
inteligente | Indica se a assinatura está ativada e disparando notificações de forma ativa. O valor pode ser true ou false . |
id
, createdAt
ou createdBy
, pois esses campos são definidos automaticamente.
Por exemplo, o corpo da solicitação pode ser parecido com o seguinte:
eventType
deve ser um tipo de assinatura válido, conforme definido na seção acima, e propertyName
deve ser um nome de propriedade válido. Se um cliente não tiver uma propriedade definida que corresponda a esse valor, essa assinatura não resultará em notificação.
Atualizar uma assinatura
Para ativar ou pausar uma assinatura, faça uma solicitaçãoPUT
para webhooks/v3/{appId}/subscriptions/{subscriptionId}
.
No corpo da solicitação, inclua o seguinte:
Campo | Description |
---|---|
inteligente | Indica se a assinatura está ativada e disparando notificações de forma ativa. O valor pode ser true ou false . |
Excluir uma assinatura
Para excluir uma assinatura, faça uma solicitaçãoDELETE
para webhooks/v3/{appId}/subscriptions/{subscriptionId}
.
Payloads de webhooks
O ponto de extremidade na URL de destino especificada nas configurações de webhooks do aplicativo receberá do HubSpot solicitaçõesPOST
contendo dados em formato JSON.
Para garantir que as solicitações que você está recebendo no ponto de extremidade do webhook sejam provenientes do HubSpot, o HubSpot preenche um cabeçalho X-HubSpot-Signature
com um hash SHA-256 criado usando o segredo do cliente do seu aplicativo combinado com os detalhes da solicitação. Saiba mais sobre como validar assinaturas de solicitação.
Use as tabelas abaixo para visualizar detalhes sobre os campos que podem estar contidos no conteúdo.
Campo | Description |
---|---|
objectId | O ID do objeto que foi criado, alterado ou excluído. Para contatos, é o ID do contato; para empresas, é o ID da empresa; para negócios, é o ID do negócio; e para conversas, é o ID do thread. |
propertyName | É enviado apenas para assinaturas de alteração de propriedade e é o nome da propriedade que foi alterada. |
propertyValue | É enviado apenas para assinaturas de alteração de propriedade e representa o novo valor definido para a propriedade que disparou a notificação. |
changeSource | A origem da alteração. Pode ser qualquer uma das origens de alteração que aparecem nos históricos de propriedades de contato. |
eventId | O ID do evento que disparou essa notificação. Não há garantias de que esse valor seja exclusivo. |
subscriptionId | O ID da assinatura que disparou uma notificação sobre o evento. |
portalId | O ID da conta da HubSpot do cliente onde o evento ocorreu. |
appId | O ID do aplicativo. Isso é usado caso você tenha vários aplicativos apontando para a mesmo URL de Webhook. |
occurredAt | Quando esse evento ocorreu, como uma marca de data/hora em milissegundos. |
eventType | O tipo de evento para o qual esta notificação se destina. Revise a lista de tipos de assinatura permitidos na seção de assinatura de webhooks acima. |
attemptNumber | Começando em 0, o número desta tentativa de notificação do seu serviço sobre esse evento. Se o serviço atingir o tempo limite ou lançar um erro conforme descrito na seção Tentativas abaixo, o HubSpot tentará enviar a notificação novamente. |
messageId | Somente será enviado quando um webhook estiver monitorando novas mensagens para um thread. É o ID da nova mensagem. |
messageType | Somente será enviado quando um webhook estiver monitorando novas mensagens para um thread. Representa o tipo de mensagem que você está enviando. Este valor pode ser MESSAGE ou COMMENT . |
Campo | Description |
---|---|
primaryObjectId | O ID do vencedor da mesclagem, que é o registro que permanece após a mesclagem. Na interface de mesclagem do HubSpot, é o registro à direita. |
mergedObjectIds | Uma matriz de IDs que representam os registros mesclados no vencedor da mesclagem. Na interface de mesclagem do HubSpot, é o registro à esquerda. |
newObjectId | O ID do registro criado como resultado da mesclagem. Isso é separado do primaryObjectId porque, em alguns casos, um novo registro é criado como resultado da mesclagem. |
numberOfPropertiesMoved | Um número inteiro que representa quantas propriedades foram transferidas durante a mesclagem. |
Campo | Description |
---|---|
associationType | O tipo de associação, que será um dos seguintes:
|
fromObjectId | O ID do registro do qual a alteração da associação foi feita. |
toObjectId | O ID do registro secundário no evento de associação. |
associationRemoved | Um booleano que representa o seguinte:
|
isPrimaryAssociation | Um booleano que representa o seguinte:
|
occurredAt
para cada notificação a fim de determinar quando o evento que disparou a notificação ocorreu.
O HubSpot também não garante que você receberá somente uma notificação para cada evento. Pode acontecer de o HubSpot enviar a mesma notificação várias vezes, embora isso provavelmente não ocorrerá.
Exclusões de contatos em conformidade com a privacidade
Usuários do HubSpot podem excluir permanentemente um registro de contato para cumprir as leis de privacidade. Saiba mais sobre como realizar uma exclusão em conformidade com o GDPR. Você pode se inscrever no tipo de assinaturacontact.privacyDeletion
para receber notificações de Webhook quando um usuário realizar a exclusão de um contato em conformidade com a privacidade.
As notificações de exclusão de privacidade têm comportamentos especiais:
- Um evento de exclusão de privacidade também disparará o evento de exclusão de contato. Portanto, você receberá duas notificações se estiver inscrito nos dois eventos.
- Essas notificações não serão necessariamente enviadas em uma ordem específica ou no mesmo lote de mensagens. Você precisará usar o ID do objeto para corresponder mensagens separadas.
Segurança
Para garantir que as solicitações que você está recebendo no ponto de extremidade do webhook sejam provenientes do HubSpot, o HubSpot preenche um cabeçalhoX-HubSpot-Signature
com um hash SHA-256 da concatenação do segredo do aplicativo e do corpo da solicitação que estamos enviando.
Para verificar essa assinatura, concatene o segredo do aplicativo e o corpo de solicitação não analisado da solicitação que você está gerenciando e obtenha um hash SHA-256 do resultado. Compare o hash resultante com o valor do cabeçalho X-HubSpot-Signature
. Se esses valores corresponderem, isso confirmará que essa solicitação veio da HubSpot. Ou a solicitação veio de outra pessoa que conhece o segredo do seu aplicativo. É importante manter esse valor em segredo.
Se esses valores forem diferentes, essa solicitação pode ter sido alterada em trânsito ou alguém pode ter falsificado as notificações de webhook no seu ponto de extremidade.
Saiba mais sobre como validar solicitações de assinatura.
Tentativas
Se, em algum momento, o serviço enfrentar problemas ao lidar com notificações, o HubSpot fará 10 tentativas de reenviar as notificações com falha. O HubSpot tentará novamente nos seguintes casos:- Falha na conexão: se o HubSpot não conseguir estabelecer uma conexão http com a URL do webhook fornecida.
- Tempo limite: se o serviço demorar mais de cinco segundos para enviar uma resposta a um lote de notificações.
- Códigos de erro: se o serviço responder com qualquer código de status HTTP (4xx ou 5xx).
Limites
As solicitaçõesPOST
que o HubSpot envia ao seu serviço por meio das assinaturas de webhook não serão contabilizadas nos limites de taxa de API do aplicativo.
Você pode criar no máximo de 1.000 assinaturas por aplicativo. Se tentar criar mais de 1.000 assinaturas, você receberá uma solicitação 400 inválida com a seguinte mensagem: