tovarish-relayer/lib/services/data.js

152 lines
4.7 KiB
JavaScript
Vendored

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.existsAsync = existsAsync;
exports.zipAsync = zipAsync;
exports.unzipAsync = unzipAsync;
exports.saveUserFile = saveUserFile;
exports.saveLastBlock = saveLastBlock;
exports.loadLastBlock = loadLastBlock;
exports.loadSavedEvents = loadSavedEvents;
exports.download = download;
exports.loadCachedEvents = loadCachedEvents;
const path_1 = __importDefault(require("path"));
const promises_1 = require("fs/promises");
const fflate_1 = require("fflate");
async function existsAsync(fileOrDir) {
try {
await (0, promises_1.stat)(fileOrDir);
return true;
}
catch {
return false;
}
}
function zipAsync(file) {
return new Promise((res, rej) => {
(0, fflate_1.zip)(file, { mtime: new Date('1/1/1980') }, (err, data) => {
if (err) {
rej(err);
return;
}
res(data);
});
});
}
function unzipAsync(data) {
return new Promise((res, rej) => {
(0, fflate_1.unzip)(data, {}, (err, data) => {
if (err) {
rej(err);
return;
}
res(data);
});
});
}
async function saveUserFile({ fileName, userDirectory, dataString, lastBlock, }) {
fileName = fileName.toLowerCase();
const filePath = path_1.default.join(userDirectory, fileName);
const payload = await zipAsync({
[fileName]: new TextEncoder().encode(dataString),
});
if (!(await existsAsync(userDirectory))) {
await (0, promises_1.mkdir)(userDirectory, { recursive: true });
}
await (0, promises_1.writeFile)(filePath + '.zip', payload);
await (0, promises_1.writeFile)(filePath, dataString);
if (lastBlock) {
await saveLastBlock({
fileName: fileName.replace('.json', ''),
userDirectory,
lastBlock,
});
}
}
async function saveLastBlock({ fileName, userDirectory, lastBlock, }) {
const filePath = path_1.default.join(userDirectory, fileName);
if (lastBlock) {
await (0, promises_1.writeFile)(filePath + '.lastblock.txt', String(lastBlock));
}
}
async function loadLastBlock({ name, directory }) {
const filePath = path_1.default.join(directory, `${name}.lastblock.txt`);
if (!(await existsAsync(filePath))) {
return;
}
try {
const lastBlock = Number(await (0, promises_1.readFile)(filePath, { encoding: 'utf8' }));
if (lastBlock) {
return lastBlock;
}
// eslint-disable-next-line no-empty
}
catch { }
}
async function loadSavedEvents({ name, userDirectory, }) {
const filePath = path_1.default.join(userDirectory, `${name}.json`.toLowerCase());
const loadedBlock = await loadLastBlock({
name,
directory: userDirectory,
});
if (!(await existsAsync(filePath))) {
return {
events: [],
lastBlock: loadedBlock || 0,
};
}
try {
const events = JSON.parse(await (0, promises_1.readFile)(filePath, { encoding: 'utf8' }));
return {
events,
lastBlock: loadedBlock || events[events.length - 1]?.blockNumber || 0,
};
}
catch (err) {
console.log('Method loadSavedEvents has error');
console.log(err);
return {
events: [],
lastBlock: 0,
};
}
}
async function download({ name, cacheDirectory }) {
const fileName = `${name}.json`.toLowerCase();
const zipName = `${fileName}.zip`;
const zipPath = path_1.default.join(cacheDirectory, zipName);
const data = await (0, promises_1.readFile)(zipPath);
const { [fileName]: content } = await unzipAsync(data);
return new TextDecoder().decode(content);
}
async function loadCachedEvents({ name, cacheDirectory, deployedBlock, }) {
try {
const module = await download({ cacheDirectory, name });
if (module) {
const events = JSON.parse(module);
const lastBlock = events && events.length ? events[events.length - 1].blockNumber : deployedBlock;
return {
events,
lastBlock,
fromCache: true,
};
}
return {
events: [],
lastBlock: deployedBlock,
fromCache: true,
};
}
catch (err) {
console.log('Method loadCachedEvents has error');
console.log(err);
return {
events: [],
lastBlock: deployedBlock,
fromCache: true,
};
}
}