mirror of
https://github.com/logos-messaging/lab.waku.org.git
synced 2026-05-10 04:49:27 +00:00
22 lines
17 KiB
JavaScript
22 lines
17 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
self["webpackHotUpdate_N_E"]("app/layout",{
|
|
|
|
/***/ "(app-pages-browser)/./src/services/waku.ts":
|
|
/*!******************************!*\
|
|
!*** ./src/services/waku.ts ***!
|
|
\******************************/
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Waku: function() { return /* binding */ Waku; },\n/* harmony export */ WakuEvents: function() { return /* binding */ WakuEvents; },\n/* harmony export */ waku: function() { return /* binding */ waku; }\n/* harmony export */ });\n/* harmony import */ var _const__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @/const */ \"(app-pages-browser)/./src/const.ts\");\n/* harmony import */ var _waku_sdk__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @waku/sdk */ \"(app-pages-browser)/./node_modules/@waku/sdk/dist/index.js\");\n/* harmony import */ var _waku_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @waku/utils */ \"(app-pages-browser)/./node_modules/@waku/utils/dist/index.js\");\n/* __next_internal_client_entry_do_not_use__ WakuEvents,Waku,waku auto */ \n\n\n\nvar WakuEvents;\n(function(WakuEvents) {\n WakuEvents[\"Status\"] = \"status\";\n})(WakuEvents || (WakuEvents = {}));\nclass Waku {\n async init() {\n if (this.initialized || this.initializing) {\n return;\n }\n this.initializing = true;\n try {\n this.emitStatusEvent(_const__WEBPACK_IMPORTED_MODULE_0__.WakuStatus.Initializing);\n const singleShardInfo = (0,_waku_utils__WEBPACK_IMPORTED_MODULE_2__.pubsubTopicToSingleShardInfo)((0,_waku_utils__WEBPACK_IMPORTED_MODULE_2__.contentTopicToPubsubTopic)(_const__WEBPACK_IMPORTED_MODULE_0__.CONTENT_TOPIC));\n this.pubsubTopic = (0,_waku_utils__WEBPACK_IMPORTED_MODULE_2__.contentTopicToPubsubTopic)(_const__WEBPACK_IMPORTED_MODULE_0__.CONTENT_TOPIC);\n console.log(singleShardInfo);\n const node = await (0,_waku_sdk__WEBPACK_IMPORTED_MODULE_1__.createLightNode)({\n defaultBootstrap: true,\n pubsubTopics: [\n this.pubsubTopic\n ]\n });\n await node.start();\n this.emitStatusEvent(_const__WEBPACK_IMPORTED_MODULE_0__.WakuStatus.WaitingForPeers);\n await (0,_waku_sdk__WEBPACK_IMPORTED_MODULE_1__.waitForRemotePeer)(node, [\n _waku_sdk__WEBPACK_IMPORTED_MODULE_1__.Protocols.Filter,\n _waku_sdk__WEBPACK_IMPORTED_MODULE_1__.Protocols.LightPush,\n _waku_sdk__WEBPACK_IMPORTED_MODULE_1__.Protocols.Store\n ]);\n this.node = node;\n this.initialized = true;\n this.emitStatusEvent(_const__WEBPACK_IMPORTED_MODULE_0__.WakuStatus.Connected);\n } catch (error) {\n console.error(\"Failed to initialize Waku node:\", error);\n this.emitStatusEvent(_const__WEBPACK_IMPORTED_MODULE_0__.WakuStatus.Failed);\n }\n this.initializing = false;\n }\n addEventListener(event, fn) {\n return this.emitter.addEventListener(event, fn);\n }\n removeEventListener(event, fn) {\n return this.emitter.removeEventListener(event, fn);\n }\n send(encoder, message) {\n var _this_node;\n this.ensureWakuInitialized();\n return (_this_node = this.node) === null || _this_node === void 0 ? void 0 : _this_node.lightPush.send(encoder, message);\n }\n async getHistory(decoder) {\n this.ensureWakuInitialized();\n let messages = [];\n for await (const promises of this.node.store.queryGenerator([\n decoder\n ])){\n const messagesRaw = await Promise.all(promises);\n const filteredMessages = messagesRaw.filter((v)=>!!v);\n messages = [\n ...messages,\n ...filteredMessages\n ];\n }\n return messages;\n }\n async subscribe(decoder, fn) {\n this.ensureWakuInitialized();\n return this.node.filter.subscribe(decoder, fn);\n }\n emitStatusEvent(payload) {\n this.emitter.dispatchEvent(new CustomEvent(\"status\", {\n detail: payload\n }));\n }\n ensureWakuInitialized() {\n if (!waku.initialized) {\n const message = \"Waku is not initialized.\";\n console.log(message);\n throw Error(message);\n }\n }\n constructor(){\n this.emitter = new EventTarget();\n this.initialized = false;\n this.initializing = false;\n }\n}\nconst waku = new Waku();\n\n\n;\n // Wrapped in an IIFE to avoid polluting the global scope\n ;\n (function () {\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n // @ts-ignore __webpack_module__ is global\n var currentExports = module.exports;\n // @ts-ignore __webpack_module__ is global\n var prevSignature = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevSignature) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports signature on update so we can compare the boundary\n // signatures. We avoid saving exports themselves since it causes memory leaks (https://github.com/vercel/next.js/pull/53797)\n module.hot.dispose(function (data) {\n data.prevSignature =\n self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports);\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n // @ts-ignore importMeta is replaced in the loader\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevSignature !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevSignature, self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports))) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevSignature !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n })();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./src/services/waku.ts","mappings":";;;;;;;;;0EAEqC;AAUlB;AACqB;AAInB;;UAITO;;GAAAA,eAAAA;AAIL,MAAMC;IAUX,MAAaC,OAAsB;QACjC,IAAI,IAAI,CAACC,WAAW,IAAI,IAAI,CAACC,YAAY,EAAE;YACzC;QACF;QAEA,IAAI,CAACA,YAAY,GAAG;QACpB,IAAI;YACF,IAAI,CAACC,eAAe,CAACZ,8CAAUA,CAACa,YAAY;YAC5C,MAAMC,kBAAkBR,yEAA4BA,CAClDD,sEAAyBA,CAACD,iDAAaA;YAEzC,IAAI,CAACW,WAAW,GAAGV,sEAAyBA,CAACD,iDAAaA;YAC1DY,QAAQC,GAAG,CAACH;YACZ,MAAMI,OAAO,MAAMjB,0DAAeA,CAAC;gBACjCkB,kBAAkB;gBAClBC,cAAc;oBAAC,IAAI,CAACL,WAAW;iBAAC;YAClC;YACA,MAAMG,KAAKG,KAAK;YAChB,IAAI,CAACT,eAAe,CAACZ,8CAAUA,CAACsB,eAAe;YAC/C,MAAMpB,4DAAiBA,CAACgB,MAAM;gBAC5Bf,gDAASA,CAACoB,MAAM;gBAChBpB,gDAASA,CAACqB,SAAS;gBACnBrB,gDAASA,CAACsB,KAAK;aAChB;YACD,IAAI,CAACP,IAAI,GAAGA;YACZ,IAAI,CAACR,WAAW,GAAG;YACnB,IAAI,CAACE,eAAe,CAACZ,8CAAUA,CAAC0B,SAAS;QAC3C,EAAE,OAAOC,OAAO;YACdX,QAAQW,KAAK,CAAC,mCAAmCA;YACjD,IAAI,CAACf,eAAe,CAACZ,8CAAUA,CAAC4B,MAAM;QACxC;QACA,IAAI,CAACjB,YAAY,GAAG;IACtB;IAEOkB,iBAAiBC,KAAiB,EAAEC,EAAiB,EAAE;QAC5D,OAAO,IAAI,CAACC,OAAO,CAACH,gBAAgB,CAACC,OAAOC;IAC9C;IAEOE,oBAAoBH,KAAiB,EAAEC,EAAiB,EAAE;QAC/D,OAAO,IAAI,CAACC,OAAO,CAACC,mBAAmB,CAACH,OAAOC;IACjD;IAEOG,KAAKC,OAAiB,EAAEC,OAAiB,EAAE;YAEzC;QADP,IAAI,CAACC,qBAAqB;QAC1B,QAAO,iBAAI,CAACnB,IAAI,cAAT,4CAAWoB,SAAS,CAACJ,IAAI,CAACC,SAASC;IAC5C;IAEA,MAAaG,WACXC,OAAkC,EACN;QAC5B,IAAI,CAACH,qBAAqB;QAE1B,IAAII,WAA8B,EAAE;QACpC,WAAW,MAAMC,YAAY,IAAI,CAACxB,IAAI,CAAEyB,KAAK,CAACC,cAAc,CAAC;YAACJ;SAAQ,EAAG;YACvE,MAAMK,cAAc,MAAMC,QAAQC,GAAG,CAACL;YACtC,MAAMM,mBAAmBH,YAAYI,MAAM,CACzC,CAACC,IAA4B,CAAC,CAACA;YAGjCT,WAAW;mBAAIA;mBAAaO;aAAiB;QAC/C;QAEA,OAAOP;IACT;IAEA,MAAaU,UACXX,OAAkC,EAClCT,EAAgC,EAChC;QACA,IAAI,CAACM,qBAAqB;QAC1B,OAAO,IAAI,CAACnB,IAAI,CAAE+B,MAAM,CAACE,SAAS,CAACX,SAAST;IAC9C;IAEQnB,gBAAgBwC,OAAe,EAAE;QACvC,IAAI,CAACpB,OAAO,CAACqB,aAAa,CACxB,IAAIC,sBAA+B;YAAEC,QAAQH;QAAQ;IAEzD;IAEQf,wBAAwB;QAC9B,IAAI,CAACmB,KAAK9C,WAAW,EAAE;YACrB,MAAM0B,UAAU;YAChBpB,QAAQC,GAAG,CAACmB;YACZ,MAAMqB,MAAMrB;QACd;IACF;IAvFAsB,aAAc;aALN1B,UAAU,IAAI2B;aACdjD,cAAuB;aACvBC,eAAwB;IAGjB;AAwFjB;AAEO,MAAM6C,OAAO,IAAIhD,OAAO","sources":["webpack://_N_E/./src/services/waku.ts?54b3"],"sourcesContent":["\"use client\";\n\nimport { WakuStatus } from \"@/const\";\nimport {\n  IDecoder,\n  IEncoder,\n  IMessage,\n  LightNode,\n  createLightNode,\n  waitForRemotePeer,\n  IDecodedMessage,\n  Protocols,\n} from \"@waku/sdk\";\nimport { CONTENT_TOPIC } from \"@/const\";\nimport {\n  contentTopicToPubsubTopic,\n  pubsubTopicToSingleShardInfo,\n} from \"@waku/utils\";\n\ntype EventListener = (event: CustomEvent) => void;\n\nexport enum WakuEvents {\n  Status = \"status\",\n}\n\nexport class Waku {\n  private node: undefined | LightNode;\n\n  private emitter = new EventTarget();\n  private initialized: boolean = false;\n  private initializing: boolean = false;\n  public pubsubTopic?: string;\n\n  constructor() {}\n\n  public async init(): Promise<void> {\n    if (this.initialized || this.initializing) {\n      return;\n    }\n\n    this.initializing = true;\n    try {\n      this.emitStatusEvent(WakuStatus.Initializing);\n      const singleShardInfo = pubsubTopicToSingleShardInfo(\n        contentTopicToPubsubTopic(CONTENT_TOPIC)\n      );\n      this.pubsubTopic = contentTopicToPubsubTopic(CONTENT_TOPIC);\n      console.log(singleShardInfo)\n      const node = await createLightNode({\n        defaultBootstrap: true,\n        pubsubTopics: [this.pubsubTopic]\n      });\n      await node.start();\n      this.emitStatusEvent(WakuStatus.WaitingForPeers);\n      await waitForRemotePeer(node, [\n        Protocols.Filter,\n        Protocols.LightPush,\n        Protocols.Store,\n      ]);\n      this.node = node;\n      this.initialized = true;\n      this.emitStatusEvent(WakuStatus.Connected);\n    } catch (error) {\n      console.error(\"Failed to initialize Waku node:\", error);\n      this.emitStatusEvent(WakuStatus.Failed);\n    }\n    this.initializing = false;\n  }\n\n  public addEventListener(event: WakuEvents, fn: EventListener) {\n    return this.emitter.addEventListener(event, fn as any);\n  }\n\n  public removeEventListener(event: WakuEvents, fn: EventListener) {\n    return this.emitter.removeEventListener(event, fn as any);\n  }\n\n  public send(encoder: IEncoder, message: IMessage) {\n    this.ensureWakuInitialized();\n    return this.node?.lightPush.send(encoder, message);\n  }\n\n  public async getHistory(\n    decoder: IDecoder<IDecodedMessage>\n  ): Promise<IDecodedMessage[]> {\n    this.ensureWakuInitialized();\n\n    let messages: IDecodedMessage[] = [];\n    for await (const promises of this.node!.store.queryGenerator([decoder])) {\n      const messagesRaw = await Promise.all(promises);\n      const filteredMessages = messagesRaw.filter(\n        (v): v is IDecodedMessage => !!v\n      );\n\n      messages = [...messages, ...filteredMessages];\n    }\n\n    return messages;\n  }\n\n  public async subscribe(\n    decoder: IDecoder<IDecodedMessage>,\n    fn: (m: IDecodedMessage) => void\n  ) {\n    this.ensureWakuInitialized();\n    return this.node!.filter.subscribe(decoder, fn);\n  }\n\n  private emitStatusEvent(payload: string) {\n    this.emitter.dispatchEvent(\n      new CustomEvent(WakuEvents.Status, { detail: payload })\n    );\n  }\n\n  private ensureWakuInitialized() {\n    if (!waku.initialized) {\n      const message = \"Waku is not initialized.\";\n      console.log(message);\n      throw Error(message);\n    }\n  }\n}\n\nexport const waku = new Waku();\n"],"names":["WakuStatus","createLightNode","waitForRemotePeer","Protocols","CONTENT_TOPIC","contentTopicToPubsubTopic","pubsubTopicToSingleShardInfo","WakuEvents","Waku","init","initialized","initializing","emitStatusEvent","Initializing","singleShardInfo","pubsubTopic","console","log","node","defaultBootstrap","pubsubTopics","start","WaitingForPeers","Filter","LightPush","Store","Connected","error","Failed","addEventListener","event","fn","emitter","removeEventListener","send","encoder","message","ensureWakuInitialized","lightPush","getHistory","decoder","messages","promises","store","queryGenerator","messagesRaw","Promise","all","filteredMessages","filter","v","subscribe","payload","dispatchEvent","CustomEvent","detail","waku","Error","constructor","EventTarget"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./src/services/waku.ts\n"));
|
|
|
|
/***/ })
|
|
|
|
}); |