Incoming webhook with Node

Complete the steps described in the rest of this page, and in about fifteen minutes you'll have created a Google Chat app that sends messages to a Google Chat space. This quickstart uses a simple Node.js script that sends HTTP requests to an incoming webhook registered to a Google Chat space.


To run this quickstart, you need:

Step 1: Register the incoming webhook

  1. Open Google Chat in your browser.
  2. Go to the space to which you want to add a app.
  3. From the menu at the top of the page, select Configure webhooks.
  4. Under Incoming Webhooks, click ADD WEBHOOK.
  5. Name the new webhook 'Quickstart Webhook' and click SAVE.
  6. Copy the URL listed next to your new webhook in the Webhook Url column.
  7. Click outside the dialog box to close.

Step 2: Create the Node.js script

Create a file named index.js in your working directory and copy the following code:


const fetch = require('node-fetch');

const webhookURL = '<INCOMING-WEBHOOK-URL>';

const data = JSON.stringify({
  'text': 'Hello from a Node script!',

fetch(webhookURL, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json; charset=UTF-8',
  body: data,
}).then((response) => {

Be sure to replace the value for the webhookURL variable in the code snippet with the URL provided to you by Google Chat when you registered the incoming webhook. (If you need to find the URL again, go to the Google Chat space, select Configure webhooks, and then copy the URL associated with your new incoming webhook in the Webhook Url column.)

Step 3: Run the sample

Run the sample by running the following command from your working directory:

$ node .

Further reading


403: The caller does not have permission

Incoming webhooks for spaces will fail with this error if not all users in your domain have apps enabled. See the webhooks documentation for more information.