temp-disposable-email 1.11.6 → 1.12.0

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 (39) hide show
  1. package/README.md +38 -20
  2. package/cypress.config.ts +1 -0
  3. package/dist/cjs/index.d.ts +2 -1
  4. package/dist/cjs/index.d.ts.map +1 -1
  5. package/dist/cjs/index.js +4 -3
  6. package/dist/cjs/index.js.map +1 -1
  7. package/dist/cjs/services/accountService.d.ts +10 -27
  8. package/dist/cjs/services/accountService.d.ts.map +1 -1
  9. package/dist/cjs/services/accountService.js +18 -60
  10. package/dist/cjs/services/accountService.js.map +1 -1
  11. package/dist/cjs/services/messageService.d.ts +7 -1
  12. package/dist/cjs/services/messageService.d.ts.map +1 -1
  13. package/dist/cjs/services/messageService.js +19 -42
  14. package/dist/cjs/services/messageService.js.map +1 -1
  15. package/dist/cjs/utils/api.d.ts +97 -2
  16. package/dist/cjs/utils/api.d.ts.map +1 -1
  17. package/dist/cjs/utils/api.js +79 -9
  18. package/dist/cjs/utils/api.js.map +1 -1
  19. package/dist/esm/index.d.ts +2 -1
  20. package/dist/esm/index.d.ts.map +1 -1
  21. package/dist/esm/index.js +2 -1
  22. package/dist/esm/index.js.map +1 -1
  23. package/dist/esm/services/accountService.d.ts +10 -27
  24. package/dist/esm/services/accountService.d.ts.map +1 -1
  25. package/dist/esm/services/accountService.js +17 -55
  26. package/dist/esm/services/accountService.js.map +1 -1
  27. package/dist/esm/services/messageService.d.ts +7 -1
  28. package/dist/esm/services/messageService.d.ts.map +1 -1
  29. package/dist/esm/services/messageService.js +20 -43
  30. package/dist/esm/services/messageService.js.map +1 -1
  31. package/dist/esm/utils/api.d.ts +97 -2
  32. package/dist/esm/utils/api.d.ts.map +1 -1
  33. package/dist/esm/utils/api.js +71 -6
  34. package/dist/esm/utils/api.js.map +1 -1
  35. package/package.json +1 -1
  36. package/src/index.ts +2 -1
  37. package/src/services/accountService.ts +26 -66
  38. package/src/services/messageService.ts +38 -57
  39. package/src/utils/api.ts +163 -6
@@ -11,28 +11,93 @@ export const getAuthHeaders = () => {
11
11
  Authorization: `Bearer ${token}`,
12
12
  };
13
13
  };
14
- export const fetchMessages = async () => {
14
+ export const getDomains = async () => {
15
15
  try {
16
- const res = await axios.get(`${BASE_URL}/messages`, {
16
+ const { data } = await axios.get(`${BASE_URL}/domains`, {
17
+ headers: { accept: 'application/json' },
18
+ });
19
+ return data;
20
+ }
21
+ catch (error) {
22
+ console.error('Error fetching domains:', error);
23
+ throw new Error('Failed to fetch messages. Please try again later.');
24
+ }
25
+ };
26
+ export const getMessages = async () => {
27
+ try {
28
+ const { data } = await axios.get(`${BASE_URL}/messages`, {
17
29
  headers: getAuthHeaders(),
18
30
  });
19
- return res.data;
31
+ return data;
20
32
  }
21
33
  catch (error) {
22
34
  console.error('Error fetching messages:', error);
23
35
  throw new Error('Failed to fetch messages. Please try again later.');
24
36
  }
25
37
  };
26
- export const fetchMessageContent = async (messageId) => {
38
+ export const getMessagesContent = async (messageId) => {
27
39
  try {
28
- const res = await axios.get(`${BASE_URL}/messages/${messageId}`, {
40
+ const { data } = await axios.get(`${BASE_URL}/messages/${messageId}`, {
29
41
  headers: getAuthHeaders(),
30
42
  });
31
- return res.data;
43
+ return data;
32
44
  }
33
45
  catch (error) {
34
46
  console.error(`Error fetching message content for ID ${messageId}:`, error);
35
47
  throw new Error('Failed to fetch message content. Please try again later.');
36
48
  }
37
49
  };
50
+ export const getMessageAttachments = async (messageId, attachmentsId) => {
51
+ try {
52
+ const { data } = await axios.get(`${BASE_URL}/messages/${messageId}/attachment/${attachmentsId}`, {
53
+ headers: getAuthHeaders(),
54
+ });
55
+ return data;
56
+ }
57
+ catch (error) {
58
+ console.error(`Error fetching message attachment for ID ${messageId}:`, error);
59
+ throw new Error('Failed to fetch message content. Please try again later.');
60
+ }
61
+ };
62
+ export const deleteMessage = async (messageId) => {
63
+ try {
64
+ const { status } = await axios.delete(`${BASE_URL}/messages/${messageId}`, {
65
+ headers: getAuthHeaders(),
66
+ });
67
+ return status;
68
+ }
69
+ catch (error) {
70
+ console.error(`Error deleting message for ID ${messageId}:`, error);
71
+ throw new Error('Failed to fetch message content. Please try again later.');
72
+ }
73
+ };
74
+ export const createAccount = async (payload) => {
75
+ const { data } = await axios.post(`${BASE_URL}/accounts`, payload, {
76
+ headers: { accept: 'application/json' },
77
+ });
78
+ return data;
79
+ };
80
+ /**
81
+ * Deletes the account created during `generateEmail`.
82
+ *
83
+ * @returns {Promise<number>} status code of 204 when the account is successfully deleted.
84
+ *
85
+ * @throws {Error} If no account is authenticated or deletion fails.
86
+ *
87
+ * @example
88
+ * await deleteAccount();
89
+ * console.log("Account deleted successfully.");
90
+ */
91
+ export const deleteAccount = async (accountId) => {
92
+ try {
93
+ const { status } = await axios.delete(`${BASE_URL}/accounts/${accountId}`, {
94
+ headers: getAuthHeaders(),
95
+ });
96
+ return status;
97
+ }
98
+ catch (error) {
99
+ console.error(`Error deleting account for ID ${accountId}:`, error);
100
+ throw new Error('Failed to fetch message content. Please try again later.');
101
+ }
102
+ };
38
103
  //# sourceMappingURL=api.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"api.js","sourceRoot":"","sources":["../../../src/utils/api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAEnD,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IACD,OAAO;QACL,MAAM,EAAE,kBAAkB;QAC1B,aAAa,EAAE,UAAU,KAAK,EAAE;KACjC,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,IAAoB,EAAE;IACtD,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,QAAQ,WAAW,EAAE;YAClD,OAAO,EAAE,cAAc,EAAE;SAC1B,CAAC,CAAC;QACH,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,KAAK,CAAC,CAAC;QACjD,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACvE,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,SAAiB,EAAgB,EAAE;IAC3E,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,QAAQ,aAAa,SAAS,EAAE,EAAE;YAC/D,OAAO,EAAE,cAAc,EAAE;SAC1B,CAAC,CAAC;QACH,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,yCAAyC,SAAS,GAAG,EAAE,KAAK,CAAC,CAAC;QAC5E,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAC;IAC9E,CAAC;AACH,CAAC,CAAC"}
1
+ {"version":3,"file":"api.js","sourceRoot":"","sources":["../../../src/utils/api.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "temp-disposable-email",
3
- "version": "1.11.6",
3
+ "version": "1.12.0",
4
4
  "description": "Generating Temporary email address for testing, retrieving email from the temporary email address",
5
5
  "main": "dist/cjs/index.js",
6
6
  "exports": {
package/src/index.ts CHANGED
@@ -1,7 +1,8 @@
1
1
  import * as dotenv from 'dotenv';
2
2
  dotenv.config();
3
3
 
4
- export { createInbox, deleteAccount } from './services/accountService';
4
+ export { generateEmail, GeneratedEmail } from './services/accountService';
5
+ export { deleteAccount } from './utils/api';
5
6
  export {
6
7
  getRecentEmail,
7
8
  deleteMessage,
@@ -1,39 +1,38 @@
1
- import axios from 'axios';
2
- import { authenticate, getToken } from './authService';
1
+ import { authenticate } from './authService';
3
2
  import { generateRandomName } from '../utils/generateRandomName';
4
3
  import { delay } from '../utils/delay';
5
- import { BASE_URL } from '../utils/constant';
4
+ import { createAccount, getDomains } from '../utils/api';
5
+
6
+ export interface GeneratedEmail {
7
+ emailAddress: string;
8
+ accountId: string;
9
+ }
6
10
 
7
- let accountId: string | null = null;
8
11
  /**
9
12
  * Creates a new email inbox with a unique address.
10
13
  *
11
- * This function selects an available domain, generates an email
12
- * address, and attempts to create an account on the Mail.tm service.
13
- * If account creation is rate-limited, the function retries with a
14
- * delay. Upon successful creation, it authenticates the account and
15
- * stores the token and account ID for future API calls.
14
+ * This function generates an temp inbox & email address
16
15
  *
17
- * @param {string} [username] - Optional username; a random one is generated if not provided.
18
- * @returns {Promise<string>} The generated email address.
16
+ * @param {string} [emailPrefix] - Optional emailPrefix; a random one is generated if not provided.
17
+ * @returns {Promise<GeneratedEmail>} The generated email address & account ID.
19
18
  *
20
19
  * @throws {Error} If no domains are available or account creation fails.
21
20
  *
22
21
  * @example
23
- * const email = await createInbox("customUser");
24
- * console.log(email); // Outputs: "customUser@mail.tm"
22
+ * const email = await generateEmail("customUser");
23
+ * console.log(email); // Outputs: {"emailAddress": "customUser@mail.tm" , "accountId": "1234"}
25
24
  */
26
25
 
27
- export const createInbox = async (username?: string): Promise<string> => {
28
- const domainsResponse = await axios.get(`${BASE_URL}/domains`, {
29
- headers: { accept: 'application/ld+json' },
30
- });
31
- const domains = domainsResponse.data['hydra:member'].map(
32
- (domain: { domain: string }) => domain.domain
33
- );
26
+ export const generateEmail = async (
27
+ emailPrefix?: string
28
+ ): Promise<GeneratedEmail> => {
29
+ const domainsResponse = await getDomains();
30
+ const domains = domainsResponse
31
+ .filter((domain: { isActive: boolean }) => domain.isActive)
32
+ .map((domain: { domain: string }) => domain.domain);
34
33
  if (domains.length === 0) throw new Error('No available domains.');
35
34
 
36
- const emailAddress = `${username || generateRandomName()}@${domains[0]}`;
35
+ const emailAddress = `${emailPrefix || generateRandomName()}@${domains[0]}`;
37
36
  const password = generateRandomName();
38
37
 
39
38
  let attempts = 0;
@@ -41,19 +40,13 @@ export const createInbox = async (username?: string): Promise<string> => {
41
40
 
42
41
  while (attempts < maxRetries) {
43
42
  try {
44
- const accountResponse = await axios.post(
45
- `${BASE_URL}/accounts`,
46
- { address: emailAddress, password },
47
- {
48
- headers: {
49
- accept: 'application/json',
50
- 'Content-Type': 'application/json',
51
- },
52
- }
53
- );
54
- accountId = accountResponse.data.id;
43
+ const accountResponse = await createAccount({
44
+ address: emailAddress,
45
+ password,
46
+ });
47
+
55
48
  await authenticate(emailAddress, password);
56
- return emailAddress;
49
+ return { emailAddress, accountId: accountResponse.id };
57
50
  } catch (error: any) {
58
51
  if (error.response?.status === 429) {
59
52
  attempts++;
@@ -68,36 +61,3 @@ export const createInbox = async (username?: string): Promise<string> => {
68
61
  }
69
62
  throw new Error('Failed to create account after multiple retries.');
70
63
  };
71
-
72
- /**
73
- * Deletes the account created during `createInbox`.
74
- *
75
- * This function removes the email account from the Mail.tm service
76
- * and clears the stored authentication token and account ID.
77
- * Subsequent API calls requiring authentication will fail until a
78
- * new account is created.
79
- *
80
- * @returns {Promise<void>} Resolves when the account is successfully deleted.
81
- *
82
- * @throws {Error} If no account is authenticated or deletion fails.
83
- *
84
- * @example
85
- * await deleteAccount();
86
- * console.log("Account deleted successfully.");
87
- */
88
- export const deleteAccount = async (): Promise<void> => {
89
- const token = getToken();
90
- if (!token || !accountId) {
91
- throw new Error(
92
- 'Account information missing. Create and authenticate an account first.'
93
- );
94
- }
95
-
96
- await axios.delete(`${BASE_URL}/accounts/${accountId}`, {
97
- headers: {
98
- accept: '*/*',
99
- Authorization: `Bearer ${token}`,
100
- },
101
- });
102
- accountId = null;
103
- };
@@ -1,7 +1,7 @@
1
1
  import axios from 'axios';
2
2
  import { getToken } from './authService';
3
3
  import { BASE_URL } from '../utils/constant';
4
- import { fetchMessageContent, fetchMessages } from '../utils/api';
4
+ import { getMessagesContent, getMessages } from '../utils/api';
5
5
 
6
6
  export interface MessageContent {
7
7
  from: { address: string };
@@ -9,7 +9,9 @@ export interface MessageContent {
9
9
  subject: string;
10
10
  intro: string;
11
11
  text: string;
12
- html: string;
12
+ html: string[];
13
+ createdAt: string;
14
+ updatedAt: string;
13
15
  }
14
16
  export interface GetEmailOptions {
15
17
  maxWaitTime?: number;
@@ -27,6 +29,10 @@ export interface GetEmailOptions {
27
29
  * deleted after reading.
28
30
  *
29
31
  * @param {GetEmailOptions} [options] - Optional settings for polling and deletion.
32
+ * @param {number} [options.maxWaitTime=30000] - Maximum time to wait for messages (in milliseconds). Default is 30 seconds.
33
+ * @param {number} [options.waitInterval=2000] - Time interval between polling attempts (in milliseconds). Default is 2 seconds.
34
+ * @param {boolean} [options.logPolling=false] - Whether to log polling attempts. Default is `false`.
35
+ * @param {boolean} [options.deleteAfterRead=false] - Whether to delete the message after reading. Default is `false`.
30
36
  * @returns {Promise<MessageContent | null>} The email content (sender, recipient, subject, text, HTML), or `null` if no messages are found.
31
37
  *
32
38
  * @throws {Error} If no messages are available within the polling timeout or authentication fails.
@@ -38,84 +44,59 @@ export interface GetEmailOptions {
38
44
  export const getRecentEmail = async (
39
45
  options?: GetEmailOptions
40
46
  ): Promise<MessageContent | null> => {
41
- const token = getToken();
42
47
  const {
43
48
  maxWaitTime = 30000,
44
49
  waitInterval = 2000,
45
50
  logPolling = false,
46
51
  deleteAfterRead = false,
47
52
  } = options || {};
48
- if (!token)
49
- throw new Error('Authentication required. Call createInbox() first.');
50
-
51
- if (!options) {
52
- const messages = await fetchMessages();
53
- if (messages.length === 0) throw new Error('No messages available');
54
- const messageId = messages[0].id;
55
- const { from, to, subject, intro, text, html } = await fetchMessageContent(
56
- messageId
57
- );
58
- if (deleteAfterRead) {
59
- await deleteMessage(messageId);
60
- }
61
- return {
62
- from: from.address,
63
- to: to[0].address,
64
- subject,
65
- intro,
66
- text,
67
- html,
68
- };
69
- }
70
53
 
71
54
  const startTime = Date.now();
55
+ const logger = (message: string) => logPolling && console.log(message);
72
56
 
73
- if (logPolling) {
74
- console.log(
75
- `Polling started with a timeout of ${
76
- maxWaitTime / 1000
77
- }sec and interval of ${waitInterval / 1000}sec.`
78
- );
79
- }
57
+ logger(
58
+ `Polling started with a timeout of ${
59
+ maxWaitTime / 1000
60
+ }sec and interval of ${waitInterval / 1000}sec.`
61
+ );
80
62
  while (Date.now() - startTime < maxWaitTime) {
81
- const messages = await fetchMessages();
63
+ const messages = await getMessages();
82
64
  if (messages.length > 0) {
83
- if (logPolling) {
84
- console.log(`Found ${messages.length} message(s), fetching details...`);
85
- }
86
- const messageId = messages[0].id;
87
- if (logPolling) {
88
- console.log(`Message retrieved`);
89
- }
90
- const { from, to, subject, intro, text, html } =
91
- await fetchMessageContent(messageId);
65
+ logger(`Found ${messages.length} message(s), fetching details...`);
66
+ const sortedMessages = messages.sort(
67
+ (a, b) =>
68
+ new Date(a.createdAt).getTime() - new Date(b.createdAt).getTime()
69
+ );
70
+ const messageId = sortedMessages[0].id;
71
+
72
+ logger(`Found ${messageId}`);
73
+
74
+ const { from, to, subject, intro, text, html, createdAt, updatedAt } =
75
+ await getMessagesContent(messageId);
92
76
 
93
77
  if (deleteAfterRead) {
94
78
  await deleteMessage(messageId);
95
79
  }
96
80
  return {
97
- from: from.address,
98
- to: to[0].address,
81
+ from: from,
82
+ to: to,
99
83
  subject,
100
84
  intro,
101
85
  text,
102
86
  html,
87
+ createdAt,
88
+ updatedAt,
103
89
  };
104
90
  }
105
91
  await new Promise((resolve) => setTimeout(resolve, waitInterval));
106
- if (logPolling) {
107
- console.log(
108
- `No messages found, waiting for ${waitInterval / 1000} seconds...`
109
- );
110
- }
111
- }
112
- if (logPolling) {
113
- console.log(
114
- `Waiting timeout of ${
115
- maxWaitTime / 1000
116
- } seconds reached. No messages found.`
117
- );
92
+ logger(`No messages found, waiting for ${waitInterval / 1000} seconds...`);
118
93
  }
94
+ logger(
95
+ `Waiting timeout of ${
96
+ maxWaitTime / 1000
97
+ } seconds reached. No messages found.`
98
+ );
99
+
119
100
  throw new Error(
120
101
  `No messages available within ${maxWaitTime / 1000} seconds timeout`
121
102
  );
@@ -140,7 +121,7 @@ export const getRecentEmail = async (
140
121
  export const deleteMessage = async (messageId: string): Promise<void> => {
141
122
  const token = getToken();
142
123
  if (!token)
143
- throw new Error('Authentication required. Call createInbox() first.');
124
+ throw new Error('Authentication required. Call generateEmail() first.');
144
125
 
145
126
  try {
146
127
  await axios.delete(`${BASE_URL}/messages/${messageId}`, {
package/src/utils/api.ts CHANGED
@@ -2,6 +2,83 @@ import axios from 'axios';
2
2
  import { BASE_URL } from './constant';
3
3
  import { getToken } from '../services/authService';
4
4
 
5
+ interface EmailAccount {
6
+ id: string;
7
+ address: string;
8
+ quota: number;
9
+ used: number;
10
+ isDisabled: boolean;
11
+ isDeleted: boolean;
12
+ createdAt: string;
13
+ updatedAt: string;
14
+ }
15
+ interface ListOfDomains {
16
+ id: string;
17
+ domain: string;
18
+ isActive: boolean;
19
+ isPrivate: boolean;
20
+ createdAt: string;
21
+ updatedAt: string;
22
+ }
23
+
24
+ interface Address {
25
+ address: string;
26
+ name: string;
27
+ }
28
+ interface EmailObject {
29
+ id: string;
30
+ msgid: string;
31
+ from: Address;
32
+ to: Address[];
33
+ subject: string;
34
+ intro: string;
35
+ seen: boolean;
36
+ isDeleted: boolean;
37
+ hasAttachments: boolean;
38
+ size: number;
39
+ downloadUrl: string;
40
+ sourceUrl: string;
41
+ createdAt: string;
42
+ updatedAt: string;
43
+ accountId: string;
44
+ }
45
+ interface Attachment {
46
+ id: string;
47
+ filename: string;
48
+ contentType: string;
49
+ disposition: string;
50
+ transferEncoding: string;
51
+ related: boolean;
52
+ size: number;
53
+ downloadUrl: string;
54
+ }
55
+ interface EmailResource {
56
+ id: string;
57
+ msgid: string;
58
+ from: Address;
59
+ to: Address[];
60
+ cc: Address[];
61
+ bcc: Address[];
62
+ subject: string;
63
+ intro: string;
64
+ seen: boolean;
65
+ flagged: boolean;
66
+ isDeleted: boolean;
67
+ verifications: string[];
68
+ retention: boolean;
69
+ retentionDate: string;
70
+ text: string;
71
+ html: string[];
72
+ hasAttachments: boolean;
73
+ attachments: Attachment[];
74
+ size: number;
75
+ downloadUrl: string;
76
+ sourceUrl: string;
77
+ createdAt: string;
78
+ updatedAt: string;
79
+ accountId: string;
80
+ }
81
+
5
82
  export const getAuthHeaders = () => {
6
83
  const token = getToken();
7
84
  if (!token) {
@@ -13,26 +90,106 @@ export const getAuthHeaders = () => {
13
90
  };
14
91
  };
15
92
 
16
- export const fetchMessages = async (): Promise<any[]> => {
93
+ export const getDomains = async (): Promise<ListOfDomains[]> => {
94
+ try {
95
+ const { data } = await axios.get(`${BASE_URL}/domains`, {
96
+ headers: { accept: 'application/json' },
97
+ });
98
+ return data;
99
+ } catch (error) {
100
+ console.error('Error fetching domains:', error);
101
+ throw new Error('Failed to fetch messages. Please try again later.');
102
+ }
103
+ };
104
+
105
+ export const getMessages = async (): Promise<EmailObject[]> => {
17
106
  try {
18
- const res = await axios.get(`${BASE_URL}/messages`, {
107
+ const { data } = await axios.get(`${BASE_URL}/messages`, {
19
108
  headers: getAuthHeaders(),
20
109
  });
21
- return res.data;
110
+ return data;
22
111
  } catch (error) {
23
112
  console.error('Error fetching messages:', error);
24
113
  throw new Error('Failed to fetch messages. Please try again later.');
25
114
  }
26
115
  };
27
116
 
28
- export const fetchMessageContent = async (messageId: string): Promise<any> => {
117
+ export const getMessagesContent = async (
118
+ messageId: string
119
+ ): Promise<EmailResource> => {
29
120
  try {
30
- const res = await axios.get(`${BASE_URL}/messages/${messageId}`, {
121
+ const { data } = await axios.get(`${BASE_URL}/messages/${messageId}`, {
31
122
  headers: getAuthHeaders(),
32
123
  });
33
- return res.data;
124
+ return data;
34
125
  } catch (error) {
35
126
  console.error(`Error fetching message content for ID ${messageId}:`, error);
36
127
  throw new Error('Failed to fetch message content. Please try again later.');
37
128
  }
38
129
  };
130
+
131
+ export const getMessageAttachments = async (
132
+ messageId: string,
133
+ attachmentsId: string
134
+ ): Promise<any> => {
135
+ try {
136
+ const { data } = await axios.get(
137
+ `${BASE_URL}/messages/${messageId}/attachment/${attachmentsId}`,
138
+ {
139
+ headers: getAuthHeaders(),
140
+ }
141
+ );
142
+ return data;
143
+ } catch (error) {
144
+ console.error(
145
+ `Error fetching message attachment for ID ${messageId}:`,
146
+ error
147
+ );
148
+ throw new Error('Failed to fetch message content. Please try again later.');
149
+ }
150
+ };
151
+
152
+ export const deleteMessage = async (messageId: string): Promise<number> => {
153
+ try {
154
+ const { status } = await axios.delete(`${BASE_URL}/messages/${messageId}`, {
155
+ headers: getAuthHeaders(),
156
+ });
157
+ return status;
158
+ } catch (error) {
159
+ console.error(`Error deleting message for ID ${messageId}:`, error);
160
+ throw new Error('Failed to fetch message content. Please try again later.');
161
+ }
162
+ };
163
+
164
+ export const createAccount = async (payload: {
165
+ address: string;
166
+ password: string;
167
+ }): Promise<EmailAccount> => {
168
+ const { data } = await axios.post(`${BASE_URL}/accounts`, payload, {
169
+ headers: { accept: 'application/json' },
170
+ });
171
+ return data;
172
+ };
173
+
174
+ /**
175
+ * Deletes the account created during `generateEmail`.
176
+ *
177
+ * @returns {Promise<number>} status code of 204 when the account is successfully deleted.
178
+ *
179
+ * @throws {Error} If no account is authenticated or deletion fails.
180
+ *
181
+ * @example
182
+ * await deleteAccount();
183
+ * console.log("Account deleted successfully.");
184
+ */
185
+ export const deleteAccount = async (accountId: string): Promise<number> => {
186
+ try {
187
+ const { status } = await axios.delete(`${BASE_URL}/accounts/${accountId}`, {
188
+ headers: getAuthHeaders(),
189
+ });
190
+ return status;
191
+ } catch (error) {
192
+ console.error(`Error deleting account for ID ${accountId}:`, error);
193
+ throw new Error('Failed to fetch message content. Please try again later.');
194
+ }
195
+ };