@hubspot/app-connect-sdk 1.0.0-alpha.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/.turbo/turbo-format$colon$check.log +4 -0
- package/.turbo/turbo-lint.log +2 -0
- package/.turbo/turbo-test.log +76 -0
- package/.turbo/turbo-tsc.log +2 -0
- package/.turbo/turbo-tsdown.log +521 -0
- package/README.md +5 -0
- package/build/tsconfig.browser.tsbuildinfo +1 -0
- package/build/tsconfig.server.tsbuildinfo +1 -0
- package/dist/browser/HubSpotAppConnect-BW45gyDs.js +489 -0
- package/dist/browser/HubSpotAppConnect-BW45gyDs.js.map +1 -0
- package/dist/browser/assets/src/browser/react/components/AppConnectHeader/AppConnectHeader.css.ts.vanilla-DpJ0aBGF.css +211 -0
- package/dist/browser/assets/src/browser/react/components/Button/Button.css.ts.vanilla-Df16gUKx.css +42 -0
- package/dist/browser/assets/src/browser/react/components/ConnectButton/ConnectButton.css.ts.vanilla-BXXMQqfA.css +66 -0
- package/dist/browser/assets/src/browser/react/components/DisconnectedBody/DisconnectedBody.css.ts.vanilla-DLvostZL.css +19 -0
- package/dist/browser/assets/src/browser/react/components/HubSpotAppConnect/HubSpotAppConnect.css.ts.vanilla-Boi40eip.css +17 -0
- package/dist/browser/assets/src/browser/react/components/LoadingIndicator/LoadingIndicator.css.ts.vanilla-RVWGi6Ny.css +25 -0
- package/dist/browser/assets/src/browser/react/components/ShareButton/ShareButton.css.ts.vanilla-CY8SC-0T.css +40 -0
- package/dist/browser/assets/src/browser/theme-tokens.generated.css.ts.vanilla-C8Rjb8NH.css +220 -0
- package/dist/browser/assets/src/browser/theme.css.ts.vanilla-D_GBwEeI.css +12 -0
- package/dist/browser/create-vctOhpX9.js +517 -0
- package/dist/browser/create-vctOhpX9.js.map +1 -0
- package/dist/browser/index.d.ts +465 -0
- package/dist/browser/index.js +3 -0
- package/dist/browser/react/lovable.d.ts +30 -0
- package/dist/browser/react/lovable.js +23 -0
- package/dist/browser/react/lovable.js.map +1 -0
- package/dist/browser/react.d.ts +47 -0
- package/dist/browser/react.js +2 -0
- package/dist/browser/theme.css-CJbxi5hC.js +368 -0
- package/dist/browser/theme.css-CJbxi5hC.js.map +1 -0
- package/dist/browser/types-rTQw6A54.d.ts +79 -0
- package/dist/server/api-client-core/apis/account/account-info-types.generated.d.ts +111 -0
- package/dist/server/api-client-core/apis/account/account-info.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/account/account-info.generated.js +9 -0
- package/dist/server/api-client-core/apis/account/account-info.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/account/audit-logs-types.generated.d.ts +247 -0
- package/dist/server/api-client-core/apis/account/audit-logs.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/account/audit-logs.generated.js +28 -0
- package/dist/server/api-client-core/apis/account/audit-logs.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/auth/oauth-types.generated.d.ts +121 -0
- package/dist/server/api-client-core/apis/auth/oauth.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/auth/oauth.generated.js +19 -0
- package/dist/server/api-client-core/apis/auth/oauth.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/automation/actions-types.generated.d.ts +933 -0
- package/dist/server/api-client-core/apis/automation/actions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/automation/actions.generated.js +121 -0
- package/dist/server/api-client-core/apis/automation/actions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/automation/sequences-types.generated.d.ts +422 -0
- package/dist/server/api-client-core/apis/automation/sequences.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/automation/sequences.generated.js +22 -0
- package/dist/server/api-client-core/apis/automation/sequences.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/business-units-types.generated.d.ts +75 -0
- package/dist/server/api-client-core/apis/business-units.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/business-units.generated.js +12 -0
- package/dist/server/api-client-core/apis/business-units.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/authors-types.generated.d.ts +551 -0
- package/dist/server/api-client-core/apis/cms/authors.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/authors.generated.js +163 -0
- package/dist/server/api-client-core/apis/cms/authors.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/blog-settings-types.generated.d.ts +366 -0
- package/dist/server/api-client-core/apis/cms/blog-settings.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/blog-settings.generated.js +43 -0
- package/dist/server/api-client-core/apis/cms/blog-settings.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/cms-content-audit-types.generated.d.ts +157 -0
- package/dist/server/api-client-core/apis/cms/cms-content-audit.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/cms-content-audit.generated.js +18 -0
- package/dist/server/api-client-core/apis/cms/cms-content-audit.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/domains-types.generated.d.ts +193 -0
- package/dist/server/api-client-core/apis/cms/domains.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/domains.generated.js +20 -0
- package/dist/server/api-client-core/apis/cms/domains.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/hubdb-types.generated.d.ts +1097 -0
- package/dist/server/api-client-core/apis/cms/hubdb.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/hubdb.generated.js +192 -0
- package/dist/server/api-client-core/apis/cms/hubdb.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/media-bridge-types.generated.d.ts +1780 -0
- package/dist/server/api-client-core/apis/cms/media-bridge.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/media-bridge.generated.js +185 -0
- package/dist/server/api-client-core/apis/cms/media-bridge.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/pages-types.generated.d.ts +1768 -0
- package/dist/server/api-client-core/apis/cms/pages.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/pages.generated.js +331 -0
- package/dist/server/api-client-core/apis/cms/pages.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/posts-types.generated.d.ts +1090 -0
- package/dist/server/api-client-core/apis/cms/posts.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/posts.generated.js +201 -0
- package/dist/server/api-client-core/apis/cms/posts.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/site-search-types.generated.d.ts +200 -0
- package/dist/server/api-client-core/apis/cms/site-search.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/site-search.generated.js +32 -0
- package/dist/server/api-client-core/apis/cms/site-search.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/source-code-types.generated.d.ts +218 -0
- package/dist/server/api-client-core/apis/cms/source-code.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/source-code.generated.js +52 -0
- package/dist/server/api-client-core/apis/cms/source-code.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/tags-types.generated.d.ts +515 -0
- package/dist/server/api-client-core/apis/cms/tags.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/tags.generated.js +163 -0
- package/dist/server/api-client-core/apis/cms/tags.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/url-mappings-types.generated.d.ts +177 -0
- package/dist/server/api-client-core/apis/cms/url-mappings.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/url-mappings.generated.js +14 -0
- package/dist/server/api-client-core/apis/cms/url-mappings.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/cms/url-redirects-types.generated.d.ts +226 -0
- package/dist/server/api-client-core/apis/cms/url-redirects.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/cms/url-redirects.generated.js +26 -0
- package/dist/server/api-client-core/apis/cms/url-redirects.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/communication-preferences/subscriptions-types.generated.d.ts +802 -0
- package/dist/server/api-client-core/apis/communication-preferences/subscriptions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/communication-preferences/subscriptions.generated.js +74 -0
- package/dist/server/api-client-core/apis/communication-preferences/subscriptions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/conversations/custom-channels-types.generated.d.ts +551 -0
- package/dist/server/api-client-core/apis/conversations/custom-channels.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/conversations/custom-channels.generated.js +80 -0
- package/dist/server/api-client-core/apis/conversations/custom-channels.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/conversations/visitor-identification-types.generated.d.ts +60 -0
- package/dist/server/api-client-core/apis/conversations/visitor-identification.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/conversations/visitor-identification.generated.js +6 -0
- package/dist/server/api-client-core/apis/conversations/visitor-identification.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/conversations-types.generated.d.ts +908 -0
- package/dist/server/api-client-core/apis/conversations.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/conversations.generated.js +108 -0
- package/dist/server/api-client-core/apis/conversations.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/app-uninstalls-types.generated.d.ts +37 -0
- package/dist/server/api-client-core/apis/crm/app-uninstalls.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/app-uninstalls.generated.js +6 -0
- package/dist/server/api-client-core/apis/crm/app-uninstalls.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/appointments-types.generated.d.ts +989 -0
- package/dist/server/api-client-core/apis/crm/appointments.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/appointments.generated.js +118 -0
- package/dist/server/api-client-core/apis/crm/appointments.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/associations-schema-types.generated.d.ts +329 -0
- package/dist/server/api-client-core/apis/crm/associations-schema.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/associations-schema.generated.js +60 -0
- package/dist/server/api-client-core/apis/crm/associations-schema.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/associations-types.generated.d.ts +661 -0
- package/dist/server/api-client-core/apis/crm/associations.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/associations.generated.js +83 -0
- package/dist/server/api-client-core/apis/crm/associations.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/calling-extensions-types.generated.d.ts +466 -0
- package/dist/server/api-client-core/apis/crm/calling-extensions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/calling-extensions.generated.js +42 -0
- package/dist/server/api-client-core/apis/crm/calling-extensions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/calls-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/calls.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/calls.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/calls.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/carts-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/carts.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/carts.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/carts.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/commerce-payments-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/commerce-payments.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/commerce-payments.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/commerce-payments.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/commerce-subscriptions-types.generated.d.ts +847 -0
- package/dist/server/api-client-core/apis/crm/commerce-subscriptions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/commerce-subscriptions.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/commerce-subscriptions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/communications-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/communications.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/communications.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/communications.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/companies-types.generated.d.ts +884 -0
- package/dist/server/api-client-core/apis/crm/companies.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/companies.generated.js +67 -0
- package/dist/server/api-client-core/apis/crm/companies.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/contacts-types.generated.d.ts +899 -0
- package/dist/server/api-client-core/apis/crm/contacts.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/contacts.generated.js +70 -0
- package/dist/server/api-client-core/apis/crm/contacts.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/contracts-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/contracts.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/contracts.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/contracts.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/courses-types.generated.d.ts +853 -0
- package/dist/server/api-client-core/apis/crm/courses.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/courses.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/courses.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/crm-owners-types.generated.d.ts +140 -0
- package/dist/server/api-client-core/apis/crm/crm-owners.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/crm-owners.generated.js +20 -0
- package/dist/server/api-client-core/apis/crm/crm-owners.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/custom-objects-types.generated.d.ts +934 -0
- package/dist/server/api-client-core/apis/crm/custom-objects.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/custom-objects.generated.js +101 -0
- package/dist/server/api-client-core/apis/crm/custom-objects.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/deal-splits-types.generated.d.ts +196 -0
- package/dist/server/api-client-core/apis/crm/deal-splits.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/deal-splits.generated.js +9 -0
- package/dist/server/api-client-core/apis/crm/deal-splits.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/deals-types.generated.d.ts +872 -0
- package/dist/server/api-client-core/apis/crm/deals.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/deals.generated.js +67 -0
- package/dist/server/api-client-core/apis/crm/deals.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/discounts-types.generated.d.ts +846 -0
- package/dist/server/api-client-core/apis/crm/discounts.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/discounts.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/discounts.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/emails-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/emails.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/emails.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/emails.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/exports-types.generated.d.ts +281 -0
- package/dist/server/api-client-core/apis/crm/exports.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/exports.generated.js +12 -0
- package/dist/server/api-client-core/apis/crm/exports.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/feedback-submissions-types.generated.d.ts +616 -0
- package/dist/server/api-client-core/apis/crm/feedback-submissions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/feedback-submissions.generated.js +55 -0
- package/dist/server/api-client-core/apis/crm/feedback-submissions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/fees-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/fees.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/fees.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/fees.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/goal-targets-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/goal-targets.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/goal-targets.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/goal-targets.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/imports-types.generated.d.ts +371 -0
- package/dist/server/api-client-core/apis/crm/imports.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/imports.generated.js +30 -0
- package/dist/server/api-client-core/apis/crm/imports.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/invoices-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/invoices.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/invoices.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/invoices.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/leads-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/leads.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/leads.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/leads.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/limits-tracking-types.generated.d.ts +331 -0
- package/dist/server/api-client-core/apis/crm/limits-tracking.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/limits-tracking.generated.js +22 -0
- package/dist/server/api-client-core/apis/crm/limits-tracking.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/line-items-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/line-items.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/line-items.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/line-items.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/listings-types.generated.d.ts +853 -0
- package/dist/server/api-client-core/apis/crm/listings.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/listings.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/listings.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/lists-types.generated.d.ts +2265 -0
- package/dist/server/api-client-core/apis/crm/lists.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/lists.generated.js +105 -0
- package/dist/server/api-client-core/apis/crm/lists.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/meetings-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/meetings.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/meetings.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/meetings.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/notes-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/notes.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/notes.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/notes.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/object-library-types.generated.d.ts +60 -0
- package/dist/server/api-client-core/apis/crm/object-library.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/object-library.generated.js +9 -0
- package/dist/server/api-client-core/apis/crm/object-library.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/objects-types.generated.d.ts +712 -0
- package/dist/server/api-client-core/apis/crm/objects.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/objects.generated.js +76 -0
- package/dist/server/api-client-core/apis/crm/objects.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/orders-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/orders.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/orders.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/orders.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/partner-clients-types.generated.d.ts +725 -0
- package/dist/server/api-client-core/apis/crm/partner-clients.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/partner-clients.generated.js +71 -0
- package/dist/server/api-client-core/apis/crm/partner-clients.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/partner-services-types.generated.d.ts +725 -0
- package/dist/server/api-client-core/apis/crm/partner-services.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/partner-services.generated.js +71 -0
- package/dist/server/api-client-core/apis/crm/partner-services.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/pipelines-types.generated.d.ts +430 -0
- package/dist/server/api-client-core/apis/crm/pipelines.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/pipelines.generated.js +94 -0
- package/dist/server/api-client-core/apis/crm/pipelines.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/postal-mail-types.generated.d.ts +844 -0
- package/dist/server/api-client-core/apis/crm/postal-mail.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/postal-mail.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/postal-mail.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/products-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/products.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/products.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/products.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/projects-types.generated.d.ts +881 -0
- package/dist/server/api-client-core/apis/crm/projects.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/projects.generated.js +67 -0
- package/dist/server/api-client-core/apis/crm/projects.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/properties-types.generated.d.ts +603 -0
- package/dist/server/api-client-core/apis/crm/properties.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/properties.generated.js +86 -0
- package/dist/server/api-client-core/apis/crm/properties.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/property-validations-types.generated.d.ts +121 -0
- package/dist/server/api-client-core/apis/crm/property-validations.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/property-validations.generated.js +25 -0
- package/dist/server/api-client-core/apis/crm/property-validations.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/public-app-crm-cards-types.generated.d.ts +486 -0
- package/dist/server/api-client-core/apis/crm/public-app-crm-cards.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/public-app-crm-cards.generated.js +34 -0
- package/dist/server/api-client-core/apis/crm/public-app-crm-cards.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/public-app-feature-flags-types.generated.d.ts +247 -0
- package/dist/server/api-client-core/apis/crm/public-app-feature-flags.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/public-app-feature-flags.generated.js +69 -0
- package/dist/server/api-client-core/apis/crm/public-app-feature-flags.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/quotes-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/quotes.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/quotes.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/quotes.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/schemas-types.generated.d.ts +669 -0
- package/dist/server/api-client-core/apis/crm/schemas.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/schemas.generated.js +41 -0
- package/dist/server/api-client-core/apis/crm/schemas.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/services-types.generated.d.ts +853 -0
- package/dist/server/api-client-core/apis/crm/services.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/services.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/services.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/tasks-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/tasks.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/tasks.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/tasks.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/taxes-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/taxes.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/taxes.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/taxes.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/tickets-types.generated.d.ts +884 -0
- package/dist/server/api-client-core/apis/crm/tickets.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/tickets.generated.js +67 -0
- package/dist/server/api-client-core/apis/crm/tickets.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/timeline-types.generated.d.ts +187 -0
- package/dist/server/api-client-core/apis/crm/timeline.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/timeline.generated.js +12 -0
- package/dist/server/api-client-core/apis/crm/timeline.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/transcriptions-types.generated.d.ts +152 -0
- package/dist/server/api-client-core/apis/crm/transcriptions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/transcriptions.generated.js +15 -0
- package/dist/server/api-client-core/apis/crm/transcriptions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/users-types.generated.d.ts +850 -0
- package/dist/server/api-client-core/apis/crm/users.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/users.generated.js +66 -0
- package/dist/server/api-client-core/apis/crm/users.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/crm/video-conferencing-extension-types.generated.d.ts +72 -0
- package/dist/server/api-client-core/apis/crm/video-conferencing-extension.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/crm/video-conferencing-extension.generated.js +13 -0
- package/dist/server/api-client-core/apis/crm/video-conferencing-extension.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/events/manage-event-definitions-types.generated.d.ts +1005 -0
- package/dist/server/api-client-core/apis/events/manage-event-definitions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/events/manage-event-definitions.generated.js +39 -0
- package/dist/server/api-client-core/apis/events/manage-event-definitions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/events/send-event-completions-types.generated.d.ts +94 -0
- package/dist/server/api-client-core/apis/events/send-event-completions.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/events/send-event-completions.generated.js +9 -0
- package/dist/server/api-client-core/apis/events/send-event-completions.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/events-types.generated.d.ts +137 -0
- package/dist/server/api-client-core/apis/events.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/events.generated.js +23 -0
- package/dist/server/api-client-core/apis/events.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/files-types.generated.d.ts +791 -0
- package/dist/server/api-client-core/apis/files.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/files.generated.js +119 -0
- package/dist/server/api-client-core/apis/files.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/marketing/campaigns-public-api-types.generated.d.ts +989 -0
- package/dist/server/api-client-core/apis/marketing/campaigns-public-api.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/marketing/campaigns-public-api.generated.js +139 -0
- package/dist/server/api-client-core/apis/marketing/campaigns-public-api.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/marketing/marketing-emails-types.generated.d.ts +883 -0
- package/dist/server/api-client-core/apis/marketing/marketing-emails.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/marketing/marketing-emails.generated.js +108 -0
- package/dist/server/api-client-core/apis/marketing/marketing-emails.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/marketing/marketing-events-types.generated.d.ts +1788 -0
- package/dist/server/api-client-core/apis/marketing/marketing-events.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/marketing/marketing-events.generated.js +176 -0
- package/dist/server/api-client-core/apis/marketing/marketing-events.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/marketing/single-send-types.generated.d.ts +123 -0
- package/dist/server/api-client-core/apis/marketing/single-send.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/marketing/single-send.generated.js +6 -0
- package/dist/server/api-client-core/apis/marketing/single-send.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/marketing/transactional-single-send-types.generated.d.ts +257 -0
- package/dist/server/api-client-core/apis/marketing/transactional-single-send.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/marketing/transactional-single-send.generated.js +20 -0
- package/dist/server/api-client-core/apis/marketing/transactional-single-send.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/meta/origins-types.generated.d.ts +77 -0
- package/dist/server/api-client-core/apis/meta/origins.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/meta/origins.generated.js +15 -0
- package/dist/server/api-client-core/apis/meta/origins.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/scheduler/meetings-types.generated.d.ts +913 -0
- package/dist/server/api-client-core/apis/scheduler/meetings.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/scheduler/meetings.generated.js +34 -0
- package/dist/server/api-client-core/apis/scheduler/meetings.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/settings/multicurrency-types.generated.d.ts +404 -0
- package/dist/server/api-client-core/apis/settings/multicurrency.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/settings/multicurrency.generated.js +38 -0
- package/dist/server/api-client-core/apis/settings/multicurrency.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/settings/tax-rates-types.generated.d.ts +111 -0
- package/dist/server/api-client-core/apis/settings/tax-rates.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/settings/tax-rates.generated.js +13 -0
- package/dist/server/api-client-core/apis/settings/tax-rates.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/settings/user-provisioning-types.generated.d.ts +297 -0
- package/dist/server/api-client-core/apis/settings/user-provisioning.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/settings/user-provisioning.generated.js +31 -0
- package/dist/server/api-client-core/apis/settings/user-provisioning.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/webhooks-journal-types.generated.d.ts +643 -0
- package/dist/server/api-client-core/apis/webhooks-journal.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/webhooks-journal.generated.js +75 -0
- package/dist/server/api-client-core/apis/webhooks-journal.generated.js.map +1 -0
- package/dist/server/api-client-core/apis/webhooks-types.generated.d.ts +1016 -0
- package/dist/server/api-client-core/apis/webhooks.generated.d.ts +7 -0
- package/dist/server/api-client-core/apis/webhooks.generated.js +105 -0
- package/dist/server/api-client-core/apis/webhooks.generated.js.map +1 -0
- package/dist/server/api-client-core/binary-data.d.ts +33 -0
- package/dist/server/api-client-core/binary-data.js +29 -0
- package/dist/server/api-client-core/binary-data.js.map +1 -0
- package/dist/server/api-client-core/client.d.ts +14 -0
- package/dist/server/api-client-core/client.js +75 -0
- package/dist/server/api-client-core/client.js.map +1 -0
- package/dist/server/api-client-core/codegen-helpers/file-op-wrappers.js +25 -0
- package/dist/server/api-client-core/codegen-helpers/file-op-wrappers.js.map +1 -0
- package/dist/server/api-client-core/errors.d.ts +27 -0
- package/dist/server/api-client-core/errors.js +33 -0
- package/dist/server/api-client-core/errors.js.map +1 -0
- package/dist/server/api-client-core/op.d.ts +37 -0
- package/dist/server/api-client-core/op.js +44 -0
- package/dist/server/api-client-core/op.js.map +1 -0
- package/dist/server/api-client-core/pagination.d.ts +60 -0
- package/dist/server/api-client-core/pagination.js +103 -0
- package/dist/server/api-client-core/pagination.js.map +1 -0
- package/dist/server/api-client-core/plugins/fetch-transport.js +72 -0
- package/dist/server/api-client-core/plugins/fetch-transport.js.map +1 -0
- package/dist/server/api-client-core/types.d.ts +135 -0
- package/dist/server/api-client.d.ts +197 -0
- package/dist/server/api-client.js +101 -0
- package/dist/server/constants.js +46 -0
- package/dist/server/constants.js.map +1 -0
- package/dist/server/deno/start.d.ts +12 -0
- package/dist/server/deno/start.js +21 -0
- package/dist/server/deno/start.js.map +1 -0
- package/dist/server/hono/hono-request-handler.js +54 -0
- package/dist/server/hono/hono-request-handler.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/auth-callback.js +125 -0
- package/dist/server/hono/hubspot-connect-routes/auth-callback.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/auth-init-session.js +90 -0
- package/dist/server/hono/hubspot-connect-routes/auth-init-session.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/auth-logout.js +97 -0
- package/dist/server/hono/hubspot-connect-routes/auth-logout.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/auth-refresh.js +101 -0
- package/dist/server/hono/hubspot-connect-routes/auth-refresh.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/cimd-client-metadata-types.d.ts +16 -0
- package/dist/server/hono/hubspot-connect-routes/cimd-client-metadata-types.js +13 -0
- package/dist/server/hono/hubspot-connect-routes/cimd-client-metadata-types.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/cimd-public-routes.js +42 -0
- package/dist/server/hono/hubspot-connect-routes/cimd-public-routes.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/constants.js +8 -0
- package/dist/server/hono/hubspot-connect-routes/constants.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/fetch-hubspot-client-metadata.js +43 -0
- package/dist/server/hono/hubspot-connect-routes/fetch-hubspot-client-metadata.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/hubspot-connect-routes.js +35 -0
- package/dist/server/hono/hubspot-connect-routes/hubspot-connect-routes.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/load-hubspot-connect-routes-env.js +34 -0
- package/dist/server/hono/hubspot-connect-routes/load-hubspot-connect-routes-env.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/oauth-client.js +104 -0
- package/dist/server/hono/hubspot-connect-routes/oauth-client.js.map +1 -0
- package/dist/server/hono/hubspot-connect-routes/utils.js +73 -0
- package/dist/server/hono/hubspot-connect-routes/utils.js.map +1 -0
- package/dist/server/hono/index.js +4 -0
- package/dist/server/hono/types.d.ts +28 -0
- package/dist/server/hono/utils/cookie-utils.js +29 -0
- package/dist/server/hono/utils/cookie-utils.js.map +1 -0
- package/dist/server/import-app-keys.js +42 -0
- package/dist/server/import-app-keys.js.map +1 -0
- package/dist/server/lovable/create-app-function-start.d.ts +26 -0
- package/dist/server/lovable/create-app-function-start.js +28 -0
- package/dist/server/lovable/create-app-function-start.js.map +1 -0
- package/dist/server/lovable/hubspot-connect/index.d.ts +15 -0
- package/dist/server/lovable/hubspot-connect/index.js +20 -0
- package/dist/server/lovable/hubspot-connect/index.js.map +1 -0
- package/dist/server/lovable/hubspot-connect/run-hubspot-connect-lovable-server.js +29 -0
- package/dist/server/lovable/hubspot-connect/run-hubspot-connect-lovable-server.js.map +1 -0
- package/dist/server/lovable.d.ts +6 -0
- package/dist/server/lovable.js +4 -0
- package/dist/server/oauth.d.ts +6 -0
- package/dist/server/oauth.js +5 -0
- package/dist/server/proxy.js +68 -0
- package/dist/server/proxy.js.map +1 -0
- package/dist/server/sanitize-request.js +41 -0
- package/dist/server/sanitize-request.js.map +1 -0
- package/dist/server/secure-start-core.d.ts +23 -0
- package/dist/server/secure-start-core.js +28 -0
- package/dist/server/secure-start-core.js.map +1 -0
- package/dist/server/shared/constants.js +17 -0
- package/dist/server/shared/constants.js.map +1 -0
- package/dist/server/shared/encoding/base64.js +45 -0
- package/dist/server/shared/encoding/base64.js.map +1 -0
- package/dist/server/shared/encoding/sha256.d.ts +10 -0
- package/dist/server/shared/encoding/sha256.js +15 -0
- package/dist/server/shared/encoding/sha256.js.map +1 -0
- package/dist/server/shared/logger.d.ts +15 -0
- package/dist/server/shared/logger.js +16 -0
- package/dist/server/shared/logger.js.map +1 -0
- package/dist/server/types.d.ts +56 -0
- package/dist/server/utils/cookie-utils.js +21 -0
- package/dist/server/utils/cookie-utils.js.map +1 -0
- package/dist/server/utils/dpop-utils.d.ts +67 -0
- package/dist/server/utils/dpop-utils.js +75 -0
- package/dist/server/utils/dpop-utils.js.map +1 -0
- package/dist/server/utils/env-utils.js +54 -0
- package/dist/server/utils/env-utils.js.map +1 -0
- package/dist/server/utils/jwk-utils.d.ts +16 -0
- package/dist/server/utils/jwk-utils.js +24 -0
- package/dist/server/utils/jwk-utils.js.map +1 -0
- package/dist/server/utils/jwt-utils.d.ts +39 -0
- package/dist/server/utils/jwt-utils.js +87 -0
- package/dist/server/utils/jwt-utils.js.map +1 -0
- package/eslint.config.js +5 -0
- package/package.json +68 -0
- package/src/browser/app-connect-controller/README.md +92 -0
- package/src/browser/app-connect-controller/connect-start.ts +45 -0
- package/src/browser/app-connect-controller/constants.ts +15 -0
- package/src/browser/app-connect-controller/create.ts +137 -0
- package/src/browser/app-connect-controller/default-session-storage.ts +21 -0
- package/src/browser/app-connect-controller/disconnect.ts +54 -0
- package/src/browser/app-connect-controller/init.ts +35 -0
- package/src/browser/app-connect-controller/refresh.ts +124 -0
- package/src/browser/app-connect-controller/types.ts +48 -0
- package/src/browser/app-connect-controller/utils/crypto-utils.ts +1 -0
- package/src/browser/app-connect-controller/utils/encode-utils.ts +1 -0
- package/src/browser/app-connect-controller/utils/memoize-utils.test.ts +48 -0
- package/src/browser/app-connect-controller/utils/memoize-utils.ts +26 -0
- package/src/browser/app-connect-controller/utils/session-utils.test.ts +127 -0
- package/src/browser/app-connect-controller/utils/session-utils.ts +58 -0
- package/src/browser/app-connect-controller/utils/store-utils.test.ts +102 -0
- package/src/browser/app-connect-controller/utils/store-utils.ts +119 -0
- package/src/browser/app-connect-controller/utils/timeout-utils.ts +8 -0
- package/src/browser/app-connect-controller/view-state.test.ts +70 -0
- package/src/browser/app-connect-controller/view-state.ts +40 -0
- package/src/browser/index.ts +13 -0
- package/src/browser/react/components/AppConnectHeader/AppConnectHeader.css.ts +231 -0
- package/src/browser/react/components/AppConnectHeader/AppConnectHeader.tsx +124 -0
- package/src/browser/react/components/Button/Button.css.ts +59 -0
- package/src/browser/react/components/Button/Button.tsx +38 -0
- package/src/browser/react/components/ConnectButton/ConnectButton.css.ts +73 -0
- package/src/browser/react/components/ConnectButton/ConnectButton.tsx +43 -0
- package/src/browser/react/components/DisconnectedBody/DisconnectedBody.css.ts +25 -0
- package/src/browser/react/components/DisconnectedBody/DisconnectedBody.tsx +25 -0
- package/src/browser/react/components/HubSpotAppConnect/HubSpotAppConnect.css.ts +23 -0
- package/src/browser/react/components/HubSpotAppConnect/HubSpotAppConnect.tsx +90 -0
- package/src/browser/react/components/LoadingIndicator/LoadingIndicator.css.ts +28 -0
- package/src/browser/react/components/LoadingIndicator/LoadingIndicator.tsx +9 -0
- package/src/browser/react/components/ShareButton/ShareButton.css.ts +52 -0
- package/src/browser/react/components/ShareButton/ShareButton.tsx +43 -0
- package/src/browser/react/components/icons/ChevronDownIcon.tsx +23 -0
- package/src/browser/react/components/icons/ExternalLinkIcon.tsx +23 -0
- package/src/browser/react/components/icons/HubSpotDataSourceIcon.tsx +33 -0
- package/src/browser/react/components/icons/LogoutIcon.tsx +37 -0
- package/src/browser/react/components/icons/ShareIcon.tsx +31 -0
- package/src/browser/react/context.ts +12 -0
- package/src/browser/react/hooks.ts +28 -0
- package/src/browser/react/index.ts +6 -0
- package/src/browser/react/lovable/LovableHubSpotAppConnect.tsx +37 -0
- package/src/browser/react/lovable/index.ts +4 -0
- package/src/browser/theme-tokens.generated.css.ts +424 -0
- package/src/browser/theme.css.ts +21 -0
- package/src/browser/types.ts +83 -0
- package/src/server/api-client-core/apis/account/account-info-types.generated.ts +116 -0
- package/src/server/api-client-core/apis/account/account-info.generated.ts +14 -0
- package/src/server/api-client-core/apis/account/audit-logs-types.generated.ts +409 -0
- package/src/server/api-client-core/apis/account/audit-logs.generated.ts +41 -0
- package/src/server/api-client-core/apis/auth/oauth-types.generated.ts +138 -0
- package/src/server/api-client-core/apis/auth/oauth.generated.ts +26 -0
- package/src/server/api-client-core/apis/automation/actions-types.generated.ts +1337 -0
- package/src/server/api-client-core/apis/automation/actions.generated.ts +166 -0
- package/src/server/api-client-core/apis/automation/sequences-types.generated.ts +456 -0
- package/src/server/api-client-core/apis/automation/sequences.generated.ts +34 -0
- package/src/server/api-client-core/apis/business-units-types.generated.ts +82 -0
- package/src/server/api-client-core/apis/business-units.generated.ts +16 -0
- package/src/server/api-client-core/apis/cms/authors-types.generated.ts +4003 -0
- package/src/server/api-client-core/apis/cms/authors.generated.ts +199 -0
- package/src/server/api-client-core/apis/cms/blog-settings-types.generated.ts +3795 -0
- package/src/server/api-client-core/apis/cms/blog-settings.generated.ts +79 -0
- package/src/server/api-client-core/apis/cms/cms-content-audit-types.generated.ts +198 -0
- package/src/server/api-client-core/apis/cms/cms-content-audit.generated.ts +31 -0
- package/src/server/api-client-core/apis/cms/domains-types.generated.ts +201 -0
- package/src/server/api-client-core/apis/cms/domains.generated.ts +30 -0
- package/src/server/api-client-core/apis/cms/hubdb-types.generated.ts +1276 -0
- package/src/server/api-client-core/apis/cms/hubdb.generated.ts +220 -0
- package/src/server/api-client-core/apis/cms/media-bridge-types.generated.ts +8928 -0
- package/src/server/api-client-core/apis/cms/media-bridge.generated.ts +244 -0
- package/src/server/api-client-core/apis/cms/pages-types.generated.ts +5548 -0
- package/src/server/api-client-core/apis/cms/pages.generated.ts +423 -0
- package/src/server/api-client-core/apis/cms/posts-types.generated.ts +4682 -0
- package/src/server/api-client-core/apis/cms/posts.generated.ts +254 -0
- package/src/server/api-client-core/apis/cms/site-search-types.generated.ts +1914 -0
- package/src/server/api-client-core/apis/cms/site-search.generated.ts +40 -0
- package/src/server/api-client-core/apis/cms/source-code-types.generated.ts +240 -0
- package/src/server/api-client-core/apis/cms/source-code.generated.ts +54 -0
- package/src/server/api-client-core/apis/cms/tags-types.generated.ts +3969 -0
- package/src/server/api-client-core/apis/cms/tags.generated.ts +199 -0
- package/src/server/api-client-core/apis/cms/url-mappings-types.generated.ts +245 -0
- package/src/server/api-client-core/apis/cms/url-mappings.generated.ts +25 -0
- package/src/server/api-client-core/apis/cms/url-redirects-types.generated.ts +241 -0
- package/src/server/api-client-core/apis/cms/url-redirects.generated.ts +40 -0
- package/src/server/api-client-core/apis/communication-preferences/subscriptions-types.generated.ts +893 -0
- package/src/server/api-client-core/apis/communication-preferences/subscriptions.generated.ts +108 -0
- package/src/server/api-client-core/apis/conversations/custom-channels-types.generated.ts +687 -0
- package/src/server/api-client-core/apis/conversations/custom-channels.generated.ts +121 -0
- package/src/server/api-client-core/apis/conversations/visitor-identification-types.generated.ts +66 -0
- package/src/server/api-client-core/apis/conversations/visitor-identification.generated.ts +14 -0
- package/src/server/api-client-core/apis/conversations-types.generated.ts +1126 -0
- package/src/server/api-client-core/apis/conversations.generated.ts +152 -0
- package/src/server/api-client-core/apis/crm/app-uninstalls-types.generated.ts +37 -0
- package/src/server/api-client-core/apis/crm/app-uninstalls.generated.ts +12 -0
- package/src/server/api-client-core/apis/crm/appointments-types.generated.ts +1094 -0
- package/src/server/api-client-core/apis/crm/appointments.generated.ts +153 -0
- package/src/server/api-client-core/apis/crm/associations-schema-types.generated.ts +403 -0
- package/src/server/api-client-core/apis/crm/associations-schema.generated.ts +99 -0
- package/src/server/api-client-core/apis/crm/associations-types.generated.ts +750 -0
- package/src/server/api-client-core/apis/crm/associations.generated.ts +134 -0
- package/src/server/api-client-core/apis/crm/calling-extensions-types.generated.ts +565 -0
- package/src/server/api-client-core/apis/crm/calling-extensions.generated.ts +75 -0
- package/src/server/api-client-core/apis/crm/calls-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/calls.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/carts-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/carts.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/commerce-payments-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/commerce-payments.generated.ts +115 -0
- package/src/server/api-client-core/apis/crm/commerce-subscriptions-types.generated.ts +935 -0
- package/src/server/api-client-core/apis/crm/commerce-subscriptions.generated.ts +109 -0
- package/src/server/api-client-core/apis/crm/communications-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/communications.generated.ts +115 -0
- package/src/server/api-client-core/apis/crm/companies-types.generated.ts +976 -0
- package/src/server/api-client-core/apis/crm/companies.generated.ts +112 -0
- package/src/server/api-client-core/apis/crm/contacts-types.generated.ts +996 -0
- package/src/server/api-client-core/apis/crm/contacts.generated.ts +114 -0
- package/src/server/api-client-core/apis/crm/contracts-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/contracts.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/courses-types.generated.ts +941 -0
- package/src/server/api-client-core/apis/crm/courses.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/crm-owners-types.generated.ts +148 -0
- package/src/server/api-client-core/apis/crm/crm-owners.generated.ts +25 -0
- package/src/server/api-client-core/apis/crm/custom-objects-types.generated.ts +1024 -0
- package/src/server/api-client-core/apis/crm/custom-objects.generated.ts +136 -0
- package/src/server/api-client-core/apis/crm/deal-splits-types.generated.ts +208 -0
- package/src/server/api-client-core/apis/crm/deal-splits.generated.ts +14 -0
- package/src/server/api-client-core/apis/crm/deals-types.generated.ts +963 -0
- package/src/server/api-client-core/apis/crm/deals.generated.ts +107 -0
- package/src/server/api-client-core/apis/crm/discounts-types.generated.ts +934 -0
- package/src/server/api-client-core/apis/crm/discounts.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/emails-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/emails.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/exports-types.generated.ts +360 -0
- package/src/server/api-client-core/apis/crm/exports.generated.ts +24 -0
- package/src/server/api-client-core/apis/crm/feedback-submissions-types.generated.ts +676 -0
- package/src/server/api-client-core/apis/crm/feedback-submissions.generated.ts +89 -0
- package/src/server/api-client-core/apis/crm/fees-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/fees.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/goal-targets-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/goal-targets.generated.ts +107 -0
- package/src/server/api-client-core/apis/crm/imports-types.generated.ts +754 -0
- package/src/server/api-client-core/apis/crm/imports.generated.ts +41 -0
- package/src/server/api-client-core/apis/crm/invoices-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/invoices.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/leads-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/leads.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/limits-tracking-types.generated.ts +371 -0
- package/src/server/api-client-core/apis/crm/limits-tracking.generated.ts +42 -0
- package/src/server/api-client-core/apis/crm/line-items-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/line-items.generated.ts +107 -0
- package/src/server/api-client-core/apis/crm/listings-types.generated.ts +941 -0
- package/src/server/api-client-core/apis/crm/listings.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/lists-types.generated.ts +3053 -0
- package/src/server/api-client-core/apis/crm/lists.generated.ts +166 -0
- package/src/server/api-client-core/apis/crm/meetings-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/meetings.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/notes-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/notes.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/object-library-types.generated.ts +67 -0
- package/src/server/api-client-core/apis/crm/object-library.generated.ts +16 -0
- package/src/server/api-client-core/apis/crm/objects-types.generated.ts +785 -0
- package/src/server/api-client-core/apis/crm/objects.generated.ts +90 -0
- package/src/server/api-client-core/apis/crm/orders-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/orders.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/partner-clients-types.generated.ts +804 -0
- package/src/server/api-client-core/apis/crm/partner-clients.generated.ts +108 -0
- package/src/server/api-client-core/apis/crm/partner-services-types.generated.ts +802 -0
- package/src/server/api-client-core/apis/crm/partner-services.generated.ts +108 -0
- package/src/server/api-client-core/apis/crm/pipelines-types.generated.ts +491 -0
- package/src/server/api-client-core/apis/crm/pipelines.generated.ts +144 -0
- package/src/server/api-client-core/apis/crm/postal-mail-types.generated.ts +932 -0
- package/src/server/api-client-core/apis/crm/postal-mail.generated.ts +107 -0
- package/src/server/api-client-core/apis/crm/products-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/products.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/projects-types.generated.ts +973 -0
- package/src/server/api-client-core/apis/crm/projects.generated.ts +112 -0
- package/src/server/api-client-core/apis/crm/properties-types.generated.ts +705 -0
- package/src/server/api-client-core/apis/crm/properties.generated.ts +97 -0
- package/src/server/api-client-core/apis/crm/property-validations-types.generated.ts +225 -0
- package/src/server/api-client-core/apis/crm/property-validations.generated.ts +47 -0
- package/src/server/api-client-core/apis/crm/public-app-crm-cards-types.generated.ts +550 -0
- package/src/server/api-client-core/apis/crm/public-app-crm-cards.generated.ts +46 -0
- package/src/server/api-client-core/apis/crm/public-app-feature-flags-types.generated.ts +284 -0
- package/src/server/api-client-core/apis/crm/public-app-feature-flags.generated.ts +89 -0
- package/src/server/api-client-core/apis/crm/quotes-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/quotes.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/schemas-types.generated.ts +735 -0
- package/src/server/api-client-core/apis/crm/schemas.generated.ts +68 -0
- package/src/server/api-client-core/apis/crm/services-types.generated.ts +941 -0
- package/src/server/api-client-core/apis/crm/services.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/tasks-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/tasks.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/taxes-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/taxes.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/tickets-types.generated.ts +976 -0
- package/src/server/api-client-core/apis/crm/tickets.generated.ts +112 -0
- package/src/server/api-client-core/apis/crm/timeline-types.generated.ts +207 -0
- package/src/server/api-client-core/apis/crm/timeline.generated.ts +23 -0
- package/src/server/api-client-core/apis/crm/transcriptions-types.generated.ts +200 -0
- package/src/server/api-client-core/apis/crm/transcriptions.generated.ts +29 -0
- package/src/server/api-client-core/apis/crm/users-types.generated.ts +938 -0
- package/src/server/api-client-core/apis/crm/users.generated.ts +106 -0
- package/src/server/api-client-core/apis/crm/video-conferencing-extension-types.generated.ts +78 -0
- package/src/server/api-client-core/apis/crm/video-conferencing-extension.generated.ts +25 -0
- package/src/server/api-client-core/apis/events/manage-event-definitions-types.generated.ts +1621 -0
- package/src/server/api-client-core/apis/events/manage-event-definitions.generated.ts +73 -0
- package/src/server/api-client-core/apis/events/send-event-completions-types.generated.ts +103 -0
- package/src/server/api-client-core/apis/events/send-event-completions.generated.ts +19 -0
- package/src/server/api-client-core/apis/events-types.generated.ts +145 -0
- package/src/server/api-client-core/apis/events.generated.ts +30 -0
- package/src/server/api-client-core/apis/files-types.generated.ts +904 -0
- package/src/server/api-client-core/apis/files.generated.ts +164 -0
- package/src/server/api-client-core/apis/index.generated.ts +97 -0
- package/src/server/api-client-core/apis/marketing/campaigns-public-api-types.generated.ts +1434 -0
- package/src/server/api-client-core/apis/marketing/campaigns-public-api.generated.ts +191 -0
- package/src/server/api-client-core/apis/marketing/marketing-emails-types.generated.ts +3858 -0
- package/src/server/api-client-core/apis/marketing/marketing-emails.generated.ts +146 -0
- package/src/server/api-client-core/apis/marketing/marketing-events-types.generated.ts +2122 -0
- package/src/server/api-client-core/apis/marketing/marketing-events.generated.ts +320 -0
- package/src/server/api-client-core/apis/marketing/single-send-types.generated.ts +178 -0
- package/src/server/api-client-core/apis/marketing/single-send.generated.ts +15 -0
- package/src/server/api-client-core/apis/marketing/transactional-single-send-types.generated.ts +337 -0
- package/src/server/api-client-core/apis/marketing/transactional-single-send.generated.ts +44 -0
- package/src/server/api-client-core/apis/meta/origins-types.generated.ts +84 -0
- package/src/server/api-client-core/apis/meta/origins.generated.ts +19 -0
- package/src/server/api-client-core/apis/scheduler/meetings-types.generated.ts +1110 -0
- package/src/server/api-client-core/apis/scheduler/meetings.generated.ts +50 -0
- package/src/server/api-client-core/apis/settings/multicurrency-types.generated.ts +2054 -0
- package/src/server/api-client-core/apis/settings/multicurrency.generated.ts +78 -0
- package/src/server/api-client-core/apis/settings/tax-rates-types.generated.ts +119 -0
- package/src/server/api-client-core/apis/settings/tax-rates.generated.ts +23 -0
- package/src/server/api-client-core/apis/settings/user-provisioning-types.generated.ts +322 -0
- package/src/server/api-client-core/apis/settings/user-provisioning.generated.ts +48 -0
- package/src/server/api-client-core/apis/webhooks-journal-types.generated.ts +906 -0
- package/src/server/api-client-core/apis/webhooks-journal.generated.ts +131 -0
- package/src/server/api-client-core/apis/webhooks-types.generated.ts +1423 -0
- package/src/server/api-client-core/apis/webhooks.generated.ts +171 -0
- package/src/server/api-client-core/binary-data.ts +38 -0
- package/src/server/api-client-core/client.ts +115 -0
- package/src/server/api-client-core/codegen-helpers/file-op-wrappers.ts +25 -0
- package/src/server/api-client-core/errors.ts +31 -0
- package/src/server/api-client-core/index.ts +49 -0
- package/src/server/api-client-core/op.ts +61 -0
- package/src/server/api-client-core/pagination.ts +106 -0
- package/src/server/api-client-core/plugins/fetch-transport.ts +115 -0
- package/src/server/api-client-core/plugins/index.ts +10 -0
- package/src/server/api-client-core/types.ts +148 -0
- package/src/server/api-client.ts +1 -0
- package/src/server/constants.ts +53 -0
- package/src/server/deno/index.ts +1 -0
- package/src/server/deno/start.ts +25 -0
- package/src/server/hono/hono-request-handler.ts +106 -0
- package/src/server/hono/hubspot-connect-routes/auth-callback.test.ts +225 -0
- package/src/server/hono/hubspot-connect-routes/auth-callback.ts +198 -0
- package/src/server/hono/hubspot-connect-routes/auth-init-session.test.ts +144 -0
- package/src/server/hono/hubspot-connect-routes/auth-init-session.ts +126 -0
- package/src/server/hono/hubspot-connect-routes/auth-logout.test.ts +124 -0
- package/src/server/hono/hubspot-connect-routes/auth-logout.ts +140 -0
- package/src/server/hono/hubspot-connect-routes/auth-refresh.test.ts +224 -0
- package/src/server/hono/hubspot-connect-routes/auth-refresh.ts +171 -0
- package/src/server/hono/hubspot-connect-routes/cimd-client-metadata-types.ts +54 -0
- package/src/server/hono/hubspot-connect-routes/cimd-public-routes.test.ts +128 -0
- package/src/server/hono/hubspot-connect-routes/cimd-public-routes.ts +72 -0
- package/src/server/hono/hubspot-connect-routes/constants.ts +3 -0
- package/src/server/hono/hubspot-connect-routes/fetch-hubspot-client-metadata.test.ts +75 -0
- package/src/server/hono/hubspot-connect-routes/fetch-hubspot-client-metadata.ts +73 -0
- package/src/server/hono/hubspot-connect-routes/hubspot-connect-routes.ts +95 -0
- package/src/server/hono/hubspot-connect-routes/load-hubspot-connect-routes-env.test.ts +145 -0
- package/src/server/hono/hubspot-connect-routes/load-hubspot-connect-routes-env.ts +67 -0
- package/src/server/hono/hubspot-connect-routes/oauth-client.ts +181 -0
- package/src/server/hono/hubspot-connect-routes/types.ts +36 -0
- package/src/server/hono/hubspot-connect-routes/utils.test.ts +132 -0
- package/src/server/hono/hubspot-connect-routes/utils.ts +138 -0
- package/src/server/hono/index.ts +6 -0
- package/src/server/hono/types.ts +25 -0
- package/src/server/hono/utils/cookie-utils.ts +55 -0
- package/src/server/import-app-keys.ts +55 -0
- package/src/server/lovable/create-app-function-start.ts +55 -0
- package/src/server/lovable/hubspot-connect/index.ts +28 -0
- package/src/server/lovable/hubspot-connect/run-hubspot-connect-lovable-server.ts +40 -0
- package/src/server/lovable/index.ts +16 -0
- package/src/server/node/index.ts +1 -0
- package/src/server/node/start.ts +25 -0
- package/src/server/oauth.ts +6 -0
- package/src/server/proxy.test.ts +80 -0
- package/src/server/proxy.ts +116 -0
- package/src/server/sanitize-request.test.ts +65 -0
- package/src/server/sanitize-request.ts +52 -0
- package/src/server/secure-start-core.ts +67 -0
- package/src/server/types.ts +62 -0
- package/src/server/utils/base64-utils.ts +5 -0
- package/src/server/utils/cookie-utils.test.ts +48 -0
- package/src/server/utils/cookie-utils.ts +26 -0
- package/src/server/utils/crypto-utils.ts +1 -0
- package/src/server/utils/dpop-utils.test.ts +102 -0
- package/src/server/utils/dpop-utils.ts +161 -0
- package/src/server/utils/env-utils.test.ts +92 -0
- package/src/server/utils/env-utils.ts +65 -0
- package/src/server/utils/jwk-utils.test.ts +34 -0
- package/src/server/utils/jwk-utils.ts +30 -0
- package/src/server/utils/jwt-utils.test.ts +81 -0
- package/src/server/utils/jwt-utils.ts +141 -0
- package/src/server/utils/test-fixtures.ts +32 -0
- package/src/shared/constants.ts +13 -0
- package/src/shared/encoding/base64.test.ts +57 -0
- package/src/shared/encoding/base64.ts +50 -0
- package/src/shared/encoding/sha256.test.ts +25 -0
- package/src/shared/encoding/sha256.ts +14 -0
- package/src/shared/logger.ts +50 -0
- package/src/shared/wire-types.ts +40 -0
- package/tsconfig.browser.json +10 -0
- package/tsconfig.json +8 -0
- package/tsconfig.server.json +12 -0
- package/tsdown.config.ts +38 -0
- package/vitest.config.ts +9 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { InitSessionResponse } from '../../shared/wire-types.ts';
|
|
2
|
+
import type { AppConnectContext } from './types.ts';
|
|
3
|
+
import { delay } from './utils/timeout-utils.ts';
|
|
4
|
+
|
|
5
|
+
/** Extra wait before redirect so the connect progress UI is visible; set to `0` to disable. */
|
|
6
|
+
const ARTIFICIAL_CONNECT_REDIRECT_DELAY_MS = 500;
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Begins the OAuth connect flow:
|
|
10
|
+
*
|
|
11
|
+
* 1. Calls the SDK's `auth/init-session` route to mint a fresh PKCE
|
|
12
|
+
* verifier + state and obtain HubSpot's `authorize` URL.
|
|
13
|
+
* 2. Navigates the browser to that URL (full-page redirect).
|
|
14
|
+
*
|
|
15
|
+
* The `return_path` is the current path + query so the user lands
|
|
16
|
+
* back where they started after authorizing.
|
|
17
|
+
*
|
|
18
|
+
* Throws when the init call fails. Does not return after the redirect
|
|
19
|
+
* begins because the page is unloaded.
|
|
20
|
+
*/
|
|
21
|
+
export async function startHubSpotConnection(
|
|
22
|
+
context: AppConnectContext
|
|
23
|
+
): Promise<void> {
|
|
24
|
+
const { config } = context;
|
|
25
|
+
|
|
26
|
+
const returnPath = `${window.location.pathname}${window.location.search}`;
|
|
27
|
+
|
|
28
|
+
const initUrl = new URL(
|
|
29
|
+
`${config.hubSpotConnectBaseUrl}/auth/init-session`,
|
|
30
|
+
window.location.origin
|
|
31
|
+
);
|
|
32
|
+
initUrl.searchParams.set('return_path', returnPath);
|
|
33
|
+
|
|
34
|
+
const initResponse = await fetch(initUrl.toString(), {
|
|
35
|
+
credentials: 'include',
|
|
36
|
+
});
|
|
37
|
+
if (!initResponse.ok)
|
|
38
|
+
throw new Error(`Failed to init session: ${initResponse.status}`);
|
|
39
|
+
const { authorization_url: authorizationUrl } =
|
|
40
|
+
(await initResponse.json()) as InitSessionResponse;
|
|
41
|
+
|
|
42
|
+
await delay(ARTIFICIAL_CONNECT_REDIRECT_DELAY_MS);
|
|
43
|
+
|
|
44
|
+
window.location.href = authorizationUrl;
|
|
45
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export { EXPIRES_AT_URL_PARAM } from '../../shared/constants.ts';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Key the controller persists the access-token `expiresAt` (Unix
|
|
5
|
+
* epoch milliseconds) under in `sessionStorage`. Survives full-page
|
|
6
|
+
* navigations within the same tab.
|
|
7
|
+
*/
|
|
8
|
+
export const EXPIRES_AT_KEY = 'hubspot_token_expires_at';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Number of milliseconds before `expiresAt` that the refresh
|
|
12
|
+
* scheduler attempts to mint a new access token. 60s is comfortably
|
|
13
|
+
* larger than typical network latency without burning lifetime.
|
|
14
|
+
*/
|
|
15
|
+
export const REFRESH_BUFFER_MS = 60_000;
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { noopLogger, type Logger } from '../../shared/logger.ts';
|
|
2
|
+
import type {
|
|
3
|
+
AppConnectBrowserConfig,
|
|
4
|
+
AppConnectController,
|
|
5
|
+
AppConnectState,
|
|
6
|
+
} from '../types.ts';
|
|
7
|
+
import { startHubSpotConnection } from './connect-start.ts';
|
|
8
|
+
import { createDefaultSessionStorage } from './default-session-storage.ts';
|
|
9
|
+
import { disconnectFromHubSpot as runDisconnectFromHubSpot } from './disconnect.ts';
|
|
10
|
+
import { initAppConnect } from './init.ts';
|
|
11
|
+
import { startRefreshScheduler } from './refresh.ts';
|
|
12
|
+
import type {
|
|
13
|
+
AppConnectContext,
|
|
14
|
+
AppConnectInternalState,
|
|
15
|
+
AppConnectStore,
|
|
16
|
+
} from './types.ts';
|
|
17
|
+
import { memoizeLast } from './utils/memoize-utils.ts';
|
|
18
|
+
import {
|
|
19
|
+
getExpiresAtFromSessionStorage,
|
|
20
|
+
isClientSessionActive,
|
|
21
|
+
} from './utils/session-utils.ts';
|
|
22
|
+
import { createStore } from './utils/store-utils.ts';
|
|
23
|
+
import { getDerivedStatus, SERVER_VIEW } from './view-state.ts';
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Options accepted by {@link createAppConnectController}.
|
|
27
|
+
*/
|
|
28
|
+
export interface CreateAppConnectControllerOptions {
|
|
29
|
+
/** Runtime configuration; see {@link AppConnectBrowserConfig}. */
|
|
30
|
+
config: AppConnectBrowserConfig;
|
|
31
|
+
/** Logger the controller uses for status/debug messages. */
|
|
32
|
+
logger?: Logger;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Creates an `AppConnectController`. Exactly one controller should be
|
|
37
|
+
* shared by the entire app — the React provider takes the controller
|
|
38
|
+
* as a prop and exposes it via context.
|
|
39
|
+
*
|
|
40
|
+
* The returned controller is inert until `start()` is called: nothing
|
|
41
|
+
* is read from session storage, no refresh timer is scheduled, and no
|
|
42
|
+
* fetches are issued. Tests can construct a controller and inspect
|
|
43
|
+
* its initial snapshot without triggering side effects.
|
|
44
|
+
*/
|
|
45
|
+
export function createAppConnectController(
|
|
46
|
+
options: CreateAppConnectControllerOptions
|
|
47
|
+
): AppConnectController {
|
|
48
|
+
const { config, logger = noopLogger } = options;
|
|
49
|
+
const sessionStorage = createDefaultSessionStorage();
|
|
50
|
+
const store: AppConnectStore = createStore<AppConnectInternalState>({
|
|
51
|
+
isInitComplete: false,
|
|
52
|
+
isConnectInFlight: false,
|
|
53
|
+
isDisconnectInFlight: false,
|
|
54
|
+
isSessionConnected: false,
|
|
55
|
+
error: null,
|
|
56
|
+
expiresAt: null,
|
|
57
|
+
});
|
|
58
|
+
const context: AppConnectContext = {
|
|
59
|
+
config,
|
|
60
|
+
logger,
|
|
61
|
+
sessionStorage,
|
|
62
|
+
store,
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
store.setState({ expiresAt: getExpiresAtFromSessionStorage(context) });
|
|
66
|
+
|
|
67
|
+
let hasStarted = false;
|
|
68
|
+
|
|
69
|
+
const connectToHubSpot = async () => {
|
|
70
|
+
logger.info('connectToHubSpot: starting');
|
|
71
|
+
store.setState({ error: null, isConnectInFlight: true });
|
|
72
|
+
try {
|
|
73
|
+
await startHubSpotConnection(context);
|
|
74
|
+
} catch (err) {
|
|
75
|
+
const message = err instanceof Error ? err.message : 'Connection failed';
|
|
76
|
+
logger.error('connectToHubSpot: failed', err);
|
|
77
|
+
store.setState({ error: message });
|
|
78
|
+
} finally {
|
|
79
|
+
logger.debug(
|
|
80
|
+
'connectToHubSpot: connect flow step finished (may redirect to HubSpot)'
|
|
81
|
+
);
|
|
82
|
+
store.setState({ isConnectInFlight: false });
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
const disconnectFromHubSpot = () => runDisconnectFromHubSpot(context);
|
|
86
|
+
|
|
87
|
+
const getViewStateMemoized = memoizeLast<
|
|
88
|
+
Readonly<AppConnectInternalState>,
|
|
89
|
+
AppConnectState
|
|
90
|
+
>((storeState) => ({
|
|
91
|
+
status: getDerivedStatus(storeState),
|
|
92
|
+
error: storeState.error,
|
|
93
|
+
connectToHubSpot,
|
|
94
|
+
disconnectFromHubSpot,
|
|
95
|
+
}));
|
|
96
|
+
|
|
97
|
+
function getSnapshot() {
|
|
98
|
+
return getViewStateMemoized(store.getSnapshot());
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return {
|
|
102
|
+
start() {
|
|
103
|
+
if (hasStarted) {
|
|
104
|
+
logger.debug('start skipped (already started)');
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
hasStarted = true;
|
|
108
|
+
startRefreshScheduler(context);
|
|
109
|
+
|
|
110
|
+
logger.info('start: initSdk (OAuth return handling if applicable)');
|
|
111
|
+
void (async () => {
|
|
112
|
+
try {
|
|
113
|
+
await initAppConnect(context);
|
|
114
|
+
logger.info('initSdk: completed without error');
|
|
115
|
+
} catch (err) {
|
|
116
|
+
logger.error('initSdk: failed', err);
|
|
117
|
+
store.setState({
|
|
118
|
+
error:
|
|
119
|
+
err instanceof Error
|
|
120
|
+
? err.message
|
|
121
|
+
: 'App Connect initialization failed',
|
|
122
|
+
});
|
|
123
|
+
} finally {
|
|
124
|
+
const sessionActive = isClientSessionActive(context);
|
|
125
|
+
logger.info('start: init complete, session active:', sessionActive);
|
|
126
|
+
store.setState({
|
|
127
|
+
isInitComplete: true,
|
|
128
|
+
isSessionConnected: sessionActive,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
})();
|
|
132
|
+
},
|
|
133
|
+
subscribe: (fn) => store.subscribe(fn),
|
|
134
|
+
getSnapshot,
|
|
135
|
+
getServerSnapshot: () => SERVER_VIEW,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { SessionStorage } from './types.ts';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Builds a `SessionStorage` adapter that delegates to the global
|
|
5
|
+
* `sessionStorage` object exposed by browsers. The controller uses
|
|
6
|
+
* this when no custom storage is supplied (e.g. for tests or non-DOM
|
|
7
|
+
* environments).
|
|
8
|
+
*/
|
|
9
|
+
export function createDefaultSessionStorage(): SessionStorage {
|
|
10
|
+
return {
|
|
11
|
+
setItem: (key, value) => {
|
|
12
|
+
sessionStorage.setItem(key, value);
|
|
13
|
+
},
|
|
14
|
+
getItem: (key) => {
|
|
15
|
+
return sessionStorage.getItem(key);
|
|
16
|
+
},
|
|
17
|
+
removeItem: (key) => {
|
|
18
|
+
sessionStorage.removeItem(key);
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { LogoutResponse } from '../../shared/wire-types.ts';
|
|
2
|
+
import type { AppConnectContext } from './types.ts';
|
|
3
|
+
import { clearSessionStorage } from './utils/session-utils.ts';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Disconnect flow:
|
|
7
|
+
*
|
|
8
|
+
* 1. Calls the SDK's `auth/logout` route to revoke the upstream token
|
|
9
|
+
* and clear the refresh-token cookie.
|
|
10
|
+
* 2. Clears the local session-storage `expiresAt` entry.
|
|
11
|
+
* 3. Updates the controller state to `disconnected` and navigates the
|
|
12
|
+
* browser to the URL the server returned in `redirect_to`.
|
|
13
|
+
*
|
|
14
|
+
* Errors are caught, logged, and surfaced via the controller's
|
|
15
|
+
* `error` field so the UI can show a retry state.
|
|
16
|
+
*/
|
|
17
|
+
export async function disconnectFromHubSpot(
|
|
18
|
+
context: AppConnectContext
|
|
19
|
+
): Promise<void> {
|
|
20
|
+
const { config, logger, store } = context;
|
|
21
|
+
logger.info('disconnectFromHubSpot: starting');
|
|
22
|
+
store.setState({ error: null, isDisconnectInFlight: true });
|
|
23
|
+
const { hubSpotConnectBaseUrl: appConnectBaseUrl } = config;
|
|
24
|
+
|
|
25
|
+
try {
|
|
26
|
+
clearSessionStorage(context);
|
|
27
|
+
|
|
28
|
+
const response = await fetch(`${appConnectBaseUrl}/auth/logout`, {
|
|
29
|
+
method: 'POST',
|
|
30
|
+
credentials: 'include',
|
|
31
|
+
});
|
|
32
|
+
if (!response.ok) {
|
|
33
|
+
throw new Error(`Logout failed: ${response.status}`);
|
|
34
|
+
}
|
|
35
|
+
const { redirect_to: redirectTo } =
|
|
36
|
+
(await response.json()) as LogoutResponse;
|
|
37
|
+
|
|
38
|
+
store.setState({
|
|
39
|
+
expiresAt: null,
|
|
40
|
+
isSessionConnected: false,
|
|
41
|
+
isDisconnectInFlight: false,
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
window.location.href = redirectTo;
|
|
45
|
+
logger.info('disconnectFromHubSpot: redirecting');
|
|
46
|
+
} catch (err) {
|
|
47
|
+
const message = err instanceof Error ? err.message : 'Disconnect failed';
|
|
48
|
+
logger.error('disconnectFromHubSpot: failed', err);
|
|
49
|
+
store.setState({
|
|
50
|
+
error: message,
|
|
51
|
+
isDisconnectInFlight: false,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { EXPIRES_AT_KEY, EXPIRES_AT_URL_PARAM } from './constants.ts';
|
|
2
|
+
import type { AppConnectContext } from './types.ts';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Picks up the `__hs_expires_at` parameter the OAuth callback adds to
|
|
6
|
+
* the redirect URL, persists it to the controller, and strips it from
|
|
7
|
+
* the address bar so it's not logged or bookmarked.
|
|
8
|
+
*
|
|
9
|
+
* Called once by `controller.start()`. A no-op when the parameter
|
|
10
|
+
* isn't present (e.g. on every page load other than the OAuth return
|
|
11
|
+
* trip).
|
|
12
|
+
*/
|
|
13
|
+
export async function initAppConnect(
|
|
14
|
+
context: AppConnectContext
|
|
15
|
+
): Promise<void> {
|
|
16
|
+
const params = new URLSearchParams(window.location.search);
|
|
17
|
+
const expiresAtStr = params.get(EXPIRES_AT_URL_PARAM);
|
|
18
|
+
if (!expiresAtStr) return;
|
|
19
|
+
|
|
20
|
+
const expiresAt = parseInt(expiresAtStr, 10);
|
|
21
|
+
if (isNaN(expiresAt)) return;
|
|
22
|
+
|
|
23
|
+
params.delete(EXPIRES_AT_URL_PARAM);
|
|
24
|
+
const cleanSearch = params.toString();
|
|
25
|
+
history.replaceState(
|
|
26
|
+
null,
|
|
27
|
+
'',
|
|
28
|
+
cleanSearch
|
|
29
|
+
? `${window.location.pathname}?${cleanSearch}`
|
|
30
|
+
: window.location.pathname
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
context.store.setState({ expiresAt });
|
|
34
|
+
context.sessionStorage.setItem(EXPIRES_AT_KEY, String(expiresAt));
|
|
35
|
+
}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import type { RefreshTokenResponse } from '../../shared/wire-types.ts';
|
|
2
|
+
import { REFRESH_BUFFER_MS } from './constants.ts';
|
|
3
|
+
import type { AppConnectContext } from './types.ts';
|
|
4
|
+
import {
|
|
5
|
+
isClientSessionActive,
|
|
6
|
+
storeExpiresAt,
|
|
7
|
+
} from './utils/session-utils.ts';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Tear-down handle returned by {@link startRefreshScheduler}. Calling
|
|
11
|
+
* `stop()` clears any pending refresh timer and unsubscribes from the
|
|
12
|
+
* store so the controller can be garbage-collected.
|
|
13
|
+
*/
|
|
14
|
+
export interface RefreshSchedulerHandle {
|
|
15
|
+
stop: () => void;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
async function refreshAccessToken(context: AppConnectContext): Promise<void> {
|
|
19
|
+
const { config } = context;
|
|
20
|
+
|
|
21
|
+
const refreshResponse = await fetch(
|
|
22
|
+
`${config.hubSpotConnectBaseUrl}/auth/refresh`,
|
|
23
|
+
{
|
|
24
|
+
method: 'POST',
|
|
25
|
+
credentials: 'include',
|
|
26
|
+
}
|
|
27
|
+
);
|
|
28
|
+
if (!refreshResponse.ok) {
|
|
29
|
+
throw new Error(`Refresh failed: ${refreshResponse.status}`);
|
|
30
|
+
}
|
|
31
|
+
const { expires_in: expiresInSeconds } =
|
|
32
|
+
(await refreshResponse.json()) as RefreshTokenResponse;
|
|
33
|
+
if (
|
|
34
|
+
typeof expiresInSeconds !== 'number' ||
|
|
35
|
+
!Number.isFinite(expiresInSeconds) ||
|
|
36
|
+
expiresInSeconds <= 0
|
|
37
|
+
) {
|
|
38
|
+
throw new Error('Refresh response missing or invalid expires_in');
|
|
39
|
+
}
|
|
40
|
+
const expiresAtMs = Date.now() + expiresInSeconds * 1000;
|
|
41
|
+
|
|
42
|
+
storeExpiresAt({ context, expiresAtMs });
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Subscribes to store changes and (re)schedules a token refresh
|
|
47
|
+
* whenever `expiresAt` moves. Returns a handle that the caller can
|
|
48
|
+
* use to stop the scheduler when the controller is destroyed.
|
|
49
|
+
*/
|
|
50
|
+
export function startRefreshScheduler(
|
|
51
|
+
context: AppConnectContext
|
|
52
|
+
): RefreshSchedulerHandle {
|
|
53
|
+
const { logger, store } = context;
|
|
54
|
+
|
|
55
|
+
let refreshTimer: ReturnType<typeof setTimeout> | null = null;
|
|
56
|
+
let stopped = false;
|
|
57
|
+
|
|
58
|
+
const scheduleRefresh = () => {
|
|
59
|
+
if (refreshTimer) {
|
|
60
|
+
clearTimeout(refreshTimer);
|
|
61
|
+
refreshTimer = null;
|
|
62
|
+
}
|
|
63
|
+
if (stopped) return;
|
|
64
|
+
|
|
65
|
+
const state = store.getSnapshot();
|
|
66
|
+
if (!state.isInitComplete || !state.isSessionConnected) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const expiresAt = state.expiresAt;
|
|
71
|
+
if (!expiresAt) {
|
|
72
|
+
logger.debug('scheduleRefresh: no expiresAt, skipping');
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const delayMs = Math.max(0, expiresAt - Date.now() - REFRESH_BUFFER_MS);
|
|
76
|
+
logger.debug(
|
|
77
|
+
'scheduleRefresh: next refresh in ',
|
|
78
|
+
(delayMs / 1000).toFixed(1),
|
|
79
|
+
's',
|
|
80
|
+
{
|
|
81
|
+
expiresAt,
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
refreshTimer = setTimeout(() => {
|
|
85
|
+
logger.debug('scheduleRefresh: timer fired, refreshing token');
|
|
86
|
+
refreshTimer = null;
|
|
87
|
+
if (stopped) return;
|
|
88
|
+
|
|
89
|
+
void (async () => {
|
|
90
|
+
try {
|
|
91
|
+
await refreshAccessToken(context);
|
|
92
|
+
if (stopped) return;
|
|
93
|
+
if (isClientSessionActive(context)) {
|
|
94
|
+
logger.info('token refresh: success, session still active');
|
|
95
|
+
} else {
|
|
96
|
+
logger.warn(
|
|
97
|
+
'token refresh: success but no active session in storage'
|
|
98
|
+
);
|
|
99
|
+
store.setState({ isSessionConnected: false });
|
|
100
|
+
}
|
|
101
|
+
} catch (err) {
|
|
102
|
+
logger.error('token refresh: failed', err);
|
|
103
|
+
if (stopped) return;
|
|
104
|
+
store.setState({ isSessionConnected: false });
|
|
105
|
+
}
|
|
106
|
+
})();
|
|
107
|
+
}, delayMs);
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
const unsubscribe = store.subscribe(() => {
|
|
111
|
+
scheduleRefresh();
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
return {
|
|
115
|
+
stop: () => {
|
|
116
|
+
stopped = true;
|
|
117
|
+
unsubscribe();
|
|
118
|
+
if (refreshTimer) {
|
|
119
|
+
clearTimeout(refreshTimer);
|
|
120
|
+
refreshTimer = null;
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { Logger } from '../index.ts';
|
|
2
|
+
import type { AppConnectBrowserConfig } from '../types.ts';
|
|
3
|
+
import type { Store } from './utils/store-utils.ts';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Subset of the browser `Storage` interface the controller relies on.
|
|
7
|
+
* Lets tests substitute an in-memory implementation without spinning
|
|
8
|
+
* up a DOM.
|
|
9
|
+
*/
|
|
10
|
+
export interface SessionStorage {
|
|
11
|
+
setItem: (key: string, value: string) => void;
|
|
12
|
+
getItem: (key: string) => string | null;
|
|
13
|
+
removeItem: (key: string) => void;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Internal state of the controller. The publicly visible
|
|
18
|
+
* `AppConnectState` is derived from this via `view-state.ts`.
|
|
19
|
+
*/
|
|
20
|
+
export interface AppConnectInternalState {
|
|
21
|
+
/** True after `start()` has finished its init step. */
|
|
22
|
+
isInitComplete: boolean;
|
|
23
|
+
/** True while `connectToHubSpot()` is in flight. */
|
|
24
|
+
isConnectInFlight: boolean;
|
|
25
|
+
/** True when `expiresAt` is in the future (i.e. the user is logged in). */
|
|
26
|
+
isSessionConnected: boolean;
|
|
27
|
+
/** True while `disconnectFromHubSpot()` is in flight. */
|
|
28
|
+
isDisconnectInFlight: boolean;
|
|
29
|
+
/** Last error message from any flow, or `null`. */
|
|
30
|
+
error: string | null;
|
|
31
|
+
/** Access-token expiry (Unix epoch milliseconds), or `null` if unknown. */
|
|
32
|
+
expiresAt: number | null;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/** Convenience alias for the typed store used by the controller. */
|
|
36
|
+
export type AppConnectStore = Store<AppConnectInternalState>;
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Bag of dependencies the per-controller flows need. Constructed
|
|
40
|
+
* once inside `createAppConnectController` and passed around so
|
|
41
|
+
* helpers don't have to take six positional arguments.
|
|
42
|
+
*/
|
|
43
|
+
export interface AppConnectContext {
|
|
44
|
+
config: AppConnectBrowserConfig;
|
|
45
|
+
logger: Logger;
|
|
46
|
+
sessionStorage: SessionStorage;
|
|
47
|
+
store: AppConnectStore;
|
|
48
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { sha256base64url } from '../../../shared/encoding/sha256.ts';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { base64url } from '../../../shared/encoding/base64.ts';
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
|
|
3
|
+
import { memoizeLast } from './memoize-utils.ts';
|
|
4
|
+
|
|
5
|
+
describe('memoizeLast', () => {
|
|
6
|
+
it('caches the most recent input/output pair', () => {
|
|
7
|
+
const inner = vi.fn((value: number) => value * 2);
|
|
8
|
+
const memoized = memoizeLast(inner);
|
|
9
|
+
|
|
10
|
+
expect(memoized(2)).toBe(4);
|
|
11
|
+
expect(memoized(2)).toBe(4);
|
|
12
|
+
expect(inner).toHaveBeenCalledTimes(1);
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it('re-runs when the input changes', () => {
|
|
16
|
+
const inner = vi.fn((value: number) => value * 2);
|
|
17
|
+
const memoized = memoizeLast(inner);
|
|
18
|
+
|
|
19
|
+
memoized(2);
|
|
20
|
+
memoized(3);
|
|
21
|
+
expect(inner).toHaveBeenCalledTimes(2);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it('uses Object.is for comparison', () => {
|
|
25
|
+
const inner = vi.fn((arg: { x: number }) => arg.x);
|
|
26
|
+
const memoized = memoizeLast(inner);
|
|
27
|
+
|
|
28
|
+
const a = { x: 1 };
|
|
29
|
+
memoized(a);
|
|
30
|
+
memoized(a);
|
|
31
|
+
expect(inner).toHaveBeenCalledTimes(1);
|
|
32
|
+
|
|
33
|
+
memoized({ x: 1 });
|
|
34
|
+
expect(inner).toHaveBeenCalledTimes(2);
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it('returns the cached output even when inner would error on re-call', () => {
|
|
38
|
+
let calls = 0;
|
|
39
|
+
const inner = (value: number): number => {
|
|
40
|
+
calls += 1;
|
|
41
|
+
if (calls > 1) throw new Error('should not be called twice');
|
|
42
|
+
return value;
|
|
43
|
+
};
|
|
44
|
+
const memoized = memoizeLast(inner);
|
|
45
|
+
expect(memoized(7)).toBe(7);
|
|
46
|
+
expect(memoized(7)).toBe(7);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Wraps `fn` so that calls with the same input (compared via
|
|
3
|
+
* `Object.is`) return the previous output without re-invoking `fn`.
|
|
4
|
+
* The cache holds at most one entry, so this is safe to use for
|
|
5
|
+
* derived view-state from a single store snapshot.
|
|
6
|
+
*
|
|
7
|
+
* Used by `getSnapshot` to keep the React state reference stable
|
|
8
|
+
* between unrelated store updates — `useSyncExternalStore` would
|
|
9
|
+
* otherwise re-render every consumer on every change.
|
|
10
|
+
*/
|
|
11
|
+
export function memoizeLast<TInput, TOutput>(
|
|
12
|
+
fn: (input: TInput) => TOutput
|
|
13
|
+
): (input: TInput) => TOutput {
|
|
14
|
+
let lastInput: TInput;
|
|
15
|
+
let lastOutput: TOutput;
|
|
16
|
+
let hasValue = false;
|
|
17
|
+
return (input: TInput): TOutput => {
|
|
18
|
+
if (hasValue && Object.is(lastInput, input)) {
|
|
19
|
+
return lastOutput;
|
|
20
|
+
}
|
|
21
|
+
lastInput = input;
|
|
22
|
+
lastOutput = fn(input);
|
|
23
|
+
hasValue = true;
|
|
24
|
+
return lastOutput;
|
|
25
|
+
};
|
|
26
|
+
}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
2
|
+
|
|
3
|
+
import { noopLogger } from '../../../shared/logger.ts';
|
|
4
|
+
import { EXPIRES_AT_KEY } from '../constants.ts';
|
|
5
|
+
import type {
|
|
6
|
+
AppConnectContext,
|
|
7
|
+
AppConnectInternalState,
|
|
8
|
+
SessionStorage,
|
|
9
|
+
} from '../types.ts';
|
|
10
|
+
import {
|
|
11
|
+
clearSessionStorage,
|
|
12
|
+
getExpiresAtFromSessionStorage,
|
|
13
|
+
isClientSessionActive,
|
|
14
|
+
storeExpiresAt,
|
|
15
|
+
} from './session-utils.ts';
|
|
16
|
+
import { createStore } from './store-utils.ts';
|
|
17
|
+
|
|
18
|
+
function createInMemorySessionStorage(): SessionStorage {
|
|
19
|
+
const map = new Map<string, string>();
|
|
20
|
+
return {
|
|
21
|
+
getItem: (key) => map.get(key) ?? null,
|
|
22
|
+
setItem: (key, value) => {
|
|
23
|
+
map.set(key, value);
|
|
24
|
+
},
|
|
25
|
+
removeItem: (key) => {
|
|
26
|
+
map.delete(key);
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function createTestContext(): AppConnectContext {
|
|
32
|
+
const initialState: AppConnectInternalState = {
|
|
33
|
+
isInitComplete: true,
|
|
34
|
+
isConnectInFlight: false,
|
|
35
|
+
isSessionConnected: false,
|
|
36
|
+
isDisconnectInFlight: false,
|
|
37
|
+
error: null,
|
|
38
|
+
expiresAt: null,
|
|
39
|
+
};
|
|
40
|
+
return {
|
|
41
|
+
config: { hubSpotConnectBaseUrl: '/functions/v1/hubspot-connect' },
|
|
42
|
+
logger: noopLogger,
|
|
43
|
+
sessionStorage: createInMemorySessionStorage(),
|
|
44
|
+
store: createStore<AppConnectInternalState>(initialState),
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
describe('session-utils', () => {
|
|
49
|
+
const FIXED_NOW = 1_700_000_000_000;
|
|
50
|
+
|
|
51
|
+
beforeEach(() => {
|
|
52
|
+
vi.useFakeTimers();
|
|
53
|
+
vi.setSystemTime(new Date(FIXED_NOW));
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
afterEach(() => {
|
|
57
|
+
vi.useRealTimers();
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
describe('storeExpiresAt', () => {
|
|
61
|
+
it('writes both the store and session storage', () => {
|
|
62
|
+
const context = createTestContext();
|
|
63
|
+
storeExpiresAt({ context, expiresAtMs: FIXED_NOW + 60_000 });
|
|
64
|
+
|
|
65
|
+
expect(context.store.getSnapshot().expiresAt).toBe(FIXED_NOW + 60_000);
|
|
66
|
+
expect(context.sessionStorage.getItem(EXPIRES_AT_KEY)).toBe(
|
|
67
|
+
String(FIXED_NOW + 60_000)
|
|
68
|
+
);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('getExpiresAtFromSessionStorage', () => {
|
|
73
|
+
it('returns null when nothing is stored', () => {
|
|
74
|
+
const context = createTestContext();
|
|
75
|
+
expect(getExpiresAtFromSessionStorage(context)).toBeNull();
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it('returns the stored value when in the future', () => {
|
|
79
|
+
const context = createTestContext();
|
|
80
|
+
const expiresAt = FIXED_NOW + 60_000;
|
|
81
|
+
context.sessionStorage.setItem(EXPIRES_AT_KEY, String(expiresAt));
|
|
82
|
+
expect(getExpiresAtFromSessionStorage(context)).toBe(expiresAt);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
it('clears and returns null on malformed input', () => {
|
|
86
|
+
const context = createTestContext();
|
|
87
|
+
context.sessionStorage.setItem(EXPIRES_AT_KEY, 'not-a-number');
|
|
88
|
+
expect(getExpiresAtFromSessionStorage(context)).toBeNull();
|
|
89
|
+
expect(context.sessionStorage.getItem(EXPIRES_AT_KEY)).toBeNull();
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('clears and returns null on already-expired values', () => {
|
|
93
|
+
const context = createTestContext();
|
|
94
|
+
context.sessionStorage.setItem(EXPIRES_AT_KEY, String(FIXED_NOW - 1));
|
|
95
|
+
expect(getExpiresAtFromSessionStorage(context)).toBeNull();
|
|
96
|
+
expect(context.sessionStorage.getItem(EXPIRES_AT_KEY)).toBeNull();
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
describe('clearSessionStorage', () => {
|
|
101
|
+
it('removes the persisted expiresAt key', () => {
|
|
102
|
+
const context = createTestContext();
|
|
103
|
+
context.sessionStorage.setItem(EXPIRES_AT_KEY, '123');
|
|
104
|
+
clearSessionStorage(context);
|
|
105
|
+
expect(context.sessionStorage.getItem(EXPIRES_AT_KEY)).toBeNull();
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
describe('isClientSessionActive', () => {
|
|
110
|
+
it('returns false when expiresAt is null', () => {
|
|
111
|
+
const context = createTestContext();
|
|
112
|
+
expect(isClientSessionActive(context)).toBe(false);
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
it('returns true when expiresAt is in the future', () => {
|
|
116
|
+
const context = createTestContext();
|
|
117
|
+
context.store.setState({ expiresAt: FIXED_NOW + 1_000 });
|
|
118
|
+
expect(isClientSessionActive(context)).toBe(true);
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it('returns false when expiresAt is in the past', () => {
|
|
122
|
+
const context = createTestContext();
|
|
123
|
+
context.store.setState({ expiresAt: FIXED_NOW - 1 });
|
|
124
|
+
expect(isClientSessionActive(context)).toBe(false);
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
});
|