tempmail-sdk 1.1.9 → 1.2.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 CHANGED
@@ -3,7 +3,7 @@
3
3
  [![npm version](https://badge.fury.io/js/tempmail-sdk.svg)](https://www.npmjs.com/package/tempmail-sdk)
4
4
  [![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
5
5
 
6
- 临时邮箱 SDK(TypeScript/Node.js),支持 **20** 个邮箱服务提供商,所有渠道返回**统一标准化格式**。
6
+ 临时邮箱 SDK(TypeScript/Node.js),支持 **25** 个邮箱服务提供商,所有渠道返回**统一标准化格式**。
7
7
 
8
8
  ## 安装
9
9
 
@@ -17,11 +17,15 @@ npm install @XxxXTeam/tempmail-sdk --registry=https://npm.pkg.github.com
17
17
 
18
18
  ## 支持的渠道
19
19
 
20
- 共 **20** 个,顺序与 `listChannels()` / 随机尝试顺序一致(与 `src/index.ts` 中 `allChannels` 相同)。
20
+ 共 **25** 个,顺序与 `listChannels()` / 随机尝试顺序一致(与 `src/index.ts` 中 `allChannels` 相同;无 `tempmailg`,与 Rust/Python/C 一致)。
21
21
 
22
22
  | 渠道 | 服务商 | 需要 Token | 说明 |
23
23
  |------|--------|:----------:|------|
24
24
  | `tempmail` | tempmail.ing | - | 支持自定义有效期 |
25
+ | `tempmail-cn` | tempmail.cn | - | Socket.IO:`request shortid` / `set shortid` / `mail`;`domain` 可指定 `tempmail.cn` 或自定义接入域名 |
26
+ | `tmpmails` | tmpmails.com | ✅ | 首页 Cookie + Next.js Server Action;`domain` 可选语言路径(`zh`/`en`) |
27
+ | `ta-easy` | ta-easy.com | ✅ | REST 创建 + 收件箱列表;`expiresAt` 毫秒时间戳 |
28
+ | `10mail-wangtz` | 10mail.wangtz.cn | - | REST `/api/tempMail`、`/api/emailList`;**默认 `fetchWithInsecureTLS` 跳过证书校验** |
25
29
  | `linshi-email` | linshi-email.com | - | |
26
30
  | `linshiyou` | linshiyou.com | ✅ | `NEXUS_TOKEN` + `tmail-emails` 等 Cookie;HTML 分段解析 |
27
31
  | `mffac` | mffac.com | ✅ | `POST /api/mailboxes`;token 为 mailbox `id`;24h |
@@ -41,6 +45,7 @@ npm install @XxxXTeam/tempmail-sdk --registry=https://npm.pkg.github.com
41
45
  | `vip-215` | vip.215.im | ✅ | `POST` 建箱 + `wss`;无正文时 synthetic 兜底 |
42
46
  | `anonbox` | anonbox.net | ✅ | `GET /en/` 解析 HTML + mbox 收信 |
43
47
  | `fake-legal` | fake.legal | - | `/api/domains` + `/api/inbox/new?domain=`;`/api/inbox/{encodeURIComponent(邮箱)}` 拉信;可选 `domain` |
48
+ | `moakt` | moakt.com | ✅ | HTML 收件箱 + `tm_session`;`domain` 可选语言路径;Token 为 `mok1:` + Base64 JSON |
44
49
 
45
50
  > **提示:** 使用 `TempEmailClient` 类时无需手动处理 Token,SDK 自动管理。
46
51
 
@@ -106,6 +111,9 @@ const emailInfo3 = await generateEmail({ channel: 'tempmail', duration: 60 });
106
111
  // tempmail-lol 渠道支持指定域名
107
112
  const emailInfo4 = await generateEmail({ channel: 'tempmail-lol', domain: 'example.com' });
108
113
 
114
+ // tempmail-cn 渠道支持指定 tempmail.cn 自定义接入域名
115
+ const emailInfo5 = await generateEmail({ channel: 'tempmail-cn', domain: 'mail.example.com' });
116
+
109
117
  // 只尝试指定渠道(探测可用性、写自动化时用)
110
118
  const probe = await generateEmail({ channel: 'smail-pw', channelFallback: false });
111
119
  ```
@@ -162,7 +170,7 @@ if (mailTm) {
162
170
  | `channel` | `Channel` | 指定渠道(可选,不指定则随机) |
163
171
  | `channelFallback` | `boolean` | 默认 `true`:指定渠道失败会继续尝试其他渠道;设为 `false` 时仅尝试 `channel` |
164
172
  | `duration` | `number` | 有效期分钟数(仅 `tempmail` 渠道) |
165
- | `domain` | `string` | 指定域名(`tempmail-lol`、`maildrop`、`fake-legal`) |
173
+ | `domain` | `string` | 指定域名或接入参数(`tempmail-cn`、`tempmail-lol`、`maildrop`、`fake-legal`、`tmpmails` / `moakt` 语言路径、`10mail-wangtz` 本地部分等) |
166
174
  | `retry` | `RetryConfig` | 创建邮箱时的重试(超时、5xx、网络错误等) |
167
175
 
168
176
  **返回值:** `EmailInfo`
@@ -260,6 +268,8 @@ setConfig({
260
268
  | `timeout` | `number?` | 全局超时毫秒数,默认 15000 |
261
269
  | `insecure` | `boolean?` | 跳过 SSL 验证(调试用) |
262
270
  | `customFetch` | `typeof fetch?` | 自定义 fetch 函数,用于代理等高级场景 |
271
+ | `telemetryEnabled` | `boolean?` | 未设则默认开启匿名遥测;`false` 关闭 |
272
+ | `telemetryUrl` | `string?` | 覆盖默认上报 URL |
263
273
 
264
274
  **环境变量(无需修改代码):**
265
275
 
@@ -267,12 +277,18 @@ setConfig({
267
277
  export TEMPMAIL_PROXY="http://127.0.0.1:7890"
268
278
  export TEMPMAIL_INSECURE=1
269
279
  export TEMPMAIL_TIMEOUT=30000
280
+ export TEMPMAIL_TELEMETRY_ENABLED=false
281
+ export TEMPMAIL_TELEMETRY_URL="https://example.com/v1/event"
270
282
  ```
271
283
 
272
284
  > **提示:** Node.js 原生 fetch 不支持代理,推荐通过 `customFetch` + `undici` 的 `ProxyAgent` 实现代理支持。
273
285
 
274
286
  DropMail 自动令牌等更多配置见源码 `src/config.ts` 注释(`DROPMAIL_*` 环境变量)。
275
287
 
288
+ ## 匿名遥测
289
+
290
+ 默认 **开启**:在进程内排队,定时或满批向默认端点 `POST` 匿名事件(`schema_version: 2`,含 SDK 语言/版本、OS、操作类型、渠道、成败与重试次数等;错误串脱敏)。关闭:`TEMPMAIL_TELEMETRY_ENABLED=false`(或 `0` / `no`)或 `setConfig({ telemetryEnabled: false })`;改 URL:`TEMPMAIL_TELEMETRY_URL` 或 `telemetryUrl`(内置默认见 `src/telemetry.ts`)。
291
+
276
292
  ## 示例脚本(本仓库)
277
293
 
278
294
  在 `sdk/npm` 目录执行:
package/dist/config.d.ts CHANGED
@@ -9,6 +9,8 @@
9
9
  * DROPMAIL_AUTH_TOKEN / DROPMAIL_API_TOKEN - DropMail GraphQL 的 af_ 令牌(可选;未设置时 SDK 会 /api/token/generate 获取并在将过期时用 /api/token/renew 续期)
10
10
  * DROPMAIL_NO_AUTO_TOKEN - 设为 "1" 或 "true" 则禁止自动拉取/续期令牌
11
11
  * DROPMAIL_RENEW_LIFETIME - 自动续期请求的 lifetime,默认 1d(与官网 renew 接口一致)
12
+ * TEMPMAIL_TELEMETRY_ENABLED - true/false,默认 true;false/0/no 关闭匿名用量上报
13
+ * TEMPMAIL_TELEMETRY_URL - 自定义上报端点 URL
12
14
  *
13
15
  * Node.js 环境下设置 insecure 会自动设置 NODE_TLS_REJECT_UNAUTHORIZED=0
14
16
  */
@@ -40,6 +42,10 @@ export interface SDKConfig {
40
42
  * 当设置了 proxy 但环境不支持 undici 时,可通过此选项传入支持代理的 fetch 实现
41
43
  */
42
44
  customFetch?: typeof fetch;
45
+ /** 为 false 时关闭匿名用量上报;未设置时默认开启 */
46
+ telemetryEnabled?: boolean;
47
+ /** 非空时覆盖默认上报 URL */
48
+ telemetryUrl?: string;
43
49
  }
44
50
  /**
45
51
  * 设置 SDK 全局配置
package/dist/config.js CHANGED
@@ -10,6 +10,8 @@
10
10
  * DROPMAIL_AUTH_TOKEN / DROPMAIL_API_TOKEN - DropMail GraphQL 的 af_ 令牌(可选;未设置时 SDK 会 /api/token/generate 获取并在将过期时用 /api/token/renew 续期)
11
11
  * DROPMAIL_NO_AUTO_TOKEN - 设为 "1" 或 "true" 则禁止自动拉取/续期令牌
12
12
  * DROPMAIL_RENEW_LIFETIME - 自动续期请求的 lifetime,默认 1d(与官网 renew 接口一致)
13
+ * TEMPMAIL_TELEMETRY_ENABLED - true/false,默认 true;false/0/no 关闭匿名用量上报
14
+ * TEMPMAIL_TELEMETRY_URL - 自定义上报端点 URL
13
15
  *
14
16
  * Node.js 环境下设置 insecure 会自动设置 NODE_TLS_REJECT_UNAUTHORIZED=0
15
17
  */
@@ -31,6 +33,16 @@ function loadEnvConfig() {
31
33
  if (process.env.TEMPMAIL_INSECURE === '1' || process.env.TEMPMAIL_INSECURE?.toLowerCase() === 'true') {
32
34
  config.insecure = true;
33
35
  }
36
+ const te = process.env.TEMPMAIL_TELEMETRY_ENABLED?.trim().toLowerCase();
37
+ if (te === 'false' || te === '0' || te === 'no') {
38
+ config.telemetryEnabled = false;
39
+ }
40
+ else if (te === 'true' || te === '1' || te === 'yes') {
41
+ config.telemetryEnabled = true;
42
+ }
43
+ if (process.env.TEMPMAIL_TELEMETRY_URL?.trim()) {
44
+ config.telemetryUrl = process.env.TEMPMAIL_TELEMETRY_URL.trim();
45
+ }
34
46
  }
35
47
  return config;
36
48
  }
@@ -68,4 +80,4 @@ function setConfig(config) {
68
80
  function getConfig() {
69
81
  return globalConfig;
70
82
  }
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7R0FhRzs7QUFxRUgsOEJBVUM7QUFHRCw4QkFFQztBQXBERCxrQkFBa0I7QUFDbEIsU0FBUyxhQUFhO0lBQ3BCLE1BQU0sTUFBTSxHQUFjLEVBQUUsQ0FBQztJQUM3QixJQUFJLE9BQU8sT0FBTyxLQUFLLFdBQVcsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDbEQsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQy9CLE1BQU0sQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUM7UUFDNUMsQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1lBQ2pDLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3JELElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7Z0JBQUUsTUFBTSxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUM7UUFDN0MsQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsS0FBSyxHQUFHLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsRUFBRSxXQUFXLEVBQUUsS0FBSyxNQUFNLEVBQUUsQ0FBQztZQUNyRyxNQUFNLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztRQUN6QixDQUFDO0lBQ0gsQ0FBQztJQUNELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUFFRCxJQUFJLFlBQVksR0FBYyxhQUFhLEVBQUUsQ0FBQztBQUU5Qzs7Ozs7Ozs7Ozs7Ozs7OztHQWdCRztBQUNILFNBQWdCLFNBQVMsQ0FBQyxNQUFpQjtJQUN6QyxZQUFZLEdBQUcsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDO0lBQzdCLG1DQUFtQztJQUNuQyxJQUFJLE9BQU8sT0FBTyxLQUFLLFdBQVcsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDbEQsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDcEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsR0FBRyxHQUFHLENBQUM7UUFDakQsQ0FBQzthQUFNLENBQUM7WUFDTixPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsNEJBQTRCLENBQUM7UUFDbEQsQ0FBQztJQUNILENBQUM7QUFDSCxDQUFDO0FBRUQsb0JBQW9CO0FBQ3BCLFNBQWdCLFNBQVM7SUFDdkIsT0FBTyxZQUFZLENBQUM7QUFDdEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU0RLIOWFqOWxgOmFjee9rlxuICog5YyF5ZCr5Luj55CG44CB6LaF5pe244CBU1NMIOetieiuvue9ru+8jOS9nOeUqOS6juaJgOaciSBIVFRQIOivt+axglxuICpcbiAqIOaUr+aMgeeOr+Wig+WPmOmHj+iHquWKqOivu+WPlu+8iOS8mOWFiOe6p+S9juS6juS7o+eggeiuvue9ru+8ie+8mlxuICogICBURU1QTUFJTF9QUk9YWSAgICAtIOS7o+eQhiBVUkxcbiAqICAgVEVNUE1BSUxfVElNRU9VVCAgLSDotoXml7bmr6vnp5LmlbBcbiAqICAgVEVNUE1BSUxfSU5TRUNVUkUgLSDorr7kuLogXCIxXCIg5oiWIFwidHJ1ZVwiIOi3s+i/hyBTU0wg6aqM6K+BXG4gKiAgIERST1BNQUlMX0FVVEhfVE9LRU4gLyBEUk9QTUFJTF9BUElfVE9LRU4gLSBEcm9wTWFpbCBHcmFwaFFMIOeahCBhZl8g5Luk54mM77yI5Y+v6YCJ77yb5pyq6K6+572u5pe2IFNESyDkvJogL2FwaS90b2tlbi9nZW5lcmF0ZSDojrflj5blubblnKjlsIbov4fmnJ/ml7bnlKggL2FwaS90b2tlbi9yZW5ldyDnu63mnJ/vvIlcbiAqICAgRFJPUE1BSUxfTk9fQVVUT19UT0tFTiAtIOiuvuS4uiBcIjFcIiDmiJYgXCJ0cnVlXCIg5YiZ56aB5q2i6Ieq5Yqo5ouJ5Y+WL+e7reacn+S7pOeJjFxuICogICBEUk9QTUFJTF9SRU5FV19MSUZFVElNRSAtIOiHquWKqOe7reacn+ivt+axgueahCBsaWZldGltZe+8jOm7mOiupCAxZO+8iOS4juWumOe9kSByZW5ldyDmjqXlj6PkuIDoh7TvvIlcbiAqXG4gKiBOb2RlLmpzIOeOr+Wig+S4i+iuvue9riBpbnNlY3VyZSDkvJroh6rliqjorr7nva4gTk9ERV9UTFNfUkVKRUNUX1VOQVVUSE9SSVpFRD0wXG4gKi9cblxuLyoqXG4gKiBTREsg5YWo5bGA6YWN572u5o6l5Y+jXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU0RLQ29uZmlnIHtcbiAgLyoqIOS7o+eQhiBVUkzvvIzmlK/mjIEgaHR0cC9odHRwcy9zb2NrczXvvIzlpoIgXCJodHRwOi8vMTI3LjAuMC4xOjc4OTBcIiAqL1xuICBwcm94eT86IHN0cmluZztcbiAgLyoqIOWFqOWxgOm7mOiupOi2heaXtu+8iOavq+enku+8ie+8jOm7mOiupCAxNTAwMCAqL1xuICB0aW1lb3V0PzogbnVtYmVyO1xuICAvKiog6Lez6L+HIFNTTCDor4Hkuabpqozor4HvvIjosIPor5XnlKjvvIkgKi9cbiAgaW5zZWN1cmU/OiBib29sZWFuO1xuICAvKipcbiAgICogRHJvcE1haWwg5rig6YGT5LiT55So77yaR3JhcGhRTCDnq6/ngrkgYGh0dHBzOi8vZHJvcG1haWwubWUvYXBpL2dyYXBocWwvJHt0b2tlbn1gIOS4reeahCB0b2tlbu+8iOmhu+S4uuWumOe9keeUn+aIkOeahCBgYWZfYCDliY3nvIDku6TniYzvvInjgIJcbiAgICog5Lmf5Y+v6YCa6L+H546v5aKD5Y+Y6YePIERST1BNQUlMX0FVVEhfVE9LRU4g5oiWIERST1BNQUlMX0FQSV9UT0tFTiDmj5DkvpvjgIJcbiAgICog5pyq6YWN572u5LiU5pyq6K6+572uIERST1BNQUlMX05PX0FVVE9fVE9LRU4g5pe277yM5Lya5ZCRIGh0dHBzOi8vZHJvcG1haWwubWUvYXBpL3Rva2VuL2dlbmVyYXRlIOeUs+ivtyAxaCDku6TniYzlubblhoXlrZjnvJPlrZjjgIJcbiAgICovXG4gIGRyb3BtYWlsQXV0aFRva2VuPzogc3RyaW5nO1xuICAvKiog5Li6IHRydWUg5pe25LiN6Ieq5Yqo6K+35rGCIHRva2Vu77yI6aG76YWN572uIGRyb3BtYWlsQXV0aFRva2VuIOaIlueOr+Wig+WPmOmHj++8iSAqL1xuICBkcm9wbWFpbERpc2FibGVBdXRvVG9rZW4/OiBib29sZWFuO1xuICAvKipcbiAgICog6Ieq5Yqo566h55CG5Luk54mM5Y2z5bCG6L+H5pyf5pe277yM6LCD55SoIC9hcGkvdG9rZW4vcmVuZXcg5L2/55So55qEIGxpZmV0aW1l77yI5aaCIDFo44CBMWTvvInjgIJcbiAgICog5Lmf5Y+v6YCa6L+H546v5aKD5Y+Y6YePIERST1BNQUlMX1JFTkVXX0xJRkVUSU1FIOiuvue9ruOAglxuICAgKi9cbiAgZHJvcG1haWxSZW5ld0xpZmV0aW1lPzogc3RyaW5nO1xuICAvKipcbiAgICog6Ieq5a6a5LmJIGZldGNoIOWHveaVsO+8jOeUqOS6juWujOWFqOaOp+WItiBIVFRQIOivt+axguihjOS4ulxuICAgKiDlvZPorr7nva7kuoYgcHJveHkg5L2G546v5aKD5LiN5pSv5oyBIHVuZGljaSDml7bvvIzlj6/pgJrov4fmraTpgInpobnkvKDlhaXmlK/mjIHku6PnkIbnmoQgZmV0Y2gg5a6e546wXG4gICAqL1xuICBjdXN0b21GZXRjaD86IHR5cGVvZiBmZXRjaDtcbn1cblxuLyoqIOS7jueOr+Wig+WPmOmHj+ivu+WPlum7mOiupOmFjee9riAqL1xuZnVuY3Rpb24gbG9hZEVudkNvbmZpZygpOiBTREtDb25maWcge1xuICBjb25zdCBjb25maWc6IFNES0NvbmZpZyA9IHt9O1xuICBpZiAodHlwZW9mIHByb2Nlc3MgIT09ICd1bmRlZmluZWQnICYmIHByb2Nlc3MuZW52KSB7XG4gICAgaWYgKHByb2Nlc3MuZW52LlRFTVBNQUlMX1BST1hZKSB7XG4gICAgICBjb25maWcucHJveHkgPSBwcm9jZXNzLmVudi5URU1QTUFJTF9QUk9YWTtcbiAgICB9XG4gICAgaWYgKHByb2Nlc3MuZW52LlRFTVBNQUlMX1RJTUVPVVQpIHtcbiAgICAgIGNvbnN0IHQgPSBwYXJzZUludChwcm9jZXNzLmVudi5URU1QTUFJTF9USU1FT1VULCAxMCk7XG4gICAgICBpZiAoIWlzTmFOKHQpICYmIHQgPiAwKSBjb25maWcudGltZW91dCA9IHQ7XG4gICAgfVxuICAgIGlmIChwcm9jZXNzLmVudi5URU1QTUFJTF9JTlNFQ1VSRSA9PT0gJzEnIHx8IHByb2Nlc3MuZW52LlRFTVBNQUlMX0lOU0VDVVJFPy50b0xvd2VyQ2FzZSgpID09PSAndHJ1ZScpIHtcbiAgICAgIGNvbmZpZy5pbnNlY3VyZSA9IHRydWU7XG4gICAgfVxuICB9XG4gIHJldHVybiBjb25maWc7XG59XG5cbmxldCBnbG9iYWxDb25maWc6IFNES0NvbmZpZyA9IGxvYWRFbnZDb25maWcoKTtcblxuLyoqXG4gKiDorr7nva4gU0RLIOWFqOWxgOmFjee9rlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogLy8g5LiA6KGM6Lez6L+HIFNTTCDpqozor4FcbiAqIHNldENvbmZpZyh7IGluc2VjdXJlOiB0cnVlIH0pO1xuICpcbiAqIC8vIOiuvue9ruS7o+eQhuWSjOi2heaXtlxuICogc2V0Q29uZmlnKHsgcHJveHk6ICdodHRwOi8vMTI3LjAuMC4xOjc4OTAnLCB0aW1lb3V0OiAzMDAwMCB9KTtcbiAqXG4gKiAvLyDkvb/nlKjoh6rlrprkuYkgZmV0Y2jvvIjlpoLmlK/mjIHku6PnkIbnmoQgdW5kaWNp77yJXG4gKiBpbXBvcnQgeyBQcm94eUFnZW50LCBmZXRjaCBhcyB1bmRpY2lGZXRjaCB9IGZyb20gJ3VuZGljaSc7XG4gKiBjb25zdCBhZ2VudCA9IG5ldyBQcm94eUFnZW50KCdodHRwOi8vMTI3LjAuMC4xOjc4OTAnKTtcbiAqIHNldENvbmZpZyh7IGN1c3RvbUZldGNoOiAodXJsLCBpbml0KSA9PiB1bmRpY2lGZXRjaCh1cmwsIHsgLi4uaW5pdCwgZGlzcGF0Y2hlcjogYWdlbnQgfSkgfSk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHNldENvbmZpZyhjb25maWc6IFNES0NvbmZpZyk6IHZvaWQge1xuICBnbG9iYWxDb25maWcgPSB7IC4uLmNvbmZpZyB9O1xuICAvKiBOb2RlLmpzIOeOr+Wig+S4iyBpbnNlY3VyZSDoh6rliqjorr7nva7njq/looPlj5jph48gKi9cbiAgaWYgKHR5cGVvZiBwcm9jZXNzICE9PSAndW5kZWZpbmVkJyAmJiBwcm9jZXNzLmVudikge1xuICAgIGlmIChjb25maWcuaW5zZWN1cmUpIHtcbiAgICAgIHByb2Nlc3MuZW52Lk5PREVfVExTX1JFSkVDVF9VTkFVVEhPUklaRUQgPSAnMCc7XG4gICAgfSBlbHNlIHtcbiAgICAgIGRlbGV0ZSBwcm9jZXNzLmVudi5OT0RFX1RMU19SRUpFQ1RfVU5BVVRIT1JJWkVEO1xuICAgIH1cbiAgfVxufVxuXG4vKiog6I635Y+W5b2T5YmNIFNESyDlhajlsYDphY3nva4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogU0RLQ29uZmlnIHtcbiAgcmV0dXJuIGdsb2JhbENvbmZpZztcbn1cbiJdfQ==
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;GAeG;;AAkFH,8BAUC;AAGD,8BAEC;AA7DD,kBAAkB;AAClB,SAAS,aAAa;IACpB,MAAM,MAAM,GAAc,EAAE,CAAC;IAC7B,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;QAClD,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC;YAC/B,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC;QAC5C,CAAC;QACD,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YACjC,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC;YACrD,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;gBAAE,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,KAAK,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,WAAW,EAAE,KAAK,MAAM,EAAE,CAAC;YACrG,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC;QACD,MAAM,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACxE,IAAI,EAAE,KAAK,OAAO,IAAI,EAAE,KAAK,GAAG,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChD,MAAM,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAClC,CAAC;aAAM,IAAI,EAAE,KAAK,MAAM,IAAI,EAAE,KAAK,GAAG,IAAI,EAAE,KAAK,KAAK,EAAE,CAAC;YACvD,MAAM,CAAC,gBAAgB,GAAG,IAAI,CAAC;QACjC,CAAC;QACD,IAAI,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,IAAI,EAAE,EAAE,CAAC;YAC/C,MAAM,CAAC,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC;QAClE,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,IAAI,YAAY,GAAc,aAAa,EAAE,CAAC;AAE9C;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,SAAS,CAAC,MAAiB;IACzC,YAAY,GAAG,EAAE,GAAG,MAAM,EAAE,CAAC;IAC7B,mCAAmC;IACnC,IAAI,OAAO,OAAO,KAAK,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;QAClD,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACpB,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,GAAG,CAAC;QACjD,CAAC;aAAM,CAAC;YACN,OAAO,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC;QAClD,CAAC;IACH,CAAC;AACH,CAAC;AAED,oBAAoB;AACpB,SAAgB,SAAS;IACvB,OAAO,YAAY,CAAC;AACtB,CAAC","sourcesContent":["/**\n * SDK 全局配置\n * 包含代理、超时、SSL 等设置，作用于所有 HTTP 请求\n *\n * 支持环境变量自动读取（优先级低于代码设置）：\n *   TEMPMAIL_PROXY    - 代理 URL\n *   TEMPMAIL_TIMEOUT  - 超时毫秒数\n *   TEMPMAIL_INSECURE - 设为 \"1\" 或 \"true\" 跳过 SSL 验证\n *   DROPMAIL_AUTH_TOKEN / DROPMAIL_API_TOKEN - DropMail GraphQL 的 af_ 令牌（可选；未设置时 SDK 会 /api/token/generate 获取并在将过期时用 /api/token/renew 续期）\n *   DROPMAIL_NO_AUTO_TOKEN - 设为 \"1\" 或 \"true\" 则禁止自动拉取/续期令牌\n *   DROPMAIL_RENEW_LIFETIME - 自动续期请求的 lifetime，默认 1d（与官网 renew 接口一致）\n *   TEMPMAIL_TELEMETRY_ENABLED - true/false，默认 true；false/0/no 关闭匿名用量上报\n *   TEMPMAIL_TELEMETRY_URL - 自定义上报端点 URL\n *\n * Node.js 环境下设置 insecure 会自动设置 NODE_TLS_REJECT_UNAUTHORIZED=0\n */\n\n/**\n * SDK 全局配置接口\n */\nexport interface SDKConfig {\n  /** 代理 URL，支持 http/https/socks5，如 \"http://127.0.0.1:7890\" */\n  proxy?: string;\n  /** 全局默认超时（毫秒），默认 15000 */\n  timeout?: number;\n  /** 跳过 SSL 证书验证（调试用） */\n  insecure?: boolean;\n  /**\n   * DropMail 渠道专用：GraphQL 端点 `https://dropmail.me/api/graphql/${token}` 中的 token（须为官网生成的 `af_` 前缀令牌）。\n   * 也可通过环境变量 DROPMAIL_AUTH_TOKEN 或 DROPMAIL_API_TOKEN 提供。\n   * 未配置且未设置 DROPMAIL_NO_AUTO_TOKEN 时，会向 https://dropmail.me/api/token/generate 申请 1h 令牌并内存缓存。\n   */\n  dropmailAuthToken?: string;\n  /** 为 true 时不自动请求 token（须配置 dropmailAuthToken 或环境变量） */\n  dropmailDisableAutoToken?: boolean;\n  /**\n   * 自动管理令牌即将过期时，调用 /api/token/renew 使用的 lifetime（如 1h、1d）。\n   * 也可通过环境变量 DROPMAIL_RENEW_LIFETIME 设置。\n   */\n  dropmailRenewLifetime?: string;\n  /**\n   * 自定义 fetch 函数，用于完全控制 HTTP 请求行为\n   * 当设置了 proxy 但环境不支持 undici 时，可通过此选项传入支持代理的 fetch 实现\n   */\n  customFetch?: typeof fetch;\n  /** 为 false 时关闭匿名用量上报；未设置时默认开启 */\n  telemetryEnabled?: boolean;\n  /** 非空时覆盖默认上报 URL */\n  telemetryUrl?: string;\n}\n\n/** 从环境变量读取默认配置 */\nfunction loadEnvConfig(): SDKConfig {\n  const config: SDKConfig = {};\n  if (typeof process !== 'undefined' && process.env) {\n    if (process.env.TEMPMAIL_PROXY) {\n      config.proxy = process.env.TEMPMAIL_PROXY;\n    }\n    if (process.env.TEMPMAIL_TIMEOUT) {\n      const t = parseInt(process.env.TEMPMAIL_TIMEOUT, 10);\n      if (!isNaN(t) && t > 0) config.timeout = t;\n    }\n    if (process.env.TEMPMAIL_INSECURE === '1' || process.env.TEMPMAIL_INSECURE?.toLowerCase() === 'true') {\n      config.insecure = true;\n    }\n    const te = process.env.TEMPMAIL_TELEMETRY_ENABLED?.trim().toLowerCase();\n    if (te === 'false' || te === '0' || te === 'no') {\n      config.telemetryEnabled = false;\n    } else if (te === 'true' || te === '1' || te === 'yes') {\n      config.telemetryEnabled = true;\n    }\n    if (process.env.TEMPMAIL_TELEMETRY_URL?.trim()) {\n      config.telemetryUrl = process.env.TEMPMAIL_TELEMETRY_URL.trim();\n    }\n  }\n  return config;\n}\n\nlet globalConfig: SDKConfig = loadEnvConfig();\n\n/**\n * 设置 SDK 全局配置\n *\n * @example\n * ```ts\n * // 一行跳过 SSL 验证\n * setConfig({ insecure: true });\n *\n * // 设置代理和超时\n * setConfig({ proxy: 'http://127.0.0.1:7890', timeout: 30000 });\n *\n * // 使用自定义 fetch（如支持代理的 undici）\n * import { ProxyAgent, fetch as undiciFetch } from 'undici';\n * const agent = new ProxyAgent('http://127.0.0.1:7890');\n * setConfig({ customFetch: (url, init) => undiciFetch(url, { ...init, dispatcher: agent }) });\n * ```\n */\nexport function setConfig(config: SDKConfig): void {\n  globalConfig = { ...config };\n  /* Node.js 环境下 insecure 自动设置环境变量 */\n  if (typeof process !== 'undefined' && process.env) {\n    if (config.insecure) {\n      process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';\n    } else {\n      delete process.env.NODE_TLS_REJECT_UNAUTHORIZED;\n    }\n  }\n}\n\n/** 获取当前 SDK 全局配置 */\nexport function getConfig(): SDKConfig {\n  return globalConfig;\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -2,9 +2,11 @@ import { Channel, EmailInfo, GetEmailsResult, GenerateEmailOptions, GetEmailsOpt
2
2
  import { setConfig, getConfig } from './config';
3
3
  export { Channel, EmailInfo, Email, EmailAttachment, GetEmailsResult, GenerateEmailOptions, GetEmailsOptions } from './types';
4
4
  export { normalizeEmail } from './normalize';
5
- export { withRetry, fetchWithTimeout, RetryOptions } from './retry';
5
+ export { withRetry, withRetryWithAttempts, fetchWithTimeout, RetryOptions } from './retry';
6
+ export type { RetryWithAttemptsResult, FetchWithTimeoutOptions } from './retry';
6
7
  export { LogLevel, LogHandler, setLogLevel, getLogLevel, setLogger, logger } from './logger';
7
8
  export { SDKConfig, setConfig, getConfig } from './config';
9
+ export { getSdkVersion } from './version';
8
10
  export type { SyntheticBrowserProfile } from './providers/linshi-token';
9
11
  export { deriveLinshiApiPathKey, randomSyntheticLinshiKey, randomBrowserLikeProfile, syntheticVisitorIdFromProfile, } from './providers/linshi-token';
10
12
  /**
package/dist/index.js CHANGED
@@ -33,12 +33,16 @@ var __importStar = (this && this.__importStar) || (function () {
33
33
  };
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.TempEmailClient = exports.syntheticVisitorIdFromProfile = exports.randomBrowserLikeProfile = exports.randomSyntheticLinshiKey = exports.deriveLinshiApiPathKey = exports.getConfig = exports.setConfig = exports.logger = exports.setLogger = exports.getLogLevel = exports.setLogLevel = exports.LogLevel = exports.fetchWithTimeout = exports.withRetry = exports.normalizeEmail = void 0;
36
+ exports.TempEmailClient = exports.syntheticVisitorIdFromProfile = exports.randomBrowserLikeProfile = exports.randomSyntheticLinshiKey = exports.deriveLinshiApiPathKey = exports.getSdkVersion = exports.getConfig = exports.setConfig = exports.logger = exports.setLogger = exports.getLogLevel = exports.setLogLevel = exports.LogLevel = exports.fetchWithTimeout = exports.withRetryWithAttempts = exports.withRetry = exports.normalizeEmail = void 0;
37
37
  exports.listChannels = listChannels;
38
38
  exports.getChannelInfo = getChannelInfo;
39
39
  exports.generateEmail = generateEmail;
40
40
  exports.getEmails = getEmails;
41
41
  const tempmail = __importStar(require("./providers/tempmail"));
42
+ const tempmailCn = __importStar(require("./providers/tempmail-cn"));
43
+ const tmpmails = __importStar(require("./providers/tmpmails"));
44
+ const taEasy = __importStar(require("./providers/ta-easy"));
45
+ const tenmailWangtz = __importStar(require("./providers/10mail-wangtz"));
42
46
  const linshiEmail = __importStar(require("./providers/linshi-email"));
43
47
  const linshiyou = __importStar(require("./providers/linshiyou"));
44
48
  const mffac = __importStar(require("./providers/mffac"));
@@ -58,7 +62,10 @@ const minmail = __importStar(require("./providers/minmail"));
58
62
  const vip215 = __importStar(require("./providers/vip-215"));
59
63
  const anonbox = __importStar(require("./providers/anonbox"));
60
64
  const fakeLegal = __importStar(require("./providers/fake-legal"));
65
+ const moakt = __importStar(require("./providers/moakt"));
66
+ const tenminuteOne = __importStar(require("./providers/10minute-one"));
61
67
  const retry_1 = require("./retry");
68
+ const telemetry_1 = require("./telemetry");
62
69
  const logger_1 = require("./logger");
63
70
  const config_1 = require("./config");
64
71
  /**
@@ -72,6 +79,7 @@ var normalize_1 = require("./normalize");
72
79
  Object.defineProperty(exports, "normalizeEmail", { enumerable: true, get: function () { return normalize_1.normalizeEmail; } });
73
80
  var retry_2 = require("./retry");
74
81
  Object.defineProperty(exports, "withRetry", { enumerable: true, get: function () { return retry_2.withRetry; } });
82
+ Object.defineProperty(exports, "withRetryWithAttempts", { enumerable: true, get: function () { return retry_2.withRetryWithAttempts; } });
75
83
  Object.defineProperty(exports, "fetchWithTimeout", { enumerable: true, get: function () { return retry_2.fetchWithTimeout; } });
76
84
  var logger_2 = require("./logger");
77
85
  Object.defineProperty(exports, "LogLevel", { enumerable: true, get: function () { return logger_2.LogLevel; } });
@@ -82,16 +90,23 @@ Object.defineProperty(exports, "logger", { enumerable: true, get: function () {
82
90
  var config_2 = require("./config");
83
91
  Object.defineProperty(exports, "setConfig", { enumerable: true, get: function () { return config_2.setConfig; } });
84
92
  Object.defineProperty(exports, "getConfig", { enumerable: true, get: function () { return config_2.getConfig; } });
93
+ var version_1 = require("./version");
94
+ Object.defineProperty(exports, "getSdkVersion", { enumerable: true, get: function () { return version_1.getSdkVersion; } });
85
95
  var linshi_token_1 = require("./providers/linshi-token");
86
96
  Object.defineProperty(exports, "deriveLinshiApiPathKey", { enumerable: true, get: function () { return linshi_token_1.deriveLinshiApiPathKey; } });
87
97
  Object.defineProperty(exports, "randomSyntheticLinshiKey", { enumerable: true, get: function () { return linshi_token_1.randomSyntheticLinshiKey; } });
88
98
  Object.defineProperty(exports, "randomBrowserLikeProfile", { enumerable: true, get: function () { return linshi_token_1.randomBrowserLikeProfile; } });
89
99
  Object.defineProperty(exports, "syntheticVisitorIdFromProfile", { enumerable: true, get: function () { return linshi_token_1.syntheticVisitorIdFromProfile; } });
90
100
  /** 所有支持的渠道列表,用于随机选择和遍历 */
91
- const allChannels = ['tempmail', 'linshi-email', 'linshiyou', 'mffac', 'tempmail-lol', 'chatgpt-org-uk', 'temp-mail-io', 'awamail', 'temporary-email-org', 'mail-tm', 'mail-cx', 'dropmail', 'guerrillamail', 'maildrop', 'smail-pw', 'boomlify', 'minmail', 'vip-215', 'anonbox', 'fake-legal'];
101
+ const allChannels = ['tempmail', 'tempmail-cn', 'tmpmails', 'ta-easy', '10mail-wangtz', '10minute-one', 'linshi-email', 'linshiyou', 'mffac', 'tempmail-lol', 'chatgpt-org-uk', 'temp-mail-io', 'awamail', 'temporary-email-org', 'mail-tm', 'mail-cx', 'dropmail', 'guerrillamail', 'maildrop', 'smail-pw', 'boomlify', 'minmail', 'vip-215', 'anonbox', 'fake-legal', 'moakt'];
92
102
  /** 渠道信息映射表 */
93
103
  const channelInfoMap = {
94
104
  'tempmail': { channel: 'tempmail', name: 'TempMail', website: 'tempmail.ing' },
105
+ 'tempmail-cn': { channel: 'tempmail-cn', name: 'TempMail CN', website: 'tempmail.cn' },
106
+ 'tmpmails': { channel: 'tmpmails', name: 'TmpMails', website: 'tmpmails.com' },
107
+ 'ta-easy': { channel: 'ta-easy', name: 'TA Easy', website: 'ta-easy.com' },
108
+ '10mail-wangtz': { channel: '10mail-wangtz', name: '10mail Wangtz', website: '10mail.wangtz.cn' },
109
+ '10minute-one': { channel: '10minute-one', name: '10 Minute Email', website: '10minutemail.one' },
95
110
  'linshi-email': { channel: 'linshi-email', name: '临时邮箱', website: 'linshi-email.com' },
96
111
  'linshiyou': { channel: 'linshiyou', name: '临时邮', website: 'linshiyou.com' },
97
112
  'tempmail-lol': { channel: 'tempmail-lol', name: 'TempMail LOL', website: 'tempmail.lol' },
@@ -111,6 +126,7 @@ const channelInfoMap = {
111
126
  'vip-215': { channel: 'vip-215', name: 'VIP 215', website: 'vip.215.im' },
112
127
  'anonbox': { channel: 'anonbox', name: 'Anonbox', website: 'anonbox.net' },
113
128
  'fake-legal': { channel: 'fake-legal', name: 'Fake Legal', website: 'fake.legal' },
129
+ 'moakt': { channel: 'moakt', name: 'Moakt', website: 'moakt.com' },
114
130
  };
115
131
  /**
116
132
  * 获取所有支持的渠道列表
@@ -161,11 +177,16 @@ async function generateEmail(options = {}) {
161
177
  */
162
178
  const allowFallback = options.channelFallback !== false;
163
179
  const tryOrder = buildChannelOrder(options.channel, allowFallback);
180
+ let channelsTried = 0;
181
+ let lastErr = '';
164
182
  for (const ch of tryOrder) {
183
+ channelsTried += 1;
165
184
  logger_1.logger.info(`创建临时邮箱, 渠道: ${ch}`);
166
- try {
167
- const internal = await (0, retry_1.withRetry)(() => generateEmailOnce(ch, options), options.retry);
185
+ const r = await (0, retry_1.withRetryWithAttempts)(() => generateEmailOnce(ch, options), options.retry);
186
+ if (r.ok) {
187
+ const internal = r.value;
168
188
  logger_1.logger.info(`邮箱创建成功: ${internal.email} (渠道: ${ch})`);
189
+ (0, telemetry_1.reportTelemetry)('generate_email', ch, true, r.attempts, channelsTried, '');
169
190
  /* 将 token 存入内部存储,不暴露给用户 */
170
191
  const publicInfo = {
171
192
  channel: internal.channel,
@@ -178,11 +199,12 @@ async function generateEmail(options = {}) {
178
199
  }
179
200
  return publicInfo;
180
201
  }
181
- catch (err) {
182
- logger_1.logger.warn(`渠道 ${ch} 不可用: ${err.message || err},尝试下一个渠道`);
183
- }
202
+ const msg = r.error?.message || String(r.error);
203
+ lastErr = msg;
204
+ logger_1.logger.warn(`渠道 ${ch} 不可用: ${msg},尝试下一个渠道`);
184
205
  }
185
206
  logger_1.logger.error('所有渠道均不可用,创建邮箱失败');
207
+ (0, telemetry_1.reportTelemetry)('generate_email', '', false, 0, channelsTried, lastErr);
186
208
  return null;
187
209
  }
188
210
  /**
@@ -209,6 +231,16 @@ async function generateEmailOnce(channel, options) {
209
231
  switch (channel) {
210
232
  case 'tempmail':
211
233
  return tempmail.generateEmail(options.duration || 30);
234
+ case 'tempmail-cn':
235
+ return tempmailCn.generateEmail(options.domain ?? null);
236
+ case 'tmpmails':
237
+ return tmpmails.generateEmail(options.domain ?? null);
238
+ case 'ta-easy':
239
+ return taEasy.generateEmail();
240
+ case '10mail-wangtz':
241
+ return tenmailWangtz.generateEmail(options.domain ?? null);
242
+ case '10minute-one':
243
+ return tenminuteOne.generateEmail(options.domain ?? null);
212
244
  case 'linshi-email':
213
245
  return linshiEmail.generateEmail();
214
246
  case 'linshiyou':
@@ -245,6 +277,8 @@ async function generateEmailOnce(channel, options) {
245
277
  return anonbox.generateEmail();
246
278
  case 'fake-legal':
247
279
  return fakeLegal.generateEmail(options.domain ?? null);
280
+ case 'moakt':
281
+ return moakt.generateEmail(options.domain ?? null);
248
282
  default:
249
283
  throw new Error(`Unknown channel: ${channel}`);
250
284
  }
@@ -273,35 +307,41 @@ async function generateEmailOnce(channel, options) {
273
307
  */
274
308
  async function getEmails(info, options) {
275
309
  if (!info) {
310
+ (0, telemetry_1.reportTelemetry)('get_emails', '', false, 0, 0, 'EmailInfo is required, call generateEmail() first');
276
311
  throw new Error('EmailInfo is required, call generateEmail() first');
277
312
  }
278
313
  const { channel, email } = info;
279
314
  const token = tokenStore.get(info);
280
315
  if (!channel) {
316
+ (0, telemetry_1.reportTelemetry)('get_emails', '', false, 0, 0, 'Channel is required');
281
317
  throw new Error('Channel is required');
282
318
  }
283
319
  if (!email && channel !== 'tempmail-lol') {
320
+ (0, telemetry_1.reportTelemetry)('get_emails', channel, false, 0, 0, 'Email is required');
284
321
  throw new Error('Email is required');
285
322
  }
286
323
  logger_1.logger.debug(`获取邮件, 渠道: ${channel}, 邮箱: ${email}`);
287
- try {
288
- const emails = await (0, retry_1.withRetry)(() => getEmailsOnce(channel, email, token), options?.retry);
324
+ const gr = await (0, retry_1.withRetryWithAttempts)(() => getEmailsOnce(channel, email, token), options?.retry);
325
+ if (gr.ok) {
326
+ const emails = gr.value;
289
327
  if (emails.length > 0) {
290
328
  logger_1.logger.info(`获取到 ${emails.length} 封邮件, 渠道: ${channel}`);
291
329
  }
292
330
  else {
293
331
  logger_1.logger.debug(`暂无邮件, 渠道: ${channel}`);
294
332
  }
333
+ (0, telemetry_1.reportTelemetry)('get_emails', channel, true, gr.attempts, 0, '');
295
334
  return { channel, email, emails, success: true };
296
335
  }
297
- catch (err) {
298
- /*
299
- * 重试耗尽后仍然失败 → 返回空结果而非抛异常
300
- * 这样调用方在轮询场景下不会因为一次网络波动而中断整个流程
301
- */
302
- logger_1.logger.error(`获取邮件失败, 渠道: ${channel}, 错误: ${err.message || err}`);
303
- return { channel, email, emails: [], success: false };
304
- }
336
+ const err = gr.error;
337
+ const errMsg = err?.message || String(err);
338
+ /*
339
+ * 重试耗尽后仍然失败 → 返回空结果而非抛异常
340
+ * 这样调用方在轮询场景下不会因为一次网络波动而中断整个流程
341
+ */
342
+ logger_1.logger.error(`获取邮件失败, 渠道: ${channel}, 错误: ${errMsg}`);
343
+ (0, telemetry_1.reportTelemetry)('get_emails', channel, false, gr.attempts, 0, errMsg);
344
+ return { channel, email, emails: [], success: false };
305
345
  }
306
346
  /**
307
347
  * 单次获取邮件(不含重试逻辑)
@@ -311,6 +351,22 @@ async function getEmailsOnce(channel, email, token) {
311
351
  switch (channel) {
312
352
  case 'tempmail':
313
353
  return tempmail.getEmails(email);
354
+ case 'tempmail-cn':
355
+ return tempmailCn.getEmails(email);
356
+ case 'tmpmails':
357
+ if (!token)
358
+ throw new Error('internal error: token missing for tmpmails');
359
+ return tmpmails.getEmails(email, token);
360
+ case 'ta-easy':
361
+ if (!token)
362
+ throw new Error('internal error: token missing for ta-easy');
363
+ return taEasy.getEmails(email, token);
364
+ case '10mail-wangtz':
365
+ return tenmailWangtz.getEmails(email);
366
+ case '10minute-one':
367
+ if (!token)
368
+ throw new Error('internal error: token missing for 10minute-one');
369
+ return tenminuteOne.getEmails(email, token);
314
370
  case 'linshi-email':
315
371
  if (!token)
316
372
  throw new Error('internal error: token missing for linshi-email');
@@ -379,6 +435,10 @@ async function getEmailsOnce(channel, email, token) {
379
435
  return anonbox.getEmails(token, email);
380
436
  case 'fake-legal':
381
437
  return fakeLegal.getEmails(email);
438
+ case 'moakt':
439
+ if (!token)
440
+ throw new Error('internal error: token missing for moakt');
441
+ return moakt.getEmails(email, token);
382
442
  default:
383
443
  throw new Error(`Unknown channel: ${channel}`);
384
444
  }
@@ -421,6 +481,7 @@ class TempEmailClient {
421
481
  */
422
482
  async getEmails(options) {
423
483
  if (!this.emailInfo) {
484
+ (0, telemetry_1.reportTelemetry)('get_emails', '', false, 0, 0, 'No email generated. Call generate() first.');
424
485
  throw new Error('No email generated. Call generate() first.');
425
486
  }
426
487
  return getEmails(this.emailInfo, options);
@@ -443,4 +504,4 @@ exports.default = {
443
504
  setConfig: config_1.setConfig,
444
505
  getConfig: config_1.getConfig,
445
506
  };
446
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as tempmail from './providers/tempmail';\nimport * as linshiEmail from './providers/linshi-email';\nimport * as linshiyou from './providers/linshiyou';\nimport * as mffac from './providers/mffac';\nimport * as tempmailLol from './providers/tempmail-lol';\nimport * as chatgptOrgUk from './providers/chatgpt-org-uk';\nimport * as tempMailIO from './providers/temp-mail-io';\nimport * as awamail from './providers/awamail';\nimport * as temporaryEmailOrg from './providers/temporary-email-org';\nimport * as mailTm from './providers/mail-tm';\nimport * as mailCx from './providers/mail-cx';\nimport * as dropmail from './providers/dropmail';\nimport * as guerrillamail from './providers/guerrillamail';\nimport * as maildropProvider from './providers/maildrop';\nimport * as smailPw from './providers/smail-pw';\nimport * as boomlify from './providers/boomlify';\nimport * as minmail from './providers/minmail';\nimport * as vip215 from './providers/vip-215';\nimport * as anonbox from './providers/anonbox';\nimport * as fakeLegal from './providers/fake-legal';\nimport { Channel, EmailInfo, InternalEmailInfo, Email, GetEmailsResult, GenerateEmailOptions, GetEmailsOptions } from './types';\nimport { withRetry } from './retry';\nimport { logger } from './logger';\nimport { setConfig, getConfig } from './config';\n\nexport { Channel, EmailInfo, Email, EmailAttachment, GetEmailsResult, GenerateEmailOptions, GetEmailsOptions } from './types';\n\n/**\n * SDK 内部 token 存储\n * 使用 WeakMap 将 EmailInfo 对象映射到对应的 token\n * 用户无法直接访问 token，由 SDK 自动管理\n * @internal\n */\nconst tokenStore = new WeakMap<EmailInfo, string>();\nexport { normalizeEmail } from './normalize';\nexport { withRetry, fetchWithTimeout, RetryOptions } from './retry';\nexport { LogLevel, LogHandler, setLogLevel, getLogLevel, setLogger, logger } from './logger';\nexport { SDKConfig, setConfig, getConfig } from './config';\nexport type { SyntheticBrowserProfile } from './providers/linshi-token';\nexport {\n  deriveLinshiApiPathKey,\n  randomSyntheticLinshiKey,\n  randomBrowserLikeProfile,\n  syntheticVisitorIdFromProfile,\n} from './providers/linshi-token';\n\n/** 所有支持的渠道列表，用于随机选择和遍历 */\nconst allChannels: Channel[] = ['tempmail', 'linshi-email', 'linshiyou', 'mffac', 'tempmail-lol', 'chatgpt-org-uk', 'temp-mail-io', 'awamail', 'temporary-email-org', 'mail-tm', 'mail-cx', 'dropmail', 'guerrillamail', 'maildrop', 'smail-pw', 'boomlify', 'minmail', 'vip-215', 'anonbox', 'fake-legal'];\n\n/**\n * 渠道信息，包含渠道标识、显示名称和对应网站\n */\nexport interface ChannelInfo {\n  /** 渠道标识 */\n  channel: Channel;\n  /** 渠道显示名称 */\n  name: string;\n  /** 对应的临时邮箱服务网站 */\n  website: string;\n}\n\n/** 渠道信息映射表 */\nconst channelInfoMap: Record<Channel, ChannelInfo> = {\n  'tempmail': { channel: 'tempmail', name: 'TempMail', website: 'tempmail.ing' },\n  'linshi-email': { channel: 'linshi-email', name: '临时邮箱', website: 'linshi-email.com' },\n  'linshiyou': { channel: 'linshiyou', name: '临时邮', website: 'linshiyou.com' },\n  'tempmail-lol': { channel: 'tempmail-lol', name: 'TempMail LOL', website: 'tempmail.lol' },\n  'chatgpt-org-uk': { channel: 'chatgpt-org-uk', name: 'ChatGPT Mail', website: 'mail.chatgpt.org.uk' },\n  'temp-mail-io': { channel: 'temp-mail-io', name: 'Temp Mail IO', website: 'temp-mail.io' },\n  'awamail': { channel: 'awamail', name: 'AwaMail', website: 'awamail.com' },\n  'temporary-email-org': { channel: 'temporary-email-org', name: 'Temporary Email', website: 'temporary-email.org' },\n  'mail-tm': { channel: 'mail-tm', name: 'Mail.tm', website: 'mail.tm' },\n  'mail-cx': { channel: 'mail-cx', name: 'Mail.cx', website: 'mail.cx' },\n  'dropmail': { channel: 'dropmail', name: 'DropMail', website: 'dropmail.me' },\n  'guerrillamail': { channel: 'guerrillamail', name: 'Guerrilla Mail', website: 'guerrillamail.com' },\n  'maildrop': { channel: 'maildrop', name: 'Maildrop', website: 'maildrop.cx' },\n  'smail-pw': { channel: 'smail-pw', name: 'Smail.pw', website: 'smail.pw' },\n  'boomlify': { channel: 'boomlify', name: 'Boomlify', website: 'boomlify.com' },\n  'minmail': { channel: 'minmail', name: 'MinMail', website: 'minmail.app' },\n  'mffac': { channel: 'mffac', name: 'MFFAC', website: 'mffac.com' },\n  'vip-215': { channel: 'vip-215', name: 'VIP 215', website: 'vip.215.im' },\n  'anonbox': { channel: 'anonbox', name: 'Anonbox', website: 'anonbox.net' },\n  'fake-legal': { channel: 'fake-legal', name: 'Fake Legal', website: 'fake.legal' },\n};\n\n/**\n * 获取所有支持的渠道列表\n *\n * @returns 所有渠道的信息数组\n *\n * @example\n * ```ts\n * const channels = listChannels();\n * channels.forEach(ch => console.log(`${ch.name} (${ch.website})`));\n * ```\n */\nexport function listChannels(): ChannelInfo[] {\n  return allChannels.map(ch => channelInfoMap[ch]);\n}\n\n/**\n * 获取指定渠道的详细信息\n *\n * @param channel - 渠道标识\n * @returns 渠道信息，不存在时返回 undefined\n */\nexport function getChannelInfo(channel: Channel): ChannelInfo | undefined {\n  return channelInfoMap[channel];\n}\n\n/**\n * 创建临时邮箱\n *\n * 错误处理策略：\n * - 指定渠道失败时，默认自动尝试其他可用渠道（打乱顺序逐个尝试）\n * - `channelFallback: false` 且指定了 `channel` 时，仅尝试该渠道，失败即返回 null\n * - 未指定渠道时，打乱全部渠道逐个尝试，直到成功\n * - 所有渠道均不可用时返回 null（不抛出异常）\n *\n * @param options - 创建选项，可指定渠道、有效时长、域名等\n * @returns 邮箱信息，所有渠道均不可用时返回 null\n *\n * @example\n * ```ts\n * const emailInfo = await generateEmail({ channel: 'temp-mail-io' });\n * if (emailInfo) console.log(emailInfo.email);\n * ```\n */\nexport async function generateEmail(options: GenerateEmailOptions = {}): Promise<EmailInfo | null> {\n  /*\n   * 构建尝试顺序：\n   * - 指定渠道 → 优先尝试该渠道，失败后随机尝试其他渠道\n   * - 未指定 → 打乱全部渠道逐个尝试\n   */\n  const allowFallback = options.channelFallback !== false;\n  const tryOrder = buildChannelOrder(options.channel, allowFallback);\n\n  for (const ch of tryOrder) {\n    logger.info(`创建临时邮箱, 渠道: ${ch}`);\n    try {\n      const internal: InternalEmailInfo = await withRetry(() => generateEmailOnce(ch, options), options.retry);\n      logger.info(`邮箱创建成功: ${internal.email} (渠道: ${ch})`);\n\n      /* 将 token 存入内部存储，不暴露给用户 */\n      const publicInfo: EmailInfo = {\n        channel: internal.channel,\n        email: internal.email,\n        expiresAt: internal.expiresAt,\n        createdAt: internal.createdAt,\n      };\n      if (internal.token) {\n        tokenStore.set(publicInfo, internal.token);\n      }\n      return publicInfo;\n    } catch (err: any) {\n      logger.warn(`渠道 ${ch} 不可用: ${err.message || err}，尝试下一个渠道`);\n    }\n  }\n\n  logger.error('所有渠道均不可用，创建邮箱失败');\n  return null;\n}\n\n/**\n * 构建渠道尝试顺序\n * 指定渠道时优先尝试该渠道，其余渠道打乱追加\n * 未指定时打乱全部渠道\n */\nfunction buildChannelOrder(preferred?: Channel, allowFallback = true): Channel[] {\n  const shuffled = [...allChannels].sort(() => Math.random() - 0.5);\n  if (!preferred) {\n    return shuffled;\n  }\n  if (!allowFallback) {\n    return [preferred];\n  }\n  const rest = shuffled.filter(ch => ch !== preferred);\n  return [preferred, ...rest];\n}\n\n/**\n * 单次创建邮箱（不含重试逻辑）\n * 根据渠道类型分发到对应的 provider 实现\n */\nasync function generateEmailOnce(channel: Channel, options: GenerateEmailOptions): Promise<InternalEmailInfo> {\n  switch (channel) {\n    case 'tempmail':\n      return tempmail.generateEmail(options.duration || 30);\n    case 'linshi-email':\n      return linshiEmail.generateEmail();\n    case 'linshiyou':\n      return linshiyou.generateEmail();\n    case 'tempmail-lol':\n      return tempmailLol.generateEmail(options.domain || null);\n    case 'chatgpt-org-uk':\n      return chatgptOrgUk.generateEmail();\n    case 'temp-mail-io':\n      return tempMailIO.generateEmail();\n    case 'awamail':\n      return awamail.generateEmail();\n    case 'temporary-email-org':\n      return temporaryEmailOrg.generateEmail();\n    case 'mail-tm':\n      return mailTm.generateEmail();\n    case 'dropmail':\n      return dropmail.generateEmail();\n    case 'guerrillamail':\n      return guerrillamail.generateEmail();\n    case 'maildrop':\n      return maildropProvider.generateEmail(options.domain ?? null);\n    case 'smail-pw':\n      return smailPw.generateEmail();\n    case 'boomlify':\n      return boomlify.generateEmail();\n    case 'mffac':\n      return mffac.generateEmail();\n    case 'minmail':\n      return minmail.generateEmail();\n    case 'vip-215':\n      return vip215.generateEmail();\n    case 'anonbox':\n      return anonbox.generateEmail();\n    case 'fake-legal':\n      return fakeLegal.generateEmail(options.domain ?? null);\n    default:\n      throw new Error(`Unknown channel: ${channel}`);\n  }\n}\n\n/**\n * 获取邮件列表\n * Channel/Email/Token 等由 SDK 从 EmailInfo 中自动获取，用户无需手动传递\n *\n * 错误处理策略：\n * - 网络错误、超时、429、服务端 5xx 错误 → 自动重试（默认 2 次）\n * - 重试耗尽后返回 { success: false, emails: [] }，不抛异常\n * - 参数校验错误（缺少 EmailInfo）直接抛出\n *\n * @param info - GenerateEmail() 返回的邮箱信息\n * @param options - 可选配置（重试等）\n * @returns 邮件结果，包含 success 标记和邮件列表\n *\n * @example\n * ```ts\n * const info = await generateEmail({ channel: 'mail-tm' });\n * const result = await getEmails(info);\n * if (result.success && result.emails.length > 0) {\n *   console.log('收到邮件:', result.emails[0].subject);\n * }\n * ```\n */\nexport async function getEmails(info: EmailInfo, options?: GetEmailsOptions): Promise<GetEmailsResult> {\n  if (!info) {\n    throw new Error('EmailInfo is required, call generateEmail() first');\n  }\n\n  const { channel, email } = info;\n  const token = tokenStore.get(info);\n\n  if (!channel) {\n    throw new Error('Channel is required');\n  }\n  if (!email && channel !== 'tempmail-lol') {\n    throw new Error('Email is required');\n  }\n\n  logger.debug(`获取邮件, 渠道: ${channel}, 邮箱: ${email}`);\n  try {\n    const emails = await withRetry(() => getEmailsOnce(channel, email, token), options?.retry);\n    if (emails.length > 0) {\n      logger.info(`获取到 ${emails.length} 封邮件, 渠道: ${channel}`);\n    } else {\n      logger.debug(`暂无邮件, 渠道: ${channel}`);\n    }\n    return { channel, email, emails, success: true };\n  } catch (err: any) {\n    /*\n     * 重试耗尽后仍然失败 → 返回空结果而非抛异常\n     * 这样调用方在轮询场景下不会因为一次网络波动而中断整个流程\n     */\n    logger.error(`获取邮件失败, 渠道: ${channel}, 错误: ${err.message || err}`);\n    return { channel, email, emails: [], success: false };\n  }\n}\n\n/**\n * 单次获取邮件（不含重试逻辑）\n * 根据渠道类型分发到对应的 provider 实现，并校验必需的 token 参数\n */\nasync function getEmailsOnce(channel: Channel, email: string, token?: string): Promise<Email[]> {\n  switch (channel) {\n    case 'tempmail':\n      return tempmail.getEmails(email);\n    case 'linshi-email':\n      if (!token) throw new Error('internal error: token missing for linshi-email');\n      return linshiEmail.getEmails(email, token);\n    case 'linshiyou':\n      if (!token) throw new Error('internal error: token missing for linshiyou');\n      return linshiyou.getEmails(token, email);\n    case 'tempmail-lol':\n      if (!token) throw new Error('internal error: token missing for tempmail-lol');\n      return tempmailLol.getEmails(token, email);\n    case 'chatgpt-org-uk':\n      if (!token) throw new Error('internal error: token missing for chatgpt-org-uk');\n      return chatgptOrgUk.getEmails(token, email);\n    case 'temp-mail-io':\n      return tempMailIO.getEmails(email);\n    case 'awamail':\n      if (!token) throw new Error('internal error: token missing for awamail');\n      return awamail.getEmails(token, email);\n    case 'temporary-email-org':\n      if (!token) throw new Error('internal error: token missing for temporary-email-org');\n      return temporaryEmailOrg.getEmails(email, token);\n    case 'mail-tm':\n      if (!token) throw new Error('internal error: token missing for mail-tm');\n      return mailTm.getEmails(token, email);\n    case 'mail-cx':\n      if (!token) throw new Error('internal error: token missing for mail-cx');\n      return mailCx.getEmails(token, email);\n    case 'dropmail':\n      if (!token) throw new Error('internal error: token missing for dropmail');\n      return dropmail.getEmails(token, email);\n    case 'guerrillamail':\n      if (!token) throw new Error('internal error: token missing for guerrillamail');\n      return guerrillamail.getEmails(token, email);\n    case 'maildrop':\n      if (!token) throw new Error('internal error: token missing for maildrop');\n      return maildropProvider.getEmails(token, email);\n    case 'smail-pw':\n      if (!token) throw new Error('internal error: token missing for smail-pw');\n      return smailPw.getEmails(token, email);\n    case 'boomlify':\n      return boomlify.getEmails(email);\n    case 'mffac':\n      return mffac.getEmails(email, token);\n    case 'minmail':\n      if (!token) throw new Error('internal error: token missing for minmail');\n      return minmail.getEmails(email, token);\n    case 'vip-215':\n      if (!token) throw new Error('internal error: token missing for vip-215');\n      return vip215.getEmails(token, email);\n    case 'anonbox':\n      if (!token) throw new Error('internal error: token missing for anonbox');\n      return anonbox.getEmails(token, email);\n    case 'fake-legal':\n      return fakeLegal.getEmails(email);\n    default:\n      throw new Error(`Unknown channel: ${channel}`);\n  }\n}\n\n/**\n * 临时邮箱客户端\n * 封装了邮箱创建和邮件获取的完整流程，自动管理邮箱信息和认证令牌\n *\n * @example\n * ```ts\n * const client = new TempEmailClient();\n * const emailInfo = await client.generate({ channel: 'mail-tm' });\n * console.log('邮箱:', emailInfo.email);\n *\n * // 轮询获取邮件\n * const result = await client.getEmails();\n * if (result.success) {\n *   console.log('邮件数:', result.emails.length);\n * }\n * ```\n */\nexport class TempEmailClient {\n  private emailInfo: EmailInfo | null = null;\n\n  /**\n   * 创建临时邮箱并缓存邮箱信息\n   * 后续调用 getEmails() 时自动使用此邮箱的渠道、地址和令牌\n   * 所有渠道均不可用时返回 null\n   */\n  async generate(options: GenerateEmailOptions = {}): Promise<EmailInfo | null> {\n    this.emailInfo = await generateEmail(options);\n    return this.emailInfo;\n  }\n\n  /**\n   * 获取当前邮箱的邮件列表\n   * 必须先调用 generate() 创建邮箱\n   *\n   * @throws 未调用 generate() 时抛出异常\n   */\n  async getEmails(options?: GetEmailsOptions): Promise<GetEmailsResult> {\n    if (!this.emailInfo) {\n      throw new Error('No email generated. Call generate() first.');\n    }\n\n    return getEmails(this.emailInfo, options);\n  }\n\n  /**\n   * 获取当前缓存的邮箱信息\n   * 未调用 generate() 时返回 null\n   */\n  getEmailInfo(): EmailInfo | null {\n    return this.emailInfo;\n  }\n}\n\nexport default {\n  listChannels,\n  getChannelInfo,\n  generateEmail,\n  getEmails,\n  TempEmailClient,\n  setConfig,\n  getConfig,\n};\n"]}
507
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as tempmail from './providers/tempmail';\nimport * as tempmailCn from './providers/tempmail-cn';\nimport * as tmpmails from './providers/tmpmails';\nimport * as taEasy from './providers/ta-easy';\nimport * as tenmailWangtz from './providers/10mail-wangtz';\nimport * as linshiEmail from './providers/linshi-email';\nimport * as linshiyou from './providers/linshiyou';\nimport * as mffac from './providers/mffac';\nimport * as tempmailLol from './providers/tempmail-lol';\nimport * as chatgptOrgUk from './providers/chatgpt-org-uk';\nimport * as tempMailIO from './providers/temp-mail-io';\nimport * as awamail from './providers/awamail';\nimport * as temporaryEmailOrg from './providers/temporary-email-org';\nimport * as mailTm from './providers/mail-tm';\nimport * as mailCx from './providers/mail-cx';\nimport * as dropmail from './providers/dropmail';\nimport * as guerrillamail from './providers/guerrillamail';\nimport * as maildropProvider from './providers/maildrop';\nimport * as smailPw from './providers/smail-pw';\nimport * as boomlify from './providers/boomlify';\nimport * as minmail from './providers/minmail';\nimport * as vip215 from './providers/vip-215';\nimport * as anonbox from './providers/anonbox';\nimport * as fakeLegal from './providers/fake-legal';\nimport * as moakt from './providers/moakt';\nimport * as tenminuteOne from './providers/10minute-one';\nimport { Channel, EmailInfo, InternalEmailInfo, Email, GetEmailsResult, GenerateEmailOptions, GetEmailsOptions } from './types';\nimport { withRetry, withRetryWithAttempts } from './retry';\nimport { reportTelemetry } from './telemetry';\nimport { logger } from './logger';\nimport { setConfig, getConfig } from './config';\n\nexport { Channel, EmailInfo, Email, EmailAttachment, GetEmailsResult, GenerateEmailOptions, GetEmailsOptions } from './types';\n\n/**\n * SDK 内部 token 存储\n * 使用 WeakMap 将 EmailInfo 对象映射到对应的 token\n * 用户无法直接访问 token，由 SDK 自动管理\n * @internal\n */\nconst tokenStore = new WeakMap<EmailInfo, string>();\nexport { normalizeEmail } from './normalize';\nexport { withRetry, withRetryWithAttempts, fetchWithTimeout, RetryOptions } from './retry';\nexport type { RetryWithAttemptsResult, FetchWithTimeoutOptions } from './retry';\nexport { LogLevel, LogHandler, setLogLevel, getLogLevel, setLogger, logger } from './logger';\nexport { SDKConfig, setConfig, getConfig } from './config';\nexport { getSdkVersion } from './version';\nexport type { SyntheticBrowserProfile } from './providers/linshi-token';\nexport {\n  deriveLinshiApiPathKey,\n  randomSyntheticLinshiKey,\n  randomBrowserLikeProfile,\n  syntheticVisitorIdFromProfile,\n} from './providers/linshi-token';\n\n/** 所有支持的渠道列表，用于随机选择和遍历 */\nconst allChannels: Channel[] = ['tempmail', 'tempmail-cn', 'tmpmails', 'ta-easy', '10mail-wangtz', '10minute-one', 'linshi-email', 'linshiyou', 'mffac', 'tempmail-lol', 'chatgpt-org-uk', 'temp-mail-io', 'awamail', 'temporary-email-org', 'mail-tm', 'mail-cx', 'dropmail', 'guerrillamail', 'maildrop', 'smail-pw', 'boomlify', 'minmail', 'vip-215', 'anonbox', 'fake-legal', 'moakt'];\n\n/**\n * 渠道信息，包含渠道标识、显示名称和对应网站\n */\nexport interface ChannelInfo {\n  /** 渠道标识 */\n  channel: Channel;\n  /** 渠道显示名称 */\n  name: string;\n  /** 对应的临时邮箱服务网站 */\n  website: string;\n}\n\n/** 渠道信息映射表 */\nconst channelInfoMap: Record<Channel, ChannelInfo> = {\n  'tempmail': { channel: 'tempmail', name: 'TempMail', website: 'tempmail.ing' },\n  'tempmail-cn': { channel: 'tempmail-cn', name: 'TempMail CN', website: 'tempmail.cn' },\n  'tmpmails': { channel: 'tmpmails', name: 'TmpMails', website: 'tmpmails.com' },\n  'ta-easy': { channel: 'ta-easy', name: 'TA Easy', website: 'ta-easy.com' },\n  '10mail-wangtz': { channel: '10mail-wangtz', name: '10mail Wangtz', website: '10mail.wangtz.cn' },\n  '10minute-one': { channel: '10minute-one', name: '10 Minute Email', website: '10minutemail.one' },\n  'linshi-email': { channel: 'linshi-email', name: '临时邮箱', website: 'linshi-email.com' },\n  'linshiyou': { channel: 'linshiyou', name: '临时邮', website: 'linshiyou.com' },\n  'tempmail-lol': { channel: 'tempmail-lol', name: 'TempMail LOL', website: 'tempmail.lol' },\n  'chatgpt-org-uk': { channel: 'chatgpt-org-uk', name: 'ChatGPT Mail', website: 'mail.chatgpt.org.uk' },\n  'temp-mail-io': { channel: 'temp-mail-io', name: 'Temp Mail IO', website: 'temp-mail.io' },\n  'awamail': { channel: 'awamail', name: 'AwaMail', website: 'awamail.com' },\n  'temporary-email-org': { channel: 'temporary-email-org', name: 'Temporary Email', website: 'temporary-email.org' },\n  'mail-tm': { channel: 'mail-tm', name: 'Mail.tm', website: 'mail.tm' },\n  'mail-cx': { channel: 'mail-cx', name: 'Mail.cx', website: 'mail.cx' },\n  'dropmail': { channel: 'dropmail', name: 'DropMail', website: 'dropmail.me' },\n  'guerrillamail': { channel: 'guerrillamail', name: 'Guerrilla Mail', website: 'guerrillamail.com' },\n  'maildrop': { channel: 'maildrop', name: 'Maildrop', website: 'maildrop.cx' },\n  'smail-pw': { channel: 'smail-pw', name: 'Smail.pw', website: 'smail.pw' },\n  'boomlify': { channel: 'boomlify', name: 'Boomlify', website: 'boomlify.com' },\n  'minmail': { channel: 'minmail', name: 'MinMail', website: 'minmail.app' },\n  'mffac': { channel: 'mffac', name: 'MFFAC', website: 'mffac.com' },\n  'vip-215': { channel: 'vip-215', name: 'VIP 215', website: 'vip.215.im' },\n  'anonbox': { channel: 'anonbox', name: 'Anonbox', website: 'anonbox.net' },\n  'fake-legal': { channel: 'fake-legal', name: 'Fake Legal', website: 'fake.legal' },\n  'moakt': { channel: 'moakt', name: 'Moakt', website: 'moakt.com' },\n};\n\n/**\n * 获取所有支持的渠道列表\n *\n * @returns 所有渠道的信息数组\n *\n * @example\n * ```ts\n * const channels = listChannels();\n * channels.forEach(ch => console.log(`${ch.name} (${ch.website})`));\n * ```\n */\nexport function listChannels(): ChannelInfo[] {\n  return allChannels.map(ch => channelInfoMap[ch]);\n}\n\n/**\n * 获取指定渠道的详细信息\n *\n * @param channel - 渠道标识\n * @returns 渠道信息，不存在时返回 undefined\n */\nexport function getChannelInfo(channel: Channel): ChannelInfo | undefined {\n  return channelInfoMap[channel];\n}\n\n/**\n * 创建临时邮箱\n *\n * 错误处理策略：\n * - 指定渠道失败时，默认自动尝试其他可用渠道（打乱顺序逐个尝试）\n * - `channelFallback: false` 且指定了 `channel` 时，仅尝试该渠道，失败即返回 null\n * - 未指定渠道时，打乱全部渠道逐个尝试，直到成功\n * - 所有渠道均不可用时返回 null（不抛出异常）\n *\n * @param options - 创建选项，可指定渠道、有效时长、域名等\n * @returns 邮箱信息，所有渠道均不可用时返回 null\n *\n * @example\n * ```ts\n * const emailInfo = await generateEmail({ channel: 'temp-mail-io' });\n * if (emailInfo) console.log(emailInfo.email);\n * ```\n */\nexport async function generateEmail(options: GenerateEmailOptions = {}): Promise<EmailInfo | null> {\n  /*\n   * 构建尝试顺序：\n   * - 指定渠道 → 优先尝试该渠道，失败后随机尝试其他渠道\n   * - 未指定 → 打乱全部渠道逐个尝试\n   */\n  const allowFallback = options.channelFallback !== false;\n  const tryOrder = buildChannelOrder(options.channel, allowFallback);\n\n  let channelsTried = 0;\n  let lastErr = '';\n  for (const ch of tryOrder) {\n    channelsTried += 1;\n    logger.info(`创建临时邮箱, 渠道: ${ch}`);\n    const r = await withRetryWithAttempts(() => generateEmailOnce(ch, options), options.retry);\n    if (r.ok) {\n      const internal = r.value;\n      logger.info(`邮箱创建成功: ${internal.email} (渠道: ${ch})`);\n      reportTelemetry('generate_email', ch, true, r.attempts, channelsTried, '');\n\n      /* 将 token 存入内部存储，不暴露给用户 */\n      const publicInfo: EmailInfo = {\n        channel: internal.channel,\n        email: internal.email,\n        expiresAt: internal.expiresAt,\n        createdAt: internal.createdAt,\n      };\n      if (internal.token) {\n        tokenStore.set(publicInfo, internal.token);\n      }\n      return publicInfo;\n    }\n    const msg = (r.error as any)?.message || String(r.error);\n    lastErr = msg;\n    logger.warn(`渠道 ${ch} 不可用: ${msg}，尝试下一个渠道`);\n  }\n\n  logger.error('所有渠道均不可用，创建邮箱失败');\n  reportTelemetry('generate_email', '', false, 0, channelsTried, lastErr);\n  return null;\n}\n\n/**\n * 构建渠道尝试顺序\n * 指定渠道时优先尝试该渠道，其余渠道打乱追加\n * 未指定时打乱全部渠道\n */\nfunction buildChannelOrder(preferred?: Channel, allowFallback = true): Channel[] {\n  const shuffled = [...allChannels].sort(() => Math.random() - 0.5);\n  if (!preferred) {\n    return shuffled;\n  }\n  if (!allowFallback) {\n    return [preferred];\n  }\n  const rest = shuffled.filter(ch => ch !== preferred);\n  return [preferred, ...rest];\n}\n\n/**\n * 单次创建邮箱（不含重试逻辑）\n * 根据渠道类型分发到对应的 provider 实现\n */\nasync function generateEmailOnce(channel: Channel, options: GenerateEmailOptions): Promise<InternalEmailInfo> {\n  switch (channel) {\n    case 'tempmail':\n      return tempmail.generateEmail(options.duration || 30);\n    case 'tempmail-cn':\n      return tempmailCn.generateEmail(options.domain ?? null);\n    case 'tmpmails':\n      return tmpmails.generateEmail(options.domain ?? null);\n    case 'ta-easy':\n      return taEasy.generateEmail();\n    case '10mail-wangtz':\n      return tenmailWangtz.generateEmail(options.domain ?? null);\n    case '10minute-one':\n      return tenminuteOne.generateEmail(options.domain ?? null);\n    case 'linshi-email':\n      return linshiEmail.generateEmail();\n    case 'linshiyou':\n      return linshiyou.generateEmail();\n    case 'tempmail-lol':\n      return tempmailLol.generateEmail(options.domain || null);\n    case 'chatgpt-org-uk':\n      return chatgptOrgUk.generateEmail();\n    case 'temp-mail-io':\n      return tempMailIO.generateEmail();\n    case 'awamail':\n      return awamail.generateEmail();\n    case 'temporary-email-org':\n      return temporaryEmailOrg.generateEmail();\n    case 'mail-tm':\n      return mailTm.generateEmail();\n    case 'dropmail':\n      return dropmail.generateEmail();\n    case 'guerrillamail':\n      return guerrillamail.generateEmail();\n    case 'maildrop':\n      return maildropProvider.generateEmail(options.domain ?? null);\n    case 'smail-pw':\n      return smailPw.generateEmail();\n    case 'boomlify':\n      return boomlify.generateEmail();\n    case 'mffac':\n      return mffac.generateEmail();\n    case 'minmail':\n      return minmail.generateEmail();\n    case 'vip-215':\n      return vip215.generateEmail();\n    case 'anonbox':\n      return anonbox.generateEmail();\n    case 'fake-legal':\n      return fakeLegal.generateEmail(options.domain ?? null);\n    case 'moakt':\n      return moakt.generateEmail(options.domain ?? null);\n    default:\n      throw new Error(`Unknown channel: ${channel}`);\n  }\n}\n\n/**\n * 获取邮件列表\n * Channel/Email/Token 等由 SDK 从 EmailInfo 中自动获取，用户无需手动传递\n *\n * 错误处理策略：\n * - 网络错误、超时、429、服务端 5xx 错误 → 自动重试（默认 2 次）\n * - 重试耗尽后返回 { success: false, emails: [] }，不抛异常\n * - 参数校验错误（缺少 EmailInfo）直接抛出\n *\n * @param info - GenerateEmail() 返回的邮箱信息\n * @param options - 可选配置（重试等）\n * @returns 邮件结果，包含 success 标记和邮件列表\n *\n * @example\n * ```ts\n * const info = await generateEmail({ channel: 'mail-tm' });\n * const result = await getEmails(info);\n * if (result.success && result.emails.length > 0) {\n *   console.log('收到邮件:', result.emails[0].subject);\n * }\n * ```\n */\nexport async function getEmails(info: EmailInfo, options?: GetEmailsOptions): Promise<GetEmailsResult> {\n  if (!info) {\n    reportTelemetry('get_emails', '', false, 0, 0, 'EmailInfo is required, call generateEmail() first');\n    throw new Error('EmailInfo is required, call generateEmail() first');\n  }\n\n  const { channel, email } = info;\n  const token = tokenStore.get(info);\n\n  if (!channel) {\n    reportTelemetry('get_emails', '', false, 0, 0, 'Channel is required');\n    throw new Error('Channel is required');\n  }\n  if (!email && channel !== 'tempmail-lol') {\n    reportTelemetry('get_emails', channel, false, 0, 0, 'Email is required');\n    throw new Error('Email is required');\n  }\n\n  logger.debug(`获取邮件, 渠道: ${channel}, 邮箱: ${email}`);\n  const gr = await withRetryWithAttempts(() => getEmailsOnce(channel, email, token), options?.retry);\n  if (gr.ok) {\n    const emails = gr.value;\n    if (emails.length > 0) {\n      logger.info(`获取到 ${emails.length} 封邮件, 渠道: ${channel}`);\n    } else {\n      logger.debug(`暂无邮件, 渠道: ${channel}`);\n    }\n    reportTelemetry('get_emails', channel, true, gr.attempts, 0, '');\n    return { channel, email, emails, success: true };\n  }\n  const err = gr.error as any;\n  const errMsg = err?.message || String(err);\n  /*\n   * 重试耗尽后仍然失败 → 返回空结果而非抛异常\n   * 这样调用方在轮询场景下不会因为一次网络波动而中断整个流程\n   */\n  logger.error(`获取邮件失败, 渠道: ${channel}, 错误: ${errMsg}`);\n  reportTelemetry('get_emails', channel, false, gr.attempts, 0, errMsg);\n  return { channel, email, emails: [], success: false };\n}\n\n/**\n * 单次获取邮件（不含重试逻辑）\n * 根据渠道类型分发到对应的 provider 实现，并校验必需的 token 参数\n */\nasync function getEmailsOnce(channel: Channel, email: string, token?: string): Promise<Email[]> {\n  switch (channel) {\n    case 'tempmail':\n      return tempmail.getEmails(email);\n    case 'tempmail-cn':\n      return tempmailCn.getEmails(email);\n    case 'tmpmails':\n      if (!token) throw new Error('internal error: token missing for tmpmails');\n      return tmpmails.getEmails(email, token);\n    case 'ta-easy':\n      if (!token) throw new Error('internal error: token missing for ta-easy');\n      return taEasy.getEmails(email, token);\n    case '10mail-wangtz':\n      return tenmailWangtz.getEmails(email);\n    case '10minute-one':\n      if (!token) throw new Error('internal error: token missing for 10minute-one');\n      return tenminuteOne.getEmails(email, token);\n    case 'linshi-email':\n      if (!token) throw new Error('internal error: token missing for linshi-email');\n      return linshiEmail.getEmails(email, token);\n    case 'linshiyou':\n      if (!token) throw new Error('internal error: token missing for linshiyou');\n      return linshiyou.getEmails(token, email);\n    case 'tempmail-lol':\n      if (!token) throw new Error('internal error: token missing for tempmail-lol');\n      return tempmailLol.getEmails(token, email);\n    case 'chatgpt-org-uk':\n      if (!token) throw new Error('internal error: token missing for chatgpt-org-uk');\n      return chatgptOrgUk.getEmails(token, email);\n    case 'temp-mail-io':\n      return tempMailIO.getEmails(email);\n    case 'awamail':\n      if (!token) throw new Error('internal error: token missing for awamail');\n      return awamail.getEmails(token, email);\n    case 'temporary-email-org':\n      if (!token) throw new Error('internal error: token missing for temporary-email-org');\n      return temporaryEmailOrg.getEmails(email, token);\n    case 'mail-tm':\n      if (!token) throw new Error('internal error: token missing for mail-tm');\n      return mailTm.getEmails(token, email);\n    case 'mail-cx':\n      if (!token) throw new Error('internal error: token missing for mail-cx');\n      return mailCx.getEmails(token, email);\n    case 'dropmail':\n      if (!token) throw new Error('internal error: token missing for dropmail');\n      return dropmail.getEmails(token, email);\n    case 'guerrillamail':\n      if (!token) throw new Error('internal error: token missing for guerrillamail');\n      return guerrillamail.getEmails(token, email);\n    case 'maildrop':\n      if (!token) throw new Error('internal error: token missing for maildrop');\n      return maildropProvider.getEmails(token, email);\n    case 'smail-pw':\n      if (!token) throw new Error('internal error: token missing for smail-pw');\n      return smailPw.getEmails(token, email);\n    case 'boomlify':\n      return boomlify.getEmails(email);\n    case 'mffac':\n      return mffac.getEmails(email, token);\n    case 'minmail':\n      if (!token) throw new Error('internal error: token missing for minmail');\n      return minmail.getEmails(email, token);\n    case 'vip-215':\n      if (!token) throw new Error('internal error: token missing for vip-215');\n      return vip215.getEmails(token, email);\n    case 'anonbox':\n      if (!token) throw new Error('internal error: token missing for anonbox');\n      return anonbox.getEmails(token, email);\n    case 'fake-legal':\n      return fakeLegal.getEmails(email);\n    case 'moakt':\n      if (!token) throw new Error('internal error: token missing for moakt');\n      return moakt.getEmails(email, token);\n    default:\n      throw new Error(`Unknown channel: ${channel}`);\n  }\n}\n\n/**\n * 临时邮箱客户端\n * 封装了邮箱创建和邮件获取的完整流程，自动管理邮箱信息和认证令牌\n *\n * @example\n * ```ts\n * const client = new TempEmailClient();\n * const emailInfo = await client.generate({ channel: 'mail-tm' });\n * console.log('邮箱:', emailInfo.email);\n *\n * // 轮询获取邮件\n * const result = await client.getEmails();\n * if (result.success) {\n *   console.log('邮件数:', result.emails.length);\n * }\n * ```\n */\nexport class TempEmailClient {\n  private emailInfo: EmailInfo | null = null;\n\n  /**\n   * 创建临时邮箱并缓存邮箱信息\n   * 后续调用 getEmails() 时自动使用此邮箱的渠道、地址和令牌\n   * 所有渠道均不可用时返回 null\n   */\n  async generate(options: GenerateEmailOptions = {}): Promise<EmailInfo | null> {\n    this.emailInfo = await generateEmail(options);\n    return this.emailInfo;\n  }\n\n  /**\n   * 获取当前邮箱的邮件列表\n   * 必须先调用 generate() 创建邮箱\n   *\n   * @throws 未调用 generate() 时抛出异常\n   */\n  async getEmails(options?: GetEmailsOptions): Promise<GetEmailsResult> {\n    if (!this.emailInfo) {\n      reportTelemetry('get_emails', '', false, 0, 0, 'No email generated. Call generate() first.');\n      throw new Error('No email generated. Call generate() first.');\n    }\n\n    return getEmails(this.emailInfo, options);\n  }\n\n  /**\n   * 获取当前缓存的邮箱信息\n   * 未调用 generate() 时返回 null\n   */\n  getEmailInfo(): EmailInfo | null {\n    return this.emailInfo;\n  }\n}\n\nexport default {\n  listChannels,\n  getChannelInfo,\n  generateEmail,\n  getEmails,\n  TempEmailClient,\n  setConfig,\n  getConfig,\n};\n"]}