UNPKG

15.4 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const tslib_1 = require("tslib");
4const node_storage_common_1 = require("@neo-one/node-storage-common");
5const utils_1 = require("@neo-one/utils");
6const lru_cache_1 = tslib_1.__importDefault(require("lru-cache"));
7const convertChange_1 = require("./convertChange");
8const read = tslib_1.__importStar(require("./read"));
9exports.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.typeKeyToSerializeKeyString.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'
28 ? `block:${hashOrIndex}`
29 : node_storage_common_1.keys.typeKeyToSerializeKeyString.block({ hash: hashOrIndex });
30 const blockBase = read.createReadStorage({
31 cache,
32 storage: storage.block,
33 serializeKeyString: serializeBlockKey,
34 });
35 const block = {
36 get: blockBase.get,
37 tryGet: blockBase.tryGet,
38 tryGetLatest: storage.block.tryGetLatest,
39 };
40 return {
41 header,
42 block,
43 blockData: read.createReadStorage({
44 cache,
45 storage: storage.blockData,
46 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.blockData,
47 }),
48 account: read.createReadAllStorage({
49 cache,
50 storage: storage.account,
51 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.account,
52 }),
53 accountUnspent: storage.accountUnspent,
54 accountUnclaimed: storage.accountUnclaimed,
55 action: storage.action,
56 asset: read.createReadStorage({
57 cache,
58 storage: storage.asset,
59 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.asset,
60 }),
61 transaction: read.createReadStorage({
62 cache,
63 storage: storage.transaction,
64 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.transaction,
65 }),
66 transactionData: read.createReadStorage({
67 cache,
68 storage: storage.transactionData,
69 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.transactionData,
70 }),
71 output: read.createReadStorage({
72 cache,
73 storage: storage.output,
74 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.output,
75 }),
76 contract: read.createReadStorage({
77 cache,
78 storage: storage.contract,
79 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.contract,
80 }),
81 storageItem: read.createReadGetAllStorage({
82 cache,
83 storage: storage.storageItem,
84 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.storageItem,
85 }),
86 validator: read.createReadAllStorage({
87 cache,
88 storage: storage.validator,
89 serializeKeyString: node_storage_common_1.keys.typeKeyToSerializeKeyString.validator,
90 }),
91 invocationData: storage.invocationData,
92 validatorsCount: storage.validatorsCount,
93 async close() {
94 await storage.close();
95 },
96 async commit(changeSet) {
97 const changesList = changeSet.map(convertChange_1.convertChange);
98 // tslint:disable-next-line no-loop-statement
99 for (const changes of changesList) {
100 // tslint:disable-next-line no-loop-statement
101 for (const change of changes) {
102 switch (change.type) {
103 case 'add':
104 cache.set(change.key, change.value);
105 break;
106 case 'delete':
107 cache.del(change.key);
108 break;
109 default:
110 utils_1.utils.assertNever(change);
111 throw new Error('For TS');
112 }
113 }
114 }
115 await storage.commit(changeSet);
116 },
117 async reset() {
118 cache.reset();
119 await storage.reset();
120 },
121 };
122};
123
124//# 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.typeKeyToSerializeKeyString.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'\n      ? `block:${hashOrIndex}`\n      : keys.typeKeyToSerializeKeyString.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.typeKeyToSerializeKeyString.blockData,\n    }),\n\n    account: read.createReadAllStorage({\n      cache,\n      storage: storage.account,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.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.typeKeyToSerializeKeyString.asset,\n    }),\n\n    transaction: read.createReadStorage({\n      cache,\n      storage: storage.transaction,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.transaction,\n    }),\n\n    transactionData: read.createReadStorage({\n      cache,\n      storage: storage.transactionData,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.transactionData,\n    }),\n\n    output: read.createReadStorage({\n      cache,\n      storage: storage.output,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.output,\n    }),\n\n    contract: read.createReadStorage({\n      cache,\n      storage: storage.contract,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.contract,\n    }),\n\n    storageItem: read.createReadGetAllStorage({\n      cache,\n      storage: storage.storageItem,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.storageItem,\n    }),\n\n    validator: read.createReadAllStorage({\n      cache,\n      storage: storage.validator,\n      serializeKeyString: keys.typeKeyToSerializeKeyString.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"]}