temp-disposable-email 1.11.7 → 1.12.1
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/README.md +28 -18
- package/cypress.config.ts +1 -0
- package/dist/cjs/index.d.ts +2 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +4 -3
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/services/accountService.d.ts +10 -27
- package/dist/cjs/services/accountService.d.ts.map +1 -1
- package/dist/cjs/services/accountService.js +18 -60
- package/dist/cjs/services/accountService.js.map +1 -1
- package/dist/cjs/services/messageService.d.ts +7 -1
- package/dist/cjs/services/messageService.d.ts.map +1 -1
- package/dist/cjs/services/messageService.js +19 -42
- package/dist/cjs/services/messageService.js.map +1 -1
- package/dist/cjs/utils/api.d.ts +97 -2
- package/dist/cjs/utils/api.d.ts.map +1 -1
- package/dist/cjs/utils/api.js +79 -9
- package/dist/cjs/utils/api.js.map +1 -1
- package/dist/esm/index.d.ts +2 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +2 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/services/accountService.d.ts +10 -27
- package/dist/esm/services/accountService.d.ts.map +1 -1
- package/dist/esm/services/accountService.js +17 -55
- package/dist/esm/services/accountService.js.map +1 -1
- package/dist/esm/services/messageService.d.ts +7 -1
- package/dist/esm/services/messageService.d.ts.map +1 -1
- package/dist/esm/services/messageService.js +20 -43
- package/dist/esm/services/messageService.js.map +1 -1
- package/dist/esm/utils/api.d.ts +97 -2
- package/dist/esm/utils/api.d.ts.map +1 -1
- package/dist/esm/utils/api.js +71 -6
- package/dist/esm/utils/api.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +2 -1
- package/src/services/accountService.ts +26 -66
- package/src/services/messageService.ts +38 -57
- package/src/utils/api.ts +163 -6
package/dist/esm/utils/api.js
CHANGED
|
@@ -11,28 +11,93 @@ export const getAuthHeaders = () => {
|
|
|
11
11
|
Authorization: `Bearer ${token}`,
|
|
12
12
|
};
|
|
13
13
|
};
|
|
14
|
-
export const
|
|
14
|
+
export const getDomains = async () => {
|
|
15
15
|
try {
|
|
16
|
-
const
|
|
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
|
|
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
|
|
38
|
+
export const getMessagesContent = async (messageId) => {
|
|
27
39
|
try {
|
|
28
|
-
const
|
|
40
|
+
const { data } = await axios.get(`${BASE_URL}/messages/${messageId}`, {
|
|
29
41
|
headers: getAuthHeaders(),
|
|
30
42
|
});
|
|
31
|
-
return
|
|
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;
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../src/utils/api.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import * as dotenv from 'dotenv';
|
|
2
2
|
dotenv.config();
|
|
3
3
|
|
|
4
|
-
export {
|
|
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
|
|
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 {
|
|
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
|
|
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} [
|
|
18
|
-
* @returns {Promise<
|
|
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
|
|
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
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
const domains = domainsResponse
|
|
32
|
-
(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 = `${
|
|
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
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
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 {
|
|
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
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
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
|
|
63
|
+
const messages = await getMessages();
|
|
82
64
|
if (messages.length > 0) {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
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
|
|
98
|
-
to: to
|
|
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
|
-
|
|
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
|
|
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
|
|
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
|
|
107
|
+
const { data } = await axios.get(`${BASE_URL}/messages`, {
|
|
19
108
|
headers: getAuthHeaders(),
|
|
20
109
|
});
|
|
21
|
-
return
|
|
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
|
|
117
|
+
export const getMessagesContent = async (
|
|
118
|
+
messageId: string
|
|
119
|
+
): Promise<EmailResource> => {
|
|
29
120
|
try {
|
|
30
|
-
const
|
|
121
|
+
const { data } = await axios.get(`${BASE_URL}/messages/${messageId}`, {
|
|
31
122
|
headers: getAuthHeaders(),
|
|
32
123
|
});
|
|
33
|
-
return
|
|
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
|
+
};
|