@ominity/api-typescript 0.0.1
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/FUNCTIONS.md +38 -0
- package/LICENSE.md +8 -0
- package/README.md +468 -0
- package/RUNTIMES.md +48 -0
- package/dist/commonjs/core.d.ts +10 -0
- package/dist/commonjs/core.d.ts.map +1 -0
- package/dist/commonjs/core.js +14 -0
- package/dist/commonjs/core.js.map +1 -0
- package/dist/commonjs/hooks/hooks.d.ts +25 -0
- package/dist/commonjs/hooks/hooks.d.ts.map +1 -0
- package/dist/commonjs/hooks/hooks.js +83 -0
- package/dist/commonjs/hooks/hooks.js.map +1 -0
- package/dist/commonjs/hooks/index.d.ts +3 -0
- package/dist/commonjs/hooks/index.d.ts.map +1 -0
- package/dist/commonjs/hooks/index.js +19 -0
- package/dist/commonjs/hooks/index.js.map +1 -0
- package/dist/commonjs/hooks/ominity-hooks.d.ts +12 -0
- package/dist/commonjs/hooks/ominity-hooks.d.ts.map +1 -0
- package/dist/commonjs/hooks/ominity-hooks.js +86 -0
- package/dist/commonjs/hooks/ominity-hooks.js.map +1 -0
- package/dist/commonjs/hooks/registration.d.ts +3 -0
- package/dist/commonjs/hooks/registration.d.ts.map +1 -0
- package/dist/commonjs/hooks/registration.js +16 -0
- package/dist/commonjs/hooks/registration.js.map +1 -0
- package/dist/commonjs/hooks/types.d.ts +76 -0
- package/dist/commonjs/hooks/types.d.ts.map +1 -0
- package/dist/commonjs/hooks/types.js +3 -0
- package/dist/commonjs/hooks/types.js.map +1 -0
- package/dist/commonjs/index.d.ts +6 -0
- package/dist/commonjs/index.d.ts.map +1 -0
- package/dist/commonjs/index.js +45 -0
- package/dist/commonjs/index.js.map +1 -0
- package/dist/commonjs/lib/base64.d.ts +10 -0
- package/dist/commonjs/lib/base64.d.ts.map +1 -0
- package/dist/commonjs/lib/base64.js +70 -0
- package/dist/commonjs/lib/base64.js.map +1 -0
- package/dist/commonjs/lib/config.d.ts +52 -0
- package/dist/commonjs/lib/config.d.ts.map +1 -0
- package/dist/commonjs/lib/config.js +33 -0
- package/dist/commonjs/lib/config.js.map +1 -0
- package/dist/commonjs/lib/dlv.d.ts +14 -0
- package/dist/commonjs/lib/dlv.d.ts.map +1 -0
- package/dist/commonjs/lib/dlv.js +46 -0
- package/dist/commonjs/lib/dlv.js.map +1 -0
- package/dist/commonjs/lib/encodings.d.ts +53 -0
- package/dist/commonjs/lib/encodings.d.ts.map +1 -0
- package/dist/commonjs/lib/encodings.js +381 -0
- package/dist/commonjs/lib/encodings.js.map +1 -0
- package/dist/commonjs/lib/env.d.ts +16 -0
- package/dist/commonjs/lib/env.d.ts.map +1 -0
- package/dist/commonjs/lib/env.js +80 -0
- package/dist/commonjs/lib/env.js.map +1 -0
- package/dist/commonjs/lib/files.d.ts +13 -0
- package/dist/commonjs/lib/files.d.ts.map +1 -0
- package/dist/commonjs/lib/files.js +74 -0
- package/dist/commonjs/lib/files.js.map +1 -0
- package/dist/commonjs/lib/http.d.ts +67 -0
- package/dist/commonjs/lib/http.d.ts.map +1 -0
- package/dist/commonjs/lib/http.js +214 -0
- package/dist/commonjs/lib/http.js.map +1 -0
- package/dist/commonjs/lib/is-plain-object.d.ts +2 -0
- package/dist/commonjs/lib/is-plain-object.d.ts.map +1 -0
- package/dist/commonjs/lib/is-plain-object.js +38 -0
- package/dist/commonjs/lib/is-plain-object.js.map +1 -0
- package/dist/commonjs/lib/logger.d.ts +6 -0
- package/dist/commonjs/lib/logger.d.ts.map +1 -0
- package/dist/commonjs/lib/logger.js +3 -0
- package/dist/commonjs/lib/logger.js.map +1 -0
- package/dist/commonjs/lib/matchers.d.ts +59 -0
- package/dist/commonjs/lib/matchers.d.ts.map +1 -0
- package/dist/commonjs/lib/matchers.js +219 -0
- package/dist/commonjs/lib/matchers.js.map +1 -0
- package/dist/commonjs/lib/primitives.d.ts +26 -0
- package/dist/commonjs/lib/primitives.d.ts.map +1 -0
- package/dist/commonjs/lib/primitives.js +108 -0
- package/dist/commonjs/lib/primitives.js.map +1 -0
- package/dist/commonjs/lib/retries.d.ts +38 -0
- package/dist/commonjs/lib/retries.d.ts.map +1 -0
- package/dist/commonjs/lib/retries.js +150 -0
- package/dist/commonjs/lib/retries.js.map +1 -0
- package/dist/commonjs/lib/schemas.d.ts +21 -0
- package/dist/commonjs/lib/schemas.d.ts.map +1 -0
- package/dist/commonjs/lib/schemas.js +92 -0
- package/dist/commonjs/lib/schemas.js.map +1 -0
- package/dist/commonjs/lib/sdks.d.ts +63 -0
- package/dist/commonjs/lib/sdks.d.ts.map +1 -0
- package/dist/commonjs/lib/sdks.js +270 -0
- package/dist/commonjs/lib/sdks.js.map +1 -0
- package/dist/commonjs/lib/security.d.ts +83 -0
- package/dist/commonjs/lib/security.d.ts.map +1 -0
- package/dist/commonjs/lib/security.js +155 -0
- package/dist/commonjs/lib/security.js.map +1 -0
- package/dist/commonjs/lib/url.d.ts +5 -0
- package/dist/commonjs/lib/url.d.ts.map +1 -0
- package/dist/commonjs/lib/url.js +22 -0
- package/dist/commonjs/lib/url.js.map +1 -0
- package/dist/commonjs/models/errors/documentation.d.ts +22 -0
- package/dist/commonjs/models/errors/documentation.d.ts.map +1 -0
- package/dist/commonjs/models/errors/documentation.js +61 -0
- package/dist/commonjs/models/errors/documentation.js.map +1 -0
- package/dist/commonjs/models/errors/error-response-links.d.ts +21 -0
- package/dist/commonjs/models/errors/error-response-links.d.ts.map +1 -0
- package/dist/commonjs/models/errors/error-response-links.js +59 -0
- package/dist/commonjs/models/errors/error-response-links.js.map +1 -0
- package/dist/commonjs/models/errors/error-response.d.ts +56 -0
- package/dist/commonjs/models/errors/error-response.d.ts.map +1 -0
- package/dist/commonjs/models/errors/error-response.js +98 -0
- package/dist/commonjs/models/errors/error-response.js.map +1 -0
- package/dist/commonjs/models/errors/http-client-errors.d.ts +44 -0
- package/dist/commonjs/models/errors/http-client-errors.d.ts.map +1 -0
- package/dist/commonjs/models/errors/http-client-errors.js +75 -0
- package/dist/commonjs/models/errors/http-client-errors.js.map +1 -0
- package/dist/commonjs/models/errors/index.d.ts +9 -0
- package/dist/commonjs/models/errors/index.d.ts.map +1 -0
- package/dist/commonjs/models/errors/index.js +25 -0
- package/dist/commonjs/models/errors/index.js.map +1 -0
- package/dist/commonjs/models/errors/ominity-default-error.d.ts +10 -0
- package/dist/commonjs/models/errors/ominity-default-error.d.ts.map +1 -0
- package/dist/commonjs/models/errors/ominity-default-error.js +31 -0
- package/dist/commonjs/models/errors/ominity-default-error.js.map +1 -0
- package/dist/commonjs/models/errors/ominity-error.d.ts +19 -0
- package/dist/commonjs/models/errors/ominity-error.d.ts.map +1 -0
- package/dist/commonjs/models/errors/ominity-error.js +17 -0
- package/dist/commonjs/models/errors/ominity-error.js.map +1 -0
- package/dist/commonjs/models/errors/response-validation-error.d.ts +26 -0
- package/dist/commonjs/models/errors/response-validation-error.d.ts.map +1 -0
- package/dist/commonjs/models/errors/response-validation-error.js +63 -0
- package/dist/commonjs/models/errors/response-validation-error.js.map +1 -0
- package/dist/commonjs/models/errors/sdk-validation-error.d.ts +21 -0
- package/dist/commonjs/models/errors/sdk-validation-error.d.ts.map +1 -0
- package/dist/commonjs/models/errors/sdk-validation-error.js +79 -0
- package/dist/commonjs/models/errors/sdk-validation-error.js.map +1 -0
- package/dist/commonjs/models/index.d.ts +2 -0
- package/dist/commonjs/models/index.d.ts.map +1 -0
- package/dist/commonjs/models/index.js +18 -0
- package/dist/commonjs/models/index.js.map +1 -0
- package/dist/commonjs/models/operations/index.d.ts +2 -0
- package/dist/commonjs/models/operations/index.d.ts.map +1 -0
- package/dist/commonjs/models/operations/index.js +3 -0
- package/dist/commonjs/models/operations/index.js.map +1 -0
- package/dist/commonjs/models/security.d.ts +19 -0
- package/dist/commonjs/models/security.d.ts.map +1 -0
- package/dist/commonjs/models/security.js +58 -0
- package/dist/commonjs/models/security.js.map +1 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/commonjs/sdk/cms/index.d.ts +4 -0
- package/dist/commonjs/sdk/cms/index.d.ts.map +1 -0
- package/dist/commonjs/sdk/cms/index.js +11 -0
- package/dist/commonjs/sdk/cms/index.js.map +1 -0
- package/dist/commonjs/sdk/commerce/index.d.ts +7 -0
- package/dist/commonjs/sdk/commerce/index.d.ts.map +1 -0
- package/dist/commonjs/sdk/commerce/index.js +15 -0
- package/dist/commonjs/sdk/commerce/index.js.map +1 -0
- package/dist/commonjs/sdk/commerce/products.d.ts +4 -0
- package/dist/commonjs/sdk/commerce/products.d.ts.map +1 -0
- package/dist/commonjs/sdk/commerce/products.js +11 -0
- package/dist/commonjs/sdk/commerce/products.js.map +1 -0
- package/dist/commonjs/sdk/http.d.ts +19 -0
- package/dist/commonjs/sdk/http.d.ts.map +1 -0
- package/dist/commonjs/sdk/http.js +143 -0
- package/dist/commonjs/sdk/http.js.map +1 -0
- package/dist/commonjs/sdk/index.d.ts +2 -0
- package/dist/commonjs/sdk/index.d.ts.map +1 -0
- package/dist/commonjs/sdk/index.js +18 -0
- package/dist/commonjs/sdk/index.js.map +1 -0
- package/dist/commonjs/sdk/sdk.d.ts +16 -0
- package/dist/commonjs/sdk/sdk.d.ts.map +1 -0
- package/dist/commonjs/sdk/sdk.js +24 -0
- package/dist/commonjs/sdk/sdk.js.map +1 -0
- package/dist/commonjs/sdk/settings/index.d.ts +4 -0
- package/dist/commonjs/sdk/settings/index.d.ts.map +1 -0
- package/dist/commonjs/sdk/settings/index.js +11 -0
- package/dist/commonjs/sdk/settings/index.js.map +1 -0
- package/dist/commonjs/types/async.d.ts +23 -0
- package/dist/commonjs/types/async.d.ts.map +1 -0
- package/dist/commonjs/types/async.js +41 -0
- package/dist/commonjs/types/async.js.map +1 -0
- package/dist/commonjs/types/blobs.d.ts +4 -0
- package/dist/commonjs/types/blobs.d.ts.map +1 -0
- package/dist/commonjs/types/blobs.js +59 -0
- package/dist/commonjs/types/blobs.js.map +1 -0
- package/dist/commonjs/types/const-date-time.d.ts +3 -0
- package/dist/commonjs/types/const-date-time.d.ts.map +1 -0
- package/dist/commonjs/types/const-date-time.js +43 -0
- package/dist/commonjs/types/const-date-time.js.map +1 -0
- package/dist/commonjs/types/default-to-zero-value.d.ts +12 -0
- package/dist/commonjs/types/default-to-zero-value.d.ts.map +1 -0
- package/dist/commonjs/types/default-to-zero-value.js +32 -0
- package/dist/commonjs/types/default-to-zero-value.js.map +1 -0
- package/dist/commonjs/types/enums.d.ts +9 -0
- package/dist/commonjs/types/enums.d.ts.map +1 -0
- package/dist/commonjs/types/enums.js +63 -0
- package/dist/commonjs/types/enums.js.map +1 -0
- package/dist/commonjs/types/fp.d.ts +31 -0
- package/dist/commonjs/types/fp.d.ts.map +1 -0
- package/dist/commonjs/types/fp.js +34 -0
- package/dist/commonjs/types/fp.js.map +1 -0
- package/dist/commonjs/types/index.d.ts +10 -0
- package/dist/commonjs/types/index.d.ts.map +1 -0
- package/dist/commonjs/types/index.js +28 -0
- package/dist/commonjs/types/index.js.map +1 -0
- package/dist/commonjs/types/operations.d.ts +27 -0
- package/dist/commonjs/types/operations.d.ts.map +1 -0
- package/dist/commonjs/types/operations.js +80 -0
- package/dist/commonjs/types/operations.js.map +1 -0
- package/dist/commonjs/types/primitives.d.ts +11 -0
- package/dist/commonjs/types/primitives.d.ts.map +1 -0
- package/dist/commonjs/types/primitives.js +173 -0
- package/dist/commonjs/types/primitives.js.map +1 -0
- package/dist/commonjs/types/rfcdate.d.ts +21 -0
- package/dist/commonjs/types/rfcdate.d.ts.map +1 -0
- package/dist/commonjs/types/rfcdate.js +43 -0
- package/dist/commonjs/types/rfcdate.js.map +1 -0
- package/dist/commonjs/types/smart-union.d.ts +7 -0
- package/dist/commonjs/types/smart-union.d.ts.map +1 -0
- package/dist/commonjs/types/smart-union.js +143 -0
- package/dist/commonjs/types/smart-union.js.map +1 -0
- package/dist/commonjs/types/streams.d.ts +2 -0
- package/dist/commonjs/types/streams.d.ts.map +1 -0
- package/dist/commonjs/types/streams.js +15 -0
- package/dist/commonjs/types/streams.js.map +1 -0
- package/dist/commonjs/types/unrecognized.d.ts +16 -0
- package/dist/commonjs/types/unrecognized.d.ts.map +1 -0
- package/dist/commonjs/types/unrecognized.js +31 -0
- package/dist/commonjs/types/unrecognized.js.map +1 -0
- package/dist/esm/core.d.ts +10 -0
- package/dist/esm/core.d.ts.map +1 -0
- package/dist/esm/core.js +10 -0
- package/dist/esm/core.js.map +1 -0
- package/dist/esm/hooks/hooks.d.ts +25 -0
- package/dist/esm/hooks/hooks.d.ts.map +1 -0
- package/dist/esm/hooks/hooks.js +79 -0
- package/dist/esm/hooks/hooks.js.map +1 -0
- package/dist/esm/hooks/index.d.ts +3 -0
- package/dist/esm/hooks/index.d.ts.map +1 -0
- package/dist/esm/hooks/index.js +3 -0
- package/dist/esm/hooks/index.js.map +1 -0
- package/dist/esm/hooks/ominity-hooks.d.ts +12 -0
- package/dist/esm/hooks/ominity-hooks.d.ts.map +1 -0
- package/dist/esm/hooks/ominity-hooks.js +82 -0
- package/dist/esm/hooks/ominity-hooks.js.map +1 -0
- package/dist/esm/hooks/registration.d.ts +3 -0
- package/dist/esm/hooks/registration.d.ts.map +1 -0
- package/dist/esm/hooks/registration.js +13 -0
- package/dist/esm/hooks/registration.js.map +1 -0
- package/dist/esm/hooks/types.d.ts +76 -0
- package/dist/esm/hooks/types.d.ts.map +1 -0
- package/dist/esm/hooks/types.js +2 -0
- package/dist/esm/hooks/types.js.map +1 -0
- package/dist/esm/index.d.ts +6 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +5 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/base64.d.ts +10 -0
- package/dist/esm/lib/base64.d.ts.map +1 -0
- package/dist/esm/lib/base64.js +28 -0
- package/dist/esm/lib/base64.js.map +1 -0
- package/dist/esm/lib/config.d.ts +52 -0
- package/dist/esm/lib/config.d.ts.map +1 -0
- package/dist/esm/lib/config.js +29 -0
- package/dist/esm/lib/config.js.map +1 -0
- package/dist/esm/lib/dlv.d.ts +14 -0
- package/dist/esm/lib/dlv.d.ts.map +1 -0
- package/dist/esm/lib/dlv.js +43 -0
- package/dist/esm/lib/dlv.js.map +1 -0
- package/dist/esm/lib/encodings.d.ts +53 -0
- package/dist/esm/lib/encodings.d.ts.map +1 -0
- package/dist/esm/lib/encodings.js +367 -0
- package/dist/esm/lib/encodings.js.map +1 -0
- package/dist/esm/lib/env.d.ts +16 -0
- package/dist/esm/lib/env.d.ts.map +1 -0
- package/dist/esm/lib/env.js +42 -0
- package/dist/esm/lib/env.js.map +1 -0
- package/dist/esm/lib/files.d.ts +13 -0
- package/dist/esm/lib/files.d.ts.map +1 -0
- package/dist/esm/lib/files.js +70 -0
- package/dist/esm/lib/files.js.map +1 -0
- package/dist/esm/lib/http.d.ts +67 -0
- package/dist/esm/lib/http.d.ts.map +1 -0
- package/dist/esm/lib/http.js +204 -0
- package/dist/esm/lib/http.js.map +1 -0
- package/dist/esm/lib/is-plain-object.d.ts +2 -0
- package/dist/esm/lib/is-plain-object.d.ts.map +1 -0
- package/dist/esm/lib/is-plain-object.js +35 -0
- package/dist/esm/lib/is-plain-object.js.map +1 -0
- package/dist/esm/lib/logger.d.ts +6 -0
- package/dist/esm/lib/logger.d.ts.map +1 -0
- package/dist/esm/lib/logger.js +2 -0
- package/dist/esm/lib/logger.js.map +1 -0
- package/dist/esm/lib/matchers.d.ts +59 -0
- package/dist/esm/lib/matchers.d.ts.map +1 -0
- package/dist/esm/lib/matchers.js +200 -0
- package/dist/esm/lib/matchers.js.map +1 -0
- package/dist/esm/lib/primitives.d.ts +26 -0
- package/dist/esm/lib/primitives.d.ts.map +1 -0
- package/dist/esm/lib/primitives.js +100 -0
- package/dist/esm/lib/primitives.js.map +1 -0
- package/dist/esm/lib/retries.d.ts +38 -0
- package/dist/esm/lib/retries.d.ts.map +1 -0
- package/dist/esm/lib/retries.js +144 -0
- package/dist/esm/lib/retries.js.map +1 -0
- package/dist/esm/lib/schemas.d.ts +21 -0
- package/dist/esm/lib/schemas.d.ts.map +1 -0
- package/dist/esm/lib/schemas.js +54 -0
- package/dist/esm/lib/schemas.js.map +1 -0
- package/dist/esm/lib/sdks.d.ts +63 -0
- package/dist/esm/lib/sdks.d.ts.map +1 -0
- package/dist/esm/lib/sdks.js +266 -0
- package/dist/esm/lib/sdks.js.map +1 -0
- package/dist/esm/lib/security.d.ts +83 -0
- package/dist/esm/lib/security.d.ts.map +1 -0
- package/dist/esm/lib/security.js +148 -0
- package/dist/esm/lib/security.js.map +1 -0
- package/dist/esm/lib/url.d.ts +5 -0
- package/dist/esm/lib/url.d.ts.map +1 -0
- package/dist/esm/lib/url.js +19 -0
- package/dist/esm/lib/url.js.map +1 -0
- package/dist/esm/models/errors/documentation.d.ts +22 -0
- package/dist/esm/models/errors/documentation.d.ts.map +1 -0
- package/dist/esm/models/errors/documentation.js +23 -0
- package/dist/esm/models/errors/documentation.js.map +1 -0
- package/dist/esm/models/errors/error-response-links.d.ts +21 -0
- package/dist/esm/models/errors/error-response-links.d.ts.map +1 -0
- package/dist/esm/models/errors/error-response-links.js +21 -0
- package/dist/esm/models/errors/error-response-links.js.map +1 -0
- package/dist/esm/models/errors/error-response.d.ts +56 -0
- package/dist/esm/models/errors/error-response.d.ts.map +1 -0
- package/dist/esm/models/errors/error-response.js +61 -0
- package/dist/esm/models/errors/error-response.js.map +1 -0
- package/dist/esm/models/errors/http-client-errors.d.ts +44 -0
- package/dist/esm/models/errors/http-client-errors.d.ts.map +1 -0
- package/dist/esm/models/errors/http-client-errors.js +66 -0
- package/dist/esm/models/errors/http-client-errors.js.map +1 -0
- package/dist/esm/models/errors/index.d.ts +9 -0
- package/dist/esm/models/errors/index.d.ts.map +1 -0
- package/dist/esm/models/errors/index.js +9 -0
- package/dist/esm/models/errors/index.js.map +1 -0
- package/dist/esm/models/errors/ominity-default-error.d.ts +10 -0
- package/dist/esm/models/errors/ominity-default-error.d.ts.map +1 -0
- package/dist/esm/models/errors/ominity-default-error.js +27 -0
- package/dist/esm/models/errors/ominity-default-error.js.map +1 -0
- package/dist/esm/models/errors/ominity-error.d.ts +19 -0
- package/dist/esm/models/errors/ominity-error.d.ts.map +1 -0
- package/dist/esm/models/errors/ominity-error.js +13 -0
- package/dist/esm/models/errors/ominity-error.js.map +1 -0
- package/dist/esm/models/errors/response-validation-error.d.ts +26 -0
- package/dist/esm/models/errors/response-validation-error.d.ts.map +1 -0
- package/dist/esm/models/errors/response-validation-error.js +26 -0
- package/dist/esm/models/errors/response-validation-error.js.map +1 -0
- package/dist/esm/models/errors/sdk-validation-error.d.ts +21 -0
- package/dist/esm/models/errors/sdk-validation-error.d.ts.map +1 -0
- package/dist/esm/models/errors/sdk-validation-error.js +41 -0
- package/dist/esm/models/errors/sdk-validation-error.js.map +1 -0
- package/dist/esm/models/index.d.ts +2 -0
- package/dist/esm/models/index.d.ts.map +1 -0
- package/dist/esm/models/index.js +2 -0
- package/dist/esm/models/index.js.map +1 -0
- package/dist/esm/models/operations/index.d.ts +2 -0
- package/dist/esm/models/operations/index.d.ts.map +1 -0
- package/dist/esm/models/operations/index.js +2 -0
- package/dist/esm/models/operations/index.js.map +1 -0
- package/dist/esm/models/security.d.ts +19 -0
- package/dist/esm/models/security.d.ts.map +1 -0
- package/dist/esm/models/security.js +20 -0
- package/dist/esm/models/security.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/sdk/cms/index.d.ts +4 -0
- package/dist/esm/sdk/cms/index.d.ts.map +1 -0
- package/dist/esm/sdk/cms/index.js +7 -0
- package/dist/esm/sdk/cms/index.js.map +1 -0
- package/dist/esm/sdk/commerce/index.d.ts +7 -0
- package/dist/esm/sdk/commerce/index.d.ts.map +1 -0
- package/dist/esm/sdk/commerce/index.js +11 -0
- package/dist/esm/sdk/commerce/index.js.map +1 -0
- package/dist/esm/sdk/commerce/products.d.ts +4 -0
- package/dist/esm/sdk/commerce/products.d.ts.map +1 -0
- package/dist/esm/sdk/commerce/products.js +7 -0
- package/dist/esm/sdk/commerce/products.js.map +1 -0
- package/dist/esm/sdk/http.d.ts +19 -0
- package/dist/esm/sdk/http.d.ts.map +1 -0
- package/dist/esm/sdk/http.js +139 -0
- package/dist/esm/sdk/http.js.map +1 -0
- package/dist/esm/sdk/index.d.ts +2 -0
- package/dist/esm/sdk/index.d.ts.map +1 -0
- package/dist/esm/sdk/index.js +2 -0
- package/dist/esm/sdk/index.js.map +1 -0
- package/dist/esm/sdk/sdk.d.ts +16 -0
- package/dist/esm/sdk/sdk.d.ts.map +1 -0
- package/dist/esm/sdk/sdk.js +20 -0
- package/dist/esm/sdk/sdk.js.map +1 -0
- package/dist/esm/sdk/settings/index.d.ts +4 -0
- package/dist/esm/sdk/settings/index.d.ts.map +1 -0
- package/dist/esm/sdk/settings/index.js +7 -0
- package/dist/esm/sdk/settings/index.js.map +1 -0
- package/dist/esm/types/async.d.ts +23 -0
- package/dist/esm/types/async.d.ts.map +1 -0
- package/dist/esm/types/async.js +37 -0
- package/dist/esm/types/async.js.map +1 -0
- package/dist/esm/types/blobs.d.ts +4 -0
- package/dist/esm/types/blobs.d.ts.map +1 -0
- package/dist/esm/types/blobs.js +22 -0
- package/dist/esm/types/blobs.js.map +1 -0
- package/dist/esm/types/const-date-time.d.ts +3 -0
- package/dist/esm/types/const-date-time.d.ts.map +1 -0
- package/dist/esm/types/const-date-time.js +7 -0
- package/dist/esm/types/const-date-time.js.map +1 -0
- package/dist/esm/types/default-to-zero-value.d.ts +12 -0
- package/dist/esm/types/default-to-zero-value.d.ts.map +1 -0
- package/dist/esm/types/default-to-zero-value.js +28 -0
- package/dist/esm/types/default-to-zero-value.js.map +1 -0
- package/dist/esm/types/enums.d.ts +9 -0
- package/dist/esm/types/enums.d.ts.map +1 -0
- package/dist/esm/types/enums.js +24 -0
- package/dist/esm/types/enums.js.map +1 -0
- package/dist/esm/types/fp.d.ts +31 -0
- package/dist/esm/types/fp.d.ts.map +1 -0
- package/dist/esm/types/fp.js +28 -0
- package/dist/esm/types/fp.js.map +1 -0
- package/dist/esm/types/index.d.ts +10 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/index.js +7 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/operations.d.ts +27 -0
- package/dist/esm/types/operations.d.ts.map +1 -0
- package/dist/esm/types/operations.js +74 -0
- package/dist/esm/types/operations.js.map +1 -0
- package/dist/esm/types/primitives.d.ts +11 -0
- package/dist/esm/types/primitives.d.ts.map +1 -0
- package/dist/esm/types/primitives.js +129 -0
- package/dist/esm/types/primitives.js.map +1 -0
- package/dist/esm/types/rfcdate.d.ts +21 -0
- package/dist/esm/types/rfcdate.d.ts.map +1 -0
- package/dist/esm/types/rfcdate.js +39 -0
- package/dist/esm/types/rfcdate.js.map +1 -0
- package/dist/esm/types/smart-union.d.ts +7 -0
- package/dist/esm/types/smart-union.d.ts.map +1 -0
- package/dist/esm/types/smart-union.js +107 -0
- package/dist/esm/types/smart-union.js.map +1 -0
- package/dist/esm/types/streams.d.ts +2 -0
- package/dist/esm/types/streams.d.ts.map +1 -0
- package/dist/esm/types/streams.js +12 -0
- package/dist/esm/types/streams.js.map +1 -0
- package/dist/esm/types/unrecognized.d.ts +16 -0
- package/dist/esm/types/unrecognized.d.ts.map +1 -0
- package/dist/esm/types/unrecognized.js +28 -0
- package/dist/esm/types/unrecognized.js.map +1 -0
- package/jsr.json +27 -0
- package/package.json +122 -0
- package/src/core.ts +10 -0
- package/src/hooks/hooks.ts +128 -0
- package/src/hooks/index.ts +2 -0
- package/src/hooks/ominity-hooks.ts +117 -0
- package/src/hooks/registration.ts +15 -0
- package/src/hooks/types.ts +103 -0
- package/src/index.ts +6 -0
- package/src/lib/base64.ts +36 -0
- package/src/lib/config.ts +84 -0
- package/src/lib/dlv.ts +49 -0
- package/src/lib/encodings.ts +497 -0
- package/src/lib/env.ts +56 -0
- package/src/lib/files.ts +79 -0
- package/src/lib/http.ts +320 -0
- package/src/lib/is-plain-object.ts +40 -0
- package/src/lib/logger.ts +6 -0
- package/src/lib/matchers.ts +349 -0
- package/src/lib/primitives.ts +147 -0
- package/src/lib/retries.ts +215 -0
- package/src/lib/schemas.ts +91 -0
- package/src/lib/sdks.ts +403 -0
- package/src/lib/security.ts +276 -0
- package/src/lib/url.ts +30 -0
- package/src/models/errors/documentation.ts +50 -0
- package/src/models/errors/error-response-links.ts +58 -0
- package/src/models/errors/error-response.ts +121 -0
- package/src/models/errors/http-client-errors.ts +58 -0
- package/src/models/errors/index.ts +8 -0
- package/src/models/errors/ominity-default-error.ts +36 -0
- package/src/models/errors/ominity-error.ts +31 -0
- package/src/models/errors/response-validation-error.ts +46 -0
- package/src/models/errors/sdk-validation-error.ts +50 -0
- package/src/models/index.ts +1 -0
- package/src/models/operations/index.ts +2 -0
- package/src/models/security.ts +46 -0
- package/src/sdk/cms/index.ts +7 -0
- package/src/sdk/commerce/index.ts +13 -0
- package/src/sdk/commerce/products.ts +7 -0
- package/src/sdk/http.ts +204 -0
- package/src/sdk/index.ts +2 -0
- package/src/sdk/sdk.ts +28 -0
- package/src/sdk/settings/index.ts +7 -0
- package/src/types/async.ts +65 -0
- package/src/types/blobs.ts +30 -0
- package/src/types/const-date-time.ts +12 -0
- package/src/types/default-to-zero-value.ts +30 -0
- package/src/types/enums.ts +42 -0
- package/src/types/fp.ts +47 -0
- package/src/types/index.ts +10 -0
- package/src/types/operations.ts +102 -0
- package/src/types/primitives.ts +165 -0
- package/src/types/rfcdate.ts +51 -0
- package/src/types/smart-union.ts +142 -0
- package/src/types/streams.ts +18 -0
- package/src/types/unrecognized.ts +32 -0
- package/tsconfig.json +40 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
|
|
2
|
+
class InvariantError extends Error {
|
|
3
|
+
constructor(message: string) {
|
|
4
|
+
super(message);
|
|
5
|
+
this.name = "InvariantError";
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export function invariant(
|
|
10
|
+
condition: unknown,
|
|
11
|
+
message: string,
|
|
12
|
+
): asserts condition {
|
|
13
|
+
if (!condition) {
|
|
14
|
+
throw new InvariantError(message);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export type ExactPartial<T> = {
|
|
19
|
+
[P in keyof T]?: T[P] | undefined;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
export type Remap<Inp, Mapping extends { [k in keyof Inp]?: string | null }> = {
|
|
23
|
+
[k in keyof Inp as Mapping[k] extends string /* if we have a string mapping for this key then use it */
|
|
24
|
+
? Mapping[k]
|
|
25
|
+
: Mapping[k] extends null /* if the mapping is to `null` then drop the key */
|
|
26
|
+
? never
|
|
27
|
+
: k /* otherwise keep the key as-is */]: Inp[k];
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Converts or omits an object's keys according to a mapping.
|
|
32
|
+
*
|
|
33
|
+
* @param inp An object whose keys will be remapped
|
|
34
|
+
* @param mappings A mapping of original keys to new keys. If a key is not present in the mapping, it will be left as is. If a key is mapped to `null`, it will be removed in the resulting object.
|
|
35
|
+
* @returns A new object with keys remapped or omitted according to the mappings
|
|
36
|
+
*/
|
|
37
|
+
export function remap<
|
|
38
|
+
Inp extends Record<string, unknown>,
|
|
39
|
+
const Mapping extends { [k in keyof Inp]?: string | null },
|
|
40
|
+
>(inp: Inp, mappings: Mapping): Remap<Inp, Mapping> {
|
|
41
|
+
let out: any = {};
|
|
42
|
+
|
|
43
|
+
if (!Object.keys(mappings).length) {
|
|
44
|
+
out = inp;
|
|
45
|
+
return out;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
for (const [k, v] of Object.entries(inp)) {
|
|
49
|
+
const j = mappings[k];
|
|
50
|
+
if (j === null) {
|
|
51
|
+
continue;
|
|
52
|
+
}
|
|
53
|
+
out[j ?? k] = v;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return out;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export function combineSignals(
|
|
60
|
+
...signals: Array<AbortSignal | null | undefined>
|
|
61
|
+
): AbortSignal | null {
|
|
62
|
+
const filtered: AbortSignal[] = [];
|
|
63
|
+
for (const signal of signals) {
|
|
64
|
+
if (signal) {
|
|
65
|
+
filtered.push(signal);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
switch (filtered.length) {
|
|
70
|
+
case 0:
|
|
71
|
+
case 1:
|
|
72
|
+
return filtered[0] || null;
|
|
73
|
+
default:
|
|
74
|
+
if ("any" in AbortSignal && typeof AbortSignal.any === "function") {
|
|
75
|
+
return AbortSignal.any(filtered);
|
|
76
|
+
}
|
|
77
|
+
return abortSignalAny(filtered);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
export function abortSignalAny(signals: AbortSignal[]): AbortSignal {
|
|
82
|
+
const controller = new AbortController();
|
|
83
|
+
const result = controller.signal;
|
|
84
|
+
if (!signals.length) {
|
|
85
|
+
return controller.signal;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (signals.length === 1) {
|
|
89
|
+
return signals[0] || controller.signal;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
for (const signal of signals) {
|
|
93
|
+
if (signal.aborted) {
|
|
94
|
+
return signal;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
function abort(this: AbortSignal) {
|
|
99
|
+
controller.abort(this.reason);
|
|
100
|
+
clean();
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
const signalRefs: WeakRef<AbortSignal>[] = [];
|
|
104
|
+
function clean() {
|
|
105
|
+
for (const signalRef of signalRefs) {
|
|
106
|
+
const signal = signalRef.deref();
|
|
107
|
+
if (signal) {
|
|
108
|
+
signal.removeEventListener("abort", abort);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
for (const signal of signals) {
|
|
114
|
+
signalRefs.push(new WeakRef(signal));
|
|
115
|
+
signal.addEventListener("abort", abort);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
return result;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
export function compactMap<T>(
|
|
122
|
+
values: Record<string, T | undefined>,
|
|
123
|
+
): Record<string, T> {
|
|
124
|
+
const out: Record<string, T> = {};
|
|
125
|
+
|
|
126
|
+
for (const [k, v] of Object.entries(values)) {
|
|
127
|
+
if (typeof v !== "undefined") {
|
|
128
|
+
out[k] = v;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
return out;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
export function allRequired<V extends Record<string, unknown>>(
|
|
136
|
+
v: V,
|
|
137
|
+
):
|
|
138
|
+
| {
|
|
139
|
+
[K in keyof V]: NonNullable<V[K]>;
|
|
140
|
+
}
|
|
141
|
+
| undefined {
|
|
142
|
+
if (Object.values(v).every((x) => x == null)) {
|
|
143
|
+
return void 0;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
return v as ReturnType<typeof allRequired<V>>;
|
|
147
|
+
}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
|
|
2
|
+
import { isConnectionError, isTimeoutError } from "./http.js";
|
|
3
|
+
|
|
4
|
+
export type BackoffStrategy = {
|
|
5
|
+
initialInterval: number;
|
|
6
|
+
maxInterval: number;
|
|
7
|
+
exponent: number;
|
|
8
|
+
maxElapsedTime: number;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
const defaultBackoff: BackoffStrategy = {
|
|
12
|
+
initialInterval: 500,
|
|
13
|
+
maxInterval: 60000,
|
|
14
|
+
exponent: 1.5,
|
|
15
|
+
maxElapsedTime: 3600000,
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export type RetryConfig =
|
|
19
|
+
| { strategy: "none" }
|
|
20
|
+
| {
|
|
21
|
+
strategy: "backoff";
|
|
22
|
+
backoff?: BackoffStrategy;
|
|
23
|
+
retryConnectionErrors?: boolean;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* PermanentError is an error that is not recoverable. Throwing this error will
|
|
28
|
+
* cause a retry loop to terminate.
|
|
29
|
+
*/
|
|
30
|
+
export class PermanentError extends Error {
|
|
31
|
+
/** The underlying cause of the error. */
|
|
32
|
+
override readonly cause: unknown;
|
|
33
|
+
|
|
34
|
+
constructor(message: string, options?: { cause?: unknown }) {
|
|
35
|
+
let msg = message;
|
|
36
|
+
if (options?.cause) {
|
|
37
|
+
msg += `: ${options.cause}`;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
super(msg, options);
|
|
41
|
+
this.name = "PermanentError";
|
|
42
|
+
// In older runtimes, the cause field would not have been assigned through
|
|
43
|
+
// the super() call.
|
|
44
|
+
if (typeof this.cause === "undefined") {
|
|
45
|
+
this.cause = options?.cause;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
Object.setPrototypeOf(this, PermanentError.prototype);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* TemporaryError is an error is used to signal that an HTTP request can be
|
|
54
|
+
* retried as part of a retry loop. If retry attempts are exhausted and this
|
|
55
|
+
* error is thrown, the response will be returned to the caller.
|
|
56
|
+
*/
|
|
57
|
+
export class TemporaryError extends Error {
|
|
58
|
+
response: Response;
|
|
59
|
+
|
|
60
|
+
constructor(message: string, response: Response) {
|
|
61
|
+
super(message);
|
|
62
|
+
this.response = response;
|
|
63
|
+
this.name = "TemporaryError";
|
|
64
|
+
|
|
65
|
+
Object.setPrototypeOf(this, TemporaryError.prototype);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export async function retry(
|
|
70
|
+
fetchFn: () => Promise<Response>,
|
|
71
|
+
options: {
|
|
72
|
+
config: RetryConfig;
|
|
73
|
+
statusCodes: string[];
|
|
74
|
+
},
|
|
75
|
+
): Promise<Response> {
|
|
76
|
+
switch (options.config.strategy) {
|
|
77
|
+
case "backoff":
|
|
78
|
+
return retryBackoff(
|
|
79
|
+
wrapFetcher(fetchFn, {
|
|
80
|
+
statusCodes: options.statusCodes,
|
|
81
|
+
retryConnectionErrors: !!options.config.retryConnectionErrors,
|
|
82
|
+
}),
|
|
83
|
+
options.config.backoff ?? defaultBackoff,
|
|
84
|
+
);
|
|
85
|
+
default:
|
|
86
|
+
return await fetchFn();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function wrapFetcher(
|
|
91
|
+
fn: () => Promise<Response>,
|
|
92
|
+
options: {
|
|
93
|
+
statusCodes: string[];
|
|
94
|
+
retryConnectionErrors: boolean;
|
|
95
|
+
},
|
|
96
|
+
): () => Promise<Response> {
|
|
97
|
+
return async () => {
|
|
98
|
+
try {
|
|
99
|
+
const res = await fn();
|
|
100
|
+
if (isRetryableResponse(res, options.statusCodes)) {
|
|
101
|
+
throw new TemporaryError(
|
|
102
|
+
"Response failed with retryable status code",
|
|
103
|
+
res,
|
|
104
|
+
);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
return res;
|
|
108
|
+
} catch (err: unknown) {
|
|
109
|
+
if (err instanceof TemporaryError) {
|
|
110
|
+
throw err;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (
|
|
114
|
+
options.retryConnectionErrors &&
|
|
115
|
+
(isTimeoutError(err) || isConnectionError(err))
|
|
116
|
+
) {
|
|
117
|
+
throw err;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
throw new PermanentError("Permanent error", { cause: err });
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
const codeRangeRE = new RegExp("^[0-9]xx$", "i");
|
|
126
|
+
|
|
127
|
+
function isRetryableResponse(res: Response, statusCodes: string[]): boolean {
|
|
128
|
+
const actual = `${res.status}`;
|
|
129
|
+
|
|
130
|
+
return statusCodes.some((code) => {
|
|
131
|
+
if (!codeRangeRE.test(code)) {
|
|
132
|
+
return code === actual;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
const expectFamily = code.charAt(0);
|
|
136
|
+
if (!expectFamily) {
|
|
137
|
+
throw new Error("Invalid status code range");
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
const actualFamily = actual.charAt(0);
|
|
141
|
+
if (!actualFamily) {
|
|
142
|
+
throw new Error(`Invalid response status code: ${actual}`);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return actualFamily === expectFamily;
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
async function retryBackoff(
|
|
150
|
+
fn: () => Promise<Response>,
|
|
151
|
+
strategy: BackoffStrategy,
|
|
152
|
+
): Promise<Response> {
|
|
153
|
+
const { maxElapsedTime, initialInterval, exponent, maxInterval } = strategy;
|
|
154
|
+
|
|
155
|
+
const start = Date.now();
|
|
156
|
+
let x = 0;
|
|
157
|
+
|
|
158
|
+
while (true) {
|
|
159
|
+
try {
|
|
160
|
+
const res = await fn();
|
|
161
|
+
return res;
|
|
162
|
+
} catch (err: unknown) {
|
|
163
|
+
if (err instanceof PermanentError) {
|
|
164
|
+
throw err.cause;
|
|
165
|
+
}
|
|
166
|
+
const elapsed = Date.now() - start;
|
|
167
|
+
if (elapsed > maxElapsedTime) {
|
|
168
|
+
if (err instanceof TemporaryError) {
|
|
169
|
+
return err.response;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
throw err;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
let retryInterval = 0;
|
|
176
|
+
if (err instanceof TemporaryError) {
|
|
177
|
+
retryInterval = retryIntervalFromResponse(err.response);
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
if (retryInterval <= 0) {
|
|
181
|
+
retryInterval =
|
|
182
|
+
initialInterval * Math.pow(x, exponent) + Math.random() * 1000;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
const d = Math.min(retryInterval, maxInterval);
|
|
186
|
+
|
|
187
|
+
await delay(d);
|
|
188
|
+
x++;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function retryIntervalFromResponse(res: Response): number {
|
|
194
|
+
const retryVal = res.headers.get("retry-after") || "";
|
|
195
|
+
if (!retryVal) {
|
|
196
|
+
return 0;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
const parsedNumber = Number(retryVal);
|
|
200
|
+
if (Number.isInteger(parsedNumber)) {
|
|
201
|
+
return parsedNumber * 1000;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
const parsedDate = Date.parse(retryVal);
|
|
205
|
+
if (Number.isInteger(parsedDate)) {
|
|
206
|
+
const deltaMS = parsedDate - Date.now();
|
|
207
|
+
return deltaMS > 0 ? Math.ceil(deltaMS) : 0;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
return 0;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
async function delay(delay: number): Promise<void> {
|
|
214
|
+
return new Promise((resolve) => setTimeout(resolve, delay));
|
|
215
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
|
|
2
|
+
import * as z from "zod/v4";
|
|
3
|
+
import { SDKValidationError } from "../models/errors/sdk-validation-error.js";
|
|
4
|
+
import { ERR, OK, Result } from "../types/fp.js";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Utility function that executes some code which may throw a ZodError. It
|
|
8
|
+
* intercepts this error and converts it to an SDKValidationError so as to not
|
|
9
|
+
* leak Zod implementation details to user code.
|
|
10
|
+
*/
|
|
11
|
+
export function parse<Inp, Out>(
|
|
12
|
+
rawValue: Inp,
|
|
13
|
+
fn: (value: Inp) => Out,
|
|
14
|
+
errorMessage: string,
|
|
15
|
+
): Out {
|
|
16
|
+
try {
|
|
17
|
+
return fn(rawValue);
|
|
18
|
+
} catch (err) {
|
|
19
|
+
if (err instanceof z.ZodError) {
|
|
20
|
+
throw new SDKValidationError(errorMessage, err, rawValue);
|
|
21
|
+
}
|
|
22
|
+
throw err;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Utility function that executes some code which may result in a ZodError. It
|
|
28
|
+
* intercepts this error and converts it to an SDKValidationError so as to not
|
|
29
|
+
* leak Zod implementation details to user code.
|
|
30
|
+
*/
|
|
31
|
+
export function safeParse<Inp, Out>(
|
|
32
|
+
rawValue: Inp,
|
|
33
|
+
fn: (value: Inp) => Out,
|
|
34
|
+
errorMessage: string,
|
|
35
|
+
): Result<Out, SDKValidationError> {
|
|
36
|
+
try {
|
|
37
|
+
return OK(fn(rawValue));
|
|
38
|
+
} catch (err) {
|
|
39
|
+
return ERR(new SDKValidationError(errorMessage, err, rawValue));
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function collectExtraKeys<
|
|
44
|
+
Shape extends z.core.$ZodShape,
|
|
45
|
+
Catchall extends z.ZodType,
|
|
46
|
+
K extends string,
|
|
47
|
+
Optional extends boolean,
|
|
48
|
+
>(
|
|
49
|
+
obj: z.ZodObject<Shape, z.core.$catchall<Catchall>>,
|
|
50
|
+
extrasKey: K,
|
|
51
|
+
optional: Optional,
|
|
52
|
+
): z.ZodPipe<
|
|
53
|
+
z.ZodObject<Shape, z.core.$catchall<Catchall>>,
|
|
54
|
+
z.ZodTransform<
|
|
55
|
+
& z.output<z.ZodObject<Shape, z.core.$strip>>
|
|
56
|
+
& (Optional extends false ? {
|
|
57
|
+
[k in K]: Record<string, z.output<Catchall>>;
|
|
58
|
+
}
|
|
59
|
+
: {
|
|
60
|
+
[k in K]?: Record<string, z.output<Catchall>> | undefined;
|
|
61
|
+
}),
|
|
62
|
+
z.output<z.ZodObject<Shape, z.core.$catchall<Catchall>>>
|
|
63
|
+
>
|
|
64
|
+
> {
|
|
65
|
+
return z.pipe(
|
|
66
|
+
obj,
|
|
67
|
+
z.transform((val: any) => {
|
|
68
|
+
const extras: Record<string, z.output<Catchall>> = {};
|
|
69
|
+
const { shape } = obj;
|
|
70
|
+
for (const [key] of Object.entries(val)) {
|
|
71
|
+
if (key in shape) {
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const v = val[key];
|
|
76
|
+
if (typeof v === "undefined") {
|
|
77
|
+
continue;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
extras[key] = v;
|
|
81
|
+
delete val[key];
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
if (optional && Object.keys(extras).length === 0) {
|
|
85
|
+
return val;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return { ...val, [extrasKey]: extras };
|
|
89
|
+
}),
|
|
90
|
+
);
|
|
91
|
+
}
|