- Products
- Solutions Use casesBy industry
- Developers
- Resources ConnectAbout Nylas
- Pricing
Nylas recently launched our API v3 and we also released updated versions of our Nylas SDKs. We will be using the Nylas Node SDK to create webhooks using Hookdeck for testing and inspecting the webhooks themselves.
In this blog post, we’ll dive into how to use and set up Nylas webhooks in API v3 using Hookdeck!
We will first use Hookdeck to set up an endpoint for registering and receiving webhooks. So create a new connection in Hookdeck and call it testing-nylas-webhooks
:
For the next section, define your event destination, let’s set up the destination as CLI (localhost) to test webhook locally:
We will keep the connection rules and name unchanged, and click Create:
Now we will be given the webhook URL to receive webhooks from Nylas:
In the upcoming sections, this URL is used as an environment variable, NYLAS_WEBHOOK_URL
. Now that we have created the initial webhook URL.
So we have an active endpoint, and when Nylas receives a create webhook request from us, to ensure the endpoint is active we must respond with the query challenge. Hookdeck will handle authenticating or handshaking with Nylas webhook automatically, so we are not required to complete any additional steps here.
After successfully setting up the webhook, each subsequent call will not contain the query challenge, where Hookdeck will respond with a status 200 to notify Nylas that the webhook event was received successfully.
Now we have completed setting up Hookdeck and are ready to test creating a Nylas webhook.
Let’s look at how to create a Nylas webhook using the endpoint, NYLAS_WEBHOOK_URL
, that we created on Hookdeck in the previous sections.
Separately, we can also setup a webhook using the Nylas Dashboard:
To get started with using the Nylas v3 Node SDK, take a look at our getting started guide. For a more detailed guide, we also have a quickstart guide for creating webhooks.
Here is a code sample for creating a webhook:
import 'dotenv/config';
import Nylas, { WebhookTriggers } from "nylas"
const NylasConfig = {
apiKey: process.env.NYLAS_API_KEY as string,
apiUri: process.env.NYLAS_API_URI as string,
};
const nylas = new Nylas(NylasConfig);
const createWebhook = async () => {
try {
const webhook = await nylas.webhooks.create({
requestBody: {
triggerTypes: [WebhookTriggers.EventUpdated],
callbackUrl: process.env.NYLAS_WEBHOOK_URL as string,
description: "My first webhook",
notificationEmailAddress: process.env.EMAIL as string,
}
});
console.log("Webhook createdd:", webhook);
} catch (error) {
console.error("Error creating webhook:", error);
}
}
createWebhook();
Now let’s run this code in the terminal:
node create-webhook.js
Webhook created: {
requestId: 'requestId',
data: {
id: 'webhookId',
description: 'My first webhook',
triggerTypes: [ event.updated' ],
webhookUrl: 'NYLAS_WEBHOOK_URL',
webhookSecret: 'webhookSecret,
status: 'active',
notificationEmailAddresses: null,
statusUpdatedAt: 1707334858,
createdAt: 1707334858,
updatedAt: 1707334858
}
}
With Hookdeck setup automatically handle the query challenge sent by Nylas, we are able to successfully create a Nylas webhook. Note the the webhookSecret
value is used for securing Nylas webhooks.
In this code sample, we requested a notification any time a new event (event.updated
) is created for a user that has connected their account. Here is a full list of webhook triggers. The general approach we will take next is as follows:
As an example, I have created a grant for my Gmail account:
So to try this out we can update an event via Google calendar:
And this will generate a new webhook event in Hookdeck showing the updated title parameter:
In this section, we set up a Nylas Webhook to send notifications anytime a connected user’s calendar events are updated.
In this blog post, we covered how to start with Nylas Webhooks in API v3 using Hookdeck.
You can sign up for Nylas for free and start building! Continue building with Nylas by exploring different quickstart guides or by visiting our developer documentation.
Ram loves teaching, building and exploring technologies. He is passionate about empowering developers to ship amazing products to market as fast as possible ????. Ram is excited to share knowledge and help others. He’s a Relaxed Tomato ????.