@osdk/client 2.5.0-beta.4 → 2.5.0-beta.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +33 -4
- package/build/browser/MinimalClientContext.js.map +1 -1
- package/build/browser/actions/applyAction.js +4 -0
- package/build/browser/actions/applyAction.js.map +1 -1
- package/build/browser/createClient.js +2 -1
- package/build/browser/createClient.js.map +1 -1
- package/build/browser/createMinimalClient.js +2 -1
- package/build/browser/createMinimalClient.js.map +1 -1
- package/build/browser/index.js +2 -0
- package/build/browser/index.js.map +1 -1
- package/build/browser/object/Cache.test.js +1 -1
- package/build/browser/object/Cache.test.js.map +1 -1
- package/build/browser/object/aggregate.js +2 -0
- package/build/browser/object/aggregate.js.map +1 -1
- package/build/browser/object/convertWireToOsdkObjects/OsdkCustomInspectPrototype.js +1 -0
- package/build/browser/object/convertWireToOsdkObjects/OsdkCustomInspectPrototype.js.map +1 -1
- package/build/browser/object/convertWireToOsdkObjects/createOsdkInterface.js +6 -0
- package/build/browser/object/convertWireToOsdkObjects/createOsdkInterface.js.map +1 -1
- package/build/browser/object/convertWireToOsdkObjects/getDollarLink.js +20 -1
- package/build/browser/object/convertWireToOsdkObjects/getDollarLink.js.map +1 -1
- package/build/browser/object/convertWireToOsdkObjects.test.js +2 -0
- package/build/browser/object/convertWireToOsdkObjects.test.js.map +1 -1
- package/build/browser/object/fetchPage.js +5 -2
- package/build/browser/object/fetchPage.js.map +1 -1
- package/build/browser/observable/internal/AbstractHelper.js +4 -3
- package/build/browser/observable/internal/AbstractHelper.js.map +1 -1
- package/build/browser/observable/internal/BatchContext.js +2 -0
- package/build/browser/observable/internal/BatchContext.js.map +1 -0
- package/build/browser/observable/internal/CacheKeys.js +61 -36
- package/build/browser/observable/internal/CacheKeys.js.map +1 -1
- package/build/browser/observable/internal/Changes.js.map +1 -1
- package/build/browser/observable/internal/KnownCacheKey.js.map +1 -1
- package/build/browser/observable/internal/Layer.js +0 -8
- package/build/browser/observable/internal/Layer.js.map +1 -1
- package/build/browser/observable/internal/Layers.js +151 -0
- package/build/browser/observable/internal/Layers.js.map +1 -0
- package/build/browser/observable/internal/ObservableClientImpl.js +3 -1
- package/build/browser/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/browser/observable/internal/OrderByCanonicalizer.js +1 -37
- package/build/browser/observable/internal/OrderByCanonicalizer.js.map +1 -1
- package/build/browser/observable/internal/Queries.js +40 -0
- package/build/browser/observable/internal/Queries.js.map +1 -0
- package/build/browser/observable/internal/Query.js +1 -0
- package/build/browser/observable/internal/Query.js.map +1 -1
- package/build/browser/observable/internal/Store.js +37 -226
- package/build/browser/observable/internal/Store.js.map +1 -1
- package/build/browser/observable/internal/Store.test.js +12 -10
- package/build/browser/observable/internal/Store.test.js.map +1 -1
- package/build/browser/observable/internal/SubjectPayload.js +2 -0
- package/build/browser/observable/internal/SubjectPayload.js.map +1 -0
- package/build/browser/observable/internal/Subjects.js +55 -0
- package/build/browser/observable/internal/Subjects.js.map +1 -0
- package/build/browser/observable/internal/WeakRefTrie.js +61 -0
- package/build/browser/observable/internal/WeakRefTrie.js.map +1 -0
- package/build/browser/observable/internal/{ActionApplication.js → actions/ActionApplication.js} +2 -2
- package/build/browser/observable/internal/actions/ActionApplication.js.map +1 -0
- package/build/browser/observable/internal/{OptimisticJob.js → actions/OptimisticJob.js} +3 -3
- package/build/browser/observable/internal/actions/OptimisticJob.js.map +1 -0
- package/build/browser/observable/internal/base-list/BaseCollectionQuery.js.map +1 -0
- package/build/browser/observable/internal/base-list/BaseListQuery.js +411 -0
- package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -0
- package/build/{esm/observable/internal → browser/observable/internal/base-list}/createCollectionConnectable.js +2 -2
- package/build/browser/observable/internal/base-list/createCollectionConnectable.js.map +1 -0
- package/build/{esm/observable/internal → browser/observable/internal/base-list}/createCollectionConnectable.test.js +24 -26
- package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -0
- package/build/browser/observable/internal/base-list/removeDuplicates.js.map +1 -0
- package/build/browser/observable/internal/createInitEntry.js +25 -0
- package/build/browser/observable/internal/createInitEntry.js.map +1 -0
- package/build/browser/observable/internal/links/LinksHelper.js +5 -5
- package/build/browser/observable/internal/links/LinksHelper.js.map +1 -1
- package/build/browser/observable/internal/links/SpecificLinkCacheKey.js.map +1 -1
- package/build/browser/observable/internal/links/SpecificLinkQuery.js +1 -1
- package/build/browser/observable/internal/links/SpecificLinkQuery.js.map +1 -1
- package/build/browser/observable/internal/{ListCacheKey.js.map → list/ListCacheKey.js.map} +1 -1
- package/build/browser/observable/internal/{ListQuery.js → list/ListQuery.js} +12 -421
- package/build/browser/observable/internal/list/ListQuery.js.map +1 -0
- package/build/browser/observable/internal/list/ListQueryOptions.js +2 -0
- package/build/browser/observable/internal/list/ListQueryOptions.js.map +1 -0
- package/build/browser/observable/internal/list/ListsHelper.js +6 -6
- package/build/browser/observable/internal/list/ListsHelper.js.map +1 -1
- package/build/browser/observable/internal/object/ObjectCacheKey.js +2 -0
- package/build/browser/observable/internal/object/ObjectCacheKey.js.map +1 -0
- package/build/browser/observable/internal/{ObjectQuery.js → object/ObjectQuery.js} +4 -20
- package/build/browser/observable/internal/object/ObjectQuery.js.map +1 -0
- package/build/browser/observable/internal/object/ObjectsHelper.js +17 -3
- package/build/browser/observable/internal/object/ObjectsHelper.js.map +1 -1
- package/build/browser/observable/internal/sorting/SortingStrategy.js.map +1 -1
- package/build/browser/observable/internal/testUtils/invalidateList.js +2 -2
- package/build/browser/observable/internal/testUtils/invalidateList.js.map +1 -1
- package/build/browser/observable/internal/testUtils.js +2 -3
- package/build/browser/observable/internal/testUtils.js.map +1 -1
- package/build/browser/ontology/loadActionMetadata.js +3 -1
- package/build/browser/ontology/loadActionMetadata.js.map +1 -1
- package/build/browser/ontology/loadFullObjectMetadata.js +2 -1
- package/build/browser/ontology/loadFullObjectMetadata.js.map +1 -1
- package/build/browser/ontology/loadInterfaceMetadata.js +2 -1
- package/build/browser/ontology/loadInterfaceMetadata.js.map +1 -1
- package/build/browser/queries/applyQuery.js +3 -3
- package/build/browser/queries/applyQuery.js.map +1 -1
- package/build/browser/util/UserAgent.js +2 -2
- package/build/browser/util/extractObjectOrInterfaceType.js +9 -1
- package/build/browser/util/extractObjectOrInterfaceType.js.map +1 -1
- package/build/browser/util/extractObjectOrInterfaceType.test.js +2 -2
- package/build/browser/util/extractObjectOrInterfaceType.test.js.map +1 -1
- package/build/cjs/{chunk-6CBVXAAV.cjs → chunk-4GWXMQZE.cjs} +107 -75
- package/build/cjs/chunk-4GWXMQZE.cjs.map +1 -0
- package/build/cjs/{chunk-QR7IBJPZ.cjs → chunk-5KDG5ZET.cjs} +18 -6
- package/build/cjs/chunk-5KDG5ZET.cjs.map +1 -0
- package/build/cjs/{createClient-BJo8T7Js.d.cts → createClient-mOlFts15.d.cts} +1 -0
- package/build/cjs/index.cjs +7 -7
- package/build/cjs/index.d.cts +1 -1
- package/build/cjs/public/internal.cjs +8 -8
- package/build/cjs/public/unstable-do-not-use.cjs +831 -775
- package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
- package/build/cjs/public/unstable-do-not-use.d.cts +1 -1
- package/build/esm/MinimalClientContext.js.map +1 -1
- package/build/esm/actions/applyAction.js +4 -0
- package/build/esm/actions/applyAction.js.map +1 -1
- package/build/esm/createClient.js +2 -1
- package/build/esm/createClient.js.map +1 -1
- package/build/esm/createMinimalClient.js +2 -1
- package/build/esm/createMinimalClient.js.map +1 -1
- package/build/esm/index.js +2 -0
- package/build/esm/index.js.map +1 -1
- package/build/esm/object/Cache.test.js +1 -1
- package/build/esm/object/Cache.test.js.map +1 -1
- package/build/esm/object/aggregate.js +2 -0
- package/build/esm/object/aggregate.js.map +1 -1
- package/build/esm/object/convertWireToOsdkObjects/OsdkCustomInspectPrototype.js +1 -0
- package/build/esm/object/convertWireToOsdkObjects/OsdkCustomInspectPrototype.js.map +1 -1
- package/build/esm/object/convertWireToOsdkObjects/createOsdkInterface.js +6 -0
- package/build/esm/object/convertWireToOsdkObjects/createOsdkInterface.js.map +1 -1
- package/build/esm/object/convertWireToOsdkObjects/getDollarLink.js +20 -1
- package/build/esm/object/convertWireToOsdkObjects/getDollarLink.js.map +1 -1
- package/build/esm/object/convertWireToOsdkObjects.test.js +2 -0
- package/build/esm/object/convertWireToOsdkObjects.test.js.map +1 -1
- package/build/esm/object/fetchPage.js +5 -2
- package/build/esm/object/fetchPage.js.map +1 -1
- package/build/esm/observable/internal/AbstractHelper.js +4 -3
- package/build/esm/observable/internal/AbstractHelper.js.map +1 -1
- package/build/esm/observable/internal/BatchContext.js +2 -0
- package/build/esm/observable/internal/BatchContext.js.map +1 -0
- package/build/esm/observable/internal/CacheKeys.js +61 -36
- package/build/esm/observable/internal/CacheKeys.js.map +1 -1
- package/build/esm/observable/internal/Changes.js.map +1 -1
- package/build/esm/observable/internal/KnownCacheKey.js.map +1 -1
- package/build/esm/observable/internal/Layer.js +0 -8
- package/build/esm/observable/internal/Layer.js.map +1 -1
- package/build/esm/observable/internal/Layers.js +151 -0
- package/build/esm/observable/internal/Layers.js.map +1 -0
- package/build/esm/observable/internal/ObservableClientImpl.js +3 -1
- package/build/esm/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/esm/observable/internal/OrderByCanonicalizer.js +1 -37
- package/build/esm/observable/internal/OrderByCanonicalizer.js.map +1 -1
- package/build/esm/observable/internal/Queries.js +40 -0
- package/build/esm/observable/internal/Queries.js.map +1 -0
- package/build/esm/observable/internal/Query.js +1 -0
- package/build/esm/observable/internal/Query.js.map +1 -1
- package/build/esm/observable/internal/Store.js +37 -226
- package/build/esm/observable/internal/Store.js.map +1 -1
- package/build/esm/observable/internal/Store.test.js +12 -10
- package/build/esm/observable/internal/Store.test.js.map +1 -1
- package/build/esm/observable/internal/SubjectPayload.js +2 -0
- package/build/esm/observable/internal/SubjectPayload.js.map +1 -0
- package/build/esm/observable/internal/Subjects.js +55 -0
- package/build/esm/observable/internal/Subjects.js.map +1 -0
- package/build/esm/observable/internal/WeakRefTrie.js +61 -0
- package/build/esm/observable/internal/WeakRefTrie.js.map +1 -0
- package/build/esm/observable/internal/{ActionApplication.js → actions/ActionApplication.js} +2 -2
- package/build/esm/observable/internal/actions/ActionApplication.js.map +1 -0
- package/build/esm/observable/internal/{OptimisticJob.js → actions/OptimisticJob.js} +3 -3
- package/build/esm/observable/internal/actions/OptimisticJob.js.map +1 -0
- package/build/esm/observable/internal/base-list/BaseCollectionQuery.js.map +1 -0
- package/build/esm/observable/internal/base-list/BaseListQuery.js +411 -0
- package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -0
- package/build/{browser/observable/internal → esm/observable/internal/base-list}/createCollectionConnectable.js +2 -2
- package/build/esm/observable/internal/base-list/createCollectionConnectable.js.map +1 -0
- package/build/{browser/observable/internal → esm/observable/internal/base-list}/createCollectionConnectable.test.js +24 -26
- package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -0
- package/build/esm/observable/internal/base-list/removeDuplicates.js.map +1 -0
- package/build/esm/observable/internal/createInitEntry.js +25 -0
- package/build/esm/observable/internal/createInitEntry.js.map +1 -0
- package/build/esm/observable/internal/links/LinksHelper.js +5 -5
- package/build/esm/observable/internal/links/LinksHelper.js.map +1 -1
- package/build/esm/observable/internal/links/SpecificLinkCacheKey.js.map +1 -1
- package/build/esm/observable/internal/links/SpecificLinkQuery.js +1 -1
- package/build/esm/observable/internal/links/SpecificLinkQuery.js.map +1 -1
- package/build/esm/observable/internal/{ListCacheKey.js.map → list/ListCacheKey.js.map} +1 -1
- package/build/esm/observable/internal/{ListQuery.js → list/ListQuery.js} +12 -421
- package/build/esm/observable/internal/list/ListQuery.js.map +1 -0
- package/build/esm/observable/internal/list/ListQueryOptions.js +2 -0
- package/build/esm/observable/internal/list/ListQueryOptions.js.map +1 -0
- package/build/esm/observable/internal/list/ListsHelper.js +6 -6
- package/build/esm/observable/internal/list/ListsHelper.js.map +1 -1
- package/build/esm/observable/internal/object/ObjectCacheKey.js +2 -0
- package/build/esm/observable/internal/object/ObjectCacheKey.js.map +1 -0
- package/build/esm/observable/internal/{ObjectQuery.js → object/ObjectQuery.js} +4 -20
- package/build/esm/observable/internal/object/ObjectQuery.js.map +1 -0
- package/build/esm/observable/internal/object/ObjectsHelper.js +17 -3
- package/build/esm/observable/internal/object/ObjectsHelper.js.map +1 -1
- package/build/esm/observable/internal/sorting/SortingStrategy.js.map +1 -1
- package/build/esm/observable/internal/testUtils/invalidateList.js +2 -2
- package/build/esm/observable/internal/testUtils/invalidateList.js.map +1 -1
- package/build/esm/observable/internal/testUtils.js +2 -3
- package/build/esm/observable/internal/testUtils.js.map +1 -1
- package/build/esm/ontology/loadActionMetadata.js +3 -1
- package/build/esm/ontology/loadActionMetadata.js.map +1 -1
- package/build/esm/ontology/loadFullObjectMetadata.js +2 -1
- package/build/esm/ontology/loadFullObjectMetadata.js.map +1 -1
- package/build/esm/ontology/loadInterfaceMetadata.js +2 -1
- package/build/esm/ontology/loadInterfaceMetadata.js.map +1 -1
- package/build/esm/queries/applyQuery.js +3 -3
- package/build/esm/queries/applyQuery.js.map +1 -1
- package/build/esm/util/UserAgent.js +2 -2
- package/build/esm/util/extractObjectOrInterfaceType.js +9 -1
- package/build/esm/util/extractObjectOrInterfaceType.js.map +1 -1
- package/build/esm/util/extractObjectOrInterfaceType.test.js +2 -2
- package/build/esm/util/extractObjectOrInterfaceType.test.js.map +1 -1
- package/build/types/MinimalClientContext.d.ts +1 -0
- package/build/types/MinimalClientContext.d.ts.map +1 -1
- package/build/types/actions/applyAction.d.ts.map +1 -1
- package/build/types/createClient.d.ts +1 -0
- package/build/types/createClient.d.ts.map +1 -1
- package/build/types/index.d.ts +1 -1
- package/build/types/index.d.ts.map +1 -1
- package/build/types/observable/internal/AbstractHelper.d.ts +3 -1
- package/build/types/observable/internal/AbstractHelper.d.ts.map +1 -1
- package/build/types/observable/internal/BatchContext.d.ts +11 -0
- package/build/types/observable/internal/BatchContext.d.ts.map +1 -0
- package/build/types/observable/internal/CacheKeys.d.ts +9 -9
- package/build/types/observable/internal/CacheKeys.d.ts.map +1 -1
- package/build/types/observable/internal/Changes.d.ts +2 -2
- package/build/types/observable/internal/Changes.d.ts.map +1 -1
- package/build/types/observable/internal/KnownCacheKey.d.ts +2 -2
- package/build/types/observable/internal/KnownCacheKey.d.ts.map +1 -1
- package/build/types/observable/internal/Layer.d.ts +1 -2
- package/build/types/observable/internal/Layer.d.ts.map +1 -1
- package/build/types/observable/internal/Layers.d.ts +26 -0
- package/build/types/observable/internal/Layers.d.ts.map +1 -0
- package/build/types/observable/internal/OrderByCanonicalizer.d.ts +0 -7
- package/build/types/observable/internal/OrderByCanonicalizer.d.ts.map +1 -1
- package/build/types/observable/internal/Queries.d.ts +9 -0
- package/build/types/observable/internal/Queries.d.ts.map +1 -0
- package/build/types/observable/internal/Query.d.ts +5 -1
- package/build/types/observable/internal/Query.d.ts.map +1 -1
- package/build/types/observable/internal/Store.d.ts +19 -34
- package/build/types/observable/internal/Store.d.ts.map +1 -1
- package/build/types/observable/internal/Store.test.d.ts.map +1 -1
- package/build/types/observable/internal/SubjectPayload.d.ts +5 -0
- package/build/types/observable/internal/SubjectPayload.d.ts.map +1 -0
- package/build/types/observable/internal/Subjects.d.ts +16 -0
- package/build/types/observable/internal/Subjects.d.ts.map +1 -0
- package/build/types/observable/internal/WeakRefTrie.d.ts +13 -0
- package/build/types/observable/internal/WeakRefTrie.d.ts.map +1 -0
- package/build/types/observable/internal/{ActionApplication.d.ts → actions/ActionApplication.d.ts} +2 -2
- package/build/types/observable/internal/{ActionApplication.d.ts.map → actions/ActionApplication.d.ts.map} +1 -1
- package/build/types/observable/internal/{OptimisticJob.d.ts → actions/OptimisticJob.d.ts} +4 -4
- package/build/types/observable/internal/actions/OptimisticJob.d.ts.map +1 -0
- package/build/types/observable/internal/{BaseCollectionQuery.d.ts → base-list/BaseCollectionQuery.d.ts} +4 -4
- package/build/types/observable/internal/base-list/BaseCollectionQuery.d.ts.map +1 -0
- package/build/types/observable/internal/{ListQuery.d.ts → base-list/BaseListQuery.d.ts} +9 -91
- package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -0
- package/build/types/observable/internal/{createCollectionConnectable.d.ts → base-list/createCollectionConnectable.d.ts} +5 -4
- package/build/types/observable/internal/base-list/createCollectionConnectable.d.ts.map +1 -0
- package/build/types/observable/internal/base-list/createCollectionConnectable.test.d.ts.map +1 -0
- package/build/types/observable/internal/{removeDuplicates.d.ts → base-list/removeDuplicates.d.ts} +2 -2
- package/build/types/observable/internal/base-list/removeDuplicates.d.ts.map +1 -0
- package/build/types/observable/internal/createInitEntry.d.ts +3 -0
- package/build/types/observable/internal/createInitEntry.d.ts.map +1 -0
- package/build/types/observable/internal/links/LinksHelper.d.ts +3 -1
- package/build/types/observable/internal/links/LinksHelper.d.ts.map +1 -1
- package/build/types/observable/internal/links/SpecificLinkCacheKey.d.ts +1 -1
- package/build/types/observable/internal/links/SpecificLinkCacheKey.d.ts.map +1 -1
- package/build/types/observable/internal/links/SpecificLinkQuery.d.ts +4 -2
- package/build/types/observable/internal/links/SpecificLinkQuery.d.ts.map +1 -1
- package/build/types/observable/internal/{ListCacheKey.d.ts → list/ListCacheKey.d.ts} +4 -4
- package/build/types/observable/internal/list/ListCacheKey.d.ts.map +1 -0
- package/build/types/observable/internal/list/ListQuery.d.ts +75 -0
- package/build/types/observable/internal/list/ListQuery.d.ts.map +1 -0
- package/build/types/observable/internal/list/ListQueryOptions.d.ts +4 -0
- package/build/types/observable/internal/list/ListQueryOptions.d.ts.map +1 -0
- package/build/types/observable/internal/list/ListsHelper.d.ts +4 -2
- package/build/types/observable/internal/list/ListsHelper.d.ts.map +1 -1
- package/build/types/observable/internal/object/ObjectCacheKey.d.ts +5 -0
- package/build/types/observable/internal/object/ObjectCacheKey.d.ts.map +1 -0
- package/build/types/observable/internal/{ObjectQuery.d.ts → object/ObjectQuery.d.ts} +10 -10
- package/build/types/observable/internal/object/ObjectQuery.d.ts.map +1 -0
- package/build/types/observable/internal/object/ObjectsHelper.d.ts +1 -1
- package/build/types/observable/internal/object/ObjectsHelper.d.ts.map +1 -1
- package/build/types/observable/internal/sorting/SortingStrategy.d.ts +2 -2
- package/build/types/observable/internal/sorting/SortingStrategy.d.ts.map +1 -1
- package/build/types/observable/internal/testUtils.d.ts +1 -1
- package/build/types/observable/internal/testUtils.d.ts.map +1 -1
- package/package.json +23 -23
- package/build/browser/observable/internal/ActionApplication.js.map +0 -1
- package/build/browser/observable/internal/BaseCollectionQuery.js.map +0 -1
- package/build/browser/observable/internal/ListQuery.js.map +0 -1
- package/build/browser/observable/internal/ObjectQuery.js.map +0 -1
- package/build/browser/observable/internal/OptimisticJob.js.map +0 -1
- package/build/browser/observable/internal/createCollectionConnectable.js.map +0 -1
- package/build/browser/observable/internal/createCollectionConnectable.test.js.map +0 -1
- package/build/browser/observable/internal/removeDuplicates.js.map +0 -1
- package/build/cjs/chunk-6CBVXAAV.cjs.map +0 -1
- package/build/cjs/chunk-QR7IBJPZ.cjs.map +0 -1
- package/build/esm/observable/internal/ActionApplication.js.map +0 -1
- package/build/esm/observable/internal/BaseCollectionQuery.js.map +0 -1
- package/build/esm/observable/internal/ListQuery.js.map +0 -1
- package/build/esm/observable/internal/ObjectQuery.js.map +0 -1
- package/build/esm/observable/internal/OptimisticJob.js.map +0 -1
- package/build/esm/observable/internal/createCollectionConnectable.js.map +0 -1
- package/build/esm/observable/internal/createCollectionConnectable.test.js.map +0 -1
- package/build/esm/observable/internal/removeDuplicates.js.map +0 -1
- package/build/types/observable/internal/BaseCollectionQuery.d.ts.map +0 -1
- package/build/types/observable/internal/ListCacheKey.d.ts.map +0 -1
- package/build/types/observable/internal/ListQuery.d.ts.map +0 -1
- package/build/types/observable/internal/ObjectQuery.d.ts.map +0 -1
- package/build/types/observable/internal/OptimisticJob.d.ts.map +0 -1
- package/build/types/observable/internal/createCollectionConnectable.d.ts.map +0 -1
- package/build/types/observable/internal/createCollectionConnectable.test.d.ts.map +0 -1
- package/build/types/observable/internal/removeDuplicates.d.ts.map +0 -1
- /package/build/browser/observable/internal/{BaseCollectionQuery.js → base-list/BaseCollectionQuery.js} +0 -0
- /package/build/browser/observable/internal/{removeDuplicates.js → base-list/removeDuplicates.js} +0 -0
- /package/build/browser/observable/internal/{ListCacheKey.js → list/ListCacheKey.js} +0 -0
- /package/build/esm/observable/internal/{BaseCollectionQuery.js → base-list/BaseCollectionQuery.js} +0 -0
- /package/build/esm/observable/internal/{removeDuplicates.js → base-list/removeDuplicates.js} +0 -0
- /package/build/esm/observable/internal/{ListCacheKey.js → list/ListCacheKey.js} +0 -0
- /package/build/types/observable/internal/{createCollectionConnectable.test.d.ts → base-list/createCollectionConnectable.test.d.ts} +0 -0
|
@@ -14,427 +14,18 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
|
|
17
|
-
import deepEqual from "fast-deep-equal";
|
|
18
17
|
import groupBy from "object.groupby";
|
|
19
18
|
import invariant from "tiny-invariant";
|
|
20
|
-
import { additionalContext } from "
|
|
21
|
-
import { ObjectDefRef, UnderlyingOsdkObject } from "
|
|
22
|
-
import {
|
|
23
|
-
import { DEBUG_ONLY__changesToString } from "
|
|
24
|
-
import {
|
|
25
|
-
import {
|
|
26
|
-
import { objectSortaMatchesWhereClause as objectMatchesWhereClause } from "./objectMatchesWhereClause.js";
|
|
27
|
-
import { storeOsdkInstances } from "./ObjectQuery.js";
|
|
28
|
-
import { Query } from "./Query.js";
|
|
29
|
-
import { removeDuplicates } from "./removeDuplicates.js";
|
|
30
|
-
import { NoOpSortingStrategy, OrderBySortingStrategy } from "./sorting/SortingStrategy.js";
|
|
19
|
+
import { additionalContext } from "../../../Client.js";
|
|
20
|
+
import { ObjectDefRef, UnderlyingOsdkObject } from "../../../object/convertWireToOsdkObjects/InternalSymbols.js";
|
|
21
|
+
import { BaseListQuery } from "../base-list/BaseListQuery.js";
|
|
22
|
+
import { DEBUG_ONLY__changesToString } from "../Changes.js";
|
|
23
|
+
import { objectSortaMatchesWhereClause as objectMatchesWhereClause } from "../objectMatchesWhereClause.js";
|
|
24
|
+
import { OrderBySortingStrategy } from "../sorting/SortingStrategy.js";
|
|
31
25
|
export const API_NAME_IDX = 1;
|
|
32
26
|
export const TYPE_IDX = 0;
|
|
33
27
|
export const WHERE_IDX = 2;
|
|
34
28
|
export const ORDER_BY_IDX = 3;
|
|
35
|
-
/**
|
|
36
|
-
* Base class for collection-based queries (lists and links)
|
|
37
|
-
* Provides common functionality for working with collections of objects
|
|
38
|
-
*/
|
|
39
|
-
export class BaseListQuery extends Query {
|
|
40
|
-
/**
|
|
41
|
-
* The sorting strategy to use for this collection
|
|
42
|
-
* @protected
|
|
43
|
-
*/
|
|
44
|
-
sortingStrategy = new NoOpSortingStrategy();
|
|
45
|
-
|
|
46
|
-
// Collection-specific behavior is implemented by subclasses
|
|
47
|
-
/**
|
|
48
|
-
* Token for the next page of results
|
|
49
|
-
* @protected
|
|
50
|
-
*/
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Promise tracking an in-progress page fetch
|
|
54
|
-
* @protected
|
|
55
|
-
*/
|
|
56
|
-
|
|
57
|
-
//
|
|
58
|
-
// Shared Implementations
|
|
59
|
-
//
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Standard method to update a list of objects
|
|
63
|
-
* Handles common list update patterns for both ListQuery and SpecificLinkQuery
|
|
64
|
-
*
|
|
65
|
-
* @param items Objects or cache keys to add to the list
|
|
66
|
-
* @param status Status to set for the list
|
|
67
|
-
* @param batch Batch context to use
|
|
68
|
-
* @param append Whether to append to the existing list or replace it
|
|
69
|
-
* @returns The updated entry
|
|
70
|
-
*/
|
|
71
|
-
_updateList(items, status, batch, append = false) {
|
|
72
|
-
if (process.env.NODE_ENV !== "production") {
|
|
73
|
-
const logger = process.env.NODE_ENV !== "production" ? this.logger?.child({
|
|
74
|
-
methodName: "updateList"
|
|
75
|
-
}) : this.logger;
|
|
76
|
-
logger?.debug(`{status: ${status}, append: ${append}}`, JSON.stringify(items, null, 2));
|
|
77
|
-
}
|
|
78
|
-
let objectCacheKeys;
|
|
79
|
-
if (items.length === 0) {
|
|
80
|
-
objectCacheKeys = [];
|
|
81
|
-
} else if (isObjectInstance(items[0])) {
|
|
82
|
-
// Items are object instances, need to store them first
|
|
83
|
-
objectCacheKeys = this.storeObjects(items, batch);
|
|
84
|
-
} else {
|
|
85
|
-
// Items are already cache keys
|
|
86
|
-
objectCacheKeys = items;
|
|
87
|
-
}
|
|
88
|
-
objectCacheKeys = this.#retainReleaseAppend(batch, append, objectCacheKeys);
|
|
89
|
-
objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);
|
|
90
|
-
objectCacheKeys = removeDuplicates(objectCacheKeys, batch);
|
|
91
|
-
return this.writeToStore({
|
|
92
|
-
data: objectCacheKeys
|
|
93
|
-
}, status, batch);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* Common implementation for writing to store for collection-based queries
|
|
98
|
-
* @param data The collection data to write to the store
|
|
99
|
-
* @param status The status to set
|
|
100
|
-
* @param batch The batch context
|
|
101
|
-
*/
|
|
102
|
-
writeToStore(data, status, batch) {
|
|
103
|
-
const entry = batch.read(this.cacheKey);
|
|
104
|
-
if (entry && deepEqual(data, entry.value)) {
|
|
105
|
-
// Check if both data AND status are the same
|
|
106
|
-
if (entry.status === status) {
|
|
107
|
-
if (process.env.NODE_ENV !== "production") {
|
|
108
|
-
this.logger?.child({
|
|
109
|
-
methodName: "writeToStore"
|
|
110
|
-
}).debug(`Collection data was deep equal and status unchanged (${status}), skipping update`);
|
|
111
|
-
}
|
|
112
|
-
// Return the existing entry without writing to avoid unnecessary notifications
|
|
113
|
-
return entry;
|
|
114
|
-
}
|
|
115
|
-
if (process.env.NODE_ENV !== "production") {
|
|
116
|
-
this.logger?.child({
|
|
117
|
-
methodName: "writeToStore"
|
|
118
|
-
}).debug(`Collection data was deep equal, just updating status from ${entry.status} to ${status}`);
|
|
119
|
-
}
|
|
120
|
-
// Keep the same value but update status and lastUpdated
|
|
121
|
-
return batch.write(this.cacheKey, entry.value, status);
|
|
122
|
-
}
|
|
123
|
-
if (process.env.NODE_ENV !== "production") {
|
|
124
|
-
this.logger?.child({
|
|
125
|
-
methodName: "writeToStore"
|
|
126
|
-
}).debug(`{status: ${status}},`, DEBUG_ONLY__cacheKeysToString(data.data));
|
|
127
|
-
}
|
|
128
|
-
const ret = batch.write(this.cacheKey, data, status);
|
|
129
|
-
this.registerCacheChanges(batch);
|
|
130
|
-
return ret;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
/**
|
|
134
|
-
* Register changes to the cache based on the specific collection type
|
|
135
|
-
* Implemented by subclasses to handle specific change registration
|
|
136
|
-
*/
|
|
137
|
-
|
|
138
|
-
/**
|
|
139
|
-
* Common method to store objects in the cache and return their cache keys
|
|
140
|
-
* Used by collection queries when storing object references
|
|
141
|
-
*
|
|
142
|
-
* @param objects Array of objects to store
|
|
143
|
-
* @param batch The batch context to use
|
|
144
|
-
* @returns Array of cache keys for the stored objects
|
|
145
|
-
*/
|
|
146
|
-
storeObjects(objects, batch) {
|
|
147
|
-
// Store the individual objects in their respective cache entries
|
|
148
|
-
return objects.length > 0 ? storeOsdkInstances(this.store, objects, batch) : [];
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
/**
|
|
152
|
-
* Common method for managing object reference counting and appending results
|
|
153
|
-
* Used by collection queries when updating object references
|
|
154
|
-
*
|
|
155
|
-
* @param batch The batch context to use
|
|
156
|
-
* @param append Whether to append to existing objects or replace them
|
|
157
|
-
* @param objectCacheKeys Array of object cache keys to process
|
|
158
|
-
* @returns The final array of object cache keys after retain/release/append
|
|
159
|
-
*/
|
|
160
|
-
#retainReleaseAppend(batch, append, objectCacheKeys) {
|
|
161
|
-
const existingList = batch.read(this.cacheKey);
|
|
162
|
-
|
|
163
|
-
// whether its append or update we need to retain all the new objects
|
|
164
|
-
if (!batch.optimisticWrite) {
|
|
165
|
-
if (!append) {
|
|
166
|
-
// we need to release all the old objects
|
|
167
|
-
// N.B. the store keeps the cache keys around for a bit so we don't
|
|
168
|
-
// need to worry about them being GC'd before we re-retain them
|
|
169
|
-
for (const objectCacheKey of existingList?.value?.data ?? []) {
|
|
170
|
-
this.store.release(objectCacheKey);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
for (const objectCacheKey of objectCacheKeys) {
|
|
174
|
-
this.store.retain(objectCacheKey);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
if (append) {
|
|
178
|
-
objectCacheKeys = [...(existingList?.value?.data ?? []), ...objectCacheKeys];
|
|
179
|
-
}
|
|
180
|
-
return objectCacheKeys;
|
|
181
|
-
}
|
|
182
|
-
_dispose() {
|
|
183
|
-
// eslint-disable-next-line no-console
|
|
184
|
-
console.log("DISPOSE LIST QUERY");
|
|
185
|
-
this.store.batch({}, batch => {
|
|
186
|
-
const entry = batch.read(this.cacheKey);
|
|
187
|
-
if (entry) {
|
|
188
|
-
for (const objectCacheKey of entry.value?.data ?? []) {
|
|
189
|
-
this.store.release(objectCacheKey);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
});
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
/**
|
|
196
|
-
* Creates a payload from collection parameters
|
|
197
|
-
* Default implementation that covers common fields for all collection types
|
|
198
|
-
* Subclasses may override to add type-specific fields if needed
|
|
199
|
-
*
|
|
200
|
-
* @param params Common collection parameters
|
|
201
|
-
* @returns A typed payload for the specific collection type
|
|
202
|
-
*/
|
|
203
|
-
createPayload(params) {
|
|
204
|
-
return {
|
|
205
|
-
resolvedList: params.resolvedData,
|
|
206
|
-
isOptimistic: params.isOptimistic,
|
|
207
|
-
fetchMore: this.fetchMore,
|
|
208
|
-
hasMore: this.nextPageToken != null,
|
|
209
|
-
status: params.status,
|
|
210
|
-
lastUpdated: params.lastUpdated
|
|
211
|
-
}; // Type assertion needed since we don't know exact subtype
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
/**
|
|
215
|
-
* Creates a connectable observable for this collection
|
|
216
|
-
* Common implementation shared by all collection types
|
|
217
|
-
*
|
|
218
|
-
* @param subject The subject to connect to
|
|
219
|
-
* @returns A connectable observable of the collection's payload type
|
|
220
|
-
*/
|
|
221
|
-
_createConnectable(subject) {
|
|
222
|
-
return createCollectionConnectable(subject, this.store, params => this.createPayload(params));
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
/**
|
|
226
|
-
* @override Reset pagination state before a fetch
|
|
227
|
-
*/
|
|
228
|
-
_preFetch() {
|
|
229
|
-
this.nextPageToken = undefined;
|
|
230
|
-
super._preFetch();
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
/**
|
|
234
|
-
* Common fetchMore implementation for pagination
|
|
235
|
-
* Handles pending request management and loading states
|
|
236
|
-
*/
|
|
237
|
-
fetchMore = () => {
|
|
238
|
-
if (this.pendingPageFetch) {
|
|
239
|
-
return this.pendingPageFetch;
|
|
240
|
-
}
|
|
241
|
-
if (this.pendingFetch) {
|
|
242
|
-
this.pendingPageFetch = new Promise(async res => {
|
|
243
|
-
await this.pendingFetch;
|
|
244
|
-
res(this.fetchMore());
|
|
245
|
-
});
|
|
246
|
-
return this.pendingPageFetch;
|
|
247
|
-
}
|
|
248
|
-
if (this.nextPageToken == null) {
|
|
249
|
-
return Promise.resolve(undefined);
|
|
250
|
-
}
|
|
251
|
-
this.store.batch({}, batch => {
|
|
252
|
-
this.setStatus("loading", batch);
|
|
253
|
-
});
|
|
254
|
-
this.pendingFetch = this.fetchPageAndUpdate("loaded", this.abortController?.signal).then(() => void 0).finally(() => {
|
|
255
|
-
this.pendingPageFetch = undefined;
|
|
256
|
-
});
|
|
257
|
-
return this.pendingFetch;
|
|
258
|
-
};
|
|
259
|
-
|
|
260
|
-
/**
|
|
261
|
-
* Minimum number of results to load initially
|
|
262
|
-
* May be overridden by subclasses for specific collection types
|
|
263
|
-
* @protected
|
|
264
|
-
*/
|
|
265
|
-
minResultsToLoad = 0;
|
|
266
|
-
|
|
267
|
-
/**
|
|
268
|
-
* Common _fetchAndStore implementation for pagination
|
|
269
|
-
* Uses fetchPageAndUpdate to load the initial set of data
|
|
270
|
-
* Will load multiple pages if necessary to reach minResultsToLoad
|
|
271
|
-
*/
|
|
272
|
-
async _fetchAndStore() {
|
|
273
|
-
if (process.env.NODE_ENV !== "production") {
|
|
274
|
-
this.logger?.child({
|
|
275
|
-
methodName: "_fetchAndStore"
|
|
276
|
-
}).debug("fetching pages");
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
// Keep fetching pages until we have the minimum number of results or no more pages
|
|
280
|
-
while (true) {
|
|
281
|
-
const entry = await this.fetchPageAndUpdate("loading", this.abortController?.signal);
|
|
282
|
-
if (!entry) {
|
|
283
|
-
// we were aborted
|
|
284
|
-
return;
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
// Check if we have enough results or no more pages
|
|
288
|
-
const count = entry.value?.data.length || 0;
|
|
289
|
-
if (count >= this.minResultsToLoad || this.nextPageToken == null) {
|
|
290
|
-
break;
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
this.store.batch({}, batch => {
|
|
294
|
-
this.setStatus("loaded", batch);
|
|
295
|
-
});
|
|
296
|
-
return Promise.resolve();
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
/**
|
|
300
|
-
* Template method for fetching a page of data and updating the store
|
|
301
|
-
* Provides common error handling and abort signal checking
|
|
302
|
-
*
|
|
303
|
-
* @param status The status to set for the entry
|
|
304
|
-
* @param signal Optional AbortSignal for cancellation
|
|
305
|
-
* @returns A promise that resolves to the updated entry or undefined if aborted
|
|
306
|
-
*/
|
|
307
|
-
async fetchPageAndUpdate(status, signal) {
|
|
308
|
-
if (process.env.NODE_ENV !== "production") {
|
|
309
|
-
this.logger?.child({
|
|
310
|
-
methodName: "fetchPageAndUpdate"
|
|
311
|
-
}).debug(`Fetching data with status: ${status}`);
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
// Early abort check
|
|
315
|
-
if (signal?.aborted) {
|
|
316
|
-
return undefined;
|
|
317
|
-
}
|
|
318
|
-
try {
|
|
319
|
-
// Call the subclass-specific implementation to fetch data
|
|
320
|
-
const result = await this.fetchPageData(signal);
|
|
321
|
-
|
|
322
|
-
// Check for abort again after fetch
|
|
323
|
-
if (signal?.aborted) {
|
|
324
|
-
return undefined;
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
// Store the fetched data using batch operations
|
|
328
|
-
const {
|
|
329
|
-
retVal
|
|
330
|
-
} = this.store.batch({}, batch => {
|
|
331
|
-
const append = this.nextPageToken != null;
|
|
332
|
-
const finalStatus = result.nextPageToken ? status : "loaded";
|
|
333
|
-
return this._updateList(this.storeObjects(result.data, batch), finalStatus, batch, append);
|
|
334
|
-
});
|
|
335
|
-
return retVal;
|
|
336
|
-
} catch (error) {
|
|
337
|
-
// Log any errors that occur
|
|
338
|
-
if (process.env.NODE_ENV !== "production") {
|
|
339
|
-
this.logger?.child({
|
|
340
|
-
methodName: "fetchPageAndUpdate"
|
|
341
|
-
}).error("Error fetching data", error);
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
// For unexpected errors, write error status if not aborted
|
|
345
|
-
if (!signal?.aborted) {
|
|
346
|
-
const {
|
|
347
|
-
retVal
|
|
348
|
-
} = this.store.batch({}, batch => {
|
|
349
|
-
return this.handleFetchError(error, status, batch);
|
|
350
|
-
});
|
|
351
|
-
return retVal;
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
// If aborted, just return undefined
|
|
355
|
-
return undefined;
|
|
356
|
-
}
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
/**
|
|
360
|
-
* Abstract method that subclasses implement for their specific data fetching logic
|
|
361
|
-
*
|
|
362
|
-
* @param signal Optional AbortSignal for cancellation
|
|
363
|
-
* @returns A promise that resolves to the fetched data
|
|
364
|
-
*/
|
|
365
|
-
|
|
366
|
-
/**
|
|
367
|
-
* Handle fetch errors by setting appropriate error state
|
|
368
|
-
* Default implementation that subclasses can override
|
|
369
|
-
*
|
|
370
|
-
* @param error The error that occurred
|
|
371
|
-
* @param status The intended status if successful
|
|
372
|
-
* @param batch The batch context to use
|
|
373
|
-
* @returns The updated entry with error status
|
|
374
|
-
*/
|
|
375
|
-
handleFetchError(_error, _status, batch) {
|
|
376
|
-
// Default implementation writes an empty list with error status
|
|
377
|
-
// Most subclasses should be able to use this
|
|
378
|
-
return this.writeToStore({
|
|
379
|
-
data: []
|
|
380
|
-
}, "error", batch);
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
/**
|
|
384
|
-
* Sort the collection items using the configured sorting strategy
|
|
385
|
-
* @param objectCacheKeys - The cache keys to sort
|
|
386
|
-
* @param batch - The batch context
|
|
387
|
-
* @returns Sorted array of cache keys
|
|
388
|
-
*/
|
|
389
|
-
_sortCacheKeys(objectCacheKeys, batch) {
|
|
390
|
-
return this.sortingStrategy.sortCacheKeys(objectCacheKeys, batch);
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
/**
|
|
394
|
-
* Unified method for updating collection data in the store
|
|
395
|
-
* Handles storing, sorting, deduplication, and reference counting
|
|
396
|
-
*
|
|
397
|
-
* @param items - Either object cache keys or object instances to update
|
|
398
|
-
* @param options - Configuration options for the update
|
|
399
|
-
* @param batch - The batch context to use
|
|
400
|
-
* @returns The updated entry
|
|
401
|
-
*/
|
|
402
|
-
updateCollection(items, options, batch) {
|
|
403
|
-
if (process.env.NODE_ENV !== "production") {
|
|
404
|
-
const logger = process.env.NODE_ENV !== "production" ? this.logger?.child({
|
|
405
|
-
methodName: "updateCollection"
|
|
406
|
-
}) : this.logger;
|
|
407
|
-
logger?.debug(`{status: ${options.status}, append: ${options.append}}`, JSON.stringify(items, null, 2));
|
|
408
|
-
}
|
|
409
|
-
|
|
410
|
-
// Step 1: Convert items to object cache keys if needed
|
|
411
|
-
let objectCacheKeys;
|
|
412
|
-
if (items.length === 0) {
|
|
413
|
-
objectCacheKeys = [];
|
|
414
|
-
} else if (isObjectInstance(items[0])) {
|
|
415
|
-
// Items are object instances, need to store them first
|
|
416
|
-
objectCacheKeys = this.storeObjects(items, batch);
|
|
417
|
-
} else {
|
|
418
|
-
// Items are already cache keys
|
|
419
|
-
objectCacheKeys = items;
|
|
420
|
-
}
|
|
421
|
-
|
|
422
|
-
// Step 2: Handle retain/release/append logic
|
|
423
|
-
objectCacheKeys = this.#retainReleaseAppend(batch, options.append ?? false, objectCacheKeys);
|
|
424
|
-
|
|
425
|
-
// Step 3: Sort using the configured sorting strategy
|
|
426
|
-
objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);
|
|
427
|
-
|
|
428
|
-
// Step 4: Remove duplicates
|
|
429
|
-
objectCacheKeys = removeDuplicates(objectCacheKeys, batch);
|
|
430
|
-
|
|
431
|
-
// Step 5: Write to store
|
|
432
|
-
return this.writeToStore({
|
|
433
|
-
data: objectCacheKeys
|
|
434
|
-
}, options.status, batch);
|
|
435
|
-
}
|
|
436
|
-
}
|
|
437
|
-
|
|
438
29
|
/**
|
|
439
30
|
* Implements filtered and sorted object collection queries.
|
|
440
31
|
* - Handles where clause filtering and orderBy sorting
|
|
@@ -517,7 +108,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
517
108
|
*/
|
|
518
109
|
handleFetchError(error, _status, batch) {
|
|
519
110
|
this.logger?.error("error", error);
|
|
520
|
-
this.store.
|
|
111
|
+
this.store.subjects.get(this.cacheKey).error(error);
|
|
521
112
|
|
|
522
113
|
// We don't call super.handleFetchError because ListQuery has special error handling
|
|
523
114
|
// but we still use writeToStore to create a properly structured Entry
|
|
@@ -609,7 +200,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
609
200
|
// deal with the modified objects
|
|
610
201
|
for (const obj of relevantObjects.modified.all) {
|
|
611
202
|
if (relevantObjects.modified.strictMatches.has(obj)) {
|
|
612
|
-
const objectCacheKey = this.
|
|
203
|
+
const objectCacheKey = this.cacheKeys.get("object", obj.$objectType, obj.$primaryKey);
|
|
613
204
|
if (!existingList.has(objectCacheKey)) {
|
|
614
205
|
// object is new to the list
|
|
615
206
|
toAdd.add(obj);
|
|
@@ -622,7 +213,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
622
213
|
continue;
|
|
623
214
|
} else {
|
|
624
215
|
// object is no longer a strict match
|
|
625
|
-
const existingObjectCacheKey = this.
|
|
216
|
+
const existingObjectCacheKey = this.cacheKeys.get("object", obj.$objectType, obj.$primaryKey);
|
|
626
217
|
toRemove.add(existingObjectCacheKey);
|
|
627
218
|
if (relevantObjects.modified.sortaMatches.has(obj)) {
|
|
628
219
|
// since it might still be in the list we need to revalidate
|
|
@@ -635,7 +226,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
635
226
|
newList.push(key);
|
|
636
227
|
}
|
|
637
228
|
for (const obj of toAdd) {
|
|
638
|
-
newList.push(this.
|
|
229
|
+
newList.push(this.cacheKeys.get("object", obj.$objectType, obj.$primaryKey));
|
|
639
230
|
}
|
|
640
231
|
this._updateList(newList, status, batch, /* append */false);
|
|
641
232
|
});
|
|
@@ -774,7 +365,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
774
365
|
if (state === "ADDED_OR_UPDATED") {
|
|
775
366
|
const object = objOrIface.$apiName !== objOrIface.$objectType ? objOrIface.$as(objOrIface.$objectType) : objOrIface;
|
|
776
367
|
this.store.batch({}, batch => {
|
|
777
|
-
this.
|
|
368
|
+
this.store.objects.storeOsdkInstances([object], batch);
|
|
778
369
|
});
|
|
779
370
|
} else if (state === "REMOVED") {
|
|
780
371
|
this.#onOswRemoved(objOrIface, logger);
|
|
@@ -786,7 +377,7 @@ export class ListQuery extends BaseListQuery {
|
|
|
786
377
|
const existing = batch.read(this.cacheKey);
|
|
787
378
|
!existing ? process.env.NODE_ENV !== "production" ? invariant(false, "the truth value for our list should exist as we already subscribed") : invariant(false) : void 0;
|
|
788
379
|
if (existing.status === "loaded") {
|
|
789
|
-
const objectCacheKey = this.
|
|
380
|
+
const objectCacheKey = this.cacheKeys.get("object", objOrIface.$objectType, objOrIface.$primaryKey);
|
|
790
381
|
// remove the object from the list
|
|
791
382
|
const newObjects = existing.value?.data.filter(o => o !== objectCacheKey);
|
|
792
383
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListQuery.js","names":["groupBy","invariant","additionalContext","ObjectDefRef","UnderlyingOsdkObject","BaseListQuery","DEBUG_ONLY__changesToString","objectSortaMatchesWhereClause","objectMatchesWhereClause","OrderBySortingStrategy","API_NAME_IDX","TYPE_IDX","WHERE_IDX","ORDER_BY_IDX","ListQuery","type","apiName","whereClause","orderBy","objectSet","registerCacheChanges","batch","changes","registerList","cacheKey","constructor","store","subject","apiType","opts","process","env","NODE_ENV","client","logger","child","msgPrefix","otherKeys","map","x","JSON","stringify","join","undefined","where","sortingStrategy","minResultsToLoad","canonicalWhere","fetchPageData","signal","resp","fetchPage","$nextPageToken","nextPageToken","$pageSize","options","pageSize","Object","keys","length","$orderBy","aborted","Error","fetchedData","data","reloadDataAsFullObjects","handleFetchError","error","_status","subjects","get","writeToStore","revalidateObjectType","revalidate","objectMetadata","fetchMetadata","interfaceMap","invalidateObjectType","objectType","modified","add","maybeUpdateAndRevalidate","optimisticId","methodName","debug","has","relevantObjects","_extractRelevantObjects","status","added","sortaMatches","size","newList","needsRevalidation","existingList","Set","read","value","toAdd","strictMatches","toRemove","deleted","obj","all","objectCacheKey","cacheKeys","$objectType","$primaryKey","optimisticWrite","existingObjectCacheKey","key","push","_updateList","matchType","#matchType","extractRelevantObjectsForTypeObject","extractRelevantObjectsForTypeInterface","group","values","#extractRelevantObjectsForTypeInterface","matchesApiName","object","Array","from","addedObjects","filter","$as","modifiedObjects","#extractRelevantObjectsForTypeObject","registerStreamUpdates","sub","info","websocketSubscription","subscribe","onChange","onOswChange","bind","onError","onOswError","onOutOfDate","onOswOutOfDate","onSuccessfulSubscription","onOswSuccessfulSubscription","unsubscribe","#onOswSuccessfulSubscription","#onOswOutOfDate","#onOswError","errors","#onOswChange","objOrIface","state","$apiName","objects","storeOsdkInstances","onOswRemoved","#onOswRemoved","existing","newObjects","o","write","catch","e","console","groups","objectTypeToPrimaryKeyToObject","fromEntries","Promise","entries","objectDef","primaryKeyApiName","$in","result","isListCacheKey"],"sources":["ListQuery.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n Logger,\n ObjectOrInterfaceDefinition,\n ObjectSet,\n ObjectTypeDefinition,\n Osdk,\n PageResult,\n PropertyKeys,\n} from \"@osdk/api\";\nimport groupBy from \"object.groupby\";\nimport type { Observable, Subscription } from \"rxjs\";\nimport invariant from \"tiny-invariant\";\nimport { additionalContext, type Client } from \"../../../Client.js\";\nimport type { InterfaceHolder } from \"../../../object/convertWireToOsdkObjects/InterfaceHolder.js\";\nimport {\n ObjectDefRef,\n UnderlyingOsdkObject,\n} from \"../../../object/convertWireToOsdkObjects/InternalSymbols.js\";\nimport type {\n ObjectHolder,\n} from \"../../../object/convertWireToOsdkObjects/ObjectHolder.js\";\nimport type { ListPayload } from \"../../ListPayload.js\";\nimport type { Status } from \"../../ObservableClient/common.js\";\nimport { BaseListQuery } from \"../base-list/BaseListQuery.js\";\nimport type { BatchContext } from \"../BatchContext.js\";\nimport { type CacheKey } from \"../CacheKey.js\";\nimport type { Canonical } from \"../Canonical.js\";\nimport { type Changes, DEBUG_ONLY__changesToString } from \"../Changes.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { objectSortaMatchesWhereClause as objectMatchesWhereClause } from \"../objectMatchesWhereClause.js\";\nimport type { OptimisticId } from \"../OptimisticId.js\";\nimport type { SimpleWhereClause } from \"../SimpleWhereClause.js\";\nimport { OrderBySortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport type { Store } from \"../Store.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type { ListCacheKey } from \"./ListCacheKey.js\";\nimport type { ListQueryOptions } from \"./ListQueryOptions.js\";\n\nexport const API_NAME_IDX = 1;\nexport const TYPE_IDX = 0;\nexport const WHERE_IDX = 2;\nexport const ORDER_BY_IDX = 3;\n\ntype ExtractRelevantObjectsResult = Record<\"added\" | \"modified\", {\n all: (ObjectHolder | InterfaceHolder)[];\n strictMatches: Set<(ObjectHolder | InterfaceHolder)>;\n sortaMatches: Set<(ObjectHolder | InterfaceHolder)>;\n}>;\n\n/**\n * Implements filtered and sorted object collection queries.\n * - Handles where clause filtering and orderBy sorting\n * - Manages pagination through fetchMore\n * - Auto-updates when matching objects change\n * - Uses canonicalized cache keys for consistency\n */\nexport class ListQuery extends BaseListQuery<\n ListCacheKey,\n ListPayload,\n ListQueryOptions\n> {\n // pageSize?: number; // this is the internal page size. we need to track this properly\n\n #type: \"object\" | \"interface\";\n #apiName: string;\n #whereClause: Canonical<SimpleWhereClause>;\n\n // Using base class minResultsToLoad instead of a private property\n #orderBy: Canonical<Record<string, \"asc\" | \"desc\" | undefined>>;\n #objectSet: ObjectSet<ObjectTypeDefinition>;\n\n /**\n * Register changes to the cache specific to ListQuery\n */\n protected registerCacheChanges(batch: BatchContext): void {\n batch.changes.registerList(this.cacheKey);\n }\n\n constructor(\n store: Store,\n subject: Observable<SubjectPayload<ListCacheKey>>,\n apiType: \"object\" | \"interface\",\n apiName: string,\n whereClause: Canonical<SimpleWhereClause>,\n orderBy: Canonical<Record<string, \"asc\" | \"desc\" | undefined>>,\n cacheKey: ListCacheKey,\n opts: ListQueryOptions,\n ) {\n super(\n store,\n subject,\n opts,\n cacheKey,\n process.env.NODE_ENV !== \"production\"\n ? (\n store.client[additionalContext].logger?.child({}, {\n msgPrefix: `ListQuery<${\n cacheKey.otherKeys.map(x => JSON.stringify(x)).join(\", \")\n }>`,\n })\n )\n : undefined,\n );\n\n this.#type = apiType;\n this.#apiName = apiName;\n this.#whereClause = whereClause;\n this.#orderBy = orderBy;\n this.#objectSet = store.client({\n type: this.#type,\n apiName: this.#apiName,\n } as ObjectTypeDefinition)\n .where(this.#whereClause);\n // Initialize the sorting strategy\n this.sortingStrategy = new OrderBySortingStrategy(\n this.#apiName,\n this.#orderBy,\n );\n // Initialize the minResultsToLoad inherited from BaseCollectionQuery\n this.minResultsToLoad = 0;\n }\n\n get canonicalWhere(): Canonical<SimpleWhereClause> {\n return this.#whereClause;\n }\n\n /**\n * Implements fetchPageData from BaseCollectionQuery template method\n * Fetches a page of data\n */\n protected async fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>> {\n // Fetch the data with pagination\n const resp = await this.#objectSet.fetchPage({\n $nextPageToken: this.nextPageToken,\n $pageSize: this.options.pageSize,\n // For now this keeps the shared test code from falling apart\n // but shouldn't be needed ideally\n ...(Object.keys(this.#orderBy).length > 0\n ? { $orderBy: this.#orderBy }\n : {}),\n });\n\n if (signal?.aborted) {\n throw new Error(\"Aborted\");\n }\n\n this.nextPageToken = resp.nextPageToken;\n let fetchedData = resp.data;\n\n // Our caching really expects to have the full objects in the list\n // so we need to fetch them all here\n if (this.#type === \"interface\") {\n fetchedData = await reloadDataAsFullObjects(\n this.store.client,\n fetchedData,\n );\n }\n\n return {\n ...resp,\n data: fetchedData,\n };\n }\n\n /**\n * Handle fetch errors by setting appropriate error state and notifying subscribers\n */\n protected handleFetchError(\n error: unknown,\n _status: Status,\n batch: BatchContext,\n ): Entry<ListCacheKey> {\n this.logger?.error(\"error\", error);\n this.store.subjects.get(this.cacheKey).error(error);\n\n // We don't call super.handleFetchError because ListQuery has special error handling\n // but we still use writeToStore to create a properly structured Entry\n return this.writeToStore({ data: [] }, \"error\", batch);\n }\n\n /**\n * Will revalidate the list if its query is affected by invalidating the\n * apiName of the object type passed in.\n *\n * @param apiName to invalidate\n * @returns\n */\n revalidateObjectType = async (\n apiName: string,\n ): Promise<void> => {\n if (this.#type === \"object\") {\n if (this.#apiName === apiName) {\n await this.revalidate(/* force */ true);\n return;\n } else {\n return;\n }\n }\n //\n const objectMetadata = await this.store.client.fetchMetadata({\n type: \"object\",\n apiName,\n });\n\n if (this.#apiName in objectMetadata.interfaceMap) {\n await this.revalidate(/* force */ true);\n return;\n }\n };\n\n invalidateObjectType = async (\n objectType: string,\n changes: Changes | undefined,\n ): Promise<void> => {\n if (this.cacheKey.otherKeys[1] === objectType) {\n // Only invalidate lists for the matching apiName\n changes?.modified.add(this.cacheKey);\n return this.revalidate(true);\n }\n };\n\n /**\n * Note: This method is not async because I want it to return right after it\n * finishes the synchronous updates. The promise that is returned\n * will resolve after the revalidation is complete.\n * @param changes\n * @param optimisticId\n * @returns If revalidation is needed, a promise that resolves after the\n * revalidation is complete. Otherwise, undefined.\n */\n\n maybeUpdateAndRevalidate = (\n changes: Changes,\n optimisticId: OptimisticId | undefined,\n ): Promise<void> | undefined => {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"maybeUpdateAndRevalidate\" }).debug(\n DEBUG_ONLY__changesToString(changes),\n );\n this.logger?.child({ methodName: \"maybeUpdateAndRevalidate\" }).debug(\n `Already in changes? ${changes.modified.has(this.cacheKey)}`,\n );\n }\n\n if (changes.modified.has(this.cacheKey)) return;\n // mark ourselves as updated so we don't infinite recurse.\n changes.modified.add(this.cacheKey);\n\n try {\n const relevantObjects = this._extractRelevantObjects(changes);\n\n // If we got purely strict matches we can just update the list and move\n // on with our lives. But if we got sorta matches, then we need to revalidate\n // the list so we preemptively set it to loading to avoid thrashing the store.\n const status = optimisticId\n || relevantObjects.added.sortaMatches.size > 0\n || relevantObjects.modified.sortaMatches.size > 0\n ? \"loading\"\n : \"loaded\";\n\n // while we only push updates for the strict matches, we still need to\n // trigger the list updating if some of our objects changed\n\n const newList: Array<ObjectCacheKey> = [];\n\n let needsRevalidation = false;\n this.store.batch({ optimisticId, changes }, (batch) => {\n const existingList = new Set(\n batch.read(this.cacheKey)?.value?.data,\n );\n\n const toAdd = new Set<ObjectHolder | InterfaceHolder>(\n // easy case. objects are new to the cache and they match this filter\n relevantObjects.added.strictMatches,\n );\n\n // anything thats been deleted can be removed, so start there\n const toRemove = new Set<CacheKey>(changes.deleted);\n\n // deal with the modified objects\n for (const obj of relevantObjects.modified.all) {\n if (relevantObjects.modified.strictMatches.has(obj)) {\n const objectCacheKey = this.cacheKeys.get<ObjectCacheKey>(\n \"object\",\n obj.$objectType,\n obj.$primaryKey,\n );\n\n if (!existingList.has(objectCacheKey)) {\n // object is new to the list\n toAdd.add(obj);\n }\n continue;\n } else if (batch.optimisticWrite) {\n // we aren't removing objects in optimistic mode\n // we also don't want to trigger revalidation in optimistic mode\n // as it should be triggered when the optimistic job is done\n continue;\n } else {\n // object is no longer a strict match\n const existingObjectCacheKey = this.cacheKeys.get<ObjectCacheKey>(\n \"object\",\n obj.$objectType,\n obj.$primaryKey,\n );\n\n toRemove.add(existingObjectCacheKey);\n\n if (relevantObjects.modified.sortaMatches.has(obj)) {\n // since it might still be in the list we need to revalidate\n needsRevalidation = true;\n }\n }\n }\n\n for (const key of existingList) {\n if (toRemove.has(key)) continue;\n newList.push(key);\n }\n for (const obj of toAdd) {\n newList.push(\n this.cacheKeys.get<ObjectCacheKey>(\n \"object\",\n obj.$objectType,\n obj.$primaryKey,\n ),\n );\n }\n\n this._updateList(\n newList,\n status,\n batch,\n /* append */ false,\n );\n });\n\n if (needsRevalidation) {\n return this.revalidate(true);\n }\n return undefined;\n } finally {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"maybeUpdateAndRevalidate\" })\n .debug(\"in finally\");\n }\n }\n };\n\n #matchType(obj: ObjectHolder | InterfaceHolder): false | \"strict\" | \"sorta\" {\n // if its a strict match we can just insert it into place\n if (objectMatchesWhereClause(obj, this.#whereClause, true)) {\n return \"strict\";\n }\n // sorta match means it used a filter we cannot use on the frontend\n if (objectMatchesWhereClause(obj, this.#whereClause, false)) {\n return \"sorta\";\n }\n return false;\n }\n\n protected _extractRelevantObjects(\n changes: Changes,\n ): ExtractRelevantObjectsResult {\n // TODO refactor this ternary into subclasses\n const relevantObjects = this.#type === \"object\"\n ? this.#extractRelevantObjectsForTypeObject(changes)\n : this.#extractRelevantObjectsForTypeInterface(changes);\n\n // categorize\n for (const group of Object.values(relevantObjects)) {\n for (const obj of group.all ?? []) {\n const matchType = this.#matchType(obj);\n if (matchType) {\n group[`${matchType}Matches`].add(obj);\n }\n }\n }\n\n return relevantObjects;\n }\n\n #extractRelevantObjectsForTypeInterface(\n changes: Changes,\n ): ExtractRelevantObjectsResult {\n const matchesApiName = ([, object]: [unknown, ObjectHolder]) => {\n return this.#apiName in object[ObjectDefRef].interfaceMap;\n };\n\n const added = Array.from(changes.addedObjects).filter(matchesApiName).map((\n [, object],\n ) => object.$as(this.#apiName));\n\n const modified = Array.from(changes.modifiedObjects).filter(matchesApiName)\n .map((\n [, object],\n ) => object.$as(this.#apiName));\n\n return {\n added: {\n all: added,\n strictMatches: new Set(),\n sortaMatches: new Set(),\n },\n modified: {\n all: modified,\n strictMatches: new Set(),\n sortaMatches: new Set(),\n },\n };\n }\n\n #extractRelevantObjectsForTypeObject(\n changes: Changes,\n ): ExtractRelevantObjectsResult {\n return {\n added: {\n all: changes.addedObjects.get(this.cacheKey.otherKeys[API_NAME_IDX])\n ?? [],\n strictMatches: new Set(),\n sortaMatches: new Set(),\n },\n modified: {\n all: changes.modifiedObjects.get(this.cacheKey.otherKeys[API_NAME_IDX])\n ?? [],\n strictMatches: new Set(),\n sortaMatches: new Set(),\n },\n };\n }\n\n registerStreamUpdates(sub: Subscription): void {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"registerStreamUpdates\" })\n : this.logger;\n\n if (process.env.NODE_ENV !== \"production\") {\n logger?.child({ methodName: \"observeList\" }).info(\n \"Subscribing from websocket\",\n );\n }\n\n // FIXME: We should only do this once. If we already have one we should probably\n // just reuse it.\n\n const websocketSubscription = this.#objectSet.subscribe({\n onChange: this.#onOswChange.bind(this),\n onError: this.#onOswError.bind(this),\n onOutOfDate: this.#onOswOutOfDate.bind(this),\n onSuccessfulSubscription: this.#onOswSuccessfulSubscription.bind(this),\n });\n\n sub.add(() => {\n if (process.env.NODE_ENV !== \"production\") {\n logger?.child({ methodName: \"observeList\" }).info(\n \"Unsubscribing from websocket\",\n );\n }\n\n websocketSubscription.unsubscribe();\n });\n }\n\n #onOswSuccessfulSubscription(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child(\n { methodName: \"onSuccessfulSubscription\" },\n ).debug(\"\");\n }\n }\n\n #onOswOutOfDate(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child(\n { methodName: \"onOutOfDate\" },\n ).debug(\"\");\n }\n }\n\n #onOswError(errors: {\n subscriptionClosed: boolean;\n error: any;\n }) {\n if (this.logger) {\n this.logger?.child({ methodName: \"onError\" }).error(\n \"subscription errors\",\n errors,\n );\n }\n }\n\n #onOswChange(\n { object: objOrIface, state }: ObjectUpdate<ObjectTypeDefinition, string>,\n ): void {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"registerStreamUpdates\" })\n : this.logger;\n\n if (process.env.NODE_ENV !== \"production\") {\n logger?.child({ methodName: \"onChange\" }).debug(\n `Got an update of type: ${state}`,\n objOrIface,\n );\n }\n\n if (state === \"ADDED_OR_UPDATED\") {\n const object: ObjectHolder =\n (objOrIface.$apiName !== objOrIface.$objectType\n ? objOrIface.$as(objOrIface.$objectType)\n : objOrIface) as unknown as ObjectHolder;\n\n this.store.batch({}, (batch) => {\n this.store.objects.storeOsdkInstances(\n [object as Osdk.Instance<any>],\n batch,\n );\n });\n } else if (state === \"REMOVED\") {\n this.#onOswRemoved(objOrIface, logger);\n }\n }\n\n #onOswRemoved(\n objOrIface: Osdk.Instance<ObjectTypeDefinition, never, string, {}>,\n logger: Logger | undefined,\n ) {\n this.store.batch({}, (batch) => {\n // Read the truth layer (since not optimistic)\n const existing = batch.read(this.cacheKey);\n invariant(\n existing,\n \"the truth value for our list should exist as we already subscribed\",\n );\n if (existing.status === \"loaded\") {\n const objectCacheKey = this.cacheKeys.get<ObjectCacheKey>(\n \"object\",\n objOrIface.$objectType,\n objOrIface.$primaryKey,\n );\n // remove the object from the list\n const newObjects = existing.value?.data.filter(\n (o) => o !== objectCacheKey,\n );\n\n // If the filter didn't change anything, then the list was already\n // updated (or didn't exist, which is nonsensical)\n if (newObjects?.length !== existing.value?.data.length) {\n batch.changes.registerList(this.cacheKey);\n batch.write(\n this.cacheKey,\n { data: newObjects ?? [] },\n \"loaded\",\n );\n // Should there be an else for this case? Do we need to invalidate\n // the paging tokens we may have? FIXME\n }\n\n return;\n }\n // There may be a tiny race here where OSW tells us the object has\n // been removed but an outstanding invalidation of this query is\n // about to return. In this case, its possible that we remove this item\n // from the list and then the returned list load re-adds it.\n // To avoid this, we will just force reload the query to be sure\n // we don't leave things in a bad state.\n if (process.env.NODE_ENV !== \"production\") {\n logger?.info(\n \"Removing an object from an object list that is in the middle of being loaded.\",\n existing,\n );\n }\n\n this.revalidate(/* force */ true).catch((e: unknown) => {\n if (logger) {\n logger?.error(\"Uncaught error while revalidating list\", e);\n } else {\n // Make sure we write to the console if there is no logger!\n // eslint-disable-next-line no-console\n console.error(\"Uncaught error while revalidating list\", e);\n }\n });\n });\n }\n}\n\n// Hopefully this can go away when we can just request the full object properties on first load\nasync function reloadDataAsFullObjects(\n client: Client,\n data: Osdk.Instance<any>[],\n) {\n const groups = groupBy(data, (x) => x.$objectType);\n const objectTypeToPrimaryKeyToObject = Object.fromEntries(\n await Promise.all(\n Object.entries(groups).map<\n Promise<\n [\n /** objectType **/ string,\n Record<string | number, Osdk.Instance<ObjectTypeDefinition>>,\n ]\n >\n >(async ([apiName, objects]) => {\n // to keep InternalSimpleOsdkInstance simple, we make both the `ObjectDefRef` and\n // the `InterfaceDefRef` optional but we know that the right one is on there\n // thus we can `!`\n const objectDef = (objects[0] as ObjectHolder)[UnderlyingOsdkObject][\n ObjectDefRef\n ]!;\n const where: SimpleWhereClause = {\n [objectDef.primaryKeyApiName]: {\n $in: objects.map(x => x.$primaryKey),\n },\n };\n\n const result = await client(\n objectDef as ObjectTypeDefinition,\n ).where(where).fetchPage();\n return [\n apiName,\n Object.fromEntries(result.data.map(\n x => [x.$primaryKey, x],\n )),\n ];\n }),\n ),\n );\n\n data = data.map((obj) => {\n invariant(\n objectTypeToPrimaryKeyToObject[obj.$objectType][obj.$primaryKey],\n `Could not find object ${obj.$objectType} ${obj.$primaryKey}`,\n );\n return objectTypeToPrimaryKeyToObject[obj.$objectType][obj.$primaryKey];\n });\n\n return data;\n}\n\nexport function isListCacheKey(\n cacheKey: CacheKey,\n): cacheKey is ListCacheKey {\n return cacheKey.type === \"list\";\n}\n\n/**\n * Copied from @osdk/api\n */\ntype ObjectUpdate<\n O extends ObjectOrInterfaceDefinition,\n P extends PropertyKeys<O>,\n> = {\n object: Osdk.Instance<O, never, P>;\n state: \"ADDED_OR_UPDATED\" | \"REMOVED\";\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListQueryOptions.js","names":[],"sources":["ListQueryOptions.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { CommonObserveOptions } from \"../../ObservableClient/common.js\";\n\nexport interface ListQueryOptions extends CommonObserveOptions {\n pageSize?: number;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -15,10 +15,10 @@
|
|
|
15
15
|
*/
|
|
16
16
|
|
|
17
17
|
import { AbstractHelper } from "../AbstractHelper.js";
|
|
18
|
-
import { ListQuery } from "
|
|
18
|
+
import { ListQuery } from "./ListQuery.js";
|
|
19
19
|
export class ListsHelper extends AbstractHelper {
|
|
20
|
-
constructor(store, whereCanonicalizer, orderByCanonicalizer) {
|
|
21
|
-
super(store);
|
|
20
|
+
constructor(store, cacheKeys, whereCanonicalizer, orderByCanonicalizer) {
|
|
21
|
+
super(store, cacheKeys);
|
|
22
22
|
this.whereCanonicalizer = whereCanonicalizer;
|
|
23
23
|
this.orderByCanonicalizer = orderByCanonicalizer;
|
|
24
24
|
}
|
|
@@ -40,9 +40,9 @@ export class ListsHelper extends AbstractHelper {
|
|
|
40
40
|
} = options;
|
|
41
41
|
const canonWhere = this.whereCanonicalizer.canonicalize(where ?? {});
|
|
42
42
|
const canonOrderBy = this.orderByCanonicalizer.canonicalize(orderBy ?? {});
|
|
43
|
-
const listCacheKey = this.
|
|
44
|
-
return this.store.
|
|
45
|
-
return new ListQuery(this.store, this.store.
|
|
43
|
+
const listCacheKey = this.cacheKeys.get("list", type, apiName, canonWhere, canonOrderBy);
|
|
44
|
+
return this.store.queries.get(listCacheKey, () => {
|
|
45
|
+
return new ListQuery(this.store, this.store.subjects.get(listCacheKey), type, apiName, canonWhere, canonOrderBy, listCacheKey, options);
|
|
46
46
|
});
|
|
47
47
|
}
|
|
48
48
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ListsHelper.js","names":["AbstractHelper","ListQuery","ListsHelper","constructor","store","whereCanonicalizer","orderByCanonicalizer","observe","options","subFn","ret","streamUpdates","query","registerStreamUpdates","subscription","getQuery","type","apiName","where","orderBy","canonWhere","canonicalize","canonOrderBy","listCacheKey","
|
|
1
|
+
{"version":3,"file":"ListsHelper.js","names":["AbstractHelper","ListQuery","ListsHelper","constructor","store","cacheKeys","whereCanonicalizer","orderByCanonicalizer","observe","options","subFn","ret","streamUpdates","query","registerStreamUpdates","subscription","getQuery","type","apiName","where","orderBy","canonWhere","canonicalize","canonOrderBy","listCacheKey","get","queries","subjects"],"sources":["ListsHelper.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { InterfaceDefinition, ObjectTypeDefinition } from \"@osdk/api\";\nimport type { ListPayload } from \"../../ListPayload.js\";\nimport type { ObserveListOptions } from \"../../ObservableClient.js\";\nimport type { Observer } from \"../../ObservableClient/common.js\";\nimport { AbstractHelper } from \"../AbstractHelper.js\";\nimport type { CacheKeys } from \"../CacheKeys.js\";\nimport type { KnownCacheKey } from \"../KnownCacheKey.js\";\nimport type { OrderByCanonicalizer } from \"../OrderByCanonicalizer.js\";\nimport type { QuerySubscription } from \"../QuerySubscription.js\";\nimport type { Store } from \"../Store.js\";\nimport type { WhereClauseCanonicalizer } from \"../WhereClauseCanonicalizer.js\";\nimport type { ListCacheKey } from \"./ListCacheKey.js\";\nimport { ListQuery } from \"./ListQuery.js\";\n\nexport class ListsHelper extends AbstractHelper<\n ListQuery,\n ObserveListOptions<ObjectTypeDefinition | InterfaceDefinition>\n> {\n whereCanonicalizer: WhereClauseCanonicalizer;\n orderByCanonicalizer: OrderByCanonicalizer;\n\n constructor(\n store: Store,\n cacheKeys: CacheKeys<KnownCacheKey>,\n whereCanonicalizer: WhereClauseCanonicalizer,\n orderByCanonicalizer: OrderByCanonicalizer,\n ) {\n super(store, cacheKeys);\n\n this.whereCanonicalizer = whereCanonicalizer;\n this.orderByCanonicalizer = orderByCanonicalizer;\n }\n\n observe<T extends ObjectTypeDefinition | InterfaceDefinition>(\n options: ObserveListOptions<T>,\n subFn: Observer<ListPayload>,\n ): QuerySubscription<ListQuery> {\n const ret = super.observe(options, subFn);\n\n if (options.streamUpdates) {\n ret.query.registerStreamUpdates(ret.subscription);\n }\n return ret;\n }\n\n getQuery<T extends ObjectTypeDefinition | InterfaceDefinition>(\n options: ObserveListOptions<T>,\n ): ListQuery {\n const { type: { apiName, type }, where, orderBy } = options;\n\n const canonWhere = this.whereCanonicalizer.canonicalize(where ?? {});\n const canonOrderBy = this.orderByCanonicalizer.canonicalize(orderBy ?? {});\n const listCacheKey = this.cacheKeys.get<ListCacheKey>(\n \"list\",\n type,\n apiName,\n canonWhere,\n canonOrderBy,\n );\n\n return this.store.queries.get(listCacheKey, () => {\n return new ListQuery(\n this.store,\n this.store.subjects.get(listCacheKey),\n type,\n apiName,\n canonWhere,\n canonOrderBy,\n listCacheKey,\n options,\n );\n });\n }\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMA,SAASA,cAAc,QAAQ,sBAAsB;AAQrD,SAASC,SAAS,QAAQ,gBAAgB;AAE1C,OAAO,MAAMC,WAAW,SAASF,cAAc,CAG7C;EAIAG,WAAWA,CACTC,KAAY,EACZC,SAAmC,EACnCC,kBAA4C,EAC5CC,oBAA0C,EAC1C;IACA,KAAK,CAACH,KAAK,EAAEC,SAAS,CAAC;IAEvB,IAAI,CAACC,kBAAkB,GAAGA,kBAAkB;IAC5C,IAAI,CAACC,oBAAoB,GAAGA,oBAAoB;EAClD;EAEAC,OAAOA,CACLC,OAA8B,EAC9BC,KAA4B,EACE;IAC9B,MAAMC,GAAG,GAAG,KAAK,CAACH,OAAO,CAACC,OAAO,EAAEC,KAAK,CAAC;IAEzC,IAAID,OAAO,CAACG,aAAa,EAAE;MACzBD,GAAG,CAACE,KAAK,CAACC,qBAAqB,CAACH,GAAG,CAACI,YAAY,CAAC;IACnD;IACA,OAAOJ,GAAG;EACZ;EAEAK,QAAQA,CACNP,OAA8B,EACnB;IACX,MAAM;MAAEQ,IAAI,EAAE;QAAEC,OAAO;QAAED;MAAK,CAAC;MAAEE,KAAK;MAAEC;IAAQ,CAAC,GAAGX,OAAO;IAE3D,MAAMY,UAAU,GAAG,IAAI,CAACf,kBAAkB,CAACgB,YAAY,CAACH,KAAK,IAAI,CAAC,CAAC,CAAC;IACpE,MAAMI,YAAY,GAAG,IAAI,CAAChB,oBAAoB,CAACe,YAAY,CAACF,OAAO,IAAI,CAAC,CAAC,CAAC;IAC1E,MAAMI,YAAY,GAAG,IAAI,CAACnB,SAAS,CAACoB,GAAG,CACrC,MAAM,EACNR,IAAI,EACJC,OAAO,EACPG,UAAU,EACVE,YACF,CAAC;IAED,OAAO,IAAI,CAACnB,KAAK,CAACsB,OAAO,CAACD,GAAG,CAACD,YAAY,EAAE,MAAM;MAChD,OAAO,IAAIvB,SAAS,CAClB,IAAI,CAACG,KAAK,EACV,IAAI,CAACA,KAAK,CAACuB,QAAQ,CAACF,GAAG,CAACD,YAAY,CAAC,EACrCP,IAAI,EACJC,OAAO,EACPG,UAAU,EACVE,YAAY,EACZC,YAAY,EACZf,OACF,CAAC;IACH,CAAC,CAAC;EACJ;AACF","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ObjectCacheKey.js","names":[],"sources":["ObjectCacheKey.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { ObjectTypeDefinition, PrimaryKeyType } from \"@osdk/api\";\nimport type { ObjectHolder } from \"../../../object/convertWireToOsdkObjects/ObjectHolder.js\";\nimport type { CacheKey } from \"../CacheKey.js\";\nimport type { ObjectQuery } from \"./ObjectQuery.js\";\n\nexport interface ObjectCacheKey extends\n CacheKey<\n \"object\",\n ObjectHolder,\n ObjectQuery,\n [string, pk: PrimaryKeyType<ObjectTypeDefinition>]\n >\n{\n}\n"],"mappings":"","ignoreList":[]}
|