dub 0.10.0 → 0.20.2
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/.github/workflows/sdk_generation.yaml +26 -0
- package/.github/workflows/sdk_publish.yaml +15 -0
- package/.speakeasy/gen.lock +205 -0
- package/.speakeasy/gen.yaml +37 -0
- package/.speakeasy/workflow.yaml +12 -0
- package/README.md +292 -182
- package/docs/sdks/analytics/README.md +535 -0
- package/docs/sdks/dub/README.md +9 -0
- package/docs/sdks/links/README.md +415 -0
- package/docs/sdks/qrcodes/README.md +58 -0
- package/docs/sdks/tags/README.md +113 -0
- package/docs/sdks/workspaces/README.md +168 -0
- package/hooks/hooks.d.ts +20 -0
- package/hooks/hooks.d.ts.map +1 -0
- package/hooks/hooks.js +55 -0
- package/hooks/hooks.js.map +1 -0
- package/hooks/index.d.ts +3 -0
- package/hooks/index.d.ts.map +1 -0
- package/{_shims/auto/runtime-bun.js → hooks/index.js} +6 -5
- package/hooks/index.js.map +1 -0
- package/hooks/types.d.ts +59 -0
- package/hooks/types.d.ts.map +1 -0
- package/hooks/types.js +6 -0
- package/hooks/types.js.map +1 -0
- package/index.d.ts +4 -125
- package/index.d.ts.map +1 -1
- package/index.js +10 -103
- package/index.js.map +1 -1
- package/lib/base64.d.ts +10 -0
- package/lib/base64.d.ts.map +1 -0
- package/lib/base64.js +61 -0
- package/lib/base64.js.map +1 -0
- package/lib/config.d.ts +39 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +39 -0
- package/lib/config.js.map +1 -0
- package/lib/encodings.d.ts +39 -0
- package/lib/encodings.d.ts.map +1 -0
- package/lib/encodings.js +311 -0
- package/lib/encodings.js.map +1 -0
- package/lib/http.d.ts +46 -0
- package/lib/http.d.ts.map +1 -0
- package/lib/http.js +143 -0
- package/lib/http.js.map +1 -0
- package/lib/retries.d.ts +18 -0
- package/lib/retries.d.ts.map +1 -0
- package/lib/retries.js +157 -0
- package/lib/retries.js.map +1 -0
- package/lib/schemas.d.ts +7 -0
- package/lib/schemas.d.ts.map +1 -0
- package/{shims/web.js → lib/schemas.js} +24 -6
- package/lib/schemas.js.map +1 -0
- package/lib/sdks.d.ts +39 -0
- package/lib/sdks.d.ts.map +1 -0
- package/lib/sdks.js +98 -0
- package/lib/sdks.js.map +1 -0
- package/lib/security.d.ts +57 -0
- package/lib/security.d.ts.map +1 -0
- package/lib/security.js +115 -0
- package/lib/security.js.map +1 -0
- package/lib/url.d.ts +4 -0
- package/lib/url.d.ts.map +1 -0
- package/lib/url.js +26 -0
- package/lib/url.js.map +1 -0
- package/models/components/index.d.ts +5 -0
- package/models/components/index.d.ts.map +1 -0
- package/{_shims/auto/runtime-node.js → models/components/index.js} +8 -5
- package/models/components/index.js.map +1 -0
- package/models/components/linkschema.d.ts +222 -0
- package/models/components/linkschema.d.ts.map +1 -0
- package/models/components/linkschema.js +189 -0
- package/models/components/linkschema.js.map +1 -0
- package/models/components/security.d.ts +16 -0
- package/models/components/security.d.ts.map +1 -0
- package/models/components/security.js +53 -0
- package/models/components/security.js.map +1 -0
- package/models/components/tagschema.d.ts +45 -0
- package/models/components/tagschema.d.ts.map +1 -0
- package/models/components/tagschema.js +76 -0
- package/models/components/tagschema.js.map +1 -0
- package/models/components/workspaceschema.d.ts +178 -0
- package/models/components/workspaceschema.d.ts.map +1 -0
- package/models/components/workspaceschema.js +190 -0
- package/models/components/workspaceschema.js.map +1 -0
- package/models/errors/badrequest.d.ts +65 -0
- package/models/errors/badrequest.d.ts.map +1 -0
- package/models/errors/badrequest.js +111 -0
- package/models/errors/badrequest.js.map +1 -0
- package/models/errors/conflict.d.ts +65 -0
- package/models/errors/conflict.d.ts.map +1 -0
- package/models/errors/conflict.js +111 -0
- package/models/errors/conflict.js.map +1 -0
- package/models/errors/forbidden.d.ts +65 -0
- package/models/errors/forbidden.d.ts.map +1 -0
- package/models/errors/forbidden.js +111 -0
- package/models/errors/forbidden.js.map +1 -0
- package/models/errors/index.d.ts +12 -0
- package/models/errors/index.d.ts.map +1 -0
- package/{_shims/auto/types-node.js → models/errors/index.js} +15 -5
- package/models/errors/index.js.map +1 -0
- package/models/errors/internalservererror.d.ts +65 -0
- package/models/errors/internalservererror.d.ts.map +1 -0
- package/models/errors/internalservererror.js +111 -0
- package/models/errors/internalservererror.js.map +1 -0
- package/models/errors/inviteexpired.d.ts +65 -0
- package/models/errors/inviteexpired.d.ts.map +1 -0
- package/models/errors/inviteexpired.js +111 -0
- package/models/errors/inviteexpired.js.map +1 -0
- package/models/errors/notfound.d.ts +65 -0
- package/models/errors/notfound.d.ts.map +1 -0
- package/models/errors/notfound.js +111 -0
- package/models/errors/notfound.js.map +1 -0
- package/models/errors/ratelimitexceeded.d.ts +65 -0
- package/models/errors/ratelimitexceeded.d.ts.map +1 -0
- package/models/errors/ratelimitexceeded.js +111 -0
- package/models/errors/ratelimitexceeded.js.map +1 -0
- package/models/errors/sdkerror.d.ts +7 -0
- package/models/errors/sdkerror.d.ts.map +1 -0
- package/models/errors/sdkerror.js +19 -0
- package/models/errors/sdkerror.js.map +1 -0
- package/models/errors/sdkvalidationerror.d.ts +17 -0
- package/models/errors/sdkvalidationerror.d.ts.map +1 -0
- package/models/errors/sdkvalidationerror.js +107 -0
- package/models/errors/sdkvalidationerror.js.map +1 -0
- package/models/errors/unauthorized.d.ts +65 -0
- package/models/errors/unauthorized.d.ts.map +1 -0
- package/models/errors/unauthorized.js +111 -0
- package/models/errors/unauthorized.js.map +1 -0
- package/models/errors/unprocessableentity.d.ts +65 -0
- package/models/errors/unprocessableentity.d.ts.map +1 -0
- package/models/errors/unprocessableentity.js +111 -0
- package/models/errors/unprocessableentity.js.map +1 -0
- package/models/operations/bulkcreatelinks.d.ts +146 -0
- package/models/operations/bulkcreatelinks.d.ts.map +1 -0
- package/models/operations/bulkcreatelinks.js +138 -0
- package/models/operations/bulkcreatelinks.js.map +1 -0
- package/models/operations/createlink.d.ts +146 -0
- package/models/operations/createlink.d.ts.map +1 -0
- package/models/operations/createlink.js +141 -0
- package/models/operations/createlink.js.map +1 -0
- package/models/operations/createtag.d.ts +39 -0
- package/models/operations/createtag.d.ts.map +1 -0
- package/models/operations/createtag.js +72 -0
- package/models/operations/createtag.js.map +1 -0
- package/models/operations/createworkspace.d.ts +22 -0
- package/models/operations/createworkspace.d.ts.map +1 -0
- package/models/operations/createworkspace.js +61 -0
- package/models/operations/createworkspace.js.map +1 -0
- package/models/operations/deletelink.d.ts +39 -0
- package/models/operations/deletelink.d.ts.map +1 -0
- package/models/operations/deletelink.js +75 -0
- package/models/operations/deletelink.js.map +1 -0
- package/models/operations/editlink.d.ts +166 -0
- package/models/operations/editlink.d.ts.map +1 -0
- package/models/operations/editlink.js +167 -0
- package/models/operations/editlink.js.map +1 -0
- package/models/operations/getbrowseranalytics.d.ts +378 -0
- package/models/operations/getbrowseranalytics.d.ts.map +1 -0
- package/models/operations/getbrowseranalytics.js +395 -0
- package/models/operations/getbrowseranalytics.js.map +1 -0
- package/models/operations/getcityanalytics.d.ts +641 -0
- package/models/operations/getcityanalytics.d.ts.map +1 -0
- package/models/operations/getcityanalytics.js +657 -0
- package/models/operations/getcityanalytics.js.map +1 -0
- package/models/operations/getclicksanalytics.d.ts +355 -0
- package/models/operations/getclicksanalytics.d.ts.map +1 -0
- package/models/operations/getclicksanalytics.js +369 -0
- package/models/operations/getclicksanalytics.js.map +1 -0
- package/models/operations/getcountryanalytics.d.ts +635 -0
- package/models/operations/getcountryanalytics.d.ts.map +1 -0
- package/models/operations/getcountryanalytics.js +653 -0
- package/models/operations/getcountryanalytics.js.map +1 -0
- package/models/operations/getdeviceanalytics.d.ts +378 -0
- package/models/operations/getdeviceanalytics.d.ts.map +1 -0
- package/models/operations/getdeviceanalytics.js +395 -0
- package/models/operations/getdeviceanalytics.js.map +1 -0
- package/models/operations/getlinkinfo.d.ts +25 -0
- package/models/operations/getlinkinfo.d.ts.map +1 -0
- package/models/operations/getlinkinfo.js +57 -0
- package/models/operations/getlinkinfo.js.map +1 -0
- package/models/operations/getlinks.d.ts +88 -0
- package/models/operations/getlinks.d.ts.map +1 -0
- package/models/operations/getlinks.js +108 -0
- package/models/operations/getlinks.js.map +1 -0
- package/models/operations/getlinkscount.d.ts +93 -0
- package/models/operations/getlinkscount.d.ts.map +1 -0
- package/models/operations/getlinkscount.js +105 -0
- package/models/operations/getlinkscount.js.map +1 -0
- package/models/operations/getosanalytics.d.ts +378 -0
- package/models/operations/getosanalytics.d.ts.map +1 -0
- package/models/operations/getosanalytics.js +395 -0
- package/models/operations/getosanalytics.js.map +1 -0
- package/models/operations/getqrcode.d.ts +60 -0
- package/models/operations/getqrcode.d.ts.map +1 -0
- package/models/operations/getqrcode.js +85 -0
- package/models/operations/getqrcode.js.map +1 -0
- package/models/operations/getrefereranalytics.d.ts +378 -0
- package/models/operations/getrefereranalytics.d.ts.map +1 -0
- package/models/operations/getrefereranalytics.js +395 -0
- package/models/operations/getrefereranalytics.js.map +1 -0
- package/models/operations/gettags.d.ts +10 -0
- package/models/operations/gettags.d.ts.map +1 -0
- package/{shims/node.js → models/operations/gettags.js} +12 -6
- package/models/operations/gettags.js.map +1 -0
- package/models/operations/gettimeseriesanalytics.d.ts +378 -0
- package/models/operations/gettimeseriesanalytics.d.ts.map +1 -0
- package/models/operations/gettimeseriesanalytics.js +395 -0
- package/models/operations/gettimeseriesanalytics.js.map +1 -0
- package/models/operations/gettoplinks.d.ts +378 -0
- package/models/operations/gettoplinks.d.ts.map +1 -0
- package/models/operations/gettoplinks.js +395 -0
- package/models/operations/gettoplinks.js.map +1 -0
- package/models/operations/gettopurls.d.ts +378 -0
- package/models/operations/gettopurls.d.ts.map +1 -0
- package/models/operations/gettopurls.js +395 -0
- package/models/operations/gettopurls.js.map +1 -0
- package/models/operations/getworkspace.d.ts +19 -0
- package/models/operations/getworkspace.d.ts.map +1 -0
- package/models/operations/getworkspace.js +53 -0
- package/models/operations/getworkspace.js.map +1 -0
- package/models/operations/index.d.ts +23 -0
- package/models/operations/index.d.ts.map +1 -0
- package/models/operations/index.js +42 -0
- package/models/operations/index.js.map +1 -0
- package/package.json +25 -98
- package/sdk/analytics.d.ts +78 -0
- package/sdk/analytics.d.ts.map +1 -0
- package/sdk/analytics.js +2044 -0
- package/sdk/analytics.js.map +1 -0
- package/sdk/index.d.ts +2 -0
- package/sdk/index.d.ts.map +1 -0
- package/{_shims/auto/runtime.js → sdk/index.js} +5 -5
- package/sdk/index.js.map +1 -0
- package/sdk/links.d.ts +58 -0
- package/sdk/links.d.ts.map +1 -0
- package/sdk/links.js +1309 -0
- package/sdk/links.js.map +1 -0
- package/sdk/qrcodes.d.ts +21 -0
- package/sdk/qrcodes.d.ts.map +1 -0
- package/sdk/qrcodes.js +249 -0
- package/sdk/qrcodes.js.map +1 -0
- package/sdk/sdk.d.ts +22 -0
- package/sdk/sdk.d.ts.map +1 -0
- package/sdk/sdk.js +59 -0
- package/sdk/sdk.js.map +1 -0
- package/sdk/tags.d.ts +23 -0
- package/sdk/tags.d.ts.map +1 -0
- package/sdk/tags.js +401 -0
- package/sdk/tags.js.map +1 -0
- package/sdk/workspaces.d.ts +30 -0
- package/sdk/workspaces.d.ts.map +1 -0
- package/sdk/workspaces.js +556 -0
- package/sdk/workspaces.js.map +1 -0
- package/src/hooks/hooks.ts +81 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/types.ts +74 -0
- package/src/index.ts +8 -209
- package/src/lib/base64.ts +37 -0
- package/src/lib/config.ts +70 -0
- package/src/lib/encodings.ts +384 -0
- package/src/lib/http.ts +215 -0
- package/src/lib/retries.ts +226 -0
- package/src/lib/schemas.ts +22 -0
- package/src/lib/sdks.ts +139 -0
- package/src/lib/security.ts +180 -0
- package/src/lib/url.ts +31 -0
- package/src/models/components/index.ts +8 -0
- package/src/models/components/linkschema.ts +383 -0
- package/src/models/components/security.ts +40 -0
- package/src/models/components/tagschema.ts +79 -0
- package/src/models/components/workspaceschema.ts +316 -0
- package/src/models/errors/badrequest.ts +140 -0
- package/src/models/errors/conflict.ts +140 -0
- package/src/models/errors/forbidden.ts +140 -0
- package/src/models/errors/index.ts +15 -0
- package/src/models/errors/internalservererror.ts +140 -0
- package/src/models/errors/inviteexpired.ts +140 -0
- package/src/models/errors/notfound.ts +140 -0
- package/src/models/errors/ratelimitexceeded.ts +140 -0
- package/src/models/errors/sdkerror.ts +22 -0
- package/src/models/errors/sdkvalidationerror.ts +95 -0
- package/src/models/errors/unauthorized.ts +140 -0
- package/src/models/errors/unprocessableentity.ts +140 -0
- package/src/models/operations/bulkcreatelinks.ts +254 -0
- package/src/models/operations/createlink.ts +255 -0
- package/src/models/operations/createtag.ts +69 -0
- package/src/models/operations/createworkspace.ts +54 -0
- package/src/models/operations/deletelink.ts +84 -0
- package/src/models/operations/editlink.ts +300 -0
- package/src/models/operations/getbrowseranalytics.ts +484 -0
- package/src/models/operations/getcityanalytics.ts +744 -0
- package/src/models/operations/getclicksanalytics.ts +427 -0
- package/src/models/operations/getcountryanalytics.ts +743 -0
- package/src/models/operations/getdeviceanalytics.ts +480 -0
- package/src/models/operations/getlinkinfo.ts +53 -0
- package/src/models/operations/getlinks.ts +155 -0
- package/src/models/operations/getlinkscount.ts +157 -0
- package/src/models/operations/getosanalytics.ts +475 -0
- package/src/models/operations/getqrcode.ts +106 -0
- package/src/models/operations/getrefereranalytics.ts +484 -0
- package/src/models/operations/gettags.ts +18 -0
- package/src/models/operations/gettimeseriesanalytics.ts +476 -0
- package/src/models/operations/gettoplinks.ts +475 -0
- package/src/models/operations/gettopurls.ts +475 -0
- package/src/models/operations/getworkspace.ts +43 -0
- package/src/models/operations/index.ts +26 -0
- package/src/sdk/analytics.ts +2493 -0
- package/src/sdk/index.ts +5 -0
- package/src/sdk/links.ts +1617 -0
- package/src/sdk/qrcodes.ts +276 -0
- package/src/sdk/sdk.ts +66 -0
- package/src/sdk/tags.ts +470 -0
- package/src/sdk/workspaces.ts +670 -0
- package/src/types/blobs.ts +30 -0
- package/src/types/index.ts +8 -0
- package/src/types/operations.ts +25 -0
- package/src/types/rfcdate.ts +54 -0
- package/types/blobs.d.ts +4 -0
- package/types/blobs.d.ts.map +1 -0
- package/{resources/projects/projects.js → types/blobs.js} +23 -24
- package/types/blobs.js.map +1 -0
- package/types/index.d.ts +5 -0
- package/types/index.d.ts.map +1 -0
- package/types/index.js +14 -0
- package/types/index.js.map +1 -0
- package/types/operations.d.ts +13 -0
- package/types/operations.d.ts.map +1 -0
- package/types/operations.js +19 -0
- package/types/operations.js.map +1 -0
- package/types/rfcdate.d.ts +21 -0
- package/types/rfcdate.d.ts.map +1 -0
- package/types/rfcdate.js +46 -0
- package/types/rfcdate.js.map +1 -0
- package/CHANGELOG.md +0 -116
- package/LICENSE +0 -201
- package/_shims/MultipartBody.d.ts +0 -9
- package/_shims/MultipartBody.d.ts.map +0 -1
- package/_shims/MultipartBody.js +0 -16
- package/_shims/MultipartBody.js.map +0 -1
- package/_shims/MultipartBody.mjs +0 -12
- package/_shims/MultipartBody.mjs.map +0 -1
- package/_shims/README.md +0 -46
- package/_shims/auto/runtime-bun.d.ts +0 -5
- package/_shims/auto/runtime-bun.d.ts.map +0 -1
- package/_shims/auto/runtime-bun.js.map +0 -1
- package/_shims/auto/runtime-bun.mjs +0 -2
- package/_shims/auto/runtime-bun.mjs.map +0 -1
- package/_shims/auto/runtime-node.d.ts +0 -5
- package/_shims/auto/runtime-node.d.ts.map +0 -1
- package/_shims/auto/runtime-node.js.map +0 -1
- package/_shims/auto/runtime-node.mjs +0 -2
- package/_shims/auto/runtime-node.mjs.map +0 -1
- package/_shims/auto/runtime.d.ts +0 -5
- package/_shims/auto/runtime.d.ts.map +0 -1
- package/_shims/auto/runtime.js.map +0 -1
- package/_shims/auto/runtime.mjs +0 -2
- package/_shims/auto/runtime.mjs.map +0 -1
- package/_shims/auto/types-node.d.ts +0 -5
- package/_shims/auto/types-node.d.ts.map +0 -1
- package/_shims/auto/types-node.js.map +0 -1
- package/_shims/auto/types-node.mjs +0 -2
- package/_shims/auto/types-node.mjs.map +0 -1
- package/_shims/auto/types.d.ts +0 -101
- package/_shims/auto/types.js +0 -3
- package/_shims/auto/types.mjs +0 -3
- package/_shims/bun-runtime.d.ts +0 -6
- package/_shims/bun-runtime.d.ts.map +0 -1
- package/_shims/bun-runtime.js +0 -14
- package/_shims/bun-runtime.js.map +0 -1
- package/_shims/bun-runtime.mjs +0 -10
- package/_shims/bun-runtime.mjs.map +0 -1
- package/_shims/index.d.ts +0 -81
- package/_shims/index.js +0 -13
- package/_shims/index.mjs +0 -7
- package/_shims/manual-types.d.ts +0 -12
- package/_shims/manual-types.js +0 -3
- package/_shims/manual-types.mjs +0 -3
- package/_shims/node-runtime.d.ts +0 -3
- package/_shims/node-runtime.d.ts.map +0 -1
- package/_shims/node-runtime.js +0 -90
- package/_shims/node-runtime.js.map +0 -1
- package/_shims/node-runtime.mjs +0 -56
- package/_shims/node-runtime.mjs.map +0 -1
- package/_shims/node-types.d.ts +0 -42
- package/_shims/node-types.js +0 -3
- package/_shims/node-types.mjs +0 -3
- package/_shims/registry.d.ts +0 -37
- package/_shims/registry.d.ts.map +0 -1
- package/_shims/registry.js +0 -41
- package/_shims/registry.js.map +0 -1
- package/_shims/registry.mjs +0 -37
- package/_shims/registry.mjs.map +0 -1
- package/_shims/web-runtime.d.ts +0 -5
- package/_shims/web-runtime.d.ts.map +0 -1
- package/_shims/web-runtime.js +0 -78
- package/_shims/web-runtime.js.map +0 -1
- package/_shims/web-runtime.mjs +0 -71
- package/_shims/web-runtime.mjs.map +0 -1
- package/_shims/web-types.d.ts +0 -83
- package/_shims/web-types.js +0 -3
- package/_shims/web-types.mjs +0 -3
- package/core.d.ts +0 -237
- package/core.d.ts.map +0 -1
- package/core.js +0 -868
- package/core.js.map +0 -1
- package/core.mjs +0 -837
- package/core.mjs.map +0 -1
- package/error.d.ts +0 -53
- package/error.d.ts.map +0 -1
- package/error.js +0 -143
- package/error.js.map +0 -1
- package/error.mjs +0 -127
- package/error.mjs.map +0 -1
- package/index.d.mts +0 -127
- package/index.mjs +0 -90
- package/index.mjs.map +0 -1
- package/resource.d.ts +0 -6
- package/resource.d.ts.map +0 -1
- package/resource.js +0 -11
- package/resource.js.map +0 -1
- package/resource.mjs +0 -7
- package/resource.mjs.map +0 -1
- package/resources/index.d.ts +0 -4
- package/resources/index.d.ts.map +0 -1
- package/resources/index.js +0 -11
- package/resources/index.js.map +0 -1
- package/resources/index.mjs +0 -5
- package/resources/index.mjs.map +0 -1
- package/resources/links/bulk.d.ts +0 -274
- package/resources/links/bulk.d.ts.map +0 -1
- package/resources/links/bulk.js +0 -18
- package/resources/links/bulk.js.map +0 -1
- package/resources/links/bulk.mjs +0 -14
- package/resources/links/bulk.mjs.map +0 -1
- package/resources/links/index.d.ts +0 -4
- package/resources/links/index.d.ts.map +0 -1
- package/resources/links/index.js +0 -11
- package/resources/links/index.js.map +0 -1
- package/resources/links/index.mjs +0 -5
- package/resources/links/index.mjs.map +0 -1
- package/resources/links/info.d.ts +0 -186
- package/resources/links/info.d.ts.map +0 -1
- package/resources/links/info.js +0 -18
- package/resources/links/info.js.map +0 -1
- package/resources/links/info.mjs +0 -14
- package/resources/links/info.mjs.map +0 -1
- package/resources/links/links.d.ts +0 -916
- package/resources/links/links.d.ts.map +0 -1
- package/resources/links/links.js +0 -72
- package/resources/links/links.js.map +0 -1
- package/resources/links/links.mjs +0 -45
- package/resources/links/links.mjs.map +0 -1
- package/resources/projects/index.d.ts +0 -3
- package/resources/projects/index.d.ts.map +0 -1
- package/resources/projects/index.js +0 -9
- package/resources/projects/index.js.map +0 -1
- package/resources/projects/index.mjs +0 -4
- package/resources/projects/index.mjs.map +0 -1
- package/resources/projects/projects.d.ts +0 -200
- package/resources/projects/projects.d.ts.map +0 -1
- package/resources/projects/projects.js.map +0 -1
- package/resources/projects/projects.mjs +0 -26
- package/resources/projects/projects.mjs.map +0 -1
- package/resources/projects/tags.d.ts +0 -4
- package/resources/projects/tags.d.ts.map +0 -1
- package/resources/projects/tags.js +0 -9
- package/resources/projects/tags.js.map +0 -1
- package/resources/projects/tags.mjs +0 -5
- package/resources/projects/tags.mjs.map +0 -1
- package/resources/qr.d.ts +0 -45
- package/resources/qr.d.ts.map +0 -1
- package/resources/qr.js +0 -18
- package/resources/qr.js.map +0 -1
- package/resources/qr.mjs +0 -14
- package/resources/qr.mjs.map +0 -1
- package/shims/node.d.ts +0 -29
- package/shims/node.d.ts.map +0 -1
- package/shims/node.js.map +0 -1
- package/shims/node.mjs +0 -5
- package/shims/node.mjs.map +0 -1
- package/shims/web.d.ts +0 -26
- package/shims/web.d.ts.map +0 -1
- package/shims/web.js.map +0 -1
- package/shims/web.mjs +0 -5
- package/shims/web.mjs.map +0 -1
- package/src/_shims/MultipartBody.ts +0 -9
- package/src/_shims/README.md +0 -46
- package/src/_shims/auto/runtime-bun.ts +0 -4
- package/src/_shims/auto/runtime-node.ts +0 -4
- package/src/_shims/auto/runtime.ts +0 -4
- package/src/_shims/auto/types-node.ts +0 -4
- package/src/_shims/auto/types.d.ts +0 -101
- package/src/_shims/auto/types.js +0 -3
- package/src/_shims/auto/types.mjs +0 -3
- package/src/_shims/bun-runtime.ts +0 -14
- package/src/_shims/index.d.ts +0 -81
- package/src/_shims/index.js +0 -13
- package/src/_shims/index.mjs +0 -7
- package/src/_shims/manual-types.d.ts +0 -12
- package/src/_shims/manual-types.js +0 -3
- package/src/_shims/manual-types.mjs +0 -3
- package/src/_shims/node-runtime.ts +0 -83
- package/src/_shims/node-types.d.ts +0 -42
- package/src/_shims/node-types.js +0 -3
- package/src/_shims/node-types.mjs +0 -3
- package/src/_shims/registry.ts +0 -63
- package/src/_shims/web-runtime.ts +0 -103
- package/src/_shims/web-types.d.ts +0 -83
- package/src/_shims/web-types.js +0 -3
- package/src/_shims/web-types.mjs +0 -3
- package/src/core.ts +0 -1145
- package/src/error.ts +0 -146
- package/src/lib/.keep +0 -4
- package/src/resource.ts +0 -11
- package/src/resources/index.ts +0 -20
- package/src/resources/links/bulk.ts +0 -337
- package/src/resources/links/index.ts +0 -15
- package/src/resources/links/info.ts +0 -230
- package/src/resources/links/links.ts +0 -1135
- package/src/resources/projects/index.ts +0 -4
- package/src/resources/projects/projects.ts +0 -253
- package/src/resources/projects/tags.ts +0 -5
- package/src/resources/qr.ts +0 -64
- package/src/shims/node.ts +0 -50
- package/src/shims/web.ts +0 -50
- package/src/tsconfig.json +0 -11
- package/src/uploads.ts +0 -245
- package/src/version.ts +0 -1
- package/uploads.d.ts +0 -75
- package/uploads.d.ts.map +0 -1
- package/uploads.js +0 -163
- package/uploads.js.map +0 -1
- package/uploads.mjs +0 -150
- package/uploads.mjs.map +0 -1
- package/version.d.ts +0 -2
- package/version.d.ts.map +0 -1
- package/version.js +0 -5
- package/version.js.map +0 -1
- package/version.mjs +0 -2
- package/version.mjs.map +0 -1
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
export type BackoffStrategy = {
|
|
6
|
+
initialInterval: number;
|
|
7
|
+
maxInterval: number;
|
|
8
|
+
exponent: number;
|
|
9
|
+
maxElapsedTime: number;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
const defaultBackoff: BackoffStrategy = {
|
|
13
|
+
initialInterval: 500,
|
|
14
|
+
maxInterval: 60000,
|
|
15
|
+
exponent: 1.5,
|
|
16
|
+
maxElapsedTime: 3600000,
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export type RetryConfig =
|
|
20
|
+
| { strategy: "none" }
|
|
21
|
+
| {
|
|
22
|
+
strategy: "backoff";
|
|
23
|
+
backoff?: BackoffStrategy;
|
|
24
|
+
retryConnectionErrors?: boolean;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
class PermanentError extends Error {
|
|
28
|
+
inner: unknown;
|
|
29
|
+
|
|
30
|
+
constructor(inner: unknown) {
|
|
31
|
+
super("Permanent error");
|
|
32
|
+
this.inner = inner;
|
|
33
|
+
|
|
34
|
+
Object.setPrototypeOf(this, PermanentError.prototype);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
class TemporaryError extends Error {
|
|
39
|
+
res: Response;
|
|
40
|
+
|
|
41
|
+
constructor(res: Response) {
|
|
42
|
+
super("Temporary error");
|
|
43
|
+
this.res = res;
|
|
44
|
+
|
|
45
|
+
Object.setPrototypeOf(this, TemporaryError.prototype);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export async function retry(
|
|
50
|
+
fetchFn: () => Promise<Response>,
|
|
51
|
+
options: {
|
|
52
|
+
config: RetryConfig;
|
|
53
|
+
statusCodes: string[];
|
|
54
|
+
},
|
|
55
|
+
): Promise<Response> {
|
|
56
|
+
switch (options.config.strategy) {
|
|
57
|
+
case "backoff":
|
|
58
|
+
return retryBackoff(
|
|
59
|
+
wrapFetcher(fetchFn, {
|
|
60
|
+
statusCodes: options.statusCodes,
|
|
61
|
+
retryConnectionErrors: !!options.config.retryConnectionErrors,
|
|
62
|
+
}),
|
|
63
|
+
options.config.backoff ?? defaultBackoff,
|
|
64
|
+
);
|
|
65
|
+
default:
|
|
66
|
+
return await fetchFn();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function wrapFetcher(
|
|
71
|
+
fn: () => Promise<Response>,
|
|
72
|
+
options: {
|
|
73
|
+
statusCodes: string[];
|
|
74
|
+
retryConnectionErrors: boolean;
|
|
75
|
+
},
|
|
76
|
+
): () => Promise<Response> {
|
|
77
|
+
return async () => {
|
|
78
|
+
try {
|
|
79
|
+
const res = await fn();
|
|
80
|
+
if (isRetryableResponse(res, options.statusCodes)) {
|
|
81
|
+
throw new TemporaryError(res);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
return res;
|
|
85
|
+
} catch (err) {
|
|
86
|
+
if (err instanceof TemporaryError) {
|
|
87
|
+
throw err;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (
|
|
91
|
+
options.retryConnectionErrors &&
|
|
92
|
+
(isTimeoutError(err) || isConnectionError(err))
|
|
93
|
+
) {
|
|
94
|
+
throw err;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
throw new PermanentError(err);
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
function isConnectionError(err: unknown) {
|
|
103
|
+
if (typeof err !== "object" || err == null) {
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// Covers fetch in Deno as well
|
|
108
|
+
const isBrowserErr =
|
|
109
|
+
err instanceof TypeError &&
|
|
110
|
+
err.message.toLowerCase().startsWith("failed to fetch");
|
|
111
|
+
|
|
112
|
+
const isNodeErr =
|
|
113
|
+
err instanceof TypeError &&
|
|
114
|
+
err.message.toLowerCase().startsWith("fetch failed");
|
|
115
|
+
|
|
116
|
+
const isBunErr = "name" in err && err.name === "ConnectionError";
|
|
117
|
+
|
|
118
|
+
const isGenericErr =
|
|
119
|
+
"code" in err &&
|
|
120
|
+
typeof err.code === "string" &&
|
|
121
|
+
err.code.toLowerCase() === "econnreset";
|
|
122
|
+
|
|
123
|
+
return isBrowserErr || isNodeErr || isGenericErr || isBunErr;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
function isTimeoutError(err: unknown) {
|
|
127
|
+
if (typeof err !== "object" || err == null) {
|
|
128
|
+
return false;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// Fetch in browser, Node.js, Bun, Deno
|
|
132
|
+
const isNative = "name" in err && err.name === "TimeoutError";
|
|
133
|
+
|
|
134
|
+
// Node.js HTTP client and Axios
|
|
135
|
+
const isGenericErr =
|
|
136
|
+
"code" in err &&
|
|
137
|
+
typeof err.code === "string" &&
|
|
138
|
+
err.code.toLowerCase() === "econnaborted";
|
|
139
|
+
|
|
140
|
+
return isNative || isGenericErr;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
const codeRangeRE = new RegExp("^[0-9]xx$", "i");
|
|
144
|
+
|
|
145
|
+
function isRetryableResponse(res: Response, statusCodes: string[]): boolean {
|
|
146
|
+
const actual = `${res.status}`;
|
|
147
|
+
|
|
148
|
+
return statusCodes.some((code) => {
|
|
149
|
+
if (!codeRangeRE.test(code)) {
|
|
150
|
+
return code === actual;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
const expectFamily = code.charAt(0);
|
|
154
|
+
if (!expectFamily) {
|
|
155
|
+
throw new Error("Invalid status code range");
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
const actualFamily = actual.charAt(0);
|
|
159
|
+
if (!actualFamily) {
|
|
160
|
+
throw new Error(`Invalid response status code: ${actual}`);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
return actualFamily === expectFamily;
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
async function retryBackoff(
|
|
168
|
+
fn: () => Promise<Response>,
|
|
169
|
+
strategy: BackoffStrategy,
|
|
170
|
+
): Promise<Response> {
|
|
171
|
+
const { maxElapsedTime, initialInterval, exponent, maxInterval } = strategy;
|
|
172
|
+
|
|
173
|
+
const start = Date.now();
|
|
174
|
+
let x = 0;
|
|
175
|
+
|
|
176
|
+
// eslint-disable-next-line no-constant-condition
|
|
177
|
+
while (true) {
|
|
178
|
+
try {
|
|
179
|
+
const res = await fn();
|
|
180
|
+
return res;
|
|
181
|
+
} catch (err) {
|
|
182
|
+
if (err instanceof PermanentError) {
|
|
183
|
+
throw err.inner;
|
|
184
|
+
}
|
|
185
|
+
const elapsed = Date.now() - start;
|
|
186
|
+
if (elapsed > maxElapsedTime) {
|
|
187
|
+
if (err instanceof TemporaryError) {
|
|
188
|
+
return err.res;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
throw err;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
let retryInterval = 0;
|
|
195
|
+
if (err instanceof TemporaryError && err.res && err.res.headers) {
|
|
196
|
+
const retryVal = err.res.headers.get("retry-after") || "";
|
|
197
|
+
if (retryVal != "") {
|
|
198
|
+
const parsedNumber = Number(retryVal);
|
|
199
|
+
if (!isNaN(parsedNumber) && Number.isInteger(parsedNumber)) {
|
|
200
|
+
retryInterval = parsedNumber * 1000;
|
|
201
|
+
} else {
|
|
202
|
+
const parsedDate = Date.parse(retryVal);
|
|
203
|
+
if (!isNaN(parsedDate)) {
|
|
204
|
+
const deltaMS = parsedDate - Date.now();
|
|
205
|
+
retryInterval = deltaMS > 0 ? Math.ceil(deltaMS) : 0;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
if (retryInterval == 0) {
|
|
212
|
+
retryInterval =
|
|
213
|
+
initialInterval * Math.pow(x, exponent) + Math.random() * 1000;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
const d = Math.min(retryInterval, maxInterval);
|
|
217
|
+
|
|
218
|
+
await delay(d);
|
|
219
|
+
x++;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
async function delay(delay: number): Promise<void> {
|
|
225
|
+
return new Promise((resolve) => setTimeout(resolve, delay));
|
|
226
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { ZodError } from "zod";
|
|
6
|
+
import * as errors from "../models/errors";
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Utility function that executes some code which may throw a ZodError. It
|
|
10
|
+
* intercepts this error and converts it to an SDKValidationError so as to not
|
|
11
|
+
* leak Zod implementation details to user code.
|
|
12
|
+
*/
|
|
13
|
+
export function parse<Inp, Out>(rawValue: Inp, fn: (value: Inp) => Out, errorMessage: string): Out {
|
|
14
|
+
try {
|
|
15
|
+
return fn(rawValue);
|
|
16
|
+
} catch (err) {
|
|
17
|
+
if (err instanceof ZodError) {
|
|
18
|
+
throw new errors.SDKValidationError(errorMessage, err, rawValue);
|
|
19
|
+
}
|
|
20
|
+
throw err;
|
|
21
|
+
}
|
|
22
|
+
}
|
package/src/lib/sdks.ts
ADDED
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { HTTPClient, matchResponse, matchStatusCode, unpackHeaders } from "./http";
|
|
6
|
+
import { SecurityState, resolveSecurity, resolveGlobalSecurity } from "./security";
|
|
7
|
+
import { pathToFunc } from "./url";
|
|
8
|
+
import { encodeForm } from "./encodings";
|
|
9
|
+
import { stringToBase64 } from "./base64";
|
|
10
|
+
import { SDKHooks, HookContext } from "../hooks";
|
|
11
|
+
|
|
12
|
+
export type RequestOptions = {
|
|
13
|
+
fetchOptions?: Omit<RequestInit, "method" | "body">;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
type RequestConfig = {
|
|
17
|
+
method: string;
|
|
18
|
+
path: string;
|
|
19
|
+
baseURL?: string | URL;
|
|
20
|
+
query?: string;
|
|
21
|
+
body?: RequestInit["body"];
|
|
22
|
+
headers?: HeadersInit;
|
|
23
|
+
security?: SecurityState | null;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export class ClientSDK {
|
|
27
|
+
private readonly client: HTTPClient;
|
|
28
|
+
protected readonly baseURL: URL | null;
|
|
29
|
+
protected readonly hooks$: SDKHooks;
|
|
30
|
+
|
|
31
|
+
constructor(init: { client: HTTPClient; baseURL: URL | null; hooks: SDKHooks }) {
|
|
32
|
+
const url = init.baseURL;
|
|
33
|
+
if (url) {
|
|
34
|
+
url.pathname = url.pathname.replace(/\/+$/, "") + "/";
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
this.hooks$ = init.hooks;
|
|
38
|
+
const { baseURL, client } = this.hooks$.sdkInit({ baseURL: url, client: init.client });
|
|
39
|
+
this.baseURL = baseURL;
|
|
40
|
+
this.client = client;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
protected createRequest$(conf: RequestConfig, options?: RequestOptions) {
|
|
44
|
+
const { method, path, query, headers: opHeaders, security } = conf;
|
|
45
|
+
|
|
46
|
+
const base = conf.baseURL ?? this.baseURL;
|
|
47
|
+
if (!base) {
|
|
48
|
+
throw new TypeError("No base URL provided for operation");
|
|
49
|
+
}
|
|
50
|
+
const reqURL = new URL(base);
|
|
51
|
+
const inputURL = new URL(path, reqURL);
|
|
52
|
+
|
|
53
|
+
if (path) {
|
|
54
|
+
reqURL.pathname += inputURL.pathname.replace(/^\/+/, "");
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
let finalQuery = query || "";
|
|
58
|
+
|
|
59
|
+
const secQuery: string[] = [];
|
|
60
|
+
for (const [k, v] of Object.entries(security?.queryParams || {})) {
|
|
61
|
+
secQuery.push(encodeForm(k, v, { charEncoding: "percent" }));
|
|
62
|
+
}
|
|
63
|
+
if (secQuery.length) {
|
|
64
|
+
finalQuery += `&${secQuery.join("&")}`;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if (finalQuery) {
|
|
68
|
+
const q = finalQuery.startsWith("&") ? finalQuery.slice(1) : finalQuery;
|
|
69
|
+
reqURL.search = `?${q}`;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const headers = new Headers(opHeaders);
|
|
73
|
+
|
|
74
|
+
const username = security?.basic.username;
|
|
75
|
+
const password = security?.basic.password;
|
|
76
|
+
if (username != null || password != null) {
|
|
77
|
+
const encoded = stringToBase64([username || "", password || ""].join(":"));
|
|
78
|
+
headers.set("Authorization", `Basic ${encoded}`);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const securityHeaders = new Headers(security?.headers || {});
|
|
82
|
+
for (const [k, v] of securityHeaders) {
|
|
83
|
+
headers.set(k, v);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
let cookie = headers.get("cookie") || "";
|
|
87
|
+
for (const [k, v] of Object.entries(security?.cookies || {})) {
|
|
88
|
+
cookie += `; ${k}=${v}`;
|
|
89
|
+
}
|
|
90
|
+
cookie = cookie.startsWith("; ") ? cookie.slice(2) : cookie;
|
|
91
|
+
headers.set("cookie", cookie);
|
|
92
|
+
|
|
93
|
+
const userHeaders = new Headers(options?.fetchOptions?.headers);
|
|
94
|
+
for (const [k, v] of userHeaders) {
|
|
95
|
+
headers.set(k, v);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
return new Request(reqURL, {
|
|
99
|
+
...options?.fetchOptions,
|
|
100
|
+
body: conf.body ?? null,
|
|
101
|
+
headers,
|
|
102
|
+
method,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
protected async do$(
|
|
107
|
+
req: Request,
|
|
108
|
+
options: {
|
|
109
|
+
context: HookContext;
|
|
110
|
+
errorCodes: number | string | (number | string)[];
|
|
111
|
+
}
|
|
112
|
+
) {
|
|
113
|
+
const { context, errorCodes } = options;
|
|
114
|
+
|
|
115
|
+
let response = await this.client.request(await this.hooks$.beforeRequest(context, req));
|
|
116
|
+
|
|
117
|
+
if (this.matchStatusCode(response, errorCodes)) {
|
|
118
|
+
const result = await this.hooks$.afterError(context, response, null);
|
|
119
|
+
if (result.error) {
|
|
120
|
+
throw result.error;
|
|
121
|
+
}
|
|
122
|
+
response = result.response || response;
|
|
123
|
+
} else {
|
|
124
|
+
response = await this.hooks$.afterSuccess(context, response);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return response;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
protected unpackHeaders = unpackHeaders;
|
|
131
|
+
|
|
132
|
+
protected matchStatusCode = matchStatusCode;
|
|
133
|
+
protected matchResponse = matchResponse;
|
|
134
|
+
|
|
135
|
+
protected templateURLComponent = pathToFunc;
|
|
136
|
+
|
|
137
|
+
protected resolveSecurity = resolveSecurity;
|
|
138
|
+
protected resolveGlobalSecurity = resolveGlobalSecurity;
|
|
139
|
+
}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import * as components from "../models/components";
|
|
6
|
+
|
|
7
|
+
export enum SecurityErrorCode {
|
|
8
|
+
Incomplete = "incomplete",
|
|
9
|
+
UnrecognisedSecurityType = "unrecognized_security_type",
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export class SecurityError extends Error {
|
|
13
|
+
constructor(public code: SecurityErrorCode, message: string) {
|
|
14
|
+
super(message);
|
|
15
|
+
this.name = "SecurityError";
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
static incomplete(): SecurityError {
|
|
19
|
+
return new SecurityError(
|
|
20
|
+
SecurityErrorCode.Incomplete,
|
|
21
|
+
"Security requirements not met in order to perform the operation"
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
static unrecognizedType(type: string): SecurityError {
|
|
25
|
+
return new SecurityError(
|
|
26
|
+
SecurityErrorCode.UnrecognisedSecurityType,
|
|
27
|
+
`Unrecognised security type: ${type}`
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export type SecurityState = {
|
|
33
|
+
basic: { username?: string | undefined; password?: string | undefined };
|
|
34
|
+
headers: Record<string, string>;
|
|
35
|
+
queryParams: Record<string, string>;
|
|
36
|
+
cookies: Record<string, string>;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
type SecurityInputBasic = {
|
|
40
|
+
type: "http:basic";
|
|
41
|
+
value: { username?: string | undefined; password?: string | undefined } | null | undefined;
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
type SecurityInputBearer = {
|
|
45
|
+
type: "http:bearer";
|
|
46
|
+
value: string | null | undefined;
|
|
47
|
+
fieldName: string;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
type SecurityInputAPIKey = {
|
|
51
|
+
type: "apiKey:header" | "apiKey:query" | "apiKey:cookie";
|
|
52
|
+
value: string | null | undefined;
|
|
53
|
+
fieldName: string;
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
type SecurityInputOIDC = {
|
|
57
|
+
type: "openIdConnect";
|
|
58
|
+
value: string | null | undefined;
|
|
59
|
+
fieldName: string;
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
type SecurityInputOAuth2 = {
|
|
63
|
+
type: "oauth2";
|
|
64
|
+
value: string | null | undefined;
|
|
65
|
+
fieldName: string;
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
type SecurityInputOAuth2ClientCredentials = {
|
|
69
|
+
type: "oauth2:client_credentials";
|
|
70
|
+
value: string | null | undefined;
|
|
71
|
+
fieldName: "clientID" | "clientSecret";
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
export type SecurityInput =
|
|
75
|
+
| SecurityInputBasic
|
|
76
|
+
| SecurityInputBearer
|
|
77
|
+
| SecurityInputAPIKey
|
|
78
|
+
| SecurityInputOAuth2
|
|
79
|
+
| SecurityInputOAuth2ClientCredentials
|
|
80
|
+
| SecurityInputOIDC;
|
|
81
|
+
|
|
82
|
+
export function resolveSecurity(...options: SecurityInput[][]): SecurityState | null {
|
|
83
|
+
const state: SecurityState = {
|
|
84
|
+
basic: { username: "", password: "" },
|
|
85
|
+
headers: {},
|
|
86
|
+
queryParams: {},
|
|
87
|
+
cookies: {},
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
const option = options.find((opts) => {
|
|
91
|
+
return opts.every((o) => {
|
|
92
|
+
if (o.value == null) {
|
|
93
|
+
return false;
|
|
94
|
+
} else if (o.type === "http:basic") {
|
|
95
|
+
return o.value.username != null || o.value.password != null;
|
|
96
|
+
} else if (typeof o.value === "string") {
|
|
97
|
+
return !!o.value;
|
|
98
|
+
} else {
|
|
99
|
+
throw new Error(
|
|
100
|
+
`Unrecognized security type: ${o.type} (value type: ${typeof o.value})`
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
if (option == null) {
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
option.forEach((spec) => {
|
|
110
|
+
if (spec.value == null) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
const { type } = spec;
|
|
115
|
+
|
|
116
|
+
switch (type) {
|
|
117
|
+
case "apiKey:header":
|
|
118
|
+
state.headers[spec.fieldName] = spec.value;
|
|
119
|
+
break;
|
|
120
|
+
case "apiKey:query":
|
|
121
|
+
state.queryParams[spec.fieldName] = spec.value;
|
|
122
|
+
break;
|
|
123
|
+
case "apiKey:cookie":
|
|
124
|
+
state.cookies[spec.fieldName] = spec.value;
|
|
125
|
+
break;
|
|
126
|
+
case "http:basic":
|
|
127
|
+
applyBasic(state, spec);
|
|
128
|
+
break;
|
|
129
|
+
case "http:bearer":
|
|
130
|
+
applyBearer(state, spec);
|
|
131
|
+
break;
|
|
132
|
+
case "oauth2":
|
|
133
|
+
applyBearer(state, spec);
|
|
134
|
+
break;
|
|
135
|
+
case "oauth2:client_credentials":
|
|
136
|
+
break;
|
|
137
|
+
case "openIdConnect":
|
|
138
|
+
applyBearer(state, spec);
|
|
139
|
+
break;
|
|
140
|
+
default:
|
|
141
|
+
spec satisfies never;
|
|
142
|
+
throw SecurityError.unrecognizedType(type);
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
return state;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
function applyBasic(state: SecurityState, spec: SecurityInputBasic) {
|
|
150
|
+
if (spec.value == null) {
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
state.basic = spec.value;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
function applyBearer(
|
|
158
|
+
state: SecurityState,
|
|
159
|
+
spec: SecurityInputBearer | SecurityInputOAuth2 | SecurityInputOIDC
|
|
160
|
+
) {
|
|
161
|
+
if (spec.value == null) {
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
let value = spec.value;
|
|
166
|
+
if (value.slice(0, 7).toLowerCase() !== "bearer ") {
|
|
167
|
+
value = `Bearer ${value}`;
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
state.headers[spec.fieldName] = value;
|
|
171
|
+
}
|
|
172
|
+
export function resolveGlobalSecurity(security: Partial<components.Security> | null | undefined) {
|
|
173
|
+
return resolveSecurity([
|
|
174
|
+
{
|
|
175
|
+
fieldName: "Authorization",
|
|
176
|
+
type: "http:bearer",
|
|
177
|
+
value: security?.token,
|
|
178
|
+
},
|
|
179
|
+
]);
|
|
180
|
+
}
|
package/src/lib/url.ts
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasyapi.dev). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
const hasOwn = Object.prototype.hasOwnProperty;
|
|
6
|
+
|
|
7
|
+
export function pathToFunc(
|
|
8
|
+
pathPattern: string,
|
|
9
|
+
options?: { charEncoding?: "percent" | "none" },
|
|
10
|
+
): (params?: Record<string, string | number>) => string {
|
|
11
|
+
const paramRE = /\{([a-zA-Z0-9_]+?)\}/g;
|
|
12
|
+
|
|
13
|
+
return function buildURLPath(params: Record<string, unknown> = {}): string {
|
|
14
|
+
return pathPattern.replace(paramRE, function (_, placeholder) {
|
|
15
|
+
if (!hasOwn.call(params, placeholder)) {
|
|
16
|
+
throw new Error(`Parameter '${placeholder}' is required`);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const value = params[placeholder];
|
|
20
|
+
if (typeof value !== "string" && typeof value !== "number") {
|
|
21
|
+
throw new Error(
|
|
22
|
+
`Parameter '${placeholder}' must be a string or number`,
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
return options?.charEncoding === "percent"
|
|
27
|
+
? encodeURIComponent(`${value}`)
|
|
28
|
+
: `${value}`;
|
|
29
|
+
});
|
|
30
|
+
};
|
|
31
|
+
}
|