1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | const tslib_1 = require("tslib");
|
4 | const node_storage_common_1 = require("@neo-one/node-storage-common");
|
5 | const utils_1 = require("@neo-one/utils");
|
6 | const lru_cache_1 = tslib_1.__importDefault(require("lru-cache"));
|
7 | const convertChange_1 = require("./convertChange");
|
8 | const read = tslib_1.__importStar(require("./read"));
|
9 | exports.cacheStorage = ({ environment, storage, }) => {
|
10 | // tslint:disable-next-line no-any
|
11 | const cache = new lru_cache_1.default({
|
12 | max: environment.maxSizeBytes,
|
13 | });
|
14 | const serializeHeaderKey = ({ hashOrIndex }) => typeof hashOrIndex === 'number'
|
15 | ? `header:${hashOrIndex}`
|
16 | : node_storage_common_1.keys.typeKeyToSerializeKey.header({ hash: hashOrIndex });
|
17 | const headerBase = read.createReadStorage({
|
18 | cache,
|
19 | storage: storage.header,
|
20 | serializeKeyString: serializeHeaderKey,
|
21 | });
|
22 | const header = {
|
23 | get: headerBase.get,
|
24 | tryGet: headerBase.tryGet,
|
25 | tryGetLatest: storage.header.tryGetLatest,
|
26 | };
|
27 | const serializeBlockKey = ({ hashOrIndex }) => typeof hashOrIndex === 'number' ? `block:${hashOrIndex}` : node_storage_common_1.keys.typeKeyToSerializeKey.block({ hash: hashOrIndex });
|
28 | const blockBase = read.createReadStorage({
|
29 | cache,
|
30 | storage: storage.block,
|
31 | serializeKeyString: serializeBlockKey,
|
32 | });
|
33 | const block = {
|
34 | get: blockBase.get,
|
35 | tryGet: blockBase.tryGet,
|
36 | tryGetLatest: storage.block.tryGetLatest,
|
37 | };
|
38 | return {
|
39 | header,
|
40 | block,
|
41 | blockData: read.createReadStorage({
|
42 | cache,
|
43 | storage: storage.blockData,
|
44 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.blockData,
|
45 | }),
|
46 | account: read.createReadAllStorage({
|
47 | cache,
|
48 | storage: storage.account,
|
49 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.account,
|
50 | }),
|
51 | accountUnspent: storage.accountUnspent,
|
52 | accountUnclaimed: storage.accountUnclaimed,
|
53 | action: storage.action,
|
54 | asset: read.createReadStorage({
|
55 | cache,
|
56 | storage: storage.asset,
|
57 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.asset,
|
58 | }),
|
59 | transaction: read.createReadStorage({
|
60 | cache,
|
61 | storage: storage.transaction,
|
62 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.transaction,
|
63 | }),
|
64 | transactionData: read.createReadStorage({
|
65 | cache,
|
66 | storage: storage.transactionData,
|
67 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.transactionData,
|
68 | }),
|
69 | output: read.createReadStorage({
|
70 | cache,
|
71 | storage: storage.output,
|
72 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.output,
|
73 | }),
|
74 | contract: read.createReadStorage({
|
75 | cache,
|
76 | storage: storage.contract,
|
77 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.contract,
|
78 | }),
|
79 | storageItem: read.createReadGetAllStorage({
|
80 | cache,
|
81 | storage: storage.storageItem,
|
82 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.storageItem,
|
83 | }),
|
84 | validator: read.createReadAllStorage({
|
85 | cache,
|
86 | storage: storage.validator,
|
87 | serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKey.validator,
|
88 | }),
|
89 | invocationData: storage.invocationData,
|
90 | validatorsCount: storage.validatorsCount,
|
91 | async close() {
|
92 | await storage.close();
|
93 | },
|
94 | async commit(changeSet) {
|
95 | const changesList = changeSet.map(convertChange_1.convertChange);
|
96 | // tslint:disable-next-line no-loop-statement
|
97 | for (const changes of changesList) {
|
98 | // tslint:disable-next-line no-loop-statement
|
99 | for (const change of changes) {
|
100 | switch (change.type) {
|
101 | case 'add':
|
102 | cache.set(change.key, change.value);
|
103 | break;
|
104 | case 'delete':
|
105 | cache.del(change.key);
|
106 | break;
|
107 | default:
|
108 | utils_1.utils.assertNever(change);
|
109 | throw new Error('For TS');
|
110 | }
|
111 | }
|
112 | }
|
113 | await storage.commit(changeSet);
|
114 | },
|
115 | async reset() {
|
116 | cache.reset();
|
117 | await storage.reset();
|
118 | },
|
119 | };
|
120 | };
|
121 |
|
122 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["cacheStorage.ts"],"names":[],"mappings":"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","file":"neo-one-node-storage-cache/src/cacheStorage.js","sourcesContent":["import { UInt256 } from '@neo-one/client-common';\nimport { Storage } from '@neo-one/node-core';\nimport { keys } from '@neo-one/node-storage-common';\nimport { utils } from '@neo-one/utils';\nimport LRUCache from 'lru-cache';\nimport { convertChange } from './convertChange';\nimport * as read from './read';\nexport interface Environment {\n  readonly maxSizeBytes: number;\n}\n\nexport const cacheStorage = ({\n  environment,\n  storage,\n}: {\n  readonly environment: Environment;\n  readonly storage: Storage;\n}): Storage => {\n  // tslint:disable-next-line no-any\n  const cache = new LRUCache<string, any>({\n    max: environment.maxSizeBytes,\n    // length: (value, key) => value.size + Buffer.byteLength(key, 'utf8'),\n  });\n\n  const serializeHeaderKey = ({ hashOrIndex }: { hashOrIndex: number | UInt256 }) =>\n    typeof hashOrIndex === 'number'\n      ? `header:${hashOrIndex}`\n      : keys.typeKeyToSerializeKey.header({ hash: hashOrIndex });\n\n  const headerBase = read.createReadStorage({\n    cache,\n    storage: storage.header,\n    serializeKeyString: serializeHeaderKey,\n  });\n\n  const header = {\n    get: headerBase.get,\n    tryGet: headerBase.tryGet,\n    tryGetLatest: storage.header.tryGetLatest,\n  };\n\n  const serializeBlockKey = ({ hashOrIndex }: { hashOrIndex: number | UInt256 }) =>\n    typeof hashOrIndex === 'number' ? `block:${hashOrIndex}` : keys.typeKeyToSerializeKey.block({ hash: hashOrIndex });\n\n  const blockBase = read.createReadStorage({\n    cache,\n    storage: storage.block,\n    serializeKeyString: serializeBlockKey,\n  });\n\n  const block = {\n    get: blockBase.get,\n    tryGet: blockBase.tryGet,\n    tryGetLatest: storage.block.tryGetLatest,\n  };\n\n  return {\n    header,\n    block,\n    blockData: read.createReadStorage({\n      cache,\n      storage: storage.blockData,\n      serializeKeyString: keys.typeKeyToSerializeKey.blockData,\n    }),\n\n    account: read.createReadAllStorage({\n      cache,\n      storage: storage.account,\n      serializeKeyString: keys.typeKeyToSerializeKey.account,\n    }),\n\n    accountUnspent: storage.accountUnspent,\n    accountUnclaimed: storage.accountUnclaimed,\n    action: storage.action,\n    asset: read.createReadStorage({\n      cache,\n      storage: storage.asset,\n      serializeKeyString: keys.typeKeyToSerializeKey.asset,\n    }),\n\n    transaction: read.createReadStorage({\n      cache,\n      storage: storage.transaction,\n      serializeKeyString: keys.typeKeyToSerializeKey.transaction,\n    }),\n\n    transactionData: read.createReadStorage({\n      cache,\n      storage: storage.transactionData,\n      serializeKeyString: keys.typeKeyToSerializeKey.transactionData,\n    }),\n\n    output: read.createReadStorage({\n      cache,\n      storage: storage.output,\n      serializeKeyString: keys.typeKeyToSerializeKey.output,\n    }),\n\n    contract: read.createReadStorage({\n      cache,\n      storage: storage.contract,\n      serializeKeyString: keys.typeKeyToSerializeKey.contract,\n    }),\n\n    storageItem: read.createReadGetAllStorage({\n      cache,\n      storage: storage.storageItem,\n      serializeKeyString: keys.typeKeyToSerializeKey.storageItem,\n    }),\n\n    validator: read.createReadAllStorage({\n      cache,\n      storage: storage.validator,\n      serializeKeyString: keys.typeKeyToSerializeKey.validator,\n    }),\n\n    invocationData: storage.invocationData,\n    validatorsCount: storage.validatorsCount,\n    async close(): Promise<void> {\n      await storage.close();\n    },\n    async commit(changeSet): Promise<void> {\n      const changesList = changeSet.map(convertChange);\n      // tslint:disable-next-line no-loop-statement\n      for (const changes of changesList) {\n        // tslint:disable-next-line no-loop-statement\n        for (const change of changes) {\n          switch (change.type) {\n            case 'add':\n              cache.set(change.key, change.value);\n              break;\n            case 'delete':\n              cache.del(change.key);\n              break;\n            default:\n              utils.assertNever(change);\n              throw new Error('For TS');\n          }\n        }\n      }\n      await storage.commit(changeSet);\n    },\n    async reset(): Promise<void> {\n      cache.reset();\n      await storage.reset();\n    },\n  };\n};\n"]}
|