pw-js-api 0.1.1-dev.dfeb897 → 0.1.2-dev.e6a840d

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -33,11 +33,11 @@ NOTE: installing pw-js-api#dev is also available if you wish, there may be no di
33
33
  You could use a CDN like jsdelivr or unpkg. You can put this in your HTML page:
34
34
 
35
35
  ```html
36
- <script src="https://cdn.jsdelivr.net/npm/pw-js-api@0.1.0/browser/pw.prod.js"></script>
36
+ <script src="https://cdn.jsdelivr.net/npm/pw-js-api@0.1.1/browser/pw.prod.js"></script>
37
37
  ```
38
38
 
39
39
  ```html
40
- <script src="https://cdn.jsdelivr.net/npm/pw-js-api@0.1.0/browser/pw.dev.js"></script>
40
+ <script src="https://cdn.jsdelivr.net/npm/pw-js-api@0.1.1/browser/pw.dev.js"></script>
41
41
  ```
42
42
 
43
43
  When you have these scripts in your HTML file, you will be able to use the global variable PW which contains PWGameClient, PWApiClient and Constants.
package/browser/pw.dev.js CHANGED
@@ -26,7 +26,7 @@ return /******/ (() => { // webpackBootstrap
26
26
  \*********************************/
27
27
  /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
28
28
 
29
- eval("\nvar _PWApiClient_token, _PWApiClient_account;\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst tslib_1 = __webpack_require__(/*! tslib */ \"./node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.mjs\");\nconst PWGameClient_js_1 = tslib_1.__importDefault(__webpack_require__(/*! ../game/PWGameClient.js */ \"./dist/game/PWGameClient.js\"));\nconst Constants_js_1 = __webpack_require__(/*! ../util/Constants.js */ \"./dist/util/Constants.js\");\nconst Misc_js_1 = __webpack_require__(/*! ../util/Misc.js */ \"./dist/util/Misc.js\");\n/**\n * Note if you want to join a world, use new PWGameClient() then run .init()\n */\nclass PWApiClient {\n constructor(email, password) {\n /**\n * The account token, this is private to prevent tampering.\n */\n _PWApiClient_token.set(this, void 0);\n /**\n * Account details with email and password, if applicable.\n */\n _PWApiClient_account.set(this, {\n email: \"\",\n password: \"\"\n });\n this.loggedIn = false;\n if (password === undefined) {\n tslib_1.__classPrivateFieldSet(this, _PWApiClient_token, email, \"f\");\n this.loggedIn = true;\n return;\n }\n tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").email = email;\n tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").password = password;\n // this.#token = token;\n }\n authenticate(email, password) {\n if (email === undefined) {\n if (tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").email.length === 0 || tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").password.length === 0)\n throw Error(\"No email/password given.\");\n email = tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").email;\n password = tslib_1.__classPrivateFieldGet(this, _PWApiClient_account, \"f\").password;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/users/auth-with-password`, { identity: email, password }).then(res => {\n if (\"token\" in res) {\n tslib_1.__classPrivateFieldSet(this, _PWApiClient_token, res.token, \"f\");\n this.loggedIn = true;\n }\n return res;\n }); //.then(console.log);\n }\n /**\n * Internal.\n */\n getJoinKey(roomType, roomId) {\n return this.request(`${Constants_js_1.Endpoint.Api}/api/joinkey/${roomType}/${roomId}`, undefined, true);\n }\n /**\n * This route is available to take if you chose to create an API client to then join a world, in which case this returns the Game Client instance.\n *\n * Make sure the API client is already authenticated before calling this.\n *\n * The 3rd parameter is for if you wish to customise the reconnectability of the game client.\n */\n joinWorld(roomId, obj) {\n const game = new PWGameClient_js_1.default(this, obj === null || obj === void 0 ? void 0 : obj.gameSettings);\n return game.joinWorld(roomId, obj === null || obj === void 0 ? void 0 : obj.joinData);\n }\n // I feel like this is cursed.\n /**\n * This will be an empty array if getRoomTypes has never been used successfully at least once.\n */\n get roomTypes() {\n return PWApiClient.roomTypes;\n }\n /**\n * Non-authenticated. This will refresh the room types each time, so make sure to check if roomTypes is available.\n */\n getRoomTypes() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/listroomtypes`)\n .then(res => {\n PWApiClient.roomTypes = res;\n return res;\n });\n }\n /**\n * Non-authenticated. This will refresh the room types each time, so make sure to check if roomTypes is available.\n */\n static getRoomTypes() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/listroomtypes`)\n .then(res => {\n PWApiClient.roomTypes = res;\n return res;\n });\n }\n /**\n * Non-authenticated. Returns the mappings from the game API.\n */\n getMappings() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/mappings`);\n }\n getOwnedWorlds(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/worlds/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`, undefined, true);\n }\n getPlayers(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/public_profiles/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`);\n }\n getPublicWorlds(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/public_worlds/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`);\n }\n /**\n * Returns the lobby result.\n */\n getVisibleWorlds() {\n if (this.roomTypes.length === 0)\n throw Error(\"roomTypes is empty - use getRoomTypes first!\");\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/room/list/${this.roomTypes[0]}`);\n }\n /**\n * Returns the world, if it exists and is public.\n */\n getPublicWorld(id) {\n return this.getPublicWorlds(1, 1, { filter: { id } })\n .then(res => res.items[0]);\n }\n getMinimap(world, toURL = false) {\n if (toURL)\n return `${Constants_js_1.Endpoint.Api}/api/files/rhrbt6wqhc4s0cp/${world.id}/${world.minimap}`;\n return this.request(this.getMinimap(world, true))\n .then(res => {\n if (\"message\" in res)\n throw Error(\"Minimap doesn't exist, the world may be unlisted.\");\n return res;\n });\n }\n /**\n * Note that username is cap sensitive, and may require you to use toUppercase\n */\n getPlayerByName(username) {\n return this.getPlayers(1, 1, { filter: { username } });\n }\n // This doesn't seem to work so I commented it out, not removing it as there might be an oversight idk\n // getMessageTypes() {\n // return this.request<string[]>(`${Endpoint.GameHTTP}/message_types`)\n // .then(res => res instanceof Uint8Array ? [] : res ?? []);\n // }\n /**\n * IMPORTANT: This will return JSON for any responses that have the content-type of json, anything else will be sent back as Uint8array.\n * If you're expecting raw bytes, make sure the endpoint is guaranteed to give you that otherwise there isn't a reason.\n *\n * This requires the manager to be authenticated, it will error if otherwise.\n * @param url Requires to be a full URL with endpoint unfortunately. It will throw error if it doesn't match any of the 2 HTTP endpoint URLs.\n * @param body If this is passed, the request will become a POST. (If you need to send a POST but has no data, just send an empty object).\n * @param token The API token (not join key), this is if you wish to use authenticated API calls without having to instantise an api client yourself.\n */\n static request(url, body, token) {\n if (!(url.startsWith(Constants_js_1.Endpoint.Api) || url.startsWith(Constants_js_1.Endpoint.GameHTTP)))\n throw Error(\"URL given does not have the correct endpoint URL, this is for safety.\");\n const headers = {\n // \"user-agent\": \"PW-TS-API/0.0.1\"\n };\n if (typeof token === \"string\")\n headers[\"authorization\"] = token;\n if (typeof body === \"object\")\n body = JSON.stringify(body);\n let method = \"GET\";\n if (typeof body !== \"undefined\") {\n headers[\"content-type\"] = \"application/json\";\n method = \"POST\";\n }\n return fetch(url, {\n headers, method,\n body: body\n }).then(res => {\n var _a;\n if (res.status === 403)\n throw Error(\"Forbidden access - token invalid or unauthorised.\");\n // else if (res.status !== 200) throw Error(\"\")\n if ((_a = res.headers.get(\"content-type\")) === null || _a === void 0 ? void 0 : _a.startsWith(\"application/json\"))\n return res.json();\n else\n return res.arrayBuffer();\n });\n }\n /**\n * IMPORTANT: This will return JSON for any responses that have the content-type of json, anything else will be sent back as Uint8array.\n * If you're expecting raw bytes, make sure the endpoint is guaranteed to give you that otherwise there isn't a reason.\n *\n * This requires the manager to be authenticated, it will error if otherwise.\n * @param url Requires to be a full URL with endpoint unfortunately. It will throw error if it doesn't match any of the 2 HTTP endpoint URLs.\n * @param body If this is passed, the request will become a POST. (If you need to send a POST but has no data, just send an empty object).\n * @param isAuthenticated If true, this will send the token as the header.\n */\n request(url, body, isAuthenticated = false) {\n return PWApiClient.request(url, body, isAuthenticated ? tslib_1.__classPrivateFieldGet(this, _PWApiClient_token, \"f\") : undefined);\n }\n}\n_PWApiClient_token = new WeakMap(), _PWApiClient_account = new WeakMap();\n/**\n * This will be an empty array if getRoomTypes has never been used successfully at least once.\n */\nPWApiClient.roomTypes = [];\nexports[\"default\"] = PWApiClient;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUFdBcGlDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvYXBpL1BXQXBpQ2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxzRkFBbUQ7QUFHbkQsdURBQWdEO0FBQ2hELDZDQUFnRDtBQUVoRDs7R0FFRztBQUNILE1BQXFCLFdBQVc7SUEwQjVCLFlBQVksS0FBYSxFQUFFLFFBQWlCO1FBekI1Qzs7V0FFRztRQUNILHFDQUFnQjtRQUVoQjs7V0FFRztRQUNILCtCQUFXO1lBQ1AsS0FBSyxFQUFFLEVBQUU7WUFDVCxRQUFRLEVBQUUsRUFBRTtTQUNmLEVBQUE7UUFFRCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBYWIsSUFBSSxRQUFRLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDekIsK0JBQUEsSUFBSSxzQkFBVSxLQUFLLE1BQUEsQ0FBQztZQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztZQUNyQixPQUFPO1FBQ1gsQ0FBQztRQUVELCtCQUFBLElBQUksNEJBQVMsQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQzVCLCtCQUFBLElBQUksNEJBQVMsQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBRWxDLHVCQUF1QjtJQUMzQixDQUFDO0lBWUQsWUFBWSxDQUFDLEtBQWMsRUFBRSxRQUFpQjtRQUMxQyxJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUN0QixJQUFJLCtCQUFBLElBQUksNEJBQVMsQ0FBQyxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSwrQkFBQSxJQUFJLDRCQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sS0FBSyxDQUFDO2dCQUFFLE1BQU0sS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7WUFFckgsS0FBSyxHQUFHLCtCQUFBLElBQUksNEJBQVMsQ0FBQyxLQUFLLENBQUM7WUFDNUIsUUFBUSxHQUFHLCtCQUFBLElBQUksNEJBQVMsQ0FBQyxRQUFRLENBQUM7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\n\n//# sourceURL=webpack://PW/./dist/api/PWApiClient.js?");
29
+ eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst tslib_1 = __webpack_require__(/*! tslib */ \"./node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.mjs\");\nconst PWGameClient_js_1 = tslib_1.__importDefault(__webpack_require__(/*! ../game/PWGameClient.js */ \"./dist/game/PWGameClient.js\"));\nconst Constants_js_1 = __webpack_require__(/*! ../util/Constants.js */ \"./dist/util/Constants.js\");\nconst Misc_js_1 = __webpack_require__(/*! ../util/Misc.js */ \"./dist/util/Misc.js\");\n/**\n * Note if you want to join a world, use new PWGameClient() then run .init()\n */\nclass PWApiClient {\n constructor(email, password) {\n /**\n * Account details with email and password, if applicable.\n */\n this.account = {\n email: \"\",\n password: \"\"\n };\n this.loggedIn = false;\n if (password === undefined) {\n this.token = email;\n this.loggedIn = true;\n return;\n }\n this.account.email = email;\n this.account.password = password;\n // this.token = token;\n }\n authenticate(email, password) {\n if (email === undefined) {\n if (this.account.email.length === 0 || this.account.password.length === 0)\n throw Error(\"No email/password given.\");\n email = this.account.email;\n password = this.account.password;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/users/auth-with-password`, { identity: email, password }).then(res => {\n if (\"token\" in res) {\n this.token = res.token;\n this.loggedIn = true;\n }\n return res;\n }); //.then(console.log);\n }\n /**\n * Internal.\n */\n getJoinKey(roomType, roomId) {\n return this.request(`${Constants_js_1.Endpoint.Api}/api/joinkey/${roomType}/${roomId}`, undefined, true);\n }\n /**\n * This route is available to take if you chose to create an API client to then join a world, in which case this returns the Game Client instance.\n *\n * Make sure the API client is already authenticated before calling this.\n *\n * The 3rd parameter is for if you wish to customise the reconnectability of the game client.\n */\n joinWorld(roomId, obj) {\n const game = new PWGameClient_js_1.default(this, obj === null || obj === void 0 ? void 0 : obj.gameSettings);\n return game.joinWorld(roomId, obj === null || obj === void 0 ? void 0 : obj.joinData);\n }\n // I feel like this is cursed.\n /**\n * This will be an empty array if getRoomTypes has never been used successfully at least once.\n */\n get roomTypes() {\n return PWApiClient.roomTypes;\n }\n /**\n * Non-authenticated. This will refresh the room types each time, so make sure to check if roomTypes is available.\n */\n getRoomTypes() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/listroomtypes`)\n .then(res => {\n PWApiClient.roomTypes = res;\n return res;\n });\n }\n /**\n * Non-authenticated. This will refresh the room types each time, so make sure to check if roomTypes is available.\n */\n static getRoomTypes() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/listroomtypes`)\n .then(res => {\n PWApiClient.roomTypes = res;\n return res;\n });\n }\n /**\n * Non-authenticated. Returns the mappings from the game API.\n */\n getMappings() {\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/mappings`);\n }\n getOwnedWorlds(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/worlds/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`, undefined, true);\n }\n getPlayers(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/public_profiles/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`);\n }\n getPublicWorlds(page = 1, perPage = 10, query) {\n if (typeof page === \"object\") {\n query = page;\n page = 1;\n }\n return this.request(`${Constants_js_1.Endpoint.Api}/api/collections/public_worlds/records?page=${page}&perPage=${perPage}${(0, Misc_js_1.queryToString)(query)}`);\n }\n /**\n * Returns the lobby result.\n */\n getVisibleWorlds() {\n if (this.roomTypes.length === 0)\n throw Error(\"roomTypes is empty - use getRoomTypes first!\");\n return this.request(`${Constants_js_1.Endpoint.GameHTTP}/room/list/${this.roomTypes[0]}`);\n }\n /**\n * Returns the world, if it exists and is public.\n */\n getPublicWorld(id) {\n return this.getPublicWorlds(1, 1, { filter: { id } })\n .then(res => res.items[0]);\n }\n getMinimap(world, toURL = false) {\n if (toURL)\n return `${Constants_js_1.Endpoint.Api}/api/files/rhrbt6wqhc4s0cp/${world.id}/${world.minimap}`;\n return this.request(this.getMinimap(world, true))\n .then(res => {\n if (\"message\" in res)\n throw Error(\"Minimap doesn't exist, the world may be unlisted.\");\n return res;\n });\n }\n /**\n * Note that username is cap sensitive, and may require you to use toUppercase\n */\n getPlayerByName(username) {\n return this.getPlayers(1, 1, { filter: { username } });\n }\n // This doesn't seem to work so I commented it out, not removing it as there might be an oversight idk\n // getMessageTypes() {\n // return this.request<string[]>(`${Endpoint.GameHTTP}/message_types`)\n // .then(res => res instanceof Uint8Array ? [] : res ?? []);\n // }\n /**\n * IMPORTANT: This will return JSON for any responses that have the content-type of json, anything else will be sent back as Uint8array.\n * If you're expecting raw bytes, make sure the endpoint is guaranteed to give you that otherwise there isn't a reason.\n *\n * This requires the manager to be authenticated, it will error if otherwise.\n * @param url Requires to be a full URL with endpoint unfortunately. It will throw error if it doesn't match any of the 2 HTTP endpoint URLs.\n * @param body If this is passed, the request will become a POST. (If you need to send a POST but has no data, just send an empty object).\n * @param token The API token (not join key), this is if you wish to use authenticated API calls without having to instantise an api client yourself.\n */\n static request(url, body, token) {\n if (!(url.startsWith(Constants_js_1.Endpoint.Api) || url.startsWith(Constants_js_1.Endpoint.GameHTTP)))\n throw Error(\"URL given does not have the correct endpoint URL, this is for safety.\");\n const headers = {\n // \"user-agent\": \"PW-TS-API/0.0.1\"\n };\n if (typeof token === \"string\")\n headers[\"authorization\"] = token;\n if (typeof body === \"object\")\n body = JSON.stringify(body);\n let method = \"GET\";\n if (typeof body !== \"undefined\") {\n headers[\"content-type\"] = \"application/json\";\n method = \"POST\";\n }\n return fetch(url, {\n headers, method,\n body: body\n }).then(res => {\n var _a;\n if (res.status === 403)\n throw Error(\"Forbidden access - token invalid or unauthorised.\");\n // else if (res.status !== 200) throw Error(\"\")\n if ((_a = res.headers.get(\"content-type\")) === null || _a === void 0 ? void 0 : _a.startsWith(\"application/json\"))\n return res.json();\n else\n return res.arrayBuffer();\n });\n }\n /**\n * IMPORTANT: This will return JSON for any responses that have the content-type of json, anything else will be sent back as Uint8array.\n * If you're expecting raw bytes, make sure the endpoint is guaranteed to give you that otherwise there isn't a reason.\n *\n * This requires the manager to be authenticated, it will error if otherwise.\n * @param url Requires to be a full URL with endpoint unfortunately. It will throw error if it doesn't match any of the 2 HTTP endpoint URLs.\n * @param body If this is passed, the request will become a POST. (If you need to send a POST but has no data, just send an empty object).\n * @param isAuthenticated If true, this will send the token as the header.\n */\n request(url, body, isAuthenticated = false) {\n return PWApiClient.request(url, body, isAuthenticated ? this.token : undefined);\n }\n}\n/**\n * This will be an empty array if getRoomTypes has never been used successfully at least once.\n */\nPWApiClient.roomTypes = [];\nexports[\"default\"] = PWApiClient;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUFdBcGlDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvYXBpL1BXQXBpQ2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHNGQUFtRDtBQUduRCx1REFBZ0Q7QUFDaEQsNkNBQWdEO0FBRWhEOztHQUVHO0FBQ0gsTUFBcUIsV0FBVztJQTBCNUIsWUFBWSxLQUFhLEVBQUUsUUFBaUI7UUFwQjVDOztXQUVHO1FBQ0ssWUFBTyxHQUFHO1lBQ2QsS0FBSyxFQUFFLEVBQUU7WUFDVCxRQUFRLEVBQUUsRUFBRTtTQUNmLENBQUE7UUFFRCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBYWIsSUFBSSxRQUFRLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7WUFDbkIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDckIsT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBRWpDLHNCQUFzQjtJQUMxQixDQUFDO0lBWUQsWUFBWSxDQUFDLEtBQWMsRUFBRSxRQUFpQjtRQUMxQyxJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUN0QixJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxLQUFLLENBQUM7Z0JBQUUsTUFBTSxLQUFLLENBQUMsMEJBQTBCLENBQUMsQ0FBQztZQUVuSCxLQUFLLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUM7WUFDM0IsUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO1FBQ3JDLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxPQUFP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\n\n//# sourceURL=webpack://PW/./dist/api/PWApiClient.js?");
30
30
 
31
31
  /***/ }),
32
32
 
@@ -36,7 +36,7 @@ eval("\nvar _PWApiClient_token, _PWApiClient_account;\nObject.defineProperty(exp
36
36
  \***********************************/
37
37
  /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
38
38
 
39
- eval("\nvar _PWGameClient_instances, _PWGameClient_prevWorldId, _PWGameClient_createSocket;\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst tslib_1 = __webpack_require__(/*! tslib */ \"./node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.mjs\");\nconst world_pb_js_1 = __webpack_require__(/*! ../gen/world_pb.js */ \"./dist/gen/world_pb.js\");\nconst Constants_js_1 = __webpack_require__(/*! ../util/Constants.js */ \"./dist/util/Constants.js\");\nconst isows_1 = __webpack_require__(/*! isows */ \"./node_modules/.pnpm/isows@1.0.6_ws@8.18.0/node_modules/isows/_esm/native.js\");\nconst protobuf_1 = __webpack_require__(/*! @bufbuild/protobuf */ \"./node_modules/.pnpm/@bufbuild+protobuf@2.2.3/node_modules/@bufbuild/protobuf/dist/cjs/index.js\");\nconst Bucket_js_1 = tslib_1.__importDefault(__webpack_require__(/*! ../util/Bucket.js */ \"./dist/util/Bucket.js\"));\nclass PWGameClient {\n constructor(api, settings) {\n var _a, _b, _c, _d;\n _PWGameClient_instances.add(this);\n _PWGameClient_prevWorldId.set(this, void 0);\n this.totalBucket = new Bucket_js_1.default(100, 1000);\n this.chatBucket = new Bucket_js_1.default(10, 1000);\n // listen<Event extends keyof WorldEvents>(type: Event) {\n // type === \"\"\n // }\n /**\n * For faster performance (even if it seems insignificant),\n * direct functions are used instead of events which are also inconsistent with browsers/nodejs etc.\n *\n * NOTE: the \"this\" won't be the client itself. You will need to bind yourself if you want to keep this.\n */\n this.callbacks = {};\n // I can't use instanceof cos of circular reference kms.\n if (api && \"getJoinKey\" in api)\n this.api = api;\n else if (api) {\n settings = api;\n api = undefined;\n }\n this.settings = {\n reconnectable: (_a = settings === null || settings === void 0 ? void 0 : settings.reconnectable) !== null && _a !== void 0 ? _a : true,\n reconnectCount: (_b = settings === null || settings === void 0 ? void 0 : settings.reconnectCount) !== null && _b !== void 0 ? _b : 3,\n reconnectInterval: (_c = settings === null || settings === void 0 ? void 0 : settings.reconnectInterval) !== null && _c !== void 0 ? _c : 5500,\n handlePackets: (_d = settings === null || settings === void 0 ? void 0 : settings.handlePackets) !== null && _d !== void 0 ? _d : [\"PING\"]\n };\n }\n get connected() {\n var _a;\n return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === isows_1.WebSocket.OPEN;\n }\n /**\n * This will connect to the world.\n *\n * (This returns itself for chaining)\n */\n joinWorld(roomId, joinData) {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n var _a, _b, _c, _d;\n if (!this.api)\n throw Error(\"This can only work if you've used APIClient to join the world in the first place.\");\n if (((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === isows_1.WebSocket.CONNECTING)\n throw Error(\"Already trying to connect.\");\n // if (!this.api.loggedIn) throw Error(\"API isn't logged in, you must use authenticate first.\");\n const roomType = (_c = (_b = this.api.roomTypes) === null || _b === void 0 ? void 0 : _b[0]) !== null && _c !== void 0 ? _c : yield this.api.getRoomTypes().then(rTypes => rTypes[0]);\n const joinReq = yield this.api.getJoinKey(roomType, roomId);\n if (!(\"token\" in joinReq) || joinReq.token.length === 0)\n throw Error(\"Unable to secure a join key - is account details valid?\");\n const connectUrl = `${Constants_js_1.Endpoint.GameWS}/room/${joinReq.token}`\n + (joinData === undefined ? \"\" : \"?joinData=\" + btoa(JSON.stringify(joinData)));\n tslib_1.__classPrivateFieldSet(this, _PWGameClient_prevWorldId, roomId, \"f\");\n let count = (_d = this.settings.reconnectCount) !== null && _d !== void 0 ? _d : 3;\n return new Promise((res, rej) => {\n var _a;\n const timer = setTimeout(() => {\n if (count-- < 0)\n rej(new Error(\"Unable to (re)connect.\"));\n this.invoke(\"debug\", \"Failed to reconnect, retrying.\");\n this.socket = tslib_1.__classPrivateFieldGet(this, _PWGameClient_instances, \"m\", _PWGameClient_createSocket).call(this, connectUrl, timer, res);\n timer.refresh();\n }, (_a = this.settings.reconnectInterval) !== null && _a !== void 0 ? _a : 5500);\n this.socket = tslib_1.__classPrivateFieldGet(this, _PWGameClient_instances, \"m\", _PWGameClient_createSocket).call(this, connectUrl, timer, res);\n });\n });\n }\n /**\n * This is a more direct route if you already have a join key acquired via Pixelwalker's API.\n *\n * Useful for those wary of security.\n */\n static joinWorld(joinKey, obj) {\n var _a;\n const connectUrl = `${Constants_js_1.Endpoint.GameWS}/room/${joinKey}`\n + ((obj === null || obj === void 0 ? void 0 : obj.joinData) === undefined ? \"\" : \"?joinData=\" + btoa(JSON.stringify(obj.joinData)));\n const cli = new PWGameClient(obj === null || obj === void 0 ? void 0 : obj.gameSettings);\n let count = (_a = cli.settings.reconnectCount) !== null && _a !== void 0 ? _a : 3;\n return new Promise((res, rej) => {\n var _a;\n const timer = setTimeout(() => {\n if (count-- < 0)\n rej(new Error(\"Unable to (re)connect.\"));\n cli.invoke(\"debug\", \"Failed to reconnect, retrying.\");\n // I know this is impossible but anyway\n cli.socket = tslib_1.__classPrivateFieldGet(cli, _PWGameClient_instances, \"m\", _PWGameClient_createSocket).call(cli, connectUrl, timer, res);\n timer.refresh();\n }, (_a = cli.settings.reconnectInterval) !== null && _a !== void 0 ? _a : 5500);\n cli.socket = tslib_1.__classPrivateFieldGet(cli, _PWGameClient_instances, \"m\", _PWGameClient_createSocket).call(cli, connectUrl, timer, res);\n });\n }\n onSocketClose(evt) {\n this.invoke(\"debug\", `Server closed connection due to code: ${evt.code}, reason: ${evt.reason}.`);\n if (this.settings.reconnectable) {\n if (this.api === undefined)\n return this.invoke(\"debug\", \"Not attempting to reconnect as this game client was created with a join token.\");\n if (tslib_1.__classPrivateFieldGet(this, _PWGameClient_prevWorldId, \"f\"))\n return this.joinWorld(tslib_1.__classPrivateFieldGet(this, _PWGameClient_prevWorldId, \"f\"));\n else\n this.invoke(\"debug\", \"Warning: Socket closed, attempt to reconnect was made but no previous world id was kept.\");\n }\n }\n onSocketMessage(evt) {\n var _a;\n const { packet } = (0, protobuf_1.fromBinary)(world_pb_js_1.WorldPacketSchema, evt.data instanceof ArrayBuffer ? new Uint8Array(evt.data) : evt.data);\n this.invoke(\"debug\", \"Received \" + packet.case);\n if (packet.case === undefined) {\n return this.invoke(\"unknown\", packet.value);\n }\n else\n this.invoke(\"raw\", packet); //this.callbacks.raw?.(packet);;\n switch (packet.case) {\n case \"playerInitPacket\":\n if (this.settings.handlePackets.findIndex(v => v === \"INIT\") !== -1)\n this.send(\"playerInitReceived\");\n if ((_a = packet.value.playerProperties) === null || _a === void 0 ? void 0 : _a.isWorldOwner)\n this.totalBucket.interval = 250;\n else\n this.totalBucket.interval = 100;\n break;\n case \"ping\":\n if (this.settings.handlePackets.findIndex(v => v === \"PING\") !== -1)\n this.send(\"ping\", undefined, true);\n break;\n }\n this.invoke(packet.case, packet.value);\n }\n /**\n * Adds a listener for the event type, it can even be a promise too.\n *\n * If the callback returns a specific string \"STOP\", it will prevent further listeners from being invoked.\n */\n addCallback(type, ...cbs) {\n // this.callbacks[type] = cb;\n if (this.callbacks[type] === undefined)\n this.callbacks[type] = [];\n if (cbs.length === 0)\n return this;\n this.callbacks[type].push(...cbs);\n return this;\n }\n /**\n * @param type The type of the event\n * @param cb It can be the function itself (to remove that specific function). If undefined, it will remove ALL functions from that list, it will return undefined.\n */\n removeCallback(type, cb) {\n const callbacks = this.callbacks[type];\n if (callbacks === undefined || cb === undefined) {\n callbacks === null || callbacks === void 0 ? void 0 : callbacks.splice(0);\n return;\n }\n else {\n for (let i = 0, len = callbacks.length; i < len; i++) {\n if (callbacks[i] === cb) {\n return callbacks.splice(i, 1)[0];\n }\n }\n }\n return;\n }\n /**\n * INTERNAL. Invokes all functions of a callback type, unless one of them prohibits in transit.\n */\n invoke(type, data) {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n const cbs = this.callbacks[type];\n let count = 0;\n if (cbs === undefined)\n return count;\n for (let i = 0, len = cbs.length; i < len; i++) {\n const res = yield cbs[i](data);\n count++;\n if (res === \"STOP\")\n return count;\n }\n return count;\n });\n }\n /**\n * This assumes that the connection\n *\n * @param type Type of the packet.\n * @param value Value of the packet to send along with, note that some properties are optional.\n * @param direct If it should skip queue.\n */\n send(type, value, direct = false) {\n this.invoke(\"debug\", \"Sent \" + type + \" with \" + (value === undefined ? \"0\" : Object.keys(value).length) + \" parameters.\");\n const send = () => {\n var _a;\n return (_a = this.socket) === null || _a === void 0 ? void 0 : _a.send((0, protobuf_1.toBinary)(world_pb_js_1.WorldPacketSchema, (0, protobuf_1.create)(world_pb_js_1.WorldPacketSchema, { packet: { case: type, value } })));\n };\n if (direct)\n return send();\n this.totalBucket.queue(() => {\n if (type !== \"playerChatPacket\")\n send();\n else\n this.chatBucket.queue(() => { send(); });\n }, type === \"playerChatPacket\");\n }\n}\n_PWGameClient_prevWorldId = new WeakMap(), _PWGameClient_instances = new WeakSet(), _PWGameClient_createSocket = function _PWGameClient_createSocket(url, timer, res) {\n const socket = new isows_1.WebSocket(url);\n socket.binaryType = \"arraybuffer\";\n socket.onclose = this.onSocketClose.bind(this);\n socket.onmessage = this.onSocketMessage.bind(this);\n socket.onopen = (evt) => {\n clearTimeout(timer);\n this.invoke(\"debug\", \"Connected successfully.\");\n // console.log(\"Connected.\");\n // console.log(\"Connected: \" + new Date(ev.timeStamp));\n res(this);\n };\n return socket;\n};\nexports[\"default\"] = PWGameClient;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUFdHYW1lQ2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2dhbWUvUFdHYW1lQ2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFDQSxvREFBbUo7QUFFbkosdURBQWdEO0FBRWhELGlDQUFrQztBQUNsQyxpREFBa0U7QUFFbEUsMEVBQXVDO0FBR3ZDLE1BQXFCLFlBQVk7SUFpQjdCLFlBQVksR0FBK0MsRUFBRSxRQUFzQzs7O1FBWG5HLDRDQUFzQjtRQUVaLGdCQUFXLEdBQUcsSUFBSSxtQkFBTSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQyxlQUFVLEdBQUcsSUFBSSxtQkFBTSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztRQXVKNUMseURBQXlEO1FBQ3pELGtCQUFrQjtRQUNsQixJQUFJO1FBRUo7Ozs7O1dBS0c7UUFDTyxjQUFTLEdBQUcsRUFFa0YsQ0FBQztRQTFKckcsd0RBQXdEO1FBQ3hELElBQUksR0FBRyxJQUFJLFlBQVksSUFBSSxHQUFHO1lBQUUsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7YUFDMUMsSUFBSSxHQUFHLEVBQUUsQ0FBQztZQUNYLFFBQVEsR0FBRyxHQUFHLENBQUM7WUFDZixHQUFHLEdBQUcsU0FBUyxDQUFDO1FBQ3BCLENBQUM7UUFFRCxJQUFJLENBQUMsUUFBUSxHQUFHO1lBQ1osYUFBYSxFQUFFLE1BQUEsUUFBUSxhQUFSLFFBQVEsdUJBQVIsUUFBUSxDQUFFLGFBQWEsbUNBQUksSUFBSTtZQUM5QyxjQUFjLEVBQUUsTUFBQSxRQUFRLGFBQVIsUUFBUSx1QkFBUixRQUFRLENBQUUsY0FBYyxtQ0FBSSxDQUFDO1lBQzdDLGlCQUFpQixFQUFFLE1BQUEsUUFBUSxhQUFSLFFBQVEsdUJBQVIsUUFBUSxDQUFFLGlCQUFpQixtQ0FBSSxJQUFJO1lBQ3RELGFBQWEsRUFBRSxNQUFBLFFBQVEsYUFBUixRQUFRLHVCQUFSLFFBQVEsQ0FBRSxh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\n\n//# sourceURL=webpack://PW/./dist/game/PWGameClient.js?");
39
+ eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst tslib_1 = __webpack_require__(/*! tslib */ \"./node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.mjs\");\nconst world_pb_js_1 = __webpack_require__(/*! ../gen/world_pb.js */ \"./dist/gen/world_pb.js\");\nconst Constants_js_1 = __webpack_require__(/*! ../util/Constants.js */ \"./dist/util/Constants.js\");\nconst isows_1 = __webpack_require__(/*! isows */ \"./node_modules/.pnpm/isows@1.0.6_ws@8.18.0/node_modules/isows/_esm/native.js\");\nconst protobuf_1 = __webpack_require__(/*! @bufbuild/protobuf */ \"./node_modules/.pnpm/@bufbuild+protobuf@2.2.3/node_modules/@bufbuild/protobuf/dist/cjs/index.js\");\nconst Bucket_js_1 = tslib_1.__importDefault(__webpack_require__(/*! ../util/Bucket.js */ \"./dist/util/Bucket.js\"));\nclass PWGameClient {\n constructor(api, settings) {\n var _a, _b, _c, _d;\n this.totalBucket = new Bucket_js_1.default(100, 1000);\n this.chatBucket = new Bucket_js_1.default(10, 1000);\n // listen<Event extends keyof WorldEvents>(type: Event) {\n // type === \"\"\n // }\n /**\n * For faster performance (even if it seems insignificant),\n * direct functions are used instead of events which are also inconsistent with browsers/nodejs etc.\n *\n * NOTE: the \"this\" won't be the client itself. You will need to bind yourself if you want to keep this.\n */\n this.callbacks = {};\n // I can't use instanceof cos of circular reference kms.\n if (api && \"getJoinKey\" in api)\n this.api = api;\n else if (api) {\n settings = api;\n api = undefined;\n }\n this.settings = {\n reconnectable: (_a = settings === null || settings === void 0 ? void 0 : settings.reconnectable) !== null && _a !== void 0 ? _a : true,\n reconnectCount: (_b = settings === null || settings === void 0 ? void 0 : settings.reconnectCount) !== null && _b !== void 0 ? _b : 3,\n reconnectInterval: (_c = settings === null || settings === void 0 ? void 0 : settings.reconnectInterval) !== null && _c !== void 0 ? _c : 5500,\n handlePackets: (_d = settings === null || settings === void 0 ? void 0 : settings.handlePackets) !== null && _d !== void 0 ? _d : [\"PING\"]\n };\n }\n get connected() {\n var _a;\n return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === isows_1.WebSocket.OPEN;\n }\n /**\n * This will connect to the world.\n *\n * (This returns itself for chaining)\n */\n joinWorld(roomId, joinData) {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n var _a, _b, _c, _d;\n if (!this.api)\n throw Error(\"This can only work if you've used APIClient to join the world in the first place.\");\n if (((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === isows_1.WebSocket.CONNECTING)\n throw Error(\"Already trying to connect.\");\n // if (!this.api.loggedIn) throw Error(\"API isn't logged in, you must use authenticate first.\");\n const roomType = (_c = (_b = this.api.roomTypes) === null || _b === void 0 ? void 0 : _b[0]) !== null && _c !== void 0 ? _c : yield this.api.getRoomTypes().then(rTypes => rTypes[0]);\n const joinReq = yield this.api.getJoinKey(roomType, roomId);\n if (!(\"token\" in joinReq) || joinReq.token.length === 0)\n throw Error(\"Unable to secure a join key - is account details valid?\");\n const connectUrl = `${Constants_js_1.Endpoint.GameWS}/room/${joinReq.token}`\n + (joinData === undefined ? \"\" : \"?joinData=\" + btoa(JSON.stringify(joinData)));\n this.prevWorldId = roomId;\n let count = (_d = this.settings.reconnectCount) !== null && _d !== void 0 ? _d : 3;\n return new Promise((res, rej) => {\n var _a;\n const timer = setTimeout(() => {\n if (count-- < 0)\n rej(new Error(\"Unable to (re)connect.\"));\n this.invoke(\"debug\", \"Failed to reconnect, retrying.\");\n this.socket = this.createSocket(connectUrl, timer, res);\n timer.refresh();\n }, (_a = this.settings.reconnectInterval) !== null && _a !== void 0 ? _a : 5500);\n this.socket = this.createSocket(connectUrl, timer, res);\n });\n });\n }\n /**\n * INTERNAL\n */\n createSocket(url, timer, res) {\n const socket = new isows_1.WebSocket(url);\n socket.binaryType = \"arraybuffer\";\n socket.onclose = this.onSocketClose.bind(this);\n socket.onmessage = this.onSocketMessage.bind(this);\n socket.onopen = (evt) => {\n clearTimeout(timer);\n this.invoke(\"debug\", \"Connected successfully.\");\n // console.log(\"Connected.\");\n // console.log(\"Connected: \" + new Date(ev.timeStamp));\n res(this);\n };\n return socket;\n }\n /**\n * This is a more direct route if you already have a join key acquired via Pixelwalker's API.\n *\n * Useful for those wary of security.\n */\n static joinWorld(joinKey, obj) {\n var _a;\n const connectUrl = `${Constants_js_1.Endpoint.GameWS}/room/${joinKey}`\n + ((obj === null || obj === void 0 ? void 0 : obj.joinData) === undefined ? \"\" : \"?joinData=\" + btoa(JSON.stringify(obj.joinData)));\n const cli = new PWGameClient(obj === null || obj === void 0 ? void 0 : obj.gameSettings);\n let count = (_a = cli.settings.reconnectCount) !== null && _a !== void 0 ? _a : 3;\n return new Promise((res, rej) => {\n var _a;\n const timer = setTimeout(() => {\n if (count-- < 0)\n rej(new Error(\"Unable to (re)connect.\"));\n cli.invoke(\"debug\", \"Failed to reconnect, retrying.\");\n // I know this is impossible but anyway\n cli.socket = cli.createSocket(connectUrl, timer, res);\n timer.refresh();\n }, (_a = cli.settings.reconnectInterval) !== null && _a !== void 0 ? _a : 5500);\n cli.socket = cli.createSocket(connectUrl, timer, res);\n });\n }\n onSocketClose(evt) {\n this.invoke(\"debug\", `Server closed connection due to code: ${evt.code}, reason: ${evt.reason}.`);\n if (this.settings.reconnectable) {\n if (this.api === undefined)\n return this.invoke(\"debug\", \"Not attempting to reconnect as this game client was created with a join token.\");\n if (this.prevWorldId)\n return this.joinWorld(this.prevWorldId);\n else\n this.invoke(\"debug\", \"Warning: Socket closed, attempt to reconnect was made but no previous world id was kept.\");\n }\n }\n onSocketMessage(evt) {\n var _a;\n const { packet } = (0, protobuf_1.fromBinary)(world_pb_js_1.WorldPacketSchema, evt.data instanceof ArrayBuffer ? new Uint8Array(evt.data) : evt.data);\n this.invoke(\"debug\", \"Received \" + packet.case);\n if (packet.case === undefined) {\n return this.invoke(\"unknown\", packet.value);\n }\n else\n this.invoke(\"raw\", packet); //this.callbacks.raw?.(packet);;\n switch (packet.case) {\n case \"playerInitPacket\":\n if (this.settings.handlePackets.findIndex(v => v === \"INIT\") !== -1)\n this.send(\"playerInitReceived\");\n if ((_a = packet.value.playerProperties) === null || _a === void 0 ? void 0 : _a.isWorldOwner)\n this.totalBucket.interval = 250;\n else\n this.totalBucket.interval = 100;\n break;\n case \"ping\":\n if (this.settings.handlePackets.findIndex(v => v === \"PING\") !== -1)\n this.send(\"ping\", undefined, true);\n break;\n }\n this.invoke(packet.case, packet.value);\n }\n /**\n * Adds a listener for the event type, it can even be a promise too.\n *\n * If the callback returns a specific string \"STOP\", it will prevent further listeners from being invoked.\n */\n addCallback(type, ...cbs) {\n // this.callbacks[type] = cb;\n if (this.callbacks[type] === undefined)\n this.callbacks[type] = [];\n if (cbs.length === 0)\n return this;\n this.callbacks[type].push(...cbs);\n return this;\n }\n /**\n * @param type The type of the event\n * @param cb It can be the function itself (to remove that specific function). If undefined, it will remove ALL functions from that list, it will return undefined.\n */\n removeCallback(type, cb) {\n const callbacks = this.callbacks[type];\n if (callbacks === undefined || cb === undefined) {\n callbacks === null || callbacks === void 0 ? void 0 : callbacks.splice(0);\n return;\n }\n else {\n for (let i = 0, len = callbacks.length; i < len; i++) {\n if (callbacks[i] === cb) {\n return callbacks.splice(i, 1)[0];\n }\n }\n }\n return;\n }\n /**\n * INTERNAL. Invokes all functions of a callback type, unless one of them prohibits in transit.\n */\n invoke(type, data) {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n const cbs = this.callbacks[type];\n let count = 0;\n if (cbs === undefined)\n return count;\n for (let i = 0, len = cbs.length; i < len; i++) {\n const res = yield cbs[i](data);\n count++;\n if (res === \"STOP\")\n return count;\n }\n return count;\n });\n }\n /**\n * This assumes that the connection\n *\n * @param type Type of the packet.\n * @param value Value of the packet to send along with, note that some properties are optional.\n * @param direct If it should skip queue.\n */\n send(type, value, direct = false) {\n this.invoke(\"debug\", \"Sent \" + type + \" with \" + (value === undefined ? \"0\" : Object.keys(value).length) + \" parameters.\");\n const send = () => {\n var _a;\n return (_a = this.socket) === null || _a === void 0 ? void 0 : _a.send((0, protobuf_1.toBinary)(world_pb_js_1.WorldPacketSchema, (0, protobuf_1.create)(world_pb_js_1.WorldPacketSchema, { packet: { case: type, value } })));\n };\n if (direct)\n return send();\n this.totalBucket.queue(() => {\n if (type !== \"playerChatPacket\")\n send();\n else\n this.chatBucket.queue(() => { send(); });\n }, type === \"playerChatPacket\");\n }\n /**\n * By default this will set the game client settings reconnectable to false.\n *\n * If reconnect is true, an additionl parameter can be passed which is the amount of time to wait before it attempts to reconnect (DEFAULT: none)\n */\n disconnect(reconnect = false) {\n var _a, _b;\n // Accept the possibility that people may try to \n if (reconnect === true)\n this.settings.reconnectable = true;\n else\n this.settings.reconnectable = false;\n (_a = this.socket) === null || _a === void 0 ? void 0 : _a.close();\n return ((_b = this.socket) === null || _b === void 0 ? void 0 : _b.readyState) === isows_1.WebSocket.CLOSED;\n }\n}\nexports[\"default\"] = PWGameClient;\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUFdHYW1lQ2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2dhbWUvUFdHYW1lQ2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLG9EQUFtSjtBQUVuSix1REFBZ0Q7QUFFaEQsaUNBQWtDO0FBQ2xDLGlEQUFrRTtBQUVsRSwwRUFBdUM7QUFHdkMsTUFBcUIsWUFBWTtJQWdCN0IsWUFBWSxHQUErQyxFQUFFLFFBQXNDOztRQVJ6RixnQkFBVyxHQUFHLElBQUksbUJBQU0sQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDcEMsZUFBVSxHQUFHLElBQUksbUJBQU0sQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7UUF5SjVDLHlEQUF5RDtRQUN6RCxrQkFBa0I7UUFDbEIsSUFBSTtRQUVKOzs7OztXQUtHO1FBQ08sY0FBUyxHQUFHLEVBRWtGLENBQUM7UUE3SnJHLHdEQUF3RDtRQUN4RCxJQUFJLEdBQUcsSUFBSSxZQUFZLElBQUksR0FBRztZQUFFLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO2FBQzFDLElBQUksR0FBRyxFQUFFLENBQUM7WUFDWCxRQUFRLEdBQUcsR0FBRyxDQUFDO1lBQ2YsR0FBRyxHQUFHLFNBQVMsQ0FBQztRQUNwQixDQUFDO1FBRUQsSUFBSSxDQUFDLFFBQVEsR0FBRztZQUNaLGFBQWEsRUFBRSxNQUFBLFFBQVEsYUFBUixRQUFRLHVCQUFSLFFBQVEsQ0FBRSxhQUFhLG1DQUFJLElBQUk7WUFDOUMsY0FBYyxFQUFFLE1BQUEsUUFBUSxhQUFSLFFBQVEsdUJBQVIsUUFBUSxDQUFFLGNBQWMsbUNBQUksQ0FBQztZQUM3QyxpQkFBaUIsRUFBRSxNQUFBLFFBQVEsYUFBUixRQUFRLHVCQUFSLFFBQVEsQ0FBRSxpQkFBaUIsbUNBQUksSUFBSTtZQUN0RCxhQUFhLEVBQUUsTUFBQSxRQUFRLGFBQVIsUUFBUSx1QkFBUixRQUFRLENBQUUsYUFBYSxtQ0FBSSxDQUFD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\n\n//# sourceURL=webpack://PW/./dist/game/PWGameClient.js?");
40
40
 
41
41
  /***/ }),
42
42