@looker/run-it 0.9.21 → 0.9.25

Sign up to get free protection for your applications and to get access to all the features.
Files changed (81) hide show
  1. package/CHANGELOG.md +74 -1
  2. package/lib/RunIt.d.ts +2 -0
  3. package/lib/RunIt.js +20 -27
  4. package/lib/RunIt.js.map +1 -1
  5. package/lib/RunItProvider.d.ts +0 -4
  6. package/lib/RunItProvider.js +2 -7
  7. package/lib/RunItProvider.js.map +1 -1
  8. package/lib/components/ConfigForm/ConfigForm.d.ts +0 -4
  9. package/lib/components/ConfigForm/ConfigForm.js +12 -11
  10. package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
  11. package/lib/components/ConfigForm/configUtils.js +6 -4
  12. package/lib/components/ConfigForm/configUtils.js.map +1 -1
  13. package/lib/components/DocSdkCalls/DocMultiCall.d.ts +5 -2
  14. package/lib/components/DocSdkCalls/DocMultiCall.js +7 -19
  15. package/lib/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  16. package/lib/components/DocSdkCalls/DocSdkCalls.js +26 -9
  17. package/lib/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  18. package/lib/components/LoginForm/LoginForm.d.ts +2 -8
  19. package/lib/components/LoginForm/LoginForm.js +5 -6
  20. package/lib/components/LoginForm/LoginForm.js.map +1 -1
  21. package/lib/components/PerfTracker/PerfTracker.d.ts +0 -2
  22. package/lib/components/PerfTracker/PerfTracker.js +7 -8
  23. package/lib/components/PerfTracker/PerfTracker.js.map +1 -1
  24. package/lib/components/RequestForm/RequestForm.d.ts +0 -4
  25. package/lib/components/RequestForm/RequestForm.js +0 -7
  26. package/lib/components/RequestForm/RequestForm.js.map +1 -1
  27. package/lib/components/RequestForm/formUtils.d.ts +1 -1
  28. package/lib/components/RequestForm/formUtils.js +25 -10
  29. package/lib/components/RequestForm/formUtils.js.map +1 -1
  30. package/lib/components/common/index.d.ts +0 -1
  31. package/lib/components/common/index.js +0 -18
  32. package/lib/components/common/index.js.map +1 -1
  33. package/lib/esm/RunIt.js +20 -28
  34. package/lib/esm/RunIt.js.map +1 -1
  35. package/lib/esm/RunItProvider.js +2 -7
  36. package/lib/esm/RunItProvider.js.map +1 -1
  37. package/lib/esm/components/ConfigForm/ConfigForm.js +12 -12
  38. package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
  39. package/lib/esm/components/ConfigForm/configUtils.js +6 -4
  40. package/lib/esm/components/ConfigForm/configUtils.js.map +1 -1
  41. package/lib/esm/components/DocSdkCalls/DocMultiCall.js +8 -19
  42. package/lib/esm/components/DocSdkCalls/DocMultiCall.js.map +1 -1
  43. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js +25 -10
  44. package/lib/esm/components/DocSdkCalls/DocSdkCalls.js.map +1 -1
  45. package/lib/esm/components/LoginForm/LoginForm.js +5 -6
  46. package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
  47. package/lib/esm/components/PerfTracker/PerfTracker.js +7 -8
  48. package/lib/esm/components/PerfTracker/PerfTracker.js.map +1 -1
  49. package/lib/esm/components/RequestForm/RequestForm.js +0 -7
  50. package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
  51. package/lib/esm/components/RequestForm/formUtils.js +25 -10
  52. package/lib/esm/components/RequestForm/formUtils.js.map +1 -1
  53. package/lib/esm/components/common/index.js +0 -1
  54. package/lib/esm/components/common/index.js.map +1 -1
  55. package/lib/esm/scenes/OAuthScene/OAuthScene.js +3 -6
  56. package/lib/esm/scenes/OAuthScene/OAuthScene.js.map +1 -1
  57. package/lib/esm/utils/RunItSDK.js +12 -77
  58. package/lib/esm/utils/RunItSDK.js.map +1 -1
  59. package/lib/esm/utils/requestUtils.js +21 -14
  60. package/lib/esm/utils/requestUtils.js.map +1 -1
  61. package/lib/scenes/OAuthScene/OAuthScene.js +2 -5
  62. package/lib/scenes/OAuthScene/OAuthScene.js.map +1 -1
  63. package/lib/test-data/responses.js +9 -0
  64. package/lib/test-data/responses.js.map +1 -1
  65. package/lib/utils/RunItSDK.d.ts +3 -16
  66. package/lib/utils/RunItSDK.js +15 -87
  67. package/lib/utils/RunItSDK.js.map +1 -1
  68. package/lib/utils/requestUtils.d.ts +2 -3
  69. package/lib/utils/requestUtils.js +22 -15
  70. package/lib/utils/requestUtils.js.map +1 -1
  71. package/package.json +9 -8
  72. package/lib/components/DocSdkCalls/DocSingleCall.d.ts +0 -3
  73. package/lib/components/DocSdkCalls/DocSingleCall.js +0 -32
  74. package/lib/components/DocSdkCalls/DocSingleCall.js.map +0 -1
  75. package/lib/components/common/StandaloneConfigurator.d.ts +0 -7
  76. package/lib/components/common/StandaloneConfigurator.js +0 -61
  77. package/lib/components/common/StandaloneConfigurator.js.map +0 -1
  78. package/lib/esm/components/DocSdkCalls/DocSingleCall.js +0 -18
  79. package/lib/esm/components/DocSdkCalls/DocSingleCall.js.map +0 -1
  80. package/lib/esm/components/common/StandaloneConfigurator.js +0 -51
  81. package/lib/esm/components/common/StandaloneConfigurator.js.map +0 -1
@@ -2,9 +2,9 @@ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try
2
2
 
3
3
  function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
4
4
 
5
- import React, { useContext, useEffect, useState } from 'react';
5
+ import React, { useEffect, useState } from 'react';
6
6
  import { useHistory } from 'react-router-dom';
7
- import { RunItContext } from '../..';
7
+ import { getEnvAdaptor } from '@looker/extension-utils';
8
8
  import { Loading } from '../../components';
9
9
  export var OAuthScene = () => {
10
10
  var origin = window.location.origin;
@@ -12,9 +12,7 @@ export var OAuthScene = () => {
12
12
  var [auth, setAuth] = useState();
13
13
  var [oldUrl, setOldUrl] = useState();
14
14
  var history = useHistory();
15
- var {
16
- sdk
17
- } = useContext(RunItContext);
15
+ var sdk = getEnvAdaptor().sdk;
18
16
  useEffect(() => {
19
17
  if (sdk) {
20
18
  var authSession = sdk.authSession;
@@ -55,7 +53,6 @@ export var OAuthScene = () => {
55
53
 
56
54
  maybeLogin();
57
55
  }, [auth, history]);
58
- if (!sdk) return React.createElement(React.Fragment, null);
59
56
  return React.createElement(Loading, {
60
57
  loading: loading,
61
58
  message: "Returning to ".concat(oldUrl || origin, " after OAuth login ...")
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/scenes/OAuthScene/OAuthScene.tsx"],"names":["React","useContext","useEffect","useState","useHistory","RunItContext","Loading","OAuthScene","origin","window","location","loading","setLoading","auth","setAuth","oldUrl","setOldUrl","history","sdk","authSession","old","returnUrl","undefined","maybeLogin","res","login","isAuthenticated","console","error","push"],"mappings":";;;;AA2BA,OAAOA,KAAP,IAAgBC,UAAhB,EAA4BC,SAA5B,EAAuCC,QAAvC,QAAuD,OAAvD;AACA,SAASC,UAAT,QAA2B,kBAA3B;AAEA,SAASC,YAAT,QAA6B,OAA7B;AACA,SAASC,OAAT,QAAwB,kBAAxB;AAEA,OAAO,IAAMC,UAAc,GAAG,MAAM;AAClC,MAAMC,MAAM,GAAIC,MAAD,CAAgBC,QAAhB,CAAyBF,MAAxC;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwBT,QAAQ,CAAC,IAAD,CAAtC;AACA,MAAM,CAACU,IAAD,EAAOC,OAAP,IAAkBX,QAAQ,EAAhC;AACA,MAAM,CAACY,MAAD,EAASC,SAAT,IAAsBb,QAAQ,EAApC;AACA,MAAMc,OAAO,GAAGb,UAAU,EAA1B;AACA,MAAM;AAAEc,IAAAA;AAAF,MAAUjB,UAAU,CAACI,YAAD,CAA1B;AAEAH,EAAAA,SAAS,CAAC,MAAM;AACd,QAAIgB,GAAJ,EAAS;AACP,UAAMC,WAAW,GAAGD,GAAG,CAACC,WAAxB;AACAL,MAAAA,OAAO,CAACK,WAAD,CAAP;AAEA,UAAMC,GAAG,GAAGD,WAAW,CAACE,SAAZ,OAAZ;AACAL,MAAAA,SAAS,CAACI,GAAD,CAAT;AACD,KAND,MAMO;AACLN,MAAAA,OAAO,CAACQ,SAAD,CAAP;AACAN,MAAAA,SAAS,CAACM,SAAD,CAAT;AACD;AACF,GAXQ,EAWN,CAACJ,GAAD,CAXM,CAAT;AAaAhB,EAAAA,SAAS,CAAC,MAAM;AACd,QAAMqB,UAAU;AAAA,mCAAG,aAAY;AAC7B,YAAIV,IAAJ,EAAU;AACR,cAAI;AACF,gBAAMW,GAAG,SAASX,IAAI,CAACY,KAAL,EAAlB;;AACA,gBAAI,CAACZ,IAAI,CAACa,eAAL,EAAL,EAA6B;AAC3BC,cAAAA,OAAO,CAACC,KAAR,iCAAuCJ,GAAvC;AACD;AACF,WALD,CAKE,OAAOI,KAAP,EAAc;AACdD,YAAAA,OAAO,CAACC,KAAR,CAAcA,KAAd;AACD;;AACDhB,UAAAA,UAAU,CAAC,KAAD,CAAV;;AACA,cAAIG,MAAJ,EAAY;AACVE,YAAAA,OAAO,CAACY,IAAR,CAAad,MAAb;AACD;AACF;AACF,OAfe;;AAAA,sBAAVQ,UAAU;AAAA;AAAA;AAAA,OAAhB;;AAgBAA,IAAAA,UAAU;AACX,GAlBQ,EAkBN,CAACV,IAAD,EAAOI,OAAP,CAlBM,CAAT;AAqBA,MAAI,CAACC,GAAL,EAAU,OAAO,yCAAP;AAEV,SACE,oBAAC,OAAD;AACE,IAAA,OAAO,EAAEP,OADX;AAEE,IAAA,OAAO,yBAAkBI,MAAM,IAAIP,MAA5B;AAFT,IADF;AAMD,CAlDM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { FC } from 'react'\nimport React, { useContext, useEffect, useState } from 'react'\nimport { useHistory } from 'react-router-dom'\nimport type { BrowserSession } from '@looker/sdk-rtl'\nimport { RunItContext } from '../..'\nimport { Loading } from '../../components'\n\nexport const OAuthScene: FC = () => {\n const origin = (window as any).location.origin\n const [loading, setLoading] = useState(true)\n const [auth, setAuth] = useState<BrowserSession>()\n const [oldUrl, setOldUrl] = useState<string>()\n const history = useHistory()\n const { sdk } = useContext(RunItContext)\n\n useEffect(() => {\n if (sdk) {\n const authSession = sdk.authSession as BrowserSession\n setAuth(authSession)\n /** capture the stored return URL before `OAuthSession.login()` clears it */\n const old = authSession.returnUrl || `/`\n setOldUrl(old)\n } else {\n setAuth(undefined)\n setOldUrl(undefined)\n }\n }, [sdk])\n\n useEffect(() => {\n const maybeLogin = async () => {\n if (auth) {\n try {\n const res = await auth.login()\n if (!auth.isAuthenticated()) {\n console.error(`Authentication failed ${res}`)\n }\n } catch (error) {\n console.error(error)\n }\n setLoading(false)\n if (oldUrl) {\n history.push(oldUrl)\n }\n }\n }\n maybeLogin()\n }, [auth, history])\n\n // No sdk no OAuth for you\n if (!sdk) return <></>\n\n return (\n <Loading\n loading={loading}\n message={`Returning to ${oldUrl || origin} after OAuth login ...`}\n />\n )\n}\n"],"file":"OAuthScene.js"}
1
+ {"version":3,"sources":["../../../../src/scenes/OAuthScene/OAuthScene.tsx"],"names":["React","useEffect","useState","useHistory","getEnvAdaptor","Loading","OAuthScene","origin","window","location","loading","setLoading","auth","setAuth","oldUrl","setOldUrl","history","sdk","authSession","old","returnUrl","undefined","maybeLogin","res","login","isAuthenticated","console","error","push"],"mappings":";;;;AA2BA,OAAOA,KAAP,IAAgBC,SAAhB,EAA2BC,QAA3B,QAA2C,OAA3C;AACA,SAASC,UAAT,QAA2B,kBAA3B;AAEA,SAASC,aAAT,QAA8B,yBAA9B;AAEA,SAASC,OAAT,QAAwB,kBAAxB;AAEA,OAAO,IAAMC,UAAc,GAAG,MAAM;AAClC,MAAMC,MAAM,GAAIC,MAAD,CAAgBC,QAAhB,CAAyBF,MAAxC;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwBT,QAAQ,CAAC,IAAD,CAAtC;AACA,MAAM,CAACU,IAAD,EAAOC,OAAP,IAAkBX,QAAQ,EAAhC;AACA,MAAM,CAACY,MAAD,EAASC,SAAT,IAAsBb,QAAQ,EAApC;AACA,MAAMc,OAAO,GAAGb,UAAU,EAA1B;AACA,MAAMc,GAAG,GAAGb,aAAa,GAAGa,GAA5B;AAEAhB,EAAAA,SAAS,CAAC,MAAM;AACd,QAAIgB,GAAJ,EAAS;AACP,UAAMC,WAAW,GAAGD,GAAG,CAACC,WAAxB;AACAL,MAAAA,OAAO,CAACK,WAAD,CAAP;AAEA,UAAMC,GAAG,GAAGD,WAAW,CAACE,SAAZ,OAAZ;AACAL,MAAAA,SAAS,CAACI,GAAD,CAAT;AACD,KAND,MAMO;AACLN,MAAAA,OAAO,CAACQ,SAAD,CAAP;AACAN,MAAAA,SAAS,CAACM,SAAD,CAAT;AACD;AACF,GAXQ,EAWN,CAACJ,GAAD,CAXM,CAAT;AAaAhB,EAAAA,SAAS,CAAC,MAAM;AACd,QAAMqB,UAAU;AAAA,mCAAG,aAAY;AAC7B,YAAIV,IAAJ,EAAU;AACR,cAAI;AACF,gBAAMW,GAAG,SAASX,IAAI,CAACY,KAAL,EAAlB;;AACA,gBAAI,CAACZ,IAAI,CAACa,eAAL,EAAL,EAA6B;AAC3BC,cAAAA,OAAO,CAACC,KAAR,iCAAuCJ,GAAvC;AACD;AACF,WALD,CAKE,OAAOI,KAAP,EAAc;AACdD,YAAAA,OAAO,CAACC,KAAR,CAAcA,KAAd;AACD;;AACDhB,UAAAA,UAAU,CAAC,KAAD,CAAV;;AACA,cAAIG,MAAJ,EAAY;AACVE,YAAAA,OAAO,CAACY,IAAR,CAAad,MAAb;AACD;AACF;AACF,OAfe;;AAAA,sBAAVQ,UAAU;AAAA;AAAA;AAAA,OAAhB;;AAgBAA,IAAAA,UAAU;AACX,GAlBQ,EAkBN,CAACV,IAAD,EAAOI,OAAP,CAlBM,CAAT;AAoBA,SACE,oBAAC,OAAD;AACE,IAAA,OAAO,EAAEN,OADX;AAEE,IAAA,OAAO,yBAAkBI,MAAM,IAAIP,MAA5B;AAFT,IADF;AAMD,CA/CM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { FC } from 'react'\nimport React, { useEffect, useState } from 'react'\nimport { useHistory } from 'react-router-dom'\nimport type { BrowserSession } from '@looker/sdk-rtl'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { Loading } from '../../components'\n\nexport const OAuthScene: FC = () => {\n const origin = (window as any).location.origin\n const [loading, setLoading] = useState(true)\n const [auth, setAuth] = useState<BrowserSession>()\n const [oldUrl, setOldUrl] = useState<string>()\n const history = useHistory()\n const sdk = getEnvAdaptor().sdk\n\n useEffect(() => {\n if (sdk) {\n const authSession = sdk.authSession as BrowserSession\n setAuth(authSession)\n /** capture the stored return URL before `OAuthSession.login()` clears it */\n const old = authSession.returnUrl || `/`\n setOldUrl(old)\n } else {\n setAuth(undefined)\n setOldUrl(undefined)\n }\n }, [sdk])\n\n useEffect(() => {\n const maybeLogin = async () => {\n if (auth) {\n try {\n const res = await auth.login()\n if (!auth.isAuthenticated()) {\n console.error(`Authentication failed ${res}`)\n }\n } catch (error) {\n console.error(error)\n }\n setLoading(false)\n if (oldUrl) {\n history.push(oldUrl)\n }\n }\n }\n maybeLogin()\n }, [auth, history])\n\n return (\n <Loading\n loading={loading}\n message={`Returning to ${oldUrl || origin} after OAuth login ...`}\n />\n )\n}\n"],"file":"OAuthScene.js"}
@@ -4,91 +4,26 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
4
4
 
5
5
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
6
 
7
+ import { BrowserSession, BrowserTransport, DefaultSettings } from '@looker/sdk-rtl';
7
8
  import { functionalSdk40 } from '@looker/sdk';
8
- import { ApiSettings, BrowserSession, BrowserTransport, DefaultSettings } from '@looker/sdk-rtl';
9
+ import { OAuthConfigProvider } from '@looker/extension-utils';
9
10
  import { RunItConfigKey } from '../components';
11
+ export var initRunItSdk = () => {
12
+ var settings = _objectSpread(_objectSpread({}, DefaultSettings()), {}, {
13
+ base_url: 'https://self-signed.looker.com:19999',
14
+ agentTag: 'RunIt 0.8'
15
+ });
10
16
 
11
- var settings = _objectSpread(_objectSpread({}, DefaultSettings()), {}, {
12
- base_url: 'https://self-signed.looker.com:19999',
13
- agentTag: 'RunIt 0.8'
14
- });
15
-
16
- export class RunItSettings extends ApiSettings {
17
- constructor(settings, configurator) {
18
- super(settings);
19
-
20
- _defineProperty(this, "configurator", void 0);
21
-
22
- this.configurator = configurator;
23
- }
24
-
25
- getStoredConfig() {
26
- var storage = this.configurator.getStorage(RunItConfigKey);
27
- var config = {
28
- base_url: '',
29
- looker_url: ''
30
- };
31
-
32
- if (storage.value) {
33
- config = JSON.parse(storage.value);
34
- }
35
-
36
- return config;
37
- }
38
-
39
- authIsConfigured() {
40
- var config = this.getStoredConfig();
41
- return config.base_url !== '' && config.looker_url !== '';
42
- }
43
-
44
- readConfig(_section) {
45
- var config = this.getStoredConfig();
46
-
47
- if (!this.authIsConfigured()) {
48
- var url = new URL(this.base_url);
49
- var authServer = "".concat(url.protocol, "//").concat(url.hostname);
50
- config = {
51
- base_url: this.base_url,
52
- looker_url: "".concat(authServer, ":9999")
53
- };
54
- }
55
-
56
- var {
57
- base_url,
58
- looker_url
59
- } = config;
60
- this.base_url = base_url;
61
- return _objectSpread(_objectSpread({}, super.readConfig(_section)), {
62
- base_url,
63
- looker_url,
64
- client_id: 'looker.api-explorer',
65
- redirect_uri: "".concat(window.location.origin, "/oauth")
66
- });
67
- }
68
-
69
- }
70
-
71
- var perfSDK = (settings, configurator) => {
72
- var options = new RunItSettings(settings, configurator);
17
+ var options = new OAuthConfigProvider(settings, RunItConfigKey);
73
18
  var transport = new BrowserTransport(options);
74
19
  var session = new BrowserSession(options, transport);
75
20
  var sdk = functionalSdk40(session);
76
21
  BrowserTransport.trackPerformance = true;
77
22
  return sdk;
78
23
  };
24
+ export var StoreConstants;
79
25
 
80
- export var runItSDK;
81
- export var initRunItSdk = configurator => {
82
- if (!runItSDK) {
83
- runItSDK = perfSDK(settings, configurator);
84
- }
85
-
86
- return runItSDK;
87
- };
88
- export var sdkNeedsConfig = sdk => (sdk === null || sdk === void 0 ? void 0 : sdk.authSession.settings) instanceof RunItSettings;
89
- export var sdkNeedsAuth = sdk => {
90
- if (!sdk) return false;
91
- var configIsNeeded = sdkNeedsConfig(sdk);
92
- return configIsNeeded && !sdk.authSession.isAuthenticated();
93
- };
26
+ (function (StoreConstants) {
27
+ StoreConstants["LOCALSTORAGE_SETTINGS_KEY"] = "settings";
28
+ })(StoreConstants || (StoreConstants = {}));
94
29
  //# sourceMappingURL=RunItSDK.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/utils/RunItSDK.ts"],"names":["functionalSdk40","ApiSettings","BrowserSession","BrowserTransport","DefaultSettings","RunItConfigKey","settings","base_url","agentTag","RunItSettings","constructor","configurator","getStoredConfig","storage","getStorage","config","looker_url","value","JSON","parse","authIsConfigured","readConfig","_section","url","URL","authServer","protocol","hostname","client_id","redirect_uri","window","location","origin","perfSDK","options","transport","session","sdk","trackPerformance","runItSDK","initRunItSdk","sdkNeedsConfig","authSession","sdkNeedsAuth","configIsNeeded","isAuthenticated"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport { functionalSdk40 } from '@looker/sdk'\nimport type { IAPIMethods, IApiSection, IApiSettings } from '@looker/sdk-rtl'\nimport {\n ApiSettings,\n BrowserSession,\n BrowserTransport,\n DefaultSettings,\n} from '@looker/sdk-rtl'\nimport type { RunItConfigurator } from '../components'\nimport { RunItConfigKey } from '../components'\n\n// https://docs.looker.com/reference/api-and-integration/api-cors\nconst settings = {\n ...DefaultSettings(),\n base_url: 'https://self-signed.looker.com:19999',\n agentTag: 'RunIt 0.8',\n} as IApiSettings\n\n/**\n * An OAuth Session configuration provider\n *\n * @class RunItSettings\n */\nexport class RunItSettings extends ApiSettings {\n configurator: RunItConfigurator\n constructor(\n settings: Partial<IApiSettings>,\n configurator: RunItConfigurator\n ) {\n super(settings)\n this.configurator = configurator\n }\n\n getStoredConfig() {\n const storage = this.configurator.getStorage(RunItConfigKey)\n let config = { base_url: '', looker_url: '' }\n if (storage.value) {\n config = JSON.parse(storage.value)\n }\n return config\n }\n\n authIsConfigured(): boolean {\n const config = this.getStoredConfig()\n return config.base_url !== '' && config.looker_url !== ''\n }\n\n readConfig(_section?: string): IApiSection {\n // Read server url values from storage\n let config = this.getStoredConfig()\n if (!this.authIsConfigured()) {\n // derive Looker server URL from base_url\n const url = new URL(this.base_url)\n const authServer = `${url.protocol}//${url.hostname}`\n config = {\n base_url: this.base_url,\n looker_url: `${authServer}:9999`,\n }\n }\n\n const { base_url, looker_url } = config\n /* update base_url to the dynamically determined value for standard transport requests */\n this.base_url = base_url\n return {\n ...super.readConfig(_section),\n ...{\n base_url,\n looker_url,\n client_id: 'looker.api-explorer',\n redirect_uri: `${window.location.origin}/oauth`,\n },\n }\n }\n}\n\nconst perfSDK = (\n settings: Partial<IApiSettings>,\n configurator: RunItConfigurator\n): IAPIMethods => {\n const options = new RunItSettings(settings, configurator)\n const transport = new BrowserTransport(options)\n const session = new BrowserSession(options, transport)\n const sdk = functionalSdk40(session)\n BrowserTransport.trackPerformance = true\n return sdk\n}\n\n/** stand-alone API test runner */\nexport let runItSDK: IAPIMethods\n// And this which sucks\nexport const initRunItSdk = (configurator: RunItConfigurator) => {\n if (!runItSDK) {\n runItSDK = perfSDK(settings, configurator)\n }\n return runItSDK\n}\n\n/**\n * Is this a stand-alone version of Run-It that needs server and auth configuration?\n * @param sdk to check\n */\nexport const sdkNeedsConfig = (sdk: IAPIMethods | undefined) =>\n sdk?.authSession.settings instanceof RunItSettings\n\n/**\n * Determines if authentication is required\n * @param sdk to check\n */\nexport const sdkNeedsAuth = (sdk: IAPIMethods | undefined) => {\n if (!sdk) return false\n const configIsNeeded = sdkNeedsConfig(sdk)\n return configIsNeeded && !sdk.authSession.isAuthenticated()\n}\n"],"file":"RunItSDK.js"}
1
+ {"version":3,"sources":["../../../src/utils/RunItSDK.ts"],"names":["BrowserSession","BrowserTransport","DefaultSettings","functionalSdk40","OAuthConfigProvider","RunItConfigKey","initRunItSdk","settings","base_url","agentTag","options","transport","session","sdk","trackPerformance","StoreConstants"],"mappings":";;;;;;AA2BA,SACEA,cADF,EAEEC,gBAFF,EAGEC,eAHF,QAIO,iBAJP;AAKA,SAASC,eAAT,QAAgC,aAAhC;AACA,SAASC,mBAAT,QAAoC,yBAApC;AAEA,SAASC,cAAT,QAA+B,eAA/B;AAEA,OAAO,IAAMC,YAAY,GAAG,MAAM;AAChC,MAAMC,QAAQ,mCACTL,eAAe,EADN;AAEZM,IAAAA,QAAQ,EAAE,sCAFE;AAGZC,IAAAA,QAAQ,EAAE;AAHE,IAAd;;AAMA,MAAMC,OAAO,GAAG,IAAIN,mBAAJ,CAAwBG,QAAxB,EAAkCF,cAAlC,CAAhB;AACA,MAAMM,SAAS,GAAG,IAAIV,gBAAJ,CAAqBS,OAArB,CAAlB;AACA,MAAME,OAAO,GAAG,IAAIZ,cAAJ,CAAmBU,OAAnB,EAA4BC,SAA5B,CAAhB;AACA,MAAME,GAAG,GAAGV,eAAe,CAACS,OAAD,CAA3B;AACAX,EAAAA,gBAAgB,CAACa,gBAAjB,GAAoC,IAApC;AACA,SAAOD,GAAP;AACD,CAbM;AAeP,WAAYE,cAAZ;;WAAYA,c;AAAAA,EAAAA,c;GAAAA,c,KAAAA,c","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { IApiSettings } from '@looker/sdk-rtl'\nimport {\n BrowserSession,\n BrowserTransport,\n DefaultSettings,\n} from '@looker/sdk-rtl'\nimport { functionalSdk40 } from '@looker/sdk'\nimport { OAuthConfigProvider } from '@looker/extension-utils'\n\nimport { RunItConfigKey } from '../components'\n\nexport const initRunItSdk = () => {\n const settings = {\n ...DefaultSettings(),\n base_url: 'https://self-signed.looker.com:19999',\n agentTag: 'RunIt 0.8',\n } as IApiSettings\n\n const options = new OAuthConfigProvider(settings, RunItConfigKey)\n const transport = new BrowserTransport(options)\n const session = new BrowserSession(options, transport)\n const sdk = functionalSdk40(session)\n BrowserTransport.trackPerformance = true\n return sdk\n}\n\nexport enum StoreConstants {\n LOCALSTORAGE_SETTINGS_KEY = 'settings',\n}\n"],"file":"RunItSDK.js"}
@@ -5,8 +5,8 @@ function _asyncToGenerator(fn) { return function () { var self = this, args = ar
5
5
  import cloneDeep from 'lodash/cloneDeep';
6
6
  import { isEmpty } from 'lodash';
7
7
  import { ArrayType, DelimArrayType, EnumType, HashType, IntrinsicType, trimInputs } from '@looker/sdk-codegen';
8
+ import { getEnvAdaptor } from '@looker/extension-utils';
8
9
  import { RunItFormKey } from '../components';
9
- import { runItSDK } from './RunItSDK';
10
10
  export var runItNoSet = value => value;
11
11
 
12
12
  var macro = (path, vars) => path.replace(/{(\w+)}/g, (_, b) => vars[b]);
@@ -46,15 +46,22 @@ export var prepareInputs = (inputs, requestContent) => {
46
46
 
47
47
  return result;
48
48
  };
49
- export var formValues = configurator => {
50
- var storage = configurator.getStorage(RunItFormKey);
51
- var result = storage.value ? JSON.parse(storage.value) : {};
52
- configurator.removeStorage(RunItFormKey);
53
- return result;
54
- };
55
- export var initRequestContent = function initRequestContent(configurator, inputs) {
56
- var requestContent = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
57
- var content = formValues(configurator);
49
+ export var formValues = function () {
50
+ var _ref = _asyncToGenerator(function* () {
51
+ var adaptor = getEnvAdaptor();
52
+ var formValue = yield adaptor.localStorageGetItem(RunItFormKey);
53
+ var result = formValue ? JSON.parse(formValue) : {};
54
+ adaptor.localStorageRemoveItem(RunItFormKey);
55
+ return result;
56
+ });
57
+
58
+ return function formValues() {
59
+ return _ref.apply(this, arguments);
60
+ };
61
+ }();
62
+ export var initRequestContent = function initRequestContent(inputs) {
63
+ var requestContent = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
64
+ var content = {};
58
65
 
59
66
  if (isEmpty(content)) {
60
67
  content = prepareInputs(inputs, requestContent);
@@ -93,18 +100,18 @@ export var createRequestParams = (inputs, requestContent) => {
93
100
  return [pathParams, queryParams, body];
94
101
  };
95
102
  export var runRequest = function () {
96
- var _ref = _asyncToGenerator(function* (sdk, basePath, httpMethod, endpoint, pathParams, queryParams, body) {
103
+ var _ref2 = _asyncToGenerator(function* (sdk, basePath, httpMethod, endpoint, pathParams, queryParams, body) {
97
104
  if (!sdk.authSession.isAuthenticated()) {
98
- yield sdk.ok(runItSDK.authSession.login());
105
+ yield sdk.ok(sdk.authSession.login());
99
106
  }
100
107
 
101
108
  var url = "".concat(basePath).concat(pathify(endpoint, pathParams));
102
- var raw = yield sdk.authSession.transport.rawRequest(httpMethod, url, queryParams, body, props => runItSDK.authSession.authenticate(props));
109
+ var raw = yield sdk.authSession.transport.rawRequest(httpMethod, url, queryParams, body, props => sdk.authSession.authenticate(props));
103
110
  return raw;
104
111
  });
105
112
 
106
113
  return function runRequest(_x, _x2, _x3, _x4, _x5, _x6, _x7) {
107
- return _ref.apply(this, arguments);
114
+ return _ref2.apply(this, arguments);
108
115
  };
109
116
  }();
110
117
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/utils/requestUtils.ts"],"names":["cloneDeep","isEmpty","ArrayType","DelimArrayType","EnumType","HashType","IntrinsicType","trimInputs","RunItFormKey","runItSDK","runItNoSet","value","macro","path","vars","replace","_","b","pathify","pathParams","result","includes","prepareInputs","inputs","requestContent","input","name","location","parsed","JSON","parse","type","e","formValues","configurator","storage","getStorage","removeStorage","initRequestContent","content","createRequestParams","queryParams","prepped","trimmed","body","Error","runRequest","sdk","basePath","httpMethod","endpoint","authSession","isAuthenticated","ok","login","url","raw","transport","rawRequest","props","authenticate","getTypeDefault","createSampleBody","spec","getSampleValue","elementType","customType","recurse","types","sampleBody","prop","writeable","sampleValue","undefined","editType","createInputs","method","allParams","map","param","required","description"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { IAPIMethods, IRawResponse } from '@looker/sdk-rtl'\nimport cloneDeep from 'lodash/cloneDeep'\nimport { isEmpty } from 'lodash'\nimport type { IApiModel, IMethod, IType } from '@looker/sdk-codegen'\nimport {\n ArrayType,\n DelimArrayType,\n EnumType,\n HashType,\n IntrinsicType,\n trimInputs,\n} from '@looker/sdk-codegen'\n\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../RunIt'\nimport type { RunItConfigurator } from '../components'\nimport { RunItFormKey } from '../components'\nimport { runItSDK } from './RunItSDK'\n\n/** Hook to set a URL somewhere else in APIX */\nexport type RunItSetter = (value: any) => any\n\n/**\n * A \"no-op\" function\n * @param value passed through\n */\nexport const runItNoSet: RunItSetter = (value: any) => value\n\n/**\n * Replaces {foo} with vars[foo] in provided path\n * @param path with templatized param names\n * @param vars Collection of path params\n * @returns Path with param names replaced with values\n */\nconst macro = (path: string, vars: RunItValues) =>\n path.replace(/{(\\w+)}/g, (_, b) => vars[b])\n\n/**\n * Construct a full request path including path params\n * @param path A request path with path params in curly braces e.g. /queries/{query_id}/run/{result_format}\n * @param pathParams Collection of path params\n * @returns a full request path\n */\nexport const pathify = (path: string, pathParams?: RunItValues): string => {\n let result = path\n if (pathParams && path.includes('{')) {\n result = macro(path, pathParams)\n }\n return result\n}\n\n/**\n * Prepares the inputs for use with the SDK and other RunIt components\n * @param inputs An array describing RunIt form inputs\n * @param requestContent Current request parameters\n */\nexport const prepareInputs = (\n inputs: RunItInput[],\n requestContent: RunItValues\n) => {\n const result = cloneDeep(requestContent)\n for (const input of inputs) {\n const name = input.name\n if (input.location === 'body') {\n try {\n let parsed\n if (name in requestContent) {\n const value = requestContent[name]\n /** The value is not a string when the user has not interacted with this param and prepareInputs has been\n * called (e.g. if user navigates to the Code tab).\n */\n parsed = typeof value === 'string' ? JSON.parse(value) : value\n } else {\n /** This scenario occurs when RunIt is about to be mounted for a new method */\n parsed = input.type\n }\n result[name] = parsed\n } catch (e) {\n /** Treat as x-www-form-urlencoded */\n result[name] = requestContent[name]\n }\n }\n }\n return result\n}\n\n/**\n * Load and clear any saved form values from the session\n * @param configurator storage service\n */\nexport const formValues = (configurator: RunItConfigurator) => {\n const storage = configurator.getStorage(RunItFormKey)\n const result = storage.value ? JSON.parse(storage.value) : {}\n configurator.removeStorage(RunItFormKey)\n return result\n}\n\n/**\n * Initializes the request content object from local storage or input definitions, in that order\n * @param configurator storage service\n * @param inputs\n * @param requestContent the current request content\n */\nexport const initRequestContent = (\n configurator: RunItConfigurator,\n inputs: RunItInput[],\n requestContent = {}\n) => {\n let content = formValues(configurator)\n if (isEmpty(content)) {\n content = prepareInputs(inputs, requestContent)\n }\n return content\n}\n\n/**\n * Takes all form input values and categorizes them based on their request location\n * @param inputs RunIt form inputs\n * @param requestContent Form input values\n * @returns path, query and body param objects\n */\nexport const createRequestParams = (\n inputs: RunItInput[],\n requestContent: RunItValues\n) => {\n const pathParams = {}\n const queryParams = {}\n const prepped = prepareInputs(inputs, requestContent)\n const trimmed = trimInputs(prepped)\n let body\n for (const input of inputs) {\n const name = input.name\n switch (input.location) {\n case 'path':\n pathParams[name] = trimmed[name]\n break\n case 'query':\n queryParams[name] = trimmed[name]\n break\n case 'body':\n body = trimmed[name]\n break\n default:\n throw new Error(`Invalid input location: '${input.location}'`)\n }\n }\n return [pathParams, queryParams, body]\n}\n\n/**\n * Makes an http request using the SDK browser transport rawRequest method\n * @param sdk functional SDK that supports rawRequest via its transport\n * @param basePath base path for the URL. For standalone this includes the specKey. Empty for extension.\n * @param httpMethod Request operation\n * @param endpoint Request path with path params in curly braces e.g. /queries/{query_id}/run/{result_format}\n * @param pathParams Collection of path params\n * @param queryParams Collection of query params\n * @param body Collection of body params\n */\nexport const runRequest = async (\n sdk: IAPIMethods,\n basePath: string,\n httpMethod: RunItHttpMethod,\n endpoint: string,\n pathParams: RunItValues,\n queryParams: RunItValues,\n body: any\n): Promise<IRawResponse> => {\n if (!sdk.authSession.isAuthenticated()) {\n await sdk.ok(runItSDK.authSession.login())\n }\n const url = `${basePath}${pathify(endpoint, pathParams)}`\n const raw = await sdk.authSession.transport.rawRequest(\n httpMethod,\n url,\n queryParams,\n body,\n (props) => runItSDK.authSession.authenticate(props)\n )\n return raw\n}\n\n/**\n * Return a default value for a given type name\n * @param type A type name\n */\nconst getTypeDefault = (type: string) => {\n // TODO: use potential equivalent from sdk-codegen, confirm formats\n switch (type) {\n case 'boolean':\n return false\n case 'int64':\n case 'integer':\n return 0\n case 'float':\n case 'double':\n return 0.0\n case 'hostname':\n case 'ipv4':\n case 'ipv6':\n case 'uuid':\n case 'uri':\n case 'string':\n case 'email':\n return ''\n case 'string[]':\n return []\n case 'object':\n return {}\n case 'datetime':\n return ''\n default:\n return ''\n }\n}\n\n/**\n * Given a type object reduce it to its writeable intrinsic and/or custom type properties and their default values\n * @param spec Api spec\n * @param type A type object\n */\nconst createSampleBody = (spec: IApiModel, type: IType) => {\n /* eslint-disable @typescript-eslint/no-use-before-define */\n const getSampleValue = (type: IType) => {\n if (type instanceof IntrinsicType) return getTypeDefault(type.name)\n if (type instanceof DelimArrayType)\n return getTypeDefault(type.elementType.name)\n if (type instanceof EnumType) return ''\n if (type instanceof ArrayType)\n return type.customType\n ? [recurse(spec.types[type.customType])]\n : getTypeDefault(type.name)\n if (type instanceof HashType)\n return type.customType ? recurse(spec.types[type.customType]) : {}\n\n return recurse(type)\n }\n /* eslint-enable @typescript-eslint/no-use-before-define */\n\n const recurse = (type: IType) => {\n const sampleBody: RunItValues = {}\n for (const prop of type.writeable) {\n const sampleValue = getSampleValue(prop.type)\n if (sampleValue !== undefined) {\n sampleBody[prop.name] = sampleValue\n }\n }\n return sampleBody\n }\n return recurse(type)\n}\n\n/**\n * Convert model type to an editable type\n * @param spec API model for building input editor\n * @param type to convert\n */\nconst editType = (spec: IApiModel, type: IType) => {\n if (type instanceof IntrinsicType) return type.name\n // TODO create a DelimArray editing component as part of the complex type editor\n if (type instanceof DelimArrayType) return 'string'\n return createSampleBody(spec, type)\n}\n\n/**\n * Given an SDK method create and return an array of inputs for the run-it form\n * @param spec Api spec\n * @param method A method object\n */\nexport const createInputs = (spec: IApiModel, method: IMethod): RunItInput[] =>\n method.allParams.map((param) => ({\n name: param.name,\n location: param.location,\n type: editType(spec, param.type),\n required: param.required,\n description: param.description,\n }))\n"],"file":"requestUtils.js"}
1
+ {"version":3,"sources":["../../../src/utils/requestUtils.ts"],"names":["cloneDeep","isEmpty","ArrayType","DelimArrayType","EnumType","HashType","IntrinsicType","trimInputs","getEnvAdaptor","RunItFormKey","runItNoSet","value","macro","path","vars","replace","_","b","pathify","pathParams","result","includes","prepareInputs","inputs","requestContent","input","name","location","parsed","JSON","parse","type","e","formValues","adaptor","formValue","localStorageGetItem","localStorageRemoveItem","initRequestContent","content","createRequestParams","queryParams","prepped","trimmed","body","Error","runRequest","sdk","basePath","httpMethod","endpoint","authSession","isAuthenticated","ok","login","url","raw","transport","rawRequest","props","authenticate","getTypeDefault","createSampleBody","spec","getSampleValue","elementType","customType","recurse","types","sampleBody","prop","writeable","sampleValue","undefined","editType","createInputs","method","allParams","map","param","required","description"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { IAPIMethods, IRawResponse } from '@looker/sdk-rtl'\nimport cloneDeep from 'lodash/cloneDeep'\nimport { isEmpty } from 'lodash'\nimport type { IApiModel, IMethod, IType } from '@looker/sdk-codegen'\nimport {\n ArrayType,\n DelimArrayType,\n EnumType,\n HashType,\n IntrinsicType,\n trimInputs,\n} from '@looker/sdk-codegen'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../RunIt'\nimport { RunItFormKey } from '../components'\n\n/** Hook to set a URL somewhere else in APIX */\nexport type RunItSetter = (value: any) => any\n\n/**\n * A \"no-op\" function\n * @param value passed through\n */\nexport const runItNoSet: RunItSetter = (value: any) => value\n\n/**\n * Replaces {foo} with vars[foo] in provided path\n * @param path with templatized param names\n * @param vars Collection of path params\n * @returns Path with param names replaced with values\n */\nconst macro = (path: string, vars: RunItValues) =>\n path.replace(/{(\\w+)}/g, (_, b) => vars[b])\n\n/**\n * Construct a full request path including path params\n * @param path A request path with path params in curly braces e.g. /queries/{query_id}/run/{result_format}\n * @param pathParams Collection of path params\n * @returns a full request path\n */\nexport const pathify = (path: string, pathParams?: RunItValues): string => {\n let result = path\n if (pathParams && path.includes('{')) {\n result = macro(path, pathParams)\n }\n return result\n}\n\n/**\n * Prepares the inputs for use with the SDK and other RunIt components\n * @param inputs An array describing RunIt form inputs\n * @param requestContent Current request parameters\n */\nexport const prepareInputs = (\n inputs: RunItInput[],\n requestContent: RunItValues\n) => {\n const result = cloneDeep(requestContent)\n for (const input of inputs) {\n const name = input.name\n if (input.location === 'body') {\n try {\n let parsed\n if (name in requestContent) {\n const value = requestContent[name]\n /** The value is not a string when the user has not interacted with this param and prepareInputs has been\n * called (e.g. if user navigates to the Code tab).\n */\n parsed = typeof value === 'string' ? JSON.parse(value) : value\n } else {\n /** This scenario occurs when RunIt is about to be mounted for a new method */\n parsed = input.type\n }\n result[name] = parsed\n } catch (e) {\n /** Treat as x-www-form-urlencoded */\n result[name] = requestContent[name]\n }\n }\n }\n return result\n}\n\n/**\n * Load and clear any saved form values from the session\n * @param configurator storage service\n */\nexport const formValues = async () => {\n const adaptor = getEnvAdaptor()\n const formValue = await adaptor.localStorageGetItem(RunItFormKey)\n const result = formValue ? JSON.parse(formValue) : {}\n adaptor.localStorageRemoveItem(RunItFormKey)\n return result\n}\n\n/**\n * Initializes the request content object from local storage or input definitions, in that order\n * @param configurator storage service\n * @param inputs\n * @param requestContent the current request content\n */\nexport const initRequestContent = (\n inputs: RunItInput[],\n requestContent = {}\n) => {\n // TODO: Temporarily disabling request form state persistence until RunIt is using redux\n // let content = await formValues()\n let content = {}\n if (isEmpty(content)) {\n content = prepareInputs(inputs, requestContent)\n }\n return content\n}\n\n/**\n * Takes all form input values and categorizes them based on their request location\n * @param inputs RunIt form inputs\n * @param requestContent Form input values\n * @returns path, query and body param objects\n */\nexport const createRequestParams = (\n inputs: RunItInput[],\n requestContent: RunItValues\n) => {\n const pathParams = {}\n const queryParams = {}\n const prepped = prepareInputs(inputs, requestContent)\n const trimmed = trimInputs(prepped)\n let body\n for (const input of inputs) {\n const name = input.name\n switch (input.location) {\n case 'path':\n pathParams[name] = trimmed[name]\n break\n case 'query':\n queryParams[name] = trimmed[name]\n break\n case 'body':\n body = trimmed[name]\n break\n default:\n throw new Error(`Invalid input location: '${input.location}'`)\n }\n }\n return [pathParams, queryParams, body]\n}\n\n/**\n * Makes an http request using the SDK browser transport rawRequest method\n * @param sdk functional SDK that supports rawRequest via its transport\n * @param basePath base path for the URL. For standalone this includes the specKey. Empty for extension.\n * @param httpMethod Request operation\n * @param endpoint Request path with path params in curly braces e.g. /queries/{query_id}/run/{result_format}\n * @param pathParams Collection of path params\n * @param queryParams Collection of query params\n * @param body Collection of body params\n */\nexport const runRequest = async (\n sdk: IAPIMethods,\n basePath: string,\n httpMethod: RunItHttpMethod,\n endpoint: string,\n pathParams: RunItValues,\n queryParams: RunItValues,\n body: any\n): Promise<IRawResponse> => {\n if (!sdk.authSession.isAuthenticated()) {\n await sdk.ok(sdk.authSession.login())\n }\n const url = `${basePath}${pathify(endpoint, pathParams)}`\n const raw = await sdk.authSession.transport.rawRequest(\n httpMethod,\n url,\n queryParams,\n body,\n (props) => sdk.authSession.authenticate(props)\n )\n return raw\n}\n\n/**\n * Return a default value for a given type name\n * @param type A type name\n */\nconst getTypeDefault = (type: string) => {\n // TODO: use potential equivalent from sdk-codegen, confirm formats\n switch (type) {\n case 'boolean':\n return false\n case 'int64':\n case 'integer':\n return 0\n case 'float':\n case 'double':\n return 0.0\n case 'hostname':\n case 'ipv4':\n case 'ipv6':\n case 'uuid':\n case 'uri':\n case 'string':\n case 'email':\n return ''\n case 'string[]':\n return []\n case 'object':\n return {}\n case 'datetime':\n return ''\n default:\n return ''\n }\n}\n\n/**\n * Given a type object reduce it to its writeable intrinsic and/or custom type properties and their default values\n * @param spec Api spec\n * @param type A type object\n */\nconst createSampleBody = (spec: IApiModel, type: IType) => {\n /* eslint-disable @typescript-eslint/no-use-before-define */\n const getSampleValue = (type: IType) => {\n if (type instanceof IntrinsicType) return getTypeDefault(type.name)\n if (type instanceof DelimArrayType)\n return getTypeDefault(type.elementType.name)\n if (type instanceof EnumType) return ''\n if (type instanceof ArrayType)\n return type.customType\n ? [recurse(spec.types[type.customType])]\n : getTypeDefault(type.name)\n if (type instanceof HashType)\n return type.customType ? recurse(spec.types[type.customType]) : {}\n\n return recurse(type)\n }\n /* eslint-enable @typescript-eslint/no-use-before-define */\n\n const recurse = (type: IType) => {\n const sampleBody: RunItValues = {}\n for (const prop of type.writeable) {\n const sampleValue = getSampleValue(prop.type)\n if (sampleValue !== undefined) {\n sampleBody[prop.name] = sampleValue\n }\n }\n return sampleBody\n }\n return recurse(type)\n}\n\n/**\n * Convert model type to an editable type\n * @param spec API model for building input editor\n * @param type to convert\n */\nconst editType = (spec: IApiModel, type: IType) => {\n if (type instanceof IntrinsicType) return type.name\n // TODO create a DelimArray editing component as part of the complex type editor\n if (type instanceof DelimArrayType) return 'string'\n return createSampleBody(spec, type)\n}\n\n/**\n * Given an SDK method create and return an array of inputs for the run-it form\n * @param spec Api spec\n * @param method A method object\n */\nexport const createInputs = (spec: IApiModel, method: IMethod): RunItInput[] =>\n method.allParams.map((param) => ({\n name: param.name,\n location: param.location,\n type: editType(spec, param.type),\n required: param.required,\n description: param.description,\n }))\n"],"file":"requestUtils.js"}
@@ -9,7 +9,7 @@ var _react = _interopRequireWildcard(require("react"));
9
9
 
10
10
  var _reactRouterDom = require("react-router-dom");
11
11
 
12
- var _ = require("../..");
12
+ var _extensionUtils = require("@looker/extension-utils");
13
13
 
14
14
  var _components = require("../../components");
15
15
 
@@ -27,9 +27,7 @@ var OAuthScene = () => {
27
27
  var [auth, setAuth] = (0, _react.useState)();
28
28
  var [oldUrl, setOldUrl] = (0, _react.useState)();
29
29
  var history = (0, _reactRouterDom.useHistory)();
30
- var {
31
- sdk
32
- } = (0, _react.useContext)(_.RunItContext);
30
+ var sdk = (0, _extensionUtils.getEnvAdaptor)().sdk;
33
31
  (0, _react.useEffect)(() => {
34
32
  if (sdk) {
35
33
  var authSession = sdk.authSession;
@@ -70,7 +68,6 @@ var OAuthScene = () => {
70
68
 
71
69
  maybeLogin();
72
70
  }, [auth, history]);
73
- if (!sdk) return _react.default.createElement(_react.default.Fragment, null);
74
71
  return _react.default.createElement(_components.Loading, {
75
72
  loading: loading,
76
73
  message: "Returning to ".concat(oldUrl || origin, " after OAuth login ...")
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/scenes/OAuthScene/OAuthScene.tsx"],"names":["OAuthScene","origin","window","location","loading","setLoading","auth","setAuth","oldUrl","setOldUrl","history","sdk","RunItContext","authSession","old","returnUrl","undefined","maybeLogin","res","login","isAuthenticated","console","error","push"],"mappings":";;;;;;;AA2BA;;AACA;;AAEA;;AACA;;;;;;;;;;AAEO,IAAMA,UAAc,GAAG,MAAM;AAClC,MAAMC,MAAM,GAAIC,MAAD,CAAgBC,QAAhB,CAAyBF,MAAxC;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwB,qBAAS,IAAT,CAA9B;AACA,MAAM,CAACC,IAAD,EAAOC,OAAP,IAAkB,sBAAxB;AACA,MAAM,CAACC,MAAD,EAASC,SAAT,IAAsB,sBAA5B;AACA,MAAMC,OAAO,GAAG,iCAAhB;AACA,MAAM;AAAEC,IAAAA;AAAF,MAAU,uBAAWC,cAAX,CAAhB;AAEA,wBAAU,MAAM;AACd,QAAID,GAAJ,EAAS;AACP,UAAME,WAAW,GAAGF,GAAG,CAACE,WAAxB;AACAN,MAAAA,OAAO,CAACM,WAAD,CAAP;AAEA,UAAMC,GAAG,GAAGD,WAAW,CAACE,SAAZ,OAAZ;AACAN,MAAAA,SAAS,CAACK,GAAD,CAAT;AACD,KAND,MAMO;AACLP,MAAAA,OAAO,CAACS,SAAD,CAAP;AACAP,MAAAA,SAAS,CAACO,SAAD,CAAT;AACD;AACF,GAXD,EAWG,CAACL,GAAD,CAXH;AAaA,wBAAU,MAAM;AACd,QAAMM,UAAU;AAAA,mCAAG,aAAY;AAC7B,YAAIX,IAAJ,EAAU;AACR,cAAI;AACF,gBAAMY,GAAG,SAASZ,IAAI,CAACa,KAAL,EAAlB;;AACA,gBAAI,CAACb,IAAI,CAACc,eAAL,EAAL,EAA6B;AAC3BC,cAAAA,OAAO,CAACC,KAAR,iCAAuCJ,GAAvC;AACD;AACF,WALD,CAKE,OAAOI,KAAP,EAAc;AACdD,YAAAA,OAAO,CAACC,KAAR,CAAcA,KAAd;AACD;;AACDjB,UAAAA,UAAU,CAAC,KAAD,CAAV;;AACA,cAAIG,MAAJ,EAAY;AACVE,YAAAA,OAAO,CAACa,IAAR,CAAaf,MAAb;AACD;AACF;AACF,OAfe;;AAAA,sBAAVS,UAAU;AAAA;AAAA;AAAA,OAAhB;;AAgBAA,IAAAA,UAAU;AACX,GAlBD,EAkBG,CAACX,IAAD,EAAOI,OAAP,CAlBH;AAqBA,MAAI,CAACC,GAAL,EAAU,OAAO,2DAAP;AAEV,SACE,6BAAC,mBAAD;AACE,IAAA,OAAO,EAAEP,OADX;AAEE,IAAA,OAAO,yBAAkBI,MAAM,IAAIP,MAA5B;AAFT,IADF;AAMD,CAlDM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { FC } from 'react'\nimport React, { useContext, useEffect, useState } from 'react'\nimport { useHistory } from 'react-router-dom'\nimport type { BrowserSession } from '@looker/sdk-rtl'\nimport { RunItContext } from '../..'\nimport { Loading } from '../../components'\n\nexport const OAuthScene: FC = () => {\n const origin = (window as any).location.origin\n const [loading, setLoading] = useState(true)\n const [auth, setAuth] = useState<BrowserSession>()\n const [oldUrl, setOldUrl] = useState<string>()\n const history = useHistory()\n const { sdk } = useContext(RunItContext)\n\n useEffect(() => {\n if (sdk) {\n const authSession = sdk.authSession as BrowserSession\n setAuth(authSession)\n /** capture the stored return URL before `OAuthSession.login()` clears it */\n const old = authSession.returnUrl || `/`\n setOldUrl(old)\n } else {\n setAuth(undefined)\n setOldUrl(undefined)\n }\n }, [sdk])\n\n useEffect(() => {\n const maybeLogin = async () => {\n if (auth) {\n try {\n const res = await auth.login()\n if (!auth.isAuthenticated()) {\n console.error(`Authentication failed ${res}`)\n }\n } catch (error) {\n console.error(error)\n }\n setLoading(false)\n if (oldUrl) {\n history.push(oldUrl)\n }\n }\n }\n maybeLogin()\n }, [auth, history])\n\n // No sdk no OAuth for you\n if (!sdk) return <></>\n\n return (\n <Loading\n loading={loading}\n message={`Returning to ${oldUrl || origin} after OAuth login ...`}\n />\n )\n}\n"],"file":"OAuthScene.js"}
1
+ {"version":3,"sources":["../../../src/scenes/OAuthScene/OAuthScene.tsx"],"names":["OAuthScene","origin","window","location","loading","setLoading","auth","setAuth","oldUrl","setOldUrl","history","sdk","authSession","old","returnUrl","undefined","maybeLogin","res","login","isAuthenticated","console","error","push"],"mappings":";;;;;;;AA2BA;;AACA;;AAEA;;AAEA;;;;;;;;;;AAEO,IAAMA,UAAc,GAAG,MAAM;AAClC,MAAMC,MAAM,GAAIC,MAAD,CAAgBC,QAAhB,CAAyBF,MAAxC;AACA,MAAM,CAACG,OAAD,EAAUC,UAAV,IAAwB,qBAAS,IAAT,CAA9B;AACA,MAAM,CAACC,IAAD,EAAOC,OAAP,IAAkB,sBAAxB;AACA,MAAM,CAACC,MAAD,EAASC,SAAT,IAAsB,sBAA5B;AACA,MAAMC,OAAO,GAAG,iCAAhB;AACA,MAAMC,GAAG,GAAG,qCAAgBA,GAA5B;AAEA,wBAAU,MAAM;AACd,QAAIA,GAAJ,EAAS;AACP,UAAMC,WAAW,GAAGD,GAAG,CAACC,WAAxB;AACAL,MAAAA,OAAO,CAACK,WAAD,CAAP;AAEA,UAAMC,GAAG,GAAGD,WAAW,CAACE,SAAZ,OAAZ;AACAL,MAAAA,SAAS,CAACI,GAAD,CAAT;AACD,KAND,MAMO;AACLN,MAAAA,OAAO,CAACQ,SAAD,CAAP;AACAN,MAAAA,SAAS,CAACM,SAAD,CAAT;AACD;AACF,GAXD,EAWG,CAACJ,GAAD,CAXH;AAaA,wBAAU,MAAM;AACd,QAAMK,UAAU;AAAA,mCAAG,aAAY;AAC7B,YAAIV,IAAJ,EAAU;AACR,cAAI;AACF,gBAAMW,GAAG,SAASX,IAAI,CAACY,KAAL,EAAlB;;AACA,gBAAI,CAACZ,IAAI,CAACa,eAAL,EAAL,EAA6B;AAC3BC,cAAAA,OAAO,CAACC,KAAR,iCAAuCJ,GAAvC;AACD;AACF,WALD,CAKE,OAAOI,KAAP,EAAc;AACdD,YAAAA,OAAO,CAACC,KAAR,CAAcA,KAAd;AACD;;AACDhB,UAAAA,UAAU,CAAC,KAAD,CAAV;;AACA,cAAIG,MAAJ,EAAY;AACVE,YAAAA,OAAO,CAACY,IAAR,CAAad,MAAb;AACD;AACF;AACF,OAfe;;AAAA,sBAAVQ,UAAU;AAAA;AAAA;AAAA,OAAhB;;AAgBAA,IAAAA,UAAU;AACX,GAlBD,EAkBG,CAACV,IAAD,EAAOI,OAAP,CAlBH;AAoBA,SACE,6BAAC,mBAAD;AACE,IAAA,OAAO,EAAEN,OADX;AAEE,IAAA,OAAO,yBAAkBI,MAAM,IAAIP,MAA5B;AAFT,IADF;AAMD,CA/CM","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { FC } from 'react'\nimport React, { useEffect, useState } from 'react'\nimport { useHistory } from 'react-router-dom'\nimport type { BrowserSession } from '@looker/sdk-rtl'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { Loading } from '../../components'\n\nexport const OAuthScene: FC = () => {\n const origin = (window as any).location.origin\n const [loading, setLoading] = useState(true)\n const [auth, setAuth] = useState<BrowserSession>()\n const [oldUrl, setOldUrl] = useState<string>()\n const history = useHistory()\n const sdk = getEnvAdaptor().sdk\n\n useEffect(() => {\n if (sdk) {\n const authSession = sdk.authSession as BrowserSession\n setAuth(authSession)\n /** capture the stored return URL before `OAuthSession.login()` clears it */\n const old = authSession.returnUrl || `/`\n setOldUrl(old)\n } else {\n setAuth(undefined)\n setOldUrl(undefined)\n }\n }, [sdk])\n\n useEffect(() => {\n const maybeLogin = async () => {\n if (auth) {\n try {\n const res = await auth.login()\n if (!auth.isAuthenticated()) {\n console.error(`Authentication failed ${res}`)\n }\n } catch (error) {\n console.error(error)\n }\n setLoading(false)\n if (oldUrl) {\n history.push(oldUrl)\n }\n }\n }\n maybeLogin()\n }, [auth, history])\n\n return (\n <Loading\n loading={loading}\n message={`Returning to ${oldUrl || origin} after OAuth login ...`}\n />\n )\n}\n"],"file":"OAuthScene.js"}
@@ -5,6 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.testBogusJsonResponse = exports.testErrorResponse = exports.testUnknownResponse = exports.testImageResponse = exports.testSqlResponse = exports.testHtmlResponse = exports.testTextResponse = exports.testOneRowComplexJson = exports.testJsonResponse = void 0;
7
7
  var testJsonResponse = {
8
+ method: 'GET',
8
9
  url: 'https://some/json/data',
9
10
  headers: {
10
11
  'content-type': 'application/json'
@@ -17,6 +18,7 @@ var testJsonResponse = {
17
18
  };
18
19
  exports.testJsonResponse = testJsonResponse;
19
20
  var testOneRowComplexJson = {
21
+ method: 'GET',
20
22
  url: 'https://some/json/data',
21
23
  headers: {
22
24
  'content-type': 'application/json'
@@ -29,6 +31,7 @@ var testOneRowComplexJson = {
29
31
  };
30
32
  exports.testOneRowComplexJson = testOneRowComplexJson;
31
33
  var testTextResponse = {
34
+ method: 'GET',
32
35
  url: 'https://some/text/data',
33
36
  headers: {
34
37
  'content-type': 'text/plain;charset=utf-8'
@@ -41,6 +44,7 @@ var testTextResponse = {
41
44
  };
42
45
  exports.testTextResponse = testTextResponse;
43
46
  var testHtmlResponse = {
47
+ method: 'GET',
44
48
  url: "https://some/html",
45
49
  headers: {
46
50
  'content-type': 'text/html;charset=utf-8'
@@ -53,6 +57,7 @@ var testHtmlResponse = {
53
57
  };
54
58
  exports.testHtmlResponse = testHtmlResponse;
55
59
  var testSqlResponse = {
60
+ method: 'GET',
56
61
  url: "https://some/sql",
57
62
  headers: {
58
63
  'content-type': 'application/sql'
@@ -68,6 +73,7 @@ exports.testSqlResponse = testSqlResponse;
68
73
  var testImageResponse = function testImageResponse() {
69
74
  var contentType = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'image/png';
70
75
  return {
76
+ method: 'GET',
71
77
  url: "http://".concat(contentType),
72
78
  headers: {
73
79
  'content-type': contentType
@@ -82,6 +88,7 @@ var testImageResponse = function testImageResponse() {
82
88
 
83
89
  exports.testImageResponse = testImageResponse;
84
90
  var testUnknownResponse = {
91
+ method: 'GET',
85
92
  url: 'http://bogus',
86
93
  headers: {},
87
94
  contentType: 'bogus',
@@ -92,6 +99,7 @@ var testUnknownResponse = {
92
99
  };
93
100
  exports.testUnknownResponse = testUnknownResponse;
94
101
  var testErrorResponse = {
102
+ method: 'GET',
95
103
  url: 'http://error',
96
104
  headers: {},
97
105
  body: Buffer.from('{"message": "Not found", "documentation_url": "http://docs.looker.com"}'),
@@ -102,6 +110,7 @@ var testErrorResponse = {
102
110
  };
103
111
  exports.testErrorResponse = testErrorResponse;
104
112
  var testBogusJsonResponse = {
113
+ method: 'GET',
105
114
  url: 'https://some/json/data',
106
115
  headers: {},
107
116
  contentType: 'application/json',
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/test-data/responses.ts"],"names":["testJsonResponse","url","headers","contentType","ok","statusCode","statusMessage","body","Buffer","from","testOneRowComplexJson","testTextResponse","testHtmlResponse","testSqlResponse","testImageResponse","testUnknownResponse","testErrorResponse","testBogusJsonResponse"],"mappings":";;;;;;AA4BO,IAAMA,gBAA8B,GAAG;AAC5CC,EAAAA,GAAG,EAAE,wBADuC;AAE5CC,EAAAA,OAAO,EAAE;AAAE,oBAAgB;AAAlB,GAFmC;AAG5CC,EAAAA,WAAW,EAAE,kBAH+B;AAI5CC,EAAAA,EAAE,EAAE,IAJwC;AAK5CC,EAAAA,UAAU,EAAE,GALgC;AAM5CC,EAAAA,aAAa,EAAE,IAN6B;AAO5CC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CAAY,uBAAZ;AAPsC,CAAvC;;AAUA,IAAMC,qBAAmC,GAAG;AACjDT,EAAAA,GAAG,EAAE,wBAD4C;AAEjDC,EAAAA,OAAO,EAAE;AAAE,oBAAgB;AAAlB,GAFwC;AAGjDC,EAAAA,WAAW,EAAE,kBAHoC;AAIjDC,EAAAA,EAAE,EAAE,IAJ6C;AAKjDC,EAAAA,UAAU,EAAE,GALqC;AAMjDC,EAAAA,aAAa,EAAE,IANkC;AAOjDC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP;AAP2C,CAA5C;;AA6DA,IAAME,gBAA8B,GAAG;AAC5CV,EAAAA,GAAG,EAAE,wBADuC;AAE5CC,EAAAA,OAAO,EAAE;AAAE,oBAAgB;AAAlB,GAFmC;AAG5CC,EAAAA,WAAW,EAAE,0BAH+B;AAI5CC,EAAAA,EAAE,EAAE,IAJwC;AAK5CC,EAAAA,UAAU,EAAE,GALgC;AAM5CC,EAAAA,aAAa,EAAE,IAN6B;AAO5CC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CAAY,gBAAZ;AAPsC,CAAvC;;AAUA,IAAMG,gBAA8B,GAAG;AAC5CX,EAAAA,GAAG,qBADyC;AAE5CC,EAAAA,OAAO,EAAE;AAAE,oBAAgB;AAAlB,GAFmC;AAG5CC,EAAAA,WAAW,EAAE,yBAH+B;AAI5CC,EAAAA,EAAE,EAAE,IAJwC;AAK5CC,EAAAA,UAAU,EAAE,GALgC;AAM5CC,EAAAA,aAAa,EAAE,IAN6B;AAO5CC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CACJ,cACE,8DADF,GAEE,2CAFF,GAGE,UAJE;AAPsC,CAAvC;;AAeA,IAAMI,eAA6B,GAAG;AAC3CZ,EAAAA,GAAG,oBADwC;AAE3CC,EAAAA,OAAO,EAAE;AAAE,oBAAgB;AAAlB,GAFkC;AAG3CC,EAAAA,WAAW,EAAE,iBAH8B;AAI3CC,EAAAA,EAAE,EAAE,IAJuC;AAK3CC,EAAAA,UAAU,EAAE,GAL+B;AAM3CC,EAAAA,aAAa,EAAE,IAN4B;AAO3CC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP;AAPqC,CAAtC;;;AAcA,IAAMK,iBAAiB,GAAG,SAApBA,iBAAoB;AAAA,MAACX,WAAD,uEAAe,WAAf;AAAA,SAA8C;AAC7EF,IAAAA,GAAG,mBAAYE,WAAZ,CAD0E;AAE7ED,IAAAA,OAAO,EAAE;AAAE,sBAAgBC;AAAlB,KAFoE;AAG7EA,IAAAA,WAH6E;AAI7EC,IAAAA,EAAE,EAAE,IAJyE;AAK7EC,IAAAA,UAAU,EAAE,GALiE;AAM7EC,IAAAA,aAAa,EAAE,IAN8D;AAO7EC,IAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CAAY,iBAAZ;AAPuE,GAA9C;AAAA,CAA1B;;;AAUA,IAAMM,mBAAiC,GAAG;AAC/Cd,EAAAA,GAAG,EAAE,cAD0C;AAE/CC,EAAAA,OAAO,EAAE,EAFsC;AAG/CC,EAAAA,WAAW,EAAE,OAHkC;AAI/CC,EAAAA,EAAE,EAAE,IAJ2C;AAK/CC,EAAAA,UAAU,EAAE,GALmC;AAM/CC,EAAAA,aAAa,EAAE,IANgC;AAO/CC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CAAY,WAAZ;AAPyC,CAA1C;;AAUA,IAAMO,iBAA+B,GAAG;AAC7Cf,EAAAA,GAAG,EAAE,cADwC;AAE7CC,EAAAA,OAAO,EAAE,EAFoC;AAG7CK,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CACJ,yEADI,CAHuC;AAM7CN,EAAAA,WAAW,EAAE,MANgC;AAO7CC,EAAAA,EAAE,EAAE,KAPyC;AAQ7CC,EAAAA,UAAU,EAAE,GARiC;AAS7CC,EAAAA,aAAa,EAAE;AAT8B,CAAxC;;AAYA,IAAMW,qBAAmC,GAAG;AACjDhB,EAAAA,GAAG,EAAE,wBAD4C;AAEjDC,EAAAA,OAAO,EAAE,EAFwC;AAGjDC,EAAAA,WAAW,EAAE,kBAHoC;AAIjDC,EAAAA,EAAE,EAAE,IAJ6C;AAKjDC,EAAAA,UAAU,EAAE,GALqC;AAMjDC,EAAAA,aAAa,EAAE,IANkC;AAOjDC,EAAAA,IAAI,EAAEC,MAAM,CAACC,IAAP,CAAY,sDAAZ;AAP2C,CAA5C","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { IRawResponse } from '@looker/sdk-rtl'\n\nexport const testJsonResponse: IRawResponse = {\n url: 'https://some/json/data',\n headers: { 'content-type': 'application/json' },\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('[{\"key1\": \"value1\" }]'),\n}\n\nexport const testOneRowComplexJson: IRawResponse = {\n url: 'https://some/json/data',\n headers: { 'content-type': 'application/json' },\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(`{\n \"id\": 520,\n \"view\": \"orders\",\n \"fields\": [\n \"orders.id\",\n \"users.age\",\n \"users.city\"\n ],\n \"pivots\": [],\n \"fill_fields\": [],\n \"filters\": null,\n \"filter_expression\": \"\",\n \"sorts\": [],\n \"limit\": \"\",\n \"column_limit\": \"\",\n \"total\": null,\n \"row_total\": \"\",\n \"subtotals\": [],\n \"vis_config\": null,\n \"filter_config\": null,\n \"visible_ui_sections\": \"\",\n \"slug\": \"64zJjJw\",\n \"client_id\": \"zfn3SwIaaHbJTbsXSJ0JO7\",\n \"share_url\": \"https://localhost:9999/x/zfn3SwIaaHbJTbsXSJ0JO7\",\n \"expanded_share_url\": \"https://localhost:9999/explore/thelook/orders?fields=orders.id,users.age,users.city&origin=share-expanded\",\n \"url\": \"/explore/thelook/orders?fields=orders.id,users.age,users.city\",\n \"has_table_calculations\": false,\n \"model\": \"thelook\",\n \"dynamic_fields\": \"\",\n \"query_timezone\": \"\",\n \"quick_calcs\": null,\n \"analysis_config\": null,\n \"can\": {\n \"run\": true,\n \"see_results\": true,\n \"explore\": true,\n \"create\": true,\n \"show\": true,\n \"cost_estimate\": true,\n \"index\": true,\n \"see_lookml\": true,\n \"see_aggregate_table_lookml\": true,\n \"see_derived_table_lookml\": true,\n \"see_sql\": true,\n \"save\": true,\n \"generate_drill_links\": true,\n \"download\": true,\n \"download_unlimited\": true,\n \"use_custom_fields\": true,\n \"schedule\": true\n }\n}`),\n}\n\nexport const testTextResponse: IRawResponse = {\n url: 'https://some/text/data',\n headers: { 'content-type': 'text/plain;charset=utf-8' },\n contentType: 'text/plain;charset=utf-8',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some text data'),\n}\n\nexport const testHtmlResponse: IRawResponse = {\n url: `https://some/html`,\n headers: { 'content-type': 'text/html;charset=utf-8' },\n contentType: 'text/html;charset=utf-8',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(\n '<table>\\n' +\n '<tr><th>Orders Created Date</th><th>Orders Count</th></tr>\\n' +\n '<tr><td>2019-12-22</td><td>39</td></tr>\\n' +\n '</table>'\n ),\n}\n\nexport const testSqlResponse: IRawResponse = {\n url: `https://some/sql`,\n headers: { 'content-type': 'application/sql' },\n contentType: 'application/sql',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(`SELECT\n COUNT(DISTINCT products.id ) AS \\`products.count\\`\nFROM demo_db.inventory_items AS inventory_items\nLEFT JOIN demo_db.products AS products ON inventory_items.product_id = products.id\nLIMIT 500`),\n}\n\nexport const testImageResponse = (contentType = 'image/png'): IRawResponse => ({\n url: `http://${contentType}`,\n headers: { 'content-type': contentType },\n contentType,\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some image data'),\n})\n\nexport const testUnknownResponse: IRawResponse = {\n url: 'http://bogus',\n headers: {},\n contentType: 'bogus',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some data'),\n}\n\nexport const testErrorResponse: IRawResponse = {\n url: 'http://error',\n headers: {},\n body: Buffer.from(\n '{\"message\": \"Not found\", \"documentation_url\": \"http://docs.looker.com\"}'\n ),\n contentType: 'text',\n ok: false,\n statusCode: 404,\n statusMessage: 'some status message',\n}\n\nexport const testBogusJsonResponse: IRawResponse = {\n url: 'https://some/json/data',\n headers: {},\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('<html><body>I AM A LYING JSON RESPONSE</body></html>'),\n}\n"],"file":"responses.js"}
1
+ {"version":3,"sources":["../../src/test-data/responses.ts"],"names":["testJsonResponse","method","url","headers","contentType","ok","statusCode","statusMessage","body","Buffer","from","testOneRowComplexJson","testTextResponse","testHtmlResponse","testSqlResponse","testImageResponse","testUnknownResponse","testErrorResponse","testBogusJsonResponse"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type { IRawResponse } from '@looker/sdk-rtl'\n\nexport const testJsonResponse: IRawResponse = {\n method: 'GET',\n url: 'https://some/json/data',\n headers: { 'content-type': 'application/json' },\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('[{\"key1\": \"value1\" }]'),\n}\n\nexport const testOneRowComplexJson: IRawResponse = {\n method: 'GET',\n url: 'https://some/json/data',\n headers: { 'content-type': 'application/json' },\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(`{\n \"id\": 520,\n \"view\": \"orders\",\n \"fields\": [\n \"orders.id\",\n \"users.age\",\n \"users.city\"\n ],\n \"pivots\": [],\n \"fill_fields\": [],\n \"filters\": null,\n \"filter_expression\": \"\",\n \"sorts\": [],\n \"limit\": \"\",\n \"column_limit\": \"\",\n \"total\": null,\n \"row_total\": \"\",\n \"subtotals\": [],\n \"vis_config\": null,\n \"filter_config\": null,\n \"visible_ui_sections\": \"\",\n \"slug\": \"64zJjJw\",\n \"client_id\": \"zfn3SwIaaHbJTbsXSJ0JO7\",\n \"share_url\": \"https://localhost:9999/x/zfn3SwIaaHbJTbsXSJ0JO7\",\n \"expanded_share_url\": \"https://localhost:9999/explore/thelook/orders?fields=orders.id,users.age,users.city&origin=share-expanded\",\n \"url\": \"/explore/thelook/orders?fields=orders.id,users.age,users.city\",\n \"has_table_calculations\": false,\n \"model\": \"thelook\",\n \"dynamic_fields\": \"\",\n \"query_timezone\": \"\",\n \"quick_calcs\": null,\n \"analysis_config\": null,\n \"can\": {\n \"run\": true,\n \"see_results\": true,\n \"explore\": true,\n \"create\": true,\n \"show\": true,\n \"cost_estimate\": true,\n \"index\": true,\n \"see_lookml\": true,\n \"see_aggregate_table_lookml\": true,\n \"see_derived_table_lookml\": true,\n \"see_sql\": true,\n \"save\": true,\n \"generate_drill_links\": true,\n \"download\": true,\n \"download_unlimited\": true,\n \"use_custom_fields\": true,\n \"schedule\": true\n }\n}`),\n}\n\nexport const testTextResponse: IRawResponse = {\n method: 'GET',\n url: 'https://some/text/data',\n headers: { 'content-type': 'text/plain;charset=utf-8' },\n contentType: 'text/plain;charset=utf-8',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some text data'),\n}\n\nexport const testHtmlResponse: IRawResponse = {\n method: 'GET',\n url: `https://some/html`,\n headers: { 'content-type': 'text/html;charset=utf-8' },\n contentType: 'text/html;charset=utf-8',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(\n '<table>\\n' +\n '<tr><th>Orders Created Date</th><th>Orders Count</th></tr>\\n' +\n '<tr><td>2019-12-22</td><td>39</td></tr>\\n' +\n '</table>'\n ),\n}\n\nexport const testSqlResponse: IRawResponse = {\n method: 'GET',\n url: `https://some/sql`,\n headers: { 'content-type': 'application/sql' },\n contentType: 'application/sql',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from(`SELECT\n COUNT(DISTINCT products.id ) AS \\`products.count\\`\nFROM demo_db.inventory_items AS inventory_items\nLEFT JOIN demo_db.products AS products ON inventory_items.product_id = products.id\nLIMIT 500`),\n}\n\nexport const testImageResponse = (contentType = 'image/png'): IRawResponse => ({\n method: 'GET',\n url: `http://${contentType}`,\n headers: { 'content-type': contentType },\n contentType,\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some image data'),\n})\n\nexport const testUnknownResponse: IRawResponse = {\n method: 'GET',\n url: 'http://bogus',\n headers: {},\n contentType: 'bogus',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('some data'),\n}\n\nexport const testErrorResponse: IRawResponse = {\n method: 'GET',\n url: 'http://error',\n headers: {},\n body: Buffer.from(\n '{\"message\": \"Not found\", \"documentation_url\": \"http://docs.looker.com\"}'\n ),\n contentType: 'text',\n ok: false,\n statusCode: 404,\n statusMessage: 'some status message',\n}\n\nexport const testBogusJsonResponse: IRawResponse = {\n method: 'GET',\n url: 'https://some/json/data',\n headers: {},\n contentType: 'application/json',\n ok: true,\n statusCode: 200,\n statusMessage: 'OK',\n body: Buffer.from('<html><body>I AM A LYING JSON RESPONSE</body></html>'),\n}\n"],"file":"responses.js"}
@@ -1,17 +1,4 @@
1
- import type { IAPIMethods, IApiSection, IApiSettings } from '@looker/sdk-rtl';
2
- import { ApiSettings } from '@looker/sdk-rtl';
3
- import type { RunItConfigurator } from '../components';
4
- export declare class RunItSettings extends ApiSettings {
5
- configurator: RunItConfigurator;
6
- constructor(settings: Partial<IApiSettings>, configurator: RunItConfigurator);
7
- getStoredConfig(): {
8
- base_url: string;
9
- looker_url: string;
10
- };
11
- authIsConfigured(): boolean;
12
- readConfig(_section?: string): IApiSection;
1
+ export declare const initRunItSdk: () => import("@looker/sdk-rtl").APIMethods;
2
+ export declare enum StoreConstants {
3
+ LOCALSTORAGE_SETTINGS_KEY = "settings"
13
4
  }
14
- export declare let runItSDK: IAPIMethods;
15
- export declare const initRunItSdk: (configurator: RunItConfigurator) => IAPIMethods;
16
- export declare const sdkNeedsConfig: (sdk: IAPIMethods | undefined) => boolean;
17
- export declare const sdkNeedsAuth: (sdk: IAPIMethods | undefined) => boolean;