@deephaven/auth-plugins 0.46.1-beta.0 → 0.46.1-beta.4
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/AuthPluginAnonymous.js +8 -5
- package/dist/AuthPluginAnonymous.js.map +1 -1
- package/dist/AuthPluginBase.js +6 -2
- package/dist/AuthPluginBase.js.map +1 -1
- package/dist/AuthPluginParent.js +8 -5
- package/dist/AuthPluginParent.js.map +1 -1
- package/dist/AuthPluginPsk.js +46 -36
- package/dist/AuthPluginPsk.js.map +1 -1
- package/dist/Login.js +18 -12
- package/dist/Login.js.map +1 -1
- package/dist/LoginForm.js +42 -29
- package/dist/LoginForm.js.map +1 -1
- package/package.json +10 -10
|
@@ -3,6 +3,7 @@ import { useApi } from '@deephaven/jsapi-bootstrap';
|
|
|
3
3
|
import { AUTH_HANDLER_TYPE_ANONYMOUS } from "./AuthHandlerTypes.js";
|
|
4
4
|
import AuthPluginBase from "./AuthPluginBase.js";
|
|
5
5
|
import { UserPermissionsOverrideContext } from "./UserContexts.js";
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
7
|
var permissionsOverrides = {
|
|
7
8
|
canLogout: false
|
|
8
9
|
};
|
|
@@ -18,11 +19,13 @@ function Component(_ref) {
|
|
|
18
19
|
var getLoginOptions = useCallback(() => ({
|
|
19
20
|
type: dh.CoreClient.LOGIN_TYPE_ANONYMOUS
|
|
20
21
|
}), [dh]);
|
|
21
|
-
return /*#__PURE__*/
|
|
22
|
-
getLoginOptions: getLoginOptions
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
22
|
+
return /*#__PURE__*/_jsx(AuthPluginBase, {
|
|
23
|
+
getLoginOptions: getLoginOptions,
|
|
24
|
+
children: /*#__PURE__*/_jsx(UserPermissionsOverrideContext.Provider, {
|
|
25
|
+
value: permissionsOverrides,
|
|
26
|
+
children: children
|
|
27
|
+
})
|
|
28
|
+
});
|
|
26
29
|
}
|
|
27
30
|
var AuthPluginAnonymous = {
|
|
28
31
|
Component,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthPluginAnonymous.js","names":["React","useCallback","useApi","AUTH_HANDLER_TYPE_ANONYMOUS","AuthPluginBase","UserPermissionsOverrideContext","permissionsOverrides","canLogout","Component","children","dh","getLoginOptions","type","CoreClient","LOGIN_TYPE_ANONYMOUS","AuthPluginAnonymous","isAvailable","authHandlers","includes"],"sources":["../src/AuthPluginAnonymous.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { useApi } from '@deephaven/jsapi-bootstrap';\nimport { AUTH_HANDLER_TYPE_ANONYMOUS } from './AuthHandlerTypes';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport AuthPluginBase from './AuthPluginBase';\nimport {\n UserPermissionsOverride,\n UserPermissionsOverrideContext,\n} from './UserContexts';\n\nconst permissionsOverrides: UserPermissionsOverride = { canLogout: false };\n\n/**\n * AuthPlugin that tries to login anonymously. Fails if anonymous login fails\n */\nfunction Component({ children }: AuthPluginProps): JSX.Element {\n const dh = useApi();\n\n const getLoginOptions = useCallback(\n () => ({ type: dh.CoreClient.LOGIN_TYPE_ANONYMOUS }),\n [dh]\n );\n\n return (\n <AuthPluginBase getLoginOptions={getLoginOptions}>\n <UserPermissionsOverrideContext.Provider value={permissionsOverrides}>\n {children}\n </UserPermissionsOverrideContext.Provider>\n </AuthPluginBase>\n );\n}\n\nconst AuthPluginAnonymous: AuthPlugin = {\n Component,\n isAvailable: authHandlers =>\n authHandlers.includes(AUTH_HANDLER_TYPE_ANONYMOUS),\n};\n\nexport default AuthPluginAnonymous;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,WAAW,QAAQ,OAAO;AAC1C,SAASC,MAAM,QAAQ,4BAA4B;AAAC,SAC3CC,2BAA2B;AAAA,OAE7BC,cAAc;AAAA,SAGnBC,8BAA8B;AAGhC,IAAMC,oBAA6C,GAAG;EAAEC,SAAS,EAAE;AAAM,CAAC;;AAE1E;AACA;AACA;AACA,SAASC,SAAS,OAA6C;EAAA,IAA5C;IAAEC;EAA0B,CAAC;EAC9C,IAAMC,EAAE,GAAGR,MAAM,EAAE;EAEnB,IAAMS,eAAe,GAAGV,WAAW,CACjC,OAAO;IAAEW,IAAI,EAAEF,EAAE,CAACG,UAAU,CAACC;EAAqB,CAAC,CAAC,EACpD,CAACJ,EAAE,CAAC,CACL;EAED,oBACE,
|
|
1
|
+
{"version":3,"file":"AuthPluginAnonymous.js","names":["React","useCallback","useApi","AUTH_HANDLER_TYPE_ANONYMOUS","AuthPluginBase","UserPermissionsOverrideContext","permissionsOverrides","canLogout","Component","children","dh","getLoginOptions","type","CoreClient","LOGIN_TYPE_ANONYMOUS","AuthPluginAnonymous","isAvailable","authHandlers","includes"],"sources":["../src/AuthPluginAnonymous.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { useApi } from '@deephaven/jsapi-bootstrap';\nimport { AUTH_HANDLER_TYPE_ANONYMOUS } from './AuthHandlerTypes';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport AuthPluginBase from './AuthPluginBase';\nimport {\n UserPermissionsOverride,\n UserPermissionsOverrideContext,\n} from './UserContexts';\n\nconst permissionsOverrides: UserPermissionsOverride = { canLogout: false };\n\n/**\n * AuthPlugin that tries to login anonymously. Fails if anonymous login fails\n */\nfunction Component({ children }: AuthPluginProps): JSX.Element {\n const dh = useApi();\n\n const getLoginOptions = useCallback(\n () => ({ type: dh.CoreClient.LOGIN_TYPE_ANONYMOUS }),\n [dh]\n );\n\n return (\n <AuthPluginBase getLoginOptions={getLoginOptions}>\n <UserPermissionsOverrideContext.Provider value={permissionsOverrides}>\n {children}\n </UserPermissionsOverrideContext.Provider>\n </AuthPluginBase>\n );\n}\n\nconst AuthPluginAnonymous: AuthPlugin = {\n Component,\n isAvailable: authHandlers =>\n authHandlers.includes(AUTH_HANDLER_TYPE_ANONYMOUS),\n};\n\nexport default AuthPluginAnonymous;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,WAAW,QAAQ,OAAO;AAC1C,SAASC,MAAM,QAAQ,4BAA4B;AAAC,SAC3CC,2BAA2B;AAAA,OAE7BC,cAAc;AAAA,SAGnBC,8BAA8B;AAAA;AAGhC,IAAMC,oBAA6C,GAAG;EAAEC,SAAS,EAAE;AAAM,CAAC;;AAE1E;AACA;AACA;AACA,SAASC,SAAS,OAA6C;EAAA,IAA5C;IAAEC;EAA0B,CAAC;EAC9C,IAAMC,EAAE,GAAGR,MAAM,EAAE;EAEnB,IAAMS,eAAe,GAAGV,WAAW,CACjC,OAAO;IAAEW,IAAI,EAAEF,EAAE,CAACG,UAAU,CAACC;EAAqB,CAAC,CAAC,EACpD,CAACJ,EAAE,CAAC,CACL;EAED,oBACE,KAAC,cAAc;IAAC,eAAe,EAAEC,eAAgB;IAAA,uBAC/C,KAAC,8BAA8B,CAAC,QAAQ;MAAC,KAAK,EAAEL,oBAAqB;MAAA,UAClEG;IAAQ;EAC+B,EAC3B;AAErB;AAEA,IAAMM,mBAA+B,GAAG;EACtCP,SAAS;EACTQ,WAAW,EAAEC,YAAY,IACvBA,YAAY,CAACC,QAAQ,CAACf,2BAA2B;AACrD,CAAC;AAED,eAAeY,mBAAmB"}
|
package/dist/AuthPluginBase.js
CHANGED
|
@@ -6,6 +6,8 @@ import { useClient } from '@deephaven/jsapi-bootstrap';
|
|
|
6
6
|
import Log from '@deephaven/log';
|
|
7
7
|
import { CanceledPromiseError, getErrorMessage } from '@deephaven/utils';
|
|
8
8
|
import AuthenticationError from "./AuthenticationError.js";
|
|
9
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
9
11
|
var log = Log.module('AuthPluginBase');
|
|
10
12
|
/**
|
|
11
13
|
* Base AuthPlugin that gets passed a function for retrieving the login options, and then attempting to login with them.
|
|
@@ -56,7 +58,7 @@ function AuthPluginBase(_ref) {
|
|
|
56
58
|
};
|
|
57
59
|
}, [client, getLoginOptions]);
|
|
58
60
|
if (!isLoggedIn) {
|
|
59
|
-
return /*#__PURE__*/
|
|
61
|
+
return /*#__PURE__*/_jsx(LoadingOverlay, {
|
|
60
62
|
"data-testid": "auth-base-loading",
|
|
61
63
|
isLoading: error == null,
|
|
62
64
|
isLoaded: false,
|
|
@@ -65,7 +67,9 @@ function AuthPluginBase(_ref) {
|
|
|
65
67
|
}
|
|
66
68
|
|
|
67
69
|
// eslint-disable-next-line react/jsx-no-useless-fragment
|
|
68
|
-
return /*#__PURE__*/
|
|
70
|
+
return /*#__PURE__*/_jsx(_Fragment, {
|
|
71
|
+
children: children
|
|
72
|
+
});
|
|
69
73
|
}
|
|
70
74
|
export default AuthPluginBase;
|
|
71
75
|
//# sourceMappingURL=AuthPluginBase.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthPluginBase.js","names":["React","useEffect","useState","LoadingOverlay","useClient","Log","CanceledPromiseError","getErrorMessage","AuthenticationError","log","module","AuthPluginBase","children","getLoginOptions","client","error","setError","isLoggedIn","setIsLoggedIn","isCanceled","verifyNotCanceled","login","loginOptions","info","e","message"],"sources":["../src/AuthPluginBase.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { LoadingOverlay } from '@deephaven/components';\nimport { useClient } from '@deephaven/jsapi-bootstrap';\nimport Log from '@deephaven/log';\nimport type { LoginOptions } from '@deephaven/jsapi-types';\nimport { CanceledPromiseError, getErrorMessage } from '@deephaven/utils';\nimport AuthenticationError from './AuthenticationError';\n\nconst log = Log.module('AuthPluginBase');\n\nexport type AuthPluginBaseProps = {\n /**\n * The children to render after authentication is completed.\n */\n children: React.ReactNode;\n\n /**\n * Retrieve the login options for logging in to the client\n * @returns A promise for the login options\n */\n getLoginOptions: () => LoginOptions | Promise<LoginOptions>;\n};\n\n/**\n * Base AuthPlugin that gets passed a function for retrieving the login options, and then attempting to login with them.\n * @param getLoginOptions Function that returns a promise for the login options\n */\nfunction AuthPluginBase({\n children,\n getLoginOptions,\n}: AuthPluginBaseProps): JSX.Element {\n const client = useClient();\n const [error, setError] = useState<unknown>();\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n\n useEffect(() => {\n let isCanceled = false;\n function verifyNotCanceled() {\n if (isCanceled) {\n throw new CanceledPromiseError('Login canceled.');\n }\n }\n async function login() {\n try {\n const loginOptions = await getLoginOptions();\n verifyNotCanceled();\n\n log.info('Logging in...');\n await client.login(loginOptions);\n verifyNotCanceled();\n\n setIsLoggedIn(true);\n } catch (e) {\n if (!isCanceled) {\n log.error('Unable to login:', e);\n const message =\n getErrorMessage(e) ?? 'Unable to login. Verify credentials.';\n setError(new AuthenticationError(message));\n setIsLoggedIn(false);\n }\n }\n }\n login();\n return () => {\n isCanceled = true;\n };\n }, [client, getLoginOptions]);\n\n if (!isLoggedIn) {\n return (\n <LoadingOverlay\n data-testid=\"auth-base-loading\"\n isLoading={error == null}\n isLoaded={false}\n errorMessage={getErrorMessage(error)}\n />\n );\n }\n\n // eslint-disable-next-line react/jsx-no-useless-fragment\n return <>{children}</>;\n}\n\nexport default AuthPluginBase;\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAClD,SAASC,cAAc,QAAQ,uBAAuB;AACtD,SAASC,SAAS,QAAQ,4BAA4B;AACtD,OAAOC,GAAG,MAAM,gBAAgB;AAEhC,SAASC,oBAAoB,EAAEC,eAAe,QAAQ,kBAAkB;AAAC,OAClEC,mBAAmB;AAE1B,IAAMC,GAAG,GAAGJ,GAAG,CAACK,MAAM,CAAC,gBAAgB,CAAC;AAexC;AACA;AACA;AACA;AACA,SAASC,cAAc,OAGc;EAAA,IAHb;IACtBC,QAAQ;IACRC;EACmB,CAAC;EACpB,IAAMC,MAAM,GAAGV,SAAS,EAAE;EAC1B,IAAM,CAACW,KAAK,EAAEC,QAAQ,CAAC,GAAGd,QAAQ,EAAW;EAC7C,IAAM,CAACe,UAAU,EAAEC,aAAa,CAAC,GAAGhB,QAAQ,CAAC,KAAK,CAAC;EAEnDD,SAAS,CAAC,MAAM;IACd,IAAIkB,UAAU,GAAG,KAAK;IACtB,SAASC,iBAAiB,GAAG;MAC3B,IAAID,UAAU,EAAE;QACd,MAAM,IAAIb,oBAAoB,CAAC,iBAAiB,CAAC;MACnD;IACF;IAAC,SACce,KAAK;MAAA;IAAA;IAAA;MAAA,2BAApB,aAAuB;QACrB,IAAI;UACF,IAAMC,YAAY,SAAST,eAAe,EAAE;UAC5CO,iBAAiB,EAAE;UAEnBX,GAAG,CAACc,IAAI,CAAC,eAAe,CAAC;UACzB,MAAMT,MAAM,CAACO,KAAK,CAACC,YAAY,CAAC;UAChCF,iBAAiB,EAAE;UAEnBF,aAAa,CAAC,IAAI,CAAC;QACrB,CAAC,CAAC,OAAOM,CAAC,EAAE;UACV,IAAI,CAACL,UAAU,EAAE;YAAA;YACfV,GAAG,CAACM,KAAK,CAAC,kBAAkB,EAAES,CAAC,CAAC;YAChC,IAAMC,OAAO,uBACXlB,eAAe,CAACiB,CAAC,CAAC,+DAAI,sCAAsC;YAC9DR,QAAQ,CAAC,IAAIR,mBAAmB,CAACiB,OAAO,CAAC,CAAC;YAC1CP,aAAa,CAAC,KAAK,CAAC;UACtB;QACF;MACF,CAAC;MAAA;IAAA;IACDG,KAAK,EAAE;IACP,OAAO,MAAM;MACXF,UAAU,GAAG,IAAI;IACnB,CAAC;EACH,CAAC,EAAE,CAACL,MAAM,EAAED,eAAe,CAAC,CAAC;EAE7B,IAAI,CAACI,UAAU,EAAE;IACf,oBACE,
|
|
1
|
+
{"version":3,"file":"AuthPluginBase.js","names":["React","useEffect","useState","LoadingOverlay","useClient","Log","CanceledPromiseError","getErrorMessage","AuthenticationError","log","module","AuthPluginBase","children","getLoginOptions","client","error","setError","isLoggedIn","setIsLoggedIn","isCanceled","verifyNotCanceled","login","loginOptions","info","e","message"],"sources":["../src/AuthPluginBase.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { LoadingOverlay } from '@deephaven/components';\nimport { useClient } from '@deephaven/jsapi-bootstrap';\nimport Log from '@deephaven/log';\nimport type { LoginOptions } from '@deephaven/jsapi-types';\nimport { CanceledPromiseError, getErrorMessage } from '@deephaven/utils';\nimport AuthenticationError from './AuthenticationError';\n\nconst log = Log.module('AuthPluginBase');\n\nexport type AuthPluginBaseProps = {\n /**\n * The children to render after authentication is completed.\n */\n children: React.ReactNode;\n\n /**\n * Retrieve the login options for logging in to the client\n * @returns A promise for the login options\n */\n getLoginOptions: () => LoginOptions | Promise<LoginOptions>;\n};\n\n/**\n * Base AuthPlugin that gets passed a function for retrieving the login options, and then attempting to login with them.\n * @param getLoginOptions Function that returns a promise for the login options\n */\nfunction AuthPluginBase({\n children,\n getLoginOptions,\n}: AuthPluginBaseProps): JSX.Element {\n const client = useClient();\n const [error, setError] = useState<unknown>();\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n\n useEffect(() => {\n let isCanceled = false;\n function verifyNotCanceled() {\n if (isCanceled) {\n throw new CanceledPromiseError('Login canceled.');\n }\n }\n async function login() {\n try {\n const loginOptions = await getLoginOptions();\n verifyNotCanceled();\n\n log.info('Logging in...');\n await client.login(loginOptions);\n verifyNotCanceled();\n\n setIsLoggedIn(true);\n } catch (e) {\n if (!isCanceled) {\n log.error('Unable to login:', e);\n const message =\n getErrorMessage(e) ?? 'Unable to login. Verify credentials.';\n setError(new AuthenticationError(message));\n setIsLoggedIn(false);\n }\n }\n }\n login();\n return () => {\n isCanceled = true;\n };\n }, [client, getLoginOptions]);\n\n if (!isLoggedIn) {\n return (\n <LoadingOverlay\n data-testid=\"auth-base-loading\"\n isLoading={error == null}\n isLoaded={false}\n errorMessage={getErrorMessage(error)}\n />\n );\n }\n\n // eslint-disable-next-line react/jsx-no-useless-fragment\n return <>{children}</>;\n}\n\nexport default AuthPluginBase;\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAClD,SAASC,cAAc,QAAQ,uBAAuB;AACtD,SAASC,SAAS,QAAQ,4BAA4B;AACtD,OAAOC,GAAG,MAAM,gBAAgB;AAEhC,SAASC,oBAAoB,EAAEC,eAAe,QAAQ,kBAAkB;AAAC,OAClEC,mBAAmB;AAAA;AAAA;AAE1B,IAAMC,GAAG,GAAGJ,GAAG,CAACK,MAAM,CAAC,gBAAgB,CAAC;AAexC;AACA;AACA;AACA;AACA,SAASC,cAAc,OAGc;EAAA,IAHb;IACtBC,QAAQ;IACRC;EACmB,CAAC;EACpB,IAAMC,MAAM,GAAGV,SAAS,EAAE;EAC1B,IAAM,CAACW,KAAK,EAAEC,QAAQ,CAAC,GAAGd,QAAQ,EAAW;EAC7C,IAAM,CAACe,UAAU,EAAEC,aAAa,CAAC,GAAGhB,QAAQ,CAAC,KAAK,CAAC;EAEnDD,SAAS,CAAC,MAAM;IACd,IAAIkB,UAAU,GAAG,KAAK;IACtB,SAASC,iBAAiB,GAAG;MAC3B,IAAID,UAAU,EAAE;QACd,MAAM,IAAIb,oBAAoB,CAAC,iBAAiB,CAAC;MACnD;IACF;IAAC,SACce,KAAK;MAAA;IAAA;IAAA;MAAA,2BAApB,aAAuB;QACrB,IAAI;UACF,IAAMC,YAAY,SAAST,eAAe,EAAE;UAC5CO,iBAAiB,EAAE;UAEnBX,GAAG,CAACc,IAAI,CAAC,eAAe,CAAC;UACzB,MAAMT,MAAM,CAACO,KAAK,CAACC,YAAY,CAAC;UAChCF,iBAAiB,EAAE;UAEnBF,aAAa,CAAC,IAAI,CAAC;QACrB,CAAC,CAAC,OAAOM,CAAC,EAAE;UACV,IAAI,CAACL,UAAU,EAAE;YAAA;YACfV,GAAG,CAACM,KAAK,CAAC,kBAAkB,EAAES,CAAC,CAAC;YAChC,IAAMC,OAAO,uBACXlB,eAAe,CAACiB,CAAC,CAAC,+DAAI,sCAAsC;YAC9DR,QAAQ,CAAC,IAAIR,mBAAmB,CAACiB,OAAO,CAAC,CAAC;YAC1CP,aAAa,CAAC,KAAK,CAAC;UACtB;QACF;MACF,CAAC;MAAA;IAAA;IACDG,KAAK,EAAE;IACP,OAAO,MAAM;MACXF,UAAU,GAAG,IAAI;IACnB,CAAC;EACH,CAAC,EAAE,CAACL,MAAM,EAAED,eAAe,CAAC,CAAC;EAE7B,IAAI,CAACI,UAAU,EAAE;IACf,oBACE,KAAC,cAAc;MACb,eAAY,mBAAmB;MAC/B,SAAS,EAAEF,KAAK,IAAI,IAAK;MACzB,QAAQ,EAAE,KAAM;MAChB,YAAY,EAAER,eAAe,CAACQ,KAAK;IAAE,EACrC;EAEN;;EAEA;EACA,oBAAO;IAAA,UAAGH;EAAQ,EAAI;AACxB;AAEA,eAAeD,cAAc"}
|
package/dist/AuthPluginParent.js
CHANGED
|
@@ -5,6 +5,7 @@ import { getWindowParent, LOGIN_OPTIONS_REQUEST, requestParentResponse } from '@
|
|
|
5
5
|
import Log from '@deephaven/log';
|
|
6
6
|
import AuthPluginBase from "./AuthPluginBase.js";
|
|
7
7
|
import { UserPermissionsOverrideContext } from "./UserContexts.js";
|
|
8
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
9
|
var log = Log.module('AuthPluginParent');
|
|
9
10
|
var permissionsOverrides = {
|
|
10
11
|
canLogout: false
|
|
@@ -38,11 +39,13 @@ function Component(_ref) {
|
|
|
38
39
|
var {
|
|
39
40
|
children
|
|
40
41
|
} = _ref;
|
|
41
|
-
return /*#__PURE__*/
|
|
42
|
-
getLoginOptions: getLoginOptions
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
42
|
+
return /*#__PURE__*/_jsx(AuthPluginBase, {
|
|
43
|
+
getLoginOptions: getLoginOptions,
|
|
44
|
+
children: /*#__PURE__*/_jsx(UserPermissionsOverrideContext.Provider, {
|
|
45
|
+
value: permissionsOverrides,
|
|
46
|
+
children: children
|
|
47
|
+
})
|
|
48
|
+
});
|
|
46
49
|
}
|
|
47
50
|
var AuthPluginParent = {
|
|
48
51
|
Component,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthPluginParent.js","names":["React","getWindowParent","LOGIN_OPTIONS_REQUEST","requestParentResponse","Log","AuthPluginBase","UserPermissionsOverrideContext","log","module","permissionsOverrides","canLogout","isLoginOptions","options","type","getLoginOptions","info","response","Error","getWindowAuthProvider","URLSearchParams","window","location","search","get","Component","children","AuthPluginParent","isAvailable"],"sources":["../src/AuthPluginParent.tsx"],"sourcesContent":["import React from 'react';\nimport type { LoginOptions } from '@deephaven/jsapi-types';\nimport {\n getWindowParent,\n LOGIN_OPTIONS_REQUEST,\n requestParentResponse,\n} from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport AuthPluginBase from './AuthPluginBase';\nimport {\n UserPermissionsOverride,\n UserPermissionsOverrideContext,\n} from './UserContexts';\n\nconst log = Log.module('AuthPluginParent');\n\nconst permissionsOverrides: UserPermissionsOverride = { canLogout: false };\n\nfunction isLoginOptions(options: unknown): options is LoginOptions {\n return options != null && typeof (options as LoginOptions).type === 'string';\n}\n\nasync function getLoginOptions(): Promise<LoginOptions> {\n log.info('Logging in by delegating to parent window...');\n const response = await requestParentResponse(LOGIN_OPTIONS_REQUEST);\n if (!isLoginOptions(response)) {\n throw new Error(`Unexpected login options response: ${response}`);\n }\n return response;\n}\n\nfunction getWindowAuthProvider(): string {\n return new URLSearchParams(window.location.search).get('authProvider') ?? '';\n}\n\n/**\n * AuthPlugin that tries to delegate to the parent window for authentication. Fails if there is no parent window.\n */\nfunction Component({ children }: AuthPluginProps): JSX.Element {\n return (\n <AuthPluginBase getLoginOptions={getLoginOptions}>\n <UserPermissionsOverrideContext.Provider value={permissionsOverrides}>\n {children}\n </UserPermissionsOverrideContext.Provider>\n </AuthPluginBase>\n );\n}\n\nconst AuthPluginParent: AuthPlugin = {\n Component,\n isAvailable: () =>\n getWindowParent() != null && getWindowAuthProvider() === 'parent',\n};\n\nexport default AuthPluginParent;\n"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SACEC,eAAe,EACfC,qBAAqB,EACrBC,qBAAqB,QAChB,wBAAwB;AAC/B,OAAOC,GAAG,MAAM,gBAAgB;AAAC,OAE1BC,cAAc;AAAA,SAGnBC,8BAA8B;AAGhC,IAAMC,GAAG,GAAGH,GAAG,CAACI,MAAM,CAAC,kBAAkB,CAAC;AAE1C,IAAMC,oBAA6C,GAAG;EAAEC,SAAS,EAAE;AAAM,CAAC;AAE1E,SAASC,cAAc,CAACC,OAAgB,EAA2B;EACjE,OAAOA,OAAO,IAAI,IAAI,IAAI,OAAQA,OAAO,CAAkBC,IAAI,KAAK,QAAQ;AAC9E;AAAC,SAEcC,eAAe;EAAA;AAAA;AAAA;EAAA,qCAA9B,aAAwD;IACtDP,GAAG,CAACQ,IAAI,CAAC,8CAA8C,CAAC;IACxD,IAAMC,QAAQ,SAASb,qBAAqB,CAACD,qBAAqB,CAAC;IACnE,IAAI,CAACS,cAAc,CAACK,QAAQ,CAAC,EAAE;MAC7B,MAAM,IAAIC,KAAK,8CAAuCD,QAAQ,EAAG;IACnE;IACA,OAAOA,QAAQ;EACjB,CAAC;EAAA;AAAA;AAED,SAASE,qBAAqB,GAAW;EAAA;EACvC,+BAAO,IAAIC,eAAe,CAACC,MAAM,CAACC,QAAQ,CAACC,MAAM,CAAC,CAACC,GAAG,CAAC,cAAc,CAAC,uEAAI,EAAE;AAC9E;;AAEA;AACA;AACA;AACA,SAASC,SAAS,OAA6C;EAAA,IAA5C;IAAEC;EAA0B,CAAC;EAC9C,oBACE,
|
|
1
|
+
{"version":3,"file":"AuthPluginParent.js","names":["React","getWindowParent","LOGIN_OPTIONS_REQUEST","requestParentResponse","Log","AuthPluginBase","UserPermissionsOverrideContext","log","module","permissionsOverrides","canLogout","isLoginOptions","options","type","getLoginOptions","info","response","Error","getWindowAuthProvider","URLSearchParams","window","location","search","get","Component","children","AuthPluginParent","isAvailable"],"sources":["../src/AuthPluginParent.tsx"],"sourcesContent":["import React from 'react';\nimport type { LoginOptions } from '@deephaven/jsapi-types';\nimport {\n getWindowParent,\n LOGIN_OPTIONS_REQUEST,\n requestParentResponse,\n} from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport AuthPluginBase from './AuthPluginBase';\nimport {\n UserPermissionsOverride,\n UserPermissionsOverrideContext,\n} from './UserContexts';\n\nconst log = Log.module('AuthPluginParent');\n\nconst permissionsOverrides: UserPermissionsOverride = { canLogout: false };\n\nfunction isLoginOptions(options: unknown): options is LoginOptions {\n return options != null && typeof (options as LoginOptions).type === 'string';\n}\n\nasync function getLoginOptions(): Promise<LoginOptions> {\n log.info('Logging in by delegating to parent window...');\n const response = await requestParentResponse(LOGIN_OPTIONS_REQUEST);\n if (!isLoginOptions(response)) {\n throw new Error(`Unexpected login options response: ${response}`);\n }\n return response;\n}\n\nfunction getWindowAuthProvider(): string {\n return new URLSearchParams(window.location.search).get('authProvider') ?? '';\n}\n\n/**\n * AuthPlugin that tries to delegate to the parent window for authentication. Fails if there is no parent window.\n */\nfunction Component({ children }: AuthPluginProps): JSX.Element {\n return (\n <AuthPluginBase getLoginOptions={getLoginOptions}>\n <UserPermissionsOverrideContext.Provider value={permissionsOverrides}>\n {children}\n </UserPermissionsOverrideContext.Provider>\n </AuthPluginBase>\n );\n}\n\nconst AuthPluginParent: AuthPlugin = {\n Component,\n isAvailable: () =>\n getWindowParent() != null && getWindowAuthProvider() === 'parent',\n};\n\nexport default AuthPluginParent;\n"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SACEC,eAAe,EACfC,qBAAqB,EACrBC,qBAAqB,QAChB,wBAAwB;AAC/B,OAAOC,GAAG,MAAM,gBAAgB;AAAC,OAE1BC,cAAc;AAAA,SAGnBC,8BAA8B;AAAA;AAGhC,IAAMC,GAAG,GAAGH,GAAG,CAACI,MAAM,CAAC,kBAAkB,CAAC;AAE1C,IAAMC,oBAA6C,GAAG;EAAEC,SAAS,EAAE;AAAM,CAAC;AAE1E,SAASC,cAAc,CAACC,OAAgB,EAA2B;EACjE,OAAOA,OAAO,IAAI,IAAI,IAAI,OAAQA,OAAO,CAAkBC,IAAI,KAAK,QAAQ;AAC9E;AAAC,SAEcC,eAAe;EAAA;AAAA;AAAA;EAAA,qCAA9B,aAAwD;IACtDP,GAAG,CAACQ,IAAI,CAAC,8CAA8C,CAAC;IACxD,IAAMC,QAAQ,SAASb,qBAAqB,CAACD,qBAAqB,CAAC;IACnE,IAAI,CAACS,cAAc,CAACK,QAAQ,CAAC,EAAE;MAC7B,MAAM,IAAIC,KAAK,8CAAuCD,QAAQ,EAAG;IACnE;IACA,OAAOA,QAAQ;EACjB,CAAC;EAAA;AAAA;AAED,SAASE,qBAAqB,GAAW;EAAA;EACvC,+BAAO,IAAIC,eAAe,CAACC,MAAM,CAACC,QAAQ,CAACC,MAAM,CAAC,CAACC,GAAG,CAAC,cAAc,CAAC,uEAAI,EAAE;AAC9E;;AAEA;AACA;AACA;AACA,SAASC,SAAS,OAA6C;EAAA,IAA5C;IAAEC;EAA0B,CAAC;EAC9C,oBACE,KAAC,cAAc;IAAC,eAAe,EAAEX,eAAgB;IAAA,uBAC/C,KAAC,8BAA8B,CAAC,QAAQ;MAAC,KAAK,EAAEL,oBAAqB;MAAA,UAClEgB;IAAQ;EAC+B,EAC3B;AAErB;AAEA,IAAMC,gBAA4B,GAAG;EACnCF,SAAS;EACTG,WAAW,EAAE,MACX1B,eAAe,EAAE,IAAI,IAAI,IAAIiB,qBAAqB,EAAE,KAAK;AAC7D,CAAC;AAED,eAAeQ,gBAAgB"}
|
package/dist/AuthPluginPsk.js
CHANGED
|
@@ -11,6 +11,9 @@ import Cookies from 'js-cookie';
|
|
|
11
11
|
import LoginForm from "./LoginForm.js";
|
|
12
12
|
import Login from "./Login.js";
|
|
13
13
|
import AuthenticationError from "./AuthenticationError.js";
|
|
14
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
15
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
16
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
14
17
|
var AUTH_TYPE = 'io.deephaven.authentication.psk.PskAuthenticationHandler';
|
|
15
18
|
var PSK_QUERY_PARAM_KEY = 'psk';
|
|
16
19
|
var PSK_TOKEN_KEY = 'io.deephaven.web.client.auth.psk.token';
|
|
@@ -164,42 +167,49 @@ function Component(_ref) {
|
|
|
164
167
|
var _inputField$current;
|
|
165
168
|
(_inputField$current = inputField.current) === null || _inputField$current === void 0 ? void 0 : _inputField$current.focus();
|
|
166
169
|
}, [inputField, isInputRequired]);
|
|
167
|
-
return /*#__PURE__*/
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
170
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
171
|
+
children: [isLoggedIn && children, isInputRequired && /*#__PURE__*/_jsx(CSSTransition, {
|
|
172
|
+
in: !isLoggedIn,
|
|
173
|
+
timeout: ThemeExport.transitionMs,
|
|
174
|
+
classNames: "fade",
|
|
175
|
+
mountOnEnter: true,
|
|
176
|
+
unmountOnExit: true,
|
|
177
|
+
children: /*#__PURE__*/_jsx(Login, {
|
|
178
|
+
logoPath: logoPath,
|
|
179
|
+
children: /*#__PURE__*/_jsx(LoginForm, {
|
|
180
|
+
errorMessage: getErrorMessage(error),
|
|
181
|
+
isLoggingIn: isLoggingIn,
|
|
182
|
+
onSubmit: handleSubmit,
|
|
183
|
+
children: /*#__PURE__*/_jsxs("div", {
|
|
184
|
+
className: "form-group",
|
|
185
|
+
children: [/*#__PURE__*/_jsx("label", {
|
|
186
|
+
htmlFor: "auth-psk-token-input",
|
|
187
|
+
children: "Token"
|
|
188
|
+
}), /*#__PURE__*/_jsx("input", {
|
|
189
|
+
id: "auth-psk-token-input",
|
|
190
|
+
name: "token",
|
|
191
|
+
className: "input-token form-control",
|
|
192
|
+
type: "text",
|
|
193
|
+
autoComplete: "username",
|
|
194
|
+
autoCapitalize: "none",
|
|
195
|
+
autoCorrect: "off",
|
|
196
|
+
spellCheck: "false",
|
|
197
|
+
ref: inputField,
|
|
198
|
+
value: token,
|
|
199
|
+
onChange: event => {
|
|
200
|
+
setError(undefined);
|
|
201
|
+
setToken(event.target.value);
|
|
202
|
+
}
|
|
203
|
+
})]
|
|
204
|
+
})
|
|
205
|
+
})
|
|
206
|
+
})
|
|
207
|
+
}), /*#__PURE__*/_jsx(LoadingOverlay, {
|
|
208
|
+
"data-testid": "auth-psk-loading",
|
|
209
|
+
isLoaded: isLoggedIn || isInputRequired,
|
|
210
|
+
isLoading: !isLoggedIn && !isInputRequired
|
|
211
|
+
})]
|
|
212
|
+
});
|
|
203
213
|
}
|
|
204
214
|
var AuthPluginPsk = {
|
|
205
215
|
Component,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthPluginPsk.js","names":["React","useCallback","useEffect","useRef","useState","CSSTransition","LoadingOverlay","ThemeExport","useClient","useBroadcastLoginListener","Log","getErrorMessage","Cookies","LoginForm","Login","AuthenticationError","AUTH_TYPE","PSK_QUERY_PARAM_KEY","PSK_TOKEN_KEY","log","module","getWindowToken","URLSearchParams","window","location","search","get","clearWindowToken","debug2","url","URL","href","searchParams","delete","history","replaceState","readCookieToken","storeCookieToken","token","set","secure","sameSite","remove","Component","children","logoPath","client","inputField","loginPromise","error","setError","isInputRequired","setIsInputRequired","isLoggedIn","setIsLoggedIn","isLoggingIn","setIsLoggingIn","setToken","login","loginToken","showError","info","newLoginPromise","type","current","e","message","cancelLogin","onLogin","debug","newToken","onLogout","isCanceled","initialLogin","initialToken","handleSubmit","autoFocusInput","focus","transitionMs","event","undefined","target","value","AuthPluginPsk","isAvailable","authHandlers","includes"],"sources":["../src/AuthPluginPsk.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { LoadingOverlay, ThemeExport } from '@deephaven/components';\nimport { useClient } from '@deephaven/jsapi-bootstrap';\nimport { useBroadcastLoginListener } from '@deephaven/jsapi-components';\nimport Log from '@deephaven/log';\nimport { getErrorMessage } from '@deephaven/utils';\nimport Cookies from 'js-cookie';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport LoginForm from './LoginForm';\nimport Login from './Login';\nimport AuthenticationError from './AuthenticationError';\n\nconst AUTH_TYPE = 'io.deephaven.authentication.psk.PskAuthenticationHandler';\n\nconst PSK_QUERY_PARAM_KEY = 'psk';\n\nconst PSK_TOKEN_KEY = 'io.deephaven.web.client.auth.psk.token';\n\nconst log = Log.module('AuthPluginPsk');\n\nfunction getWindowToken(): string | null {\n return new URLSearchParams(window.location.search).get(PSK_QUERY_PARAM_KEY);\n}\n\nfunction clearWindowToken() {\n log.debug2('clearWindowToken');\n const url = new URL(window.location.href);\n url.searchParams.delete(PSK_QUERY_PARAM_KEY);\n\n window.history.replaceState(null, '', url.href);\n}\n\nfunction readCookieToken(): string | null {\n return Cookies.get(PSK_TOKEN_KEY) ?? null;\n}\n\nfunction storeCookieToken(token: string | null): void {\n log.debug2('Storing token in cookie', token);\n if (token != null) {\n Cookies.set(PSK_TOKEN_KEY, token, { secure: true, sameSite: 'strict' });\n } else {\n Cookies.remove(PSK_TOKEN_KEY);\n }\n}\n\nexport type AuthPluginPskProps = AuthPluginProps & {\n /** Custom path to a logo to display on the login screen */\n logoPath?: string;\n};\n\n/**\n * AuthPlugin that tries to login using a pre-shared key.\n * Add the `psk=<token>` parameter to your URL string to set the token.\n */\nfunction Component({ children, logoPath }: AuthPluginPskProps): JSX.Element {\n const client = useClient();\n const inputField = useRef<HTMLInputElement>(null);\n const loginPromise = useRef<Promise<void> | null>(null);\n const [error, setError] = useState<unknown>();\n const [isInputRequired, setIsInputRequired] = useState(false);\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n const [isLoggingIn, setIsLoggingIn] = useState(false);\n const [token, setToken] = useState('');\n\n const login = useCallback(\n // eslint-disable-next-line @typescript-eslint/no-inferrable-types\n async (loginToken: string, showError: boolean = true) => {\n log.info('Logging in...');\n setIsLoggingIn(true);\n let newLoginPromise: Promise<void> | null = null;\n try {\n newLoginPromise = client.login({ type: AUTH_TYPE, token: loginToken });\n loginPromise.current = newLoginPromise;\n await newLoginPromise;\n\n log.info('Logged in successfully');\n if (loginPromise.current !== newLoginPromise) {\n return;\n }\n storeCookieToken(loginToken);\n setIsLoggedIn(true);\n } catch (e) {\n if (loginPromise.current !== newLoginPromise) {\n return;\n }\n setIsInputRequired(true);\n if (showError) {\n log.error('Unable to login', e);\n const message =\n getErrorMessage(e) ?? 'Unable to login: Verify credentials.';\n setError(new AuthenticationError(message));\n }\n }\n setIsLoggingIn(false);\n },\n [client]\n );\n\n const cancelLogin = useCallback(() => {\n loginPromise.current = null;\n setIsLoggingIn(false);\n }, []);\n\n const onLogin = useCallback(async () => {\n log.debug('onLogin');\n\n // User logged in successfully in another tab, we should be able to read the token from the cookie and login\n const newToken = readCookieToken();\n if (isLoggedIn || isLoggingIn || newToken == null) {\n return;\n }\n\n login(newToken, false);\n }, [isLoggedIn, isLoggingIn, login]);\n const onLogout = useCallback(() => {\n storeCookieToken(null);\n }, []);\n useBroadcastLoginListener(onLogin, onLogout);\n\n useEffect(() => {\n let isCanceled = false;\n async function initialLogin() {\n const initialToken = getWindowToken() ?? readCookieToken();\n clearWindowToken();\n\n if (initialToken == null) {\n setIsInputRequired(true);\n return;\n }\n\n setIsLoggingIn(true);\n try {\n await client.login({ type: AUTH_TYPE, token: initialToken });\n if (!isCanceled) {\n storeCookieToken(initialToken);\n setIsLoggedIn(true);\n setIsLoggingIn(false);\n }\n } catch (e) {\n if (!isCanceled) {\n setIsInputRequired(true);\n setIsLoggingIn(false);\n }\n }\n }\n initialLogin();\n return () => {\n isCanceled = true;\n };\n }, [client]);\n\n const handleSubmit = useCallback(() => {\n if (!isLoggingIn) {\n login(token);\n } else {\n cancelLogin();\n }\n }, [cancelLogin, isLoggingIn, login, token]);\n\n useEffect(\n function autoFocusInput() {\n inputField.current?.focus();\n },\n [inputField, isInputRequired]\n );\n\n return (\n <>\n {isLoggedIn && children}\n {isInputRequired && (\n <CSSTransition\n in={!isLoggedIn}\n timeout={ThemeExport.transitionMs}\n classNames=\"fade\"\n mountOnEnter\n unmountOnExit\n >\n <Login logoPath={logoPath}>\n <LoginForm\n errorMessage={getErrorMessage(error)}\n isLoggingIn={isLoggingIn}\n onSubmit={handleSubmit}\n >\n <div className=\"form-group\">\n <label htmlFor=\"auth-psk-token-input\">Token</label>\n <input\n id=\"auth-psk-token-input\"\n name=\"token\"\n className=\"input-token form-control\"\n type=\"text\"\n autoComplete=\"username\"\n autoCapitalize=\"none\"\n autoCorrect=\"off\"\n spellCheck=\"false\"\n ref={inputField}\n value={token}\n onChange={event => {\n setError(undefined);\n setToken(event.target.value);\n }}\n />\n </div>\n </LoginForm>\n </Login>\n </CSSTransition>\n )}\n <LoadingOverlay\n data-testid=\"auth-psk-loading\"\n isLoaded={isLoggedIn || isInputRequired}\n isLoading={!isLoggedIn && !isInputRequired}\n />\n </>\n );\n}\n\nconst AuthPluginPsk: AuthPlugin = {\n Component,\n isAvailable: authHandlers => authHandlers.includes(AUTH_TYPE),\n};\n\nexport default AuthPluginPsk;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"AuthPluginPsk.js","names":["React","useCallback","useEffect","useRef","useState","CSSTransition","LoadingOverlay","ThemeExport","useClient","useBroadcastLoginListener","Log","getErrorMessage","Cookies","LoginForm","Login","AuthenticationError","AUTH_TYPE","PSK_QUERY_PARAM_KEY","PSK_TOKEN_KEY","log","module","getWindowToken","URLSearchParams","window","location","search","get","clearWindowToken","debug2","url","URL","href","searchParams","delete","history","replaceState","readCookieToken","storeCookieToken","token","set","secure","sameSite","remove","Component","children","logoPath","client","inputField","loginPromise","error","setError","isInputRequired","setIsInputRequired","isLoggedIn","setIsLoggedIn","isLoggingIn","setIsLoggingIn","setToken","login","loginToken","showError","info","newLoginPromise","type","current","e","message","cancelLogin","onLogin","debug","newToken","onLogout","isCanceled","initialLogin","initialToken","handleSubmit","autoFocusInput","focus","transitionMs","event","undefined","target","value","AuthPluginPsk","isAvailable","authHandlers","includes"],"sources":["../src/AuthPluginPsk.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { LoadingOverlay, ThemeExport } from '@deephaven/components';\nimport { useClient } from '@deephaven/jsapi-bootstrap';\nimport { useBroadcastLoginListener } from '@deephaven/jsapi-components';\nimport Log from '@deephaven/log';\nimport { getErrorMessage } from '@deephaven/utils';\nimport Cookies from 'js-cookie';\nimport { AuthPlugin, AuthPluginProps } from './AuthPlugin';\nimport LoginForm from './LoginForm';\nimport Login from './Login';\nimport AuthenticationError from './AuthenticationError';\n\nconst AUTH_TYPE = 'io.deephaven.authentication.psk.PskAuthenticationHandler';\n\nconst PSK_QUERY_PARAM_KEY = 'psk';\n\nconst PSK_TOKEN_KEY = 'io.deephaven.web.client.auth.psk.token';\n\nconst log = Log.module('AuthPluginPsk');\n\nfunction getWindowToken(): string | null {\n return new URLSearchParams(window.location.search).get(PSK_QUERY_PARAM_KEY);\n}\n\nfunction clearWindowToken() {\n log.debug2('clearWindowToken');\n const url = new URL(window.location.href);\n url.searchParams.delete(PSK_QUERY_PARAM_KEY);\n\n window.history.replaceState(null, '', url.href);\n}\n\nfunction readCookieToken(): string | null {\n return Cookies.get(PSK_TOKEN_KEY) ?? null;\n}\n\nfunction storeCookieToken(token: string | null): void {\n log.debug2('Storing token in cookie', token);\n if (token != null) {\n Cookies.set(PSK_TOKEN_KEY, token, { secure: true, sameSite: 'strict' });\n } else {\n Cookies.remove(PSK_TOKEN_KEY);\n }\n}\n\nexport type AuthPluginPskProps = AuthPluginProps & {\n /** Custom path to a logo to display on the login screen */\n logoPath?: string;\n};\n\n/**\n * AuthPlugin that tries to login using a pre-shared key.\n * Add the `psk=<token>` parameter to your URL string to set the token.\n */\nfunction Component({ children, logoPath }: AuthPluginPskProps): JSX.Element {\n const client = useClient();\n const inputField = useRef<HTMLInputElement>(null);\n const loginPromise = useRef<Promise<void> | null>(null);\n const [error, setError] = useState<unknown>();\n const [isInputRequired, setIsInputRequired] = useState(false);\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n const [isLoggingIn, setIsLoggingIn] = useState(false);\n const [token, setToken] = useState('');\n\n const login = useCallback(\n // eslint-disable-next-line @typescript-eslint/no-inferrable-types\n async (loginToken: string, showError: boolean = true) => {\n log.info('Logging in...');\n setIsLoggingIn(true);\n let newLoginPromise: Promise<void> | null = null;\n try {\n newLoginPromise = client.login({ type: AUTH_TYPE, token: loginToken });\n loginPromise.current = newLoginPromise;\n await newLoginPromise;\n\n log.info('Logged in successfully');\n if (loginPromise.current !== newLoginPromise) {\n return;\n }\n storeCookieToken(loginToken);\n setIsLoggedIn(true);\n } catch (e) {\n if (loginPromise.current !== newLoginPromise) {\n return;\n }\n setIsInputRequired(true);\n if (showError) {\n log.error('Unable to login', e);\n const message =\n getErrorMessage(e) ?? 'Unable to login: Verify credentials.';\n setError(new AuthenticationError(message));\n }\n }\n setIsLoggingIn(false);\n },\n [client]\n );\n\n const cancelLogin = useCallback(() => {\n loginPromise.current = null;\n setIsLoggingIn(false);\n }, []);\n\n const onLogin = useCallback(async () => {\n log.debug('onLogin');\n\n // User logged in successfully in another tab, we should be able to read the token from the cookie and login\n const newToken = readCookieToken();\n if (isLoggedIn || isLoggingIn || newToken == null) {\n return;\n }\n\n login(newToken, false);\n }, [isLoggedIn, isLoggingIn, login]);\n const onLogout = useCallback(() => {\n storeCookieToken(null);\n }, []);\n useBroadcastLoginListener(onLogin, onLogout);\n\n useEffect(() => {\n let isCanceled = false;\n async function initialLogin() {\n const initialToken = getWindowToken() ?? readCookieToken();\n clearWindowToken();\n\n if (initialToken == null) {\n setIsInputRequired(true);\n return;\n }\n\n setIsLoggingIn(true);\n try {\n await client.login({ type: AUTH_TYPE, token: initialToken });\n if (!isCanceled) {\n storeCookieToken(initialToken);\n setIsLoggedIn(true);\n setIsLoggingIn(false);\n }\n } catch (e) {\n if (!isCanceled) {\n setIsInputRequired(true);\n setIsLoggingIn(false);\n }\n }\n }\n initialLogin();\n return () => {\n isCanceled = true;\n };\n }, [client]);\n\n const handleSubmit = useCallback(() => {\n if (!isLoggingIn) {\n login(token);\n } else {\n cancelLogin();\n }\n }, [cancelLogin, isLoggingIn, login, token]);\n\n useEffect(\n function autoFocusInput() {\n inputField.current?.focus();\n },\n [inputField, isInputRequired]\n );\n\n return (\n <>\n {isLoggedIn && children}\n {isInputRequired && (\n <CSSTransition\n in={!isLoggedIn}\n timeout={ThemeExport.transitionMs}\n classNames=\"fade\"\n mountOnEnter\n unmountOnExit\n >\n <Login logoPath={logoPath}>\n <LoginForm\n errorMessage={getErrorMessage(error)}\n isLoggingIn={isLoggingIn}\n onSubmit={handleSubmit}\n >\n <div className=\"form-group\">\n <label htmlFor=\"auth-psk-token-input\">Token</label>\n <input\n id=\"auth-psk-token-input\"\n name=\"token\"\n className=\"input-token form-control\"\n type=\"text\"\n autoComplete=\"username\"\n autoCapitalize=\"none\"\n autoCorrect=\"off\"\n spellCheck=\"false\"\n ref={inputField}\n value={token}\n onChange={event => {\n setError(undefined);\n setToken(event.target.value);\n }}\n />\n </div>\n </LoginForm>\n </Login>\n </CSSTransition>\n )}\n <LoadingOverlay\n data-testid=\"auth-psk-loading\"\n isLoaded={isLoggedIn || isInputRequired}\n isLoading={!isLoggedIn && !isInputRequired}\n />\n </>\n );\n}\n\nconst AuthPluginPsk: AuthPlugin = {\n Component,\n isAvailable: authHandlers => authHandlers.includes(AUTH_TYPE),\n};\n\nexport default AuthPluginPsk;\n"],"mappings":"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"}
|
package/dist/Login.js
CHANGED
|
@@ -1,23 +1,29 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { RandomAreaPlotAnimation } from '@deephaven/components';
|
|
3
3
|
import "./Login.css";
|
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
4
6
|
export function Login(_ref) {
|
|
5
7
|
var {
|
|
6
8
|
children,
|
|
7
9
|
logoPath = './logo.png'
|
|
8
10
|
} = _ref;
|
|
9
|
-
return /*#__PURE__*/
|
|
10
|
-
className: "login-container"
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
11
|
+
return /*#__PURE__*/_jsxs("div", {
|
|
12
|
+
className: "login-container",
|
|
13
|
+
children: [/*#__PURE__*/_jsx(RandomAreaPlotAnimation, {}), /*#__PURE__*/_jsxs("div", {
|
|
14
|
+
className: "login-box",
|
|
15
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
16
|
+
className: "logo",
|
|
17
|
+
children: /*#__PURE__*/_jsx("img", {
|
|
18
|
+
src: logoPath,
|
|
19
|
+
alt: "Deephaven Data Labs"
|
|
20
|
+
})
|
|
21
|
+
}), children, /*#__PURE__*/_jsxs("p", {
|
|
22
|
+
className: "footer",
|
|
23
|
+
children: ["\xA9 2016-", new Date().getFullYear(), " Deephaven Data Labs LLC. Patent Pending."]
|
|
24
|
+
})]
|
|
25
|
+
})]
|
|
26
|
+
});
|
|
21
27
|
}
|
|
22
28
|
export default Login;
|
|
23
29
|
//# sourceMappingURL=Login.js.map
|
package/dist/Login.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Login.js","names":["React","RandomAreaPlotAnimation","Login","children","logoPath","Date","getFullYear"],"sources":["../src/Login.tsx"],"sourcesContent":["import React from 'react';\nimport { RandomAreaPlotAnimation } from '@deephaven/components';\nimport './Login.scss';\n\ninterface LoginProps {\n /** What to show in the login input part of the login form. */\n children: React.ReactNode;\n\n /** Path to the custom logo, relative to document base */\n logoPath?: string;\n}\n\nexport function Login({ children, logoPath = './logo.png' }: LoginProps) {\n return (\n <div className=\"login-container\">\n <RandomAreaPlotAnimation />\n <div className=\"login-box\">\n <div className=\"logo\">\n <img src={logoPath} alt=\"Deephaven Data Labs\" />\n </div>\n {children}\n <p className=\"footer\">\n © 2016-{new Date().getFullYear()} Deephaven Data Labs LLC. Patent\n Pending.\n </p>\n </div>\n </div>\n );\n}\n\nexport default Login;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,uBAAuB,QAAQ,uBAAuB;AAAC;AAWhE,OAAO,SAASC,KAAK,OAAoD;EAAA,IAAnD;IAAEC,QAAQ;IAAEC,QAAQ,GAAG;EAAyB,CAAC;EACrE,oBACE;IAAK,SAAS,EAAC;
|
|
1
|
+
{"version":3,"file":"Login.js","names":["React","RandomAreaPlotAnimation","Login","children","logoPath","Date","getFullYear"],"sources":["../src/Login.tsx"],"sourcesContent":["import React from 'react';\nimport { RandomAreaPlotAnimation } from '@deephaven/components';\nimport './Login.scss';\n\ninterface LoginProps {\n /** What to show in the login input part of the login form. */\n children: React.ReactNode;\n\n /** Path to the custom logo, relative to document base */\n logoPath?: string;\n}\n\nexport function Login({ children, logoPath = './logo.png' }: LoginProps) {\n return (\n <div className=\"login-container\">\n <RandomAreaPlotAnimation />\n <div className=\"login-box\">\n <div className=\"logo\">\n <img src={logoPath} alt=\"Deephaven Data Labs\" />\n </div>\n {children}\n <p className=\"footer\">\n © 2016-{new Date().getFullYear()} Deephaven Data Labs LLC. Patent\n Pending.\n </p>\n </div>\n </div>\n );\n}\n\nexport default Login;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,uBAAuB,QAAQ,uBAAuB;AAAC;AAAA;AAAA;AAWhE,OAAO,SAASC,KAAK,OAAoD;EAAA,IAAnD;IAAEC,QAAQ;IAAEC,QAAQ,GAAG;EAAyB,CAAC;EACrE,oBACE;IAAK,SAAS,EAAC,iBAAiB;IAAA,wBAC9B,KAAC,uBAAuB,KAAG,eAC3B;MAAK,SAAS,EAAC,WAAW;MAAA,wBACxB;QAAK,SAAS,EAAC,MAAM;QAAA,uBACnB;UAAK,GAAG,EAAEA,QAAS;UAAC,GAAG,EAAC;QAAqB;MAAG,EAC5C,EACLD,QAAQ,eACT;QAAG,SAAS,EAAC,QAAQ;QAAA,WAAC,YACb,EAAC,IAAIE,IAAI,EAAE,CAACC,WAAW,EAAE,EAAC,2CAEnC;MAAA,EAAI;IAAA,EACA;EAAA,EACF;AAEV;AAEA,eAAeJ,KAAK"}
|
package/dist/LoginForm.js
CHANGED
|
@@ -2,6 +2,8 @@ import { LoadingSpinner } from '@deephaven/components';
|
|
|
2
2
|
import classNames from 'classnames';
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import "./LoginForm.css";
|
|
5
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
5
7
|
export function LoginForm(_ref) {
|
|
6
8
|
var {
|
|
7
9
|
children,
|
|
@@ -9,40 +11,51 @@ export function LoginForm(_ref) {
|
|
|
9
11
|
isLoggingIn = false,
|
|
10
12
|
onSubmit: _onSubmit
|
|
11
13
|
} = _ref;
|
|
12
|
-
return /*#__PURE__*/
|
|
14
|
+
return /*#__PURE__*/_jsxs("form", {
|
|
13
15
|
className: "login-form",
|
|
14
16
|
onSubmit: event => {
|
|
15
17
|
event.preventDefault();
|
|
16
18
|
event.stopPropagation();
|
|
17
19
|
_onSubmit === null || _onSubmit === void 0 ? void 0 : _onSubmit(event);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
20
|
+
},
|
|
21
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
22
|
+
className: "flex-spacer"
|
|
23
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
24
|
+
className: "flex-wrapper",
|
|
25
|
+
children: [/*#__PURE__*/_jsx("fieldset", {
|
|
26
|
+
disabled: isLoggingIn,
|
|
27
|
+
className: "container-fluid",
|
|
28
|
+
children: children
|
|
29
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
30
|
+
className: "form-group d-flex justify-content-end align-items-center mb-0",
|
|
31
|
+
children: /*#__PURE__*/_jsxs("button", {
|
|
32
|
+
type: "submit",
|
|
33
|
+
className: classNames('btn btn-primary', {
|
|
34
|
+
'btn-spinner': isLoggingIn
|
|
35
|
+
}, {
|
|
36
|
+
'btn-cancelable': isLoggingIn
|
|
37
|
+
}),
|
|
38
|
+
"data-testid": "btn-login",
|
|
39
|
+
children: [isLoggingIn && /*#__PURE__*/_jsxs("span", {
|
|
40
|
+
children: [/*#__PURE__*/_jsx(LoadingSpinner, {}), /*#__PURE__*/_jsx("span", {
|
|
41
|
+
className: "btn-normal-content",
|
|
42
|
+
children: "Logging in"
|
|
43
|
+
}), /*#__PURE__*/_jsx("span", {
|
|
44
|
+
className: "btn-hover-content",
|
|
45
|
+
children: "Cancel"
|
|
46
|
+
})]
|
|
47
|
+
}), !isLoggingIn && 'Login']
|
|
48
|
+
})
|
|
49
|
+
})]
|
|
50
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
51
|
+
className: "flex-spacer",
|
|
52
|
+
children: errorMessage != null && /*#__PURE__*/_jsx("p", {
|
|
53
|
+
className: "error-message mb-0",
|
|
54
|
+
role: "alert",
|
|
55
|
+
children: "".concat(errorMessage)
|
|
56
|
+
})
|
|
57
|
+
})]
|
|
58
|
+
});
|
|
46
59
|
}
|
|
47
60
|
export default LoginForm;
|
|
48
61
|
//# sourceMappingURL=LoginForm.js.map
|
package/dist/LoginForm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LoginForm.js","names":["LoadingSpinner","classNames","React","LoginForm","children","errorMessage","isLoggingIn","onSubmit","event","preventDefault","stopPropagation"],"sources":["../src/LoginForm.tsx"],"sourcesContent":["import { LoadingSpinner } from '@deephaven/components';\nimport classNames from 'classnames';\nimport React, { FormEventHandler } from 'react';\nimport './LoginForm.scss';\n\nexport interface LoginFormProps {\n /** What to display inside the form */\n children: React.ReactNode;\n\n /** Error message to display */\n errorMessage?: string;\n\n /** Whether currently logging in */\n isLoggingIn?: boolean;\n\n /** Triggered when the form is submitting */\n onSubmit?: FormEventHandler;\n}\n\nexport function LoginForm({\n children,\n errorMessage,\n isLoggingIn = false,\n onSubmit,\n}: LoginFormProps) {\n return (\n <form\n className=\"login-form\"\n onSubmit={event => {\n event.preventDefault();\n event.stopPropagation();\n onSubmit?.(event);\n }}\n >\n <div className=\"flex-spacer\" />\n <div className=\"flex-wrapper\">\n <fieldset disabled={isLoggingIn} className=\"container-fluid\">\n {children}\n </fieldset>\n <div className=\"form-group d-flex justify-content-end align-items-center mb-0\">\n <button\n type=\"submit\"\n className={classNames(\n 'btn btn-primary',\n { 'btn-spinner': isLoggingIn },\n { 'btn-cancelable': isLoggingIn }\n )}\n data-testid=\"btn-login\"\n >\n {isLoggingIn && (\n <span>\n <LoadingSpinner />\n <span className=\"btn-normal-content\">Logging in</span>\n <span className=\"btn-hover-content\">Cancel</span>\n </span>\n )}\n {!isLoggingIn && 'Login'}\n </button>\n </div>\n </div>\n <div className=\"flex-spacer\">\n {errorMessage != null && (\n <p className=\"error-message mb-0\" role=\"alert\">{`${errorMessage}`}</p>\n )}\n </div>\n </form>\n );\n}\n\nexport default LoginForm;\n"],"mappings":"AAAA,SAASA,cAAc,QAAQ,uBAAuB;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,MAA4B,OAAO;AAAC;AAiBhD,OAAO,SAASC,SAAS,OAKN;EAAA,IALO;IACxBC,QAAQ;IACRC,YAAY;IACZC,WAAW,GAAG,KAAK;IACnBC,QAAQ,EAARA;EACc,CAAC;EACf,oBACE;IACE,SAAS,EAAC,YAAY;IACtB,QAAQ,EAAEC,KAAK,IAAI;MACjBA,KAAK,CAACC,cAAc,EAAE;MACtBD,KAAK,CAACE,eAAe,EAAE;MACvBH,SAAQ,aAARA,SAAQ,uBAARA,SAAQ,CAAGC,KAAK,CAAC;IACnB;
|
|
1
|
+
{"version":3,"file":"LoginForm.js","names":["LoadingSpinner","classNames","React","LoginForm","children","errorMessage","isLoggingIn","onSubmit","event","preventDefault","stopPropagation"],"sources":["../src/LoginForm.tsx"],"sourcesContent":["import { LoadingSpinner } from '@deephaven/components';\nimport classNames from 'classnames';\nimport React, { FormEventHandler } from 'react';\nimport './LoginForm.scss';\n\nexport interface LoginFormProps {\n /** What to display inside the form */\n children: React.ReactNode;\n\n /** Error message to display */\n errorMessage?: string;\n\n /** Whether currently logging in */\n isLoggingIn?: boolean;\n\n /** Triggered when the form is submitting */\n onSubmit?: FormEventHandler;\n}\n\nexport function LoginForm({\n children,\n errorMessage,\n isLoggingIn = false,\n onSubmit,\n}: LoginFormProps) {\n return (\n <form\n className=\"login-form\"\n onSubmit={event => {\n event.preventDefault();\n event.stopPropagation();\n onSubmit?.(event);\n }}\n >\n <div className=\"flex-spacer\" />\n <div className=\"flex-wrapper\">\n <fieldset disabled={isLoggingIn} className=\"container-fluid\">\n {children}\n </fieldset>\n <div className=\"form-group d-flex justify-content-end align-items-center mb-0\">\n <button\n type=\"submit\"\n className={classNames(\n 'btn btn-primary',\n { 'btn-spinner': isLoggingIn },\n { 'btn-cancelable': isLoggingIn }\n )}\n data-testid=\"btn-login\"\n >\n {isLoggingIn && (\n <span>\n <LoadingSpinner />\n <span className=\"btn-normal-content\">Logging in</span>\n <span className=\"btn-hover-content\">Cancel</span>\n </span>\n )}\n {!isLoggingIn && 'Login'}\n </button>\n </div>\n </div>\n <div className=\"flex-spacer\">\n {errorMessage != null && (\n <p className=\"error-message mb-0\" role=\"alert\">{`${errorMessage}`}</p>\n )}\n </div>\n </form>\n );\n}\n\nexport default LoginForm;\n"],"mappings":"AAAA,SAASA,cAAc,QAAQ,uBAAuB;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,MAA4B,OAAO;AAAC;AAAA;AAAA;AAiBhD,OAAO,SAASC,SAAS,OAKN;EAAA,IALO;IACxBC,QAAQ;IACRC,YAAY;IACZC,WAAW,GAAG,KAAK;IACnBC,QAAQ,EAARA;EACc,CAAC;EACf,oBACE;IACE,SAAS,EAAC,YAAY;IACtB,QAAQ,EAAEC,KAAK,IAAI;MACjBA,KAAK,CAACC,cAAc,EAAE;MACtBD,KAAK,CAACE,eAAe,EAAE;MACvBH,SAAQ,aAARA,SAAQ,uBAARA,SAAQ,CAAGC,KAAK,CAAC;IACnB,CAAE;IAAA,wBAEF;MAAK,SAAS,EAAC;IAAa,EAAG,eAC/B;MAAK,SAAS,EAAC,cAAc;MAAA,wBAC3B;QAAU,QAAQ,EAAEF,WAAY;QAAC,SAAS,EAAC,iBAAiB;QAAA,UACzDF;MAAQ,EACA,eACX;QAAK,SAAS,EAAC,+DAA+D;QAAA,uBAC5E;UACE,IAAI,EAAC,QAAQ;UACb,SAAS,EAAEH,UAAU,CACnB,iBAAiB,EACjB;YAAE,aAAa,EAAEK;UAAY,CAAC,EAC9B;YAAE,gBAAgB,EAAEA;UAAY,CAAC,CACjC;UACF,eAAY,WAAW;UAAA,WAEtBA,WAAW,iBACV;YAAA,wBACE,KAAC,cAAc,KAAG,eAClB;cAAM,SAAS,EAAC,oBAAoB;cAAA,UAAC;YAAU,EAAO,eACtD;cAAM,SAAS,EAAC,mBAAmB;cAAA,UAAC;YAAM,EAAO;UAAA,EAEpD,EACA,CAACA,WAAW,IAAI,OAAO;QAAA;MACjB,EACL;IAAA,EACF,eACN;MAAK,SAAS,EAAC,aAAa;MAAA,UACzBD,YAAY,IAAI,IAAI,iBACnB;QAAG,SAAS,EAAC,oBAAoB;QAAC,IAAI,EAAC,OAAO;QAAA,oBAAKA,YAAY;MAAA;IAChE,EACG;EAAA,EACD;AAEX;AAEA,eAAeF,SAAS"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@deephaven/auth-plugins",
|
|
3
|
-
"version": "0.46.1-beta.
|
|
3
|
+
"version": "0.46.1-beta.4+6ff27a67",
|
|
4
4
|
"description": "Deephaven Auth Plugins",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"Deephaven",
|
|
@@ -33,14 +33,14 @@
|
|
|
33
33
|
"build:sass": "sass --embed-sources --load-path=../../node_modules ./src:./dist"
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
|
-
"@deephaven/components": "^0.46.1-beta.
|
|
37
|
-
"@deephaven/jsapi-bootstrap": "^0.46.1-beta.
|
|
38
|
-
"@deephaven/jsapi-components": "^0.46.1-beta.
|
|
39
|
-
"@deephaven/jsapi-types": "^0.46.1-beta.
|
|
40
|
-
"@deephaven/jsapi-utils": "^0.46.1-beta.
|
|
41
|
-
"@deephaven/log": "^0.46.1-beta.
|
|
42
|
-
"@deephaven/redux": "^0.46.1-beta.
|
|
43
|
-
"@deephaven/utils": "^0.46.1-beta.
|
|
36
|
+
"@deephaven/components": "^0.46.1-beta.4+6ff27a67",
|
|
37
|
+
"@deephaven/jsapi-bootstrap": "^0.46.1-beta.4+6ff27a67",
|
|
38
|
+
"@deephaven/jsapi-components": "^0.46.1-beta.4+6ff27a67",
|
|
39
|
+
"@deephaven/jsapi-types": "^0.46.1-beta.4+6ff27a67",
|
|
40
|
+
"@deephaven/jsapi-utils": "^0.46.1-beta.4+6ff27a67",
|
|
41
|
+
"@deephaven/log": "^0.46.1-beta.4+6ff27a67",
|
|
42
|
+
"@deephaven/redux": "^0.46.1-beta.4+6ff27a67",
|
|
43
|
+
"@deephaven/utils": "^0.46.1-beta.4+6ff27a67",
|
|
44
44
|
"classnames": "^2.3.1",
|
|
45
45
|
"js-cookie": "^3.0.5",
|
|
46
46
|
"react-transition-group": "^4.4.2"
|
|
@@ -59,5 +59,5 @@
|
|
|
59
59
|
"publishConfig": {
|
|
60
60
|
"access": "public"
|
|
61
61
|
},
|
|
62
|
-
"gitHead": "
|
|
62
|
+
"gitHead": "6ff27a67fded2d6a7affe5ec8480faf01ff1af00"
|
|
63
63
|
}
|