@payloadcms/email-resend 3.83.0-internal.06ac84e → 3.83.0-internal.ddc1147

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.
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAoB,MAAM,SAAS,CAAA;AAI7D,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,MAAM,CAAA;IACd,kBAAkB,EAAE,MAAM,CAAA;IAC1B,eAAe,EAAE,MAAM,CAAA;CACxB,CAAA;AAED,KAAK,aAAa,GAAG,YAAY,CAAC,cAAc,CAAC,CAAA;AAEjD,KAAK,WAAW,GAAG;IACjB,OAAO,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,KAAK,cAAc,GAAG;IAAE,EAAE,EAAE,MAAM,CAAA;CAAE,GAAG,WAAW,CAAA;AAElD;;GAEG;AACH,eAAO,MAAM,aAAa,SAAU,iBAAiB,KAAG,aAyCvD,CAAA;AAsKD,MAAM,MAAM,GAAG,GAAG;IAChB;;OAEG;IACH,IAAI,EAAE,MAAM,CAAA;IACZ;;OAEG;IACH,KAAK,EAAE,MAAM,CAAA;CACd,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAoB,MAAM,SAAS,CAAA;AAI7D,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,MAAM,CAAA;IACd,kBAAkB,EAAE,MAAM,CAAA;IAC1B,eAAe,EAAE,MAAM,CAAA;CACxB,CAAA;AAED,KAAK,aAAa,GAAG,YAAY,CAAC,cAAc,CAAC,CAAA;AAEjD,KAAK,WAAW,GAAG;IACjB,OAAO,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,KAAK,cAAc,GAAG;IAAE,EAAE,EAAE,MAAM,CAAA;CAAE,GAAG,WAAW,CAAA;AAElD;;GAEG;AACH,eAAO,MAAM,aAAa,SAAU,iBAAiB,KAAG,aAyCvD,CAAA;AA8MD,MAAM,MAAM,GAAG,GAAG;IAChB;;OAEG;IACH,IAAI,EAAE,MAAM,CAAA;IACZ;;OAEG;IACH,KAAK,EAAE,MAAM,CAAA;CACd,CAAA"}
package/dist/index.js CHANGED
@@ -45,6 +45,7 @@ function mapPayloadEmailToResendEmail(message, defaultFromAddress, defaultFromNa
45
45
  reply_to: mapAddresses(message.replyTo),
46
46
  // Optional
47
47
  attachments: mapAttachments(message.attachments),
48
+ headers: mapHeaders(message.headers),
48
49
  html: message.html?.toString() || '',
49
50
  text: message.text?.toString() || ''
50
51
  };
@@ -77,12 +78,23 @@ function mapAttachments(attachments) {
77
78
  return [];
78
79
  }
79
80
  return attachments.map((attachment)=>{
80
- if (!attachment.filename || !attachment.content) {
81
- throw new APIError('Attachment is missing filename or content', 400);
81
+ if (!attachment.filename) {
82
+ throw new APIError('Attachment is missing filename', 400);
83
+ }
84
+ if (!attachment.content && !attachment.path) {
85
+ throw new APIError('Attachment is missing both content and path', 400);
86
+ }
87
+ // When both content and path are provided, content takes priority; path is ignored.
88
+ if (attachment.path && !attachment.content) {
89
+ const path = typeof attachment.path === 'string' ? attachment.path : attachment.path.href;
90
+ return {
91
+ filename: attachment.filename,
92
+ path
93
+ };
82
94
  }
83
95
  if (typeof attachment.content === 'string') {
84
96
  return {
85
- content: Buffer.from(attachment.content),
97
+ content: attachment.content,
86
98
  filename: attachment.filename
87
99
  };
88
100
  }
@@ -95,5 +107,28 @@ function mapAttachments(attachments) {
95
107
  throw new APIError('Attachment content must be a string or a buffer', 400);
96
108
  });
97
109
  }
110
+ function mapHeaders(headers) {
111
+ if (!headers) {
112
+ return undefined;
113
+ }
114
+ // Array-of-objects form: [{ key: string; value: string }, ...]
115
+ if (Array.isArray(headers)) {
116
+ return headers.reduce((acc, { key, value })=>{
117
+ acc[key] = value;
118
+ return acc;
119
+ }, {});
120
+ }
121
+ // Object form: { [key: string]: string | string[] | { prepared: boolean; value: string } }
122
+ return Object.entries(headers).reduce((acc, [key, value])=>{
123
+ if (typeof value === 'string') {
124
+ acc[key] = value;
125
+ } else if (Array.isArray(value)) {
126
+ acc[key] = value.join(', ');
127
+ } else {
128
+ acc[key] = value.value;
129
+ }
130
+ return acc;
131
+ }, {});
132
+ }
98
133
 
99
134
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { EmailAdapter, SendEmailOptions } from 'payload'\n\nimport { APIError } from 'payload'\n\nexport type ResendAdapterArgs = {\n apiKey: string\n defaultFromAddress: string\n defaultFromName: string\n}\n\ntype ResendAdapter = EmailAdapter<ResendResponse>\n\ntype ResendError = {\n message: string\n name: string\n statusCode: number\n}\n\ntype ResendResponse = { id: string } | ResendError\n\n/**\n * Email adapter for [Resend](https://resend.com) REST API\n */\nexport const resendAdapter = (args: ResendAdapterArgs): ResendAdapter => {\n const { apiKey, defaultFromAddress, defaultFromName } = args\n\n const adapter: ResendAdapter = () => ({\n name: 'resend-rest',\n defaultFromAddress,\n defaultFromName,\n sendEmail: async (message) => {\n // Map the Payload email options to Resend email options\n const sendEmailOptions = mapPayloadEmailToResendEmail(\n message,\n defaultFromAddress,\n defaultFromName,\n )\n\n const res = await fetch('https://api.resend.com/emails', {\n body: JSON.stringify(sendEmailOptions),\n headers: {\n Authorization: `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n })\n\n const data = (await res.json()) as ResendResponse\n\n if ('id' in data) {\n return data\n } else {\n const statusCode = data.statusCode || res.status\n let formattedError = `Error sending email: ${statusCode}`\n if (data.name && data.message) {\n formattedError += ` ${data.name} - ${data.message}`\n }\n\n throw new APIError(formattedError, statusCode)\n }\n },\n })\n\n return adapter\n}\n\nfunction mapPayloadEmailToResendEmail(\n message: SendEmailOptions,\n defaultFromAddress: string,\n defaultFromName: string,\n): ResendSendEmailOptions {\n return {\n // Required\n from: mapFromAddress(message.from, defaultFromName, defaultFromAddress),\n subject: message.subject ?? '',\n to: mapAddresses(message.to),\n\n // Other To fields\n bcc: mapAddresses(message.bcc),\n cc: mapAddresses(message.cc),\n reply_to: mapAddresses(message.replyTo),\n\n // Optional\n attachments: mapAttachments(message.attachments),\n html: message.html?.toString() || '',\n text: message.text?.toString() || '',\n } as ResendSendEmailOptions\n}\n\nfunction mapFromAddress(\n address: SendEmailOptions['from'],\n defaultFromName: string,\n defaultFromAddress: string,\n): ResendSendEmailOptions['from'] {\n if (!address) {\n return `${defaultFromName} <${defaultFromAddress}>`\n }\n\n if (typeof address === 'string') {\n return address\n }\n\n return `${address.name} <${address.address}>`\n}\n\nfunction mapAddresses(addresses: SendEmailOptions['to']): ResendSendEmailOptions['to'] {\n if (!addresses) {\n return ''\n }\n\n if (typeof addresses === 'string') {\n return addresses\n }\n\n if (Array.isArray(addresses)) {\n return addresses.map((address) => (typeof address === 'string' ? address : address.address))\n }\n\n return [addresses.address]\n}\n\nfunction mapAttachments(\n attachments: SendEmailOptions['attachments'],\n): ResendSendEmailOptions['attachments'] {\n if (!attachments) {\n return []\n }\n\n return attachments.map((attachment) => {\n if (!attachment.filename || !attachment.content) {\n throw new APIError('Attachment is missing filename or content', 400)\n }\n\n if (typeof attachment.content === 'string') {\n return {\n content: Buffer.from(attachment.content),\n filename: attachment.filename,\n }\n }\n\n if (attachment.content instanceof Buffer) {\n return {\n content: attachment.content,\n filename: attachment.filename,\n }\n }\n\n throw new APIError('Attachment content must be a string or a buffer', 400)\n })\n}\n\ntype ResendSendEmailOptions = {\n /**\n * Filename and content of attachments (max 40mb per email)\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n attachments?: Attachment[]\n /**\n * Blind carbon copy recipient email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n bcc?: string | string[]\n\n /**\n * Carbon copy recipient email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n cc?: string | string[]\n /**\n * Sender email address. To include a friendly name, use the format `\"Your Name <sender@domain.com>\"`\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n from: string\n /**\n * Custom headers to add to the email.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n headers?: Record<string, string>\n /**\n * The HTML version of the message.\n *\n * @link https://resend.com/api-reference/emails/send-email#body-parameters\n */\n html?: string\n /**\n * Reply-to email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n reply_to?: string | string[]\n /**\n * Email subject.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n subject: string\n /**\n * Email tags\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n tags?: Tag[]\n /**\n * The plain text version of the message.\n *\n * @link https://resend.com/api-reference/emails/send-email#body-parameters\n */\n text?: string\n /**\n * Recipient email address. For multiple addresses, send as an array of strings. Max 50.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n to: string | string[]\n}\n\ntype Attachment = {\n /** Content of an attached file. */\n content?: Buffer | string\n /** Name of attached file. */\n filename?: false | string | undefined\n /** Path where the attachment file is hosted */\n path?: string\n}\n\nexport type Tag = {\n /**\n * The name of the email tag. It can only contain ASCII letters (a–z, A–Z), numbers (0–9), underscores (_), or dashes (-). It can contain no more than 256 characters.\n */\n name: string\n /**\n * The value of the email tag. It can only contain ASCII letters (a–z, A–Z), numbers (0–9), underscores (_), or dashes (-). It can contain no more than 256 characters.\n */\n value: string\n}\n"],"names":["APIError","resendAdapter","args","apiKey","defaultFromAddress","defaultFromName","adapter","name","sendEmail","message","sendEmailOptions","mapPayloadEmailToResendEmail","res","fetch","body","JSON","stringify","headers","Authorization","method","data","json","statusCode","status","formattedError","from","mapFromAddress","subject","to","mapAddresses","bcc","cc","reply_to","replyTo","attachments","mapAttachments","html","toString","text","address","addresses","Array","isArray","map","attachment","filename","content","Buffer"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { EmailAdapter, SendEmailOptions } from 'payload'\n\nimport { APIError } from 'payload'\n\nexport type ResendAdapterArgs = {\n apiKey: string\n defaultFromAddress: string\n defaultFromName: string\n}\n\ntype ResendAdapter = EmailAdapter<ResendResponse>\n\ntype ResendError = {\n message: string\n name: string\n statusCode: number\n}\n\ntype ResendResponse = { id: string } | ResendError\n\n/**\n * Email adapter for [Resend](https://resend.com) REST API\n */\nexport const resendAdapter = (args: ResendAdapterArgs): ResendAdapter => {\n const { apiKey, defaultFromAddress, defaultFromName } = args\n\n const adapter: ResendAdapter = () => ({\n name: 'resend-rest',\n defaultFromAddress,\n defaultFromName,\n sendEmail: async (message) => {\n // Map the Payload email options to Resend email options\n const sendEmailOptions = mapPayloadEmailToResendEmail(\n message,\n defaultFromAddress,\n defaultFromName,\n )\n\n const res = await fetch('https://api.resend.com/emails', {\n body: JSON.stringify(sendEmailOptions),\n headers: {\n Authorization: `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n })\n\n const data = (await res.json()) as ResendResponse\n\n if ('id' in data) {\n return data\n } else {\n const statusCode = data.statusCode || res.status\n let formattedError = `Error sending email: ${statusCode}`\n if (data.name && data.message) {\n formattedError += ` ${data.name} - ${data.message}`\n }\n\n throw new APIError(formattedError, statusCode)\n }\n },\n })\n\n return adapter\n}\n\nfunction mapPayloadEmailToResendEmail(\n message: SendEmailOptions,\n defaultFromAddress: string,\n defaultFromName: string,\n): ResendSendEmailOptions {\n return {\n // Required\n from: mapFromAddress(message.from, defaultFromName, defaultFromAddress),\n subject: message.subject ?? '',\n to: mapAddresses(message.to),\n\n // Other To fields\n bcc: mapAddresses(message.bcc),\n cc: mapAddresses(message.cc),\n reply_to: mapAddresses(message.replyTo),\n\n // Optional\n attachments: mapAttachments(message.attachments),\n headers: mapHeaders(message.headers),\n html: message.html?.toString() || '',\n text: message.text?.toString() || '',\n } as ResendSendEmailOptions\n}\n\nfunction mapFromAddress(\n address: SendEmailOptions['from'],\n defaultFromName: string,\n defaultFromAddress: string,\n): ResendSendEmailOptions['from'] {\n if (!address) {\n return `${defaultFromName} <${defaultFromAddress}>`\n }\n\n if (typeof address === 'string') {\n return address\n }\n\n return `${address.name} <${address.address}>`\n}\n\nfunction mapAddresses(addresses: SendEmailOptions['to']): ResendSendEmailOptions['to'] {\n if (!addresses) {\n return ''\n }\n\n if (typeof addresses === 'string') {\n return addresses\n }\n\n if (Array.isArray(addresses)) {\n return addresses.map((address) => (typeof address === 'string' ? address : address.address))\n }\n\n return [addresses.address]\n}\n\nfunction mapAttachments(\n attachments: SendEmailOptions['attachments'],\n): ResendSendEmailOptions['attachments'] {\n if (!attachments) {\n return []\n }\n\n return attachments.map((attachment): Attachment => {\n if (!attachment.filename) {\n throw new APIError('Attachment is missing filename', 400)\n }\n\n if (!attachment.content && !attachment.path) {\n throw new APIError('Attachment is missing both content and path', 400)\n }\n\n // When both content and path are provided, content takes priority; path is ignored.\n if (attachment.path && !attachment.content) {\n const path = typeof attachment.path === 'string' ? attachment.path : attachment.path.href\n return {\n filename: attachment.filename,\n path,\n }\n }\n\n if (typeof attachment.content === 'string') {\n return {\n content: attachment.content,\n filename: attachment.filename,\n }\n }\n\n if (attachment.content instanceof Buffer) {\n return {\n content: attachment.content,\n filename: attachment.filename,\n }\n }\n\n throw new APIError('Attachment content must be a string or a buffer', 400)\n })\n}\n\nfunction mapHeaders(headers: SendEmailOptions['headers']): Record<string, string> | undefined {\n if (!headers) {\n return undefined\n }\n\n // Array-of-objects form: [{ key: string; value: string }, ...]\n if (Array.isArray(headers)) {\n return headers.reduce<Record<string, string>>((acc, { key, value }) => {\n acc[key] = value\n return acc\n }, {})\n }\n\n // Object form: { [key: string]: string | string[] | { prepared: boolean; value: string } }\n return Object.entries(headers).reduce<Record<string, string>>((acc, [key, value]) => {\n if (typeof value === 'string') {\n acc[key] = value\n } else if (Array.isArray(value)) {\n acc[key] = value.join(', ')\n } else {\n acc[key] = value.value\n }\n return acc\n }, {})\n}\n\ntype ResendSendEmailOptions = {\n /**\n * Filename and content of attachments (max 40mb per email)\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n attachments?: Attachment[]\n /**\n * Blind carbon copy recipient email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n bcc?: string | string[]\n\n /**\n * Carbon copy recipient email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n cc?: string | string[]\n /**\n * Sender email address. To include a friendly name, use the format `\"Your Name <sender@domain.com>\"`\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n from: string\n /**\n * Custom headers to add to the email.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n headers?: Record<string, string>\n /**\n * The HTML version of the message.\n *\n * @link https://resend.com/api-reference/emails/send-email#body-parameters\n */\n html?: string\n /**\n * Reply-to email address. For multiple addresses, send as an array of strings.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n reply_to?: string | string[]\n /**\n * Email subject.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n subject: string\n /**\n * Email tags\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n tags?: Tag[]\n /**\n * The plain text version of the message.\n *\n * @link https://resend.com/api-reference/emails/send-email#body-parameters\n */\n text?: string\n /**\n * Recipient email address. For multiple addresses, send as an array of strings. Max 50.\n *\n * @link https://resend.com/docs/api-reference/emails/send-email#body-parameters\n */\n to: string | string[]\n}\n\ntype Attachment = {\n /** Content of an attached file. */\n content?: Buffer | string\n /** Name of attached file. */\n filename?: false | string | undefined\n /** Path where the attachment file is hosted */\n path?: string\n}\n\nexport type Tag = {\n /**\n * The name of the email tag. It can only contain ASCII letters (a–z, A–Z), numbers (0–9), underscores (_), or dashes (-). It can contain no more than 256 characters.\n */\n name: string\n /**\n * The value of the email tag. It can only contain ASCII letters (a–z, A–Z), numbers (0–9), underscores (_), or dashes (-). It can contain no more than 256 characters.\n */\n value: string\n}\n"],"names":["APIError","resendAdapter","args","apiKey","defaultFromAddress","defaultFromName","adapter","name","sendEmail","message","sendEmailOptions","mapPayloadEmailToResendEmail","res","fetch","body","JSON","stringify","headers","Authorization","method","data","json","statusCode","status","formattedError","from","mapFromAddress","subject","to","mapAddresses","bcc","cc","reply_to","replyTo","attachments","mapAttachments","mapHeaders","html","toString","text","address","addresses","Array","isArray","map","attachment","filename","content","path","href","Buffer","undefined","reduce","acc","key","value","Object","entries","join"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/email-resend",
3
- "version": "3.83.0-internal.06ac84e",
3
+ "version": "3.83.0-internal.ddc1147",
4
4
  "description": "Payload Resend Email Adapter",
5
5
  "homepage": "https://payloadcms.com",
6
6
  "repository": {
@@ -32,10 +32,10 @@
32
32
  "dist"
33
33
  ],
34
34
  "devDependencies": {
35
- "payload": "3.83.0-internal.06ac84e"
35
+ "payload": "3.83.0-internal.ddc1147"
36
36
  },
37
37
  "peerDependencies": {
38
- "payload": "3.83.0-internal.06ac84e"
38
+ "payload": "3.83.0-internal.ddc1147"
39
39
  },
40
40
  "engines": {
41
41
  "node": "^18.20.2 || >=20.9.0"