@berish/rfp
Version:
Binary secure transport organization protocol for peer communication using function fingerprints
53 lines • 2.85 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());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.sendRaw = void 0;
const chunk_1 = require("../../chunk");
const serber_1 = require("../../serber");
const request_1 = require("../request");
const waitResponse_1 = require("./waitResponse");
const errors_1 = require("../../errors");
const checkConnection_1 = require("./checkConnection");
const convertStep_1 = require("./convertStep");
const blockStep_1 = require("./blockStep");
const unblockStep_1 = require("./unblockStep");
function sendRaw(peer, outcomeChunk, incomeChunk) {
return __awaiter(this, void 0, void 0, function* () {
if (!peer)
throw new TypeError('send Peer is null');
if (!outcomeChunk)
throw new TypeError('send outcomeChunk is null');
if (!checkConnection_1.checkConnection(peer, outcomeChunk))
return void 0;
outcomeChunk = outcomeChunk && chunk_1.fillChunk(outcomeChunk);
incomeChunk = incomeChunk && chunk_1.fillChunk(incomeChunk);
const outcomeRequest = outcomeChunk && request_1.createRequest(peer, outcomeChunk);
const incomeRequest = incomeChunk && request_1.createRequest(peer, incomeChunk);
yield blockStep_1.blockStep(peer, outcomeChunk);
const { outcomeRequestConverted, deferredList } = yield convertStep_1.convertStep(outcomeRequest, incomeRequest);
serber_1.deferredReceiveStart(deferredList);
if (!checkConnection_1.checkConnection(peer, outcomeChunk))
return void 0;
const sended = yield peer.connection.transport.send(peer, outcomeRequestConverted.chunk);
if (!sended)
throw new errors_1.ConnectionError('send is not executed');
if (outcomeChunk.notWaiting) {
peer.logger('send')('not wait').info(outcomeChunk.chunkId);
return void 0;
}
peer.logger('send')('wait').info(outcomeChunk.chunkId);
const result = yield waitResponse_1.waitResponse(peer, outcomeChunk);
yield unblockStep_1.unblockStep(peer, outcomeChunk);
return result;
});
}
exports.sendRaw = sendRaw;
//# sourceMappingURL=sendRaw.js.map