@scalar/api-client 2.5.32 → 2.5.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +20 -0
- package/dist/components/AddressBar/AddressBar.vue.js +1 -1
- package/dist/components/AddressBar/AddressBar.vue2.js +120 -128
- package/dist/components/AddressBar/AddressBarHistory.vue.js +1 -1
- package/dist/components/AddressBar/AddressBarHistory.vue2.js +57 -63
- package/dist/components/CodeInput/CodeInput.vue.js +2 -2
- package/dist/components/CodeInput/CodeInput.vue2.js +143 -150
- package/dist/components/CodeInput/codeVariableWidget.js +70 -75
- package/dist/components/CommandPalette/CommandActionInput.vue.js +17 -19
- package/dist/components/CommandPalette/CommandPaletteCollection.vue.js +26 -27
- package/dist/components/CommandPalette/CommandPaletteExample.vue.js +53 -55
- package/dist/components/CommandPalette/CommandPaletteImport.vue.js +129 -133
- package/dist/components/CommandPalette/CommandPaletteImportCurl.vue.js +1 -1
- package/dist/components/CommandPalette/CommandPaletteImportCurl.vue2.js +84 -98
- package/dist/components/CommandPalette/CommandPaletteServer.vue.js +64 -74
- package/dist/components/CommandPalette/CommandPaletteTag.vue.js +5 -11
- package/dist/components/CommandPalette/TheCommandPalette.vue.js +1 -1
- package/dist/components/CommandPalette/TheCommandPalette.vue2.js +164 -183
- package/dist/components/DataTable/DataTableInput.vue.d.ts.map +1 -1
- package/dist/components/DataTable/DataTableInput.vue.js +4 -4
- package/dist/components/DataTable/DataTableInput.vue2.js +31 -31
- package/dist/components/DataTable/DataTableInputSelect.vue.js +1 -2
- package/dist/components/EmptyState.vue.js +1 -1
- package/dist/components/EnvironmentSelector/EnvironmentSelector.vue.js +75 -84
- package/dist/components/Form/LabelInput.vue.js +1 -1
- package/dist/components/HttpMethod/HttpMethod.vue.js +1 -1
- package/dist/components/HttpMethod/HttpMethod.vue2.js +11 -11
- package/dist/components/ImportCollection/DropEventListener.vue.js +42 -44
- package/dist/components/ImportCollection/ImportCollectionListener.vue.js +22 -23
- package/dist/components/ImportCollection/ImportCollectionModal.vue.js +141 -149
- package/dist/components/ImportCollection/ImportCollectionModal.vue3.js +1 -1
- package/dist/components/ImportCollection/ImportNowButton.vue.js +22 -23
- package/dist/components/ImportCollection/IntegrationLogo.vue.js +12 -13
- package/dist/components/ImportCollection/PasteEventListener.vue.js +11 -12
- package/dist/components/ImportCollection/WorkspaceSelector.vue.js +69 -76
- package/dist/components/ImportCollection/utils/get-openapi-version.js +8 -8
- package/dist/components/ImportCollection/utils/import-collection.js +14 -14
- package/dist/components/OpenApiClientButton.vue.js +1 -1
- package/dist/components/OpenApiClientButton.vue2.js +10 -10
- package/dist/components/ScalarAsciiArt.vue.js +1 -1
- package/dist/components/ScalarAsciiArt.vue2.js +19 -22
- package/dist/components/Search/useSearch.js +51 -61
- package/dist/components/SectionFilter.vue.js +1 -1
- package/dist/components/SectionFilter.vue2.js +26 -29
- package/dist/components/Server/ServerDropdown.vue.js +70 -96
- package/dist/components/Server/ServerDropdownItem.vue.js +1 -1
- package/dist/components/Server/ServerDropdownItem.vue2.js +57 -67
- package/dist/components/Server/ServerSelector.vue.js +44 -55
- package/dist/components/Server/ServerVariablesForm.vue.js +36 -42
- package/dist/components/Server/ServerVariablesSelect.vue.js +6 -6
- package/dist/components/SideNav/DownloadAppButton.vue.js +1 -1
- package/dist/components/SideNav/SideNav.vue.js +68 -74
- package/dist/components/Sidebar/Actions/SidebarListElementForm.vue.js +1 -1
- package/dist/components/Sidebar/Sidebar.vue.js +1 -1
- package/dist/components/Sidebar/SidebarListElement.vue.js +2 -2
- package/dist/components/TopNav/TopNav.vue.js +107 -122
- package/dist/components/TopNav/TopNavItem.vue.js +1 -1
- package/dist/hooks/useFileDialog.js +12 -12
- package/dist/hooks/useResponseBody.js +14 -16
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -2
- package/dist/layouts/App/ApiClientApp.vue.js +50 -56
- package/dist/layouts/App/ApiClientApp.vue3.js +1 -1
- package/dist/layouts/App/create-api-client-app.js +19 -20
- package/dist/layouts/App/index.js +1 -1
- package/dist/layouts/Modal/ApiClientModal.vue.js +1 -1
- package/dist/layouts/Modal/ApiClientModal.vue2.js +18 -21
- package/dist/layouts/Web/ApiClientWeb.vue.js +45 -51
- package/dist/layouts/Web/ApiClientWeb.vue3.js +1 -1
- package/dist/layouts/Web/create-api-client-web.js +19 -20
- package/dist/layouts/Web/index.js +1 -1
- package/dist/libs/create-client.js +102 -109
- package/dist/libs/env-helpers.js +3 -3
- package/dist/libs/event-bus.js +15 -15
- package/dist/libs/extractAttachmentFilename.js +5 -6
- package/dist/libs/find-request.js +9 -10
- package/dist/libs/get-request-uid-by-path-method.js +12 -12
- package/dist/libs/getOpenApiDocumentDetails.js +7 -7
- package/dist/libs/importers/curl.js +3 -3
- package/dist/libs/normalize-headers.js +9 -10
- package/dist/libs/postman.js +15 -17
- package/dist/libs/send-request/build-request-security.js +9 -10
- package/dist/libs/send-request/create-fetch-body.js +11 -12
- package/dist/libs/send-request/create-fetch-query-params.js +13 -13
- package/dist/libs/send-request/create-request-operation.js +83 -84
- package/dist/libs/send-request/decode-buffer.d.ts.map +1 -1
- package/dist/libs/send-request/set-request-cookies.js +12 -12
- package/dist/libs/string-template.js +21 -21
- package/dist/libs/validate-parameters.js +5 -8
- package/dist/plugins/plugin-manager.js +11 -17
- package/dist/store/active-entities.js +90 -117
- package/dist/store/collections.js +41 -42
- package/dist/store/import-spec.js +25 -26
- package/dist/store/request-example.js +20 -24
- package/dist/store/requests.js +63 -81
- package/dist/store/router-params.js +7 -7
- package/dist/store/security-schemes.js +35 -36
- package/dist/store/store.js +2 -2
- package/dist/store/tags.js +20 -21
- package/dist/style.css +1 -1
- package/dist/views/Collection/Collection.vue2.js +21 -22
- package/dist/views/Collection/CollectionAuthentication.vue.js +1 -1
- package/dist/views/Collection/CollectionAuthentication.vue2.js +43 -47
- package/dist/views/Collection/CollectionEnvironment.vue.js +1 -1
- package/dist/views/Collection/CollectionEnvironment.vue2.js +196 -207
- package/dist/views/Collection/CollectionInfoForm.vue.js +1 -1
- package/dist/views/Collection/CollectionInfoForm.vue2.js +34 -41
- package/dist/views/Collection/CollectionNavigation.vue.js +116 -125
- package/dist/views/Collection/CollectionOverview.vue2.js +22 -25
- package/dist/views/Collection/CollectionServerForm.vue.js +39 -45
- package/dist/views/Collection/CollectionServers.vue2.js +88 -98
- package/dist/views/Collection/CollectionSettings.vue.js +1 -1
- package/dist/views/Collection/CollectionSettings.vue2.js +101 -108
- package/dist/views/Collection/components/EnvironmentForm.vue.js +1 -1
- package/dist/views/Collection/components/EnvironmentForm.vue2.js +141 -145
- package/dist/views/Collection/components/MarkdownInput.vue.js +1 -1
- package/dist/views/Collection/components/MarkdownInput.vue2.js +1 -2
- package/dist/views/Components/CodeSnippet/CodeSnippet.vue.js +15 -15
- package/dist/views/Components/CodeSnippet/helpers/convert-to-har-request.js +15 -16
- package/dist/views/Components/CodeSnippet/helpers/get-har-request.js +61 -64
- package/dist/views/Components/CodeSnippet/helpers/get-snippet.js +9 -10
- package/dist/views/Cookies/CookieModal.vue.js +1 -1
- package/dist/views/Cookies/Cookies.vue2.js +90 -93
- package/dist/views/Environment/Environment.vue2.js +267 -295
- package/dist/views/Environment/EnvironmentModal.vue.js +63 -70
- package/dist/views/Environment/EnvironmentVariableDropdown.vue.js +38 -42
- package/dist/views/Request/Request.vue.js +1 -1
- package/dist/views/Request/Request.vue2.js +60 -67
- package/dist/views/Request/RequestRoot.vue.js +1 -1
- package/dist/views/Request/RequestRoot.vue2.js +78 -89
- package/dist/views/Request/RequestSection/RequestAuth/DeleteRequestAuthModal.vue.js +37 -44
- package/dist/views/Request/RequestSection/RequestAuth/OAuth2.vue.js +44 -45
- package/dist/views/Request/RequestSection/RequestAuth/OAuthScopesInput.vue.js +111 -127
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuth.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuth.vue2.js +120 -139
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuthDataTable.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuthTab.vue.js +97 -97
- package/dist/views/Request/RequestSection/RequestBody.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestBody.vue2.js +287 -310
- package/dist/views/Request/RequestSection/RequestCodeExample.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestCodeExample.vue2.js +86 -94
- package/dist/views/Request/RequestSection/RequestParams.vue.js +37 -38
- package/dist/views/Request/RequestSection/RequestPathParams.vue.js +36 -38
- package/dist/views/Request/RequestSection/RequestSection.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestSection.vue2.js +28 -31
- package/dist/views/Request/RequestSection/RequestTable.vue.js +1 -1
- package/dist/views/Request/RequestSection/RequestTable.vue2.js +49 -52
- package/dist/views/Request/RequestSection/RequestTableTooltip.vue.js +1 -1
- package/dist/views/Request/RequestSection/helpers/filter-security-requirements.js +16 -16
- package/dist/views/Request/RequestSection/helpers/getting-started.js +7 -11
- package/dist/views/Request/RequestSection/helpers/update-scheme.js +7 -8
- package/dist/views/Request/RequestSidebar.vue.js +1 -1
- package/dist/views/Request/RequestSidebar.vue2.js +199 -211
- package/dist/views/Request/RequestSidebarItem.vue.js +2 -2
- package/dist/views/Request/RequestSidebarItem.vue2.js +332 -349
- package/dist/views/Request/RequestSidebarItemMenu.vue.js +1 -1
- package/dist/views/Request/RequestSidebarItemMenu.vue2.js +210 -240
- package/dist/views/Request/RequestSubpageHeader.vue.js +1 -1
- package/dist/views/Request/ResponseSection/RequestHeaders.vue.js +38 -41
- package/dist/views/Request/ResponseSection/ResponseBody.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseBody.vue2.js +58 -64
- package/dist/views/Request/ResponseSection/ResponseBodyDownload.vue.js +1 -2
- package/dist/views/Request/ResponseSection/ResponseBodyPreview.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseBodyRaw.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseBodyRaw.vue2.js +20 -23
- package/dist/views/Request/ResponseSection/ResponseBodyVirtual.vue3.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseEmpty.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseEmpty.vue2.js +29 -30
- package/dist/views/Request/ResponseSection/ResponseHeaders.vue.js +38 -41
- package/dist/views/Request/ResponseSection/ResponseLoadingOverlay.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseMetaInformation.vue.js +28 -29
- package/dist/views/Request/ResponseSection/ResponseSection.vue.js +1 -1
- package/dist/views/Request/ResponseSection/ResponseSection.vue2.js +128 -140
- package/dist/views/Request/components/WorkspaceDropdown.vue.js +116 -124
- package/dist/views/Request/consts/mediaTypes.js +2 -3
- package/dist/views/Request/handle-drag.js +24 -28
- package/dist/views/Request/hooks/useOpenApiWatcher.js +26 -33
- package/dist/views/Request/libs/auth.js +37 -43
- package/dist/views/Request/libs/oauth2.js +30 -32
- package/dist/views/Request/libs/watch-mode.js +100 -103
- package/dist/views/Settings/SettingsGeneral.vue.js +206 -236
- package/package.json +22 -22
- package/dist/components/AddressBar/AddressBar.vue3.js +0 -4
- package/dist/components/AddressBar/AddressBarHistory.vue3.js +0 -4
- package/dist/components/CodeInput/CodeInput.vue3.js +0 -4
- package/dist/components/CodeInput/CodeInput.vue4.js +0 -4
- package/dist/components/CommandPalette/CommandPaletteImportCurl.vue3.js +0 -4
- package/dist/components/CommandPalette/TheCommandPalette.vue3.js +0 -4
- package/dist/components/DataTable/DataTableInput.vue3.js +0 -4
- package/dist/components/EmptyState.vue3.js +0 -4
- package/dist/components/Form/LabelInput.vue3.js +0 -4
- package/dist/components/HttpMethod/HttpMethod.vue3.js +0 -4
- package/dist/components/ImportCollection/ImportCollectionModal.vue2.js +0 -4
- package/dist/components/OpenApiClientButton.vue3.js +0 -4
- package/dist/components/ScalarAsciiArt.vue3.js +0 -4
- package/dist/components/SectionFilter.vue3.js +0 -4
- package/dist/components/Server/ServerDropdownItem.vue3.js +0 -4
- package/dist/components/SideNav/DownloadAppButton.vue3.js +0 -4
- package/dist/components/Sidebar/Actions/SidebarListElementForm.vue3.js +0 -4
- package/dist/components/Sidebar/Sidebar.vue3.js +0 -4
- package/dist/components/Sidebar/SidebarListElement.vue3.js +0 -4
- package/dist/components/Sidebar/SidebarListElement.vue4.js +0 -4
- package/dist/components/TopNav/TopNavItem.vue3.js +0 -4
- package/dist/layouts/App/ApiClientApp.vue2.js +0 -4
- package/dist/layouts/Modal/ApiClientModal.vue3.js +0 -4
- package/dist/layouts/Web/ApiClientWeb.vue2.js +0 -4
- package/dist/style.css.js +0 -4
- package/dist/views/Collection/CollectionAuthentication.vue3.js +0 -4
- package/dist/views/Collection/CollectionEnvironment.vue3.js +0 -4
- package/dist/views/Collection/CollectionInfoForm.vue3.js +0 -4
- package/dist/views/Collection/CollectionSettings.vue3.js +0 -4
- package/dist/views/Collection/components/EnvironmentForm.vue3.js +0 -4
- package/dist/views/Collection/components/MarkdownInput.vue3.js +0 -4
- package/dist/views/Cookies/CookieModal.vue3.js +0 -4
- package/dist/views/Request/Request.vue3.js +0 -4
- package/dist/views/Request/RequestRoot.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuth.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestAuth/RequestAuthDataTable.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestBody.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestCodeExample.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestSection.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestTable.vue3.js +0 -4
- package/dist/views/Request/RequestSection/RequestTableTooltip.vue3.js +0 -4
- package/dist/views/Request/RequestSidebar.vue3.js +0 -4
- package/dist/views/Request/RequestSidebarItem.vue3.js +0 -4
- package/dist/views/Request/RequestSidebarItem.vue4.js +0 -4
- package/dist/views/Request/RequestSidebarItemMenu.vue3.js +0 -4
- package/dist/views/Request/RequestSubpageHeader.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseBody.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseBodyPreview.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseBodyRaw.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseBodyVirtual.vue2.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseEmpty.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseLoadingOverlay.vue3.js +0 -4
- package/dist/views/Request/ResponseSection/ResponseSection.vue3.js +0 -4
|
@@ -1,26 +1,25 @@
|
|
|
1
|
-
import { replaceTemplateVariables as
|
|
2
|
-
import { canMethodHaveBody as
|
|
3
|
-
function
|
|
4
|
-
|
|
5
|
-
if (!c(f))
|
|
1
|
+
import { replaceTemplateVariables as r } from "../string-template.js";
|
|
2
|
+
import { canMethodHaveBody as e } from "@scalar/oas-utils/helpers";
|
|
3
|
+
function c(i, o, t) {
|
|
4
|
+
if (!e(i))
|
|
6
5
|
return { body: void 0, contentType: void 0 };
|
|
7
6
|
if (o.body.activeBody === "formData" && o.body.formData) {
|
|
8
|
-
const
|
|
7
|
+
const n = o.body.formData.encoding === "form-data" ? "multipart/form-data" : "application/x-www-form-urlencoded", d = o.body.formData.encoding === "form-data" ? new FormData() : new URLSearchParams();
|
|
9
8
|
return o.body.formData.value.forEach((a) => {
|
|
10
|
-
!a.enabled || !a.key || (a.file && d instanceof FormData ? d.append(a.key, a.file, a.file.name) : a.value !== void 0 && d.append(a.key,
|
|
11
|
-
}), { body: d, contentType:
|
|
9
|
+
!a.enabled || !a.key || (a.file && d instanceof FormData ? d.append(a.key, a.file, a.file.name) : a.value !== void 0 && d.append(a.key, r(a.value, t)));
|
|
10
|
+
}), { body: d, contentType: n };
|
|
12
11
|
}
|
|
13
12
|
return o.body.activeBody === "raw" ? {
|
|
14
|
-
body:
|
|
15
|
-
contentType:
|
|
13
|
+
body: r(o.body.raw?.value ?? "", t),
|
|
14
|
+
contentType: o.body.raw?.encoding
|
|
16
15
|
} : o.body.activeBody === "binary" ? {
|
|
17
16
|
body: o.body.binary,
|
|
18
|
-
contentType:
|
|
17
|
+
contentType: o.body.binary?.type
|
|
19
18
|
} : {
|
|
20
19
|
body: void 0,
|
|
21
20
|
contentType: void 0
|
|
22
21
|
};
|
|
23
22
|
}
|
|
24
23
|
export {
|
|
25
|
-
|
|
24
|
+
c as createFetchBody
|
|
26
25
|
};
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
import { replaceTemplateVariables as
|
|
2
|
-
function
|
|
3
|
-
const r = new URLSearchParams(),
|
|
1
|
+
import { replaceTemplateVariables as c } from "../string-template.js";
|
|
2
|
+
function m(o, n, l) {
|
|
3
|
+
const r = new URLSearchParams(), u = (l?.parameters ?? []).reduce(
|
|
4
4
|
(e, a) => (a.in === "query" && (e[a.name] = a), e),
|
|
5
5
|
{}
|
|
6
6
|
);
|
|
7
|
-
return
|
|
7
|
+
return o.parameters.query.forEach((e) => {
|
|
8
8
|
if (!e.enabled) return;
|
|
9
|
-
const a =
|
|
9
|
+
const a = u[e.key];
|
|
10
10
|
switch (e.type) {
|
|
11
11
|
case "array": {
|
|
12
|
-
const t =
|
|
13
|
-
if (
|
|
14
|
-
const
|
|
15
|
-
r.append(e.key,
|
|
12
|
+
const t = c(e.value ?? "", n).split(/,\ ?/);
|
|
13
|
+
if (a?.explode === !1) {
|
|
14
|
+
const s = t.join(",");
|
|
15
|
+
r.append(e.key, s);
|
|
16
16
|
} else
|
|
17
|
-
t.forEach((
|
|
18
|
-
r.append(e.key,
|
|
17
|
+
t.forEach((s) => {
|
|
18
|
+
r.append(e.key, s.trim());
|
|
19
19
|
});
|
|
20
20
|
break;
|
|
21
21
|
}
|
|
22
22
|
default: {
|
|
23
|
-
const t =
|
|
23
|
+
const t = c(e.value ?? "", n);
|
|
24
24
|
r.append(e.key, t.trim());
|
|
25
25
|
break;
|
|
26
26
|
}
|
|
@@ -28,5 +28,5 @@ function f(l, o, n) {
|
|
|
28
28
|
}), r;
|
|
29
29
|
}
|
|
30
30
|
export {
|
|
31
|
-
|
|
31
|
+
m as createFetchQueryParams
|
|
32
32
|
};
|
|
@@ -1,126 +1,125 @@
|
|
|
1
|
-
import { ERRORS as
|
|
2
|
-
import { normalizeHeaders as
|
|
3
|
-
import { createFetchBody as
|
|
4
|
-
import { createFetchHeaders as
|
|
5
|
-
import { createFetchQueryParams as
|
|
6
|
-
import { decodeBuffer as
|
|
7
|
-
import { setRequestCookies as
|
|
8
|
-
import { replaceTemplateVariables as
|
|
9
|
-
import { isElectron as
|
|
10
|
-
import { isDefined as
|
|
11
|
-
import { buildRequestSecurity as
|
|
12
|
-
const
|
|
13
|
-
environment:
|
|
14
|
-
example:
|
|
15
|
-
globalCookies:
|
|
1
|
+
import { ERRORS as T, normalizeError as H } from "../errors.js";
|
|
2
|
+
import { normalizeHeaders as Y } from "../normalize-headers.js";
|
|
3
|
+
import { createFetchBody as G } from "./create-fetch-body.js";
|
|
4
|
+
import { createFetchHeaders as J } from "./create-fetch-headers.js";
|
|
5
|
+
import { createFetchQueryParams as N } from "./create-fetch-query-params.js";
|
|
6
|
+
import { decodeBuffer as Z } from "./decode-buffer.js";
|
|
7
|
+
import { setRequestCookies as $, getCookieHeader as M } from "./set-request-cookies.js";
|
|
8
|
+
import { replaceTemplateVariables as c } from "../string-template.js";
|
|
9
|
+
import { isElectron as P } from "../electron.js";
|
|
10
|
+
import { isDefined as ee, mergeUrls as te, shouldUseProxy as U, redirectToProxy as oe, httpStatusCodes as re } from "@scalar/oas-utils/helpers";
|
|
11
|
+
import { buildRequestSecurity as se } from "./build-request-security.js";
|
|
12
|
+
const be = ({
|
|
13
|
+
environment: q,
|
|
14
|
+
example: s,
|
|
15
|
+
globalCookies: v,
|
|
16
16
|
proxyUrl: u,
|
|
17
|
-
request:
|
|
18
|
-
securitySchemes:
|
|
19
|
-
selectedSecuritySchemeUids:
|
|
20
|
-
server:
|
|
21
|
-
status:
|
|
22
|
-
pluginManager:
|
|
17
|
+
request: a,
|
|
18
|
+
securitySchemes: D,
|
|
19
|
+
selectedSecuritySchemeUids: E = [],
|
|
20
|
+
server: k,
|
|
21
|
+
status: m,
|
|
22
|
+
pluginManager: h
|
|
23
23
|
}) => {
|
|
24
24
|
try {
|
|
25
|
-
const
|
|
26
|
-
let
|
|
27
|
-
if (!
|
|
28
|
-
throw
|
|
29
|
-
Object.entries(
|
|
30
|
-
|
|
31
|
-
[
|
|
25
|
+
const o = q ?? {}, b = new AbortController(), w = s.parameters.path.reduce((t, e) => (e.enabled && (t[e.key] = c(e.value, o)), t), {}), L = c(k?.url ?? "", o), l = c(c(a.path, o), w);
|
|
26
|
+
let r = L || l;
|
|
27
|
+
if (!r)
|
|
28
|
+
throw T.URL_EMPTY;
|
|
29
|
+
Object.entries(k?.variables ?? {}).forEach(([t, e]) => {
|
|
30
|
+
r = c(r, {
|
|
31
|
+
[t]: w[t] || e.default
|
|
32
32
|
});
|
|
33
33
|
});
|
|
34
|
-
const
|
|
35
|
-
example:
|
|
36
|
-
env:
|
|
37
|
-
globalCookies:
|
|
38
|
-
serverUrl:
|
|
34
|
+
const z = N(s, o, a), B = J(s, o), { body: F } = G(a.method, s, o), { cookieParams: _ } = $({
|
|
35
|
+
example: s,
|
|
36
|
+
env: o,
|
|
37
|
+
globalCookies: v,
|
|
38
|
+
serverUrl: r,
|
|
39
39
|
proxyUrl: u
|
|
40
|
-
}),
|
|
41
|
-
(
|
|
40
|
+
}), O = E.flat().map((t) => D[t]).filter(ee), f = se(O, o), n = { ...Object.entries(f.headers).reduce(
|
|
41
|
+
(t, [e, S]) => (t[e.toLowerCase()] = S, t),
|
|
42
42
|
{}
|
|
43
|
-
), ...
|
|
44
|
-
|
|
45
|
-
const
|
|
46
|
-
|
|
43
|
+
), ...B }, W = [..._, ...f.cookies], x = new URLSearchParams([...z, ...f.urlParams]);
|
|
44
|
+
P() && n["user-agent"] && (n["X-Scalar-User-Agent"] = n["user-agent"]), r = te(r, l, x);
|
|
45
|
+
const p = c(M(W, n.Cookie), o);
|
|
46
|
+
p && (P() || U(u, r) ? (console.warn(
|
|
47
47
|
"We're using a `X-Scalar-Cookie` custom header to the request. The proxy will forward this as a `Cookie` header. We do this to avoid the browser omitting the `Cookie` header for cross-origin requests for security reasons."
|
|
48
|
-
),
|
|
48
|
+
), n["X-Scalar-Cookie"] = p) : (console.warn(
|
|
49
49
|
`We're trying to add a Cookie header, but browsers often omit them for cross-origin requests for various security reasons. If it's not working, that's probably why. Here are the requirements for it to work:
|
|
50
50
|
|
|
51
51
|
- The browser URL must be on the same domain as the server URL.
|
|
52
52
|
- The connection must be made over HTTPS.
|
|
53
53
|
`
|
|
54
|
-
),
|
|
55
|
-
const
|
|
56
|
-
method:
|
|
57
|
-
body:
|
|
58
|
-
headers:
|
|
54
|
+
), n.Cookie = p));
|
|
55
|
+
const A = oe(u, r), y = new Request(A, {
|
|
56
|
+
method: a.method.toUpperCase(),
|
|
57
|
+
body: F ?? null,
|
|
58
|
+
headers: n
|
|
59
59
|
});
|
|
60
60
|
return [
|
|
61
61
|
null,
|
|
62
62
|
{
|
|
63
|
-
request:
|
|
63
|
+
request: y,
|
|
64
64
|
sendRequest: async () => {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
const e = Date.now();
|
|
65
|
+
m?.emit("start"), h && h.executeHook("onBeforeRequest", { request: y });
|
|
66
|
+
const t = Date.now();
|
|
68
67
|
try {
|
|
69
|
-
const
|
|
70
|
-
signal:
|
|
71
|
-
}),
|
|
72
|
-
|
|
73
|
-
const
|
|
74
|
-
status:
|
|
75
|
-
statusText:
|
|
76
|
-
headers:
|
|
68
|
+
const e = await fetch(y, {
|
|
69
|
+
signal: b.signal
|
|
70
|
+
}), S = e.headers.get("content-type")?.startsWith("text/event-stream");
|
|
71
|
+
m?.emit("stop");
|
|
72
|
+
const X = Date.now() - t, j = e.clone(), R = Y(e.headers, U(u, r)), I = e.headers.get("content-type") ?? "text/plain;charset=UTF-8", C = await j.arrayBuffer(), Q = Z(C, I), i = e.clone(), V = i.statusText || re[i.status]?.name || "", K = [204, 205, 304].includes(i.status), d = new Response(K ? null : i.body, {
|
|
73
|
+
status: i.status,
|
|
74
|
+
statusText: V,
|
|
75
|
+
headers: i.headers
|
|
77
76
|
});
|
|
78
|
-
|
|
79
|
-
const
|
|
80
|
-
return
|
|
77
|
+
h && h.executeHook("onResponseReceived", { response: d, operation: a });
|
|
78
|
+
const g = "getSetCookie" in d.headers && typeof d.headers.getSetCookie == "function" ? d.headers.getSetCookie() : [];
|
|
79
|
+
return S && e.body ? [
|
|
81
80
|
null,
|
|
82
81
|
{
|
|
83
82
|
timestamp: Date.now(),
|
|
84
|
-
request:
|
|
83
|
+
request: s,
|
|
85
84
|
response: {
|
|
86
|
-
...
|
|
87
|
-
headers:
|
|
88
|
-
cookieHeaderKeys:
|
|
89
|
-
reader:
|
|
90
|
-
duration:
|
|
91
|
-
method:
|
|
92
|
-
path:
|
|
85
|
+
...d,
|
|
86
|
+
headers: R,
|
|
87
|
+
cookieHeaderKeys: g,
|
|
88
|
+
reader: e.body?.getReader(),
|
|
89
|
+
duration: X,
|
|
90
|
+
method: a.method,
|
|
91
|
+
path: l
|
|
93
92
|
}
|
|
94
93
|
}
|
|
95
94
|
] : [
|
|
96
95
|
null,
|
|
97
96
|
{
|
|
98
97
|
timestamp: Date.now(),
|
|
99
|
-
request:
|
|
98
|
+
request: s,
|
|
100
99
|
response: {
|
|
101
|
-
...
|
|
102
|
-
headers:
|
|
103
|
-
cookieHeaderKeys:
|
|
104
|
-
data:
|
|
105
|
-
size:
|
|
106
|
-
duration: Date.now() -
|
|
107
|
-
method:
|
|
108
|
-
status:
|
|
109
|
-
path:
|
|
100
|
+
...e,
|
|
101
|
+
headers: R,
|
|
102
|
+
cookieHeaderKeys: g,
|
|
103
|
+
data: Q,
|
|
104
|
+
size: C.byteLength,
|
|
105
|
+
duration: Date.now() - t,
|
|
106
|
+
method: a.method,
|
|
107
|
+
status: e.status,
|
|
108
|
+
path: l
|
|
110
109
|
}
|
|
111
110
|
}
|
|
112
111
|
];
|
|
113
|
-
} catch (
|
|
114
|
-
return
|
|
112
|
+
} catch (e) {
|
|
113
|
+
return m?.emit("abort"), [H(e, T.REQUEST_FAILED), null];
|
|
115
114
|
}
|
|
116
115
|
},
|
|
117
|
-
controller:
|
|
116
|
+
controller: b
|
|
118
117
|
}
|
|
119
118
|
];
|
|
120
|
-
} catch (
|
|
121
|
-
return console.error(
|
|
119
|
+
} catch (o) {
|
|
120
|
+
return console.error(o), m?.emit("abort"), [H(o), null];
|
|
122
121
|
}
|
|
123
122
|
};
|
|
124
123
|
export {
|
|
125
|
-
|
|
124
|
+
be as createRequestOperation
|
|
126
125
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"decode-buffer.d.ts","sourceRoot":"","sources":["../../../src/libs/send-request/decode-buffer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"decode-buffer.d.ts","sourceRoot":"","sources":["../../../src/libs/send-request/decode-buffer.ts"],"names":[],"mappings":"AAKA,sDAAsD;AACtD,wBAAgB,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAapE"}
|
|
@@ -5,20 +5,20 @@ const l = "/";
|
|
|
5
5
|
function C({
|
|
6
6
|
example: a,
|
|
7
7
|
env: t,
|
|
8
|
-
globalCookies:
|
|
9
|
-
serverUrl:
|
|
8
|
+
globalCookies: o,
|
|
9
|
+
serverUrl: e,
|
|
10
10
|
proxyUrl: r
|
|
11
11
|
}) {
|
|
12
|
-
const n = [], h = $(r,
|
|
13
|
-
h ? r :
|
|
12
|
+
const n = [], h = $(r, e), i = W(
|
|
13
|
+
h ? r : e ?? "http://localhost"
|
|
14
14
|
);
|
|
15
|
-
return
|
|
16
|
-
const { name:
|
|
17
|
-
!k(
|
|
15
|
+
return o.forEach((s) => {
|
|
16
|
+
const { name: m, value: u, domain: c, ...d } = s;
|
|
17
|
+
!k(e, c) || !m || n.push(
|
|
18
18
|
p.parse({
|
|
19
|
-
name:
|
|
19
|
+
name: m,
|
|
20
20
|
value: u,
|
|
21
|
-
domain:
|
|
21
|
+
domain: c,
|
|
22
22
|
path: d.path
|
|
23
23
|
})
|
|
24
24
|
);
|
|
@@ -42,14 +42,14 @@ const W = (a) => {
|
|
|
42
42
|
if (!a || !t)
|
|
43
43
|
return !0;
|
|
44
44
|
try {
|
|
45
|
-
const
|
|
45
|
+
const o = a.startsWith("http") ? a : `http://${a}`, e = new URL(o).hostname, r = !t, n = t === e, h = t.startsWith(".") && t === `.${e}`, i = t.startsWith(".") && e?.endsWith(t);
|
|
46
46
|
return r || n || i || h;
|
|
47
47
|
} catch {
|
|
48
48
|
return !1;
|
|
49
49
|
}
|
|
50
50
|
}, D = (a, t) => {
|
|
51
|
-
const
|
|
52
|
-
return t ? `${t}; ${
|
|
51
|
+
const o = a.map((e) => `${e.name}=${e.value}`).join("; ");
|
|
52
|
+
return t ? `${t}; ${o}`.trim() : o.trim();
|
|
53
53
|
};
|
|
54
54
|
export {
|
|
55
55
|
D as getCookieHeader,
|
|
@@ -1,36 +1,36 @@
|
|
|
1
1
|
import { REGEX as l, isDefined as a } from "@scalar/oas-utils/helpers";
|
|
2
2
|
function i(c, o) {
|
|
3
|
-
const
|
|
4
|
-
return typeof
|
|
3
|
+
const s = c.split(".").reduce((u, r) => u?.[r], o);
|
|
4
|
+
return typeof s == "string" ? s : JSON.stringify(s);
|
|
5
5
|
}
|
|
6
6
|
function p(c, o) {
|
|
7
7
|
let t = c;
|
|
8
|
-
const
|
|
9
|
-
return t = t.replace(l.VARIABLES, (
|
|
8
|
+
const s = /* @__PURE__ */ new Set();
|
|
9
|
+
return t = t.replace(l.VARIABLES, (u, r) => {
|
|
10
10
|
const e = r.trim();
|
|
11
|
-
|
|
12
|
-
const
|
|
13
|
-
return a(
|
|
14
|
-
}), t = t.replace(l.PATH, (
|
|
11
|
+
s.add(e);
|
|
12
|
+
const n = i(e, o);
|
|
13
|
+
return a(n) && n !== "" ? n : `{{${e}}}`;
|
|
14
|
+
}), t = t.replace(l.PATH, (u, r) => {
|
|
15
15
|
const e = r.trim();
|
|
16
|
-
if (
|
|
16
|
+
if (s.has(e))
|
|
17
17
|
return `{${e}}`;
|
|
18
|
-
const
|
|
19
|
-
return a(
|
|
20
|
-
}), t = t.replace(/:\b[\w.]+\b/g, (
|
|
21
|
-
const r =
|
|
22
|
-
if (
|
|
23
|
-
return
|
|
18
|
+
const n = i(e, o);
|
|
19
|
+
return a(n) && n !== "" ? n : `{${e}}`;
|
|
20
|
+
}), t = t.replace(/:\b[\w.]+\b/g, (u) => {
|
|
21
|
+
const r = u.slice(1);
|
|
22
|
+
if (s.has(r))
|
|
23
|
+
return u;
|
|
24
24
|
const e = i(r, o);
|
|
25
|
-
return a(e) && e !== "" ? e :
|
|
25
|
+
return a(e) && e !== "" ? e : u;
|
|
26
26
|
}), t;
|
|
27
27
|
}
|
|
28
28
|
function y(c) {
|
|
29
|
-
function o(t,
|
|
30
|
-
const
|
|
31
|
-
return
|
|
32
|
-
const
|
|
33
|
-
typeof t[e] == "object" ? r.push(...o(t[e],
|
|
29
|
+
function o(t, s) {
|
|
30
|
+
const u = Object.keys(t), r = [];
|
|
31
|
+
return u.forEach((e) => {
|
|
32
|
+
const n = s ? `${s}.${e}` : e;
|
|
33
|
+
typeof t[e] == "object" ? r.push(...o(t[e], n)) : r.push([n, String(t[e])]);
|
|
34
34
|
}), r;
|
|
35
35
|
}
|
|
36
36
|
return o(c);
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
const
|
|
1
|
+
const n = (a) => {
|
|
2
2
|
const e = /* @__PURE__ */ new Set();
|
|
3
|
-
return a && ["path", "query", "headers", "cookies"].some((
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
r.required && r.value === "" && e.add(r.key);
|
|
7
|
-
});
|
|
8
|
-
}), e;
|
|
3
|
+
return a && ["path", "query", "headers", "cookies"].some((s) => a.parameters?.[s]?.some((r) => {
|
|
4
|
+
r.required && r.value === "" && e.add(r.key);
|
|
5
|
+
})), e;
|
|
9
6
|
};
|
|
10
7
|
export {
|
|
11
|
-
|
|
8
|
+
n as validateParameters
|
|
12
9
|
};
|
|
@@ -1,32 +1,26 @@
|
|
|
1
|
-
const
|
|
2
|
-
const
|
|
3
|
-
return
|
|
4
|
-
const
|
|
5
|
-
|
|
1
|
+
const s = ({ plugins: a = [] }) => {
|
|
2
|
+
const t = /* @__PURE__ */ new Map();
|
|
3
|
+
return a.forEach((r) => {
|
|
4
|
+
const e = r();
|
|
5
|
+
t.set(e.name, e);
|
|
6
6
|
}), {
|
|
7
7
|
/**
|
|
8
8
|
* Get all components for a specific view
|
|
9
9
|
*/
|
|
10
|
-
getViewComponents: (
|
|
11
|
-
var t;
|
|
12
|
-
return ((t = r.views) == null ? void 0 : t[n]) || [];
|
|
13
|
-
}),
|
|
10
|
+
getViewComponents: (r) => Array.from(t.values()).flatMap((e) => e.views?.[r] || []),
|
|
14
11
|
/**
|
|
15
12
|
* Execute a hook for a specific event
|
|
16
13
|
*/
|
|
17
|
-
executeHook: (
|
|
18
|
-
const
|
|
19
|
-
(
|
|
20
|
-
var s;
|
|
21
|
-
return ((s = e.hooks) == null ? void 0 : s[n]) || [];
|
|
22
|
-
}
|
|
14
|
+
executeHook: (r, ...e) => {
|
|
15
|
+
const o = Array.from(t.values()).flatMap(
|
|
16
|
+
(n) => n.hooks?.[r] || []
|
|
23
17
|
);
|
|
24
18
|
return Promise.all(
|
|
25
|
-
|
|
19
|
+
o.filter((n) => n != null).map((n) => n?.(...e))
|
|
26
20
|
);
|
|
27
21
|
}
|
|
28
22
|
};
|
|
29
23
|
};
|
|
30
24
|
export {
|
|
31
|
-
|
|
25
|
+
s as createPluginManager
|
|
32
26
|
};
|