whatsauto.js 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/README.md +37 -0
  2. package/dist/Defaults/index.d.ts +32 -0
  3. package/dist/Defaults/index.d.ts.map +1 -0
  4. package/dist/Defaults/index.js +37 -0
  5. package/dist/Error/index.d.ts +9 -0
  6. package/dist/Error/index.d.ts.map +1 -0
  7. package/dist/Error/index.js +25 -0
  8. package/dist/Logger/index.d.ts +8 -0
  9. package/dist/Logger/index.d.ts.map +1 -0
  10. package/dist/Logger/index.js +17 -0
  11. package/dist/Messaging/index.d.ts +33 -0
  12. package/dist/Messaging/index.d.ts.map +1 -0
  13. package/dist/Messaging/index.js +245 -0
  14. package/dist/Socket/index.d.ts +29 -0
  15. package/dist/Socket/index.d.ts.map +1 -0
  16. package/dist/Socket/index.js +374 -0
  17. package/dist/Types/index.d.ts +89 -0
  18. package/dist/Types/index.d.ts.map +1 -0
  19. package/dist/Types/index.js +2 -0
  20. package/dist/Utils/create-delay.d.ts +2 -0
  21. package/dist/Utils/create-delay.d.ts.map +1 -0
  22. package/dist/Utils/create-delay.js +18 -0
  23. package/dist/Utils/error.d.ts +4 -0
  24. package/dist/Utils/error.d.ts.map +1 -0
  25. package/dist/Utils/error.js +8 -0
  26. package/dist/Utils/helper.d.ts +22 -0
  27. package/dist/Utils/helper.d.ts.map +1 -0
  28. package/dist/Utils/helper.js +129 -0
  29. package/dist/Utils/index.d.ts +3 -0
  30. package/dist/Utils/index.d.ts.map +1 -0
  31. package/dist/Utils/index.js +18 -0
  32. package/dist/Utils/is-exist.d.ts +3 -0
  33. package/dist/Utils/is-exist.d.ts.map +1 -0
  34. package/dist/Utils/is-exist.js +38 -0
  35. package/dist/Utils/message-status.d.ts +4 -0
  36. package/dist/Utils/message-status.d.ts.map +1 -0
  37. package/dist/Utils/message-status.js +18 -0
  38. package/dist/Utils/phone-to-jid.d.ts +5 -0
  39. package/dist/Utils/phone-to-jid.d.ts.map +1 -0
  40. package/dist/Utils/phone-to-jid.js +30 -0
  41. package/dist/Utils/save-media.d.ts +5 -0
  42. package/dist/Utils/save-media.d.ts.map +1 -0
  43. package/dist/Utils/save-media.js +49 -0
  44. package/dist/Utils/set-credentials-dir.d.ts +3 -0
  45. package/dist/Utils/set-credentials-dir.d.ts.map +1 -0
  46. package/dist/Utils/set-credentials-dir.js +14 -0
  47. package/dist/Utils/tools.d.ts +12 -0
  48. package/dist/Utils/tools.d.ts.map +1 -0
  49. package/dist/Utils/tools.js +34 -0
  50. package/dist/WhatsApp/AutoWA.d.ts +38 -0
  51. package/dist/WhatsApp/AutoWA.d.ts.map +1 -0
  52. package/dist/WhatsApp/AutoWA.js +545 -0
  53. package/dist/WhatsApp/AutoWAEvent.d.ts +28 -0
  54. package/dist/WhatsApp/AutoWAEvent.d.ts.map +1 -0
  55. package/dist/WhatsApp/AutoWAEvent.js +66 -0
  56. package/dist/WhatsApp/AutoWAManager.d.ts +12 -0
  57. package/dist/WhatsApp/AutoWAManager.d.ts.map +1 -0
  58. package/dist/WhatsApp/AutoWAManager.js +68 -0
  59. package/dist/WhatsApp/action.d.ts +1 -0
  60. package/dist/WhatsApp/action.d.ts.map +1 -0
  61. package/dist/WhatsApp/action.js +272 -0
  62. package/dist/WhatsApp/auto-wa-event.d.ts +26 -0
  63. package/dist/WhatsApp/auto-wa-event.d.ts.map +1 -0
  64. package/dist/WhatsApp/auto-wa-event.js +60 -0
  65. package/dist/WhatsApp/auto-wa-manager.d.ts +12 -0
  66. package/dist/WhatsApp/auto-wa-manager.d.ts.map +1 -0
  67. package/dist/WhatsApp/auto-wa-manager.js +68 -0
  68. package/dist/WhatsApp/auto-wa.d.ts +36 -0
  69. package/dist/WhatsApp/auto-wa.d.ts.map +1 -0
  70. package/dist/WhatsApp/auto-wa.js +497 -0
  71. package/dist/WhatsApp/event.d.ts +24 -0
  72. package/dist/WhatsApp/event.d.ts.map +1 -0
  73. package/dist/WhatsApp/event.js +54 -0
  74. package/dist/WhatsApp/index.d.ts +3 -0
  75. package/dist/WhatsApp/index.d.ts.map +1 -0
  76. package/dist/WhatsApp/index.js +18 -0
  77. package/dist/WhatsApp/multi-auto-wa.d.ts +14 -0
  78. package/dist/WhatsApp/multi-auto-wa.d.ts.map +1 -0
  79. package/dist/WhatsApp/multi-auto-wa.js +86 -0
  80. package/dist/WhatsApp/setup.d.ts +1 -0
  81. package/dist/WhatsApp/setup.d.ts.map +1 -0
  82. package/dist/WhatsApp/setup.js +221 -0
  83. package/dist/WhatsApp/undefined.jpeg +0 -0
  84. package/dist/index.d.ts +5 -0
  85. package/dist/index.d.ts.map +1 -0
  86. package/dist/index.js +20 -0
  87. package/package.json +38 -0
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.MultiAutoWA = void 0;
16
+ const path_1 = __importDefault(require("path"));
17
+ const Defaults_1 = require("../Defaults");
18
+ const auto_wa_1 = require("./auto-wa");
19
+ const fs_1 = __importDefault(require("fs"));
20
+ class MultiAutoWA {
21
+ saveSessions(autoWAs) {
22
+ for (const autoWA of autoWAs) {
23
+ this.saveSession(autoWA);
24
+ }
25
+ }
26
+ saveSession(autoWA) {
27
+ this.sessions.set(autoWA.sessionId, autoWA);
28
+ }
29
+ shouldLoadSession(sessionId) {
30
+ if (fs_1.default.existsSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME)) &&
31
+ fs_1.default.existsSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME, sessionId + Defaults_1.CREDENTIALS.PREFIX)) &&
32
+ fs_1.default.readdirSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME, sessionId + Defaults_1.CREDENTIALS.PREFIX)).length &&
33
+ !this.getSession(sessionId)) {
34
+ return true;
35
+ }
36
+ return false;
37
+ }
38
+ isSessionExistAndRunning(sessionId) {
39
+ if (fs_1.default.existsSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME)) &&
40
+ fs_1.default.existsSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME, sessionId + Defaults_1.CREDENTIALS.PREFIX)) &&
41
+ fs_1.default.readdirSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME, sessionId + Defaults_1.CREDENTIALS.PREFIX)).length &&
42
+ this.getSession(sessionId)) {
43
+ return true;
44
+ }
45
+ return false;
46
+ }
47
+ startSessions(options) {
48
+ if (!fs_1.default.existsSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME))) {
49
+ fs_1.default.mkdirSync(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME));
50
+ }
51
+ fs_1.default.readdir(path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME), (err, dirs) => __awaiter(this, void 0, void 0, function* () {
52
+ if (err) {
53
+ throw err;
54
+ }
55
+ for (const dir of dirs) {
56
+ const sessionId = dir.split("_")[0];
57
+ if (!this.shouldLoadSession(sessionId))
58
+ continue;
59
+ const autoWA = new auto_wa_1.AutoWA(sessionId, options, this);
60
+ yield autoWA.initialize();
61
+ }
62
+ }));
63
+ }
64
+ deleteSession(sessionId) {
65
+ return __awaiter(this, void 0, void 0, function* () {
66
+ const session = this.getSession(sessionId);
67
+ try {
68
+ yield (session === null || session === void 0 ? void 0 : session.logout());
69
+ }
70
+ catch (error) { }
71
+ session === null || session === void 0 ? void 0 : session.end();
72
+ this.sessions.delete(sessionId);
73
+ const dir = path_1.default.resolve(Defaults_1.CREDENTIALS.DIR_NAME, sessionId + Defaults_1.CREDENTIALS.PREFIX);
74
+ if (fs_1.default.existsSync(dir)) {
75
+ fs_1.default.rmSync(dir, { force: true, recursive: true });
76
+ }
77
+ });
78
+ }
79
+ getSessions() {
80
+ return Array.from(this.sessions.keys());
81
+ }
82
+ getSession(sessionId) {
83
+ return this.sessions.get(sessionId);
84
+ }
85
+ }
86
+ exports.MultiAutoWA = MultiAutoWA;
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=setup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../src/WhatsApp/setup.ts"],"names":[],"mappings":""}
@@ -0,0 +1,221 @@
1
+ "use strict";
2
+ // import makeWASocket, {
3
+ // Browsers,
4
+ // DisconnectReason,
5
+ // downloadMediaMessage,
6
+ // fetchLatestBaileysVersion,
7
+ // useMultiFileAuthState,
8
+ // WASocket,
9
+ // } from "@whiskeysockets/baileys";
10
+ // import path from "path";
11
+ // import { Boom } from "@hapi/boom";
12
+ // import fs from "fs";
13
+ // import type {
14
+ // LoadSessionsParams,
15
+ // MessageReceived,
16
+ // MessageUpdated,
17
+ // StartWhatsAppParams,
18
+ // } from "../Types";
19
+ // import { CALLBACK_KEY, CREDENTIALS, Messages } from "../Defaults";
20
+ // import { saveDocumentHandler, saveImageHandler, saveVideoHandler } from "../Utils/save-media";
21
+ // import { ValidationError, WhatsAppError } from "../Error";
22
+ // import { getMediaMimeType, parseMessageStatusCodeToReadable } from "../Utils/message";
23
+ // import Event from "./event";
24
+ // const sessions: Map<string, WASocket> = new Map();
25
+ // const callback: Map<string, Function> = new Map();
26
+ // const retryCount: Map<string, number> = new Map();
27
+ // const P = require("pino")({
28
+ // level: "silent",
29
+ // });
30
+ // const setupWASocket = async (
31
+ // sessionId: string,
32
+ // options: StartWhatsAppParams,
33
+ // sock: WASocket,
34
+ // startSocket: Function,
35
+ // saveCreds: Function
36
+ // ): Promise<WASocket> => {
37
+ // try {
38
+ // sock.ev.on("connection.update", async (update) => {
39
+ // const { connection, lastDisconnect, qr } = update;
40
+ // if (options.printQR && qr) {
41
+ // callback.get(CALLBACK_KEY.ON_QR)?.({ sessionId, qr });
42
+ // options.onQRUpdated?.(qr);
43
+ // }
44
+ // if (connection == "connecting") {
45
+ // callback.get(CALLBACK_KEY.ON_CONNECTING)?.(sessionId);
46
+ // options.onConnecting?.();
47
+ // }
48
+ // if (connection === "close") {
49
+ // const code = (lastDisconnect?.error as Boom)?.output?.statusCode;
50
+ // let retryAttempt = retryCount.get(sessionId) ?? 0;
51
+ // let shouldRetry;
52
+ // if (code != DisconnectReason.loggedOut && retryAttempt < 10) {
53
+ // shouldRetry = true;
54
+ // }
55
+ // if (shouldRetry) {
56
+ // retryAttempt++;
57
+ // retryCount.set(sessionId, retryAttempt);
58
+ // startSocket();
59
+ // } else {
60
+ // retryCount.delete(sessionId);
61
+ // deleteSession(sessionId);
62
+ // callback.get(CALLBACK_KEY.ON_DISCONNECTED)?.(sessionId);
63
+ // options.onDisconnected?.();
64
+ // }
65
+ // }
66
+ // if (connection == "open") {
67
+ // retryCount.delete(sessionId);
68
+ // callback.get(CALLBACK_KEY.ON_CONNECTED)?.(sessionId);
69
+ // options.onConnected?.();
70
+ // }
71
+ // });
72
+ // sock.ev.on("creds.update", async () => {
73
+ // await saveCreds();
74
+ // });
75
+ // sock.ev.on("messages.update", async (message) => {
76
+ // const msg = message[0];
77
+ // const data: MessageUpdated = {
78
+ // sessionId: sessionId,
79
+ // messageStatus: parseMessageStatusCodeToReadable(msg.update.status!),
80
+ // ...msg,
81
+ // };
82
+ // callback.get(CALLBACK_KEY.ON_MESSAGE_UPDATED)?.(data);
83
+ // options.onMessageUpdated?.(data);
84
+ // });
85
+ // sock.ev.on("messages.upsert", async (new_message) => {
86
+ // let msg = new_message.messages?.[0] as MessageReceived;
87
+ // const mimeType = getMediaMimeType(msg);
88
+ // const media = { mimeType, data: "" };
89
+ // if (mimeType !== "") {
90
+ // const mediaBuffer = await downloadMediaMessage(msg, "buffer", {});
91
+ // media.data = mediaBuffer.toString("base64");
92
+ // }
93
+ // msg.media = media;
94
+ // msg.sessionId = sessionId;
95
+ // msg.saveImage = (path) => saveImageHandler(msg, path);
96
+ // msg.saveVideo = (path) => saveVideoHandler(msg, path);
97
+ // msg.saveDocument = (path) => saveDocumentHandler(msg, path);
98
+ // callback.get(CALLBACK_KEY.ON_MESSAGE)?.({
99
+ // ...msg,
100
+ // });
101
+ // options.onMessage?.(msg);
102
+ // const from = msg.key.remoteJid || "";
103
+ // const isGroup = from.includes("@g.us");
104
+ // if (isGroup) {
105
+ // callback.get(CALLBACK_KEY.ON_GROUP_MESSAGE)?.({
106
+ // ...msg,
107
+ // });
108
+ // options.onGroupMessage?.(msg);
109
+ // } else {
110
+ // callback.get(CALLBACK_KEY.ON_PRIVATE_MESSAGE)?.({
111
+ // ...msg,
112
+ // });
113
+ // options.onPrivateMessage?.(msg);
114
+ // }
115
+ // if (!msg.key.fromMe) {
116
+ // callback.get(CALLBACK_KEY.ON_MESSAGE_RECEIVED)?.({
117
+ // ...msg,
118
+ // });
119
+ // options.onMessageReceived?.(msg);
120
+ // if (isGroup) {
121
+ // callback.get(CALLBACK_KEY.ON_GROUP_MESSAGE_RECEIVED)?.({
122
+ // ...msg,
123
+ // });
124
+ // options.onGroupMessageReceived?.(msg);
125
+ // } else {
126
+ // callback.get(CALLBACK_KEY.ON_PRIVATE_MESSAGE_RECEIVED)?.({
127
+ // ...msg,
128
+ // });
129
+ // options.onPrivateMessageReceived?.(msg);
130
+ // }
131
+ // }
132
+ // });
133
+ // return sock;
134
+ // } catch (error) {
135
+ // throw error as WhatsAppError;
136
+ // }
137
+ // };
138
+ // /**
139
+ // * Start WhatsApp session
140
+ // */
141
+ // export const startWhatsApp = async (
142
+ // sessionId = "mysession",
143
+ // options: StartWhatsAppParams = { printQR: true }
144
+ // ): Promise<WASocket> => {
145
+ // if (isSessionExistAndRunning(sessionId))
146
+ // throw new ValidationError(Messages.sessionAlreadyExist(sessionId));
147
+ // if (typeof options.phoneNumber == "string") {
148
+ // if (options.phoneNumber === "")
149
+ // throw new ValidationError(Messages.paremetersNotValid("phoneNumber"));
150
+ // options.printQR = false;
151
+ // }
152
+ // const { version } = await fetchLatestBaileysVersion();
153
+ // const startSocket = async () => {
154
+ // const { state, saveCreds } = await useMultiFileAuthState(
155
+ // path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX)
156
+ // );
157
+ // const sock: WASocket = makeWASocket({
158
+ // version,
159
+ // printQRInTerminal: options.printQR,
160
+ // auth: state,
161
+ // logger: P,
162
+ // markOnlineOnConnect: false,
163
+ // browser: Browsers.windows("Desktop"),
164
+ // });
165
+ // sessions.set(sessionId, { ...sock });
166
+ // return setupWASocket(sessionId, options, sock, startSocket, saveCreds);
167
+ // };
168
+ // return startSocket();
169
+ // };
170
+ // export const deleteSession = async (sessionId: string) => {
171
+ // const session = getSession(sessionId);
172
+ // try {
173
+ // await session?.logout();
174
+ // } catch (error) {}
175
+ // session?.end(undefined);
176
+ // sessions.delete(sessionId);
177
+ // const dir = path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX);
178
+ // if (fs.existsSync(dir)) {
179
+ // fs.rmSync(dir, { force: true, recursive: true });
180
+ // }
181
+ // };
182
+ // export const getAllSession = (): string[] => Array.from(sessions.keys());
183
+ // export const getSession = (key: string): WASocket | undefined => sessions.get(key) as WASocket;
184
+ // export const isSessionExistAndRunning = (sessionId: string): boolean => {
185
+ // if (
186
+ // fs.existsSync(path.resolve(CREDENTIALS.DIR_NAME)) &&
187
+ // fs.existsSync(path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX)) &&
188
+ // fs.readdirSync(path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX)).length &&
189
+ // getSession(sessionId)
190
+ // ) {
191
+ // return true;
192
+ // }
193
+ // return false;
194
+ // };
195
+ // const shouldLoadSession = (sessionId: string): boolean => {
196
+ // if (
197
+ // fs.existsSync(path.resolve(CREDENTIALS.DIR_NAME)) &&
198
+ // fs.existsSync(path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX)) &&
199
+ // fs.readdirSync(path.resolve(CREDENTIALS.DIR_NAME, sessionId + CREDENTIALS.PREFIX)).length &&
200
+ // !getSession(sessionId)
201
+ // ) {
202
+ // return true;
203
+ // }
204
+ // return false;
205
+ // };
206
+ // export const loadSessionsFromStorage = (options: LoadSessionsParams) => {
207
+ // if (!fs.existsSync(path.resolve(CREDENTIALS.DIR_NAME))) {
208
+ // fs.mkdirSync(path.resolve(CREDENTIALS.DIR_NAME));
209
+ // }
210
+ // fs.readdir(path.resolve(CREDENTIALS.DIR_NAME), async (err, dirs) => {
211
+ // if (err) {
212
+ // throw err;
213
+ // }
214
+ // for (const dir of dirs) {
215
+ // const sessionId = dir.split("_")[0];
216
+ // if (!shouldLoadSession(sessionId)) continue;
217
+ // startWhatsApp(sessionId, options);
218
+ // }
219
+ // });
220
+ // };
221
+ // export const ev = new Event(callback);
Binary file
@@ -0,0 +1,5 @@
1
+ export * from "./WhatsApp";
2
+ export * from "./Utils";
3
+ export * from "./Types";
4
+ export * from "./Error";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./WhatsApp"), exports);
18
+ __exportStar(require("./Utils"), exports);
19
+ __exportStar(require("./Types"), exports);
20
+ __exportStar(require("./Error"), exports);
package/package.json ADDED
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "whatsauto.js",
3
+ "version": "0.0.0",
4
+ "description": "WhatsApp Automation with Multi Session",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist/**/*"
9
+ ],
10
+ "scripts": {
11
+ "build": "tsc",
12
+ "start": "tsc && node ./dist/index.js",
13
+ "test": "jest --watchAll"
14
+ },
15
+ "author": "freack21",
16
+ "license": "ISC",
17
+ "dependencies": {
18
+ "@adiwajshing/keyed-db": "^0.2.4",
19
+ "@hapi/boom": "^10.0.1",
20
+ "@whiskeysockets/baileys": "^6.7.9",
21
+ "mime": "^3.0.0",
22
+ "pino": "^9.5.0",
23
+ "qrcode-terminal": "^0.12.0",
24
+ "wa-sticker-formatter": "^4.4.4"
25
+ },
26
+ "repository": {
27
+ "type": "git",
28
+ "url": "git+ssh://git@github.com/freack21/whatsauto.js.git"
29
+ },
30
+ "devDependencies": {
31
+ "@jest/globals": "^29.7.0",
32
+ "@types/jest": "^29.5.14",
33
+ "@types/mime": "^3.0.1",
34
+ "jest": "^29.7.0",
35
+ "ts-jest": "^29.2.5",
36
+ "typescript": "^5.7.2"
37
+ }
38
+ }