@visulima/email 1.0.0-alpha.1 → 1.0.0-alpha.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.
Files changed (138) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/README.md +377 -60
  3. package/dist/crypto/index.js +1 -1
  4. package/dist/draft-mail-message.d.ts +13 -0
  5. package/dist/index.d.ts +3 -16
  6. package/dist/index.js +1 -1
  7. package/dist/mail-message.d.ts +425 -0
  8. package/dist/mail.d.ts +124 -275
  9. package/dist/packem_shared/{DkimSigner-Z8D4Il10.js → DkimSigner-pFd4c3fZ.js} +1 -1
  10. package/dist/packem_shared/Mail-6Bltpy_p.js +1 -0
  11. package/dist/packem_shared/MailMessage-B76GPBBA.js +1 -0
  12. package/dist/packem_shared/{SmimeSigner-02aXVi90.js → SmimeSigner-CObA4jzT.js} +1 -1
  13. package/dist/packem_shared/ahaSendProvider-DlFKEQ6D.js +1 -0
  14. package/dist/packem_shared/{awsSesProvider-CkuFOzb0.js → awsSesProvider-Ba-eVJxZ.js} +6 -6
  15. package/dist/packem_shared/azureProvider-CQYAkgVF.js +1 -0
  16. package/dist/packem_shared/brevoProvider-5p6jjiK9.js +1 -0
  17. package/dist/packem_shared/build-mime-message-IYaUqqPJ.js +2 -0
  18. package/dist/packem_shared/create-logger-BiWdqFNg.js +1 -0
  19. package/dist/packem_shared/failoverProvider-CAHQQueo.js +1 -0
  20. package/dist/packem_shared/{generateBoundary-CZ8kJuY6.js → generate-boundary-Cx8nXYS0.js} +1 -1
  21. package/dist/packem_shared/{generateMessageId-11Ls5JsR.js → generate-message-id-D4uA8gkj.js} +1 -1
  22. package/dist/packem_shared/headers-to-record-Qo124ImV.js +1 -0
  23. package/dist/packem_shared/httpProvider-CZD6LZX3.js +1 -0
  24. package/dist/packem_shared/infobipProvider-CtLwrUaP.js +1 -0
  25. package/dist/packem_shared/{mailCrabProvider-BEwRjB3F.js → mailCrabProvider-CM_CFDca.js} +1 -1
  26. package/dist/packem_shared/mailPaceProvider-B6yKvh6z.js +1 -0
  27. package/dist/packem_shared/mailerSendProvider-CeeIXFnW.js +1 -0
  28. package/dist/packem_shared/mailgunProvider-mmjKzouh.js +1 -0
  29. package/dist/packem_shared/mailjetProvider-DwN6i0VA.js +1 -0
  30. package/dist/packem_shared/mailomatProvider-DMQmjKHT.js +1 -0
  31. package/dist/packem_shared/mailtrapProvider-BN3UBEQw.js +1 -0
  32. package/dist/packem_shared/{makeRequest-DwxHX0xo.js → make-request-BDzF9W9D.js} +1 -1
  33. package/dist/packem_shared/mandrillProvider-370y7CLu.js +1 -0
  34. package/dist/packem_shared/mockProvider-DN5ZwutD.js +1 -0
  35. package/dist/packem_shared/nodemailerProvider-_w8QXMU-.js +1 -0
  36. package/dist/packem_shared/opentelemetryProvider-C_ZXOLSd.js +1 -0
  37. package/dist/packem_shared/plunkProvider-DfJumQ4U.js +1 -0
  38. package/dist/packem_shared/postalProvider-Bavx2FcH.js +1 -0
  39. package/dist/packem_shared/postmarkProvider-DFC0uvjO.js +1 -0
  40. package/dist/packem_shared/provider-base-Cmzx6BTO.js +1 -0
  41. package/dist/packem_shared/resendProvider-CfqU7UdE.js +1 -0
  42. package/dist/packem_shared/roundRobinProvider-1WQnuKR8.js +1 -0
  43. package/dist/packem_shared/scalewayProvider-be1HPimL.js +1 -0
  44. package/dist/packem_shared/sendGridProvider-BVI1sq3n.js +1 -0
  45. package/dist/packem_shared/smtpProvider-BV-ufR53.js +23 -0
  46. package/dist/packem_shared/sweegoProvider-7419CSAq.js +1 -0
  47. package/dist/packem_shared/validate-email-options-DfJ7llf8.js +1 -0
  48. package/dist/packem_shared/zeptomailProvider-C2lh0Xmo.js +1 -0
  49. package/dist/providers/ahasend/index.js +1 -1
  50. package/dist/providers/aws-ses/index.js +1 -1
  51. package/dist/providers/azure/index.js +1 -1
  52. package/dist/providers/brevo/index.js +1 -1
  53. package/dist/providers/brevo/types.d.ts +10 -3
  54. package/dist/providers/failover/index.js +1 -1
  55. package/dist/providers/http/index.js +1 -1
  56. package/dist/providers/infobip/index.js +1 -1
  57. package/dist/providers/mailcrab/index.js +1 -1
  58. package/dist/providers/mailersend/index.js +1 -1
  59. package/dist/providers/mailgun/index.js +1 -1
  60. package/dist/providers/mailjet/index.js +1 -1
  61. package/dist/providers/mailomat/index.js +1 -1
  62. package/dist/providers/mailpace/index.js +1 -1
  63. package/dist/providers/mailtrap/index.js +1 -1
  64. package/dist/providers/mandrill/index.js +1 -1
  65. package/dist/providers/mock/index.js +1 -1
  66. package/dist/providers/nodemailer/index.js +1 -1
  67. package/dist/providers/opentelemetry/index.js +1 -1
  68. package/dist/providers/plunk/index.js +1 -1
  69. package/dist/providers/postal/index.js +1 -1
  70. package/dist/providers/postmark/index.js +1 -1
  71. package/dist/providers/resend/index.js +1 -1
  72. package/dist/providers/roundrobin/index.js +1 -1
  73. package/dist/providers/scaleway/index.js +1 -1
  74. package/dist/providers/sendgrid/index.js +1 -1
  75. package/dist/providers/smtp/index.js +1 -1
  76. package/dist/providers/sweego/index.js +1 -1
  77. package/dist/providers/zeptomail/index.js +1 -1
  78. package/dist/types.d.ts +18 -0
  79. package/dist/utils/cache.d.ts +54 -0
  80. package/dist/utils/cache.js +1 -0
  81. package/dist/utils/create-logger.d.ts +2 -4
  82. package/dist/utils/format-email-address.js +1 -0
  83. package/dist/utils/normalize-email-aliases.d.ts +22 -0
  84. package/dist/utils/normalize-email-aliases.js +1 -0
  85. package/dist/utils/parse-address.js +1 -0
  86. package/dist/utils/validation/check-mx-records.d.ts +42 -0
  87. package/dist/utils/validation/check-mx-records.js +1 -0
  88. package/dist/utils/validation/disposable-email-domains.d.ts +13 -0
  89. package/dist/utils/validation/disposable-email-domains.js +1 -0
  90. package/dist/utils/validation/role-accounts.d.ts +21 -0
  91. package/dist/utils/validation/role-accounts.js +1 -0
  92. package/dist/utils/{validate-email-options.d.ts → validation/validate-email-options.d.ts} +1 -1
  93. package/dist/utils/validation/verify-email.d.ts +47 -0
  94. package/dist/utils/validation/verify-email.js +1 -0
  95. package/dist/utils/validation/verify-smtp.d.ts +39 -0
  96. package/dist/utils/validation/verify-smtp.js +4 -0
  97. package/package.json +47 -1
  98. package/dist/packem_shared/MailMessage-Hdgowmvi.js +0 -1
  99. package/dist/packem_shared/ahaSendProvider-NUD_kwyT.js +0 -1
  100. package/dist/packem_shared/azureProvider-Ckdrpmw9.js +0 -1
  101. package/dist/packem_shared/brevoProvider-CB3IYW4n.js +0 -1
  102. package/dist/packem_shared/buildMimeMessage-BPtd0pno.js +0 -2
  103. package/dist/packem_shared/comparePriority-BfiwjVsV.js +0 -1
  104. package/dist/packem_shared/createLogger-DlElSVQP.js +0 -1
  105. package/dist/packem_shared/failoverProvider-sam9n1AG.js +0 -1
  106. package/dist/packem_shared/formatEmailAddress-CHeME3Vk.js +0 -1
  107. package/dist/packem_shared/formatEmailAddresses-UegVOe5A.js +0 -1
  108. package/dist/packem_shared/headersToRecord-BKUTr40L.js +0 -1
  109. package/dist/packem_shared/httpProvider-BhN0RrK-.js +0 -1
  110. package/dist/packem_shared/infobipProvider-D8vYTHV4.js +0 -1
  111. package/dist/packem_shared/isPortAvailable-5kfsfo8u.js +0 -1
  112. package/dist/packem_shared/mailPaceProvider-C47Izgaj.js +0 -1
  113. package/dist/packem_shared/mailerSendProvider-C4uAo-fc.js +0 -1
  114. package/dist/packem_shared/mailgunProvider-B7upu_OV.js +0 -1
  115. package/dist/packem_shared/mailjetProvider-ReErm08u.js +0 -1
  116. package/dist/packem_shared/mailomatProvider-OlCT_O2i.js +0 -1
  117. package/dist/packem_shared/mailtrapProvider-hVMV3h6r.js +0 -1
  118. package/dist/packem_shared/mandrillProvider-DdnbkHZI.js +0 -1
  119. package/dist/packem_shared/mockProvider-BDWZJpea.js +0 -1
  120. package/dist/packem_shared/nodemailerProvider-BV21eRGX.js +0 -1
  121. package/dist/packem_shared/opentelemetryProvider-kAz62mKm.js +0 -1
  122. package/dist/packem_shared/parseAddress-CATTKGe_.js +0 -1
  123. package/dist/packem_shared/plunkProvider-Bs6K51lT.js +0 -1
  124. package/dist/packem_shared/postalProvider-Bcsxp-z6.js +0 -1
  125. package/dist/packem_shared/postmarkProvider-BUq3wuYD.js +0 -1
  126. package/dist/packem_shared/provider-base-_hbWXBdK.js +0 -1
  127. package/dist/packem_shared/resendProvider-D-_HQpN_.js +0 -1
  128. package/dist/packem_shared/retry-D1MBqS49.js +0 -1
  129. package/dist/packem_shared/roundRobinProvider-CejLM1rZ.js +0 -1
  130. package/dist/packem_shared/scalewayProvider-1n6ePiGl.js +0 -1
  131. package/dist/packem_shared/sendGridProvider-B1T62dyX.js +0 -1
  132. package/dist/packem_shared/smtpProvider-CcAoRrkt.js +0 -23
  133. package/dist/packem_shared/sweegoProvider-CxFmEUh6.js +0 -1
  134. package/dist/packem_shared/validateEmailOptions-BzlJECG5.js +0 -1
  135. package/dist/packem_shared/zeptomailProvider-CWYQPAJk.js +0 -1
  136. package/dist/utils/compare-priority.d.ts +0 -16
  137. /package/dist/utils/{validate-email.d.ts → validation/validate-email.d.ts} +0 -0
  138. /package/dist/{packem_shared/validateEmail-BkVdVioP.js → utils/validation/validate-email.js} +0 -0
@@ -0,0 +1,13 @@
1
+ import MailMessage from "./mail-message.d.ts";
2
+ /**
3
+ * Draft mail message - extends MailMessage with X-Unsent header automatically set.
4
+ * Draft messages cannot be sent directly - they must be converted to regular messages first.
5
+ */
6
+ export declare class DraftMailMessage extends MailMessage {
7
+ /**
8
+ * Creates a new draft mail message.
9
+ * The X-Unsent header is automatically set to '1' to mark this as a draft.
10
+ */
11
+ constructor();
12
+ }
13
+ export default DraftMailMessage;
package/dist/index.d.ts CHANGED
@@ -1,22 +1,9 @@
1
1
  export { type AttachmentDataOptions, type AttachmentOptions, detectMimeType, generateContentId, readFileAsBuffer } from "./attachment-helpers.d.ts";
2
2
  export { default as EmailError } from "./errors/email-error.d.ts";
3
3
  export { default as RequiredOptionError } from "./errors/required-option-error.d.ts";
4
- export { createMail, Mail, type Mailable, MailMessage } from "./mail.d.ts";
4
+ export { createMail, Mail, type MailGlobalConfig, type SendableMessage } from "./mail.d.ts";
5
+ export { default as MailMessage } from "./mail-message.d.ts";
5
6
  export type { Provider, ProviderFactory } from "./providers/provider.d.ts";
6
7
  export { defineProvider } from "./providers/provider.d.ts";
7
8
  export type { TemplateRenderer } from "./template-engines/types.d.ts";
8
- export type { Attachment, BaseConfig, EmailAddress, EmailHeaders, EmailOptions, EmailResult, EmailTag, FeatureFlags, ImmutableHeaders, MaybePromise, Priority, Receipt, Result, } from "./types.d.ts";
9
- export { default as buildMimeMessage } from "./utils/build-mime-message.d.ts";
10
- export { default as comparePriority } from "./utils/compare-priority.d.ts";
11
- export { default as createLogger } from "./utils/create-logger.d.ts";
12
- export { default as formatEmailAddress } from "./utils/format-email-address.d.ts";
13
- export { default as formatEmailAddresses } from "./utils/format-email-addresses.d.ts";
14
- export { default as generateBoundary } from "./utils/generate-boundary.d.ts";
15
- export { default as generateMessageId } from "./utils/generate-message-id.d.ts";
16
- export { default as headersToRecord } from "./utils/headers-to-record.d.ts";
17
- export { default as isPortAvailable } from "./utils/is-port-available.d.ts";
18
- export { makeRequest, type RequestOptions } from "./utils/make-request.d.ts";
19
- export { default as parseAddress } from "./utils/parse-address.d.ts";
20
- export { default as retry } from "./utils/retry.d.ts";
21
- export { default as validateEmail } from "./utils/validate-email.d.ts";
22
- export { default as validateEmailOptions } from "./utils/validate-email-options.d.ts";
9
+ export type { Attachment, BaseConfig, CalendarEventOptions, EmailAddress, EmailHeaders, EmailOptions, EmailResult, EmailTag, FeatureFlags, ImmutableHeaders, MaybePromise, Priority, Receipt, Result, } from "./types.d.ts";
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- import{detectMimeType as a,generateContentId as o,readFileAsBuffer as t}from"./packem_shared/detectMimeType-S8WRsNtY.js";import{default as d}from"./packem_shared/EmailError-zm2ffVav.js";import{default as m}from"./packem_shared/RequiredOptionError-CevW3u2K.js";import{Mail as p,MailMessage as i,createMail as u}from"./packem_shared/MailMessage-Hdgowmvi.js";import{defineProvider as n}from"./packem_shared/defineProvider-B9rSklAJ.js";import{default as M}from"./packem_shared/buildMimeMessage-BPtd0pno.js";import{default as c}from"./packem_shared/comparePriority-BfiwjVsV.js";import{default as v}from"./packem_shared/createLogger-DlElSVQP.js";import{default as P}from"./packem_shared/formatEmailAddress-CHeME3Vk.js";import{default as b}from"./packem_shared/formatEmailAddresses-UegVOe5A.js";import{default as B}from"./packem_shared/generateBoundary-CZ8kJuY6.js";import{default as O}from"./packem_shared/generateMessageId-11Ls5JsR.js";import{default as h}from"./packem_shared/headersToRecord-BKUTr40L.js";import{default as C}from"./packem_shared/isPortAvailable-5kfsfo8u.js";import{makeRequest as L}from"./packem_shared/makeRequest-DwxHX0xo.js";import{default as w}from"./packem_shared/parseAddress-CATTKGe_.js";import{default as D}from"./packem_shared/retry-D1MBqS49.js";import{default as H}from"./packem_shared/validateEmail-BkVdVioP.js";import{default as K}from"./packem_shared/validateEmailOptions-BzlJECG5.js";export{d as EmailError,p as Mail,i as MailMessage,m as RequiredOptionError,M as buildMimeMessage,c as comparePriority,v as createLogger,u as createMail,n as defineProvider,a as detectMimeType,P as formatEmailAddress,b as formatEmailAddresses,B as generateBoundary,o as generateContentId,O as generateMessageId,h as headersToRecord,C as isPortAvailable,L as makeRequest,w as parseAddress,t as readFileAsBuffer,D as retry,H as validateEmail,K as validateEmailOptions};
1
+ import{detectMimeType as o,generateContentId as t,readFileAsBuffer as a}from"./packem_shared/detectMimeType-S8WRsNtY.js";import{default as i}from"./packem_shared/EmailError-zm2ffVav.js";import{default as m}from"./packem_shared/RequiredOptionError-CevW3u2K.js";import{Mail as l,createMail as x}from"./packem_shared/Mail-6Bltpy_p.js";import{MailMessage as s}from"./packem_shared/MailMessage-B76GPBBA.js";import{defineProvider as u}from"./packem_shared/defineProvider-B9rSklAJ.js";export{i as EmailError,l as Mail,s as MailMessage,m as RequiredOptionError,x as createMail,u as defineProvider,o as detectMimeType,t as generateContentId,a as readFileAsBuffer};
@@ -0,0 +1,425 @@
1
+ import type { ICalCalendar } from "ical-generator";
2
+ import type { AttachmentDataOptions, AttachmentOptions } from './attachment-helpers.d.ts';
3
+ import type { EmailEncrypter, EmailSigner } from './crypto/index.d.ts';
4
+ import type { TemplateRenderer } from './template-engines/types.d.ts';
5
+ import type { Attachment, CalendarEventOptions, EmailAddress, EmailHeaders, EmailOptions, Priority } from './types.d.ts';
6
+ type AddressInput = EmailAddress | EmailAddress[] | string | string[];
7
+ /**
8
+ * Mail message builder - provides fluent interface for building emails.
9
+ */
10
+ export declare class MailMessage {
11
+ private fromAddress?;
12
+ private toAddresses;
13
+ private ccAddresses;
14
+ private bccAddresses;
15
+ private subjectText;
16
+ private textContent?;
17
+ private textCharset;
18
+ private autoTextEnabled;
19
+ private htmlContent?;
20
+ private htmlCharset;
21
+ private dateValue?;
22
+ private returnPathAddress?;
23
+ private senderAddress?;
24
+ private headers;
25
+ private attachments;
26
+ private replyToAddress?;
27
+ private priorityValue?;
28
+ private tagsValue;
29
+ private signer?;
30
+ private encrypter?;
31
+ private logger?;
32
+ private icalEventData?;
33
+ /**
34
+ * Sets the sender address.
35
+ * @param address The sender email address (string or EmailAddress object).
36
+ * @returns This instance for method chaining.
37
+ */
38
+ from(address: EmailAddress | string): this;
39
+ /**
40
+ * Sets the recipient address(es).
41
+ * @param address The recipient email address(es) (string, EmailAddress, or arrays of either).
42
+ * @returns This instance for method chaining.
43
+ */
44
+ to(address: AddressInput): this;
45
+ /**
46
+ * Sets the CC recipient address(es).
47
+ * @param address The CC recipient email address(es) (string, EmailAddress, or arrays of either).
48
+ * @returns This instance for method chaining.
49
+ */
50
+ cc(address: AddressInput): this;
51
+ /**
52
+ * Sets the BCC recipient address(es).
53
+ * @param address The BCC recipient email address(es) (string, EmailAddress, or arrays of either).
54
+ * @returns This instance for method chaining.
55
+ */
56
+ bcc(address: AddressInput): this;
57
+ /**
58
+ * Sets the subject line for the email message.
59
+ * @param text The subject text to set.
60
+ * @returns This instance for method chaining.
61
+ */
62
+ subject(text: string): this;
63
+ /**
64
+ * Sets the plain text content of the email.
65
+ * @param content The plain text content to set.
66
+ * @param charset Optional charset for the text content (default: 'utf8').
67
+ * @returns This instance for method chaining.
68
+ */
69
+ text(content: string, charset?: string): this;
70
+ /**
71
+ * Sets the HTML content of the email.
72
+ * @param content The HTML content to set.
73
+ * @param charset Optional charset for the HTML content (default: 'utf8').
74
+ * @returns This instance for method chaining.
75
+ */
76
+ html(content: string, charset?: string): this;
77
+ /**
78
+ * Sets a custom email header.
79
+ * @param name The header name to set.
80
+ * @param value The header value to set.
81
+ * @returns This instance for method chaining.
82
+ */
83
+ header(name: string, value: string): this;
84
+ /**
85
+ * Sets multiple headers.
86
+ * Accepts both Record<string, string> and ImmutableHeaders.
87
+ * @param headers The headers to set (Record or ImmutableHeaders).
88
+ * @returns This instance for method chaining.
89
+ */
90
+ setHeaders(headers: EmailHeaders): this;
91
+ /**
92
+ * Attaches a file from path (reads file from filesystem).
93
+ * Similar to Laravel's attach() method.
94
+ * @param filePath The absolute or relative filesystem path to the file to attach.
95
+ * @param options Optional attachment configuration (filename, contentType, etc.).
96
+ * @returns This instance for method chaining.
97
+ * @example
98
+ * ```ts
99
+ * message.attachFromPath('/path/to/file.pdf')
100
+ * message.attachFromPath('/path/to/file.pdf', { filename: 'custom-name.pdf' })
101
+ * ```
102
+ */
103
+ attachFromPath(filePath: string, options?: AttachmentOptions): Promise<this>;
104
+ /**
105
+ * Attaches raw data (string or Buffer).
106
+ * Similar to Laravel's attachData() method.
107
+ * @param content The content to attach (string or Buffer).
108
+ * @param options Attachment options including filename.
109
+ * @returns This instance for method chaining.
110
+ * @example
111
+ * ```ts
112
+ * message.attachData(Buffer.from('content'), 'file.txt')
113
+ * message.attachData('content', 'file.txt', { contentType: 'text/plain' })
114
+ * ```
115
+ */
116
+ attachData(content: string | Buffer, options: AttachmentDataOptions): this;
117
+ /**
118
+ * Embeds an inline attachment from file path (for images in HTML).
119
+ * Similar to Laravel's embed() method.
120
+ * Returns the Content-ID that can be used in HTML: &lt;img src="cid:{cid}">.
121
+ * @param filePath The path to the file to embed.
122
+ * @param options Optional attachment options (filename, contentType, etc.).
123
+ * @returns The Content-ID string that can be used in HTML.
124
+ * @example
125
+ * ```ts
126
+ * const cid = await message.embedFromPath('/path/to/logo.png')
127
+ * message.html(`<img src="cid:${cid}">`)
128
+ * ```
129
+ */
130
+ embedFromPath(filePath: string, options?: Omit<AttachmentOptions, "contentDisposition" | "cid">): Promise<string>;
131
+ /**
132
+ * Embeds raw data as inline attachment (for images in HTML).
133
+ * Similar to Laravel's embedData() method.
134
+ * Returns the Content-ID that can be used in HTML: &lt;img src="cid:{cid}">.
135
+ * @param content The content to embed (string or Buffer).
136
+ * @param filename The filename for the embedded attachment.
137
+ * @param options Optional attachment options (contentType, etc.).
138
+ * @returns The Content-ID string that can be used in HTML.
139
+ * @example
140
+ * ```ts
141
+ * const imageBuffer = Buffer.from('...')
142
+ * const cid = message.embedData(imageBuffer, 'logo.png', { contentType: 'image/png' })
143
+ * message.html(`<img src="cid:${cid}">`)
144
+ * ```
145
+ */
146
+ embedData(content: string | Buffer, filename: string, options?: Omit<AttachmentDataOptions, "filename" | "contentDisposition" | "cid">): string;
147
+ /**
148
+ * Sets the reply-to address.
149
+ * @param address The reply-to email address (string or EmailAddress object).
150
+ * @returns This instance for method chaining.
151
+ */
152
+ replyTo(address: EmailAddress | string): this;
153
+ /**
154
+ * Sets the date header for the email.
155
+ * @param date The date to set (Date object or ISO string).
156
+ * @returns This instance for method chaining.
157
+ */
158
+ date(date: Date | string): this;
159
+ /**
160
+ * Sets the return-path address (bounce address).
161
+ * @param address The return-path email address (string or EmailAddress object).
162
+ * @returns This instance for method chaining.
163
+ */
164
+ returnPath(address: EmailAddress | string): this;
165
+ /**
166
+ * Sets the sender address (different from From - used when From contains multiple addresses).
167
+ * @param address The sender email address (string or EmailAddress object).
168
+ * @returns This instance for method chaining.
169
+ */
170
+ sender(address: EmailAddress | string): this;
171
+ /**
172
+ * Adds recipient address(es) without replacing existing ones.
173
+ * @param address The recipient email address(es) (string, EmailAddress, or arrays of either).
174
+ * @returns This instance for method chaining.
175
+ */
176
+ addTo(address: AddressInput): this;
177
+ /**
178
+ * Adds CC recipient address(es) without replacing existing ones.
179
+ * @param address The CC recipient email address(es) (string, EmailAddress, or arrays of either).
180
+ * @returns This instance for method chaining.
181
+ */
182
+ addCc(address: AddressInput): this;
183
+ /**
184
+ * Adds BCC recipient address(es) without replacing existing ones.
185
+ * @param address The BCC recipient email address(es) (string, EmailAddress, or arrays of either).
186
+ * @returns This instance for method chaining.
187
+ */
188
+ addBcc(address: AddressInput): this;
189
+ /**
190
+ * Adds reply-to address(es) without replacing existing ones.
191
+ * @param address The reply-to email address(es) (string, EmailAddress, or arrays of either).
192
+ * @returns This instance for method chaining.
193
+ */
194
+ addReplyTo(address: EmailAddress | string | (EmailAddress | string)[]): this;
195
+ /**
196
+ * Adds from address(es) without replacing existing ones.
197
+ * @param address The sender email address(es) (string, EmailAddress, or arrays of either).
198
+ * @returns This instance for method chaining.
199
+ */
200
+ addFrom(address: EmailAddress | string | (EmailAddress | string)[]): this;
201
+ /**
202
+ * Sets the email priority.
203
+ * @param priority The priority level ('high', 'normal', or 'low').
204
+ * @returns This instance for method chaining.
205
+ */
206
+ priority(priority: Priority): this;
207
+ /**
208
+ * Sets email tags for categorization.
209
+ * @param tags The tags to set (string or array of strings).
210
+ * @returns This instance for method chaining.
211
+ */
212
+ tags(tags: string | string[]): this;
213
+ /**
214
+ * Signs the email message using a signer (DKIM or S/MIME).
215
+ * @param signer The signer instance to use.
216
+ * @example
217
+ * ```ts
218
+ * import { createDkimSigner } from '@visulima/email/crypto';
219
+ * const signer = createDkimSigner({
220
+ * domainName: 'example.com',
221
+ * keySelector: 'default',
222
+ * privateKey: '-----BEGIN PRIVATE KEY-----...'
223
+ * });
224
+ * message.sign(signer)
225
+ * ```
226
+ */
227
+ sign(signer: EmailSigner): this;
228
+ /**
229
+ * Encrypts the email message using an encrypter (S/MIME).
230
+ * @param encrypter The encrypter instance to use.
231
+ * @example
232
+ * ```ts
233
+ * import { createSmimeEncrypter } from '@visulima/email/crypto';
234
+ * const encrypter = createSmimeEncrypter({
235
+ * certificates: '/path/to/certificate.crt'
236
+ * });
237
+ * message.encrypt(encrypter)
238
+ * ```
239
+ */
240
+ encrypt(encrypter: EmailEncrypter): this;
241
+ /**
242
+ * Sets the logger instance for this message.
243
+ * @param logger The logger instance (Console) to use for logging.
244
+ * @returns This instance for method chaining.
245
+ * @example
246
+ * ```ts
247
+ * message.logger(console)
248
+ * ```
249
+ */
250
+ setLogger(logger: Console): this;
251
+ /**
252
+ * Attach a calendar event and define contents as string or function.
253
+ * @param contents The calendar content as a string or a function that receives an ICalCalendar instance.
254
+ * @param options Optional calendar event options (method, alternativeText).
255
+ * @returns This instance for method chaining.
256
+ * @example
257
+ * ```ts
258
+ * message.icalEvent((calendar) => {
259
+ * calendar.createEvent({
260
+ * start: new Date(),
261
+ * summary: 'Meeting'
262
+ * });
263
+ * })
264
+ * message.icalEvent('BEGIN:VCALENDAR...')
265
+ * ```
266
+ */
267
+ icalEvent(contents: ((calendar: ICalCalendar) => void) | string, options?: CalendarEventOptions): this;
268
+ /**
269
+ * Attach a calendar event and load contents from a file.
270
+ * @param file The file path (string or URL) to load the calendar event from.
271
+ * @param options Optional calendar event options (method, alternativeText).
272
+ * @returns This instance for method chaining.
273
+ * @example
274
+ * ```ts
275
+ * message.icalEventFromFile('/path/to/event.ics')
276
+ * message.icalEventFromFile(new URL('file:///path/to/event.ics'))
277
+ * ```
278
+ */
279
+ icalEventFromFile(file: string | URL, options?: CalendarEventOptions): this;
280
+ /**
281
+ * Attach a calendar event and load contents from a URL.
282
+ * @param url The URL to fetch the calendar event from.
283
+ * @param options Optional calendar event options (method, alternativeText).
284
+ * @returns This instance for method chaining.
285
+ * @example
286
+ * ```ts
287
+ * message.icalEventFromUrl('https://example.com/event.ics')
288
+ * ```
289
+ */
290
+ icalEventFromUrl(url: string, options?: CalendarEventOptions): this;
291
+ /**
292
+ * Renders a template and sets as HTML content.
293
+ * Accepts a render function for flexible template engine support.
294
+ * @param render The template renderer function.
295
+ * @param template The template content (string, React component, etc.).
296
+ * @param data Optional data/variables to pass to the template.
297
+ * @param options Optional renderer-specific options.
298
+ * @param options.autoText Whether to auto-generate text version from HTML (default: true).
299
+ * @returns This instance for method chaining.
300
+ * @example
301
+ * ```ts
302
+ * import { renderHandlebars } from '@visulima/email/template/handlebars';
303
+ * message.view(renderHandlebars, '<h1>Hello {{name}}!</h1>', { name: 'John' })
304
+ *
305
+ * import { renderMjml } from '@visulima/email/template/mjml';
306
+ * message.view(renderMjml, mjmlTemplate)
307
+ *
308
+ * import { renderReactEmail } from '@visulima/email/template/react-email';
309
+ * message.view(renderReactEmail, <WelcomeEmail name="John" />)
310
+ * ```
311
+ */
312
+ view(render: TemplateRenderer, template: unknown, data?: Record<string, unknown>, options?: {
313
+ [key: string]: unknown;
314
+ autoText?: boolean;
315
+ }): Promise<this>;
316
+ /**
317
+ * Renders a text template and sets as text content.
318
+ * @param render The template renderer function.
319
+ * @param template The text template content.
320
+ * @param data Optional data/variables to pass to the template.
321
+ * @param options Optional renderer-specific options.
322
+ * @returns This instance for method chaining.
323
+ * @example
324
+ * ```ts
325
+ * import { renderHandlebars } from '@visulima/email/template/handlebars';
326
+ * message.viewText(renderHandlebars, 'Hello {{name}}!', { name: 'John' })
327
+ * ```
328
+ */
329
+ viewText(render: TemplateRenderer, template: string, data?: Record<string, unknown>, options?: Record<string, unknown>): Promise<this>;
330
+ /**
331
+ * Builds the email options.
332
+ * @returns The built email options ready for sending.
333
+ * @throws {Error} When required fields (from, to, subject, content) are missing.
334
+ */
335
+ build(): Promise<EmailOptions>;
336
+ /**
337
+ * Gets the subject of the email.
338
+ * @returns The subject text or empty string if not set.
339
+ */
340
+ getSubject(): string;
341
+ /**
342
+ * Gets the from address.
343
+ * @returns The from address or undefined if not set.
344
+ */
345
+ getFrom(): EmailAddress | undefined;
346
+ /**
347
+ * Gets the recipient addresses.
348
+ * @returns Array of recipient addresses.
349
+ */
350
+ getTo(): EmailAddress[];
351
+ /**
352
+ * Gets the CC recipient addresses.
353
+ * @returns Array of CC recipient addresses.
354
+ */
355
+ getCc(): EmailAddress[];
356
+ /**
357
+ * Gets the BCC recipient addresses.
358
+ * @returns Array of BCC recipient addresses.
359
+ */
360
+ getBcc(): EmailAddress[];
361
+ /**
362
+ * Gets the reply-to address.
363
+ * @returns The reply-to address or undefined if not set.
364
+ */
365
+ getReplyTo(): EmailAddress | undefined;
366
+ /**
367
+ * Gets the sender address.
368
+ * @returns The sender address or undefined if not set.
369
+ */
370
+ getSender(): EmailAddress | undefined;
371
+ /**
372
+ * Gets the return-path address.
373
+ * @returns The return-path address or undefined if not set.
374
+ */
375
+ getReturnPath(): EmailAddress | undefined;
376
+ /**
377
+ * Gets the date header.
378
+ * @returns The date or undefined if not set.
379
+ */
380
+ getDate(): Date | undefined;
381
+ /**
382
+ * Gets the priority of the email.
383
+ * @returns The priority ('high', 'normal', 'low') or undefined if not set.
384
+ */
385
+ getPriority(): Priority | undefined;
386
+ /**
387
+ * Gets the plain text content.
388
+ * @returns The text content or undefined if not set.
389
+ */
390
+ getTextBody(): string | undefined;
391
+ /**
392
+ * Gets the charset for the text content.
393
+ * @returns The text charset (default: 'utf8').
394
+ */
395
+ getTextCharset(): string;
396
+ /**
397
+ * Gets the HTML content.
398
+ * @returns The HTML content or undefined if not set.
399
+ */
400
+ getHtmlBody(): string | undefined;
401
+ /**
402
+ * Gets the charset for the HTML content.
403
+ * @returns The HTML charset (default: 'utf8').
404
+ */
405
+ getHtmlCharset(): string;
406
+ /**
407
+ * Gets the attachments.
408
+ * @returns Array of attachments.
409
+ */
410
+ getAttachments(): Attachment[];
411
+ /**
412
+ * Attempts to auto-generate text content from HTML.
413
+ * @param html The HTML content to convert.
414
+ * @private
415
+ */
416
+ private tryAutoGenerateText;
417
+ /**
418
+ * Creates an error, logs it, and throws it.
419
+ * @param message Error message to throw.
420
+ * @param logMessage Optional log message (defaults to message).
421
+ * @private
422
+ */
423
+ private throwAndLogError;
424
+ }
425
+ export default MailMessage;