@gaias/basenode 1.7.2 → 1.7.3

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.
@@ -5,6 +5,7 @@ import { InputMedia } from './InputMedia';
5
5
  export declare class TelegramClient {
6
6
  private readonly logger;
7
7
  private readonly bots;
8
+ private readonly messageQueue;
8
9
  private constructor();
9
10
  static create(config: TelegramConfig): Promise<TelegramClient>;
10
11
  private initialize;
@@ -13,7 +14,14 @@ export declare class TelegramClient {
13
14
  getBot(botName: string): Bot<Context> | undefined;
14
15
  getBotNames(): string[];
15
16
  isBotStarted(botName: string): boolean;
16
- sendMessage(botName: string, message: string, options?: Record<string, any>): Promise<Message.TextMessage | undefined>;
17
- sendMediaGroup(botName: string, medias: ReadonlyArray<InputMedia>, options?: Record<string, any>): Promise<Array<Message.PhotoMessage | Message.AudioMessage | Message.DocumentMessage | Message.VideoMessage> | undefined>;
17
+ sendMessage(botName: string, message: string, options?: Record<string, any>, priority?: number): Promise<Message.TextMessage | undefined>;
18
+ sendMediaGroup(botName: string, medias: ReadonlyArray<InputMedia>, options?: Record<string, any>, priority?: number): Promise<Array<Message.PhotoMessage | Message.AudioMessage | Message.DocumentMessage | Message.VideoMessage> | undefined>;
19
+ getQueueStatus(botName: string): {
20
+ queueLength: number;
21
+ isProcessing: boolean;
22
+ retryAfterMs: number;
23
+ };
24
+ clearQueue(botName: string): void;
25
+ clearAllQueues(): void;
18
26
  }
19
27
  //# sourceMappingURL=TelegramClient.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TelegramClient.d.ts","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramClient.ts"],"names":[],"mappings":"AAmDA,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,cAAc,EAAqB,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AA+B1C,qBAAa,cAAc;IAEzB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsC;IAE7D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAuC;IAU5D,OAAO;WAkBM,MAAM,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;YAmBtD,UAAU;IA6ClB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA8CtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IA0C3B,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,SAAS;IAoBjD,WAAW,IAAI,MAAM,EAAE;IAsBvB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAsBhC,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAgD1H,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC,eAAe,GAAG,OAAO,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC;CAqCtO"}
1
+ {"version":3,"file":"TelegramClient.d.ts","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramClient.ts"],"names":[],"mappings":"AAmDA,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,cAAc,EAAqB,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAgC1C,qBAAa,cAAc;IAEzB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsC;IAE7D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAuC;IAE5D,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA8B;IAU3D,OAAO;WAkBM,MAAM,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;YAmBtD,UAAU;IA6ClB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA8CtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IA8C3B,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,SAAS;IAoBjD,WAAW,IAAI,MAAM,EAAE;IAsBvB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IA2BhC,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,EAAE,QAAQ,GAAE,MAAU,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IA2DhJ,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,EAAE,QAAQ,GAAE,MAAU,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC,eAAe,GAAG,OAAO,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC;IAgE3P,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,OAAO,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE;IAmBrG,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAiBjC,cAAc,IAAI,IAAI;CAGvB"}
@@ -3,10 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.TelegramClient = void 0;
4
4
  const grammy_1 = require("grammy");
5
5
  const logger_1 = require("../logger");
6
+ const TelegramMessageQueue_1 = require("./TelegramMessageQueue");
6
7
  class TelegramClient {
7
8
  constructor() {
8
9
  this.logger = logger_1.Logger.getLogger('TelegramClient');
9
10
  this.bots = new Map();
11
+ this.messageQueue = new TelegramMessageQueue_1.TelegramMessageQueue();
10
12
  }
11
13
  static async create(config) {
12
14
  const client = new TelegramClient();
@@ -78,6 +80,7 @@ class TelegramClient {
78
80
  }
79
81
  });
80
82
  await Promise.all(stopPromises);
83
+ this.messageQueue.clearAllQueues();
81
84
  this.logger.info(`✅ All Telegram bots stopped successfully`);
82
85
  }
83
86
  getBot(botName) {
@@ -89,55 +92,70 @@ class TelegramClient {
89
92
  isBotStarted(botName) {
90
93
  return this.bots.get(botName)?.started || false;
91
94
  }
92
- async sendMessage(botName, message, options = {}) {
93
- const startTime = performance.now();
95
+ async sendMessage(botName, message, options = {}, priority = 0) {
94
96
  const instance = this.bots.get(botName);
95
97
  if (!instance) {
96
98
  this.logger.error(`Bot not found: ${botName}`);
97
- return {};
99
+ return undefined;
98
100
  }
99
101
  if (!instance.started) {
100
102
  this.logger.error(`Bot not started: ${botName}`);
101
- return {};
102
- }
103
- try {
104
- const result = await instance.bot.api.sendMessage(instance.config.chatId, message, options);
105
- const duration = (performance.now() - startTime).toFixed(2);
106
- this.logger.info(`✅ [${botName}] Message sent to ${instance.config.chatId} in ${duration} ms`);
107
- return result;
108
- }
109
- catch (error) {
110
- this.logger.error(`🛑 [${botName}] Failed to send message:`, error);
103
+ return undefined;
111
104
  }
105
+ return this.messageQueue.enqueue(botName, async () => {
106
+ const startTime = performance.now();
107
+ try {
108
+ const result = await instance.bot.api.sendMessage(instance.config.chatId, message, options);
109
+ const duration = (performance.now() - startTime).toFixed(2);
110
+ this.logger.info(`✅ [${botName}] Message sent to ${instance.config.chatId} in ${duration} ms`);
111
+ return result;
112
+ }
113
+ catch (error) {
114
+ this.logger.error(`🛑 [${botName}] Failed to send message:`, error);
115
+ throw error;
116
+ }
117
+ }, priority);
112
118
  }
113
- async sendMediaGroup(botName, medias, options = {}) {
114
- const startTime = performance.now();
119
+ async sendMediaGroup(botName, medias, options = {}, priority = 0) {
115
120
  const instance = this.bots.get(botName);
116
121
  if (!instance) {
117
122
  this.logger.error(`Bot not found: ${botName}`);
118
- return {};
123
+ return undefined;
119
124
  }
120
125
  if (!instance.started) {
121
126
  this.logger.error(`Bot not started: ${botName}`);
122
- return {};
127
+ return undefined;
123
128
  }
124
129
  if (!medias || medias.length === 0) {
125
130
  this.logger.error(`Media array is empty: ${botName}`);
126
- return {};
131
+ return undefined;
127
132
  }
128
133
  if (medias.length > 10) {
129
134
  this.logger.warn(`Media group size ${medias.length} exceeds Telegram limit of 10, only first 10 items will be sent`);
130
135
  medias = medias.slice(0, 10);
131
136
  }
132
- try {
133
- const result = await instance.bot.api.sendMediaGroup(instance.config.chatId, medias, options);
134
- const duration = (performance.now() - startTime).toFixed(2);
135
- this.logger.info(`✅ [${botName}] Media group sent to ${instance.config.chatId} (${medias.length} items) in ${duration} ms`);
136
- return result;
137
- }
138
- catch (error) {
139
- this.logger.error(`🛑 [${botName}] Failed to send media group:`, error);
140
- }
137
+ return this.messageQueue.enqueue(botName, async () => {
138
+ const startTime = performance.now();
139
+ try {
140
+ const result = await instance.bot.api.sendMediaGroup(instance.config.chatId, medias, options);
141
+ const duration = (performance.now() - startTime).toFixed(2);
142
+ this.logger.info(`✅ [${botName}] Media group sent to ${instance.config.chatId} (${medias.length} items) in ${duration} ms`);
143
+ return result;
144
+ }
145
+ catch (error) {
146
+ this.logger.error(`🛑 [${botName}] Failed to send media group:`, error);
147
+ throw error;
148
+ }
149
+ }, priority);
150
+ }
151
+ getQueueStatus(botName) {
152
+ return this.messageQueue.getQueueStatus(botName);
153
+ }
154
+ clearQueue(botName) {
155
+ this.messageQueue.clearQueue(botName);
156
+ }
157
+ clearAllQueues() {
158
+ this.messageQueue.clearAllQueues();
141
159
  }
142
160
  }
143
161
  exports.TelegramClient = TelegramClient;
@@ -1 +1 @@
1
- {"version":3,"file":"TelegramClient.js","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramClient.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TelegramClient.js","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramClient.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ export declare class TelegramMessageQueue {
2
+ private readonly logger;
3
+ private readonly queues;
4
+ private readonly processing;
5
+ private readonly lastSendTime;
6
+ private readonly retryAfter;
7
+ private readonly config;
8
+ enqueue<T>(botName: string, execute: () => Promise<T>, priority?: number): Promise<T>;
9
+ private processQueue;
10
+ private enforceRateLimit;
11
+ private handle429Error;
12
+ private handleRetryableError;
13
+ private is429Error;
14
+ private isRetryableError;
15
+ private extractRetryAfter;
16
+ private sleep;
17
+ getQueueStatus(botName: string): {
18
+ queueLength: number;
19
+ isProcessing: boolean;
20
+ retryAfterMs: number;
21
+ };
22
+ clearQueue(botName: string): void;
23
+ clearAllQueues(): void;
24
+ }
25
+ //# sourceMappingURL=TelegramMessageQueue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TelegramMessageQueue.d.ts","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramMessageQueue.ts"],"names":[],"mappings":"AA0DA,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4C;IACnE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2C;IAClE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAmC;IAC9D,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAC/D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAkC;IAE7D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAKrB;IAWI,OAAO,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EAAE,QAAQ,GAAE,MAAU,GAAG,OAAO,CAAC,CAAC,CAAC;YAuChF,YAAY;YAsEZ,gBAAgB;YAuBhB,cAAc;YA8Bd,oBAAoB;IA6BlC,OAAO,CAAC,UAAU;IAgBlB,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,iBAAiB;IA0BzB,OAAO,CAAC,KAAK;IAWb,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,OAAO,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE;IAmBrG,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAcjC,cAAc,IAAI,IAAI;CAWvB"}
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TelegramMessageQueue = void 0;
4
+ const logger_1 = require("../logger");
5
+ class TelegramMessageQueue {
6
+ constructor() {
7
+ this.logger = logger_1.Logger.getLogger('TelegramMessageQueue');
8
+ this.queues = new Map();
9
+ this.processing = new Map();
10
+ this.lastSendTime = new Map();
11
+ this.retryAfter = new Map();
12
+ this.config = {
13
+ maxMessagesPerSecond: 25,
14
+ maxRetries: 5,
15
+ baseRetryDelay: 1000,
16
+ maxRetryDelay: 60000,
17
+ };
18
+ }
19
+ async enqueue(botName, execute, priority = 0) {
20
+ return new Promise((resolve, reject) => {
21
+ const message = {
22
+ execute,
23
+ resolve,
24
+ reject,
25
+ retryCount: 0,
26
+ botName,
27
+ priority,
28
+ };
29
+ let queue = this.queues.get(botName);
30
+ if (!queue) {
31
+ queue = [];
32
+ this.queues.set(botName, queue);
33
+ }
34
+ const insertIndex = queue.findIndex((m) => m.priority > priority);
35
+ if (insertIndex === -1) {
36
+ queue.push(message);
37
+ }
38
+ else {
39
+ queue.splice(insertIndex, 0, message);
40
+ }
41
+ this.logger.debug(`Message queued for ${botName} (queue size: ${queue.length}, priority: ${priority})`);
42
+ this.processQueue(botName);
43
+ });
44
+ }
45
+ async processQueue(botName) {
46
+ if (this.processing.get(botName)) {
47
+ return;
48
+ }
49
+ const queue = this.queues.get(botName);
50
+ if (!queue || queue.length === 0) {
51
+ return;
52
+ }
53
+ this.processing.set(botName, true);
54
+ try {
55
+ while (queue.length > 0) {
56
+ const retryAfterTime = this.retryAfter.get(botName);
57
+ if (retryAfterTime && Date.now() < retryAfterTime) {
58
+ const waitTime = retryAfterTime - Date.now();
59
+ this.logger.warn(`[${botName}] Waiting ${waitTime}ms due to rate limit (retry_after)`);
60
+ await this.sleep(waitTime);
61
+ this.retryAfter.delete(botName);
62
+ }
63
+ await this.enforceRateLimit(botName);
64
+ const message = queue[0];
65
+ try {
66
+ const result = await message.execute();
67
+ queue.shift();
68
+ message.resolve(result);
69
+ this.logger.debug(`[${botName}] Message sent successfully (${queue.length} remaining in queue)`);
70
+ }
71
+ catch (error) {
72
+ if (this.is429Error(error)) {
73
+ await this.handle429Error(botName, message, error, queue);
74
+ }
75
+ else if (this.isRetryableError(error)) {
76
+ await this.handleRetryableError(botName, message, error, queue);
77
+ }
78
+ else {
79
+ queue.shift();
80
+ message.reject(error);
81
+ this.logger.error(`[${botName}] Non-retryable error, message rejected:`, error);
82
+ }
83
+ }
84
+ }
85
+ }
86
+ finally {
87
+ this.processing.set(botName, false);
88
+ if (queue.length > 0) {
89
+ setTimeout(() => this.processQueue(botName), 100);
90
+ }
91
+ }
92
+ }
93
+ async enforceRateLimit(botName) {
94
+ const lastSend = this.lastSendTime.get(botName) || 0;
95
+ const minInterval = 1000 / this.config.maxMessagesPerSecond;
96
+ const timeSinceLastSend = Date.now() - lastSend;
97
+ if (timeSinceLastSend < minInterval) {
98
+ const waitTime = minInterval - timeSinceLastSend;
99
+ this.logger.debug(`[${botName}] Rate limiting: waiting ${waitTime.toFixed(0)}ms`);
100
+ await this.sleep(waitTime);
101
+ }
102
+ this.lastSendTime.set(botName, Date.now());
103
+ }
104
+ async handle429Error(botName, message, error, queue) {
105
+ const retryAfter = this.extractRetryAfter(error);
106
+ const retryAfterMs = (retryAfter || 5) * 1000;
107
+ this.logger.warn(`[${botName}] Rate limit hit (429), retry after ${retryAfter}s`);
108
+ this.retryAfter.set(botName, Date.now() + retryAfterMs);
109
+ message.retryCount++;
110
+ if (message.retryCount > this.config.maxRetries) {
111
+ queue.shift();
112
+ message.reject(new Error(`Max retries (${this.config.maxRetries}) exceeded for 429 error`));
113
+ this.logger.error(`[${botName}] Max retries exceeded for 429 error`);
114
+ }
115
+ }
116
+ async handleRetryableError(botName, message, error, queue) {
117
+ message.retryCount++;
118
+ if (message.retryCount > this.config.maxRetries) {
119
+ queue.shift();
120
+ message.reject(error);
121
+ this.logger.error(`[${botName}] Max retries (${this.config.maxRetries}) exceeded:`, error);
122
+ return;
123
+ }
124
+ const delay = Math.min(this.config.baseRetryDelay * Math.pow(2, message.retryCount - 1), this.config.maxRetryDelay);
125
+ this.logger.warn(`[${botName}] Retryable error, retry ${message.retryCount}/${this.config.maxRetries} after ${delay}ms:`, error);
126
+ await this.sleep(delay);
127
+ }
128
+ is429Error(error) {
129
+ return (error?.error_code === 429 ||
130
+ error?.code === 429 ||
131
+ error?.message?.includes('429') ||
132
+ error?.message?.includes('Too Many Requests'));
133
+ }
134
+ isRetryableError(error) {
135
+ const retryableMessages = ['ECONNRESET', 'ETIMEDOUT', 'ENOTFOUND', 'network', 'timeout'];
136
+ const errorMessage = error?.message?.toLowerCase() || '';
137
+ return retryableMessages.some((msg) => errorMessage.includes(msg.toLowerCase()));
138
+ }
139
+ extractRetryAfter(error) {
140
+ if (error?.parameters?.retry_after) {
141
+ return error.parameters.retry_after;
142
+ }
143
+ if (error?.retry_after) {
144
+ return error.retry_after;
145
+ }
146
+ const match = error?.description?.match(/retry after (\d+)/i);
147
+ if (match) {
148
+ return parseInt(match[1], 10);
149
+ }
150
+ return undefined;
151
+ }
152
+ sleep(ms) {
153
+ return new Promise((resolve) => setTimeout(resolve, ms));
154
+ }
155
+ getQueueStatus(botName) {
156
+ const queue = this.queues.get(botName) || [];
157
+ const isProcessing = this.processing.get(botName) || false;
158
+ const retryAfterTime = this.retryAfter.get(botName) || 0;
159
+ const retryAfterMs = Math.max(0, retryAfterTime - Date.now());
160
+ return {
161
+ queueLength: queue.length,
162
+ isProcessing,
163
+ retryAfterMs,
164
+ };
165
+ }
166
+ clearQueue(botName) {
167
+ const queue = this.queues.get(botName);
168
+ if (queue) {
169
+ queue.forEach((msg) => msg.reject(new Error('Queue cleared')));
170
+ queue.length = 0;
171
+ this.logger.info(`[${botName}] Queue cleared`);
172
+ }
173
+ }
174
+ clearAllQueues() {
175
+ this.queues.forEach((queue, botName) => {
176
+ queue.forEach((msg) => msg.reject(new Error('All queues cleared')));
177
+ queue.length = 0;
178
+ });
179
+ this.queues.clear();
180
+ this.processing.clear();
181
+ this.lastSendTime.clear();
182
+ this.retryAfter.clear();
183
+ this.logger.info('All queues cleared');
184
+ }
185
+ }
186
+ exports.TelegramMessageQueue = TelegramMessageQueue;
187
+ //# sourceMappingURL=TelegramMessageQueue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TelegramMessageQueue.js","sourceRoot":"","sources":["../../../../src/libs/telegram/TelegramMessageQueue.ts"],"names":[],"mappings":"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"}
@@ -11,5 +11,6 @@ export * from './TelegramClient';
11
11
  export * from './TelegramConfig';
12
12
  export * from './TelegramLoader';
13
13
  export * from './TelegramManager';
14
+ export * from './TelegramMessageQueue';
14
15
  export * from './TelegramSender';
15
16
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/libs/telegram/index.ts"],"names":[],"mappings":"AAEA,cAAc,uBAAuB,CAAC;AACtC,cAAc,cAAc,CAAC;AAC7B,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/libs/telegram/index.ts"],"names":[],"mappings":"AAEA,cAAc,uBAAuB,CAAC;AACtC,cAAc,cAAc,CAAC;AAC7B,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,kBAAkB,CAAC"}
@@ -27,5 +27,6 @@ __exportStar(require("./TelegramClient"), exports);
27
27
  __exportStar(require("./TelegramConfig"), exports);
28
28
  __exportStar(require("./TelegramLoader"), exports);
29
29
  __exportStar(require("./TelegramManager"), exports);
30
+ __exportStar(require("./TelegramMessageQueue"), exports);
30
31
  __exportStar(require("./TelegramSender"), exports);
31
32
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/libs/telegram/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAEA,wDAAsC;AACtC,+CAA6B;AAC7B,uDAAqC;AACrC,0DAAwC;AACxC,8CAA4B;AAC5B,mDAAiC;AACjC,oDAAkC;AAClC,0DAAwC;AACxC,8CAA4B;AAC5B,mDAAiC;AACjC,mDAAiC;AACjC,mDAAiC;AACjC,oDAAkC;AAClC,mDAAiC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/libs/telegram/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAEA,wDAAsC;AACtC,+CAA6B;AAC7B,uDAAqC;AACrC,0DAAwC;AACxC,8CAA4B;AAC5B,mDAAiC;AACjC,oDAAkC;AAClC,0DAAwC;AACxC,8CAA4B;AAC5B,mDAAiC;AACjC,mDAAiC;AACjC,mDAAiC;AACjC,oDAAkC;AAClC,yDAAuC;AACvC,mDAAiC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gaias/basenode",
3
- "version": "1.7.2",
3
+ "version": "1.7.3",
4
4
  "buildNumber": 251025471,
5
5
  "description": "API development framework for NodeJs",
6
6
  "author": "FOT",