diff --git a/dist/index.d.ts b/dist/index.d.ts
index 72ae164..99e5211 100644
--- a/dist/index.d.ts
+++ b/dist/index.d.ts
@@ -1,24 +1,20 @@
///
-///
-import { EventEmitter } from "events";
-import { ErrTuple } from "libskynet";
import { Buffer } from "buffer";
-export declare class DHT {
- private useDefaultDht;
+import { Client } from "@lumeweb/libkernel-universal";
+import { ErrTuple } from "@siaweb/libweb";
+export declare class SwarmClient extends Client {
+ private useDefaultSwarm;
private id;
+ get swarm(): number | undefined;
constructor(useDefaultDht?: boolean);
- connect(pubkey: string): Promise;
+ connect(pubkey: string | Uint8Array): Promise;
ready(): Promise;
addRelay(pubkey: string): Promise;
removeRelay(pubkey: string): Promise;
clearRelays(): Promise;
getRelays(): Promise;
- getRelayServers(): Promise;
- private create;
- close(): Promise;
- private setup;
}
-export declare class Socket extends EventEmitter {
+export declare class Socket extends Client {
private id;
private eventUpdates;
constructor(id: number);
@@ -29,4 +25,5 @@ export declare class Socket extends EventEmitter {
private ensureEvent;
private trackEvent;
}
+export declare const createClient: (...args: any) => SwarmClient;
//# sourceMappingURL=index.d.ts.map
\ No newline at end of file
diff --git a/dist/index.d.ts.map b/dist/index.d.ts.map
index 2b81a99..66a69ae 100644
--- a/dist/index.d.ts.map
+++ b/dist/index.d.ts.map
@@ -1 +1 @@
-{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAU,QAAQ,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAqBhC,qBAAa,GAAG;IACd,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,EAAE,CAAa;gBAEX,aAAa,UAAO;IAInB,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAa/C,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC;IAMnB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASvC,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAY1C,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IAK5B,SAAS,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAS9B,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YAUnC,MAAM;IAaP,KAAK,IAAI,OAAO,CAAC,OAAO,CAAC;YAcxB,KAAK;CAIpB;AAED,qBAAa,MAAO,SAAQ,YAAY;IACtC,OAAO,CAAC,EAAE,CAAS;IACnB,OAAO,CAAC,YAAY,CAAqC;gBAE7C,EAAE,EAAE,MAAM;IAKtB,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,GAAG,IAAI;IAkB/D,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,GAAG,IAAI;IAStC,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIrC,GAAG,IAAI,IAAI;IAUX,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,UAAU;CAInB"}
\ No newline at end of file
+{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,MAAM,EAAW,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAoB,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE5D,qBAAa,WAAY,SAAQ,MAAM;IACrC,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,EAAE,CAAa;IAEvB,IAAI,KAAK,IAAI,MAAM,GAAG,SAAS,CAE9B;gBAEW,aAAa,UAAO;IAKnB,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC;IAc5D,KAAK,IAAI,OAAO,CAAC,QAAQ,CAAC;IAKnB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvC,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1C,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IAG5B,SAAS,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;CAG5C;AAED,qBAAa,MAAO,SAAQ,MAAM;IAChC,OAAO,CAAC,EAAE,CAAS;IACnB,OAAO,CAAC,YAAY,CAAqC;gBAE7C,EAAE,EAAE,MAAM;IAKtB,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,GAAG,IAAI;IAiB/D,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,GAAG,IAAI;IAStC,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIrC,GAAG,IAAI,IAAI;IAUX,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,UAAU;CAInB;AAID,eAAO,MAAM,YAAY,+BAA4C,CAAC"}
\ No newline at end of file
diff --git a/dist/index.js b/dist/index.js
index 2ec8d9e..1fbbd24 100644
--- a/dist/index.js
+++ b/dist/index.js
@@ -1,112 +1,44 @@
-import { EventEmitter } from "events";
-const DHT_MODULE = "AQD1IgE4lTZkq1fqdoYGojKRNrSk0YQ_wrHbRtIiHDrnow";
-let callModule, connectModule;
-async function loadLibs() {
- if (callModule && connectModule) {
- return;
- }
- if (typeof window !== "undefined" && window?.document) {
- const pkg = await import("libkernel");
- callModule = pkg.callModule;
- connectModule = pkg.connectModule;
- }
- else {
- const pkg = await import("libkmodule");
- callModule = pkg.callModule;
- connectModule = pkg.connectModule;
- }
-}
-export class DHT {
- useDefaultDht;
+import { Client, factory } from "@lumeweb/libkernel-universal";
+import { hexToBuf } from "@siaweb/libweb";
+export class SwarmClient extends Client {
+ useDefaultSwarm;
id = 0;
+ get swarm() {
+ return this.useDefaultSwarm ? undefined : this.id;
+ }
constructor(useDefaultDht = true) {
- this.useDefaultDht = useDefaultDht;
+ super();
+ this.useDefaultSwarm = useDefaultDht;
}
async connect(pubkey) {
- await this.setup();
- const dht = !this.useDefaultDht ? this.id : undefined;
- const [resp, err] = await callModule(DHT_MODULE, "connect", {
- pubkey,
- dht,
- });
- if (err) {
- throw new Error(err);
+ if (typeof pubkey === "string") {
+ const buf = hexToBuf(pubkey);
+ pubkey = this.handleErrorOrReturn(buf);
}
- return new Socket(resp.id);
+ const resp = this.callModuleReturn("connect", {
+ pubkey,
+ swarm: this.swarm,
+ });
+ return createSocket(resp.id);
}
async ready() {
- await this.setup();
- const dht = !this.useDefaultDht ? this.id : undefined;
- return callModule(DHT_MODULE, "ready", { dht });
+ const dht = !this.useDefaultSwarm ? this.id : undefined;
+ return this.callModuleReturn("ready", { swarm: this.swarm });
}
async addRelay(pubkey) {
- await this.setup();
- const dht = !this.useDefaultDht ? this.id : undefined;
- const [, err] = await callModule(DHT_MODULE, "addRelay", { pubkey, dht });
- if (err) {
- throw new Error(err);
- }
+ return this.callModuleReturn("addRelay", { pubkey, swarm: this.swarm });
}
async removeRelay(pubkey) {
- await this.setup();
- const dht = !this.useDefaultDht ? this.id : undefined;
- const [, err] = await callModule(DHT_MODULE, "removeRelay", {
- pubkey,
- dht,
- });
- if (err) {
- throw new Error(err);
- }
+ return this.callModuleReturn("removeRelay", { pubkey, swarm: this.swarm });
}
async clearRelays() {
- await this.setup();
- const dht = !this.useDefaultDht ? this.id : undefined;
- await callModule(DHT_MODULE, "clearRelays", { dht });
+ return this.callModuleReturn("clearRelays", { swarm: this.swarm });
}
async getRelays() {
- await this.setup();
- const [list, err] = await callModule(DHT_MODULE, "getRelays");
- if (err) {
- throw new Error(err);
- }
- return list;
- }
- async getRelayServers() {
- await this.setup();
- const [list, err] = await callModule(DHT_MODULE, "getRelayServers");
- if (err) {
- throw new Error(err);
- }
- return list;
- }
- async create() {
- await loadLibs();
- if (this.useDefaultDht || this.id > 0) {
- return Promise.resolve();
- }
- const [dht, err] = await callModule(DHT_MODULE, "openDht");
- if (err) {
- throw new Error(err);
- }
- this.id = dht.dht;
- }
- async close() {
- await this.setup();
- if (this.useDefaultDht) {
- return false;
- }
- const [, err] = await callModule(DHT_MODULE, "closeDht", { dht: this.id });
- if (err) {
- throw new Error(err);
- }
- return true;
- }
- async setup() {
- await loadLibs();
- await this.create();
+ return this.callModuleReturn("getRelays", { swarm: this.swarm });
}
}
-export class Socket extends EventEmitter {
+export class Socket extends Client {
id;
eventUpdates = {};
constructor(id) {
@@ -114,7 +46,7 @@ export class Socket extends EventEmitter {
this.id = id;
}
on(eventName, listener) {
- const [update, promise] = connectModule(DHT_MODULE, "listenSocketEvent", { id: this.id, event: eventName }, (data) => {
+ const [update, promise] = this.connectModule("listenSocketEvent", { id: this.id, event: eventName }, (data) => {
this.emit(eventName, data);
});
this.trackEvent(eventName, update);
@@ -132,12 +64,12 @@ export class Socket extends EventEmitter {
return super.off(type, listener);
}
write(message) {
- callModule(DHT_MODULE, "write", { id: this.id, message });
+ this.callModule("write", { id: this.id, message });
}
end() {
- callModule(DHT_MODULE, "socketExists", { id: this.id }).then(([exists]) => {
+ this.callModule("socketExists", { id: this.id }).then(([exists]) => {
if (exists) {
- callModule(DHT_MODULE, "close", { id: this.id });
+ this.callModule("close", { id: this.id });
}
});
}
@@ -151,3 +83,6 @@ export class Socket extends EventEmitter {
this.eventUpdates[event].push(update);
}
}
+const MODULE = "_A73ORX4dxSkt7Cv8v6gtbV0W5EsLrdZX6SywPdSTFBPEg";
+export const createClient = factory(SwarmClient, MODULE);
+const createSocket = factory(Socket, MODULE);