microsoftgraph / msgraph-sdk-javascript

Microsoft Graph client library for JavaScript
https://graph.microsoft.com
MIT License
758 stars 231 forks source link

GraphError: Subscription validation request failed despite Accessible Endpoint hosted on Google Cloud #1472

Open kiritowu opened 1 year ago

kiritowu commented 1 year ago

Bug Report

Prerequisites

For more information, see the CONTRIBUTING guide.

Description

I've been working on implementing Microsoft Graph webhook subscriptions in my application, and I've run into an issue with subscription validation. Whenever I attempt to validate the subscription, I've consistently receive the following error message:

GraphError: Subscription validation request timed out.

My subscription server is deployed and hosted on Google Cloud Function v2, allowing all unauthenticated invocations.

The following verification is performed using Microsoft's Postman Collection:

However, when I actually attempt to create subscription request using MicrosoftGraph Javascript SDK, the validation request always faces timeout issue despite it being accessible via PostMan.

Code Snippet to Invoke Subscription Request

const requestBody: Subscription =
        changeType: "updated",
        resource: `/users/${folderId}/drive/root
        expirationDateTime: new Date(now.setDate(now.getDate() + 28)).toISOString(),
        notificationUrl: `${process.env.ONEDRIVE_URL}/folders/${folderId}?workspaceId=${workspaceId}`,
        clientState: "somerandomtext";
      }

await driveClient.api("/subscriptions").post(requestBody);

Console Errors:

GraphError: Subscription validation request timed out.
    at new GraphError (/code/node_modules/@microsoft/microsoft-graph-client/lib/src/GraphError.js:34:28)
    at GraphErrorHandler.constructErrorFromResponse (/code/node_modules/@microsoft/microsoft-graph-client/lib/src/GraphErrorHandler.js:63:22)
    at Function.<anonymous> (/code/node_modules/@microsoft/microsoft-graph-client/lib/src/GraphErrorHandler.js:91:48)
    at step (/code/node_modules/tslib/tslib.js:195:27)
    at Object.next (/code/node_modules/tslib/tslib.js:176:57)
    at /code/node_modules/tslib/tslib.js:169:75
    at new Promise (<anonymous>)
    at Object.__awaiter (/code/node_modules/tslib/tslib.js:165:16)
    at GraphErrorHandler.getError (/code/node_modules/@microsoft/microsoft-graph-client/lib/src/GraphErrorHandler.js:87:24)
    at GraphRequest.<anonymous> (/code/node_modules/@microsoft/microsoft-graph-client/lib/src/GraphRequest.js:315:84) {
  statusCode: 400,
  code: 'InvalidRequest',
  requestId: 'uuid,
  date: 2023-09-30T21:36:48.000Z,
  body: '{"code":"InvalidRequest","message":"Subscription validation request timed out.","innerError":{"date":"2023-10-01T05:36:48","request-id":"uuid,"client-request-id":"uuid}}',
  headers: HeadersList {
    cookies: null,
    [Symbol(headers map)]: Map(10) {
      'cache-control' => [Object],
      'transfer-encoding' => [Object],
      'content-type' => [Object],
      'content-encoding' => [Object],
      'vary' => [Object],
      'strict-transport-security' => [Object],
      'request-id' => [Object],
      'client-request-id' => [Object],
      'x-ms-ags-diagnostic' => [Object],
      'date' => [Object]
    },
    [Symbol(headers map sorted)]: null
  }
}

Code Snippet to Listen for Subscription Validation

import { FastifyPluginAsyncTypebox } from "@fastify/type-provider-typebox";

import { Type } from "@sinclair/typebox";

export const ParamsSchema = Type.Object({
  fid: Type.String(),
});

export const QuerySchema = Type.Object({
  workspaceId: Type.RegEx(/^[0-9a-z]{25}$/),
  validationToken: Type.Optional(Type.String()),
});

const main: FastifyPluginAsyncTypebox = async (app, options): Promise<void> => {
  /**
   * Listens to changes to a folder
   */
  app.post("/", { schema: { params: ParamsSchema, querystring: QuerySchema } }, async (req, rep) => {
    app.log.info("Received webhook request");
    // If there is a validationToken parameter
    // in the query string, this is the endpoint validation
    // request sent by Microsoft Graph. Return the token
    // as plain text with a 200 response
    // https://docs.microsoft.com/graph/webhooks#notification-endpoint-validation
    // https://github.com/microsoftgraph/nodejs-webhooks-sample/blob/main/routes/listen.js#L13
    if (req.query.validationToken) {
      return req.query.validationToken;
    }

    // Other logic but is commented
    return {};
  });
}

Screenshots: [If applicable, add screenshots to help explain your problem] verification-of-postman

Logs from Google Cloud Console Screenshot from 2023-10-01 14-37-55

Usage Information

Request ID - Value of the requestId field if you are receiving a Graph API error response

SDK Version - 3.0.7

Node Version - v18.17.1

I'm unsure why the validation request fails in my application but works with Postman. Can anyone offer guidance on what could be causing this issue or suggest potential solutions?

sebastienlevert commented 1 year ago

That's a good question. Can you run it locally via Dev Tunnels or ngrok? Can you create your subscription via Postman vs. just calling your validation endpoint? This would also be helpful. Thanks!

nilooy commented 9 months ago

is there any solution for this? i'm having same issue

LuanFernandes23 commented 3 weeks ago

Facing the same issue, any solution?