@mtcute/node 0.17.0 → 0.18.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 (67) hide show
  1. package/client.cjs +101 -0
  2. package/client.d.cts +40 -0
  3. package/client.d.ts +2 -9
  4. package/client.js +96 -0
  5. package/index.cjs +29 -423
  6. package/index.d.cts +2 -1
  7. package/index.d.ts +2 -1
  8. package/index.js +13 -397
  9. package/{chunks/cjs/BpvQ752Q.js → methods/download-file.cjs} +3 -7
  10. package/methods/download-file.d.cts +9 -0
  11. package/{chunks/es/CnOjjhdK.js → methods/download-file.js} +1 -6
  12. package/methods/download-node-stream.cjs +13 -0
  13. package/methods/download-node-stream.d.cts +8 -0
  14. package/methods/download-node-stream.d.ts +1 -1
  15. package/methods/download-node-stream.js +8 -0
  16. package/methods.cjs +5 -4
  17. package/methods.js +2 -1
  18. package/package.json +16 -13
  19. package/sqlite/driver.cjs +27 -0
  20. package/sqlite/driver.d.cts +25 -0
  21. package/sqlite/driver.d.ts +1 -1
  22. package/sqlite/driver.js +22 -0
  23. package/sqlite/index.cjs +18 -0
  24. package/sqlite/index.d.cts +8 -0
  25. package/sqlite/index.d.ts +1 -1
  26. package/sqlite/index.js +13 -0
  27. package/{chunks/cjs/D7i-4e0W.js → utils/crypto.cjs} +4 -3
  28. package/utils/crypto.d.cts +15 -0
  29. package/{chunks/es/HZgHrOPU.js → utils/crypto.js} +1 -1
  30. package/utils/exit-hook.cjs +46 -0
  31. package/utils/exit-hook.d.ts +1 -0
  32. package/utils/exit-hook.js +41 -0
  33. package/utils/logging.cjs +33 -0
  34. package/utils/logging.d.ts +2 -0
  35. package/utils/logging.js +28 -0
  36. package/utils/normalize-file.cjs +33 -0
  37. package/utils/normalize-file.d.cts +6 -0
  38. package/utils/normalize-file.js +28 -0
  39. package/utils/platform.cjs +44 -0
  40. package/utils/platform.d.cts +11 -0
  41. package/{common-internals-node → utils}/platform.d.ts +1 -8
  42. package/utils/platform.js +22 -0
  43. package/utils/proxies.cjs +73 -0
  44. package/utils/proxies.d.cts +34 -0
  45. package/utils/proxies.d.ts +34 -0
  46. package/utils/proxies.js +63 -0
  47. package/utils/tcp.cjs +18 -0
  48. package/utils/tcp.d.cts +7 -0
  49. package/utils/tcp.d.ts +6 -28
  50. package/utils/tcp.js +13 -0
  51. package/utils.cjs +3 -6
  52. package/utils.d.cts +0 -1
  53. package/utils.d.ts +0 -1
  54. package/utils.js +2 -5
  55. package/worker.cjs +49 -0
  56. package/worker.d.cts +12 -0
  57. package/worker.d.ts +5 -3
  58. package/worker.js +44 -0
  59. package/chunks/cjs/HP2yqAk_.js +0 -79
  60. package/chunks/cjs/package.json +0 -3
  61. package/chunks/es/CKso6cAV.js +0 -75
  62. package/utils/stream-utils.d.ts +0 -3
  63. package/utils/version.d.ts +0 -3
  64. /package/{utils/stream-utils.test.d.ts → sqlite/sqlite.test.d.cts} +0 -0
  65. /package/utils/{tcp.test.d.ts → crypto.test.d.cts} +0 -0
  66. /package/{common-internals-node/exit-hook.d.ts → utils/exit-hook.d.cts} +0 -0
  67. /package/{common-internals-node/logging.d.ts → utils/logging.d.cts} +0 -0
@@ -0,0 +1,7 @@
1
+ import { ITcpConnection } from '@fuman/net';
2
+ import { TelegramTransport, IntermediatePacketCodec } from '@mtcute/core';
3
+ import { BasicDcOption } from '@mtcute/core/utils.js';
4
+ export declare class TcpTransport implements TelegramTransport {
5
+ connect(dc: BasicDcOption): Promise<ITcpConnection>;
6
+ packetCodec(): IntermediatePacketCodec;
7
+ }
package/utils/tcp.d.ts CHANGED
@@ -1,29 +1,7 @@
1
- import { default as EventEmitter } from 'node:events';
2
- import { Socket } from 'node:net';
3
- import { IPacketCodec, ITelegramTransport, IntermediatePacketCodec, TransportState } from '@mtcute/core';
4
- import { BasicDcOption, ICryptoProvider, Logger } from '@mtcute/core/utils.js';
5
- /**
6
- * Base for TCP transports.
7
- * Subclasses must provide packet codec in `_packetCodec` property
8
- */
9
- export declare abstract class BaseTcpTransport extends EventEmitter implements ITelegramTransport {
10
- protected _currentDc: BasicDcOption | null;
11
- protected _state: TransportState;
12
- protected _socket: Socket | null;
13
- abstract _packetCodec: IPacketCodec;
14
- protected _crypto: ICryptoProvider;
15
- protected log: Logger;
16
- packetCodecInitialized: boolean;
17
- private _updateLogPrefix;
18
- setup(crypto: ICryptoProvider, log: Logger): void;
19
- state(): TransportState;
20
- currentDc(): BasicDcOption | null;
21
- connect(dc: BasicDcOption, testMode: boolean): void;
22
- close(): void;
23
- handleError(error: Error): void;
24
- handleConnect(): void;
25
- send(bytes: Uint8Array): Promise<void>;
26
- }
27
- export declare class TcpTransport extends BaseTcpTransport {
28
- _packetCodec: IntermediatePacketCodec;
1
+ import { ITcpConnection } from '@fuman/net';
2
+ import { TelegramTransport, IntermediatePacketCodec } from '@mtcute/core';
3
+ import { BasicDcOption } from '@mtcute/core/utils.js';
4
+ export declare class TcpTransport implements TelegramTransport {
5
+ connect(dc: BasicDcOption): Promise<ITcpConnection>;
6
+ packetCodec(): IntermediatePacketCodec;
29
7
  }
package/utils/tcp.js ADDED
@@ -0,0 +1,13 @@
1
+ import { connectTcp } from "@fuman/node";
2
+ import { IntermediatePacketCodec } from "@mtcute/core";
3
+ class TcpTransport {
4
+ connect(dc) {
5
+ return connectTcp({ address: dc.ipAddress, port: dc.port });
6
+ }
7
+ packetCodec() {
8
+ return new IntermediatePacketCodec();
9
+ }
10
+ }
11
+ export {
12
+ TcpTransport
13
+ };
package/utils.cjs CHANGED
@@ -1,17 +1,14 @@
1
1
  if (typeof globalThis !== "undefined" && !globalThis._MTCUTE_CJS_DEPRECATION_WARNED) {
2
2
  globalThis._MTCUTE_CJS_DEPRECATION_WARNED = true;
3
- console.warn("[@mtcute/node] CommonJS support is deprecated and will be removed soon. Please consider switching to ESM, it's " + (/* @__PURE__ */ new Date()).getFullYear() + " already.");
4
- console.warn("[@mtcute/node] Learn more about switching to ESM: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c");
3
+ console.warn("[mtcute-workspace] CommonJS support is deprecated and will be removed in 0.20.0. Please consider switching to ESM, it's " + (/* @__PURE__ */ new Date()).getFullYear() + " already.");
4
+ console.warn("[mtcute-workspace] Learn more about switching to ESM: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c");
5
5
  }
6
6
  "use strict";
7
7
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
8
- const crypto = require("./chunks/cjs/D7i-4e0W.js");
9
- const streamUtils = require("./chunks/cjs/HP2yqAk_.js");
8
+ const crypto = require("./utils/crypto.cjs");
10
9
  const utils_js = require("@mtcute/core/utils.js");
11
10
  exports.BaseNodeCryptoProvider = crypto.BaseNodeCryptoProvider;
12
11
  exports.NodeCryptoProvider = crypto.NodeCryptoProvider;
13
- exports.nodeStreamToWeb = streamUtils.nodeStreamToWeb;
14
- exports.webStreamToNode = streamUtils.webStreamToNode;
15
12
  Object.keys(utils_js).forEach((k) => {
16
13
  if (k !== "default" && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
17
14
  enumerable: true,
package/utils.d.cts CHANGED
@@ -1,3 +1,2 @@
1
1
  export * from './utils/crypto.js';
2
- export * from './utils/stream-utils.js';
3
2
  export * from '@mtcute/core/utils.js';
package/utils.d.ts CHANGED
@@ -1,3 +1,2 @@
1
1
  export * from './utils/crypto.js';
2
- export * from './utils/stream-utils.js';
3
2
  export * from '@mtcute/core/utils.js';
package/utils.js CHANGED
@@ -1,9 +1,6 @@
1
- import { BaseNodeCryptoProvider, NodeCryptoProvider } from "./chunks/es/HZgHrOPU.js";
2
- import { nodeStreamToWeb, webStreamToNode } from "./chunks/es/CKso6cAV.js";
1
+ import { BaseNodeCryptoProvider, NodeCryptoProvider } from "./utils/crypto.js";
3
2
  export * from "@mtcute/core/utils.js";
4
3
  export {
5
4
  BaseNodeCryptoProvider,
6
- NodeCryptoProvider,
7
- nodeStreamToWeb,
8
- webStreamToNode
5
+ NodeCryptoProvider
9
6
  };
package/worker.cjs ADDED
@@ -0,0 +1,49 @@
1
+ if (typeof globalThis !== "undefined" && !globalThis._MTCUTE_CJS_DEPRECATION_WARNED) {
2
+ globalThis._MTCUTE_CJS_DEPRECATION_WARNED = true;
3
+ console.warn("[mtcute-workspace] CommonJS support is deprecated and will be removed in 0.20.0. Please consider switching to ESM, it's " + (/* @__PURE__ */ new Date()).getFullYear() + " already.");
4
+ console.warn("[mtcute-workspace] Learn more about switching to ESM: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c");
5
+ }
6
+ "use strict";
7
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
8
+ const node_worker_threads = require("node:worker_threads");
9
+ const worker_js = require("@mtcute/core/worker.js");
10
+ const platform = require("./utils/platform.cjs");
11
+ let _registered = false;
12
+ class TelegramWorker extends worker_js.TelegramWorker {
13
+ registerWorker(handler) {
14
+ if (!node_worker_threads.parentPort) {
15
+ throw new Error("TelegramWorker must be created from a worker thread");
16
+ }
17
+ if (_registered) {
18
+ throw new Error("TelegramWorker must be created only once");
19
+ }
20
+ _registered = true;
21
+ const port = node_worker_threads.parentPort;
22
+ const respond = port.postMessage.bind(port);
23
+ node_worker_threads.parentPort.on("message", (message) => handler(message, respond));
24
+ return respond;
25
+ }
26
+ }
27
+ class TelegramWorkerPort extends worker_js.TelegramWorkerPort {
28
+ constructor(options) {
29
+ super({
30
+ worker: options.worker,
31
+ platform: new platform.NodePlatform()
32
+ });
33
+ }
34
+ connectToWorker(worker, handler) {
35
+ if (!(worker instanceof node_worker_threads.Worker)) {
36
+ throw new TypeError("Only worker_threads are supported");
37
+ }
38
+ const send = worker.postMessage.bind(worker);
39
+ worker.on("message", handler);
40
+ return [
41
+ send,
42
+ () => {
43
+ worker.off("message", handler);
44
+ }
45
+ ];
46
+ }
47
+ }
48
+ exports.TelegramWorker = TelegramWorker;
49
+ exports.TelegramWorkerPort = TelegramWorkerPort;
package/worker.d.cts ADDED
@@ -0,0 +1,12 @@
1
+ import { ClientMessageHandler, RespondFn, SendFn, SomeWorker, TelegramWorkerOptions, WorkerCustomMethods, WorkerMessageHandler, TelegramWorker as TelegramWorkerBase, TelegramWorkerPort as TelegramWorkerPortBase } from '@mtcute/core/worker.js';
2
+ export type { TelegramWorkerOptions, WorkerCustomMethods };
3
+ export interface TelegramWorkerPortOptions {
4
+ worker: SomeWorker;
5
+ }
6
+ export declare class TelegramWorker<T extends WorkerCustomMethods> extends TelegramWorkerBase<T> {
7
+ registerWorker(handler: WorkerMessageHandler): RespondFn;
8
+ }
9
+ export declare class TelegramWorkerPort<T extends WorkerCustomMethods> extends TelegramWorkerPortBase<T> {
10
+ constructor(options: TelegramWorkerPortOptions);
11
+ connectToWorker(worker: SomeWorker, handler: ClientMessageHandler): [SendFn, () => void];
12
+ }
package/worker.d.ts CHANGED
@@ -1,10 +1,12 @@
1
- import { ClientMessageHandler, RespondFn, SendFn, SomeWorker, TelegramWorkerOptions, TelegramWorkerPortOptions, WorkerCustomMethods, WorkerMessageHandler, TelegramWorker as TelegramWorkerBase, TelegramWorkerPort as TelegramWorkerPortBase } from '@mtcute/core/worker.js';
2
- export type { TelegramWorkerOptions, TelegramWorkerPortOptions, WorkerCustomMethods };
1
+ import { ClientMessageHandler, RespondFn, SendFn, SomeWorker, TelegramWorkerOptions, WorkerCustomMethods, WorkerMessageHandler, TelegramWorker as TelegramWorkerBase, TelegramWorkerPort as TelegramWorkerPortBase } from '@mtcute/core/worker.js';
2
+ export type { TelegramWorkerOptions, WorkerCustomMethods };
3
+ export interface TelegramWorkerPortOptions {
4
+ worker: SomeWorker;
5
+ }
3
6
  export declare class TelegramWorker<T extends WorkerCustomMethods> extends TelegramWorkerBase<T> {
4
7
  registerWorker(handler: WorkerMessageHandler): RespondFn;
5
8
  }
6
9
  export declare class TelegramWorkerPort<T extends WorkerCustomMethods> extends TelegramWorkerPortBase<T> {
7
- readonly options: TelegramWorkerPortOptions;
8
10
  constructor(options: TelegramWorkerPortOptions);
9
11
  connectToWorker(worker: SomeWorker, handler: ClientMessageHandler): [SendFn, () => void];
10
12
  }
package/worker.js ADDED
@@ -0,0 +1,44 @@
1
+ import { parentPort, Worker } from "node:worker_threads";
2
+ import { TelegramWorker as TelegramWorker$1, TelegramWorkerPort as TelegramWorkerPort$1 } from "@mtcute/core/worker.js";
3
+ import { NodePlatform } from "./utils/platform.js";
4
+ let _registered = false;
5
+ class TelegramWorker extends TelegramWorker$1 {
6
+ registerWorker(handler) {
7
+ if (!parentPort) {
8
+ throw new Error("TelegramWorker must be created from a worker thread");
9
+ }
10
+ if (_registered) {
11
+ throw new Error("TelegramWorker must be created only once");
12
+ }
13
+ _registered = true;
14
+ const port = parentPort;
15
+ const respond = port.postMessage.bind(port);
16
+ parentPort.on("message", (message) => handler(message, respond));
17
+ return respond;
18
+ }
19
+ }
20
+ class TelegramWorkerPort extends TelegramWorkerPort$1 {
21
+ constructor(options) {
22
+ super({
23
+ worker: options.worker,
24
+ platform: new NodePlatform()
25
+ });
26
+ }
27
+ connectToWorker(worker, handler) {
28
+ if (!(worker instanceof Worker)) {
29
+ throw new TypeError("Only worker_threads are supported");
30
+ }
31
+ const send = worker.postMessage.bind(worker);
32
+ worker.on("message", handler);
33
+ return [
34
+ send,
35
+ () => {
36
+ worker.off("message", handler);
37
+ }
38
+ ];
39
+ }
40
+ }
41
+ export {
42
+ TelegramWorker,
43
+ TelegramWorkerPort
44
+ };
@@ -1,79 +0,0 @@
1
- if (typeof globalThis !== "undefined" && !globalThis._MTCUTE_CJS_DEPRECATION_WARNED) {
2
- globalThis._MTCUTE_CJS_DEPRECATION_WARNED = true;
3
- console.warn("[@mtcute/node] CommonJS support is deprecated and will be removed soon. Please consider switching to ESM, it's " + (/* @__PURE__ */ new Date()).getFullYear() + " already.");
4
- console.warn("[@mtcute/node] Learn more about switching to ESM: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c");
5
- }
6
- "use strict";
7
- const node_stream = require("node:stream");
8
- const NODE_VERSION = typeof process !== "undefined" && "node" in process.versions ? process.versions.node : null;
9
- const NODE_VERSION_TUPLE = NODE_VERSION ? /* @__PURE__ */ NODE_VERSION.split(".").map(Number) : null;
10
- function isNodeVersionAfter(major, minor, patch) {
11
- if (!NODE_VERSION_TUPLE) return true;
12
- const [a, b, c] = NODE_VERSION_TUPLE;
13
- if (a > major) return true;
14
- if (a < major) return false;
15
- if (b > minor) return true;
16
- if (b < minor) return false;
17
- return c >= patch;
18
- }
19
- function nodeStreamToWeb(stream) {
20
- if (typeof node_stream.Readable.toWeb === "function") {
21
- return node_stream.Readable.toWeb(stream);
22
- }
23
- stream.pause();
24
- return new ReadableStream({
25
- start(c) {
26
- stream.on("data", (chunk) => {
27
- c.enqueue(chunk);
28
- });
29
- stream.on("end", () => {
30
- c.close();
31
- });
32
- stream.on("error", (err) => {
33
- c.error(err);
34
- });
35
- },
36
- pull() {
37
- stream.resume();
38
- }
39
- });
40
- }
41
- function webStreamToNode(stream) {
42
- if (typeof node_stream.Readable.fromWeb === "function" && isNodeVersionAfter(18, 13, 0)) {
43
- return node_stream.Readable.fromWeb(stream);
44
- }
45
- const reader = stream.getReader();
46
- let ended = false;
47
- const readable = new node_stream.Readable({
48
- async read() {
49
- try {
50
- const { done, value } = await reader.read();
51
- if (done) {
52
- this.push(null);
53
- } else {
54
- this.push(Buffer.from(value.buffer, value.byteOffset, value.byteLength));
55
- }
56
- } catch (err) {
57
- this.destroy(err);
58
- }
59
- },
60
- destroy(error, cb) {
61
- if (!ended) {
62
- void reader.cancel(error).catch(() => {
63
- }).then(() => {
64
- cb(error);
65
- });
66
- return;
67
- }
68
- cb(error);
69
- }
70
- });
71
- reader.closed.then(() => {
72
- ended = true;
73
- }).catch((err) => {
74
- readable.destroy(err);
75
- });
76
- return readable;
77
- }
78
- exports.nodeStreamToWeb = nodeStreamToWeb;
79
- exports.webStreamToNode = webStreamToNode;
@@ -1,3 +0,0 @@
1
- {
2
- "type": "commonjs"
3
- }
@@ -1,75 +0,0 @@
1
- import { Readable } from "node:stream";
2
- const NODE_VERSION = typeof process !== "undefined" && "node" in process.versions ? process.versions.node : null;
3
- const NODE_VERSION_TUPLE = NODE_VERSION ? /* @__PURE__ */ NODE_VERSION.split(".").map(Number) : null;
4
- function isNodeVersionAfter(major, minor, patch) {
5
- if (!NODE_VERSION_TUPLE) return true;
6
- const [a, b, c] = NODE_VERSION_TUPLE;
7
- if (a > major) return true;
8
- if (a < major) return false;
9
- if (b > minor) return true;
10
- if (b < minor) return false;
11
- return c >= patch;
12
- }
13
- function nodeStreamToWeb(stream) {
14
- if (typeof Readable.toWeb === "function") {
15
- return Readable.toWeb(stream);
16
- }
17
- stream.pause();
18
- return new ReadableStream({
19
- start(c) {
20
- stream.on("data", (chunk) => {
21
- c.enqueue(chunk);
22
- });
23
- stream.on("end", () => {
24
- c.close();
25
- });
26
- stream.on("error", (err) => {
27
- c.error(err);
28
- });
29
- },
30
- pull() {
31
- stream.resume();
32
- }
33
- });
34
- }
35
- function webStreamToNode(stream) {
36
- if (typeof Readable.fromWeb === "function" && isNodeVersionAfter(18, 13, 0)) {
37
- return Readable.fromWeb(stream);
38
- }
39
- const reader = stream.getReader();
40
- let ended = false;
41
- const readable = new Readable({
42
- async read() {
43
- try {
44
- const { done, value } = await reader.read();
45
- if (done) {
46
- this.push(null);
47
- } else {
48
- this.push(Buffer.from(value.buffer, value.byteOffset, value.byteLength));
49
- }
50
- } catch (err) {
51
- this.destroy(err);
52
- }
53
- },
54
- destroy(error, cb) {
55
- if (!ended) {
56
- void reader.cancel(error).catch(() => {
57
- }).then(() => {
58
- cb(error);
59
- });
60
- return;
61
- }
62
- cb(error);
63
- }
64
- });
65
- reader.closed.then(() => {
66
- ended = true;
67
- }).catch((err) => {
68
- readable.destroy(err);
69
- });
70
- return readable;
71
- }
72
- export {
73
- nodeStreamToWeb,
74
- webStreamToNode
75
- };
@@ -1,3 +0,0 @@
1
- import { Readable } from 'node:stream';
2
- export declare function nodeStreamToWeb(stream: Readable): ReadableStream<Uint8Array>;
3
- export declare function webStreamToNode(stream: ReadableStream<Uint8Array>): Readable;
@@ -1,3 +0,0 @@
1
- export declare const NODE_VERSION: string | null;
2
- export declare const NODE_VERSION_TUPLE: number[] | null;
3
- export declare function isNodeVersionAfter(major: number, minor: number, patch: number): boolean;
File without changes