@looker/run-it 0.9.23 → 0.9.24
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.md +21 -0
- package/lib/RunIt.d.ts +2 -0
- package/lib/RunIt.js +17 -26
- package/lib/RunIt.js.map +1 -1
- package/lib/RunItProvider.d.ts +0 -4
- package/lib/RunItProvider.js +2 -7
- package/lib/RunItProvider.js.map +1 -1
- package/lib/components/ConfigForm/ConfigForm.d.ts +0 -4
- package/lib/components/ConfigForm/ConfigForm.js +12 -11
- package/lib/components/ConfigForm/ConfigForm.js.map +1 -1
- package/lib/components/ConfigForm/configUtils.js +6 -4
- package/lib/components/ConfigForm/configUtils.js.map +1 -1
- package/lib/components/LoginForm/LoginForm.d.ts +2 -8
- package/lib/components/LoginForm/LoginForm.js +5 -6
- package/lib/components/LoginForm/LoginForm.js.map +1 -1
- package/lib/components/PerfTracker/PerfTracker.d.ts +0 -2
- package/lib/components/PerfTracker/PerfTracker.js +7 -8
- package/lib/components/PerfTracker/PerfTracker.js.map +1 -1
- package/lib/components/RequestForm/RequestForm.d.ts +0 -4
- package/lib/components/RequestForm/RequestForm.js +0 -7
- package/lib/components/RequestForm/RequestForm.js.map +1 -1
- package/lib/components/common/index.d.ts +0 -1
- package/lib/components/common/index.js +0 -18
- package/lib/components/common/index.js.map +1 -1
- package/lib/esm/RunIt.js +17 -27
- package/lib/esm/RunIt.js.map +1 -1
- package/lib/esm/RunItProvider.js +2 -7
- package/lib/esm/RunItProvider.js.map +1 -1
- package/lib/esm/components/ConfigForm/ConfigForm.js +12 -12
- package/lib/esm/components/ConfigForm/ConfigForm.js.map +1 -1
- package/lib/esm/components/ConfigForm/configUtils.js +6 -4
- package/lib/esm/components/ConfigForm/configUtils.js.map +1 -1
- package/lib/esm/components/LoginForm/LoginForm.js +5 -6
- package/lib/esm/components/LoginForm/LoginForm.js.map +1 -1
- package/lib/esm/components/PerfTracker/PerfTracker.js +7 -8
- package/lib/esm/components/PerfTracker/PerfTracker.js.map +1 -1
- package/lib/esm/components/RequestForm/RequestForm.js +0 -7
- package/lib/esm/components/RequestForm/RequestForm.js.map +1 -1
- package/lib/esm/components/common/index.js +0 -1
- package/lib/esm/components/common/index.js.map +1 -1
- package/lib/esm/scenes/OAuthScene/OAuthScene.js +3 -6
- package/lib/esm/scenes/OAuthScene/OAuthScene.js.map +1 -1
- package/lib/esm/utils/RunItSDK.js +8 -78
- package/lib/esm/utils/RunItSDK.js.map +1 -1
- package/lib/esm/utils/requestUtils.js +21 -14
- package/lib/esm/utils/requestUtils.js.map +1 -1
- package/lib/scenes/OAuthScene/OAuthScene.js +2 -5
- package/lib/scenes/OAuthScene/OAuthScene.js.map +1 -1
- package/lib/utils/RunItSDK.d.ts +1 -17
- package/lib/utils/RunItSDK.js +10 -88
- package/lib/utils/RunItSDK.js.map +1 -1
- package/lib/utils/requestUtils.d.ts +2 -3
- package/lib/utils/requestUtils.js +22 -15
- package/lib/utils/requestUtils.js.map +1 -1
- package/package.json +6 -5
- package/lib/components/common/StandaloneConfigurator.d.ts +0 -7
- package/lib/components/common/StandaloneConfigurator.js +0 -61
- package/lib/components/common/StandaloneConfigurator.js.map +0 -1
- package/lib/esm/components/common/StandaloneConfigurator.js +0 -51
- package/lib/esm/components/common/StandaloneConfigurator.js.map +0 -1
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/ConfigForm/ConfigForm.tsx"],"names":["React","useState","useEffect","Button","ButtonTransparent","Divider","Fieldset","FieldText","Form","MessageBar","Paragraph","Link","Space","SpaceVertical","Tooltip","CodeCopy","CollapserCard","RunItFormKey","RunItHeading","DarkSpan","runItSDK","readyToLogin","RunItNoConfig","RunItConfigKey","validateUrl","loadSpecsFromVersions","POSITIVE","defaultFieldValues","baseUrl","webUrl","headless","specs","fetchResult","fetchIntent","ConfigForm","configurator","setVersionsUrl","title","requestContent","sdk","setHasConfig","BASE_URL","WEB_URL","FETCH_INTENT","FETCH_RESULT","CRITICAL","appConfig","window","location","origin","getConfig","data","getStorage","result","value","JSON","parse","base_url","looker_url","config","fields","setFields","saved","setSaved","updateFields","nameOrValues","previousFields","validationMessages","setValidationMessages","updateMessage","intent","message","isConfigured","fetchError","updateForm","_e","save","versionsUrl","setStorage","stringify","err","handleSave","e","handleVerify","handleClear","removeStorage","isAuthenticated","handleUrlChange","event","name","currentTarget","newValidationMessages","url","type","authSession","verifyButtonDisabled","trim","length","Object","keys","saveButtonDisabled","clearButtonDisabled","loginButtonDisabled","handleLogin","preventDefault","login"],"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 { BaseSyntheticEvent, Dispatch, FC, FormEvent } from 'react'\nimport React, { useState, useEffect } from 'react'\nimport type { ValidationMessages, MessageBarIntent } from '@looker/components'\nimport {\n Button,\n ButtonTransparent,\n Divider,\n Fieldset,\n FieldText,\n Form,\n MessageBar,\n Paragraph,\n Link,\n Space,\n SpaceVertical,\n Tooltip,\n} from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\nimport type { IAPIMethods } from '@looker/sdk-rtl'\nimport type { RunItSetter, RunItValues } from '../..'\nimport {\n CollapserCard,\n RunItFormKey,\n RunItHeading,\n DarkSpan,\n runItSDK,\n readyToLogin,\n RunItNoConfig,\n} from '../..'\nimport type { RunItConfigurator, ILoadedSpecs } from './configUtils'\nimport {\n RunItConfigKey,\n validateUrl,\n loadSpecsFromVersions,\n} from './configUtils'\n\nconst POSITIVE: MessageBarIntent = 'positive'\n\ninterface IFieldValues extends ILoadedSpecs {\n fetchIntent: MessageBarIntent\n}\n\nconst defaultFieldValues: IFieldValues = {\n baseUrl: '',\n webUrl: '',\n /** not currently used but declared for property compatibility for ILoadedSpecs */\n headless: false,\n specs: {},\n fetchResult: '',\n fetchIntent: POSITIVE,\n}\n\ninterface ConfigFormProps {\n configurator: RunItConfigurator\n setVersionsUrl: RunItSetter\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** Title for the config form */\n title?: string\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** SDK to use for login. Defaults to the `runItSDK` */\n sdk?: IAPIMethods\n}\n\nexport const ConfigForm: FC<ConfigFormProps> = ({\n configurator,\n setVersionsUrl,\n title,\n requestContent,\n sdk = runItSDK,\n setHasConfig,\n}) => {\n const BASE_URL = 'baseUrl'\n const WEB_URL = 'webUrl'\n const FETCH_INTENT = 'fetchIntent'\n const FETCH_RESULT = 'fetchResult'\n const CRITICAL: MessageBarIntent = 'critical'\n const appConfig = `{\n \"client_guid\": \"looker.api-explorer\",\n \"redirect_uri\": \"${(window as any).location.origin}/oauth\",\n \"display_name\": \"CORS API Explorer\",\n \"description\": \"Looker API Explorer using CORS\",\n \"enabled\": true\n}\n`\n\n // See https://codesandbox.io/s/youthful-surf-0g27j?file=/src/index.tsx for a prototype from Luke\n // TODO see about useReducer to clean this up a bit more\n title = title || 'RunIt Configuration'\n\n const getConfig = () => {\n // get configuration from storage, or default it\n const data = configurator.getStorage(RunItConfigKey)\n const result = data.value\n ? JSON.parse(data.value)\n : { base_url: '', looker_url: '' } // TODO why is RunItNoConfig undefined here?\n return result\n }\n\n const config = getConfig()\n const [fields, setFields] = useState<IFieldValues>(defaultFieldValues)\n const [saved, setSaved] = useState<RunItValues>(config)\n\n const updateFields = (\n nameOrValues: string | Partial<IFieldValues>,\n value = ''\n ) => {\n if (typeof nameOrValues === 'string') {\n setFields((previousFields) => {\n return { ...previousFields, ...{ [nameOrValues]: value } }\n })\n } else {\n setFields((previousFields) => {\n return { ...previousFields, ...nameOrValues }\n })\n }\n }\n\n useEffect(() => {\n const data = getConfig()\n const { base_url, looker_url } = getConfig()\n setSaved(data)\n updateFields({\n [BASE_URL]: base_url,\n [WEB_URL]: looker_url,\n [FETCH_INTENT]:\n base_url !== '' && looker_url !== '' ? POSITIVE : CRITICAL,\n })\n }, [configurator])\n\n const [validationMessages, setValidationMessages] =\n useState<ValidationMessages>({})\n\n const updateMessage = (intent: MessageBarIntent, message: string) => {\n updateFields({ [FETCH_RESULT]: message, [FETCH_INTENT]: intent })\n }\n\n const isConfigured = () => {\n return (\n saved !== RunItNoConfig &&\n fields[BASE_URL] === saved.base_url &&\n fields[WEB_URL] === saved.looker_url\n )\n }\n\n const fetchError = (message: string) => {\n updateFields(WEB_URL, '')\n updateMessage(CRITICAL, message)\n }\n\n const updateForm = async (_e: BaseSyntheticEvent, save: boolean) => {\n // e.preventDefault()\n try {\n updateMessage('inform', '')\n const versionsUrl = `${fields.baseUrl}/versions`\n const { webUrl, baseUrl } = await loadSpecsFromVersions(versionsUrl)\n if (!baseUrl || !webUrl) {\n fetchError('Invalid server configuration')\n } else {\n updateFields({ [BASE_URL]: baseUrl, [WEB_URL]: webUrl })\n updateMessage(POSITIVE, 'Configuration is valid')\n if (save) {\n const data = { base_url: baseUrl, looker_url: webUrl }\n configurator.setStorage(\n RunItConfigKey,\n JSON.stringify(data),\n // Always store in local storage\n 'local'\n )\n if (setHasConfig) setHasConfig(true)\n setSaved(data)\n setVersionsUrl(versionsUrl)\n updateMessage(POSITIVE, `Saved ${webUrl} as OAuth server`)\n }\n }\n } catch (err: any) {\n fetchError(err.message)\n }\n }\n\n const handleSave = async (e: BaseSyntheticEvent) => {\n await updateForm(e, true)\n }\n\n const handleVerify = async (e: BaseSyntheticEvent) => {\n await updateForm(e, false)\n }\n\n const handleClear = async (_e: BaseSyntheticEvent) => {\n // e.preventDefault()\n configurator.removeStorage(RunItConfigKey)\n updateFields({\n [BASE_URL]: '',\n [WEB_URL]: '',\n [FETCH_INTENT]: CRITICAL,\n [FETCH_RESULT]: '',\n })\n setSaved(RunItNoConfig)\n if (setHasConfig) setHasConfig(false)\n if (isAuthenticated()) {\n updateMessage('warn', 'Please reload the browser page to log out')\n }\n }\n\n const handleUrlChange = (event: FormEvent<HTMLInputElement>) => {\n const name = event.currentTarget.name\n\n const newValidationMessages = { ...validationMessages }\n\n const url = validateUrl(event.currentTarget.value)\n if (url) {\n delete newValidationMessages[name]\n // Update URL if it's been cleaned up\n event.currentTarget.value = url\n } else {\n newValidationMessages[name] = {\n message: `'${event.currentTarget.value}' is not a valid url`,\n type: 'error',\n }\n }\n updateFields({\n [event.currentTarget.name]: event.currentTarget.value,\n [WEB_URL]: '',\n })\n\n setValidationMessages(newValidationMessages)\n }\n\n const isAuthenticated = () => sdk?.authSession.isAuthenticated()\n\n const verifyButtonDisabled =\n fields.baseUrl.trim().length === 0 ||\n Object.keys(validationMessages).length > 0\n\n const saveButtonDisabled =\n verifyButtonDisabled || fields.webUrl.trim().length === 0 || isConfigured()\n\n const clearButtonDisabled = fields.baseUrl.trim().length === 0\n\n const loginButtonDisabled =\n verifyButtonDisabled || !isConfigured() || isAuthenticated()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n configurator.setStorage(\n RunItFormKey,\n JSON.stringify(requestContent),\n 'local'\n )\n }\n // This will set storage variables and return to OAuthScene when successful\n await sdk?.authSession.login()\n }\n\n return (\n <SpaceVertical gap=\"u2\">\n <RunItHeading>{title}</RunItHeading>\n <DarkSpan fontSize=\"small\">\n To configure RunIt mode, you need to supply your API server URL, then\n authenticate into your Looker Instance\n </DarkSpan>\n <MessageBar\n intent={fields[FETCH_INTENT]}\n onPrimaryClick={() => updateMessage(fields[FETCH_INTENT], '')}\n visible={fields[FETCH_RESULT] !== ''}\n >\n {fields[FETCH_RESULT]}\n </MessageBar>\n <CollapserCard\n heading=\"1. Supply API Server URL\"\n id=\"server_config\"\n divider={false}\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical gap=\"u2\" pt=\"u3\" px=\"u6\">\n <Form validationMessages={validationMessages}>\n <Fieldset legend=\"Server locations\">\n <FieldText\n required\n label=\"API server URL\"\n placeholder=\"typically https://myserver.looker.com:19999\"\n name={BASE_URL}\n value={fields[BASE_URL]}\n onChange={handleUrlChange}\n />\n <FieldText\n label=\"OAuth server URL\"\n placeholder=\"Click 'Verify' to retrieve\"\n name={WEB_URL}\n value={fields[WEB_URL]}\n disabled={true}\n />\n </Fieldset>\n </Form>\n <Paragraph fontSize=\"small\">\n The following configuration can be used to create a{' '}\n <Link\n href=\"https://github.com/looker-open-source/sdk-codegen/blob/main/docs/cors.md#reference-implementation\"\n target=\"_blank\"\n >\n Looker OAuth client\n </Link>\n .\n </Paragraph>\n <CodeCopy key=\"appConfig\" language=\"json\" code={appConfig} />\n <Space>\n <Tooltip content=\"Clear the configuration values\">\n <ButtonTransparent\n onClick={handleClear}\n disabled={clearButtonDisabled}\n >\n Clear\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content={`Verify ${fields[BASE_URL]}`}>\n <ButtonTransparent\n disabled={verifyButtonDisabled}\n onClick={handleVerify}\n mr=\"small\"\n >\n Verify\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content=\"Save the configuration for this browser\">\n <Button\n disabled={saveButtonDisabled}\n onClick={handleSave}\n mr=\"small\"\n >\n Save\n </Button>\n </Tooltip>\n </Space>\n </SpaceVertical>\n </CollapserCard>\n <Divider appearance=\"light\" />\n <CollapserCard\n heading=\"2. Login to instance\"\n divider={false}\n id=\"login_section\"\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical pt=\"u3\" px=\"u6\">\n {isAuthenticated() ? (\n <DarkSpan>\n You are already logged in. Reload the page to log out.\n </DarkSpan>\n ) : isConfigured() ? (\n <>\n <DarkSpan>{readyToLogin}</DarkSpan>\n </>\n ) : (\n <DarkSpan>\n You will be able to login after you Verify your API Server URL\n </DarkSpan>\n )}\n <Tooltip\n content={`Login to ${fields[WEB_URL]} using OAuth to enable RunIt`}\n >\n <Button onClick={handleLogin} disabled={loginButtonDisabled}>\n Login\n </Button>\n </Tooltip>\n </SpaceVertical>\n </CollapserCard>\n </SpaceVertical>\n )\n}\n"],"file":"ConfigForm.js"}
|
1
|
+
{"version":3,"sources":["../../../../src/components/ConfigForm/ConfigForm.tsx"],"names":["React","useState","useEffect","Button","ButtonTransparent","Divider","Fieldset","FieldText","Form","MessageBar","Paragraph","Link","Space","SpaceVertical","Tooltip","CodeCopy","getEnvAdaptor","CollapserCard","RunItFormKey","RunItHeading","DarkSpan","readyToLogin","RunItNoConfig","RunItConfigKey","validateUrl","loadSpecsFromVersions","POSITIVE","defaultFieldValues","baseUrl","webUrl","headless","specs","fetchResult","fetchIntent","ConfigForm","setVersionsUrl","title","requestContent","setHasConfig","BASE_URL","WEB_URL","FETCH_INTENT","FETCH_RESULT","CRITICAL","appConfig","window","location","origin","sdk","getConfig","data","localStorage","getItem","result","JSON","parse","base_url","looker_url","config","fields","setFields","saved","setSaved","updateFields","nameOrValues","value","previousFields","validationMessages","setValidationMessages","updateMessage","intent","message","isConfigured","fetchError","updateForm","_e","save","versionsUrl","setItem","stringify","err","handleSave","e","handleVerify","handleClear","removeItem","isAuthenticated","handleUrlChange","event","name","currentTarget","newValidationMessages","url","type","authSession","verifyButtonDisabled","trim","length","Object","keys","saveButtonDisabled","clearButtonDisabled","loginButtonDisabled","handleLogin","preventDefault","login"],"mappings":";;;;;;;;;;AA2BA,OAAOA,KAAP,IAAgBC,QAAhB,EAA0BC,SAA1B,QAA2C,OAA3C;AAEA,SACEC,MADF,EAEEC,iBAFF,EAGEC,OAHF,EAIEC,QAJF,EAKEC,SALF,EAMEC,IANF,EAOEC,UAPF,EAQEC,SARF,EASEC,IATF,EAUEC,KAVF,EAWEC,aAXF,EAYEC,OAZF,QAaO,oBAbP;AAcA,SAASC,QAAT,QAAyB,qBAAzB;AACA,SAASC,aAAT,QAA8B,yBAA9B;AAGA,SACEC,aADF,EAEEC,YAFF,EAGEC,YAHF,EAIEC,QAJF,EAKEC,YALF,EAMEC,aANF,QAOO,OAPP;AASA,SACEC,cADF,EAEEC,WAFF,EAGEC,qBAHF,QAIO,eAJP;AAMA,IAAMC,QAA0B,GAAG,UAAnC;AAMA,IAAMC,kBAAgC,GAAG;AACvCC,EAAAA,OAAO,EAAE,EAD8B;AAEvCC,EAAAA,MAAM,EAAE,EAF+B;AAIvCC,EAAAA,QAAQ,EAAE,KAJ6B;AAKvCC,EAAAA,KAAK,EAAE,EALgC;AAMvCC,EAAAA,WAAW,EAAE,EAN0B;AAOvCC,EAAAA,WAAW,EAAEP;AAP0B,CAAzC;AAoBA,OAAO,IAAMQ,UAA+B,GAAG,QAKzC;AAAA,MAL0C;AAC9CC,IAAAA,cAD8C;AAE9CC,IAAAA,KAF8C;AAG9CC,IAAAA,cAH8C;AAI9CC,IAAAA;AAJ8C,GAK1C;AACJ,MAAMC,QAAQ,GAAG,SAAjB;AACA,MAAMC,OAAO,GAAG,QAAhB;AACA,MAAMC,YAAY,GAAG,aAArB;AACA,MAAMC,YAAY,GAAG,aAArB;AACA,MAAMC,QAA0B,GAAG,UAAnC;AACA,MAAMC,SAAS,mFAEKC,MAAD,CAAgBC,QAAhB,CAAyBC,MAF7B,4IAAf;AAQA,MAAMC,GAAG,GAAGhC,aAAa,GAAGgC,GAA5B;AAGAZ,EAAAA,KAAK,GAAGA,KAAK,IAAI,qBAAjB;;AAEA,MAAMa,SAAS,GAAG,MAAM;AAGtB,QAAMC,IAAI,GAAGC,YAAY,CAACC,OAAb,CAAqB7B,cAArB,CAAb;AACA,QAAM8B,MAAM,GAAGH,IAAI,GAAGI,IAAI,CAACC,KAAL,CAAWL,IAAX,CAAH,GAAsB;AAAEM,MAAAA,QAAQ,EAAE,EAAZ;AAAgBC,MAAAA,UAAU,EAAE;AAA5B,KAAzC;AACA,WAAOJ,MAAP;AACD,GAND;;AAQA,MAAMK,MAAM,GAAGT,SAAS,EAAxB;AACA,MAAM,CAACU,MAAD,EAASC,SAAT,IAAsB3D,QAAQ,CAAe0B,kBAAf,CAApC;AACA,MAAM,CAACkC,KAAD,EAAQC,QAAR,IAAoB7D,QAAQ,CAAcyD,MAAd,CAAlC;;AAEA,MAAMK,YAAY,GAAG,SAAfA,YAAe,CACnBC,YADmB,EAGhB;AAAA,QADHC,KACG,uEADK,EACL;;AACH,QAAI,OAAOD,YAAP,KAAwB,QAA5B,EAAsC;AACpCJ,MAAAA,SAAS,CAAEM,cAAD,IAAoB;AAC5B,+CAAYA,cAAZ,GAA+B;AAAE,WAACF,YAAD,GAAgBC;AAAlB,SAA/B;AACD,OAFQ,CAAT;AAGD,KAJD,MAIO;AACLL,MAAAA,SAAS,CAAEM,cAAD,IAAoB;AAC5B,+CAAYA,cAAZ,GAA+BF,YAA/B;AACD,OAFQ,CAAT;AAGD;AACF,GAbD;;AAeA9D,EAAAA,SAAS,CAAC,MAAM;AACd,QAAMgD,IAAI,GAAGD,SAAS,EAAtB;AACA,QAAM;AAAEO,MAAAA,QAAF;AAAYC,MAAAA;AAAZ,QAA2BP,IAAjC;AACAY,IAAAA,QAAQ,CAACZ,IAAD,CAAR;AACAa,IAAAA,YAAY,CAAC;AACX,OAACxB,QAAD,GAAYiB,QADD;AAEX,OAAChB,OAAD,GAAWiB,UAFA;AAGX,OAAChB,YAAD,GACEe,QAAQ,KAAK,EAAb,IAAmBC,UAAU,KAAK,EAAlC,GAAuC/B,QAAvC,GAAkDiB;AAJzC,KAAD,CAAZ;AAMD,GAVQ,EAUN,EAVM,CAAT;AAYA,MAAM,CAACwB,kBAAD,EAAqBC,qBAArB,IACJnE,QAAQ,CAAqB,EAArB,CADV;;AAGA,MAAMoE,aAAa,GAAG,CAACC,MAAD,EAA2BC,OAA3B,KAA+C;AACnER,IAAAA,YAAY,CAAC;AAAE,OAACrB,YAAD,GAAgB6B,OAAlB;AAA2B,OAAC9B,YAAD,GAAgB6B;AAA3C,KAAD,CAAZ;AACD,GAFD;;AAIA,MAAME,YAAY,GAAG,MAAM;AACzB,WACEX,KAAK,KAAKvC,aAAV,IACAqC,MAAM,CAACpB,QAAD,CAAN,KAAqBsB,KAAK,CAACL,QAD3B,IAEAG,MAAM,CAACnB,OAAD,CAAN,KAAoBqB,KAAK,CAACJ,UAH5B;AAKD,GAND;;AAQA,MAAMgB,UAAU,GAAIF,OAAD,IAAqB;AACtCR,IAAAA,YAAY,CAACvB,OAAD,EAAU,EAAV,CAAZ;AACA6B,IAAAA,aAAa,CAAC1B,QAAD,EAAW4B,OAAX,CAAb;AACD,GAHD;;AAKA,MAAMG,UAAU;AAAA,kCAAG,WAAOC,EAAP,EAA+BC,IAA/B,EAAiD;AAElE,UAAI;AACFP,QAAAA,aAAa,CAAC,QAAD,EAAW,EAAX,CAAb;AACA,YAAMQ,WAAW,aAAMlB,MAAM,CAAC/B,OAAb,cAAjB;AACA,YAAM;AAAEC,UAAAA,MAAF;AAAUD,UAAAA;AAAV,kBAA4BH,qBAAqB,CAACoD,WAAD,CAAvD;;AACA,YAAI,CAACjD,OAAD,IAAY,CAACC,MAAjB,EAAyB;AACvB4C,UAAAA,UAAU,CAAC,8BAAD,CAAV;AACD,SAFD,MAEO;AACLV,UAAAA,YAAY,CAAC;AAAE,aAACxB,QAAD,GAAYX,OAAd;AAAuB,aAACY,OAAD,GAAWX;AAAlC,WAAD,CAAZ;AACAwC,UAAAA,aAAa,CAAC3C,QAAD,EAAW,wBAAX,CAAb;;AACA,cAAIkD,IAAJ,EAAU;AACR,gBAAM1B,IAAI,GAAG;AAAEM,cAAAA,QAAQ,EAAE5B,OAAZ;AAAqB6B,cAAAA,UAAU,EAAE5B;AAAjC,aAAb;AAEAsB,YAAAA,YAAY,CAAC2B,OAAb,CAAqBvD,cAArB,EAAqC+B,IAAI,CAACyB,SAAL,CAAe7B,IAAf,CAArC;AACA,gBAAIZ,YAAJ,EAAkBA,YAAY,CAAC,IAAD,CAAZ;AAClBwB,YAAAA,QAAQ,CAACZ,IAAD,CAAR;AACAf,YAAAA,cAAc,CAAC0C,WAAD,CAAd;AACAR,YAAAA,aAAa,CAAC3C,QAAD,kBAAoBG,MAApB,sBAAb;AACD;AACF;AACF,OAnBD,CAmBE,OAAOmD,GAAP,EAAiB;AACjBP,QAAAA,UAAU,CAACO,GAAG,CAACT,OAAL,CAAV;AACD;AACF,KAxBe;;AAAA,oBAAVG,UAAU;AAAA;AAAA;AAAA,KAAhB;;AA0BA,MAAMO,UAAU;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AAClD,YAAMR,UAAU,CAACQ,CAAD,EAAI,IAAJ,CAAhB;AACD,KAFe;;AAAA,oBAAVD,UAAU;AAAA;AAAA;AAAA,KAAhB;;AAIA,MAAME,YAAY;AAAA,kCAAG,WAAOD,CAAP,EAAiC;AACpD,YAAMR,UAAU,CAACQ,CAAD,EAAI,KAAJ,CAAhB;AACD,KAFiB;;AAAA,oBAAZC,YAAY;AAAA;AAAA;AAAA,KAAlB;;AAIA,MAAMC,WAAW;AAAA,kCAAG,WAAOT,EAAP,EAAkC;AAEpDxB,MAAAA,YAAY,CAACkC,UAAb,CAAwB9D,cAAxB;AACAwC,MAAAA,YAAY,CAAC;AACX,SAACxB,QAAD,GAAY,EADD;AAEX,SAACC,OAAD,GAAW,EAFA;AAGX,SAACC,YAAD,GAAgBE,QAHL;AAIX,SAACD,YAAD,GAAgB;AAJL,OAAD,CAAZ;AAMAoB,MAAAA,QAAQ,CAACxC,aAAD,CAAR;AACA,UAAIgB,YAAJ,EAAkBA,YAAY,CAAC,KAAD,CAAZ;;AAClB,UAAIgD,eAAe,EAAnB,EAAuB;AACrBjB,QAAAA,aAAa,CAAC,MAAD,EAAS,2CAAT,CAAb;AACD;AACF,KAdgB;;AAAA,oBAAXe,WAAW;AAAA;AAAA;AAAA,KAAjB;;AAgBA,MAAMG,eAAe,GAAIC,KAAD,IAAwC;AAC9D,QAAMC,IAAI,GAAGD,KAAK,CAACE,aAAN,CAAoBD,IAAjC;;AAEA,QAAME,qBAAqB,qBAAQxB,kBAAR,CAA3B;;AAEA,QAAMyB,GAAG,GAAGpE,WAAW,CAACgE,KAAK,CAACE,aAAN,CAAoBzB,KAArB,CAAvB;;AACA,QAAI2B,GAAJ,EAAS;AACP,aAAOD,qBAAqB,CAACF,IAAD,CAA5B;AAEAD,MAAAA,KAAK,CAACE,aAAN,CAAoBzB,KAApB,GAA4B2B,GAA5B;AACD,KAJD,MAIO;AACLD,MAAAA,qBAAqB,CAACF,IAAD,CAArB,GAA8B;AAC5BlB,QAAAA,OAAO,aAAMiB,KAAK,CAACE,aAAN,CAAoBzB,KAA1B,yBADqB;AAE5B4B,QAAAA,IAAI,EAAE;AAFsB,OAA9B;AAID;;AACD9B,IAAAA,YAAY,CAAC;AACX,OAACyB,KAAK,CAACE,aAAN,CAAoBD,IAArB,GAA4BD,KAAK,CAACE,aAAN,CAAoBzB,KADrC;AAEX,OAACzB,OAAD,GAAW;AAFA,KAAD,CAAZ;AAKA4B,IAAAA,qBAAqB,CAACuB,qBAAD,CAArB;AACD,GAtBD;;AAwBA,MAAML,eAAe,GAAG,MAAMtC,GAAG,CAAC8C,WAAJ,CAAgBR,eAAhB,EAA9B;;AAEA,MAAMS,oBAAoB,GACxBpC,MAAM,CAAC/B,OAAP,CAAeoE,IAAf,GAAsBC,MAAtB,KAAiC,CAAjC,IACAC,MAAM,CAACC,IAAP,CAAYhC,kBAAZ,EAAgC8B,MAAhC,GAAyC,CAF3C;AAIA,MAAMG,kBAAkB,GACtBL,oBAAoB,IAAIpC,MAAM,CAAC9B,MAAP,CAAcmE,IAAd,GAAqBC,MAArB,KAAgC,CAAxD,IAA6DzB,YAAY,EAD3E;AAGA,MAAM6B,mBAAmB,GAAG1C,MAAM,CAAC/B,OAAP,CAAeoE,IAAf,GAAsBC,MAAtB,KAAiC,CAA7D;AAEA,MAAMK,mBAAmB,GACvBP,oBAAoB,IAAI,CAACvB,YAAY,EAArC,IAA2Cc,eAAe,EAD5D;;AAGA,MAAMiB,WAAW;AAAA,kCAAG,WAAOrB,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACsB,cAAF;;AACA,UAAInE,cAAJ,EAAoB;AAElBc,QAAAA,YAAY,CAAC2B,OAAb,CAAqB5D,YAArB,EAAmCoC,IAAI,CAACyB,SAAL,CAAe1C,cAAf,CAAnC;AACD;;AAED,YAAMW,GAAG,CAAC8C,WAAJ,CAAgBW,KAAhB,EAAN;AACD,KARgB;;AAAA,oBAAXF,WAAW;AAAA;AAAA;AAAA,KAAjB;;AAUA,SACE,oBAAC,aAAD;AAAe,IAAA,GAAG,EAAC;AAAnB,KACE,oBAAC,YAAD,QAAenE,KAAf,CADF,EAEE,oBAAC,QAAD;AAAU,IAAA,QAAQ,EAAC;AAAnB,oHAFF,EAME,oBAAC,UAAD;AACE,IAAA,MAAM,EAAEuB,MAAM,CAAClB,YAAD,CADhB;AAEE,IAAA,cAAc,EAAE,MAAM4B,aAAa,CAACV,MAAM,CAAClB,YAAD,CAAP,EAAuB,EAAvB,CAFrC;AAGE,IAAA,OAAO,EAAEkB,MAAM,CAACjB,YAAD,CAAN,KAAyB;AAHpC,KAKGiB,MAAM,CAACjB,YAAD,CALT,CANF,EAaE,oBAAC,aAAD;AACE,IAAA,OAAO,EAAC,0BADV;AAEE,IAAA,EAAE,EAAC,eAFL;AAGE,IAAA,OAAO,EAAE,KAHX;AAIE,IAAA,WAAW,EAAE,CAAC4C,eAAe;AAJ/B,KAME,oBAAC,aAAD;AAAe,IAAA,GAAG,EAAC,IAAnB;AAAwB,IAAA,EAAE,EAAC,IAA3B;AAAgC,IAAA,EAAE,EAAC;AAAnC,KACE,oBAAC,IAAD;AAAM,IAAA,kBAAkB,EAAEnB;AAA1B,KACE,oBAAC,QAAD;AAAU,IAAA,MAAM,EAAC;AAAjB,KACE,oBAAC,SAAD;AACE,IAAA,QAAQ,MADV;AAEE,IAAA,KAAK,EAAC,gBAFR;AAGE,IAAA,WAAW,EAAC,6CAHd;AAIE,IAAA,IAAI,EAAE5B,QAJR;AAKE,IAAA,KAAK,EAAEoB,MAAM,CAACpB,QAAD,CALf;AAME,IAAA,QAAQ,EAAEgD;AANZ,IADF,EASE,oBAAC,SAAD;AACE,IAAA,KAAK,EAAC,kBADR;AAEE,IAAA,WAAW,EAAC,4BAFd;AAGE,IAAA,IAAI,EAAE/C,OAHR;AAIE,IAAA,KAAK,EAAEmB,MAAM,CAACnB,OAAD,CAJf;AAKE,IAAA,QAAQ,EAAE;AALZ,IATF,CADF,CADF,EAoBE,oBAAC,SAAD;AAAW,IAAA,QAAQ,EAAC;AAApB,4DACsD,GADtD,EAEE,oBAAC,IAAD;AACE,IAAA,IAAI,EAAC,mGADP;AAEE,IAAA,MAAM,EAAC;AAFT,2BAFF,MApBF,EA8BE,oBAAC,QAAD;AAAU,IAAA,GAAG,EAAC,WAAd;AAA0B,IAAA,QAAQ,EAAC,MAAnC;AAA0C,IAAA,IAAI,EAAEI;AAAhD,IA9BF,EA+BE,oBAAC,KAAD,QACE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAC;AAAjB,KACE,oBAAC,iBAAD;AACE,IAAA,OAAO,EAAEwC,WADX;AAEE,IAAA,QAAQ,EAAEiB;AAFZ,aADF,CADF,EASE,oBAAC,OAAD;AAAS,IAAA,OAAO,mBAAY1C,MAAM,CAACpB,QAAD,CAAlB;AAAhB,KACE,oBAAC,iBAAD;AACE,IAAA,QAAQ,EAAEwD,oBADZ;AAEE,IAAA,OAAO,EAAEZ,YAFX;AAGE,IAAA,EAAE,EAAC;AAHL,cADF,CATF,EAkBE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAC;AAAjB,KACE,oBAAC,MAAD;AACE,IAAA,QAAQ,EAAEiB,kBADZ;AAEE,IAAA,OAAO,EAAEnB,UAFX;AAGE,IAAA,EAAE,EAAC;AAHL,YADF,CAlBF,CA/BF,CANF,CAbF,EAgFE,oBAAC,OAAD;AAAS,IAAA,UAAU,EAAC;AAApB,IAhFF,EAiFE,oBAAC,aAAD;AACE,IAAA,OAAO,EAAC,sBADV;AAEE,IAAA,OAAO,EAAE,KAFX;AAGE,IAAA,EAAE,EAAC,eAHL;AAIE,IAAA,WAAW,EAAE,CAACK,eAAe;AAJ/B,KAME,oBAAC,aAAD;AAAe,IAAA,EAAE,EAAC,IAAlB;AAAuB,IAAA,EAAE,EAAC;AAA1B,KACGA,eAAe,KACd,oBAAC,QAAD,iEADc,GAIZd,YAAY,KACd,0CACE,oBAAC,QAAD,QAAWnD,YAAX,CADF,CADc,GAKd,oBAAC,QAAD,yEAVJ,EAcE,oBAAC,OAAD;AACE,IAAA,OAAO,qBAAcsC,MAAM,CAACnB,OAAD,CAApB;AADT,KAGE,oBAAC,MAAD;AAAQ,IAAA,OAAO,EAAE+D,WAAjB;AAA8B,IAAA,QAAQ,EAAED;AAAxC,aAHF,CAdF,CANF,CAjFF,CADF;AAiHD,CAtSM","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 { BaseSyntheticEvent, Dispatch, FC, FormEvent } from 'react'\nimport React, { useState, useEffect } from 'react'\nimport type { ValidationMessages, MessageBarIntent } from '@looker/components'\nimport {\n Button,\n ButtonTransparent,\n Divider,\n Fieldset,\n FieldText,\n Form,\n MessageBar,\n Paragraph,\n Link,\n Space,\n SpaceVertical,\n Tooltip,\n} from '@looker/components'\nimport { CodeCopy } from '@looker/code-editor'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport type { RunItSetter, RunItValues } from '../..'\nimport {\n CollapserCard,\n RunItFormKey,\n RunItHeading,\n DarkSpan,\n readyToLogin,\n RunItNoConfig,\n} from '../..'\nimport type { ILoadedSpecs } from './configUtils'\nimport {\n RunItConfigKey,\n validateUrl,\n loadSpecsFromVersions,\n} from './configUtils'\n\nconst POSITIVE: MessageBarIntent = 'positive'\n\ninterface IFieldValues extends ILoadedSpecs {\n fetchIntent: MessageBarIntent\n}\n\nconst defaultFieldValues: IFieldValues = {\n baseUrl: '',\n webUrl: '',\n /** not currently used but declared for property compatibility for ILoadedSpecs */\n headless: false,\n specs: {},\n fetchResult: '',\n fetchIntent: POSITIVE,\n}\n\ninterface ConfigFormProps {\n setVersionsUrl: RunItSetter\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** Title for the config form */\n title?: string\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n}\n\nexport const ConfigForm: FC<ConfigFormProps> = ({\n setVersionsUrl,\n title,\n requestContent,\n setHasConfig,\n}) => {\n const BASE_URL = 'baseUrl'\n const WEB_URL = 'webUrl'\n const FETCH_INTENT = 'fetchIntent'\n const FETCH_RESULT = 'fetchResult'\n const CRITICAL: MessageBarIntent = 'critical'\n const appConfig = `{\n \"client_guid\": \"looker.api-explorer\",\n \"redirect_uri\": \"${(window as any).location.origin}/oauth\",\n \"display_name\": \"CORS API Explorer\",\n \"description\": \"Looker API Explorer using CORS\",\n \"enabled\": true\n}\n`\n const sdk = getEnvAdaptor().sdk\n // See https://codesandbox.io/s/youthful-surf-0g27j?file=/src/index.tsx for a prototype from Luke\n // TODO see about useReducer to clean this up a bit more\n title = title || 'RunIt Configuration'\n\n const getConfig = () => {\n // TODO: This is temporary until config settings are available in redux.\n // get configuration from storage, or default it\n const data = localStorage.getItem(RunItConfigKey)\n const result = data ? JSON.parse(data) : { base_url: '', looker_url: '' } // TODO why is RunItNoConfig undefined here?\n return result\n }\n\n const config = getConfig()\n const [fields, setFields] = useState<IFieldValues>(defaultFieldValues)\n const [saved, setSaved] = useState<RunItValues>(config)\n\n const updateFields = (\n nameOrValues: string | Partial<IFieldValues>,\n value = ''\n ) => {\n if (typeof nameOrValues === 'string') {\n setFields((previousFields) => {\n return { ...previousFields, ...{ [nameOrValues]: value } }\n })\n } else {\n setFields((previousFields) => {\n return { ...previousFields, ...nameOrValues }\n })\n }\n }\n\n useEffect(() => {\n const data = getConfig()\n const { base_url, looker_url } = data\n setSaved(data)\n updateFields({\n [BASE_URL]: base_url,\n [WEB_URL]: looker_url,\n [FETCH_INTENT]:\n base_url !== '' && looker_url !== '' ? POSITIVE : CRITICAL,\n })\n }, [])\n\n const [validationMessages, setValidationMessages] =\n useState<ValidationMessages>({})\n\n const updateMessage = (intent: MessageBarIntent, message: string) => {\n updateFields({ [FETCH_RESULT]: message, [FETCH_INTENT]: intent })\n }\n\n const isConfigured = () => {\n return (\n saved !== RunItNoConfig &&\n fields[BASE_URL] === saved.base_url &&\n fields[WEB_URL] === saved.looker_url\n )\n }\n\n const fetchError = (message: string) => {\n updateFields(WEB_URL, '')\n updateMessage(CRITICAL, message)\n }\n\n const updateForm = async (_e: BaseSyntheticEvent, save: boolean) => {\n // e.preventDefault()\n try {\n updateMessage('inform', '')\n const versionsUrl = `${fields.baseUrl}/versions`\n const { webUrl, baseUrl } = await loadSpecsFromVersions(versionsUrl)\n if (!baseUrl || !webUrl) {\n fetchError('Invalid server configuration')\n } else {\n updateFields({ [BASE_URL]: baseUrl, [WEB_URL]: webUrl })\n updateMessage(POSITIVE, 'Configuration is valid')\n if (save) {\n const data = { base_url: baseUrl, looker_url: webUrl }\n // TODO: replace when redux is introduced to run it\n localStorage.setItem(RunItConfigKey, JSON.stringify(data))\n if (setHasConfig) setHasConfig(true)\n setSaved(data)\n setVersionsUrl(versionsUrl)\n updateMessage(POSITIVE, `Saved ${webUrl} as OAuth server`)\n }\n }\n } catch (err: any) {\n fetchError(err.message)\n }\n }\n\n const handleSave = async (e: BaseSyntheticEvent) => {\n await updateForm(e, true)\n }\n\n const handleVerify = async (e: BaseSyntheticEvent) => {\n await updateForm(e, false)\n }\n\n const handleClear = async (_e: BaseSyntheticEvent) => {\n // TODO: replace when redux is introduced to run it\n localStorage.removeItem(RunItConfigKey)\n updateFields({\n [BASE_URL]: '',\n [WEB_URL]: '',\n [FETCH_INTENT]: CRITICAL,\n [FETCH_RESULT]: '',\n })\n setSaved(RunItNoConfig)\n if (setHasConfig) setHasConfig(false)\n if (isAuthenticated()) {\n updateMessage('warn', 'Please reload the browser page to log out')\n }\n }\n\n const handleUrlChange = (event: FormEvent<HTMLInputElement>) => {\n const name = event.currentTarget.name\n\n const newValidationMessages = { ...validationMessages }\n\n const url = validateUrl(event.currentTarget.value)\n if (url) {\n delete newValidationMessages[name]\n // Update URL if it's been cleaned up\n event.currentTarget.value = url\n } else {\n newValidationMessages[name] = {\n message: `'${event.currentTarget.value}' is not a valid url`,\n type: 'error',\n }\n }\n updateFields({\n [event.currentTarget.name]: event.currentTarget.value,\n [WEB_URL]: '',\n })\n\n setValidationMessages(newValidationMessages)\n }\n\n const isAuthenticated = () => sdk.authSession.isAuthenticated()\n\n const verifyButtonDisabled =\n fields.baseUrl.trim().length === 0 ||\n Object.keys(validationMessages).length > 0\n\n const saveButtonDisabled =\n verifyButtonDisabled || fields.webUrl.trim().length === 0 || isConfigured()\n\n const clearButtonDisabled = fields.baseUrl.trim().length === 0\n\n const loginButtonDisabled =\n verifyButtonDisabled || !isConfigured() || isAuthenticated()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n // TODO: Replace when redux is introduced to run it\n localStorage.setItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await sdk.authSession.login()\n }\n\n return (\n <SpaceVertical gap=\"u2\">\n <RunItHeading>{title}</RunItHeading>\n <DarkSpan fontSize=\"small\">\n To configure RunIt mode, you need to supply your API server URL, then\n authenticate into your Looker Instance\n </DarkSpan>\n <MessageBar\n intent={fields[FETCH_INTENT]}\n onPrimaryClick={() => updateMessage(fields[FETCH_INTENT], '')}\n visible={fields[FETCH_RESULT] !== ''}\n >\n {fields[FETCH_RESULT]}\n </MessageBar>\n <CollapserCard\n heading=\"1. Supply API Server URL\"\n id=\"server_config\"\n divider={false}\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical gap=\"u2\" pt=\"u3\" px=\"u6\">\n <Form validationMessages={validationMessages}>\n <Fieldset legend=\"Server locations\">\n <FieldText\n required\n label=\"API server URL\"\n placeholder=\"typically https://myserver.looker.com:19999\"\n name={BASE_URL}\n value={fields[BASE_URL]}\n onChange={handleUrlChange}\n />\n <FieldText\n label=\"OAuth server URL\"\n placeholder=\"Click 'Verify' to retrieve\"\n name={WEB_URL}\n value={fields[WEB_URL]}\n disabled={true}\n />\n </Fieldset>\n </Form>\n <Paragraph fontSize=\"small\">\n The following configuration can be used to create a{' '}\n <Link\n href=\"https://github.com/looker-open-source/sdk-codegen/blob/main/docs/cors.md#reference-implementation\"\n target=\"_blank\"\n >\n Looker OAuth client\n </Link>\n .\n </Paragraph>\n <CodeCopy key=\"appConfig\" language=\"json\" code={appConfig} />\n <Space>\n <Tooltip content=\"Clear the configuration values\">\n <ButtonTransparent\n onClick={handleClear}\n disabled={clearButtonDisabled}\n >\n Clear\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content={`Verify ${fields[BASE_URL]}`}>\n <ButtonTransparent\n disabled={verifyButtonDisabled}\n onClick={handleVerify}\n mr=\"small\"\n >\n Verify\n </ButtonTransparent>\n </Tooltip>\n <Tooltip content=\"Save the configuration for this browser\">\n <Button\n disabled={saveButtonDisabled}\n onClick={handleSave}\n mr=\"small\"\n >\n Save\n </Button>\n </Tooltip>\n </Space>\n </SpaceVertical>\n </CollapserCard>\n <Divider appearance=\"light\" />\n <CollapserCard\n heading=\"2. Login to instance\"\n divider={false}\n id=\"login_section\"\n defaultOpen={!isAuthenticated()}\n >\n <SpaceVertical pt=\"u3\" px=\"u6\">\n {isAuthenticated() ? (\n <DarkSpan>\n You are already logged in. Reload the page to log out.\n </DarkSpan>\n ) : isConfigured() ? (\n <>\n <DarkSpan>{readyToLogin}</DarkSpan>\n </>\n ) : (\n <DarkSpan>\n You will be able to login after you Verify your API Server URL\n </DarkSpan>\n )}\n <Tooltip\n content={`Login to ${fields[WEB_URL]} using OAuth to enable RunIt`}\n >\n <Button onClick={handleLogin} disabled={loginButtonDisabled}>\n Login\n </Button>\n </Tooltip>\n </SpaceVertical>\n </CollapserCard>\n </SpaceVertical>\n )\n}\n"],"file":"ConfigForm.js"}
|
@@ -11,7 +11,7 @@ function _asyncToGenerator(fn) { return function () { var self = this, args = ar
|
|
11
11
|
import { ApiModel, getSpecsFromVersions, upgradeSpecObject } from '@looker/sdk-codegen';
|
12
12
|
import { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl';
|
13
13
|
import { api_spec } from '@looker/sdk';
|
14
|
-
import {
|
14
|
+
import { getEnvAdaptor } from '@looker/extension-utils';
|
15
15
|
export var RunItConfigKey = 'RunItConfig';
|
16
16
|
export var RunItFormKey = 'RunItForm';
|
17
17
|
export var RunItNoConfig = {
|
@@ -73,7 +73,8 @@ var apiSpecBits = spec => {
|
|
73
73
|
};
|
74
74
|
|
75
75
|
export var funFetch = (version, name) => {
|
76
|
-
|
76
|
+
var sdk = getEnvAdaptor().sdk;
|
77
|
+
return sdk.ok(api_spec(sdk, version, name));
|
77
78
|
};
|
78
79
|
export var specUrlFetch = function () {
|
79
80
|
var _ref2 = _asyncToGenerator(function* (url) {
|
@@ -177,10 +178,11 @@ export var fallbackFetch = function () {
|
|
177
178
|
}
|
178
179
|
|
179
180
|
if (!api) {
|
180
|
-
var
|
181
|
+
var sdk = getEnvAdaptor().sdk;
|
182
|
+
var authed = sdk.authSession.isAuthenticated();
|
181
183
|
|
182
184
|
if (!authed) {
|
183
|
-
yield
|
185
|
+
yield sdk.authSession.login();
|
184
186
|
}
|
185
187
|
|
186
188
|
api = yield sdkSpecFetch(spec, fetcher);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/ConfigForm/configUtils.ts"],"names":["ApiModel","getSpecsFromVersions","upgradeSpecObject","BrowserTransport","DefaultSettings","api_spec","runItSDK","RunItConfigKey","RunItFormKey","RunItNoConfig","base_url","looker_url","validateUrl","url","result","URL","endsWith","origin","makeApi","content","json","JSON","parse","fromJson","getUrl","settings","verify_ssl","xp","response","rawRequest","body","fullify","uri","baseUrl","match","toString","apiSpecBits","spec","specURL","split","slice","funFetch","version","name","ok","specUrlFetch","error","undefined","loadSpecsFromVersions","defer","fetchResult","specs","webUrl","headless","versions","window","location","api_server_url","web_server_url","fetchSpec","api","fallbackFetch","e","message","sdkSpecFetch","fetcher","console","authed","authSession","isAuthenticated","login"],"mappings":";;;;;;;;;;AA2BA,SACEA,QADF,EAEEC,oBAFF,EAGEC,iBAHF,QAIO,qBAJP;AAKA,SAASC,gBAAT,EAA2BC,eAA3B,QAAkD,iBAAlD;AACA,SAASC,QAAT,QAAyB,aAAzB;AAEA,SAASC,QAAT,QAAyB,OAAzB;AAGA,OAAO,IAAMC,cAAc,GAAG,aAAvB;AACP,OAAO,IAAMC,YAAY,GAAG,WAArB;AACP,OAAO,IAAMC,aAAa,GAAG;AAAEC,EAAAA,QAAQ,EAAE,EAAZ;AAAgBC,EAAAA,UAAU,EAAE;AAA5B,CAAtB;AAkDP,OAAO,IAAMC,WAAW,GAAIC,GAAD,IAAyB;AAClD,MAAI;AACF,QAAMC,MAAM,GAAG,IAAIC,GAAJ,CAAQF,GAAR,CAAf;AACA,QAAIA,GAAG,CAACG,QAAJ,CAAa,GAAb,CAAJ,EAAuB,OAAOH,GAAP;AACvB,WAAOC,MAAM,CAACG,MAAd;AACD,GAJD,CAIE,gBAAM;AACN,WAAO,EAAP;AACD;AACF,CARM;;AAcP,IAAMC,OAAO,GAAIC,OAAD,IAAmC;AACjD,MAAIC,IAAJ;;AACA,MAAI,OAAOD,OAAP,KAAmB,QAAvB,EAAiC;AAC/BC,IAAAA,IAAI,GAAGC,IAAI,CAACC,KAAL,CAAWH,OAAX,CAAP;AACD,GAFD,MAEO;AACLC,IAAAA,IAAI,GAAGD,OAAP;AACD;;AACDC,EAAAA,IAAI,GAAGlB,iBAAiB,CAACkB,IAAD,CAAxB;AACA,SAAOpB,QAAQ,CAACuB,QAAT,CAAkBH,IAAlB,CAAP;AACD,CATD;;AAeA,OAAO,IAAMI,MAAM;AAAA,+BAAG,WAAOX,GAAP,EAAsD;AAC1E,QAAMY,QAAQ,mCACTrB,eAAe,EADN,GAET;AAAEM,MAAAA,QAAQ,EAAEG,GAAZ;AAAiBa,MAAAA,UAAU,EAAE;AAA7B,KAFS,CAAd;;AAIA,QAAMC,EAAE,GAAG,IAAIxB,gBAAJ,CAAqBsB,QAArB,CAAX;AACA,QAAMG,QAAQ,SAASD,EAAE,CAACE,UAAH,CAAc,KAAd,EAAqBhB,GAArB,CAAvB;AACA,WAAOe,QAAQ,CAACE,IAAhB;AACD,GARkB;;AAAA,kBAANN,MAAM;AAAA;AAAA;AAAA,GAAZ;AAeP,OAAO,IAAMO,OAAO,GAAG,CAACC,GAAD,EAAcC,OAAd,KAA0C;AAC/D,MAAID,GAAG,CAACE,KAAJ,CAAU,UAAV,CAAJ,EAA2B;AACzB,WAAOF,GAAP;AACD;;AACD,MAAMnB,GAAG,GAAG,IAAIE,GAAJ,CAAQiB,GAAR,EAAaC,OAAb,CAAZ;AACA,SAAOpB,GAAG,CAACsB,QAAJ,EAAP;AACD,CANM;;AAWP,IAAMC,WAAW,GAAIC,IAAD;AAAA;;AAAA,SAClB,kBAAAA,IAAI,CAACC,OAAL,gEAAcC,KAAd,CAAoB,GAApB,EAAyBC,KAAzB,CAA+B,CAAC,CAAhC,MAAsC,EADpB;AAAA,CAApB;;AAQA,OAAO,IAAMC,QAAQ,GAAG,CAACC,OAAD,EAAkBC,IAAlB,KAAoD;AAC1E,SAAOrC,QAAQ,CAACsC,EAAT,CAAYvC,QAAQ,CAACC,QAAD,EAAWoC,OAAX,EAAoBC,IAApB,CAApB,CAAP;AACD,CAFM;AAQP,OAAO,IAAME,YAAY;AAAA,gCAAG,WAAOhC,GAAP,EAA4C;AACtE,QAAI;AACF,UAAMM,OAAO,SAASK,MAAM,CAACX,GAAD,CAA5B;AACA,aAAOK,OAAO,CAACC,OAAD,CAAd;AACD,KAHD,CAGE,OAAO2B,KAAP,EAAc;AACd,aAAOC,SAAP;AACD;AACF,GAPwB;;AAAA,kBAAZF,YAAY;AAAA;AAAA;AAAA,GAAlB;AAkBP,OAAO,IAAMG,qBAAqB;AAAA,gCAAG,WACnCnC,GADmC,EAIT;AAAA,QAF1BM,OAE0B,uEAFkB,EAElB;AAAA,QAD1B8B,KAC0B,uEADlB,IACkB;AAC1B,QAAIC,WAAW,GAAG,EAAlB;AACA,QAAIC,KAAe,GAAG,EAAtB;AACA,QAAIlB,OAAO,GAAG,EAAd;AACA,QAAImB,MAAM,GAAG,EAAb;AACA,QAAIC,QAAQ,GAAG,KAAf;;AACA,QAAI;AACF,UAAI,CAAClC,OAAL,EAAc;AACZA,QAAAA,OAAO,SAASK,MAAM,CAACX,GAAD,CAAtB;AACD;;AACD,UAAMyC,QAAQ,GACZ,OAAOnC,OAAP,KAAmB,QAAnB,GAA8BE,IAAI,CAACC,KAAL,CAAWH,OAAX,CAA9B,GAAoDA,OADtD;AAGA,UAAMF,MAAM,GAAIsC,MAAD,CAAgBC,QAAhB,CAAyBvC,MAAxC;AACAgB,MAAAA,OAAO,GAAGqB,QAAQ,CAACG,cAAnB;AACAL,MAAAA,MAAM,GAAGE,QAAQ,CAACI,cAAlB;;AACA,UAAIJ,QAAQ,CAACD,QAAT,KAAsBN,SAA1B,EAAqC;AACnCM,QAAAA,QAAQ,GAAGC,QAAQ,CAACD,QAApB;AACD;;AACD,UAAMM,SAAS;AAAA,sCAAG,WAAOtB,IAAP,EAA0B;AAC1C,cAAIA,IAAI,CAACC,OAAT,EAAkB;AAChBD,YAAAA,IAAI,CAACC,OAAL,GAAeP,OAAO,CAACM,IAAI,CAACC,OAAN,EAAerB,MAAf,CAAtB;;AACA,gBAAI,CAACgC,KAAL,EAAY;AACVZ,cAAAA,IAAI,CAACuB,GAAL,SAAiBC,aAAa,CAACxB,IAAD,EAAOI,QAAP,CAA9B;AACD;AACF;;AACD,iBAAOJ,IAAI,CAACuB,GAAZ;AACD,SARc;;AAAA,wBAATD,SAAS;AAAA;AAAA;AAAA,SAAf;;AASAR,MAAAA,KAAK,SAASlD,oBAAoB,CAACqD,QAAD,EAAWK,SAAX,CAAlC;AACD,KAvBD,CAuBE,OAAOG,CAAP,EAAe;AACfZ,MAAAA,WAAW,GAAGY,CAAC,CAACC,OAAhB;AACD;;AAED,WAAO;AACL9B,MAAAA,OADK;AAELmB,MAAAA,MAFK;AAGLD,MAAAA,KAHK;AAILE,MAAAA,QAJK;AAKLH,MAAAA,WAAW,EAAEA;AALR,KAAP;AAOD,GA5CiC;;AAAA,kBAArBF,qBAAqB;AAAA;AAAA;AAAA,GAA3B;AAsDP,OAAO,IAAMgB,YAAY;AAAA,gCAAG,WAC1B3B,IAD0B,EAE1B4B,OAF0B,EAGF;AACxB,QAAI5B,IAAI,CAACuB,GAAT,EAAc,OAAOvB,IAAI,CAACuB,GAAZ;AACd,QAAI,CAACvB,IAAI,CAACC,OAAV,EAAmB,OAAOS,SAAP;AACnB,QAAM,CAACL,OAAD,EAAUC,IAAV,IAAkBP,WAAW,CAACC,IAAD,CAAnC;AACA,QAAMlB,OAAO,SAAS8C,OAAO,CAACvB,OAAD,EAAUC,IAAV,CAA7B;AACA,WAAOzB,OAAO,CAACC,OAAD,CAAd;AACD,GATwB;;AAAA,kBAAZ6C,YAAY;AAAA;AAAA;AAAA,GAAlB;AAgBP,OAAO,IAAMH,aAAa;AAAA,gCAAG,WAC3BxB,IAD2B,EAE3B4B,OAF2B,EAGH;AACxB,QAAI5B,IAAI,CAACuB,GAAT,EAAc,OAAOvB,IAAI,CAACuB,GAAZ;AACd,QAAI,CAACvB,IAAI,CAACC,OAAV,EAAmB,OAAOS,SAAP;AACnB,QAAIa,GAAJ;;AACA,QAAI;AACFA,MAAAA,GAAG,SAASf,YAAY,CAACR,IAAI,CAACC,OAAN,CAAxB;AACD,KAFD,CAEE,OAAOQ,KAAP,EAAc;AACdoB,MAAAA,OAAO,CAACpB,KAAR,CAAc;AAAEA,QAAAA;AAAF,OAAd;AACD;;AACD,QAAI,CAACc,GAAL,EAAU;AACR,UAAMO,MAAM,GAAG7D,QAAQ,CAAC8D,WAAT,CAAqBC,eAArB,EAAf;;AACA,UAAI,CAACF,MAAL,EAAa;AACX,cAAM7D,QAAQ,CAAC8D,WAAT,CAAqBE,KAArB,EAAN;AACD;;AACDV,MAAAA,GAAG,SAASI,YAAY,CAAC3B,IAAD,EAAO4B,OAAP,CAAxB;AACD;;AACD,WAAOL,GAAP;AACD,GApByB;;AAAA,kBAAbC,aAAa;AAAA;AAAA;AAAA,GAAnB","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 { ILookerVersions, SpecItem, SpecList } from '@looker/sdk-codegen'\nimport {\n ApiModel,\n getSpecsFromVersions,\n upgradeSpecObject,\n} from '@looker/sdk-codegen'\nimport { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl'\nimport { api_spec } from '@looker/sdk'\nimport type { RunItValues } from '../..'\nimport { runItSDK } from '../..'\n\nexport type StorageLocation = 'session' | 'local'\nexport const RunItConfigKey = 'RunItConfig'\nexport const RunItFormKey = 'RunItForm'\nexport const RunItNoConfig = { base_url: '', looker_url: '' }\n\n/** Object returned from storage service */\nexport interface IStorageValue {\n /** Location of the stored object */\n location: StorageLocation\n /** Stored string representation of the value (usually JSON) */\n value: string\n}\n\n/** function to retrieve a spec based on version and name */\nexport type ApiSpecFetcher = (\n version: string,\n name: string\n) => Promise<string | RunItValues>\n\n/** Either the spec is parsed or it's undefined */\nexport type ParsedSpec = ApiModel | undefined\n\n/** service abstraction for extension and browser based usage */\nexport interface RunItConfigurator {\n getStorage: (key: string, defaultValue?: string) => IStorageValue\n setStorage(key: string, value: string, location: 'local' | 'session'): string\n removeStorage(key: string): void\n}\n\n/** Processed specifications */\nexport interface ILoadedSpecs {\n /** API server url */\n baseUrl: string\n /** Web server url */\n webUrl: string\n /** should APIX run headless? */\n headless: boolean\n /** loaded specifications */\n specs: SpecList\n /** communication errors */\n fetchResult: string\n}\n\n/** Extends versions payload with headless toggle for API Explorer */\nexport interface IAPIXConfig extends ILookerVersions {\n headless?: boolean\n}\n\n/**\n * Validates URL and standardizes it\n * @param url to validate\n * @returns the standardized url.origin if it's valid, or an empty string if it's not\n */\nexport const validateUrl = (url: string): string => {\n try {\n const result = new URL(url)\n if (url.endsWith(':')) return url\n return result.origin\n } catch {\n return ''\n }\n}\n\n/**\n * Convert content into an ApiModel\n * @param content to convert\n */\nconst makeApi = (content: string | RunItValues) => {\n let json\n if (typeof content === 'string') {\n json = JSON.parse(content)\n } else {\n json = content\n }\n json = upgradeSpecObject(json)\n return ApiModel.fromJson(json)\n}\n\n/**\n * Use the browser transport to GET a url\n * @param url to fetch\n */\nexport const getUrl = async (url: string): Promise<string | RunItValues> => {\n const settings = {\n ...DefaultSettings(),\n ...{ base_url: url, verify_ssl: false },\n }\n const xp = new BrowserTransport(settings)\n const response = await xp.rawRequest('GET', url)\n return response.body\n}\n\n/**\n * Ensure the URI is a full URL\n * @param uri possible relative path\n * @param baseUrl base url for qualifying full path\n */\nexport const fullify = (uri: string, baseUrl: string): string => {\n if (uri.match(/^https?:/)) {\n return uri\n }\n const url = new URL(uri, baseUrl)\n return url.toString()\n}\n/**\n * parse spec url into version and name for api_spec cccall\n * @param spec to parse\n */\nconst apiSpecBits = (spec: SpecItem): string[] =>\n spec.specURL?.split('/').slice(-2) || []\n\n/**\n * Use the functional api_spec fetch\n * @param version to retrieve\n * @param name to retrieve\n */\nexport const funFetch = (version: string, name: string): Promise<string> => {\n return runItSDK.ok(api_spec(runItSDK, version, name))\n}\n\n/**\n * try to fetch a spec by URL, trap any errors and return undefined\n * @param url to convert to an API spec\n */\nexport const specUrlFetch = async (url: string): Promise<ParsedSpec> => {\n try {\n const content = await getUrl(url)\n return makeApi(content)\n } catch (error) {\n return undefined\n }\n}\n\n/**\n * Load versions payload and retrieve all supported specs\n *\n * The versions payload should match the structure of Looker's /versions endpoint\n *\n * @param url that has an unauthenticated versions payload. For Looker, this is <LookerHostName>/versions\n * @param content content of versions payload that may already be assigned\n * @param defer true to defer fetching and parsing the spec. Defaults to true.\n */\nexport const loadSpecsFromVersions = async (\n url: string,\n content: string | Record<string, unknown> = '',\n defer = true\n): Promise<ILoadedSpecs> => {\n let fetchResult = ''\n let specs: SpecList = {}\n let baseUrl = ''\n let webUrl = ''\n let headless = false\n try {\n if (!content) {\n content = await getUrl(url)\n }\n const versions = (\n typeof content === 'string' ? JSON.parse(content) : content\n ) as IAPIXConfig\n const origin = (window as any).location.origin\n baseUrl = versions.api_server_url\n webUrl = versions.web_server_url\n if (versions.headless !== undefined) {\n headless = versions.headless\n }\n const fetchSpec = async (spec: SpecItem) => {\n if (spec.specURL) {\n spec.specURL = fullify(spec.specURL, origin)\n if (!defer) {\n spec.api = await fallbackFetch(spec, funFetch)\n }\n }\n return spec.api\n }\n specs = await getSpecsFromVersions(versions, fetchSpec)\n } catch (e: any) {\n fetchResult = e.message\n }\n\n return {\n baseUrl,\n webUrl,\n specs,\n headless,\n fetchResult: fetchResult,\n }\n}\n\n/**\n * fetch and compile an API specification to an ApiModel if it's not already available\n *\n * **NOTE**: This uses Looker API 4.0 to fetch the specification so fetch works with CORS\n *\n * @param spec to fetch and compile\n * @param fetcher function to retrieve API spec content\n */\nexport const sdkSpecFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n const [version, name] = apiSpecBits(spec)\n const content = await fetcher(version, name)\n return makeApi(content)\n}\n\n/** Attempt to retrieve spec by URL, then api_spec SDK call\n *\n * @param spec to fetch\n * @param fetcher function to retrieve and parse spec\n */\nexport const fallbackFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n let api: ParsedSpec\n try {\n api = await specUrlFetch(spec.specURL)\n } catch (error) {\n console.error({ error })\n }\n if (!api) {\n const authed = runItSDK.authSession.isAuthenticated()\n if (!authed) {\n await runItSDK.authSession.login()\n }\n api = await sdkSpecFetch(spec, fetcher)\n }\n return api\n}\n"],"file":"configUtils.js"}
|
1
|
+
{"version":3,"sources":["../../../../src/components/ConfigForm/configUtils.ts"],"names":["ApiModel","getSpecsFromVersions","upgradeSpecObject","BrowserTransport","DefaultSettings","api_spec","getEnvAdaptor","RunItConfigKey","RunItFormKey","RunItNoConfig","base_url","looker_url","validateUrl","url","result","URL","endsWith","origin","makeApi","content","json","JSON","parse","fromJson","getUrl","settings","verify_ssl","xp","response","rawRequest","body","fullify","uri","baseUrl","match","toString","apiSpecBits","spec","specURL","split","slice","funFetch","version","name","sdk","ok","specUrlFetch","error","undefined","loadSpecsFromVersions","defer","fetchResult","specs","webUrl","headless","versions","window","location","api_server_url","web_server_url","fetchSpec","api","fallbackFetch","e","message","sdkSpecFetch","fetcher","console","authed","authSession","isAuthenticated","login"],"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 { ILookerVersions, SpecItem, SpecList } from '@looker/sdk-codegen'\nimport {\n ApiModel,\n getSpecsFromVersions,\n upgradeSpecObject,\n} from '@looker/sdk-codegen'\nimport { BrowserTransport, DefaultSettings } from '@looker/sdk-rtl'\nimport { api_spec } from '@looker/sdk'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport type { RunItValues } from '../..'\n\nexport type StorageLocation = 'session' | 'local'\nexport const RunItConfigKey = 'RunItConfig'\nexport const RunItFormKey = 'RunItForm'\nexport const RunItNoConfig = { base_url: '', looker_url: '' }\n\n/** Object returned from storage service */\nexport interface IStorageValue {\n /** Location of the stored object */\n location: StorageLocation\n /** Stored string representation of the value (usually JSON) */\n value: string\n}\n\n/** function to retrieve a spec based on version and name */\nexport type ApiSpecFetcher = (\n version: string,\n name: string\n) => Promise<string | RunItValues>\n\n/** Either the spec is parsed or it's undefined */\nexport type ParsedSpec = ApiModel | undefined\n\n/** service abstraction for extension and browser based usage */\nexport interface RunItConfigurator {\n getStorage: (key: string, defaultValue?: string) => IStorageValue\n setStorage(key: string, value: string, location: 'local' | 'session'): string\n removeStorage(key: string): void\n}\n\n/** Processed specifications */\nexport interface ILoadedSpecs {\n /** API server url */\n baseUrl: string\n /** Web server url */\n webUrl: string\n /** should APIX run headless? */\n headless: boolean\n /** loaded specifications */\n specs: SpecList\n /** communication errors */\n fetchResult: string\n}\n\n/** Extends versions payload with headless toggle for API Explorer */\nexport interface IAPIXConfig extends ILookerVersions {\n headless?: boolean\n}\n\n/**\n * Validates URL and standardizes it\n * @param url to validate\n * @returns the standardized url.origin if it's valid, or an empty string if it's not\n */\nexport const validateUrl = (url: string): string => {\n try {\n const result = new URL(url)\n if (url.endsWith(':')) return url\n return result.origin\n } catch {\n return ''\n }\n}\n\n/**\n * Convert content into an ApiModel\n * @param content to convert\n */\nconst makeApi = (content: string | RunItValues) => {\n let json\n if (typeof content === 'string') {\n json = JSON.parse(content)\n } else {\n json = content\n }\n json = upgradeSpecObject(json)\n return ApiModel.fromJson(json)\n}\n\n/**\n * Use the browser transport to GET a url\n * @param url to fetch\n */\nexport const getUrl = async (url: string): Promise<string | RunItValues> => {\n const settings = {\n ...DefaultSettings(),\n ...{ base_url: url, verify_ssl: false },\n }\n const xp = new BrowserTransport(settings)\n const response = await xp.rawRequest('GET', url)\n return response.body\n}\n\n/**\n * Ensure the URI is a full URL\n * @param uri possible relative path\n * @param baseUrl base url for qualifying full path\n */\nexport const fullify = (uri: string, baseUrl: string): string => {\n if (uri.match(/^https?:/)) {\n return uri\n }\n const url = new URL(uri, baseUrl)\n return url.toString()\n}\n/**\n * parse spec url into version and name for api_spec cccall\n * @param spec to parse\n */\nconst apiSpecBits = (spec: SpecItem): string[] =>\n spec.specURL?.split('/').slice(-2) || []\n\n/**\n * Use the functional api_spec fetch\n * @param version to retrieve\n * @param name to retrieve\n */\nexport const funFetch = (version: string, name: string): Promise<string> => {\n const sdk = getEnvAdaptor().sdk\n return sdk.ok(api_spec(sdk, version, name))\n}\n\n/**\n * try to fetch a spec by URL, trap any errors and return undefined\n * @param url to convert to an API spec\n */\nexport const specUrlFetch = async (url: string): Promise<ParsedSpec> => {\n try {\n const content = await getUrl(url)\n return makeApi(content)\n } catch (error) {\n return undefined\n }\n}\n\n/**\n * Load versions payload and retrieve all supported specs\n *\n * The versions payload should match the structure of Looker's /versions endpoint\n *\n * @param url that has an unauthenticated versions payload. For Looker, this is <LookerHostName>/versions\n * @param content content of versions payload that may already be assigned\n * @param defer true to defer fetching and parsing the spec. Defaults to true.\n */\nexport const loadSpecsFromVersions = async (\n url: string,\n content: string | Record<string, unknown> = '',\n defer = true\n): Promise<ILoadedSpecs> => {\n let fetchResult = ''\n let specs: SpecList = {}\n let baseUrl = ''\n let webUrl = ''\n let headless = false\n try {\n if (!content) {\n content = await getUrl(url)\n }\n const versions = (\n typeof content === 'string' ? JSON.parse(content) : content\n ) as IAPIXConfig\n const origin = (window as any).location.origin\n baseUrl = versions.api_server_url\n webUrl = versions.web_server_url\n if (versions.headless !== undefined) {\n headless = versions.headless\n }\n const fetchSpec = async (spec: SpecItem) => {\n if (spec.specURL) {\n spec.specURL = fullify(spec.specURL, origin)\n if (!defer) {\n spec.api = await fallbackFetch(spec, funFetch)\n }\n }\n return spec.api\n }\n specs = await getSpecsFromVersions(versions, fetchSpec)\n } catch (e: any) {\n fetchResult = e.message\n }\n\n return {\n baseUrl,\n webUrl,\n specs,\n headless,\n fetchResult: fetchResult,\n }\n}\n\n/**\n * fetch and compile an API specification to an ApiModel if it's not already available\n *\n * **NOTE**: This uses Looker API 4.0 to fetch the specification so fetch works with CORS\n *\n * @param spec to fetch and compile\n * @param fetcher function to retrieve API spec content\n */\nexport const sdkSpecFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n const [version, name] = apiSpecBits(spec)\n const content = await fetcher(version, name)\n return makeApi(content)\n}\n\n/** Attempt to retrieve spec by URL, then api_spec SDK call\n *\n * @param spec to fetch\n * @param fetcher function to retrieve and parse spec\n */\nexport const fallbackFetch = async (\n spec: SpecItem,\n fetcher: ApiSpecFetcher\n): Promise<ParsedSpec> => {\n if (spec.api) return spec.api\n if (!spec.specURL) return undefined\n let api: ParsedSpec\n try {\n api = await specUrlFetch(spec.specURL)\n } catch (error) {\n console.error({ error })\n }\n if (!api) {\n const sdk = getEnvAdaptor().sdk\n const authed = sdk.authSession.isAuthenticated()\n if (!authed) {\n await sdk.authSession.login()\n }\n api = await sdkSpecFetch(spec, fetcher)\n }\n return api\n}\n"],"file":"configUtils.js"}
|
@@ -4,25 +4,24 @@ function _asyncToGenerator(fn) { return function () { var self = this, args = ar
|
|
4
4
|
|
5
5
|
import React from 'react';
|
6
6
|
import { Button, Tooltip } from '@looker/components';
|
7
|
-
import {
|
7
|
+
import { getEnvAdaptor } from '@looker/extension-utils';
|
8
8
|
import { RunItFormKey } from '../ConfigForm';
|
9
9
|
export var readyToLogin = 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.';
|
10
10
|
export var LoginForm = _ref => {
|
11
11
|
var {
|
12
|
-
|
13
|
-
requestContent,
|
14
|
-
sdk = runItSDK
|
12
|
+
requestContent
|
15
13
|
} = _ref;
|
14
|
+
var adaptor = getEnvAdaptor();
|
16
15
|
|
17
16
|
var handleLogin = function () {
|
18
17
|
var _ref2 = _asyncToGenerator(function* (e) {
|
19
18
|
e.preventDefault();
|
20
19
|
|
21
20
|
if (requestContent) {
|
22
|
-
|
21
|
+
adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent));
|
23
22
|
}
|
24
23
|
|
25
|
-
yield sdk
|
24
|
+
yield adaptor.sdk.authSession.login();
|
26
25
|
});
|
27
26
|
|
28
27
|
return function handleLogin(_x) {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/LoginForm/LoginForm.tsx"],"names":["React","Button","Tooltip","
|
1
|
+
{"version":3,"sources":["../../../../src/components/LoginForm/LoginForm.tsx"],"names":["React","Button","Tooltip","getEnvAdaptor","RunItFormKey","readyToLogin","LoginForm","requestContent","adaptor","handleLogin","e","preventDefault","localStorageSetItem","JSON","stringify","sdk","authSession","login"],"mappings":";;;;AA2BA,OAAOA,KAAP,MAAkB,OAAlB;AACA,SAASC,MAAT,EAAiBC,OAAjB,QAAgC,oBAAhC;AACA,SAASC,aAAT,QAA8B,yBAA9B;AAEA,SAASC,YAAT,QAA6B,eAA7B;AAOA,OAAO,IAAMC,YAAY,GACvB,iGADK;AAGP,OAAO,IAAMC,SAA6B,GAAG,QAAwB;AAAA,MAAvB;AAAEC,IAAAA;AAAF,GAAuB;AACnE,MAAMC,OAAO,GAAGL,aAAa,EAA7B;;AAEA,MAAMM,WAAW;AAAA,kCAAG,WAAOC,CAAP,EAAiC;AACnDA,MAAAA,CAAC,CAACC,cAAF;;AACA,UAAIJ,cAAJ,EAAoB;AAClBC,QAAAA,OAAO,CAACI,mBAAR,CAA4BR,YAA5B,EAA0CS,IAAI,CAACC,SAAL,CAAeP,cAAf,CAA1C;AACD;;AAED,YAAMC,OAAO,CAACO,GAAR,CAAYC,WAAZ,CAAwBC,KAAxB,EAAN;AACD,KAPgB;;AAAA,oBAAXR,WAAW;AAAA;AAAA;AAAA,KAAjB;;AASA,SACE,oBAAC,OAAD;AAAS,IAAA,OAAO,EAAEJ;AAAlB,KACE,oBAAC,MAAD;AAAQ,IAAA,OAAO,EAAEI;AAAjB,aADF,CADF;AAKD,CAjBM","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 { BaseSyntheticEvent, FC } from 'react'\nimport React from 'react'\nimport { Button, Tooltip } from '@looker/components'\nimport { getEnvAdaptor } from '@looker/extension-utils'\n\nimport { RunItFormKey } from '../ConfigForm'\nimport type { RunItValues } from '../..'\n\ninterface LoginFormProps {\n requestContent: RunItValues\n}\n\nexport const readyToLogin =\n 'OAuth is configured but your browser session is not authenticated. Click Login to enable RunIt.'\n\nexport const LoginForm: FC<LoginFormProps> = ({ requestContent }) => {\n const adaptor = getEnvAdaptor()\n\n const handleLogin = async (e: BaseSyntheticEvent) => {\n e.preventDefault()\n if (requestContent) {\n adaptor.localStorageSetItem(RunItFormKey, JSON.stringify(requestContent))\n }\n // This will set storage variables and return to OAuthScene when successful\n await adaptor.sdk.authSession.login()\n }\n\n return (\n <Tooltip content={readyToLogin}>\n <Button onClick={handleLogin}>Login</Button>\n </Tooltip>\n )\n}\n"],"file":"LoginForm.js"}
|
@@ -7,12 +7,12 @@ import { PerfTimings } from './perfUtils';
|
|
7
7
|
import { PerfChart } from './PerfChart';
|
8
8
|
import { PerfTable } from './PerfTable';
|
9
9
|
|
10
|
-
var perfFilter = function perfFilter(
|
11
|
-
var all = arguments.length >
|
10
|
+
var perfFilter = function perfFilter() {
|
11
|
+
var all = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
12
12
|
if (all) return '.*';
|
13
|
-
var
|
14
|
-
if (!
|
15
|
-
var config = JSON.parse(
|
13
|
+
var value = localStorage.getItem(RunItConfigKey);
|
14
|
+
if (!value) return '.*';
|
15
|
+
var config = JSON.parse(value);
|
16
16
|
var url = new URL(config.base_url);
|
17
17
|
return "".concat(url.protocol, "//").concat(url.hostname, ".*");
|
18
18
|
};
|
@@ -20,12 +20,11 @@ var perfFilter = function perfFilter(configurator) {
|
|
20
20
|
export var PerfTracker = _ref => {
|
21
21
|
var {
|
22
22
|
perf = new PerfTimings(),
|
23
|
-
showAllColumns = false
|
24
|
-
configurator
|
23
|
+
showAllColumns = false
|
25
24
|
} = _ref;
|
26
25
|
var [loading, setLoading] = useState(false);
|
27
26
|
var [showAll, setShowAll] = useState(false);
|
28
|
-
var [filter, setFilter] = useState(perfFilter(
|
27
|
+
var [filter, setFilter] = useState(perfFilter());
|
29
28
|
var [data, setData] = useState(perf.entries(filter));
|
30
29
|
var [timings, setTimings] = useState(data.length > 0 ? data[0] : undefined);
|
31
30
|
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/PerfTracker/PerfTracker.tsx"],"names":["React","useEffect","useState","Heading","FlexItem","IconButton","SpaceVertical","FieldToggleSwitch","Flex","Delete","RunItConfigKey","Loading","PerfTimings","PerfChart","PerfTable","perfFilter","
|
1
|
+
{"version":3,"sources":["../../../../src/components/PerfTracker/PerfTracker.tsx"],"names":["React","useEffect","useState","Heading","FlexItem","IconButton","SpaceVertical","FieldToggleSwitch","Flex","Delete","RunItConfigKey","Loading","PerfTimings","PerfChart","PerfTable","perfFilter","all","value","localStorage","getItem","config","JSON","parse","url","URL","base_url","protocol","hostname","PerfTracker","perf","showAllColumns","loading","setLoading","showAll","setShowAll","filter","setFilter","data","setData","entries","timings","setTimings","length","undefined","handleClear","_","clear","handleFilterChange","e","target","checked","pf","handleSelect","item","supported"],"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 { BaseSyntheticEvent, FC } from 'react'\nimport React, { useEffect, useState } from 'react'\nimport {\n Heading,\n FlexItem,\n IconButton,\n SpaceVertical,\n FieldToggleSwitch,\n Flex,\n} from '@looker/components'\nimport { Delete } from '@styled-icons/material/Delete'\n\nimport { RunItConfigKey } from '../ConfigForm'\nimport { Loading } from '../Loading'\nimport type { LoadTimes } from './perfUtils'\nimport { PerfTimings } from './perfUtils'\nimport { PerfChart } from './PerfChart'\nimport { PerfTable } from './PerfTable'\n\ninterface PerfTrackerProps {\n perf?: PerfTimings\n showAllColumns?: boolean\n}\n\nconst perfFilter = (all = false) => {\n if (all) return '.*'\n // TODO: temporary solution until redux is introduced in RunIt. Using the env\n // adaptor makes the below async, which in turn makes it hard to use this to\n // set the initial state. PerfTracker is only used in the standalone version\n // so this achieves parity.\n const value = localStorage.getItem(RunItConfigKey)\n if (!value) return '.*'\n const config = JSON.parse(value)\n const url = new URL(config.base_url)\n return `${url.protocol}//${url.hostname}.*`\n}\n\nexport const PerfTracker: FC<PerfTrackerProps> = ({\n perf = new PerfTimings(),\n showAllColumns = false,\n}) => {\n // TODO UI option to filter by url pattern\n const [loading, setLoading] = useState(false)\n const [showAll, setShowAll] = useState(false)\n const [filter, setFilter] = useState(perfFilter())\n const [data, setData] = useState<LoadTimes[]>(perf.entries(filter))\n const [timings, setTimings] = useState(data.length > 0 ? data[0] : undefined)\n\n const handleClear = (_: BaseSyntheticEvent) => {\n setLoading(true)\n perf.clear()\n setData([])\n setTimings(undefined)\n }\n\n const handleFilterChange = (e: BaseSyntheticEvent) => {\n setLoading(true)\n const all = e.target.checked\n setShowAll(all)\n const pf = perfFilter(all)\n setFilter(pf)\n setData(perf.entries(pf))\n }\n\n useEffect(() => {\n setLoading(false)\n }, [data])\n\n const handleSelect = (item: LoadTimes) => setTimings(item)\n\n return (\n <>\n <Heading>Load Times for {filter}</Heading>\n <Flex>\n <FlexItem>\n <IconButton\n icon={<Delete />}\n onClick={handleClear}\n label=\"Clear the performance queue\"\n />\n </FlexItem>\n <FlexItem>\n <FieldToggleSwitch\n name=\"filtering\"\n label=\"Show All\"\n onChange={handleFilterChange}\n on={showAll}\n />\n </FlexItem>\n <FlexItem>\n <Loading loading={loading} />\n </FlexItem>\n </Flex>\n <>\n {!PerfTimings.supported &&\n 'Performance timing is not supported in this browser'}\n {PerfTimings.supported && !!timings && (\n <SpaceVertical gap=\"small\">\n <PerfChart loadTimes={timings} />\n <PerfTable\n data={data}\n onSelect={handleSelect}\n showAllColumns={showAllColumns}\n />\n </SpaceVertical>\n )}\n {PerfTimings.supported &&\n data.length < 1 &&\n 'No performance data is loaded'}\n </>\n </>\n )\n}\n"],"file":"PerfTracker.js"}
|
@@ -11,7 +11,6 @@ import { createSimpleItem, createComplexItem, showDataChangeWarning, updateNulla
|
|
11
11
|
import { FormItem } from './FormItem';
|
12
12
|
export var RequestForm = _ref => {
|
13
13
|
var {
|
14
|
-
sdk,
|
15
14
|
inputs,
|
16
15
|
httpMethod,
|
17
16
|
handleSubmit,
|
@@ -20,9 +19,7 @@ export var RequestForm = _ref => {
|
|
20
19
|
needsAuth,
|
21
20
|
hasConfig,
|
22
21
|
handleConfig,
|
23
|
-
setVersionsUrl,
|
24
22
|
setHasConfig,
|
25
|
-
configurator,
|
26
23
|
validationMessage,
|
27
24
|
setValidationMessage,
|
28
25
|
isExtension = false
|
@@ -73,10 +70,6 @@ export var RequestForm = _ref => {
|
|
73
70
|
}, validationMessage), React.createElement(Fieldset, null, inputs.map(input => typeof input.type === 'string' ? createSimpleItem(input, handleChange, handleNumberChange, handleBoolChange, handleDateChange, requestContent) : createComplexItem(input, handleComplexChange, requestContent)), httpMethod !== 'GET' && showDataChangeWarning(), React.createElement(FormItem, {
|
74
71
|
id: "buttonbar"
|
75
72
|
}, React.createElement(React.Fragment, null, hasConfig ? needsAuth ? React.createElement(LoginForm, {
|
76
|
-
sdk: sdk,
|
77
|
-
setVersionsUrl: setVersionsUrl,
|
78
|
-
setHasConfig: setHasConfig,
|
79
|
-
configurator: configurator,
|
80
73
|
requestContent: requestContent
|
81
74
|
}) : React.createElement(Tooltip, {
|
82
75
|
content: "Run the API request"
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/RequestForm/RequestForm.tsx"],"names":["React","Button","Form","ButtonTransparent","Tooltip","Fieldset","MessageBar","LoginForm","createSimpleItem","createComplexItem","showDataChangeWarning","updateNullableProp","FormItem","RequestForm","sdk","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setVersionsUrl","setHasConfig","configurator","validationMessage","setValidationMessage","isExtension","handleBoolChange","e","target","name","checked","handleNumberChange","value","parseFloat","undefined","newState","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","map","input","type"],"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 { BaseSyntheticEvent, FC, Dispatch } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n} from '@looker/components'\nimport type { IAPIMethods } from '@looker/sdk-rtl'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport type { RunItConfigurator } from '../ConfigForm'\nimport { LoginForm } from '../LoginForm'\nimport type { RunItSetter } from '../..'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n} from './formUtils'\nimport { FormItem } from './FormItem'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Established SDK instance */\n sdk: IAPIMethods\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** Hook to refresh specifications */\n setVersionsUrl: RunItSetter\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Configuration plug-in for stand-alone or extension */\n configurator: RunItConfigurator\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Is RunIt being used in a Looker extension? */\n isExtension?: boolean\n}\n\n/**\n * Dynamically generates a REST request form and its form elements corresponding to parameters from an array of RunIt\n * inputs\n */\nexport const RequestForm: FC<RequestFormProps> = ({\n sdk,\n inputs,\n httpMethod,\n handleSubmit,\n requestContent,\n setRequestContent,\n needsAuth,\n hasConfig,\n handleConfig,\n setVersionsUrl,\n setHasConfig,\n configurator,\n validationMessage,\n setValidationMessage,\n isExtension = false,\n}) => {\n const handleBoolChange = (e: BaseSyntheticEvent) => {\n setRequestContent({ ...requestContent, [e.target.name]: e.target.checked })\n }\n\n const handleNumberChange = (e: BaseSyntheticEvent) => {\n const value = e.target.value ? parseFloat(e.target.value) : undefined\n const newState = updateNullableProp(requestContent, e.target.name, value)\n setRequestContent(newState)\n }\n\n const handleDateChange = (name: string, date?: Date) => {\n const newState = updateNullableProp(requestContent, name, date)\n setRequestContent(newState)\n }\n\n const handleChange = (e: BaseSyntheticEvent) => {\n const newState = updateNullableProp(\n requestContent,\n e.target.name,\n e.target.value\n )\n setRequestContent(newState)\n }\n\n const handleComplexChange = (name: string, value: string) => {\n setRequestContent({ ...requestContent, [name]: value })\n }\n\n const safeSetMessage = (value: string) =>\n setValidationMessage && setValidationMessage(value)\n\n const handleClear = (e: BaseSyntheticEvent) => {\n e.preventDefault()\n setRequestContent({})\n safeSetMessage('')\n }\n\n return (\n <Form onSubmit={handleSubmit}>\n {validationMessage && (\n <MessageBar\n intent={'critical'}\n onPrimaryClick={() => safeSetMessage('')}\n visible={validationMessage !== ''}\n >\n {validationMessage}\n </MessageBar>\n )}\n <Fieldset>\n {inputs.map((input) =>\n typeof input.type === 'string'\n ? createSimpleItem(\n input,\n handleChange,\n handleNumberChange,\n handleBoolChange,\n handleDateChange,\n requestContent\n )\n : createComplexItem(input, handleComplexChange, requestContent)\n )}\n {httpMethod !== 'GET' && showDataChangeWarning()}\n <FormItem id=\"buttonbar\">\n <>\n {hasConfig ? (\n needsAuth ? (\n <LoginForm\n sdk={sdk}\n setVersionsUrl={setVersionsUrl}\n setHasConfig={setHasConfig}\n configurator={configurator}\n requestContent={requestContent}\n />\n ) : (\n <Tooltip content=\"Run the API request\">\n <Button type=\"submit\">Run</Button>\n </Tooltip>\n )\n ) : (\n !isExtension &&\n setHasConfig && (\n <Tooltip content=\"Configure your OAuth server to Run requests\">\n <Button onClick={handleConfig}>Configure</Button>\n </Tooltip>\n )\n )}\n <Tooltip content=\"Clear entered values\">\n <ButtonTransparent type=\"button\" onClick={handleClear}>\n Clear\n </ButtonTransparent>\n </Tooltip>\n </>\n </FormItem>\n </Fieldset>\n </Form>\n )\n}\n"],"file":"RequestForm.js"}
|
1
|
+
{"version":3,"sources":["../../../../src/components/RequestForm/RequestForm.tsx"],"names":["React","Button","Form","ButtonTransparent","Tooltip","Fieldset","MessageBar","LoginForm","createSimpleItem","createComplexItem","showDataChangeWarning","updateNullableProp","FormItem","RequestForm","inputs","httpMethod","handleSubmit","requestContent","setRequestContent","needsAuth","hasConfig","handleConfig","setHasConfig","validationMessage","setValidationMessage","isExtension","handleBoolChange","e","target","name","checked","handleNumberChange","value","parseFloat","undefined","newState","handleDateChange","date","handleChange","handleComplexChange","safeSetMessage","handleClear","preventDefault","map","input","type"],"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 { BaseSyntheticEvent, FC, Dispatch } from 'react'\nimport React from 'react'\nimport {\n Button,\n Form,\n ButtonTransparent,\n Tooltip,\n Fieldset,\n MessageBar,\n} from '@looker/components'\nimport type { RunItHttpMethod, RunItInput, RunItValues } from '../../RunIt'\nimport { LoginForm } from '../LoginForm'\nimport type { RunItSetter } from '../..'\nimport {\n createSimpleItem,\n createComplexItem,\n showDataChangeWarning,\n updateNullableProp,\n} from './formUtils'\nimport { FormItem } from './FormItem'\n\n/** Properties required by RequestForm */\ninterface RequestFormProps {\n /** Request inputs to the endpoint */\n inputs: RunItInput[]\n /** A callback for submitting the form */\n handleSubmit: (e: BaseSyntheticEvent) => void\n /** HTTP method used for this REST request */\n httpMethod: RunItHttpMethod\n /** A collection type react state to store path, query and body parameters as entered by the user */\n requestContent: RunItValues\n /** A set state callback fn for populating requestContent on interaction with the request form */\n setRequestContent: Dispatch<RunItValues>\n /** Is authentication required? */\n needsAuth: boolean\n /** Does RunIt have the configuration values it needs? */\n hasConfig: boolean\n /** Handle config button click */\n handleConfig: (e: BaseSyntheticEvent) => void\n /** Hook to refresh specifications */\n setVersionsUrl: RunItSetter\n /** A set state callback which if present allows for editing, setting or clearing OAuth configuration parameters */\n setHasConfig?: Dispatch<boolean>\n /** Validation message to display */\n validationMessage?: string\n /** Validation message setter */\n setValidationMessage?: Dispatch<string>\n /** Is RunIt being used in a Looker extension? */\n isExtension?: boolean\n}\n\n/**\n * Dynamically generates a REST request form and its form elements corresponding to parameters from an array of RunIt\n * inputs\n */\nexport const RequestForm: FC<RequestFormProps> = ({\n inputs,\n httpMethod,\n handleSubmit,\n requestContent,\n setRequestContent,\n needsAuth,\n hasConfig,\n handleConfig,\n setHasConfig,\n validationMessage,\n setValidationMessage,\n isExtension = false,\n}) => {\n const handleBoolChange = (e: BaseSyntheticEvent) => {\n setRequestContent({ ...requestContent, [e.target.name]: e.target.checked })\n }\n\n const handleNumberChange = (e: BaseSyntheticEvent) => {\n const value = e.target.value ? parseFloat(e.target.value) : undefined\n const newState = updateNullableProp(requestContent, e.target.name, value)\n setRequestContent(newState)\n }\n\n const handleDateChange = (name: string, date?: Date) => {\n const newState = updateNullableProp(requestContent, name, date)\n setRequestContent(newState)\n }\n\n const handleChange = (e: BaseSyntheticEvent) => {\n const newState = updateNullableProp(\n requestContent,\n e.target.name,\n e.target.value\n )\n setRequestContent(newState)\n }\n\n const handleComplexChange = (name: string, value: string) => {\n setRequestContent({ ...requestContent, [name]: value })\n }\n\n const safeSetMessage = (value: string) =>\n setValidationMessage && setValidationMessage(value)\n\n const handleClear = (e: BaseSyntheticEvent) => {\n e.preventDefault()\n setRequestContent({})\n safeSetMessage('')\n }\n\n return (\n <Form onSubmit={handleSubmit}>\n {validationMessage && (\n <MessageBar\n intent={'critical'}\n onPrimaryClick={() => safeSetMessage('')}\n visible={validationMessage !== ''}\n >\n {validationMessage}\n </MessageBar>\n )}\n <Fieldset>\n {inputs.map((input) =>\n typeof input.type === 'string'\n ? createSimpleItem(\n input,\n handleChange,\n handleNumberChange,\n handleBoolChange,\n handleDateChange,\n requestContent\n )\n : createComplexItem(input, handleComplexChange, requestContent)\n )}\n {httpMethod !== 'GET' && showDataChangeWarning()}\n <FormItem id=\"buttonbar\">\n <>\n {hasConfig ? (\n needsAuth ? (\n <LoginForm requestContent={requestContent} />\n ) : (\n <Tooltip content=\"Run the API request\">\n <Button type=\"submit\">Run</Button>\n </Tooltip>\n )\n ) : (\n !isExtension &&\n setHasConfig && (\n <Tooltip content=\"Configure your OAuth server to Run requests\">\n <Button onClick={handleConfig}>Configure</Button>\n </Tooltip>\n )\n )}\n <Tooltip content=\"Clear entered values\">\n <ButtonTransparent type=\"button\" onClick={handleClear}>\n Clear\n </ButtonTransparent>\n </Tooltip>\n </>\n </FormItem>\n </Fieldset>\n </Form>\n )\n}\n"],"file":"RequestForm.js"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/common/index.ts"],"names":["DarkSpan","RunItHeading"],"mappings":"AAyBA,SAASA,QAAT,EAAmBC,YAAnB,QAAuC,UAAvC
|
1
|
+
{"version":3,"sources":["../../../../src/components/common/index.ts"],"names":["DarkSpan","RunItHeading"],"mappings":"AAyBA,SAASA,QAAT,EAAmBC,YAAnB,QAAuC,UAAvC","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 */\nexport { DarkSpan, RunItHeading } from './common'\n"],"file":"index.js"}
|
@@ -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, {
|
5
|
+
import React, { useEffect, useState } from 'react';
|
6
6
|
import { useHistory } from 'react-router-dom';
|
7
|
-
import {
|
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","
|
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"}
|