From 988247315df20436b4e9317a62c3ffc9b12fb908 Mon Sep 17 00:00:00 2001 From: Xiphe Date: Mon, 15 Jan 2024 18:53:11 +0100 Subject: [PATCH] feat: internally handle rate-limit fix https://github.com/cemalgnlts/Mailjs/issues/15 --- src/index.ts | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/src/index.ts b/src/index.ts index 52a4db1..8368458 100644 --- a/src/index.ts +++ b/src/index.ts @@ -10,11 +10,13 @@ class Mailjs { private token: string; id: string; address: string; + rateLimitRetries: number; - constructor() { + constructor({ rateLimitRetries }: { rateLimitRetries?: number } = {}) { this.baseUrl = "https://api.mail.tm"; this.baseMercure = "https://mercure.mail.tm/.well-known/mercure"; this.listener = null; + this.rateLimitRetries = rateLimitRetries || 3; this.events = {}; this.token = ""; this.id = ""; @@ -235,7 +237,8 @@ class Mailjs { async _send( path: string, method: type.Methods = "GET", - body?: object + body?: object, + retry: number = 0 ): type.PromiseResult { const options: type.IRequestObject = { method, @@ -252,6 +255,12 @@ class Mailjs { } const res: Response = await fetch(this.baseUrl + path, options); + + if (res.status === 429 && retry < this.rateLimitRetries) { + await new Promise((resolve) => setTimeout(resolve, 1000)); + return this._send(path, method, body, retry + 1); + } + let data: any; const contentType = res.headers.get("content-type");