@mtcute/test 0.9.0 → 0.11.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.
- package/esm/client.js +13 -11
- package/esm/client.js.map +1 -1
- package/esm/crypto.js.map +1 -1
- package/esm/schema.js.map +1 -1
- package/esm/storage.js +1 -0
- package/esm/storage.js.map +1 -1
- package/esm/stub.js.map +1 -1
- package/esm/transport.js +5 -2
- package/esm/transport.js.map +1 -1
- package/esm/utils.js.map +1 -1
- package/package.json +8 -13
- package/cjs/client.d.ts +0 -54
- package/cjs/client.js +0 -235
- package/cjs/client.js.map +0 -1
- package/cjs/crypto.d.ts +0 -6
- package/cjs/crypto.js +0 -186
- package/cjs/crypto.js.map +0 -1
- package/cjs/index.d.ts +0 -8
- package/cjs/index.js +0 -25
- package/cjs/index.js.map +0 -1
- package/cjs/package.json +0 -3
- package/cjs/platform.d.ts +0 -3
- package/cjs/platform.js +0 -7
- package/cjs/platform.js.map +0 -1
- package/cjs/platform.web.d.ts +0 -3
- package/cjs/platform.web.js +0 -7
- package/cjs/platform.web.js.map +0 -1
- package/cjs/schema.d.ts +0 -1
- package/cjs/schema.js +0 -55
- package/cjs/schema.js.map +0 -1
- package/cjs/storage/auth-keys.d.ts +0 -3
- package/cjs/storage/auth-keys.js +0 -95
- package/cjs/storage/auth-keys.js.map +0 -1
- package/cjs/storage/index.d.ts +0 -4
- package/cjs/storage/index.js +0 -21
- package/cjs/storage/index.js.map +0 -1
- package/cjs/storage/key-value.d.ts +0 -3
- package/cjs/storage/key-value.js +0 -41
- package/cjs/storage/key-value.js.map +0 -1
- package/cjs/storage/peers.d.ts +0 -3
- package/cjs/storage/peers.js +0 -75
- package/cjs/storage/peers.js.map +0 -1
- package/cjs/storage/ref-messages.d.ts +0 -3
- package/cjs/storage/ref-messages.js +0 -69
- package/cjs/storage/ref-messages.js.map +0 -1
- package/cjs/storage.d.ts +0 -37
- package/cjs/storage.js +0 -48
- package/cjs/storage.js.map +0 -1
- package/cjs/stub.d.ts +0 -2
- package/cjs/stub.js +0 -71
- package/cjs/stub.js.map +0 -1
- package/cjs/transport.d.ts +0 -30
- package/cjs/transport.js +0 -52
- package/cjs/transport.js.map +0 -1
- package/cjs/types.d.ts +0 -8
- package/cjs/types.js +0 -3
- package/cjs/types.js.map +0 -1
- package/cjs/utils.d.ts +0 -2
- package/cjs/utils.js +0 -17
- package/cjs/utils.js.map +0 -1
package/cjs/schema.js
DELETED
|
@@ -1,55 +0,0 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.getEntriesMap = void 0;
|
|
27
|
-
const schema_ = __importStar(require("@mtcute/tl/api-schema.json"));
|
|
28
|
-
const schema = ('default' in schema_ ? schema_.default : schema_);
|
|
29
|
-
let _cachedEntriesMap = null;
|
|
30
|
-
let _cachedUnionsMap = null;
|
|
31
|
-
/** @internal */
|
|
32
|
-
function getEntriesMap() {
|
|
33
|
-
if (_cachedEntriesMap) {
|
|
34
|
-
return {
|
|
35
|
-
entries: _cachedEntriesMap,
|
|
36
|
-
unions: _cachedUnionsMap,
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
_cachedEntriesMap = new Map();
|
|
40
|
-
_cachedUnionsMap = new Map();
|
|
41
|
-
let entry;
|
|
42
|
-
for (entry of schema.e) {
|
|
43
|
-
_cachedEntriesMap.set(entry.name, entry);
|
|
44
|
-
if (!_cachedUnionsMap.has(entry.type)) {
|
|
45
|
-
_cachedUnionsMap.set(entry.type, []);
|
|
46
|
-
}
|
|
47
|
-
_cachedUnionsMap.get(entry.type).push(entry);
|
|
48
|
-
}
|
|
49
|
-
return {
|
|
50
|
-
entries: _cachedEntriesMap,
|
|
51
|
-
unions: _cachedUnionsMap,
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
exports.getEntriesMap = getEntriesMap;
|
|
55
|
-
//# sourceMappingURL=schema.js.map
|
package/cjs/schema.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/schema.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oEAA6E;AAE7E,MAAM,MAAM,GAAG,CAAC,SAAS,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAqB,CAAA;AAIrF,IAAI,iBAAiB,GAAgC,IAAI,CAAA;AACzD,IAAI,gBAAgB,GAAkC,IAAI,CAAA;AAE1D,gBAAgB;AAChB,SAAgB,aAAa;IACzB,IAAI,iBAAiB,EAAE;QACnB,OAAO;YACH,OAAO,EAAE,iBAAiB;YAC1B,MAAM,EAAE,gBAAiB;SAC5B,CAAA;KACJ;IAED,iBAAiB,GAAG,IAAI,GAAG,EAAE,CAAA;IAC7B,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAA;IAE5B,IAAI,KAAc,CAAA;IAElB,KAAK,KAAK,IAAI,MAAM,CAAC,CAAC,EAAE;QACpB,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;QAExC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YACnC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;SACvC;QACD,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;KAChD;IAED,OAAO;QACH,OAAO,EAAE,iBAAiB;QAC1B,MAAM,EAAE,gBAAgB;KAC3B,CAAA;AACL,CAAC;AA1BD,sCA0BC","sourcesContent":["import * as schema_ from '@mtcute/tl/api-schema.json' assert { type: 'json' }\n\nconst schema = ('default' in schema_ ? schema_.default : schema_) as { e: TlEntry[] }\n\nimport type { TlEntry } from '@mtcute/tl-utils'\n\nlet _cachedEntriesMap: Map<string, TlEntry> | null = null\nlet _cachedUnionsMap: Map<string, TlEntry[]> | null = null\n\n/** @internal */\nexport function getEntriesMap() {\n if (_cachedEntriesMap) {\n return {\n entries: _cachedEntriesMap,\n unions: _cachedUnionsMap!,\n }\n }\n\n _cachedEntriesMap = new Map()\n _cachedUnionsMap = new Map()\n\n let entry: TlEntry\n\n for (entry of schema.e) {\n _cachedEntriesMap.set(entry.name, entry)\n\n if (!_cachedUnionsMap.has(entry.type)) {\n _cachedUnionsMap.set(entry.type, [])\n }\n _cachedUnionsMap.get(entry.type)!.push(entry)\n }\n\n return {\n entries: _cachedEntriesMap,\n unions: _cachedUnionsMap,\n }\n}\n"]}
|
package/cjs/storage/auth-keys.js
DELETED
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.testAuthKeysRepository = exports.fakeAuthKeysRepository = void 0;
|
|
4
|
-
const vitest_1 = require("vitest");
|
|
5
|
-
function fakeAuthKeysRepository() {
|
|
6
|
-
return {
|
|
7
|
-
get: vitest_1.vi.fn(),
|
|
8
|
-
set: vitest_1.vi.fn(),
|
|
9
|
-
getTemp: vitest_1.vi.fn(),
|
|
10
|
-
setTemp: vitest_1.vi.fn(),
|
|
11
|
-
deleteByDc: vitest_1.vi.fn(),
|
|
12
|
-
deleteAll: vitest_1.vi.fn(),
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
exports.fakeAuthKeysRepository = fakeAuthKeysRepository;
|
|
16
|
-
function fixBuffer(buf) {
|
|
17
|
-
if (!buf)
|
|
18
|
-
return buf;
|
|
19
|
-
// eslint-disable-next-line no-restricted-globals
|
|
20
|
-
return typeof Buffer !== 'undefined' && buf instanceof Buffer ? new Uint8Array(buf) : buf;
|
|
21
|
-
}
|
|
22
|
-
function testAuthKeysRepository(repo) {
|
|
23
|
-
const key2 = new Uint8Array(256).fill(0x42);
|
|
24
|
-
const key3 = new Uint8Array(256).fill(0x43);
|
|
25
|
-
const key2i0 = new Uint8Array(256).fill(0x44);
|
|
26
|
-
const key2i1 = new Uint8Array(256).fill(0x45);
|
|
27
|
-
const key3i0 = new Uint8Array(256).fill(0x46);
|
|
28
|
-
const key3i1 = new Uint8Array(256).fill(0x47);
|
|
29
|
-
(0, vitest_1.describe)('auth keys', () => {
|
|
30
|
-
(0, vitest_1.afterEach)(() => repo.deleteAll());
|
|
31
|
-
(0, vitest_1.it)('should be empty by default', async () => {
|
|
32
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(2))).toEqual(null);
|
|
33
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(3))).toEqual(null);
|
|
34
|
-
});
|
|
35
|
-
(0, vitest_1.it)('should store and retrieve auth keys', async () => {
|
|
36
|
-
await repo.set(2, key2);
|
|
37
|
-
await repo.set(3, key3);
|
|
38
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(2))).toEqual(key2);
|
|
39
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(3))).toEqual(key3);
|
|
40
|
-
});
|
|
41
|
-
(0, vitest_1.it)('should delete auth keys', async () => {
|
|
42
|
-
await repo.set(2, key2);
|
|
43
|
-
await repo.set(3, key3);
|
|
44
|
-
await repo.set(2, null);
|
|
45
|
-
await repo.set(3, null);
|
|
46
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(2))).toEqual(null);
|
|
47
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(3))).toEqual(null);
|
|
48
|
-
});
|
|
49
|
-
(0, vitest_1.it)('should store and retrieve temp auth keys', async () => {
|
|
50
|
-
await repo.setTemp(2, 0, key2i0, 1);
|
|
51
|
-
await repo.setTemp(2, 1, key2i1, 1);
|
|
52
|
-
await repo.setTemp(3, 0, key3i0, 1);
|
|
53
|
-
await repo.setTemp(3, 1, key3i1, 1);
|
|
54
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(key2i0);
|
|
55
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(key2i1);
|
|
56
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(key3i0);
|
|
57
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(key3i1);
|
|
58
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 0, 100))).toEqual(null);
|
|
59
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 1, 100))).toEqual(null);
|
|
60
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 0, 100))).toEqual(null);
|
|
61
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 1, 100))).toEqual(null);
|
|
62
|
-
});
|
|
63
|
-
(0, vitest_1.it)('should delete temp auth keys', async () => {
|
|
64
|
-
await repo.setTemp(2, 0, key2i0, 1);
|
|
65
|
-
await repo.setTemp(2, 1, key2i1, 1);
|
|
66
|
-
await repo.setTemp(3, 0, key3i0, 1);
|
|
67
|
-
await repo.setTemp(3, 1, key3i1, 1);
|
|
68
|
-
await repo.setTemp(2, 0, null, 1);
|
|
69
|
-
await repo.setTemp(2, 1, null, 1);
|
|
70
|
-
await repo.setTemp(3, 0, null, 1);
|
|
71
|
-
await repo.setTemp(3, 1, null, 1);
|
|
72
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(null);
|
|
73
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(null);
|
|
74
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(null);
|
|
75
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(null);
|
|
76
|
-
});
|
|
77
|
-
(0, vitest_1.it)('should delete all auth keys by DC', async () => {
|
|
78
|
-
await repo.set(2, key2);
|
|
79
|
-
await repo.set(3, key3);
|
|
80
|
-
await repo.setTemp(2, 0, key2i0, 1);
|
|
81
|
-
await repo.setTemp(2, 1, key2i1, 1);
|
|
82
|
-
await repo.setTemp(3, 0, key3i0, 1);
|
|
83
|
-
await repo.setTemp(3, 1, key3i1, 1);
|
|
84
|
-
await repo.deleteByDc(2);
|
|
85
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(2))).toEqual(null);
|
|
86
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get(3))).toEqual(key3);
|
|
87
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(null);
|
|
88
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(null);
|
|
89
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(key3i0);
|
|
90
|
-
(0, vitest_1.expect)(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(key3i1);
|
|
91
|
-
});
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
exports.testAuthKeysRepository = testAuthKeysRepository;
|
|
95
|
-
//# sourceMappingURL=auth-keys.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-keys.js","sourceRoot":"","sources":["../../../src/storage/auth-keys.ts"],"names":[],"mappings":"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","sourcesContent":["import { afterEach, describe, expect, it, vi } from 'vitest'\n\nimport { IAuthKeysRepository } from '@mtcute/core'\n\nexport function fakeAuthKeysRepository(): IAuthKeysRepository {\n return {\n get: vi.fn(),\n set: vi.fn(),\n getTemp: vi.fn(),\n setTemp: vi.fn(),\n deleteByDc: vi.fn(),\n deleteAll: vi.fn(),\n }\n}\n\nfunction fixBuffer(buf: Uint8Array | null): Uint8Array | null {\n if (!buf) return buf\n\n // eslint-disable-next-line no-restricted-globals\n return typeof Buffer !== 'undefined' && buf instanceof Buffer ? new Uint8Array(buf) : buf\n}\n\nexport function testAuthKeysRepository(repo: IAuthKeysRepository) {\n const key2 = new Uint8Array(256).fill(0x42)\n const key3 = new Uint8Array(256).fill(0x43)\n\n const key2i0 = new Uint8Array(256).fill(0x44)\n const key2i1 = new Uint8Array(256).fill(0x45)\n const key3i0 = new Uint8Array(256).fill(0x46)\n const key3i1 = new Uint8Array(256).fill(0x47)\n\n describe('auth keys', () => {\n afterEach(() => repo.deleteAll())\n\n it('should be empty by default', async () => {\n expect(fixBuffer(await repo.get(2))).toEqual(null)\n expect(fixBuffer(await repo.get(3))).toEqual(null)\n })\n\n it('should store and retrieve auth keys', async () => {\n await repo.set(2, key2)\n await repo.set(3, key3)\n\n expect(fixBuffer(await repo.get(2))).toEqual(key2)\n expect(fixBuffer(await repo.get(3))).toEqual(key3)\n })\n\n it('should delete auth keys', async () => {\n await repo.set(2, key2)\n await repo.set(3, key3)\n\n await repo.set(2, null)\n await repo.set(3, null)\n\n expect(fixBuffer(await repo.get(2))).toEqual(null)\n expect(fixBuffer(await repo.get(3))).toEqual(null)\n })\n\n it('should store and retrieve temp auth keys', async () => {\n await repo.setTemp(2, 0, key2i0, 1)\n await repo.setTemp(2, 1, key2i1, 1)\n await repo.setTemp(3, 0, key3i0, 1)\n await repo.setTemp(3, 1, key3i1, 1)\n\n expect(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(key2i0)\n expect(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(key2i1)\n expect(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(key3i0)\n expect(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(key3i1)\n\n expect(fixBuffer(await repo.getTemp(2, 0, 100))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(2, 1, 100))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(3, 0, 100))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(3, 1, 100))).toEqual(null)\n })\n\n it('should delete temp auth keys', async () => {\n await repo.setTemp(2, 0, key2i0, 1)\n await repo.setTemp(2, 1, key2i1, 1)\n await repo.setTemp(3, 0, key3i0, 1)\n await repo.setTemp(3, 1, key3i1, 1)\n\n await repo.setTemp(2, 0, null, 1)\n await repo.setTemp(2, 1, null, 1)\n await repo.setTemp(3, 0, null, 1)\n await repo.setTemp(3, 1, null, 1)\n\n expect(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(null)\n })\n\n it('should delete all auth keys by DC', async () => {\n await repo.set(2, key2)\n await repo.set(3, key3)\n\n await repo.setTemp(2, 0, key2i0, 1)\n await repo.setTemp(2, 1, key2i1, 1)\n await repo.setTemp(3, 0, key3i0, 1)\n await repo.setTemp(3, 1, key3i1, 1)\n\n await repo.deleteByDc(2)\n\n expect(fixBuffer(await repo.get(2))).toEqual(null)\n expect(fixBuffer(await repo.get(3))).toEqual(key3)\n\n expect(fixBuffer(await repo.getTemp(2, 0, 0))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(2, 1, 0))).toEqual(null)\n expect(fixBuffer(await repo.getTemp(3, 0, 0))).toEqual(key3i0)\n expect(fixBuffer(await repo.getTemp(3, 1, 0))).toEqual(key3i1)\n })\n })\n}\n"]}
|
package/cjs/storage/index.d.ts
DELETED
package/cjs/storage/index.js
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
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("./auth-keys.js"), exports);
|
|
18
|
-
__exportStar(require("./key-value.js"), exports);
|
|
19
|
-
__exportStar(require("./peers.js"), exports);
|
|
20
|
-
__exportStar(require("./ref-messages.js"), exports);
|
|
21
|
-
//# sourceMappingURL=index.js.map
|
package/cjs/storage/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/storage/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA8B;AAC9B,iDAA8B;AAC9B,6CAA0B;AAC1B,oDAAiC","sourcesContent":["export * from './auth-keys.js'\nexport * from './key-value.js'\nexport * from './peers.js'\nexport * from './ref-messages.js'\n"]}
|
package/cjs/storage/key-value.js
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.testKeyValueRepository = exports.fakeKeyValueRepository = void 0;
|
|
4
|
-
const vitest_1 = require("vitest");
|
|
5
|
-
function fakeKeyValueRepository() {
|
|
6
|
-
return {
|
|
7
|
-
get: vitest_1.vi.fn(),
|
|
8
|
-
set: vitest_1.vi.fn(),
|
|
9
|
-
delete: vitest_1.vi.fn(),
|
|
10
|
-
deleteAll: vitest_1.vi.fn(),
|
|
11
|
-
};
|
|
12
|
-
}
|
|
13
|
-
exports.fakeKeyValueRepository = fakeKeyValueRepository;
|
|
14
|
-
function fixBuffer(buf) {
|
|
15
|
-
if (!buf)
|
|
16
|
-
return buf;
|
|
17
|
-
// eslint-disable-next-line no-restricted-globals
|
|
18
|
-
return typeof Buffer !== 'undefined' && buf instanceof Buffer ? new Uint8Array(buf) : buf;
|
|
19
|
-
}
|
|
20
|
-
function testKeyValueRepository(repo, driver) {
|
|
21
|
-
(0, vitest_1.describe)('key-value', () => {
|
|
22
|
-
(0, vitest_1.afterEach)(() => repo.deleteAll());
|
|
23
|
-
(0, vitest_1.it)('should be empty by default', async () => {
|
|
24
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get('key'))).toEqual(null);
|
|
25
|
-
});
|
|
26
|
-
(0, vitest_1.it)('should store and retrieve values', async () => {
|
|
27
|
-
await repo.set('key', new Uint8Array([1, 2, 3]));
|
|
28
|
-
await driver.save?.();
|
|
29
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get('key'))).toEqual(new Uint8Array([1, 2, 3]));
|
|
30
|
-
});
|
|
31
|
-
(0, vitest_1.it)('should delete values', async () => {
|
|
32
|
-
await repo.set('key', new Uint8Array([1, 2, 3]));
|
|
33
|
-
await driver.save?.();
|
|
34
|
-
await repo.delete('key');
|
|
35
|
-
await driver.save?.();
|
|
36
|
-
(0, vitest_1.expect)(fixBuffer(await repo.get('key'))).toEqual(null);
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
exports.testKeyValueRepository = testKeyValueRepository;
|
|
41
|
-
//# sourceMappingURL=key-value.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-value.js","sourceRoot":"","sources":["../../../src/storage/key-value.ts"],"names":[],"mappings":";;;AAAA,mCAA4D;AAI5D,SAAgB,sBAAsB;IAClC,OAAO;QACH,GAAG,EAAE,WAAE,CAAC,EAAE,EAAE;QACZ,GAAG,EAAE,WAAE,CAAC,EAAE,EAAE;QACZ,MAAM,EAAE,WAAE,CAAC,EAAE,EAAE;QACf,SAAS,EAAE,WAAE,CAAC,EAAE,EAAE;KACrB,CAAA;AACL,CAAC;AAPD,wDAOC;AAED,SAAS,SAAS,CAAC,GAAsB;IACrC,IAAI,CAAC,GAAG;QAAE,OAAO,GAAG,CAAA;IAEpB,iDAAiD;IACjD,OAAO,OAAO,MAAM,KAAK,WAAW,IAAI,GAAG,YAAY,MAAM,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAA;AAC7F,CAAC;AAED,SAAgB,sBAAsB,CAAC,IAAyB,EAAE,MAAsB;IACpF,IAAA,iBAAQ,EAAC,WAAW,EAAE,GAAG,EAAE;QACvB,IAAA,kBAAS,EAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAEjC,IAAA,WAAE,EAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;YACxC,IAAA,eAAM,EAAC,SAAS,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAC1D,CAAC,CAAC,CAAA;QAEF,IAAA,WAAE,EAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;YAC9C,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;YAChD,MAAM,MAAM,CAAC,IAAI,EAAE,EAAE,CAAA;YAErB,IAAA,eAAM,EAAC,SAAS,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;QAC/E,CAAC,CAAC,CAAA;QAEF,IAAA,WAAE,EAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;YAClC,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAA;YAChD,MAAM,MAAM,CAAC,IAAI,EAAE,EAAE,CAAA;YAErB,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YACxB,MAAM,MAAM,CAAC,IAAI,EAAE,EAAE,CAAA;YAErB,IAAA,eAAM,EAAC,SAAS,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAC1D,CAAC,CAAC,CAAA;IACN,CAAC,CAAC,CAAA;AACN,CAAC;AAzBD,wDAyBC","sourcesContent":["import { afterEach, describe, expect, it, vi } from 'vitest'\n\nimport { IKeyValueRepository, IStorageDriver } from '@mtcute/core'\n\nexport function fakeKeyValueRepository(): IKeyValueRepository {\n return {\n get: vi.fn(),\n set: vi.fn(),\n delete: vi.fn(),\n deleteAll: vi.fn(),\n }\n}\n\nfunction fixBuffer(buf: Uint8Array | null): Uint8Array | null {\n if (!buf) return buf\n\n // eslint-disable-next-line no-restricted-globals\n return typeof Buffer !== 'undefined' && buf instanceof Buffer ? new Uint8Array(buf) : buf\n}\n\nexport function testKeyValueRepository(repo: IKeyValueRepository, driver: IStorageDriver) {\n describe('key-value', () => {\n afterEach(() => repo.deleteAll())\n\n it('should be empty by default', async () => {\n expect(fixBuffer(await repo.get('key'))).toEqual(null)\n })\n\n it('should store and retrieve values', async () => {\n await repo.set('key', new Uint8Array([1, 2, 3]))\n await driver.save?.()\n\n expect(fixBuffer(await repo.get('key'))).toEqual(new Uint8Array([1, 2, 3]))\n })\n\n it('should delete values', async () => {\n await repo.set('key', new Uint8Array([1, 2, 3]))\n await driver.save?.()\n\n await repo.delete('key')\n await driver.save?.()\n\n expect(fixBuffer(await repo.get('key'))).toEqual(null)\n })\n })\n}\n"]}
|
package/cjs/storage/peers.d.ts
DELETED
package/cjs/storage/peers.js
DELETED
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.testPeersRepository = exports.fakePeersRepository = void 0;
|
|
4
|
-
const vitest_1 = require("vitest");
|
|
5
|
-
const utils_js_1 = require("@mtcute/core/utils.js");
|
|
6
|
-
const writer_js_1 = require("@mtcute/tl/binary/writer.js");
|
|
7
|
-
const stub_js_1 = require("../stub.js");
|
|
8
|
-
function fakePeersRepository() {
|
|
9
|
-
return {
|
|
10
|
-
getById: vitest_1.vi.fn(),
|
|
11
|
-
getByUsername: vitest_1.vi.fn(),
|
|
12
|
-
getByPhone: vitest_1.vi.fn(),
|
|
13
|
-
store: vitest_1.vi.fn(),
|
|
14
|
-
deleteAll: vitest_1.vi.fn(),
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
exports.fakePeersRepository = fakePeersRepository;
|
|
18
|
-
function fixPeerInfo(peer) {
|
|
19
|
-
if (!peer)
|
|
20
|
-
return peer;
|
|
21
|
-
return {
|
|
22
|
-
...peer,
|
|
23
|
-
complete:
|
|
24
|
-
// eslint-disable-next-line no-restricted-globals
|
|
25
|
-
typeof Buffer !== 'undefined' && peer.complete instanceof Buffer ?
|
|
26
|
-
new Uint8Array(peer.complete) :
|
|
27
|
-
peer.complete,
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
function testPeersRepository(repo, driver) {
|
|
31
|
-
const stubPeerUser = {
|
|
32
|
-
id: 123123,
|
|
33
|
-
accessHash: '123|456',
|
|
34
|
-
usernames: ['some_user'],
|
|
35
|
-
phone: '78005553535',
|
|
36
|
-
updated: 666,
|
|
37
|
-
complete: utils_js_1.TlBinaryWriter.serializeObject(writer_js_1.__tlWriterMap, (0, stub_js_1.createStub)('user', { id: 123123 })),
|
|
38
|
-
};
|
|
39
|
-
const stubPeerChannel = {
|
|
40
|
-
id: -1001183945448,
|
|
41
|
-
accessHash: '666|555',
|
|
42
|
-
usernames: ['some_channel'],
|
|
43
|
-
updated: 777,
|
|
44
|
-
complete: utils_js_1.TlBinaryWriter.serializeObject(writer_js_1.__tlWriterMap, (0, stub_js_1.createStub)('channel', { id: 123123 })),
|
|
45
|
-
};
|
|
46
|
-
(0, vitest_1.describe)('peers', () => {
|
|
47
|
-
(0, vitest_1.it)('should be empty by default', async () => {
|
|
48
|
-
(0, vitest_1.expect)(await repo.getById(123123)).toEqual(null);
|
|
49
|
-
(0, vitest_1.expect)(await repo.getByUsername('some_user')).toEqual(null);
|
|
50
|
-
(0, vitest_1.expect)(await repo.getByPhone('phone')).toEqual(null);
|
|
51
|
-
});
|
|
52
|
-
(0, vitest_1.it)('should store and retrieve peers', async () => {
|
|
53
|
-
await repo.store(stubPeerUser);
|
|
54
|
-
await repo.store(stubPeerChannel);
|
|
55
|
-
await driver.save?.();
|
|
56
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getById(123123))).toEqual(stubPeerUser);
|
|
57
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getByUsername('some_user'))).toEqual(stubPeerUser);
|
|
58
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getByPhone('78005553535'))).toEqual(stubPeerUser);
|
|
59
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getById(-1001183945448))).toEqual(stubPeerChannel);
|
|
60
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getByUsername('some_channel'))).toEqual(stubPeerChannel);
|
|
61
|
-
});
|
|
62
|
-
(0, vitest_1.it)('should update peers usernames', async () => {
|
|
63
|
-
await repo.store(stubPeerUser);
|
|
64
|
-
await driver.save?.();
|
|
65
|
-
const modUser = { ...stubPeerUser, usernames: ['some_user2'] };
|
|
66
|
-
await repo.store(modUser);
|
|
67
|
-
await driver.save?.();
|
|
68
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getById(123123))).toEqual(modUser);
|
|
69
|
-
(0, vitest_1.expect)(await repo.getByUsername('some_user')).toEqual(null);
|
|
70
|
-
(0, vitest_1.expect)(fixPeerInfo(await repo.getByUsername('some_user2'))).toEqual(modUser);
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
exports.testPeersRepository = testPeersRepository;
|
|
75
|
-
//# sourceMappingURL=peers.js.map
|
package/cjs/storage/peers.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"peers.js","sourceRoot":"","sources":["../../../src/storage/peers.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, expect, it, vi } from 'vitest'\n\nimport { IPeersRepository, IStorageDriver } from '@mtcute/core'\nimport { TlBinaryWriter } from '@mtcute/core/utils.js'\nimport { __tlWriterMap } from '@mtcute/tl/binary/writer.js'\n\nimport { createStub } from '../stub.js'\n\nexport function fakePeersRepository(): IPeersRepository {\n return {\n getById: vi.fn(),\n getByUsername: vi.fn(),\n getByPhone: vi.fn(),\n store: vi.fn(),\n deleteAll: vi.fn(),\n }\n}\n\nfunction fixPeerInfo(peer: IPeersRepository.PeerInfo | null): IPeersRepository.PeerInfo | null {\n if (!peer) return peer\n\n return {\n ...peer,\n complete:\n // eslint-disable-next-line no-restricted-globals\n typeof Buffer !== 'undefined' && peer.complete instanceof Buffer ?\n new Uint8Array(peer.complete) :\n peer.complete,\n }\n}\n\nexport function testPeersRepository(repo: IPeersRepository, driver: IStorageDriver) {\n const stubPeerUser: IPeersRepository.PeerInfo = {\n id: 123123,\n accessHash: '123|456',\n usernames: ['some_user'],\n phone: '78005553535',\n updated: 666,\n complete: TlBinaryWriter.serializeObject(__tlWriterMap, createStub('user', { id: 123123 })),\n }\n\n const stubPeerChannel: IPeersRepository.PeerInfo = {\n id: -1001183945448,\n accessHash: '666|555',\n usernames: ['some_channel'],\n updated: 777,\n complete: TlBinaryWriter.serializeObject(__tlWriterMap, createStub('channel', { id: 123123 })),\n }\n\n describe('peers', () => {\n it('should be empty by default', async () => {\n expect(await repo.getById(123123)).toEqual(null)\n expect(await repo.getByUsername('some_user')).toEqual(null)\n expect(await repo.getByPhone('phone')).toEqual(null)\n })\n\n it('should store and retrieve peers', async () => {\n await repo.store(stubPeerUser)\n await repo.store(stubPeerChannel)\n await driver.save?.()\n\n expect(fixPeerInfo(await repo.getById(123123))).toEqual(stubPeerUser)\n expect(fixPeerInfo(await repo.getByUsername('some_user'))).toEqual(stubPeerUser)\n expect(fixPeerInfo(await repo.getByPhone('78005553535'))).toEqual(stubPeerUser)\n\n expect(fixPeerInfo(await repo.getById(-1001183945448))).toEqual(stubPeerChannel)\n expect(fixPeerInfo(await repo.getByUsername('some_channel'))).toEqual(stubPeerChannel)\n })\n\n it('should update peers usernames', async () => {\n await repo.store(stubPeerUser)\n await driver.save?.()\n\n const modUser = { ...stubPeerUser, usernames: ['some_user2'] }\n await repo.store(modUser)\n await driver.save?.()\n\n expect(fixPeerInfo(await repo.getById(123123))).toEqual(modUser)\n expect(await repo.getByUsername('some_user')).toEqual(null)\n expect(fixPeerInfo(await repo.getByUsername('some_user2'))).toEqual(modUser)\n })\n })\n}\n"]}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { IReferenceMessagesRepository, IStorageDriver } from '@mtcute/core';
|
|
2
|
-
export declare function fakeRefMessagesRepository(): IReferenceMessagesRepository;
|
|
3
|
-
export declare function testRefMessagesRepository(repo: IReferenceMessagesRepository, driver: IStorageDriver): void;
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.testRefMessagesRepository = exports.fakeRefMessagesRepository = void 0;
|
|
4
|
-
const vitest_1 = require("vitest");
|
|
5
|
-
function fakeRefMessagesRepository() {
|
|
6
|
-
return {
|
|
7
|
-
store: vitest_1.vi.fn(),
|
|
8
|
-
getByPeer: vitest_1.vi.fn(),
|
|
9
|
-
delete: vitest_1.vi.fn(),
|
|
10
|
-
deleteByPeer: vitest_1.vi.fn(),
|
|
11
|
-
deleteAll: vitest_1.vi.fn(),
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
exports.fakeRefMessagesRepository = fakeRefMessagesRepository;
|
|
15
|
-
function testRefMessagesRepository(repo, driver) {
|
|
16
|
-
(0, vitest_1.describe)('IReferenceMessagesRepository', () => {
|
|
17
|
-
(0, vitest_1.afterEach)(() => repo.deleteAll());
|
|
18
|
-
(0, vitest_1.it)('should be empty by default', async () => {
|
|
19
|
-
(0, vitest_1.expect)(await repo.getByPeer(1)).toEqual(null);
|
|
20
|
-
});
|
|
21
|
-
(0, vitest_1.it)('should store and retrieve reference messages', async () => {
|
|
22
|
-
await repo.store(1, 2, 3);
|
|
23
|
-
await repo.store(1, 4, 5);
|
|
24
|
-
await repo.store(2, 6, 7);
|
|
25
|
-
await driver.save?.();
|
|
26
|
-
(0, vitest_1.expect)(await repo.getByPeer(1)).deep.oneOf([
|
|
27
|
-
[2, 3],
|
|
28
|
-
[4, 5],
|
|
29
|
-
]);
|
|
30
|
-
(0, vitest_1.expect)(await repo.getByPeer(2)).toEqual([6, 7]);
|
|
31
|
-
(0, vitest_1.expect)(await repo.getByPeer(3)).toEqual(null);
|
|
32
|
-
(0, vitest_1.expect)(await repo.getByPeer(4)).toEqual(null);
|
|
33
|
-
(0, vitest_1.expect)(await repo.getByPeer(5)).toEqual(null);
|
|
34
|
-
(0, vitest_1.expect)(await repo.getByPeer(6)).toEqual(null);
|
|
35
|
-
(0, vitest_1.expect)(await repo.getByPeer(7)).toEqual(null);
|
|
36
|
-
});
|
|
37
|
-
(0, vitest_1.it)('should delete reference messages', async () => {
|
|
38
|
-
await repo.store(1, 2, 3);
|
|
39
|
-
await repo.store(1, 4, 5);
|
|
40
|
-
await repo.store(2, 6, 7);
|
|
41
|
-
await driver.save?.();
|
|
42
|
-
await repo.delete(4, [5]);
|
|
43
|
-
await driver.save?.();
|
|
44
|
-
(0, vitest_1.expect)(await repo.getByPeer(1)).toEqual([2, 3]);
|
|
45
|
-
await repo.delete(2, [2, 3, 4]);
|
|
46
|
-
await driver.save?.();
|
|
47
|
-
(0, vitest_1.expect)(await repo.getByPeer(1)).toEqual(null);
|
|
48
|
-
});
|
|
49
|
-
(0, vitest_1.it)('should delete all reference messages for a peer', async () => {
|
|
50
|
-
await repo.store(1, 2, 3);
|
|
51
|
-
await repo.store(1, 4, 5);
|
|
52
|
-
await repo.store(1, 6, 7);
|
|
53
|
-
await repo.store(2, 20, 30);
|
|
54
|
-
await repo.store(2, 40, 50);
|
|
55
|
-
await repo.store(2, 60, 70);
|
|
56
|
-
await driver.save?.();
|
|
57
|
-
await repo.deleteByPeer(1);
|
|
58
|
-
await driver.save?.();
|
|
59
|
-
(0, vitest_1.expect)(await repo.getByPeer(1)).toEqual(null);
|
|
60
|
-
(0, vitest_1.expect)(await repo.getByPeer(2)).deep.oneOf([
|
|
61
|
-
[20, 30],
|
|
62
|
-
[40, 50],
|
|
63
|
-
[60, 70],
|
|
64
|
-
]);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
exports.testRefMessagesRepository = testRefMessagesRepository;
|
|
69
|
-
//# sourceMappingURL=ref-messages.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ref-messages.js","sourceRoot":"","sources":["../../../src/storage/ref-messages.ts"],"names":[],"mappings":"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","sourcesContent":["import { afterEach, describe, expect, it, vi } from 'vitest'\n\nimport { IReferenceMessagesRepository, IStorageDriver } from '@mtcute/core'\n\nexport function fakeRefMessagesRepository(): IReferenceMessagesRepository {\n return {\n store: vi.fn(),\n getByPeer: vi.fn(),\n delete: vi.fn(),\n deleteByPeer: vi.fn(),\n deleteAll: vi.fn(),\n }\n}\n\nexport function testRefMessagesRepository(repo: IReferenceMessagesRepository, driver: IStorageDriver) {\n describe('IReferenceMessagesRepository', () => {\n afterEach(() => repo.deleteAll())\n\n it('should be empty by default', async () => {\n expect(await repo.getByPeer(1)).toEqual(null)\n })\n\n it('should store and retrieve reference messages', async () => {\n await repo.store(1, 2, 3)\n await repo.store(1, 4, 5)\n await repo.store(2, 6, 7)\n await driver.save?.()\n\n expect(await repo.getByPeer(1)).deep.oneOf([\n [2, 3],\n [4, 5],\n ])\n expect(await repo.getByPeer(2)).toEqual([6, 7])\n expect(await repo.getByPeer(3)).toEqual(null)\n expect(await repo.getByPeer(4)).toEqual(null)\n expect(await repo.getByPeer(5)).toEqual(null)\n expect(await repo.getByPeer(6)).toEqual(null)\n expect(await repo.getByPeer(7)).toEqual(null)\n })\n\n it('should delete reference messages', async () => {\n await repo.store(1, 2, 3)\n await repo.store(1, 4, 5)\n await repo.store(2, 6, 7)\n await driver.save?.()\n\n await repo.delete(4, [5])\n await driver.save?.()\n expect(await repo.getByPeer(1)).toEqual([2, 3])\n\n await repo.delete(2, [2, 3, 4])\n await driver.save?.()\n expect(await repo.getByPeer(1)).toEqual(null)\n })\n\n it('should delete all reference messages for a peer', async () => {\n await repo.store(1, 2, 3)\n await repo.store(1, 4, 5)\n await repo.store(1, 6, 7)\n\n await repo.store(2, 20, 30)\n await repo.store(2, 40, 50)\n await repo.store(2, 60, 70)\n await driver.save?.()\n\n await repo.deleteByPeer(1)\n await driver.save?.()\n expect(await repo.getByPeer(1)).toEqual(null)\n expect(await repo.getByPeer(2)).deep.oneOf([\n [20, 30],\n [40, 50],\n [60, 70],\n ])\n })\n })\n}\n"]}
|
package/cjs/storage.d.ts
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { MemoryStorage } from '@mtcute/core';
|
|
2
|
-
import { ICryptoProvider } from '@mtcute/core/utils.js';
|
|
3
|
-
export declare class StubMemoryTelegramStorage extends MemoryStorage {
|
|
4
|
-
readonly params: {
|
|
5
|
-
/**
|
|
6
|
-
* IDs of the DCs for which the storage should have auth keys,
|
|
7
|
-
* or `true` to have keys for all DCs
|
|
8
|
-
*
|
|
9
|
-
* @default true
|
|
10
|
-
*/
|
|
11
|
-
hasKeys?: boolean | number[];
|
|
12
|
-
/**
|
|
13
|
-
* IDs of the DCs for which the storage should have temp auth keys,
|
|
14
|
-
* or `true` to have keys for all DCs
|
|
15
|
-
*
|
|
16
|
-
* @default true
|
|
17
|
-
*/
|
|
18
|
-
hasTempKeys?: boolean | number[];
|
|
19
|
-
};
|
|
20
|
-
constructor(params?: {
|
|
21
|
-
/**
|
|
22
|
-
* IDs of the DCs for which the storage should have auth keys,
|
|
23
|
-
* or `true` to have keys for all DCs
|
|
24
|
-
*
|
|
25
|
-
* @default true
|
|
26
|
-
*/
|
|
27
|
-
hasKeys?: boolean | number[];
|
|
28
|
-
/**
|
|
29
|
-
* IDs of the DCs for which the storage should have temp auth keys,
|
|
30
|
-
* or `true` to have keys for all DCs
|
|
31
|
-
*
|
|
32
|
-
* @default true
|
|
33
|
-
*/
|
|
34
|
-
hasTempKeys?: boolean | number[];
|
|
35
|
-
});
|
|
36
|
-
decryptOutgoingMessage(crypto: ICryptoProvider, data: Uint8Array, dcId: number, tempIndex?: number | undefined): Uint8Array;
|
|
37
|
-
}
|
package/cjs/storage.js
DELETED
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.StubMemoryTelegramStorage = void 0;
|
|
4
|
-
const core_1 = require("@mtcute/core");
|
|
5
|
-
const utils_js_1 = require("@mtcute/core/utils.js");
|
|
6
|
-
class StubMemoryTelegramStorage extends core_1.MemoryStorage {
|
|
7
|
-
constructor(params = {
|
|
8
|
-
hasKeys: true,
|
|
9
|
-
hasTempKeys: true,
|
|
10
|
-
}) {
|
|
11
|
-
super();
|
|
12
|
-
this.params = params;
|
|
13
|
-
const _origGet = this.authKeys.get;
|
|
14
|
-
this.authKeys.get = (dcId) => {
|
|
15
|
-
if (this.params.hasKeys) {
|
|
16
|
-
if (this.params.hasKeys === true || this.params.hasKeys.includes(dcId)) {
|
|
17
|
-
return new Uint8Array(256);
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return _origGet.call(this.authKeys, dcId);
|
|
21
|
-
};
|
|
22
|
-
const _origGetTemp = this.authKeys.getTemp;
|
|
23
|
-
this.authKeys.getTemp = (dcId, idx, now) => {
|
|
24
|
-
if (this.params.hasTempKeys) {
|
|
25
|
-
if (this.params.hasTempKeys === true || this.params.hasTempKeys.includes(dcId)) {
|
|
26
|
-
return new Uint8Array(256);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
return _origGetTemp.call(this.authKeys, dcId, idx, now);
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
decryptOutgoingMessage(crypto, data, dcId, tempIndex) {
|
|
33
|
-
const key = tempIndex ? this.authKeys.getTemp(dcId, tempIndex, Date.now()) : this.authKeys.get(dcId);
|
|
34
|
-
if (!key) {
|
|
35
|
-
throw new core_1.MtArgumentError(`No auth key for DC ${dcId}`);
|
|
36
|
-
}
|
|
37
|
-
const messageKey = data.subarray(8, 24);
|
|
38
|
-
const encryptedData = data.subarray(24);
|
|
39
|
-
const ige = (0, utils_js_1.createAesIgeForMessage)(crypto, key, messageKey, true);
|
|
40
|
-
const innerData = ige.decrypt(encryptedData);
|
|
41
|
-
// skipping all checks because who cares
|
|
42
|
-
const dv = new DataView(innerData.buffer, innerData.byteOffset, innerData.byteLength);
|
|
43
|
-
const length = dv.getUint32(28, true);
|
|
44
|
-
return innerData.subarray(32, 32 + length);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
exports.StubMemoryTelegramStorage = StubMemoryTelegramStorage;
|
|
48
|
-
//# sourceMappingURL=storage.js.map
|
package/cjs/storage.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storage.js","sourceRoot":"","sources":["../../src/storage.ts"],"names":[],"mappings":";;;AAAA,uCAA6D;AAC7D,oDAA+E;AAE/E,MAAa,yBAA0B,SAAQ,oBAAa;IACxD,YACa,SAgBL;QACA,OAAO,EAAE,IAAI;QACb,WAAW,EAAE,IAAI;KACpB;QAED,KAAK,EAAE,CAAA;QArBE,WAAM,GAAN,MAAM,CAmBd;QAID,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAA;QAElC,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE;YACzB,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBACrB,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBACpE,OAAO,IAAI,UAAU,CAAC,GAAG,CAAC,CAAA;iBAC7B;aACJ;YAED,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAA;QAC7C,CAAC,CAAA;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAA;QAE1C,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YACvC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;gBACzB,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBAC5E,OAAO,IAAI,UAAU,CAAC,GAAG,CAAC,CAAA;iBAC7B;aACJ;YAED,OAAO,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;QAC3D,CAAC,CAAA;IACL,CAAC;IAED,sBAAsB,CAAC,MAAuB,EAAE,IAAgB,EAAE,IAAY,EAAE,SAA8B;QAC1G,MAAM,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAEpG,IAAI,CAAC,GAAG,EAAE;YACN,MAAM,IAAI,sBAAe,CAAC,sBAAsB,IAAI,EAAE,CAAC,CAAA;SAC1D;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;QACvC,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAEvC,MAAM,GAAG,GAAG,IAAA,iCAAsB,EAAC,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;QACjE,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;QAE5C,wCAAwC;QACxC,MAAM,EAAE,GAAG,IAAI,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,UAAU,CAAC,CAAA;QACrF,MAAM,MAAM,GAAG,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,CAAA;QAErC,OAAO,SAAS,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,MAAM,CAAC,CAAA;IAC9C,CAAC;CACJ;AArED,8DAqEC","sourcesContent":["import { MemoryStorage, MtArgumentError } from '@mtcute/core'\nimport { createAesIgeForMessage, ICryptoProvider } from '@mtcute/core/utils.js'\n\nexport class StubMemoryTelegramStorage extends MemoryStorage {\n constructor(\n readonly params: {\n /**\n * IDs of the DCs for which the storage should have auth keys,\n * or `true` to have keys for all DCs\n *\n * @default true\n */\n hasKeys?: boolean | number[]\n\n /**\n * IDs of the DCs for which the storage should have temp auth keys,\n * or `true` to have keys for all DCs\n *\n * @default true\n */\n hasTempKeys?: boolean | number[]\n } = {\n hasKeys: true,\n hasTempKeys: true,\n },\n ) {\n super()\n\n const _origGet = this.authKeys.get\n\n this.authKeys.get = (dcId) => {\n if (this.params.hasKeys) {\n if (this.params.hasKeys === true || this.params.hasKeys.includes(dcId)) {\n return new Uint8Array(256)\n }\n }\n\n return _origGet.call(this.authKeys, dcId)\n }\n\n const _origGetTemp = this.authKeys.getTemp\n\n this.authKeys.getTemp = (dcId, idx, now) => {\n if (this.params.hasTempKeys) {\n if (this.params.hasTempKeys === true || this.params.hasTempKeys.includes(dcId)) {\n return new Uint8Array(256)\n }\n }\n\n return _origGetTemp.call(this.authKeys, dcId, idx, now)\n }\n }\n\n decryptOutgoingMessage(crypto: ICryptoProvider, data: Uint8Array, dcId: number, tempIndex?: number | undefined) {\n const key = tempIndex ? this.authKeys.getTemp(dcId, tempIndex, Date.now()) : this.authKeys.get(dcId)\n\n if (!key) {\n throw new MtArgumentError(`No auth key for DC ${dcId}`)\n }\n\n const messageKey = data.subarray(8, 24)\n const encryptedData = data.subarray(24)\n\n const ige = createAesIgeForMessage(crypto, key, messageKey, true)\n const innerData = ige.decrypt(encryptedData)\n\n // skipping all checks because who cares\n const dv = new DataView(innerData.buffer, innerData.byteOffset, innerData.byteLength)\n const length = dv.getUint32(28, true)\n\n return innerData.subarray(32, 32 + length)\n }\n}\n"]}
|
package/cjs/stub.d.ts
DELETED
package/cjs/stub.js
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.createStub = void 0;
|
|
7
|
-
const long_1 = __importDefault(require("long"));
|
|
8
|
-
const schema_js_1 = require("./schema.js");
|
|
9
|
-
function getDefaultFor(arg) {
|
|
10
|
-
if (arg.typeModifiers?.isVector || arg.typeModifiers?.isBareVector) {
|
|
11
|
-
return [];
|
|
12
|
-
}
|
|
13
|
-
if (arg.typeModifiers?.predicate) {
|
|
14
|
-
return arg.type === 'true' ? false : undefined;
|
|
15
|
-
}
|
|
16
|
-
switch (arg.type) {
|
|
17
|
-
case 'int':
|
|
18
|
-
case 'int53':
|
|
19
|
-
case 'double':
|
|
20
|
-
return 0;
|
|
21
|
-
case 'long':
|
|
22
|
-
return long_1.default.ZERO;
|
|
23
|
-
case 'int128':
|
|
24
|
-
return new Uint8Array(16);
|
|
25
|
-
case 'int256':
|
|
26
|
-
return new Uint8Array(32);
|
|
27
|
-
case 'string':
|
|
28
|
-
return '';
|
|
29
|
-
case 'bytes':
|
|
30
|
-
return new Uint8Array(0);
|
|
31
|
-
case 'Bool':
|
|
32
|
-
case 'bool':
|
|
33
|
-
return false;
|
|
34
|
-
default: {
|
|
35
|
-
const union = (0, schema_js_1.getEntriesMap)().unions.get(arg.type);
|
|
36
|
-
if (!union)
|
|
37
|
-
throw new Error(`Unknown type ${arg.type}`);
|
|
38
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
39
|
-
return createStub(union[0].name);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
const snakeToCamel = (s) => {
|
|
44
|
-
return s.replace(/(?<!^|_)(_[a-z0-9])/gi, ($1) => {
|
|
45
|
-
return $1.substring(1).toUpperCase();
|
|
46
|
-
});
|
|
47
|
-
};
|
|
48
|
-
function createStub(name, partial = {}) {
|
|
49
|
-
const { entries } = (0, schema_js_1.getEntriesMap)();
|
|
50
|
-
const entry = entries.get(name);
|
|
51
|
-
if (!entry)
|
|
52
|
-
throw new Error(`Entry ${name} is unknown`);
|
|
53
|
-
const ret = {
|
|
54
|
-
_: name,
|
|
55
|
-
};
|
|
56
|
-
for (const arg of entry.arguments) {
|
|
57
|
-
if (arg.type === '#')
|
|
58
|
-
continue;
|
|
59
|
-
if (arg.name in partial)
|
|
60
|
-
continue;
|
|
61
|
-
ret[snakeToCamel(arg.name)] = getDefaultFor(arg);
|
|
62
|
-
}
|
|
63
|
-
for (const key in partial) {
|
|
64
|
-
// @ts-expect-error partial is not a full object
|
|
65
|
-
ret[key] = partial[key];
|
|
66
|
-
}
|
|
67
|
-
// eslint-disable-next-line
|
|
68
|
-
return ret;
|
|
69
|
-
}
|
|
70
|
-
exports.createStub = createStub;
|
|
71
|
-
//# sourceMappingURL=stub.js.map
|