@forzalabs/remora
Version:
A powerful CLI tool for seamless data translation.
51 lines (50 loc) • 2.27 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const workerpool_1 = __importDefault(require("workerpool"));
const dotenv_1 = __importDefault(require("dotenv"));
const Affirm_1 = __importDefault(require("../core/Affirm"));
const Environment_1 = __importDefault(require("../engines/Environment"));
const Executor_1 = __importDefault(require("../executors/Executor"));
dotenv_1.default.configDotenv();
const run = (workerData) => __awaiter(void 0, void 0, void 0, function* () {
Environment_1.default.load('./');
try {
const { workerId, chunk, consumer, producer, prodDimensions, scope, options } = workerData;
(0, Affirm_1.default)(workerId, `Invalid worker id`);
(0, Affirm_1.default)(consumer, `Invalid consumer`);
(0, Affirm_1.default)(producer, `Invalid producer`);
(0, Affirm_1.default)(chunk, `Invalid chunk`);
(0, Affirm_1.default)(scope, `Invalid executor scope`);
const executor = new Executor_1.default();
const res = yield executor.run({
consumer,
producer,
prodDimensions,
workerId,
chunk,
options,
scope,
reportWork: packet => workerpool_1.default.workerEmit(packet)
});
return res;
}
catch (error) {
console.error(error);
return null;
}
});
workerpool_1.default.worker({
executor: run
});