next-sanity 5.0.0 → 5.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/webhook.cjs CHANGED
@@ -4,6 +4,7 @@ Object.defineProperty(exports, '__esModule', {
4
4
  value: true
5
5
  });
6
6
  var sanityWebhook = require('@sanity/webhook');
7
+ var server = require('next/server');
7
8
  function _interopDefaultCompat(e) {
8
9
  return e && typeof e === 'object' && 'default' in e ? e : {
9
10
  default: e
@@ -35,11 +36,21 @@ const {
35
36
  } = sanityWebhook__default.default;
36
37
  async function parseBody(req, secret) {
37
38
  let waitForContentLakeEventualConsistency = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
38
- let signature = req.headers[SIGNATURE_HEADER_NAME];
39
+ let signature;
40
+ if (req instanceof server.NextRequest) {
41
+ signature = req.headers.get(SIGNATURE_HEADER_NAME);
42
+ } else {
43
+ signature = req.headers[SIGNATURE_HEADER_NAME];
44
+ }
39
45
  if (Array.isArray(signature)) {
40
46
  signature = signature[0];
41
47
  }
42
- const body = await _readBody(req);
48
+ let body;
49
+ if (req instanceof server.NextRequest) {
50
+ body = JSON.stringify(await req.json());
51
+ } else {
52
+ body = await _readBody(req);
53
+ }
43
54
  const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null;
44
55
  if (validSignature !== false && waitForContentLakeEventualConsistency) {
45
56
  await new Promise(resolve => setTimeout(resolve, 1e3));
@@ -1 +1 @@
1
- {"version":3,"file":"webhook.cjs","sources":["../src/webhook/config.ts","../src/webhook/readBody.ts","../src/webhook/parseBody.ts"],"sourcesContent":["import type {PageConfig} from 'next/types'\n\n/**\n * Configurates the API function with the right runtime and body parsing to handle Sanity Webhook events.\n * @public\n */\nexport const config: PageConfig = {\n api: {\n /**\n * Next.js will by default parse the body, which can lead to invalid signatures.\n */\n bodyParser: false,\n },\n /**\n * `@sanity/webhook` isn't updated to support the edge runtime yet, and currently requires Node.js APIs such as Buffer.\n */\n runtime: 'nodejs',\n}\n","import type {NextApiRequest} from 'next'\n\n/** @internal */\nexport async function _readBody(readable: NextApiRequest): Promise<string> {\n const chunks = []\n for await (const chunk of readable) {\n chunks.push(typeof chunk === 'string' ? Buffer.from(chunk) : chunk)\n }\n return Buffer.concat(chunks).toString('utf8')\n}\n","import type {SanityDocument} from '@sanity/types'\nimport sanityWebhook from '@sanity/webhook'\nimport type {NextApiRequest} from 'next'\n\n// As `@sanity/webhook` isn't shipping ESM, extracting from the default export have the best ecosystem support\nconst {isValidSignature, SIGNATURE_HEADER_NAME} = sanityWebhook\n\nimport {_readBody as readBody} from './readBody'\n\n/** @public */\nexport type ParseBody = {\n /**\n * If a secret is given then it returns a boolean. If no secret is provided then no validation is done on the signature, and it'll return `null`\n */\n isValidSignature: boolean | null\n body: SanityDocument\n}\n/**\n * Handles parsing the body JSON, and validating its signature. Also waits for Content Lake eventual consistency so you can run your queries\n * without worrying about getting stale data.\n * @public\n */\nexport async function parseBody(\n req: NextApiRequest,\n secret?: string,\n waitForContentLakeEventualConsistency: boolean = true\n): Promise<ParseBody> {\n let signature = req.headers[SIGNATURE_HEADER_NAME]!\n if (Array.isArray(signature)) {\n signature = signature[0]\n }\n\n const body = await readBody(req)\n const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null\n\n if (validSignature !== false && waitForContentLakeEventualConsistency) {\n await new Promise((resolve) => setTimeout(resolve, 1000))\n }\n\n return {\n body: body.trim() && JSON.parse(body),\n isValidSignature: validSignature,\n }\n}\n"],"names":["config","api","bodyParser","runtime","_readBody","readable","chunks","chunk","push","Buffer","from","concat","toString","isValidSignature","SIGNATURE_HEADER_NAME","sanityWebhook","parseBody","req","secret","waitForContentLakeEventualConsistency","arguments","length","undefined","signature","headers","Array","isArray","body","readBody","validSignature","trim","Promise","resolve","setTimeout","JSON","parse"],"mappings":";;;;;;;;;;;;AAMO,MAAMA,MAAqB,GAAA;EAChCC,GAAK,EAAA;IAAA;AAAA;AAAA;IAIHC,UAAY,EAAA;EACd,CAAA;EAAA;AAAA;AAAA;EAIAC,OAAS,EAAA;AACX,CAAA;ACdA,eAAsBC,UAAUC,QAA2C,EAAA;EACzE,MAAMC,SAAS,EAAC;EAChB,WAAA,MAAiBC,SAASF,QAAU,EAAA;IAC3BC,MAAA,CAAAE,IAAA,CAAK,OAAOD,KAAU,KAAA,QAAA,GAAWE,OAAOC,IAAK,CAAAH,KAAK,IAAIA,KAAK,CAAA;EACpE;EACA,OAAOE,MAAO,CAAAE,MAAA,CAAOL,MAAM,CAAA,CAAEM,SAAS,MAAM,CAAA;AAC9C;ACJA,MAAM;EAACC,gBAAkB;EAAAC;AAAyB,CAAA,GAAAC,8BAAA;AAiBlD,eAAsBC,SACpBA,CAAAC,GAAA,EACAC,MACA,EACoB;EAAA,IADpBC,qCAAA,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAiD,IAC7B;EAChB,IAAAG,SAAA,GAAYN,GAAI,CAAAO,OAAA,CAAQV,qBAAqB,CAAA;EAC7C,IAAAW,KAAA,CAAMC,OAAQ,CAAAH,SAAS,CAAG,EAAA;IAC5BA,SAAA,GAAYA,UAAU,CAAC,CAAA;EACzB;EAEM,MAAAI,IAAA,GAAO,MAAMC,SAAA,CAASX,GAAG,CAAA;EACzB,MAAAY,cAAA,GAAiBX,SAASL,gBAAiB,CAAAc,IAAA,EAAMJ,WAAWL,MAAO,CAAAY,IAAA,EAAM,CAAI,GAAA,IAAA;EAE/E,IAAAD,cAAA,KAAmB,SAASV,qCAAuC,EAAA;IACrE,MAAM,IAAIY,OAAQ,CAACC,WAAYC,UAAW,CAAAD,OAAA,EAAS,GAAI,CAAC,CAAA;EAC1D;EAEO,OAAA;IACLL,MAAMA,IAAK,CAAAG,IAAA,CAAA,CAAU,IAAAI,IAAA,CAAKC,MAAMR,IAAI,CAAA;IACpCd,gBAAkB,EAAAgB;EAAA,CACpB;AACF;;"}
1
+ {"version":3,"file":"webhook.cjs","sources":["../src/webhook/config.ts","../src/webhook/readBody.ts","../src/webhook/parseBody.ts"],"sourcesContent":["import type {PageConfig} from 'next/types'\n\n/**\n * Configurates the API function with the right runtime and body parsing to handle Sanity Webhook events.\n * @public\n */\nexport const config: PageConfig = {\n api: {\n /**\n * Next.js will by default parse the body, which can lead to invalid signatures.\n */\n bodyParser: false,\n },\n /**\n * `@sanity/webhook` isn't updated to support the edge runtime yet, and currently requires Node.js APIs such as Buffer.\n */\n runtime: 'nodejs',\n}\n","import type {NextApiRequest} from 'next'\n\n/** @internal */\nexport async function _readBody(readable: NextApiRequest): Promise<string> {\n const chunks = []\n for await (const chunk of readable) {\n chunks.push(typeof chunk === 'string' ? Buffer.from(chunk) : chunk)\n }\n return Buffer.concat(chunks).toString('utf8')\n}\n","import type {SanityDocument} from '@sanity/types'\nimport sanityWebhook from '@sanity/webhook'\nimport type {NextApiRequest} from 'next'\nimport {NextRequest} from 'next/server'\n\n// As `@sanity/webhook` isn't shipping ESM, extracting from the default export have the best ecosystem support\nconst {isValidSignature, SIGNATURE_HEADER_NAME} = sanityWebhook\n\nimport {_readBody as readBody} from './readBody'\n\n/** @public */\nexport type ParseBody = {\n /**\n * If a secret is given then it returns a boolean. If no secret is provided then no validation is done on the signature, and it'll return `null`\n */\n isValidSignature: boolean | null\n body: SanityDocument\n}\n/**\n * Handles parsing the body JSON, and validating its signature. Also waits for Content Lake eventual consistency so you can run your queries\n * without worrying about getting stale data.\n * @public\n */\nexport async function parseBody(\n req: NextApiRequest | NextRequest,\n secret?: string,\n waitForContentLakeEventualConsistency: boolean = true\n): Promise<ParseBody> {\n let signature\n if (req instanceof NextRequest) {\n signature = req.headers.get(SIGNATURE_HEADER_NAME)!\n } else {\n signature = req.headers[SIGNATURE_HEADER_NAME]!\n }\n if (Array.isArray(signature)) {\n signature = signature[0]\n }\n let body\n if (req instanceof NextRequest) {\n body = JSON.stringify(await req.json())\n } else {\n body = await readBody(req)\n }\n const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null\n\n if (validSignature !== false && waitForContentLakeEventualConsistency) {\n await new Promise((resolve) => setTimeout(resolve, 1000))\n }\n\n return {\n body: body.trim() && JSON.parse(body),\n isValidSignature: validSignature,\n }\n}\n"],"names":["config","api","bodyParser","runtime","_readBody","readable","chunks","chunk","push","Buffer","from","concat","toString","isValidSignature","SIGNATURE_HEADER_NAME","sanityWebhook","parseBody","req","secret","waitForContentLakeEventualConsistency","arguments","length","undefined","signature","NextRequest","headers","get","Array","isArray","body","JSON","stringify","json","readBody","validSignature","trim","Promise","resolve","setTimeout","parse"],"mappings":";;;;;;;;;;;;;AAMO,MAAMA,MAAqB,GAAA;EAChCC,GAAK,EAAA;IAAA;AAAA;AAAA;IAIHC,UAAY,EAAA;EACd,CAAA;EAAA;AAAA;AAAA;EAIAC,OAAS,EAAA;AACX,CAAA;ACdA,eAAsBC,UAAUC,QAA2C,EAAA;EACzE,MAAMC,SAAS,EAAC;EAChB,WAAA,MAAiBC,SAASF,QAAU,EAAA;IAC3BC,MAAA,CAAAE,IAAA,CAAK,OAAOD,KAAU,KAAA,QAAA,GAAWE,OAAOC,IAAK,CAAAH,KAAK,IAAIA,KAAK,CAAA;EACpE;EACA,OAAOE,MAAO,CAAAE,MAAA,CAAOL,MAAM,CAAA,CAAEM,SAAS,MAAM,CAAA;AAC9C;ACHA,MAAM;EAACC,gBAAkB;EAAAC;AAAyB,CAAA,GAAAC,8BAAA;AAiBlD,eAAsBC,SACpBA,CAAAC,GAAA,EACAC,MACA,EACoB;EAAA,IADpBC,qCAAA,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAiD,IAC7B;EAChB,IAAAG,SAAA;EACJ,IAAIN,eAAeO,MAAAA,CAAAA,WAAa,EAAA;IAClBD,SAAA,GAAAN,GAAA,CAAIQ,OAAQ,CAAAC,GAAA,CAAIZ,qBAAqB,CAAA;EAAA,CAC5C,MAAA;IACOS,SAAA,GAAAN,GAAA,CAAIQ,QAAQX,qBAAqB,CAAA;EAC/C;EACI,IAAAa,KAAA,CAAMC,OAAQ,CAAAL,SAAS,CAAG,EAAA;IAC5BA,SAAA,GAAYA,UAAU,CAAC,CAAA;EACzB;EACI,IAAAM,IAAA;EACJ,IAAIZ,eAAeO,MAAAA,CAAAA,WAAa,EAAA;IAC9BK,IAAA,GAAOC,IAAK,CAAAC,SAAA,CAAU,MAAMd,GAAA,CAAIe,KAAM,CAAA,CAAA;EAAA,CACjC,MAAA;IACEH,IAAA,GAAA,MAAMI,UAAShB,GAAG,CAAA;EAC3B;EACM,MAAAiB,cAAA,GAAiBhB,SAASL,gBAAiB,CAAAgB,IAAA,EAAMN,WAAWL,MAAO,CAAAiB,IAAA,EAAM,CAAI,GAAA,IAAA;EAE/E,IAAAD,cAAA,KAAmB,SAASf,qCAAuC,EAAA;IACrE,MAAM,IAAIiB,OAAQ,CAACC,WAAYC,UAAW,CAAAD,OAAA,EAAS,GAAI,CAAC,CAAA;EAC1D;EAEO,OAAA;IACLR,MAAMA,IAAK,CAAAM,IAAA,CAAA,CAAU,IAAAL,IAAA,CAAKS,MAAMV,IAAI,CAAA;IACpChB,gBAAkB,EAAAqB;EAAA,CACpB;AACF;;"}
package/dist/webhook.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import type {NextApiRequest} from 'next'
2
+ import {NextRequest} from 'next/server'
2
3
  import type {PageConfig} from 'next/types'
3
4
  import type {SanityDocument} from '@sanity/types'
4
5
 
@@ -23,7 +24,7 @@ export declare type ParseBody = {
23
24
  * @public
24
25
  */
25
26
  export declare function parseBody(
26
- req: NextApiRequest,
27
+ req: NextApiRequest | NextRequest,
27
28
  secret?: string,
28
29
  waitForContentLakeEventualConsistency?: boolean
29
30
  ): Promise<ParseBody>
package/dist/webhook.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import sanityWebhook from '@sanity/webhook';
2
+ import { NextRequest } from 'next/server';
2
3
  const config = {
3
4
  api: {
4
5
  /**
@@ -24,11 +25,21 @@ const {
24
25
  } = sanityWebhook;
25
26
  async function parseBody(req, secret) {
26
27
  let waitForContentLakeEventualConsistency = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
27
- let signature = req.headers[SIGNATURE_HEADER_NAME];
28
+ let signature;
29
+ if (req instanceof NextRequest) {
30
+ signature = req.headers.get(SIGNATURE_HEADER_NAME);
31
+ } else {
32
+ signature = req.headers[SIGNATURE_HEADER_NAME];
33
+ }
28
34
  if (Array.isArray(signature)) {
29
35
  signature = signature[0];
30
36
  }
31
- const body = await _readBody(req);
37
+ let body;
38
+ if (req instanceof NextRequest) {
39
+ body = JSON.stringify(await req.json());
40
+ } else {
41
+ body = await _readBody(req);
42
+ }
32
43
  const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null;
33
44
  if (validSignature !== false && waitForContentLakeEventualConsistency) {
34
45
  await new Promise(resolve => setTimeout(resolve, 1e3));
@@ -1 +1 @@
1
- {"version":3,"file":"webhook.js","sources":["../src/webhook/config.ts","../src/webhook/readBody.ts","../src/webhook/parseBody.ts"],"sourcesContent":["import type {PageConfig} from 'next/types'\n\n/**\n * Configurates the API function with the right runtime and body parsing to handle Sanity Webhook events.\n * @public\n */\nexport const config: PageConfig = {\n api: {\n /**\n * Next.js will by default parse the body, which can lead to invalid signatures.\n */\n bodyParser: false,\n },\n /**\n * `@sanity/webhook` isn't updated to support the edge runtime yet, and currently requires Node.js APIs such as Buffer.\n */\n runtime: 'nodejs',\n}\n","import type {NextApiRequest} from 'next'\n\n/** @internal */\nexport async function _readBody(readable: NextApiRequest): Promise<string> {\n const chunks = []\n for await (const chunk of readable) {\n chunks.push(typeof chunk === 'string' ? Buffer.from(chunk) : chunk)\n }\n return Buffer.concat(chunks).toString('utf8')\n}\n","import type {SanityDocument} from '@sanity/types'\nimport sanityWebhook from '@sanity/webhook'\nimport type {NextApiRequest} from 'next'\n\n// As `@sanity/webhook` isn't shipping ESM, extracting from the default export have the best ecosystem support\nconst {isValidSignature, SIGNATURE_HEADER_NAME} = sanityWebhook\n\nimport {_readBody as readBody} from './readBody'\n\n/** @public */\nexport type ParseBody = {\n /**\n * If a secret is given then it returns a boolean. If no secret is provided then no validation is done on the signature, and it'll return `null`\n */\n isValidSignature: boolean | null\n body: SanityDocument\n}\n/**\n * Handles parsing the body JSON, and validating its signature. Also waits for Content Lake eventual consistency so you can run your queries\n * without worrying about getting stale data.\n * @public\n */\nexport async function parseBody(\n req: NextApiRequest,\n secret?: string,\n waitForContentLakeEventualConsistency: boolean = true\n): Promise<ParseBody> {\n let signature = req.headers[SIGNATURE_HEADER_NAME]!\n if (Array.isArray(signature)) {\n signature = signature[0]\n }\n\n const body = await readBody(req)\n const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null\n\n if (validSignature !== false && waitForContentLakeEventualConsistency) {\n await new Promise((resolve) => setTimeout(resolve, 1000))\n }\n\n return {\n body: body.trim() && JSON.parse(body),\n isValidSignature: validSignature,\n }\n}\n"],"names":["config","api","bodyParser","runtime","_readBody","readable","chunks","chunk","push","Buffer","from","concat","toString","isValidSignature","SIGNATURE_HEADER_NAME","sanityWebhook","parseBody","req","secret","waitForContentLakeEventualConsistency","arguments","length","undefined","signature","headers","Array","isArray","body","readBody","validSignature","trim","Promise","resolve","setTimeout","JSON","parse"],"mappings":";AAMO,MAAMA,MAAqB,GAAA;EAChCC,GAAK,EAAA;IAAA;AAAA;AAAA;IAIHC,UAAY,EAAA;EACd,CAAA;EAAA;AAAA;AAAA;EAIAC,OAAS,EAAA;AACX,CAAA;ACdA,eAAsBC,UAAUC,QAA2C,EAAA;EACzE,MAAMC,SAAS,EAAC;EAChB,WAAA,MAAiBC,SAASF,QAAU,EAAA;IAC3BC,MAAA,CAAAE,IAAA,CAAK,OAAOD,KAAU,KAAA,QAAA,GAAWE,OAAOC,IAAK,CAAAH,KAAK,IAAIA,KAAK,CAAA;EACpE;EACA,OAAOE,MAAO,CAAAE,MAAA,CAAOL,MAAM,CAAA,CAAEM,SAAS,MAAM,CAAA;AAC9C;ACJA,MAAM;EAACC,gBAAkB;EAAAC;AAAyB,CAAA,GAAAC,aAAA;AAiBlD,eAAsBC,SACpBA,CAAAC,GAAA,EACAC,MACA,EACoB;EAAA,IADpBC,qCAAA,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAiD,IAC7B;EAChB,IAAAG,SAAA,GAAYN,GAAI,CAAAO,OAAA,CAAQV,qBAAqB,CAAA;EAC7C,IAAAW,KAAA,CAAMC,OAAQ,CAAAH,SAAS,CAAG,EAAA;IAC5BA,SAAA,GAAYA,UAAU,CAAC,CAAA;EACzB;EAEM,MAAAI,IAAA,GAAO,MAAMC,SAAA,CAASX,GAAG,CAAA;EACzB,MAAAY,cAAA,GAAiBX,SAASL,gBAAiB,CAAAc,IAAA,EAAMJ,WAAWL,MAAO,CAAAY,IAAA,EAAM,CAAI,GAAA,IAAA;EAE/E,IAAAD,cAAA,KAAmB,SAASV,qCAAuC,EAAA;IACrE,MAAM,IAAIY,OAAQ,CAACC,WAAYC,UAAW,CAAAD,OAAA,EAAS,GAAI,CAAC,CAAA;EAC1D;EAEO,OAAA;IACLL,MAAMA,IAAK,CAAAG,IAAA,CAAA,CAAU,IAAAI,IAAA,CAAKC,MAAMR,IAAI,CAAA;IACpCd,gBAAkB,EAAAgB;EAAA,CACpB;AACF;"}
1
+ {"version":3,"file":"webhook.js","sources":["../src/webhook/config.ts","../src/webhook/readBody.ts","../src/webhook/parseBody.ts"],"sourcesContent":["import type {PageConfig} from 'next/types'\n\n/**\n * Configurates the API function with the right runtime and body parsing to handle Sanity Webhook events.\n * @public\n */\nexport const config: PageConfig = {\n api: {\n /**\n * Next.js will by default parse the body, which can lead to invalid signatures.\n */\n bodyParser: false,\n },\n /**\n * `@sanity/webhook` isn't updated to support the edge runtime yet, and currently requires Node.js APIs such as Buffer.\n */\n runtime: 'nodejs',\n}\n","import type {NextApiRequest} from 'next'\n\n/** @internal */\nexport async function _readBody(readable: NextApiRequest): Promise<string> {\n const chunks = []\n for await (const chunk of readable) {\n chunks.push(typeof chunk === 'string' ? Buffer.from(chunk) : chunk)\n }\n return Buffer.concat(chunks).toString('utf8')\n}\n","import type {SanityDocument} from '@sanity/types'\nimport sanityWebhook from '@sanity/webhook'\nimport type {NextApiRequest} from 'next'\nimport {NextRequest} from 'next/server'\n\n// As `@sanity/webhook` isn't shipping ESM, extracting from the default export have the best ecosystem support\nconst {isValidSignature, SIGNATURE_HEADER_NAME} = sanityWebhook\n\nimport {_readBody as readBody} from './readBody'\n\n/** @public */\nexport type ParseBody = {\n /**\n * If a secret is given then it returns a boolean. If no secret is provided then no validation is done on the signature, and it'll return `null`\n */\n isValidSignature: boolean | null\n body: SanityDocument\n}\n/**\n * Handles parsing the body JSON, and validating its signature. Also waits for Content Lake eventual consistency so you can run your queries\n * without worrying about getting stale data.\n * @public\n */\nexport async function parseBody(\n req: NextApiRequest | NextRequest,\n secret?: string,\n waitForContentLakeEventualConsistency: boolean = true\n): Promise<ParseBody> {\n let signature\n if (req instanceof NextRequest) {\n signature = req.headers.get(SIGNATURE_HEADER_NAME)!\n } else {\n signature = req.headers[SIGNATURE_HEADER_NAME]!\n }\n if (Array.isArray(signature)) {\n signature = signature[0]\n }\n let body\n if (req instanceof NextRequest) {\n body = JSON.stringify(await req.json())\n } else {\n body = await readBody(req)\n }\n const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null\n\n if (validSignature !== false && waitForContentLakeEventualConsistency) {\n await new Promise((resolve) => setTimeout(resolve, 1000))\n }\n\n return {\n body: body.trim() && JSON.parse(body),\n isValidSignature: validSignature,\n }\n}\n"],"names":["config","api","bodyParser","runtime","_readBody","readable","chunks","chunk","push","Buffer","from","concat","toString","isValidSignature","SIGNATURE_HEADER_NAME","sanityWebhook","parseBody","req","secret","waitForContentLakeEventualConsistency","arguments","length","undefined","signature","NextRequest","headers","get","Array","isArray","body","JSON","stringify","json","readBody","validSignature","trim","Promise","resolve","setTimeout","parse"],"mappings":";;AAMO,MAAMA,MAAqB,GAAA;EAChCC,GAAK,EAAA;IAAA;AAAA;AAAA;IAIHC,UAAY,EAAA;EACd,CAAA;EAAA;AAAA;AAAA;EAIAC,OAAS,EAAA;AACX,CAAA;ACdA,eAAsBC,UAAUC,QAA2C,EAAA;EACzE,MAAMC,SAAS,EAAC;EAChB,WAAA,MAAiBC,SAASF,QAAU,EAAA;IAC3BC,MAAA,CAAAE,IAAA,CAAK,OAAOD,KAAU,KAAA,QAAA,GAAWE,OAAOC,IAAK,CAAAH,KAAK,IAAIA,KAAK,CAAA;EACpE;EACA,OAAOE,MAAO,CAAAE,MAAA,CAAOL,MAAM,CAAA,CAAEM,SAAS,MAAM,CAAA;AAC9C;ACHA,MAAM;EAACC,gBAAkB;EAAAC;AAAyB,CAAA,GAAAC,aAAA;AAiBlD,eAAsBC,SACpBA,CAAAC,GAAA,EACAC,MACA,EACoB;EAAA,IADpBC,qCAAA,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAiD,IAC7B;EAChB,IAAAG,SAAA;EACJ,IAAIN,eAAeO,WAAa,EAAA;IAClBD,SAAA,GAAAN,GAAA,CAAIQ,OAAQ,CAAAC,GAAA,CAAIZ,qBAAqB,CAAA;EAAA,CAC5C,MAAA;IACOS,SAAA,GAAAN,GAAA,CAAIQ,QAAQX,qBAAqB,CAAA;EAC/C;EACI,IAAAa,KAAA,CAAMC,OAAQ,CAAAL,SAAS,CAAG,EAAA;IAC5BA,SAAA,GAAYA,UAAU,CAAC,CAAA;EACzB;EACI,IAAAM,IAAA;EACJ,IAAIZ,eAAeO,WAAa,EAAA;IAC9BK,IAAA,GAAOC,IAAK,CAAAC,SAAA,CAAU,MAAMd,GAAA,CAAIe,KAAM,CAAA,CAAA;EAAA,CACjC,MAAA;IACEH,IAAA,GAAA,MAAMI,UAAShB,GAAG,CAAA;EAC3B;EACM,MAAAiB,cAAA,GAAiBhB,SAASL,gBAAiB,CAAAgB,IAAA,EAAMN,WAAWL,MAAO,CAAAiB,IAAA,EAAM,CAAI,GAAA,IAAA;EAE/E,IAAAD,cAAA,KAAmB,SAASf,qCAAuC,EAAA;IACrE,MAAM,IAAIiB,OAAQ,CAACC,WAAYC,UAAW,CAAAD,OAAA,EAAS,GAAI,CAAC,CAAA;EAC1D;EAEO,OAAA;IACLR,MAAMA,IAAK,CAAAM,IAAA,CAAA,CAAU,IAAAL,IAAA,CAAKS,MAAMV,IAAI,CAAA;IACpChB,gBAAkB,EAAAqB;EAAA,CACpB;AACF;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "next-sanity",
3
- "version": "5.0.0",
3
+ "version": "5.0.2",
4
4
  "description": "Sanity.io toolkit for Next.js",
5
5
  "keywords": [
6
6
  "sanity",
@@ -160,7 +160,7 @@
160
160
  "singleQuote": true
161
161
  },
162
162
  "dependencies": {
163
- "@sanity/preview-kit": "2.2.1",
163
+ "@sanity/preview-kit": "2.2.2",
164
164
  "@sanity/webhook": "2.0.0",
165
165
  "groq": "^3.0.0"
166
166
  },
@@ -1,6 +1,7 @@
1
1
  import type {SanityDocument} from '@sanity/types'
2
2
  import sanityWebhook from '@sanity/webhook'
3
3
  import type {NextApiRequest} from 'next'
4
+ import {NextRequest} from 'next/server'
4
5
 
5
6
  // As `@sanity/webhook` isn't shipping ESM, extracting from the default export have the best ecosystem support
6
7
  const {isValidSignature, SIGNATURE_HEADER_NAME} = sanityWebhook
@@ -21,16 +22,25 @@ export type ParseBody = {
21
22
  * @public
22
23
  */
23
24
  export async function parseBody(
24
- req: NextApiRequest,
25
+ req: NextApiRequest | NextRequest,
25
26
  secret?: string,
26
27
  waitForContentLakeEventualConsistency: boolean = true
27
28
  ): Promise<ParseBody> {
28
- let signature = req.headers[SIGNATURE_HEADER_NAME]!
29
+ let signature
30
+ if (req instanceof NextRequest) {
31
+ signature = req.headers.get(SIGNATURE_HEADER_NAME)!
32
+ } else {
33
+ signature = req.headers[SIGNATURE_HEADER_NAME]!
34
+ }
29
35
  if (Array.isArray(signature)) {
30
36
  signature = signature[0]
31
37
  }
32
-
33
- const body = await readBody(req)
38
+ let body
39
+ if (req instanceof NextRequest) {
40
+ body = JSON.stringify(await req.json())
41
+ } else {
42
+ body = await readBody(req)
43
+ }
34
44
  const validSignature = secret ? isValidSignature(body, signature, secret.trim()) : null
35
45
 
36
46
  if (validSignature !== false && waitForContentLakeEventualConsistency) {