Compare commits

...

2 Commits

Author SHA1 Message Date
Derrick Hammer 6099a6c4f6
*Update dist 2023-04-09 12:15:38 -04:00
Derrick Hammer 5c666d38c0
*Need to async fetch rawStream 2023-04-09 12:15:23 -04:00
2 changed files with 40 additions and 4 deletions

19
dist/peer.js vendored
View File

@ -39,9 +39,10 @@ class Peer {
async init() {
const self = this;
let pipe;
const raw = await maybeGetAsyncProperty(self._peer.rawStream);
this._socket = new socket_js_1.default({
remoteAddress: self._peer.rawStream.remoteHost,
remotePort: self._peer.rawStream.remotePort,
remoteAddress: raw.remoteHost,
remotePort: raw.remotePort,
remotePublicKey: self._peer.remotePublicKey,
async write(data, cb) {
if (pipe) {
@ -90,3 +91,17 @@ class Peer {
}
}
exports.default = Peer;
async function maybeGetAsyncProperty(object) {
if (typeof object === "function") {
object = object();
}
if (isPromise(object)) {
object = await object;
}
return object;
}
function isPromise(obj) {
return (!!obj &&
(typeof obj === "object" || typeof obj === "function") &&
typeof obj.then === "function");
}

View File

@ -101,9 +101,10 @@ export default class Peer {
async init() {
const self = this;
let pipe;
const raw = await maybeGetAsyncProperty(self._peer.rawStream);
this._socket = new Socket({
remoteAddress: self._peer.rawStream.remoteHost,
remotePort: self._peer.rawStream.remotePort,
remoteAddress: raw.remoteHost,
remotePort: raw.remotePort,
remotePublicKey: self._peer.remotePublicKey,
async write(data: any, cb: Function) {
if (pipe) {
@ -157,3 +158,23 @@ export default class Peer {
await this._channel.open();
}
}
async function maybeGetAsyncProperty(object: any) {
if (typeof object === "function") {
object = object();
}
if (isPromise(object)) {
object = await object;
}
return object;
}
function isPromise(obj: Promise<any>) {
return (
!!obj &&
(typeof obj === "object" || typeof obj === "function") &&
typeof obj.then === "function"
);
}