@wandelbots/nova-js 3.11.2 → 3.11.3-pr.304.8c06a4e
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/dist/{context-kT2C20EX.mjs → context-CmXqEEwW.mjs} +47 -6
- package/dist/context-CmXqEEwW.mjs.map +1 -0
- package/dist/{context-TPb5fGlK.cjs → context-Cu5mXcFZ.cjs} +70 -5
- package/dist/context-Cu5mXcFZ.cjs.map +1 -0
- package/dist/index.cjs +6 -37
- package/dist/index.d.cts +7 -1
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts +7 -1
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +3 -35
- package/dist/v1/index.cjs +2 -2
- package/dist/v1/index.mjs +2 -2
- package/dist/v2/index.cjs +3 -6
- package/dist/v2/index.cjs.map +1 -1
- package/dist/v2/index.d.cts.map +1 -1
- package/dist/v2/index.d.mts.map +1 -1
- package/dist/v2/index.mjs +3 -6
- package/dist/v2/index.mjs.map +1 -1
- package/dist/{wandelscriptUtils-dUlZrOhy.cjs → wandelscriptUtils-BdqeVDCY.cjs} +3 -3
- package/dist/wandelscriptUtils-BdqeVDCY.cjs.map +1 -0
- package/dist/{wandelscriptUtils-CwtdZRDs.mjs → wandelscriptUtils-CKhiZJsB.mjs} +3 -3
- package/dist/{wandelscriptUtils-CwtdZRDs.mjs.map → wandelscriptUtils-CKhiZJsB.mjs.map} +1 -1
- package/dist/wandelscriptUtils-DY3WsiuB.d.cts.map +1 -1
- package/dist/wandelscriptUtils-YHTxn_p9.d.mts.map +1 -1
- package/package.json +3 -3
- package/src/lib/LoginWithAuth0.ts +3 -4
- package/src/lib/Nova.ts +2 -2
- package/src/lib/deprecated/v1/NovaClient.ts +2 -1
- package/src/lib/deprecated/v2/NovaClient.ts +2 -1
- package/src/lib/errorHandling.ts +22 -0
- package/dist/context-TPb5fGlK.cjs.map +0 -1
- package/dist/context-kT2C20EX.mjs.map +0 -1
- package/dist/index.cjs.map +0 -1
- package/dist/index.mjs.map +0 -1
- package/dist/wandelscriptUtils-dUlZrOhy.cjs.map +0 -1
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import ReconnectingWebSocket from "reconnecting-websocket";
|
|
2
|
+
import { isAxiosError } from "axios";
|
|
2
3
|
//#region src/lib/AutoReconnectingWebsocket.ts
|
|
3
4
|
var AutoReconnectingWebsocket = class extends ReconnectingWebSocket {
|
|
4
5
|
receivedFirstMessage;
|
|
@@ -236,6 +237,49 @@ const XYZ_TO_VECTOR = {
|
|
|
236
237
|
z: 2
|
|
237
238
|
};
|
|
238
239
|
//#endregion
|
|
240
|
+
//#region src/lib/errorHandling.ts
|
|
241
|
+
function delay(ms) {
|
|
242
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code
|
|
246
|
+
*/
|
|
247
|
+
function makeShortErrorMessage(err) {
|
|
248
|
+
return makeErrorMessage(err);
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Attempts to make a helpful error message from an unknown thrown error
|
|
252
|
+
* or promise rejection.
|
|
253
|
+
*
|
|
254
|
+
* This function is mainly to aid debugging and good bug reports. For
|
|
255
|
+
* expected errors encountered by end users, it's more ideal to catch
|
|
256
|
+
* the specific error code and provide a localized app-specific error message.
|
|
257
|
+
*/
|
|
258
|
+
function makeErrorMessage(err) {
|
|
259
|
+
if (isAxiosError(err)) {
|
|
260
|
+
if (err.response) return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || "accessing"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`;
|
|
261
|
+
else if (err.config) if (err.code === "ERR_NETWORK") return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`;
|
|
262
|
+
else return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}`;
|
|
263
|
+
} else if (err instanceof Error) return err.message;
|
|
264
|
+
else if (typeof err === "string") return err;
|
|
265
|
+
else if (typeof err === "object") return tryStringifyJson(err) || `Unserializable object ${err}`;
|
|
266
|
+
return `${err}`;
|
|
267
|
+
}
|
|
268
|
+
/**
|
|
269
|
+
* Reloads the page with protection against loops.
|
|
270
|
+
* Allows at most one reload per 10 seconds; otherwise throws
|
|
271
|
+
* an error.
|
|
272
|
+
*/
|
|
273
|
+
function guardedPageReload(key) {
|
|
274
|
+
const RELOAD_KEY = `novajs_reload_guard:${key}`;
|
|
275
|
+
const RELOAD_COOLDOWN_MS = 1e4;
|
|
276
|
+
const lastReloadAt = Number(window.sessionStorage.getItem(RELOAD_KEY) ?? "0");
|
|
277
|
+
if (Date.now() - lastReloadAt < RELOAD_COOLDOWN_MS) throw new Error(`Unhandled error caused a reload (${key}), but a reload was already attempted recently. Aborting to prevent reload loop.`);
|
|
278
|
+
window.sessionStorage.setItem(RELOAD_KEY, String(Date.now()));
|
|
279
|
+
window.location.reload();
|
|
280
|
+
return new Promise(() => {});
|
|
281
|
+
}
|
|
282
|
+
//#endregion
|
|
239
283
|
//#region src/lib/LoginWithAuth0.ts
|
|
240
284
|
/**
|
|
241
285
|
* Mapping of stages to Auth0 configurations.
|
|
@@ -271,10 +315,7 @@ const getAuth0Config = (instanceUrl) => {
|
|
|
271
315
|
*/
|
|
272
316
|
const loginWithAuth0 = async (instanceUrl) => {
|
|
273
317
|
if (typeof window === "undefined") throw new Error(`Access token must be set to use NovaClient when not in a browser environment.`);
|
|
274
|
-
if (instanceUrl.origin === window.location.origin)
|
|
275
|
-
window.location.reload();
|
|
276
|
-
throw new Error("Failed to reload page to get auth details, please refresh manually");
|
|
277
|
-
}
|
|
318
|
+
if (instanceUrl.origin === window.location.origin) return guardedPageReload("cloud_instance_auth");
|
|
278
319
|
const { Auth0Client } = await import("@auth0/auth0-spa-js");
|
|
279
320
|
const auth0Config = getAuth0Config(instanceUrl);
|
|
280
321
|
const auth0Client = new Auth0Client({
|
|
@@ -297,6 +338,6 @@ const loginWithAuth0 = async (instanceUrl) => {
|
|
|
297
338
|
const isBrowser = typeof window !== "undefined";
|
|
298
339
|
const isLocalhostDev = isBrowser && window.location.hostname === "localhost" && process.env.NODE_ENV === "development";
|
|
299
340
|
//#endregion
|
|
300
|
-
export {
|
|
341
|
+
export { tryParseUrl as _, delay as a, AutoReconnectingWebsocket as b, makeShortErrorMessage as c, isSameCoordinateSystem as d, makeUrlQueryString as f, tryParseJson as g, radiansToDegrees as h, loginWithAuth0 as i, XYZ_TO_VECTOR as l, parseUrl as m, isLocalhostDev as n, guardedPageReload as o, parseNovaInstanceUrl as p, getAuth0Config as r, makeErrorMessage as s, isBrowser as t, degreesToRadians as u, tryStringifyJson as v, availableStorage as y };
|
|
301
342
|
|
|
302
|
-
//# sourceMappingURL=context-
|
|
343
|
+
//# sourceMappingURL=context-CmXqEEwW.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-CmXqEEwW.mjs","names":[],"sources":["../src/lib/AutoReconnectingWebsocket.ts","../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts","../src/lib/context.ts"],"sourcesContent":["import ReconnectingWebSocket, { type ErrorEvent } from \"reconnecting-websocket\"\nimport type * as v1 from \"./deprecated/v1/mock/MockNovaInstance.ts\"\nimport type * as v2 from \"./mock/MockNovaInstance.ts\"\n\nexport class AutoReconnectingWebsocket extends ReconnectingWebSocket {\n receivedFirstMessage?: MessageEvent\n targetUrl: string\n disposed = false\n readonly opts: {\n mock?: v1.MockNovaInstance | v2.MockNovaInstance\n onDispose?: () => void\n }\n\n constructor(\n targetUrl: string,\n opts: {\n mock?: v1.MockNovaInstance | v2.MockNovaInstance\n onDispose?: () => void\n } = {},\n ) {\n console.log(\"Opening websocket to\", targetUrl)\n\n super(() => this.targetUrl || targetUrl, undefined, {\n startClosed: true,\n })\n\n // Reconnecting websocket doesn't set this properly with startClosed\n Object.defineProperty(this, \"url\", {\n get() {\n return this.targetUrl\n },\n })\n\n this.targetUrl = targetUrl\n this.opts = opts\n\n this.addEventListener(\"open\", () => {\n console.log(`Websocket to ${this.url} opened`)\n })\n\n this.addEventListener(\"message\", (ev) => {\n if (!this.receivedFirstMessage) {\n this.receivedFirstMessage = ev\n }\n })\n\n this.addEventListener(\"close\", () => {\n console.log(`Websocket to ${this.url} closed`)\n })\n\n const origReconnect = this.reconnect\n this.reconnect = () => {\n if (this.opts.mock) {\n this.opts.mock.handleWebsocketConnection(this)\n } else {\n origReconnect.apply(this)\n }\n }\n\n this.reconnect()\n }\n\n changeUrl(targetUrl: string) {\n this.receivedFirstMessage = undefined\n this.targetUrl = targetUrl\n this.reconnect()\n }\n\n sendJson(data: unknown) {\n if (this.opts.mock) {\n this.opts.mock.handleWebsocketMessage(this, JSON.stringify(data))\n } else {\n this.send(JSON.stringify(data))\n }\n }\n\n /**\n * Permanently close this websocket and indicate that\n * this object should not be used again.\n **/\n dispose() {\n this.close()\n this.disposed = true\n if (this.opts.onDispose) {\n this.opts.onDispose()\n }\n }\n\n /**\n * Returns a promise that resolves once the websocket\n * is in the OPEN state. */\n async opened() {\n return new Promise<void>((resolve, reject) => {\n if (this.readyState === WebSocket.OPEN) {\n resolve()\n } else {\n this.addEventListener(\"open\", () => resolve())\n this.addEventListener(\"error\", reject)\n }\n })\n }\n\n /**\n * Returns a promise that resolves once the websocket\n * is in the CLOSED state. */\n async closed() {\n return new Promise<void>((resolve, reject) => {\n if (this.readyState === WebSocket.CLOSED) {\n resolve()\n } else {\n this.addEventListener(\"close\", () => resolve())\n this.addEventListener(\"error\", reject)\n }\n })\n }\n\n /**\n * Returns a promise that resolves when the first message\n * is received from the websocket. Resolves immediately if\n * the first message has already been received.\n */\n async firstMessage() {\n if (this.receivedFirstMessage) {\n return this.receivedFirstMessage\n }\n\n return new Promise<MessageEvent>((resolve, reject) => {\n const onMessage = (ev: MessageEvent) => {\n this.receivedFirstMessage = ev\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n resolve(ev)\n }\n\n const onError = (ev: ErrorEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n reject(ev)\n }\n\n this.addEventListener(\"message\", onMessage)\n this.addEventListener(\"error\", onError)\n })\n }\n\n /**\n * Returns a promise that resolves when the next message\n * is received from the websocket.\n */\n async nextMessage() {\n return new Promise<MessageEvent>((resolve, reject) => {\n const onMessage = (ev: MessageEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n resolve(ev)\n }\n\n const onError = (ev: ErrorEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n reject(ev)\n }\n\n this.addEventListener(\"message\", onMessage)\n this.addEventListener(\"error\", onError)\n })\n }\n}\n","/**\n * Safety wrapper around browser localStorage providing context availability\n * checks and JSON parsing\n */\nclass AvailableStorage {\n available = typeof window !== \"undefined\" && !!window.localStorage\n\n getJSON<T>(key: string): Partial<T> | null {\n if (!this.available) return null\n\n const result = window.localStorage.getItem(key)\n if (result === null) return null\n\n try {\n return JSON.parse(result)\n } catch (err) {\n return null\n }\n }\n\n setJSON(key: string, obj: unknown) {\n if (!this.available) return null\n\n window.localStorage.setItem(key, JSON.stringify(obj))\n }\n\n delete(key: string) {\n if (!this.available) return null\n\n window.localStorage.removeItem(key)\n }\n\n setString(key: string, value: string) {\n if (!this.available) return null\n\n window.localStorage.setItem(key, value)\n }\n\n getString(key: string): string | null {\n if (!this.available) return null\n\n return window.localStorage.getItem(key)\n }\n}\n\nexport const availableStorage = new AvailableStorage()\n","export type URLParseOptions = {\n /**\n * Ignore any scheme in the input string and force this scheme instead.\n */\n scheme?: \"http\" | \"https\"\n /**\n * If the input string does not include a scheme, use this as the default\n * scheme.\n */\n defaultScheme?: \"http\" | \"https\"\n}\n\n/**\n * Parse a string as a URL, with options to enforce or default the scheme.\n */\nexport function parseUrl(url: string, options: URLParseOptions = {}): URL {\n const { scheme, defaultScheme } = options\n\n const schemeRegex = /^[a-zA-Z]+:\\/\\//\n\n if (scheme) {\n // Force the scheme by removing any existing scheme and prepending the desired one\n url = url.replace(schemeRegex, \"\")\n url = `${scheme}://${url}`\n } else if (defaultScheme && !schemeRegex.test(url)) {\n // No scheme is present, add the default one\n url = `${defaultScheme}://${url}`\n }\n\n return new URL(url)\n}\n\n/**\n * Attempt to parse a string as a URL; return undefined if we can't\n */\nexport function tryParseUrl(\n url: string,\n options: URLParseOptions = {},\n): URL | undefined {\n try {\n return parseUrl(url, options)\n } catch {\n return undefined\n }\n}\n\n/**\n * Permissively parse a NOVA instance URL from a config variable.\n * If scheme is not specified, defaults to https for *.wandelbots.io hosts,\n * and http otherwise.\n * Throws an error if a valid URL could not be determined.\n */\nexport function parseNovaInstanceUrl(url: string): URL {\n const testUrl = tryParseUrl(url, { defaultScheme: \"http\" })\n if (testUrl?.host.endsWith(\".wandelbots.io\")) {\n return parseUrl(url, { defaultScheme: \"https\" })\n } else {\n return parseUrl(url, { defaultScheme: \"http\" })\n }\n}\n\n/** Try to parse something as JSON; return undefined if we can't */\n// biome-ignore lint/suspicious/noExplicitAny: it's json\nexport function tryParseJson(json: unknown): any {\n try {\n return JSON.parse(json as string)\n } catch {\n return undefined\n }\n}\n\n/** Try to turn something into JSON; return undefined if we can't */\nexport function tryStringifyJson(json: unknown): string | undefined {\n try {\n return JSON.stringify(json)\n } catch {\n return undefined\n }\n}\n\n/**\n * Converts object parameters to query string.\n * e.g. { a: \"1\", b: \"2\" } => \"?a=1&b=2\"\n * {} => \"\"\n */\nexport function makeUrlQueryString(obj: Record<string, string>): string {\n const str = new URLSearchParams(obj).toString()\n return str ? `?${str}` : \"\"\n}\n\n/** Convert radians to degrees */\nexport function radiansToDegrees(radians: number): number {\n return radians * (180 / Math.PI)\n}\n\n/** Convert degrees to radians */\nexport function degreesToRadians(degrees: number): number {\n return degrees * (Math.PI / 180)\n}\n\n/**\n * Check for coordinate system id equivalence, accounting for the \"world\" default\n * on empty/undefined values.\n */\nexport function isSameCoordinateSystem(\n firstCoordSystem: string | undefined,\n secondCoordSystem: string | undefined,\n) {\n if (!firstCoordSystem) firstCoordSystem = \"world\"\n if (!secondCoordSystem) secondCoordSystem = \"world\"\n\n return firstCoordSystem === secondCoordSystem\n}\n\n/**\n * Helpful const for converting {x, y, z} to [x, y, z] and vice versa\n */\nexport const XYZ_TO_VECTOR = { x: 0, y: 1, z: 2 }\n","import { isAxiosError } from \"axios\"\nimport { tryStringifyJson } from \"./converters.ts\"\n\nexport function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms))\n}\n\n/**\n * @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code\n */\nexport function makeShortErrorMessage(err: unknown) {\n return makeErrorMessage(err)\n}\n\n/**\n * Attempts to make a helpful error message from an unknown thrown error\n * or promise rejection.\n *\n * This function is mainly to aid debugging and good bug reports. For\n * expected errors encountered by end users, it's more ideal to catch\n * the specific error code and provide a localized app-specific error message.\n */\nexport function makeErrorMessage(err: unknown): string {\n if (isAxiosError(err)) {\n if (err.response) {\n return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || \"accessing\"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`\n } else if (err.config) {\n if (err.code === \"ERR_NETWORK\") {\n return `${err.message} from ${err.config.method?.toUpperCase() || \"accessing\"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`\n } else {\n return `${err.message} from ${err.config.method?.toUpperCase() || \"accessing\"} ${err.config.url}`\n }\n }\n } else if (err instanceof Error) {\n return err.message\n } else if (typeof err === \"string\") {\n return err\n } else if (typeof err === \"object\") {\n return tryStringifyJson(err) || `Unserializable object ${err}`\n }\n\n return `${err}`\n}\n\n/**\n * Reloads the page with protection against loops.\n * Allows at most one reload per 10 seconds; otherwise throws\n * an error.\n */\nexport function guardedPageReload(key: string): Promise<never> {\n const RELOAD_KEY = `novajs_reload_guard:${key}`\n const RELOAD_COOLDOWN_MS = 10_000\n const lastReloadAt = Number(window.sessionStorage.getItem(RELOAD_KEY) ?? \"0\")\n\n if (Date.now() - lastReloadAt < RELOAD_COOLDOWN_MS) {\n throw new Error(\n `Unhandled error caused a reload (${key}), but a reload was already attempted recently. Aborting to prevent reload loop.`,\n )\n }\n\n window.sessionStorage.setItem(RELOAD_KEY, String(Date.now()))\n window.location.reload()\n\n return new Promise(() => {}) // never settles, the page should be reloading\n}\n","import { guardedPageReload } from \"./errorHandling.ts\"\n\n/**\n * Mapping of stages to Auth0 configurations.\n * The client ids are public identifiers for a specific auth0 application\n * and are safe to include in client-side code.\n * https://auth0.com/docs/get-started/applications/application-settings\n */\nconst auth0ConfigMap = {\n dev: {\n domain: `https://auth.portal.dev.wandelbots.io`,\n clientId: \"fLbJD0RLp5r2Dpucm5j8BjwMR6Hunfha\",\n },\n stg: {\n domain: `https://auth.portal.stg.wandelbots.io`,\n clientId: \"joVDeD9e786WzFNSGCqoVq7HNkWt5j6s\",\n },\n prod: {\n domain: `https://auth.portal.wandelbots.io`,\n clientId: \"J7WJUi38xVQdJAEBNRT9Xw1b0fXDb4J2\",\n },\n}\n\n/** Determine which Auth0 configuration to use based on instance URL */\nexport const getAuth0Config = (instanceUrl: URL) => {\n if (instanceUrl.host.endsWith(\".dev.wandelbots.io\")) return auth0ConfigMap.dev\n if (instanceUrl.host.endsWith(\".stg.wandelbots.io\")) return auth0ConfigMap.stg\n if (instanceUrl.host.endsWith(\".wandelbots.io\")) return auth0ConfigMap.prod\n throw new Error(\n `Unable to authenticate with NOVA instance \"${instanceUrl}\". Auth0 login is only supported for cloud instances with hosts of the form \"**.wandelbots.io\".`,\n )\n}\n\n/**\n * Initializes Auth0 login process using redirect if necessary and retrieves an access token.\n * Returns null when an access token should not be needed to authenticate (i.e. cookie auth\n * when deployed on the instance domain)\n */\nexport const loginWithAuth0 = async (\n instanceUrl: URL,\n): Promise<string | null> => {\n if (typeof window === \"undefined\") {\n throw new Error(\n `Access token must be set to use NovaClient when not in a browser environment.`,\n )\n }\n\n if (instanceUrl.origin === window.location.origin) {\n // When deployed on the instance itself, our auth is handled by cookies\n // and no access token is needed-- just need to reload the page and it'll\n // login again / set cookie as needed\n return guardedPageReload(\"cloud_instance_auth\")\n }\n\n // If we're on localhost or another domain, we need to do the full oauth flow\n // Note this will ONLY work for origins which are whitelisted as a redirect_uri\n // in the auth0 config, currently\n const { Auth0Client } = await import(\"@auth0/auth0-spa-js\")\n\n const auth0Config = getAuth0Config(instanceUrl)\n\n const auth0Client = new Auth0Client({\n domain: auth0Config.domain,\n clientId: auth0Config.clientId ?? \"\",\n useRefreshTokens: false,\n authorizationParams: {\n audience: \"nova-api\",\n redirect_uri: window.location.origin,\n },\n })\n\n // If the URL includes a redirect result, handle it\n if (\n window.location.search.includes(\"code=\") &&\n window.location.search.includes(\"state=\")\n ) {\n const { appState } = await auth0Client.handleRedirectCallback()\n // Return to the URL the user was originally on before the redirect\n window.history.replaceState(\n {},\n document.title,\n appState?.returnTo || window.location.pathname,\n )\n } else {\n // Initiate login with redirect\n await auth0Client.loginWithRedirect()\n }\n\n // Once logged in, retrieve the access token silently\n const accessToken = await auth0Client.getTokenSilently()\n return accessToken\n}\n","// Some general checks about the context the nova-js code is running in\n\nexport const isBrowser = typeof window !== \"undefined\"\n\nexport const isLocalhostDev =\n isBrowser &&\n window.location.hostname === \"localhost\" &&\n process.env.NODE_ENV === \"development\"\n"],"mappings":"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"}
|
|
@@ -22,6 +22,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
22
22
|
//#endregion
|
|
23
23
|
let reconnecting_websocket = require("reconnecting-websocket");
|
|
24
24
|
reconnecting_websocket = __toESM(reconnecting_websocket, 1);
|
|
25
|
+
let axios = require("axios");
|
|
25
26
|
//#region src/lib/AutoReconnectingWebsocket.ts
|
|
26
27
|
var AutoReconnectingWebsocket = class extends reconnecting_websocket.default {
|
|
27
28
|
receivedFirstMessage;
|
|
@@ -259,6 +260,49 @@ const XYZ_TO_VECTOR = {
|
|
|
259
260
|
z: 2
|
|
260
261
|
};
|
|
261
262
|
//#endregion
|
|
263
|
+
//#region src/lib/errorHandling.ts
|
|
264
|
+
function delay(ms) {
|
|
265
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
266
|
+
}
|
|
267
|
+
/**
|
|
268
|
+
* @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code
|
|
269
|
+
*/
|
|
270
|
+
function makeShortErrorMessage(err) {
|
|
271
|
+
return makeErrorMessage(err);
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Attempts to make a helpful error message from an unknown thrown error
|
|
275
|
+
* or promise rejection.
|
|
276
|
+
*
|
|
277
|
+
* This function is mainly to aid debugging and good bug reports. For
|
|
278
|
+
* expected errors encountered by end users, it's more ideal to catch
|
|
279
|
+
* the specific error code and provide a localized app-specific error message.
|
|
280
|
+
*/
|
|
281
|
+
function makeErrorMessage(err) {
|
|
282
|
+
if ((0, axios.isAxiosError)(err)) {
|
|
283
|
+
if (err.response) return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || "accessing"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`;
|
|
284
|
+
else if (err.config) if (err.code === "ERR_NETWORK") return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`;
|
|
285
|
+
else return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}`;
|
|
286
|
+
} else if (err instanceof Error) return err.message;
|
|
287
|
+
else if (typeof err === "string") return err;
|
|
288
|
+
else if (typeof err === "object") return tryStringifyJson(err) || `Unserializable object ${err}`;
|
|
289
|
+
return `${err}`;
|
|
290
|
+
}
|
|
291
|
+
/**
|
|
292
|
+
* Reloads the page with protection against loops.
|
|
293
|
+
* Allows at most one reload per 10 seconds; otherwise throws
|
|
294
|
+
* an error.
|
|
295
|
+
*/
|
|
296
|
+
function guardedPageReload(key) {
|
|
297
|
+
const RELOAD_KEY = `novajs_reload_guard:${key}`;
|
|
298
|
+
const RELOAD_COOLDOWN_MS = 1e4;
|
|
299
|
+
const lastReloadAt = Number(window.sessionStorage.getItem(RELOAD_KEY) ?? "0");
|
|
300
|
+
if (Date.now() - lastReloadAt < RELOAD_COOLDOWN_MS) throw new Error(`Unhandled error caused a reload (${key}), but a reload was already attempted recently. Aborting to prevent reload loop.`);
|
|
301
|
+
window.sessionStorage.setItem(RELOAD_KEY, String(Date.now()));
|
|
302
|
+
window.location.reload();
|
|
303
|
+
return new Promise(() => {});
|
|
304
|
+
}
|
|
305
|
+
//#endregion
|
|
262
306
|
//#region src/lib/LoginWithAuth0.ts
|
|
263
307
|
/**
|
|
264
308
|
* Mapping of stages to Auth0 configurations.
|
|
@@ -294,10 +338,7 @@ const getAuth0Config = (instanceUrl) => {
|
|
|
294
338
|
*/
|
|
295
339
|
const loginWithAuth0 = async (instanceUrl) => {
|
|
296
340
|
if (typeof window === "undefined") throw new Error(`Access token must be set to use NovaClient when not in a browser environment.`);
|
|
297
|
-
if (instanceUrl.origin === window.location.origin)
|
|
298
|
-
window.location.reload();
|
|
299
|
-
throw new Error("Failed to reload page to get auth details, please refresh manually");
|
|
300
|
-
}
|
|
341
|
+
if (instanceUrl.origin === window.location.origin) return guardedPageReload("cloud_instance_auth");
|
|
301
342
|
const { Auth0Client } = await import("@auth0/auth0-spa-js");
|
|
302
343
|
const auth0Config = getAuth0Config(instanceUrl);
|
|
303
344
|
const auth0Client = new Auth0Client({
|
|
@@ -350,12 +391,24 @@ Object.defineProperty(exports, "degreesToRadians", {
|
|
|
350
391
|
return degreesToRadians;
|
|
351
392
|
}
|
|
352
393
|
});
|
|
394
|
+
Object.defineProperty(exports, "delay", {
|
|
395
|
+
enumerable: true,
|
|
396
|
+
get: function() {
|
|
397
|
+
return delay;
|
|
398
|
+
}
|
|
399
|
+
});
|
|
353
400
|
Object.defineProperty(exports, "getAuth0Config", {
|
|
354
401
|
enumerable: true,
|
|
355
402
|
get: function() {
|
|
356
403
|
return getAuth0Config;
|
|
357
404
|
}
|
|
358
405
|
});
|
|
406
|
+
Object.defineProperty(exports, "guardedPageReload", {
|
|
407
|
+
enumerable: true,
|
|
408
|
+
get: function() {
|
|
409
|
+
return guardedPageReload;
|
|
410
|
+
}
|
|
411
|
+
});
|
|
359
412
|
Object.defineProperty(exports, "isBrowser", {
|
|
360
413
|
enumerable: true,
|
|
361
414
|
get: function() {
|
|
@@ -380,6 +433,18 @@ Object.defineProperty(exports, "loginWithAuth0", {
|
|
|
380
433
|
return loginWithAuth0;
|
|
381
434
|
}
|
|
382
435
|
});
|
|
436
|
+
Object.defineProperty(exports, "makeErrorMessage", {
|
|
437
|
+
enumerable: true,
|
|
438
|
+
get: function() {
|
|
439
|
+
return makeErrorMessage;
|
|
440
|
+
}
|
|
441
|
+
});
|
|
442
|
+
Object.defineProperty(exports, "makeShortErrorMessage", {
|
|
443
|
+
enumerable: true,
|
|
444
|
+
get: function() {
|
|
445
|
+
return makeShortErrorMessage;
|
|
446
|
+
}
|
|
447
|
+
});
|
|
383
448
|
Object.defineProperty(exports, "makeUrlQueryString", {
|
|
384
449
|
enumerable: true,
|
|
385
450
|
get: function() {
|
|
@@ -423,4 +488,4 @@ Object.defineProperty(exports, "tryStringifyJson", {
|
|
|
423
488
|
}
|
|
424
489
|
});
|
|
425
490
|
|
|
426
|
-
//# sourceMappingURL=context-
|
|
491
|
+
//# sourceMappingURL=context-Cu5mXcFZ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-Cu5mXcFZ.cjs","names":["ReconnectingWebSocket"],"sources":["../src/lib/AutoReconnectingWebsocket.ts","../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts","../src/lib/context.ts"],"sourcesContent":["import ReconnectingWebSocket, { type ErrorEvent } from \"reconnecting-websocket\"\nimport type * as v1 from \"./deprecated/v1/mock/MockNovaInstance.ts\"\nimport type * as v2 from \"./mock/MockNovaInstance.ts\"\n\nexport class AutoReconnectingWebsocket extends ReconnectingWebSocket {\n receivedFirstMessage?: MessageEvent\n targetUrl: string\n disposed = false\n readonly opts: {\n mock?: v1.MockNovaInstance | v2.MockNovaInstance\n onDispose?: () => void\n }\n\n constructor(\n targetUrl: string,\n opts: {\n mock?: v1.MockNovaInstance | v2.MockNovaInstance\n onDispose?: () => void\n } = {},\n ) {\n console.log(\"Opening websocket to\", targetUrl)\n\n super(() => this.targetUrl || targetUrl, undefined, {\n startClosed: true,\n })\n\n // Reconnecting websocket doesn't set this properly with startClosed\n Object.defineProperty(this, \"url\", {\n get() {\n return this.targetUrl\n },\n })\n\n this.targetUrl = targetUrl\n this.opts = opts\n\n this.addEventListener(\"open\", () => {\n console.log(`Websocket to ${this.url} opened`)\n })\n\n this.addEventListener(\"message\", (ev) => {\n if (!this.receivedFirstMessage) {\n this.receivedFirstMessage = ev\n }\n })\n\n this.addEventListener(\"close\", () => {\n console.log(`Websocket to ${this.url} closed`)\n })\n\n const origReconnect = this.reconnect\n this.reconnect = () => {\n if (this.opts.mock) {\n this.opts.mock.handleWebsocketConnection(this)\n } else {\n origReconnect.apply(this)\n }\n }\n\n this.reconnect()\n }\n\n changeUrl(targetUrl: string) {\n this.receivedFirstMessage = undefined\n this.targetUrl = targetUrl\n this.reconnect()\n }\n\n sendJson(data: unknown) {\n if (this.opts.mock) {\n this.opts.mock.handleWebsocketMessage(this, JSON.stringify(data))\n } else {\n this.send(JSON.stringify(data))\n }\n }\n\n /**\n * Permanently close this websocket and indicate that\n * this object should not be used again.\n **/\n dispose() {\n this.close()\n this.disposed = true\n if (this.opts.onDispose) {\n this.opts.onDispose()\n }\n }\n\n /**\n * Returns a promise that resolves once the websocket\n * is in the OPEN state. */\n async opened() {\n return new Promise<void>((resolve, reject) => {\n if (this.readyState === WebSocket.OPEN) {\n resolve()\n } else {\n this.addEventListener(\"open\", () => resolve())\n this.addEventListener(\"error\", reject)\n }\n })\n }\n\n /**\n * Returns a promise that resolves once the websocket\n * is in the CLOSED state. */\n async closed() {\n return new Promise<void>((resolve, reject) => {\n if (this.readyState === WebSocket.CLOSED) {\n resolve()\n } else {\n this.addEventListener(\"close\", () => resolve())\n this.addEventListener(\"error\", reject)\n }\n })\n }\n\n /**\n * Returns a promise that resolves when the first message\n * is received from the websocket. Resolves immediately if\n * the first message has already been received.\n */\n async firstMessage() {\n if (this.receivedFirstMessage) {\n return this.receivedFirstMessage\n }\n\n return new Promise<MessageEvent>((resolve, reject) => {\n const onMessage = (ev: MessageEvent) => {\n this.receivedFirstMessage = ev\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n resolve(ev)\n }\n\n const onError = (ev: ErrorEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n reject(ev)\n }\n\n this.addEventListener(\"message\", onMessage)\n this.addEventListener(\"error\", onError)\n })\n }\n\n /**\n * Returns a promise that resolves when the next message\n * is received from the websocket.\n */\n async nextMessage() {\n return new Promise<MessageEvent>((resolve, reject) => {\n const onMessage = (ev: MessageEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n resolve(ev)\n }\n\n const onError = (ev: ErrorEvent) => {\n this.removeEventListener(\"message\", onMessage)\n this.removeEventListener(\"error\", onError)\n reject(ev)\n }\n\n this.addEventListener(\"message\", onMessage)\n this.addEventListener(\"error\", onError)\n })\n }\n}\n","/**\n * Safety wrapper around browser localStorage providing context availability\n * checks and JSON parsing\n */\nclass AvailableStorage {\n available = typeof window !== \"undefined\" && !!window.localStorage\n\n getJSON<T>(key: string): Partial<T> | null {\n if (!this.available) return null\n\n const result = window.localStorage.getItem(key)\n if (result === null) return null\n\n try {\n return JSON.parse(result)\n } catch (err) {\n return null\n }\n }\n\n setJSON(key: string, obj: unknown) {\n if (!this.available) return null\n\n window.localStorage.setItem(key, JSON.stringify(obj))\n }\n\n delete(key: string) {\n if (!this.available) return null\n\n window.localStorage.removeItem(key)\n }\n\n setString(key: string, value: string) {\n if (!this.available) return null\n\n window.localStorage.setItem(key, value)\n }\n\n getString(key: string): string | null {\n if (!this.available) return null\n\n return window.localStorage.getItem(key)\n }\n}\n\nexport const availableStorage = new AvailableStorage()\n","export type URLParseOptions = {\n /**\n * Ignore any scheme in the input string and force this scheme instead.\n */\n scheme?: \"http\" | \"https\"\n /**\n * If the input string does not include a scheme, use this as the default\n * scheme.\n */\n defaultScheme?: \"http\" | \"https\"\n}\n\n/**\n * Parse a string as a URL, with options to enforce or default the scheme.\n */\nexport function parseUrl(url: string, options: URLParseOptions = {}): URL {\n const { scheme, defaultScheme } = options\n\n const schemeRegex = /^[a-zA-Z]+:\\/\\//\n\n if (scheme) {\n // Force the scheme by removing any existing scheme and prepending the desired one\n url = url.replace(schemeRegex, \"\")\n url = `${scheme}://${url}`\n } else if (defaultScheme && !schemeRegex.test(url)) {\n // No scheme is present, add the default one\n url = `${defaultScheme}://${url}`\n }\n\n return new URL(url)\n}\n\n/**\n * Attempt to parse a string as a URL; return undefined if we can't\n */\nexport function tryParseUrl(\n url: string,\n options: URLParseOptions = {},\n): URL | undefined {\n try {\n return parseUrl(url, options)\n } catch {\n return undefined\n }\n}\n\n/**\n * Permissively parse a NOVA instance URL from a config variable.\n * If scheme is not specified, defaults to https for *.wandelbots.io hosts,\n * and http otherwise.\n * Throws an error if a valid URL could not be determined.\n */\nexport function parseNovaInstanceUrl(url: string): URL {\n const testUrl = tryParseUrl(url, { defaultScheme: \"http\" })\n if (testUrl?.host.endsWith(\".wandelbots.io\")) {\n return parseUrl(url, { defaultScheme: \"https\" })\n } else {\n return parseUrl(url, { defaultScheme: \"http\" })\n }\n}\n\n/** Try to parse something as JSON; return undefined if we can't */\n// biome-ignore lint/suspicious/noExplicitAny: it's json\nexport function tryParseJson(json: unknown): any {\n try {\n return JSON.parse(json as string)\n } catch {\n return undefined\n }\n}\n\n/** Try to turn something into JSON; return undefined if we can't */\nexport function tryStringifyJson(json: unknown): string | undefined {\n try {\n return JSON.stringify(json)\n } catch {\n return undefined\n }\n}\n\n/**\n * Converts object parameters to query string.\n * e.g. { a: \"1\", b: \"2\" } => \"?a=1&b=2\"\n * {} => \"\"\n */\nexport function makeUrlQueryString(obj: Record<string, string>): string {\n const str = new URLSearchParams(obj).toString()\n return str ? `?${str}` : \"\"\n}\n\n/** Convert radians to degrees */\nexport function radiansToDegrees(radians: number): number {\n return radians * (180 / Math.PI)\n}\n\n/** Convert degrees to radians */\nexport function degreesToRadians(degrees: number): number {\n return degrees * (Math.PI / 180)\n}\n\n/**\n * Check for coordinate system id equivalence, accounting for the \"world\" default\n * on empty/undefined values.\n */\nexport function isSameCoordinateSystem(\n firstCoordSystem: string | undefined,\n secondCoordSystem: string | undefined,\n) {\n if (!firstCoordSystem) firstCoordSystem = \"world\"\n if (!secondCoordSystem) secondCoordSystem = \"world\"\n\n return firstCoordSystem === secondCoordSystem\n}\n\n/**\n * Helpful const for converting {x, y, z} to [x, y, z] and vice versa\n */\nexport const XYZ_TO_VECTOR = { x: 0, y: 1, z: 2 }\n","import { isAxiosError } from \"axios\"\nimport { tryStringifyJson } from \"./converters.ts\"\n\nexport function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms))\n}\n\n/**\n * @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code\n */\nexport function makeShortErrorMessage(err: unknown) {\n return makeErrorMessage(err)\n}\n\n/**\n * Attempts to make a helpful error message from an unknown thrown error\n * or promise rejection.\n *\n * This function is mainly to aid debugging and good bug reports. For\n * expected errors encountered by end users, it's more ideal to catch\n * the specific error code and provide a localized app-specific error message.\n */\nexport function makeErrorMessage(err: unknown): string {\n if (isAxiosError(err)) {\n if (err.response) {\n return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || \"accessing\"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`\n } else if (err.config) {\n if (err.code === \"ERR_NETWORK\") {\n return `${err.message} from ${err.config.method?.toUpperCase() || \"accessing\"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`\n } else {\n return `${err.message} from ${err.config.method?.toUpperCase() || \"accessing\"} ${err.config.url}`\n }\n }\n } else if (err instanceof Error) {\n return err.message\n } else if (typeof err === \"string\") {\n return err\n } else if (typeof err === \"object\") {\n return tryStringifyJson(err) || `Unserializable object ${err}`\n }\n\n return `${err}`\n}\n\n/**\n * Reloads the page with protection against loops.\n * Allows at most one reload per 10 seconds; otherwise throws\n * an error.\n */\nexport function guardedPageReload(key: string): Promise<never> {\n const RELOAD_KEY = `novajs_reload_guard:${key}`\n const RELOAD_COOLDOWN_MS = 10_000\n const lastReloadAt = Number(window.sessionStorage.getItem(RELOAD_KEY) ?? \"0\")\n\n if (Date.now() - lastReloadAt < RELOAD_COOLDOWN_MS) {\n throw new Error(\n `Unhandled error caused a reload (${key}), but a reload was already attempted recently. Aborting to prevent reload loop.`,\n )\n }\n\n window.sessionStorage.setItem(RELOAD_KEY, String(Date.now()))\n window.location.reload()\n\n return new Promise(() => {}) // never settles, the page should be reloading\n}\n","import { guardedPageReload } from \"./errorHandling.ts\"\n\n/**\n * Mapping of stages to Auth0 configurations.\n * The client ids are public identifiers for a specific auth0 application\n * and are safe to include in client-side code.\n * https://auth0.com/docs/get-started/applications/application-settings\n */\nconst auth0ConfigMap = {\n dev: {\n domain: `https://auth.portal.dev.wandelbots.io`,\n clientId: \"fLbJD0RLp5r2Dpucm5j8BjwMR6Hunfha\",\n },\n stg: {\n domain: `https://auth.portal.stg.wandelbots.io`,\n clientId: \"joVDeD9e786WzFNSGCqoVq7HNkWt5j6s\",\n },\n prod: {\n domain: `https://auth.portal.wandelbots.io`,\n clientId: \"J7WJUi38xVQdJAEBNRT9Xw1b0fXDb4J2\",\n },\n}\n\n/** Determine which Auth0 configuration to use based on instance URL */\nexport const getAuth0Config = (instanceUrl: URL) => {\n if (instanceUrl.host.endsWith(\".dev.wandelbots.io\")) return auth0ConfigMap.dev\n if (instanceUrl.host.endsWith(\".stg.wandelbots.io\")) return auth0ConfigMap.stg\n if (instanceUrl.host.endsWith(\".wandelbots.io\")) return auth0ConfigMap.prod\n throw new Error(\n `Unable to authenticate with NOVA instance \"${instanceUrl}\". Auth0 login is only supported for cloud instances with hosts of the form \"**.wandelbots.io\".`,\n )\n}\n\n/**\n * Initializes Auth0 login process using redirect if necessary and retrieves an access token.\n * Returns null when an access token should not be needed to authenticate (i.e. cookie auth\n * when deployed on the instance domain)\n */\nexport const loginWithAuth0 = async (\n instanceUrl: URL,\n): Promise<string | null> => {\n if (typeof window === \"undefined\") {\n throw new Error(\n `Access token must be set to use NovaClient when not in a browser environment.`,\n )\n }\n\n if (instanceUrl.origin === window.location.origin) {\n // When deployed on the instance itself, our auth is handled by cookies\n // and no access token is needed-- just need to reload the page and it'll\n // login again / set cookie as needed\n return guardedPageReload(\"cloud_instance_auth\")\n }\n\n // If we're on localhost or another domain, we need to do the full oauth flow\n // Note this will ONLY work for origins which are whitelisted as a redirect_uri\n // in the auth0 config, currently\n const { Auth0Client } = await import(\"@auth0/auth0-spa-js\")\n\n const auth0Config = getAuth0Config(instanceUrl)\n\n const auth0Client = new Auth0Client({\n domain: auth0Config.domain,\n clientId: auth0Config.clientId ?? \"\",\n useRefreshTokens: false,\n authorizationParams: {\n audience: \"nova-api\",\n redirect_uri: window.location.origin,\n },\n })\n\n // If the URL includes a redirect result, handle it\n if (\n window.location.search.includes(\"code=\") &&\n window.location.search.includes(\"state=\")\n ) {\n const { appState } = await auth0Client.handleRedirectCallback()\n // Return to the URL the user was originally on before the redirect\n window.history.replaceState(\n {},\n document.title,\n appState?.returnTo || window.location.pathname,\n )\n } else {\n // Initiate login with redirect\n await auth0Client.loginWithRedirect()\n }\n\n // Once logged in, retrieve the access token silently\n const accessToken = await auth0Client.getTokenSilently()\n return accessToken\n}\n","// Some general checks about the context the nova-js code is running in\n\nexport const isBrowser = typeof window !== \"undefined\"\n\nexport const isLocalhostDev =\n isBrowser &&\n window.location.hostname === \"localhost\" &&\n process.env.NODE_ENV === \"development\"\n"],"mappings":"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"}
|
package/dist/index.cjs
CHANGED
|
@@ -1,47 +1,18 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_context = require("./context-
|
|
3
|
-
const require_wandelscriptUtils = require("./wandelscriptUtils-
|
|
4
|
-
let axios = require("axios");
|
|
5
|
-
//#region src/lib/errorHandling.ts
|
|
6
|
-
function delay(ms) {
|
|
7
|
-
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
8
|
-
}
|
|
9
|
-
/**
|
|
10
|
-
* @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code
|
|
11
|
-
*/
|
|
12
|
-
function makeShortErrorMessage(err) {
|
|
13
|
-
return makeErrorMessage(err);
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Attempts to make a helpful error message from an unknown thrown error
|
|
17
|
-
* or promise rejection.
|
|
18
|
-
*
|
|
19
|
-
* This function is mainly to aid debugging and good bug reports. For
|
|
20
|
-
* expected errors encountered by end users, it's more ideal to catch
|
|
21
|
-
* the specific error code and provide a localized app-specific error message.
|
|
22
|
-
*/
|
|
23
|
-
function makeErrorMessage(err) {
|
|
24
|
-
if ((0, axios.isAxiosError)(err)) {
|
|
25
|
-
if (err.response) return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || "accessing"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`;
|
|
26
|
-
else if (err.config) if (err.code === "ERR_NETWORK") return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`;
|
|
27
|
-
else return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}`;
|
|
28
|
-
} else if (err instanceof Error) return err.message;
|
|
29
|
-
else if (typeof err === "string") return err;
|
|
30
|
-
else if (typeof err === "object") return require_context.tryStringifyJson(err) || `Unserializable object ${err}`;
|
|
31
|
-
return `${err}`;
|
|
32
|
-
}
|
|
33
|
-
//#endregion
|
|
2
|
+
const require_context = require("./context-Cu5mXcFZ.cjs");
|
|
3
|
+
const require_wandelscriptUtils = require("./wandelscriptUtils-BdqeVDCY.cjs");
|
|
34
4
|
exports.AutoReconnectingWebsocket = require_context.AutoReconnectingWebsocket;
|
|
35
5
|
exports.NovaClient = require_wandelscriptUtils.NovaClient;
|
|
36
6
|
exports.XYZ_TO_VECTOR = require_context.XYZ_TO_VECTOR;
|
|
37
7
|
exports.availableStorage = require_context.availableStorage;
|
|
38
8
|
exports.degreesToRadians = require_context.degreesToRadians;
|
|
39
|
-
exports.delay = delay;
|
|
9
|
+
exports.delay = require_context.delay;
|
|
40
10
|
exports.getAuth0Config = require_context.getAuth0Config;
|
|
11
|
+
exports.guardedPageReload = require_context.guardedPageReload;
|
|
41
12
|
exports.isSameCoordinateSystem = require_context.isSameCoordinateSystem;
|
|
42
13
|
exports.loginWithAuth0 = require_context.loginWithAuth0;
|
|
43
|
-
exports.makeErrorMessage = makeErrorMessage;
|
|
44
|
-
exports.makeShortErrorMessage = makeShortErrorMessage;
|
|
14
|
+
exports.makeErrorMessage = require_context.makeErrorMessage;
|
|
15
|
+
exports.makeShortErrorMessage = require_context.makeShortErrorMessage;
|
|
45
16
|
exports.makeUrlQueryString = require_context.makeUrlQueryString;
|
|
46
17
|
exports.parseNovaInstanceUrl = require_context.parseNovaInstanceUrl;
|
|
47
18
|
exports.parseUrl = require_context.parseUrl;
|
|
@@ -50,5 +21,3 @@ exports.radiansToDegrees = require_context.radiansToDegrees;
|
|
|
50
21
|
exports.tryParseJson = require_context.tryParseJson;
|
|
51
22
|
exports.tryParseUrl = require_context.tryParseUrl;
|
|
52
23
|
exports.tryStringifyJson = require_context.tryStringifyJson;
|
|
53
|
-
|
|
54
|
-
//# sourceMappingURL=index.cjs.map
|
package/dist/index.d.cts
CHANGED
|
@@ -86,6 +86,12 @@ declare function makeShortErrorMessage(err: unknown): string;
|
|
|
86
86
|
* the specific error code and provide a localized app-specific error message.
|
|
87
87
|
*/
|
|
88
88
|
declare function makeErrorMessage(err: unknown): string;
|
|
89
|
+
/**
|
|
90
|
+
* Reloads the page with protection against loops.
|
|
91
|
+
* Allows at most one reload per 10 seconds; otherwise throws
|
|
92
|
+
* an error.
|
|
93
|
+
*/
|
|
94
|
+
declare function guardedPageReload(key: string): Promise<never>;
|
|
89
95
|
//#endregion
|
|
90
96
|
//#region src/lib/LoginWithAuth0.d.ts
|
|
91
97
|
/** Determine which Auth0 configuration to use based on instance URL */
|
|
@@ -100,5 +106,5 @@ declare const getAuth0Config: (instanceUrl: URL) => {
|
|
|
100
106
|
*/
|
|
101
107
|
declare const loginWithAuth0: (instanceUrl: URL) => Promise<string | null>;
|
|
102
108
|
//#endregion
|
|
103
|
-
export { AutoReconnectingWebsocket, NovaClient, NovaClientConfig, URLParseOptions, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
|
109
|
+
export { AutoReconnectingWebsocket, NovaClient, NovaClientConfig, URLParseOptions, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, guardedPageReload, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
|
104
110
|
//# sourceMappingURL=index.d.cts.map
|
package/dist/index.d.cts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts"],"mappings":";;;;;;;;cAIM,gBAAA;EACJ,SAAA;EAEA,OAAA,IAAW,GAAA,WAAc,OAAO,CAAC,CAAA;EAajC,OAAA,CAAQ,GAAA,UAAa,GAAA;EAMrB,MAAA,CAAO,GAAA;EAMP,SAAA,CAAU,GAAA,UAAa,KAAA;EAMvB,SAAA,CAAU,GAAA;AAAA;AAAA,cAOC,gBAAA,EAAgB,gBAAyB;;;KC7C1C,eAAA;;;;EAIV,MAAA;EDAoB;;;;ECKpB,aAAa;AAAA;;;;iBAMC,QAAA,CAAS,GAAA,UAAa,OAAA,GAAS,eAAA,GAAuB,GAAG;;;;iBAoBzD,WAAA,CACd,GAAA,UACA,OAAA,GAAS,eAAA,GACR,GAAG;;;;;;;iBAcU,oBAAA,CAAqB,GAAA,WAAc,GAAG;ADPtD;AAAA,iBCkBgB,YAAA,CAAa,IAAa;;iBAS1B,gBAAA,CAAiB,IAAa;AD3BQ;;;;AC7CtD;AD6CsD,iBCwCtC,kBAAA,CAAmB,GAA2B,EAAtB,MAAM;;iBAM9B,gBAAA,CAAiB,OAAe;AAlFjC;AAAA,iBAuFC,gBAAA,CAAiB,OAAe;;;;;iBAQhC,sBAAA,CACd,gBAAA,sBACA,iBAAqC;;;;cAW1B,aAAA;;;;;;;iBClHG,KAAA,CAAM,EAAA,WAAU,OAAA;;;;iBAOhB,qBAAA,CAAsB,GAAY;;;;;;;;;iBAYlC,gBAAA,CAAiB,GAAY;;;;
|
|
1
|
+
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts"],"mappings":";;;;;;;;cAIM,gBAAA;EACJ,SAAA;EAEA,OAAA,IAAW,GAAA,WAAc,OAAO,CAAC,CAAA;EAajC,OAAA,CAAQ,GAAA,UAAa,GAAA;EAMrB,MAAA,CAAO,GAAA;EAMP,SAAA,CAAU,GAAA,UAAa,KAAA;EAMvB,SAAA,CAAU,GAAA;AAAA;AAAA,cAOC,gBAAA,EAAgB,gBAAyB;;;KC7C1C,eAAA;;;;EAIV,MAAA;EDAoB;;;;ECKpB,aAAa;AAAA;;;;iBAMC,QAAA,CAAS,GAAA,UAAa,OAAA,GAAS,eAAA,GAAuB,GAAG;;;;iBAoBzD,WAAA,CACd,GAAA,UACA,OAAA,GAAS,eAAA,GACR,GAAG;;;;;;;iBAcU,oBAAA,CAAqB,GAAA,WAAc,GAAG;ADPtD;AAAA,iBCkBgB,YAAA,CAAa,IAAa;;iBAS1B,gBAAA,CAAiB,IAAa;AD3BQ;;;;AC7CtD;AD6CsD,iBCwCtC,kBAAA,CAAmB,GAA2B,EAAtB,MAAM;;iBAM9B,gBAAA,CAAiB,OAAe;AAlFjC;AAAA,iBAuFC,gBAAA,CAAiB,OAAe;;;;;iBAQhC,sBAAA,CACd,gBAAA,sBACA,iBAAqC;;;;cAW1B,aAAA;;;;;;;iBClHG,KAAA,CAAM,EAAA,WAAU,OAAA;;;;iBAOhB,qBAAA,CAAsB,GAAY;;;;;;;;;iBAYlC,gBAAA,CAAiB,GAAY;;;;;;iBA2B7B,iBAAA,CAAkB,GAAA,WAAc,OAAO;;;;cCzB1C,cAAA,GAAkB,WAAA,EAAa,GAAG;;;;;;;;;cAclC,cAAA,GACX,WAAA,EAAa,GAAA,KACZ,OAAO"}
|
package/dist/index.d.mts
CHANGED
|
@@ -86,6 +86,12 @@ declare function makeShortErrorMessage(err: unknown): string;
|
|
|
86
86
|
* the specific error code and provide a localized app-specific error message.
|
|
87
87
|
*/
|
|
88
88
|
declare function makeErrorMessage(err: unknown): string;
|
|
89
|
+
/**
|
|
90
|
+
* Reloads the page with protection against loops.
|
|
91
|
+
* Allows at most one reload per 10 seconds; otherwise throws
|
|
92
|
+
* an error.
|
|
93
|
+
*/
|
|
94
|
+
declare function guardedPageReload(key: string): Promise<never>;
|
|
89
95
|
//#endregion
|
|
90
96
|
//#region src/lib/LoginWithAuth0.d.ts
|
|
91
97
|
/** Determine which Auth0 configuration to use based on instance URL */
|
|
@@ -100,5 +106,5 @@ declare const getAuth0Config: (instanceUrl: URL) => {
|
|
|
100
106
|
*/
|
|
101
107
|
declare const loginWithAuth0: (instanceUrl: URL) => Promise<string | null>;
|
|
102
108
|
//#endregion
|
|
103
|
-
export { AutoReconnectingWebsocket, NovaClient, NovaClientConfig, URLParseOptions, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
|
109
|
+
export { AutoReconnectingWebsocket, NovaClient, NovaClientConfig, URLParseOptions, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, guardedPageReload, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
|
104
110
|
//# sourceMappingURL=index.d.mts.map
|
package/dist/index.d.mts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.mts","names":[],"sources":["../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts"],"mappings":";;;;;;;;cAIM,gBAAA;EACJ,SAAA;EAEA,OAAA,IAAW,GAAA,WAAc,OAAO,CAAC,CAAA;EAajC,OAAA,CAAQ,GAAA,UAAa,GAAA;EAMrB,MAAA,CAAO,GAAA;EAMP,SAAA,CAAU,GAAA,UAAa,KAAA;EAMvB,SAAA,CAAU,GAAA;AAAA;AAAA,cAOC,gBAAA,EAAgB,gBAAyB;;;KC7C1C,eAAA;;;;EAIV,MAAA;EDAoB;;;;ECKpB,aAAa;AAAA;;;;iBAMC,QAAA,CAAS,GAAA,UAAa,OAAA,GAAS,eAAA,GAAuB,GAAG;;;;iBAoBzD,WAAA,CACd,GAAA,UACA,OAAA,GAAS,eAAA,GACR,GAAG;;;;;;;iBAcU,oBAAA,CAAqB,GAAA,WAAc,GAAG;ADPtD;AAAA,iBCkBgB,YAAA,CAAa,IAAa;;iBAS1B,gBAAA,CAAiB,IAAa;AD3BQ;;;;AC7CtD;AD6CsD,iBCwCtC,kBAAA,CAAmB,GAA2B,EAAtB,MAAM;;iBAM9B,gBAAA,CAAiB,OAAe;AAlFjC;AAAA,iBAuFC,gBAAA,CAAiB,OAAe;;;;;iBAQhC,sBAAA,CACd,gBAAA,sBACA,iBAAqC;;;;cAW1B,aAAA;;;;;;;iBClHG,KAAA,CAAM,EAAA,WAAU,OAAA;;;;iBAOhB,qBAAA,CAAsB,GAAY;;;;;;;;;iBAYlC,gBAAA,CAAiB,GAAY;;;;
|
|
1
|
+
{"version":3,"file":"index.d.mts","names":[],"sources":["../src/lib/availableStorage.ts","../src/lib/converters.ts","../src/lib/errorHandling.ts","../src/lib/LoginWithAuth0.ts"],"mappings":";;;;;;;;cAIM,gBAAA;EACJ,SAAA;EAEA,OAAA,IAAW,GAAA,WAAc,OAAO,CAAC,CAAA;EAajC,OAAA,CAAQ,GAAA,UAAa,GAAA;EAMrB,MAAA,CAAO,GAAA;EAMP,SAAA,CAAU,GAAA,UAAa,KAAA;EAMvB,SAAA,CAAU,GAAA;AAAA;AAAA,cAOC,gBAAA,EAAgB,gBAAyB;;;KC7C1C,eAAA;;;;EAIV,MAAA;EDAoB;;;;ECKpB,aAAa;AAAA;;;;iBAMC,QAAA,CAAS,GAAA,UAAa,OAAA,GAAS,eAAA,GAAuB,GAAG;;;;iBAoBzD,WAAA,CACd,GAAA,UACA,OAAA,GAAS,eAAA,GACR,GAAG;;;;;;;iBAcU,oBAAA,CAAqB,GAAA,WAAc,GAAG;ADPtD;AAAA,iBCkBgB,YAAA,CAAa,IAAa;;iBAS1B,gBAAA,CAAiB,IAAa;AD3BQ;;;;AC7CtD;AD6CsD,iBCwCtC,kBAAA,CAAmB,GAA2B,EAAtB,MAAM;;iBAM9B,gBAAA,CAAiB,OAAe;AAlFjC;AAAA,iBAuFC,gBAAA,CAAiB,OAAe;;;;;iBAQhC,sBAAA,CACd,gBAAA,sBACA,iBAAqC;;;;cAW1B,aAAA;;;;;;;iBClHG,KAAA,CAAM,EAAA,WAAU,OAAA;;;;iBAOhB,qBAAA,CAAsB,GAAY;;;;;;;;;iBAYlC,gBAAA,CAAiB,GAAY;;;;;;iBA2B7B,iBAAA,CAAkB,GAAA,WAAc,OAAO;;;;cCzB1C,cAAA,GAAkB,WAAA,EAAa,GAAG;;;;;;;;;cAclC,cAAA,GACX,WAAA,EAAa,GAAA,KACZ,OAAO"}
|
package/dist/index.mjs
CHANGED
|
@@ -1,35 +1,3 @@
|
|
|
1
|
-
import { a as
|
|
2
|
-
import { n as NovaClient, t as poseToWandelscriptString } from "./wandelscriptUtils-
|
|
3
|
-
|
|
4
|
-
//#region src/lib/errorHandling.ts
|
|
5
|
-
function delay(ms) {
|
|
6
|
-
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
7
|
-
}
|
|
8
|
-
/**
|
|
9
|
-
* @deprecated Use makeErrorMessage instead and truncate the error for display as needed, or make a situation-specific localized error message based on a response code
|
|
10
|
-
*/
|
|
11
|
-
function makeShortErrorMessage(err) {
|
|
12
|
-
return makeErrorMessage(err);
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Attempts to make a helpful error message from an unknown thrown error
|
|
16
|
-
* or promise rejection.
|
|
17
|
-
*
|
|
18
|
-
* This function is mainly to aid debugging and good bug reports. For
|
|
19
|
-
* expected errors encountered by end users, it's more ideal to catch
|
|
20
|
-
* the specific error code and provide a localized app-specific error message.
|
|
21
|
-
*/
|
|
22
|
-
function makeErrorMessage(err) {
|
|
23
|
-
if (isAxiosError(err)) {
|
|
24
|
-
if (err.response) return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.method?.toUpperCase() || "accessing"} ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`;
|
|
25
|
-
else if (err.config) if (err.code === "ERR_NETWORK") return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}. This error can happen because of either connection issues or server CORS policy.`;
|
|
26
|
-
else return `${err.message} from ${err.config.method?.toUpperCase() || "accessing"} ${err.config.url}`;
|
|
27
|
-
} else if (err instanceof Error) return err.message;
|
|
28
|
-
else if (typeof err === "string") return err;
|
|
29
|
-
else if (typeof err === "object") return tryStringifyJson(err) || `Unserializable object ${err}`;
|
|
30
|
-
return `${err}`;
|
|
31
|
-
}
|
|
32
|
-
//#endregion
|
|
33
|
-
export { AutoReconnectingWebsocket, NovaClient, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
|
34
|
-
|
|
35
|
-
//# sourceMappingURL=index.mjs.map
|
|
1
|
+
import { _ as tryParseUrl, a as delay, b as AutoReconnectingWebsocket, c as makeShortErrorMessage, d as isSameCoordinateSystem, f as makeUrlQueryString, g as tryParseJson, h as radiansToDegrees, i as loginWithAuth0, l as XYZ_TO_VECTOR, m as parseUrl, o as guardedPageReload, p as parseNovaInstanceUrl, r as getAuth0Config, s as makeErrorMessage, u as degreesToRadians, v as tryStringifyJson, y as availableStorage } from "./context-CmXqEEwW.mjs";
|
|
2
|
+
import { n as NovaClient, t as poseToWandelscriptString } from "./wandelscriptUtils-CKhiZJsB.mjs";
|
|
3
|
+
export { AutoReconnectingWebsocket, NovaClient, XYZ_TO_VECTOR, availableStorage, degreesToRadians, delay, getAuth0Config, guardedPageReload, isSameCoordinateSystem, loginWithAuth0, makeErrorMessage, makeShortErrorMessage, makeUrlQueryString, parseNovaInstanceUrl, parseUrl, poseToWandelscriptString, radiansToDegrees, tryParseJson, tryParseUrl, tryStringifyJson };
|
package/dist/v1/index.cjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_context = require("../context-
|
|
3
|
-
const require_wandelscriptUtils = require("../wandelscriptUtils-
|
|
2
|
+
const require_context = require("../context-Cu5mXcFZ.cjs");
|
|
3
|
+
const require_wandelscriptUtils = require("../wandelscriptUtils-BdqeVDCY.cjs");
|
|
4
4
|
let axios = require("axios");
|
|
5
5
|
let mobx = require("mobx");
|
|
6
6
|
//#region src/lib/deprecated/v1/getLatestTrajectories.ts
|
package/dist/v1/index.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { a as JoggerConnection, i as MotionStreamConnection, n as NovaClient, o as ConnectedMotionGroup, r as NovaCellAPIClient, t as poseToWandelscriptString } from "../wandelscriptUtils-
|
|
1
|
+
import { g as tryParseJson } from "../context-CmXqEEwW.mjs";
|
|
2
|
+
import { a as JoggerConnection, i as MotionStreamConnection, n as NovaClient, o as ConnectedMotionGroup, r as NovaCellAPIClient, t as poseToWandelscriptString } from "../wandelscriptUtils-CKhiZJsB.mjs";
|
|
3
3
|
import { AxiosError } from "axios";
|
|
4
4
|
import { makeAutoObservable, runInAction } from "mobx";
|
|
5
5
|
export * from "@wandelbots/nova-api/v1";
|
package/dist/v2/index.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_context = require("../context-
|
|
2
|
+
const require_context = require("../context-Cu5mXcFZ.cjs");
|
|
3
3
|
let axios = require("axios");
|
|
4
4
|
axios = require_context.__toESM(axios, 1);
|
|
5
5
|
let path_to_regexp = require("path-to-regexp");
|
|
@@ -762,7 +762,7 @@ var NovaClient = class {
|
|
|
762
762
|
return Promise.reject(err);
|
|
763
763
|
}
|
|
764
764
|
else if (error.response?.status === 503) {
|
|
765
|
-
if ((await fetch(window.location.href)).status === 503)
|
|
765
|
+
if ((await fetch(window.location.href)).status === 503) return require_context.guardedPageReload("503_server_unavailable");
|
|
766
766
|
}
|
|
767
767
|
}
|
|
768
768
|
return Promise.reject(error);
|
|
@@ -966,10 +966,7 @@ var Nova = class {
|
|
|
966
966
|
return new Promise(() => {});
|
|
967
967
|
}
|
|
968
968
|
} else if (error.response?.status === 503) {
|
|
969
|
-
if ((await fetch(window.location.href)).status === 503)
|
|
970
|
-
window.location.reload();
|
|
971
|
-
return new Promise(() => {});
|
|
972
|
-
}
|
|
969
|
+
if ((await fetch(window.location.href)).status === 503) return require_context.guardedPageReload("503_server_unavailable");
|
|
973
970
|
}
|
|
974
971
|
}
|
|
975
972
|
return Promise.reject(error);
|