@osdk/client 2.7.0-beta.9 → 2.7.0
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 +236 -0
- package/build/browser/MinimalClientContext.js.map +1 -1
- package/build/browser/actions/actions.test.js +9 -8
- package/build/browser/actions/actions.test.js.map +1 -1
- package/build/browser/actions/applyAction.js +0 -4
- package/build/browser/actions/applyAction.js.map +1 -1
- package/build/browser/createClient.js +1 -2
- package/build/browser/createClient.js.map +1 -1
- package/build/browser/createMinimalClient.js +0 -1
- package/build/browser/createMinimalClient.js.map +1 -1
- package/build/browser/derivedProperties/createWithPropertiesObjectSet.js +1 -17
- package/build/browser/derivedProperties/createWithPropertiesObjectSet.js.map +1 -1
- package/build/browser/index.js +1 -1
- package/build/browser/index.js.map +1 -1
- package/build/browser/internal/conversions/modernToLegacyWhereClause.js +14 -9
- package/build/browser/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
- package/build/browser/internal/conversions/modernToLegacyWhereClause.test.js +74 -0
- package/build/browser/internal/conversions/modernToLegacyWhereClause.test.js.map +1 -1
- package/build/browser/object/SimpleOsdkProperties.js.map +1 -1
- package/build/browser/object/aggregate.js +0 -1
- package/build/browser/object/aggregate.js.map +1 -1
- package/build/browser/object/convertWireToOsdkObjects/BaseHolder.js.map +1 -1
- package/build/browser/object/fetchPage.js +0 -2
- package/build/browser/object/fetchPage.js.map +1 -1
- package/build/browser/objectSet/ObjectSetListenerWebsocket.js +13 -4
- package/build/browser/objectSet/ObjectSetListenerWebsocket.js.map +1 -1
- package/build/browser/objectSet/ObjectSetListenerWebsocket.test.js +46 -2
- package/build/browser/objectSet/ObjectSetListenerWebsocket.test.js.map +1 -1
- package/build/browser/objectSet/createObjectSet.js +1 -1
- package/build/browser/objectSet/createObjectSet.js.map +1 -1
- package/build/browser/objectSet/fetchLinksPage.js +0 -1
- package/build/browser/objectSet/fetchLinksPage.js.map +1 -1
- package/build/browser/observable/FunctionPayload.js +2 -0
- package/build/browser/observable/FunctionPayload.js.map +1 -0
- package/build/browser/observable/ObservableClient.js.map +1 -1
- package/build/browser/observable/internal/BulkObjectLoader.js +2 -1
- package/build/browser/observable/internal/BulkObjectLoader.js.map +1 -1
- package/build/browser/observable/internal/Changes.js +4 -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/ObservableClientImpl.js +21 -1
- package/build/browser/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/browser/observable/internal/RidListCanonicalizer.js +30 -0
- package/build/browser/observable/internal/RidListCanonicalizer.js.map +1 -0
- package/build/browser/observable/internal/RidListCanonicalizer.test.js +50 -0
- package/build/browser/observable/internal/RidListCanonicalizer.test.js.map +1 -0
- package/build/browser/observable/internal/Store.js +11 -1
- package/build/browser/observable/internal/Store.js.map +1 -1
- package/build/browser/observable/internal/Store.test.js +57 -4
- package/build/browser/observable/internal/Store.test.js.map +1 -1
- package/build/browser/observable/internal/actions/ActionApplication.js +12 -9
- package/build/browser/observable/internal/actions/ActionApplication.js.map +1 -1
- package/build/browser/observable/internal/base-list/BaseCollectionQuery.js.map +1 -1
- package/build/browser/observable/internal/base-list/BaseListQuery.js +15 -9
- package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -1
- package/build/browser/observable/internal/base-list/createCollectionConnectable.js +4 -2
- package/build/browser/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
- package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js +1 -2
- package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
- package/build/browser/observable/internal/evaluateFilter.js +1 -1
- package/build/browser/observable/internal/evaluateFilter.js.map +1 -1
- package/build/browser/observable/internal/evaluateFilter.test.js +105 -0
- package/build/browser/observable/internal/evaluateFilter.test.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionCacheKey.js +26 -0
- package/build/browser/observable/internal/function/FunctionCacheKey.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionParamsCanonicalizer.js +151 -0
- package/build/browser/observable/internal/function/FunctionParamsCanonicalizer.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionParamsCanonicalizer.test.js +186 -0
- package/build/browser/observable/internal/function/FunctionParamsCanonicalizer.test.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionQuery.js +137 -0
- package/build/browser/observable/internal/function/FunctionQuery.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionQuery.test.js +278 -0
- package/build/browser/observable/internal/function/FunctionQuery.test.js.map +1 -0
- package/build/browser/observable/internal/function/FunctionsHelper.js +92 -0
- package/build/browser/observable/internal/function/FunctionsHelper.js.map +1 -0
- package/build/browser/observable/internal/links/SpecificLinkQuery.js +2 -1
- package/build/browser/observable/internal/links/SpecificLinkQuery.js.map +1 -1
- package/build/browser/observable/internal/list/InterfaceListQuery.js +27 -10
- package/build/browser/observable/internal/list/InterfaceListQuery.js.map +1 -1
- package/build/browser/observable/internal/list/ListCacheKey.js +1 -0
- package/build/browser/observable/internal/list/ListCacheKey.js.map +1 -1
- package/build/browser/observable/internal/list/ListQuery.js +10 -4
- package/build/browser/observable/internal/list/ListQuery.js.map +1 -1
- package/build/browser/observable/internal/list/ListQuery.test.js +167 -3
- package/build/browser/observable/internal/list/ListQuery.test.js.map +1 -1
- package/build/browser/observable/internal/list/ListsHelper.js +6 -3
- package/build/browser/observable/internal/list/ListsHelper.js.map +1 -1
- package/build/browser/observable/internal/list/ObjectListQuery.js +23 -9
- package/build/browser/observable/internal/list/ObjectListQuery.js.map +1 -1
- package/build/browser/observable/internal/object/ObjectQuery.js +15 -1
- package/build/browser/observable/internal/object/ObjectQuery.js.map +1 -1
- package/build/browser/observable/internal/object/ObjectsHelper.js +1 -3
- package/build/browser/observable/internal/object/ObjectsHelper.js.map +1 -1
- package/build/browser/observable/internal/objectMatchesWhereClause.test.js +11 -1
- package/build/browser/observable/internal/objectMatchesWhereClause.test.js.map +1 -1
- package/build/browser/observable/internal/objectset/ObjectSetQuery.js +6 -2
- package/build/browser/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
- package/build/browser/observable/internal/testUtils.js +8 -5
- package/build/browser/observable/internal/testUtils.js.map +1 -1
- package/build/browser/observable/internal/utils/rdpFieldOperations.js +6 -3
- package/build/browser/observable/internal/utils/rdpFieldOperations.js.map +1 -1
- package/build/browser/ontology/loadActionMetadata.js +1 -3
- package/build/browser/ontology/loadActionMetadata.js.map +1 -1
- package/build/browser/ontology/loadFullObjectMetadata.js +1 -2
- package/build/browser/ontology/loadFullObjectMetadata.js.map +1 -1
- package/build/browser/ontology/loadInterfaceMetadata.js +1 -2
- package/build/browser/ontology/loadInterfaceMetadata.js.map +1 -1
- package/build/browser/public/unstable-do-not-use.js.map +1 -1
- package/build/browser/queries/applyQuery.js +14 -0
- package/build/browser/queries/applyQuery.js.map +1 -1
- package/build/browser/queries/queries.test.js +14 -2
- package/build/browser/queries/queries.test.js.map +1 -1
- package/build/browser/util/UserAgent.js +2 -2
- package/build/browser/util/UserAgent.js.map +1 -1
- package/build/browser/util/isObjectSpecifiersObject.js.map +1 -1
- package/build/browser/util/toDataValue.js +0 -5
- package/build/browser/util/toDataValue.js.map +1 -1
- package/build/browser/util/toDataValue.test.js +2 -7
- package/build/browser/util/toDataValue.test.js.map +1 -1
- package/build/cjs/{Client-DaUJl7jZ.d.cts → Client-Cmx6x_V1.d.cts} +1 -1
- package/build/cjs/{chunk-IQJTM3KW.cjs → chunk-W4BHRZWL.cjs} +79 -82
- package/build/cjs/chunk-W4BHRZWL.cjs.map +1 -0
- package/build/cjs/{chunk-PARVKNVB.cjs → chunk-Y362HOIZ.cjs} +30 -35
- package/build/cjs/chunk-Y362HOIZ.cjs.map +1 -0
- package/build/cjs/{createClient-D5G3qzAO.d.cts → createClient-BDmrDOzZ.d.cts} +1 -2
- package/build/cjs/index.cjs +8 -12
- package/build/cjs/index.cjs.map +1 -1
- package/build/cjs/index.d.cts +3 -3
- package/build/cjs/public/internal.cjs +8 -8
- package/build/cjs/public/internal.d.cts +1 -1
- package/build/cjs/public/unstable-do-not-use.cjs +537 -95
- package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
- package/build/cjs/public/unstable-do-not-use.d.cts +75 -4
- package/build/esm/MinimalClientContext.js.map +1 -1
- package/build/esm/actions/actions.test.js +9 -8
- package/build/esm/actions/actions.test.js.map +1 -1
- package/build/esm/actions/applyAction.js +0 -4
- package/build/esm/actions/applyAction.js.map +1 -1
- package/build/esm/createClient.js +1 -2
- package/build/esm/createClient.js.map +1 -1
- package/build/esm/createMinimalClient.js +0 -1
- package/build/esm/createMinimalClient.js.map +1 -1
- package/build/esm/derivedProperties/createWithPropertiesObjectSet.js +1 -17
- package/build/esm/derivedProperties/createWithPropertiesObjectSet.js.map +1 -1
- package/build/esm/index.js +1 -1
- package/build/esm/index.js.map +1 -1
- package/build/esm/internal/conversions/modernToLegacyWhereClause.js +14 -9
- package/build/esm/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
- package/build/esm/internal/conversions/modernToLegacyWhereClause.test.js +74 -0
- package/build/esm/internal/conversions/modernToLegacyWhereClause.test.js.map +1 -1
- package/build/esm/object/SimpleOsdkProperties.js.map +1 -1
- package/build/esm/object/aggregate.js +0 -1
- package/build/esm/object/aggregate.js.map +1 -1
- package/build/esm/object/convertWireToOsdkObjects/BaseHolder.js.map +1 -1
- package/build/esm/object/fetchPage.js +0 -2
- package/build/esm/object/fetchPage.js.map +1 -1
- package/build/esm/objectSet/ObjectSetListenerWebsocket.js +13 -4
- package/build/esm/objectSet/ObjectSetListenerWebsocket.js.map +1 -1
- package/build/esm/objectSet/ObjectSetListenerWebsocket.test.js +46 -2
- package/build/esm/objectSet/ObjectSetListenerWebsocket.test.js.map +1 -1
- package/build/esm/objectSet/createObjectSet.js +1 -1
- package/build/esm/objectSet/createObjectSet.js.map +1 -1
- package/build/esm/objectSet/fetchLinksPage.js +0 -1
- package/build/esm/objectSet/fetchLinksPage.js.map +1 -1
- package/build/esm/observable/FunctionPayload.js +2 -0
- package/build/esm/observable/FunctionPayload.js.map +1 -0
- package/build/esm/observable/ObservableClient.js.map +1 -1
- package/build/esm/observable/internal/BulkObjectLoader.js +2 -1
- package/build/esm/observable/internal/BulkObjectLoader.js.map +1 -1
- package/build/esm/observable/internal/Changes.js +4 -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/ObservableClientImpl.js +21 -1
- package/build/esm/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/esm/observable/internal/RidListCanonicalizer.js +30 -0
- package/build/esm/observable/internal/RidListCanonicalizer.js.map +1 -0
- package/build/esm/observable/internal/RidListCanonicalizer.test.js +50 -0
- package/build/esm/observable/internal/RidListCanonicalizer.test.js.map +1 -0
- package/build/esm/observable/internal/Store.js +11 -1
- package/build/esm/observable/internal/Store.js.map +1 -1
- package/build/esm/observable/internal/Store.test.js +57 -4
- package/build/esm/observable/internal/Store.test.js.map +1 -1
- package/build/esm/observable/internal/actions/ActionApplication.js +12 -9
- package/build/esm/observable/internal/actions/ActionApplication.js.map +1 -1
- package/build/esm/observable/internal/base-list/BaseCollectionQuery.js.map +1 -1
- package/build/esm/observable/internal/base-list/BaseListQuery.js +15 -9
- package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -1
- package/build/esm/observable/internal/base-list/createCollectionConnectable.js +4 -2
- package/build/esm/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
- package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js +1 -2
- package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
- package/build/esm/observable/internal/evaluateFilter.js +1 -1
- package/build/esm/observable/internal/evaluateFilter.js.map +1 -1
- package/build/esm/observable/internal/evaluateFilter.test.js +105 -0
- package/build/esm/observable/internal/evaluateFilter.test.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionCacheKey.js +26 -0
- package/build/esm/observable/internal/function/FunctionCacheKey.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionParamsCanonicalizer.js +151 -0
- package/build/esm/observable/internal/function/FunctionParamsCanonicalizer.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionParamsCanonicalizer.test.js +186 -0
- package/build/esm/observable/internal/function/FunctionParamsCanonicalizer.test.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionQuery.js +137 -0
- package/build/esm/observable/internal/function/FunctionQuery.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionQuery.test.js +278 -0
- package/build/esm/observable/internal/function/FunctionQuery.test.js.map +1 -0
- package/build/esm/observable/internal/function/FunctionsHelper.js +92 -0
- package/build/esm/observable/internal/function/FunctionsHelper.js.map +1 -0
- package/build/esm/observable/internal/links/SpecificLinkQuery.js +2 -1
- package/build/esm/observable/internal/links/SpecificLinkQuery.js.map +1 -1
- package/build/esm/observable/internal/list/InterfaceListQuery.js +27 -10
- package/build/esm/observable/internal/list/InterfaceListQuery.js.map +1 -1
- package/build/esm/observable/internal/list/ListCacheKey.js +1 -0
- package/build/esm/observable/internal/list/ListCacheKey.js.map +1 -1
- package/build/esm/observable/internal/list/ListQuery.js +10 -4
- package/build/esm/observable/internal/list/ListQuery.js.map +1 -1
- package/build/esm/observable/internal/list/ListQuery.test.js +167 -3
- package/build/esm/observable/internal/list/ListQuery.test.js.map +1 -1
- package/build/esm/observable/internal/list/ListsHelper.js +6 -3
- package/build/esm/observable/internal/list/ListsHelper.js.map +1 -1
- package/build/esm/observable/internal/list/ObjectListQuery.js +23 -9
- package/build/esm/observable/internal/list/ObjectListQuery.js.map +1 -1
- package/build/esm/observable/internal/object/ObjectQuery.js +15 -1
- package/build/esm/observable/internal/object/ObjectQuery.js.map +1 -1
- package/build/esm/observable/internal/object/ObjectsHelper.js +1 -3
- package/build/esm/observable/internal/object/ObjectsHelper.js.map +1 -1
- package/build/esm/observable/internal/objectMatchesWhereClause.test.js +11 -1
- package/build/esm/observable/internal/objectMatchesWhereClause.test.js.map +1 -1
- package/build/esm/observable/internal/objectset/ObjectSetQuery.js +6 -2
- package/build/esm/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
- package/build/esm/observable/internal/testUtils.js +8 -5
- package/build/esm/observable/internal/testUtils.js.map +1 -1
- package/build/esm/observable/internal/utils/rdpFieldOperations.js +6 -3
- package/build/esm/observable/internal/utils/rdpFieldOperations.js.map +1 -1
- package/build/esm/ontology/loadActionMetadata.js +1 -3
- package/build/esm/ontology/loadActionMetadata.js.map +1 -1
- package/build/esm/ontology/loadFullObjectMetadata.js +1 -2
- package/build/esm/ontology/loadFullObjectMetadata.js.map +1 -1
- package/build/esm/ontology/loadInterfaceMetadata.js +1 -2
- package/build/esm/ontology/loadInterfaceMetadata.js.map +1 -1
- package/build/esm/public/unstable-do-not-use.js.map +1 -1
- package/build/esm/queries/applyQuery.js +14 -0
- package/build/esm/queries/applyQuery.js.map +1 -1
- package/build/esm/queries/queries.test.js +14 -2
- package/build/esm/queries/queries.test.js.map +1 -1
- package/build/esm/util/UserAgent.js +2 -2
- package/build/esm/util/UserAgent.js.map +1 -1
- package/build/esm/util/isObjectSpecifiersObject.js.map +1 -1
- package/build/esm/util/toDataValue.js +0 -5
- package/build/esm/util/toDataValue.js.map +1 -1
- package/build/esm/util/toDataValue.test.js +2 -7
- package/build/esm/util/toDataValue.test.js.map +1 -1
- package/build/types/MinimalClientContext.d.ts +1 -1
- package/build/types/actions/applyAction.d.ts.map +1 -1
- package/build/types/createClient.d.ts +0 -1
- 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/objectSet/createObjectSet.d.ts +14 -1
- package/build/types/objectSet/createObjectSet.d.ts.map +1 -1
- package/build/types/objectSet/fetchLinksPage.d.ts +9 -1
- package/build/types/objectSet/fetchLinksPage.d.ts.map +1 -1
- package/build/types/observable/FunctionPayload.d.ts +10 -0
- package/build/types/observable/FunctionPayload.d.ts.map +1 -0
- package/build/types/observable/ObservableClient.d.ts +73 -1
- package/build/types/observable/ObservableClient.d.ts.map +1 -1
- package/build/types/observable/internal/BulkObjectLoader.d.ts.map +1 -1
- package/build/types/observable/internal/Changes.d.ts +5 -3
- package/build/types/observable/internal/Changes.d.ts.map +1 -1
- package/build/types/observable/internal/KnownCacheKey.d.ts +2 -1
- package/build/types/observable/internal/KnownCacheKey.d.ts.map +1 -1
- package/build/types/observable/internal/RidListCanonicalizer.d.ts +5 -0
- package/build/types/observable/internal/RidListCanonicalizer.d.ts.map +1 -0
- package/build/types/observable/internal/RidListCanonicalizer.test.d.ts +1 -0
- package/build/types/observable/internal/RidListCanonicalizer.test.d.ts.map +1 -0
- package/build/types/observable/internal/Store.d.ts +7 -1
- 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/actions/ActionApplication.d.ts.map +1 -1
- package/build/types/observable/internal/base-list/BaseCollectionQuery.d.ts +3 -0
- package/build/types/observable/internal/base-list/BaseCollectionQuery.d.ts.map +1 -1
- package/build/types/observable/internal/base-list/BaseListQuery.d.ts +3 -1
- package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -1
- package/build/types/observable/internal/evaluateFilter.test.d.ts +1 -0
- package/build/types/observable/internal/evaluateFilter.test.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionCacheKey.d.ts +17 -0
- package/build/types/observable/internal/function/FunctionCacheKey.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionParamsCanonicalizer.d.ts +16 -0
- package/build/types/observable/internal/function/FunctionParamsCanonicalizer.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionParamsCanonicalizer.test.d.ts +1 -0
- package/build/types/observable/internal/function/FunctionParamsCanonicalizer.test.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionQuery.d.ts +40 -0
- package/build/types/observable/internal/function/FunctionQuery.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionQuery.test.d.ts +1 -0
- package/build/types/observable/internal/function/FunctionQuery.test.d.ts.map +1 -0
- package/build/types/observable/internal/function/FunctionsHelper.d.ts +25 -0
- package/build/types/observable/internal/function/FunctionsHelper.d.ts.map +1 -0
- package/build/types/observable/internal/links/SpecificLinkQuery.d.ts.map +1 -1
- package/build/types/observable/internal/list/InterfaceListQuery.d.ts +3 -0
- package/build/types/observable/internal/list/InterfaceListQuery.d.ts.map +1 -1
- package/build/types/observable/internal/list/ListCacheKey.d.ts +2 -1
- package/build/types/observable/internal/list/ListCacheKey.d.ts.map +1 -1
- package/build/types/observable/internal/list/ListQuery.d.ts +1 -1
- package/build/types/observable/internal/list/ListQuery.d.ts.map +1 -1
- package/build/types/observable/internal/list/ListsHelper.d.ts +3 -1
- package/build/types/observable/internal/list/ListsHelper.d.ts.map +1 -1
- package/build/types/observable/internal/list/ObjectListQuery.d.ts.map +1 -1
- package/build/types/observable/internal/object/ObjectQuery.d.ts.map +1 -1
- package/build/types/observable/internal/object/ObjectsHelper.d.ts.map +1 -1
- package/build/types/observable/internal/objectset/ObjectSetQuery.d.ts +1 -0
- package/build/types/observable/internal/objectset/ObjectSetQuery.d.ts.map +1 -1
- package/build/types/observable/internal/testUtils.d.ts.map +1 -1
- package/build/types/observable/internal/utils/rdpFieldOperations.d.ts.map +1 -1
- package/build/types/public/unstable-do-not-use.d.ts +2 -1
- package/build/types/public/unstable-do-not-use.d.ts.map +1 -1
- package/build/types/queries/applyQuery.d.ts.map +1 -1
- package/build/types/util/isObjectSpecifiersObject.d.ts +1 -0
- package/build/types/util/isObjectSpecifiersObject.d.ts.map +1 -1
- package/package.json +11 -12
- package/build/cjs/chunk-IQJTM3KW.cjs.map +0 -1
- package/build/cjs/chunk-PARVKNVB.cjs.map +0 -1
- package/build/cjs/delay-W2TSML2P.cjs +0 -75
- package/build/cjs/delay-W2TSML2P.cjs.map +0 -1
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { BehaviorSubject, connectable, map } from "rxjs";
|
|
18
|
+
import { additionalContext } from "../../../Client.js";
|
|
19
|
+
import { applyQuery } from "../../../queries/applyQuery.js";
|
|
20
|
+
import { Query } from "../Query.js";
|
|
21
|
+
export class FunctionQuery extends Query {
|
|
22
|
+
#apiName;
|
|
23
|
+
#version;
|
|
24
|
+
#params;
|
|
25
|
+
#dependsOn;
|
|
26
|
+
#dependsOnObjects;
|
|
27
|
+
#queryDef;
|
|
28
|
+
constructor(store, subject, queryDef, params, cacheKey, opts) {
|
|
29
|
+
super(store, subject, opts, cacheKey, process.env.NODE_ENV !== "production" ? store.client[additionalContext].logger?.child({}, {
|
|
30
|
+
msgPrefix: `FunctionQuery<${cacheKey.otherKeys.map(x => JSON.stringify(x)).join(", ")}>`
|
|
31
|
+
}) : undefined);
|
|
32
|
+
this.#apiName = queryDef.apiName;
|
|
33
|
+
this.#version = queryDef.isFixedVersion ? queryDef.version : undefined;
|
|
34
|
+
this.#params = params;
|
|
35
|
+
this.#dependsOn = opts.dependsOn;
|
|
36
|
+
this.#dependsOnObjects = opts.dependsOnObjects;
|
|
37
|
+
this.#queryDef = queryDef;
|
|
38
|
+
}
|
|
39
|
+
_createConnectable(subject) {
|
|
40
|
+
return connectable(subject.pipe(map(x => {
|
|
41
|
+
const value = x.value;
|
|
42
|
+
return {
|
|
43
|
+
status: x.status,
|
|
44
|
+
result: value?.result,
|
|
45
|
+
lastUpdated: value?.executedAt ?? 0,
|
|
46
|
+
error: value?.error
|
|
47
|
+
};
|
|
48
|
+
})), {
|
|
49
|
+
connector: () => new BehaviorSubject({
|
|
50
|
+
status: "init",
|
|
51
|
+
result: undefined,
|
|
52
|
+
lastUpdated: 0
|
|
53
|
+
})
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
async _fetchAndStore() {
|
|
57
|
+
if (process.env.NODE_ENV !== "production") {
|
|
58
|
+
this.logger?.child({
|
|
59
|
+
methodName: "_fetchAndStore"
|
|
60
|
+
}).debug("calling _fetchAndStore");
|
|
61
|
+
}
|
|
62
|
+
try {
|
|
63
|
+
// Type assertion needed because FunctionQuery we determine types dynamically
|
|
64
|
+
// at runtime without compile-time parameter type info. applyQuery internally
|
|
65
|
+
// converts params via remapQueryParams which handles the type safely.
|
|
66
|
+
const result = await applyQuery(this.store.client[additionalContext], this.#queryDef, this.#params);
|
|
67
|
+
const executedAt = Date.now();
|
|
68
|
+
this.store.batch({}, batch => {
|
|
69
|
+
this.writeToStore({
|
|
70
|
+
result,
|
|
71
|
+
executedAt
|
|
72
|
+
}, "loaded", batch);
|
|
73
|
+
});
|
|
74
|
+
} catch (e) {
|
|
75
|
+
if (process.env.NODE_ENV !== "production") {
|
|
76
|
+
this.logger?.child({
|
|
77
|
+
methodName: "_fetchAndStore"
|
|
78
|
+
}).error("Error executing function", e);
|
|
79
|
+
}
|
|
80
|
+
const error = e instanceof Error ? e : new Error(String(e));
|
|
81
|
+
this.store.batch({}, batch => {
|
|
82
|
+
this.writeToStore({
|
|
83
|
+
result: undefined,
|
|
84
|
+
executedAt: 0,
|
|
85
|
+
error
|
|
86
|
+
}, "error", batch);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
writeToStore(data, status, batch) {
|
|
91
|
+
batch.write(this.cacheKey, data, status);
|
|
92
|
+
return batch.read(this.cacheKey);
|
|
93
|
+
}
|
|
94
|
+
invalidateObjectType = (objectType, changes) => {
|
|
95
|
+
// Check if this function depends on the given object type
|
|
96
|
+
if (this.#dependsOn?.includes(objectType)) {
|
|
97
|
+
changes?.registerFunction(this.cacheKey);
|
|
98
|
+
return this.revalidate(true);
|
|
99
|
+
}
|
|
100
|
+
return Promise.resolve();
|
|
101
|
+
};
|
|
102
|
+
dependsOnObject(apiName, primaryKey) {
|
|
103
|
+
if (!this.#dependsOnObjects) {
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
return this.#dependsOnObjects.some(obj => obj.$apiName === apiName && obj.$primaryKey === primaryKey);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Called during batch operations when objects change.
|
|
111
|
+
* Checks if any objects in dependsOnObjects were modified/added
|
|
112
|
+
* and triggers revalidation if so.
|
|
113
|
+
*/
|
|
114
|
+
maybeUpdateAndRevalidate = changes => {
|
|
115
|
+
if (!this.#dependsOnObjects?.length) {
|
|
116
|
+
return undefined;
|
|
117
|
+
}
|
|
118
|
+
for (const dep of this.#dependsOnObjects) {
|
|
119
|
+
const modifiedObjects = changes.modifiedObjects.get(dep.$apiName);
|
|
120
|
+
if (modifiedObjects?.some(obj => obj.$primaryKey === dep.$primaryKey)) {
|
|
121
|
+
return this.revalidate(true);
|
|
122
|
+
}
|
|
123
|
+
const addedObjects = changes.addedObjects.get(dep.$apiName);
|
|
124
|
+
if (addedObjects?.some(obj => obj.$primaryKey === dep.$primaryKey)) {
|
|
125
|
+
return this.revalidate(true);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return undefined;
|
|
129
|
+
};
|
|
130
|
+
get apiName() {
|
|
131
|
+
return this.#apiName;
|
|
132
|
+
}
|
|
133
|
+
get version() {
|
|
134
|
+
return this.#version;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
//# sourceMappingURL=FunctionQuery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FunctionQuery.js","names":["BehaviorSubject","connectable","map","additionalContext","applyQuery","Query","FunctionQuery","apiName","version","params","dependsOn","dependsOnObjects","queryDef","constructor","store","subject","cacheKey","opts","process","env","NODE_ENV","client","logger","child","msgPrefix","otherKeys","x","JSON","stringify","join","undefined","isFixedVersion","_createConnectable","pipe","value","status","result","lastUpdated","executedAt","error","connector","_fetchAndStore","methodName","debug","Date","now","batch","writeToStore","e","Error","String","data","write","read","invalidateObjectType","objectType","changes","includes","registerFunction","revalidate","Promise","resolve","dependsOnObject","primaryKey","some","obj","$apiName","$primaryKey","maybeUpdateAndRevalidate","length","dep","modifiedObjects","get","addedObjects"],"sources":["FunctionQuery.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 { QueryDefinition } from \"@osdk/api\";\nimport type { Connectable, Observable, Subject } from \"rxjs\";\nimport { BehaviorSubject, connectable, map } from \"rxjs\";\nimport { additionalContext } from \"../../../Client.js\";\nimport type { MinimalClient } from \"../../../MinimalClientContext.js\";\nimport { applyQuery } from \"../../../queries/applyQuery.js\";\nimport type { FunctionPayload } from \"../../FunctionPayload.js\";\nimport type { CommonObserveOptions } from \"../../ObservableClient/common.js\";\nimport type { BatchContext } from \"../BatchContext.js\";\nimport type { Changes } from \"../Changes.js\";\nimport type { Entry } from \"../Layer.js\";\nimport type { OptimisticId } from \"../OptimisticId.js\";\nimport { Query } from \"../Query.js\";\nimport type { Store } from \"../Store.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type {\n FunctionCacheKey,\n FunctionCacheValue,\n} from \"./FunctionCacheKey.js\";\n\ntype PrimaryKeyValue = string | number;\ntype FunctionParams = Record<string, unknown>;\ntype ObjectDependency = { $apiName: string; $primaryKey: PrimaryKeyValue };\n\nexport interface FunctionObserveOptions extends CommonObserveOptions {\n dependsOn?: string[];\n dependsOnObjects?: ObjectDependency[];\n}\n\nexport class FunctionQuery extends Query<\n FunctionCacheKey,\n FunctionPayload,\n FunctionObserveOptions\n> {\n #apiName: string;\n #version: string | undefined;\n #params: FunctionParams | undefined;\n #dependsOn: string[] | undefined;\n #dependsOnObjects: ObjectDependency[] | undefined;\n #queryDef: QueryDefinition<unknown>;\n\n constructor(\n store: Store,\n subject: Subject<SubjectPayload<FunctionCacheKey>>,\n queryDef: QueryDefinition<unknown>,\n params: FunctionParams | undefined,\n cacheKey: FunctionCacheKey,\n opts: FunctionObserveOptions,\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: `FunctionQuery<${\n cacheKey.otherKeys.map(x => JSON.stringify(x)).join(\", \")\n }>`,\n })\n )\n : undefined,\n );\n this.#apiName = queryDef.apiName;\n this.#version = queryDef.isFixedVersion ? queryDef.version : undefined;\n this.#params = params;\n this.#dependsOn = opts.dependsOn;\n this.#dependsOnObjects = opts.dependsOnObjects;\n this.#queryDef = queryDef;\n }\n\n protected _createConnectable(\n subject: Observable<SubjectPayload<FunctionCacheKey>>,\n ): Connectable<FunctionPayload> {\n return connectable<FunctionPayload>(\n subject.pipe(\n map((x) => {\n const value = x.value as FunctionCacheValue | undefined;\n return {\n status: x.status,\n result: value?.result,\n lastUpdated: value?.executedAt ?? 0,\n error: value?.error,\n };\n }),\n ),\n {\n connector: () =>\n new BehaviorSubject<FunctionPayload>({\n status: \"init\",\n result: undefined,\n lastUpdated: 0,\n }),\n },\n );\n }\n\n async _fetchAndStore(): Promise<void> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).debug(\n \"calling _fetchAndStore\",\n );\n }\n\n try {\n // Type assertion needed because FunctionQuery we determine types dynamically\n // at runtime without compile-time parameter type info. applyQuery internally\n // converts params via remapQueryParams which handles the type safely.\n const result = await (applyQuery as (\n client: MinimalClient,\n query: QueryDefinition<unknown>,\n params?: Record<string, unknown>,\n ) => Promise<unknown>)(\n this.store.client[additionalContext],\n this.#queryDef,\n this.#params,\n );\n\n const executedAt = Date.now();\n\n this.store.batch({}, (batch) => {\n this.writeToStore({ result, executedAt }, \"loaded\", batch);\n });\n } catch (e) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).error(\n \"Error executing function\",\n e,\n );\n }\n const error = e instanceof Error ? e : new Error(String(e));\n this.store.batch({}, (batch) => {\n this.writeToStore(\n { result: undefined, executedAt: 0, error },\n \"error\",\n batch,\n );\n });\n }\n }\n\n writeToStore(\n data: FunctionCacheValue,\n status: \"loading\" | \"loaded\" | \"error\",\n batch: BatchContext,\n ): Entry<FunctionCacheKey> {\n batch.write(this.cacheKey, data, status);\n return batch.read(this.cacheKey)!;\n }\n\n invalidateObjectType = (\n objectType: string,\n changes: Changes | undefined,\n ): Promise<void> => {\n // Check if this function depends on the given object type\n if (this.#dependsOn?.includes(objectType)) {\n changes?.registerFunction(this.cacheKey);\n return this.revalidate(true);\n }\n return Promise.resolve();\n };\n\n dependsOnObject(apiName: string, primaryKey: PrimaryKeyValue): boolean {\n if (!this.#dependsOnObjects) {\n return false;\n }\n return this.#dependsOnObjects.some(\n (obj) => obj.$apiName === apiName && obj.$primaryKey === primaryKey,\n );\n }\n\n /**\n * Called during batch operations when objects change.\n * Checks if any objects in dependsOnObjects were modified/added\n * and triggers revalidation if so.\n */\n maybeUpdateAndRevalidate = (\n changes: Changes,\n _optimisticId: OptimisticId | undefined,\n ): Promise<void> | undefined => {\n if (!this.#dependsOnObjects?.length) {\n return undefined;\n }\n\n for (const dep of this.#dependsOnObjects) {\n const modifiedObjects = changes.modifiedObjects.get(dep.$apiName);\n if (modifiedObjects?.some(obj => obj.$primaryKey === dep.$primaryKey)) {\n return this.revalidate(true);\n }\n const addedObjects = changes.addedObjects.get(dep.$apiName);\n if (addedObjects?.some(obj => obj.$primaryKey === dep.$primaryKey)) {\n return this.revalidate(true);\n }\n }\n\n return undefined;\n };\n\n get apiName(): string {\n return this.#apiName;\n }\n\n get version(): string | undefined {\n return this.#version;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { addOne, Employee } from "@osdk/client.test.ontology";
|
|
18
|
+
import { LegacyFauxFoundry, startNodeApiServer } from "@osdk/shared.test";
|
|
19
|
+
import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest";
|
|
20
|
+
import { createClient } from "../../../createClient.js";
|
|
21
|
+
import { createChangedObjects } from "../Changes.js";
|
|
22
|
+
import { Store } from "../Store.js";
|
|
23
|
+
function mockFunctionSubCallback() {
|
|
24
|
+
return {
|
|
25
|
+
next: vi.fn(),
|
|
26
|
+
error: vi.fn(),
|
|
27
|
+
complete: vi.fn()
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function createMockObjectHolder(apiName, primaryKey) {
|
|
31
|
+
return {
|
|
32
|
+
$apiName: apiName,
|
|
33
|
+
$primaryKey: primaryKey
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
async function waitForCall(mock, count = 1) {
|
|
37
|
+
await vi.waitFor(() => {
|
|
38
|
+
expect(mock.next).toHaveBeenCalledTimes(count);
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
describe("FunctionQuery", () => {
|
|
42
|
+
let client;
|
|
43
|
+
let store;
|
|
44
|
+
beforeAll(() => {
|
|
45
|
+
const testSetup = startNodeApiServer(new LegacyFauxFoundry(), createClient);
|
|
46
|
+
({
|
|
47
|
+
client
|
|
48
|
+
} = testSetup);
|
|
49
|
+
return () => {
|
|
50
|
+
testSetup.apiServer.close();
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
beforeEach(() => {
|
|
54
|
+
store = new Store(client);
|
|
55
|
+
return () => {
|
|
56
|
+
store = undefined;
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
afterEach(() => {
|
|
60
|
+
vi.clearAllMocks();
|
|
61
|
+
});
|
|
62
|
+
it("observes function execution and returns result", async () => {
|
|
63
|
+
const subFn = mockFunctionSubCallback();
|
|
64
|
+
const subscription = store.functions.observe({
|
|
65
|
+
queryDef: addOne,
|
|
66
|
+
params: {
|
|
67
|
+
n: 2
|
|
68
|
+
},
|
|
69
|
+
dedupeInterval: 0
|
|
70
|
+
}, subFn);
|
|
71
|
+
await waitForCall(subFn, 1);
|
|
72
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
73
|
+
status: "loading"
|
|
74
|
+
}));
|
|
75
|
+
await waitForCall(subFn, 2);
|
|
76
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
77
|
+
status: "loaded",
|
|
78
|
+
result: 3
|
|
79
|
+
}));
|
|
80
|
+
subscription.unsubscribe();
|
|
81
|
+
});
|
|
82
|
+
it("invalidates function and re-fetches", async () => {
|
|
83
|
+
const subFn = mockFunctionSubCallback();
|
|
84
|
+
const subscription = store.functions.observe({
|
|
85
|
+
queryDef: addOne,
|
|
86
|
+
params: {
|
|
87
|
+
n: 2
|
|
88
|
+
},
|
|
89
|
+
dedupeInterval: 0
|
|
90
|
+
}, subFn);
|
|
91
|
+
await waitForCall(subFn, 2);
|
|
92
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
93
|
+
status: "loaded",
|
|
94
|
+
result: 3
|
|
95
|
+
}));
|
|
96
|
+
subFn.next.mockClear();
|
|
97
|
+
|
|
98
|
+
// Invalidate the function
|
|
99
|
+
await store.invalidateFunction(addOne, {
|
|
100
|
+
n: 2
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
// Wait for refetch to complete - gets loading then loaded
|
|
104
|
+
await vi.waitFor(() => {
|
|
105
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
106
|
+
status: "loaded",
|
|
107
|
+
result: 3
|
|
108
|
+
}));
|
|
109
|
+
});
|
|
110
|
+
subscription.unsubscribe();
|
|
111
|
+
});
|
|
112
|
+
it("dependsOn triggers refetch on object type invalidation", async () => {
|
|
113
|
+
const subFn = mockFunctionSubCallback();
|
|
114
|
+
const subscription = store.functions.observe({
|
|
115
|
+
queryDef: addOne,
|
|
116
|
+
params: {
|
|
117
|
+
n: 2
|
|
118
|
+
},
|
|
119
|
+
dependsOn: [Employee.apiName],
|
|
120
|
+
dedupeInterval: 0
|
|
121
|
+
}, subFn);
|
|
122
|
+
await waitForCall(subFn, 2);
|
|
123
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
124
|
+
status: "loaded",
|
|
125
|
+
result: 3
|
|
126
|
+
}));
|
|
127
|
+
subFn.next.mockClear();
|
|
128
|
+
|
|
129
|
+
// Invalidate Employee object type - should trigger function refetch
|
|
130
|
+
await store.invalidateObjectType(Employee, undefined);
|
|
131
|
+
|
|
132
|
+
// Should refetch
|
|
133
|
+
await waitForCall(subFn, 2);
|
|
134
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
135
|
+
status: "loaded",
|
|
136
|
+
result: 3
|
|
137
|
+
}));
|
|
138
|
+
subscription.unsubscribe();
|
|
139
|
+
});
|
|
140
|
+
it("cache key deduplicates same function calls", async () => {
|
|
141
|
+
const subFn1 = mockFunctionSubCallback();
|
|
142
|
+
const subFn2 = mockFunctionSubCallback();
|
|
143
|
+
const sub1 = store.functions.observe({
|
|
144
|
+
queryDef: addOne,
|
|
145
|
+
params: {
|
|
146
|
+
n: 2
|
|
147
|
+
},
|
|
148
|
+
dedupeInterval: 0
|
|
149
|
+
}, subFn1);
|
|
150
|
+
|
|
151
|
+
// Wait for first subscription to load
|
|
152
|
+
await waitForCall(subFn1, 2);
|
|
153
|
+
|
|
154
|
+
// Second subscription with same params should reuse cached result
|
|
155
|
+
const sub2 = store.functions.observe({
|
|
156
|
+
queryDef: addOne,
|
|
157
|
+
params: {
|
|
158
|
+
n: 2
|
|
159
|
+
},
|
|
160
|
+
dedupeInterval: 0
|
|
161
|
+
}, subFn2);
|
|
162
|
+
|
|
163
|
+
// Second subscriber should get the result
|
|
164
|
+
await vi.waitFor(() => {
|
|
165
|
+
expect(subFn2.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
166
|
+
result: 3
|
|
167
|
+
}));
|
|
168
|
+
});
|
|
169
|
+
sub1.unsubscribe();
|
|
170
|
+
sub2.unsubscribe();
|
|
171
|
+
});
|
|
172
|
+
it("dependsOnObjects triggers refetch when specific object is modified", async () => {
|
|
173
|
+
const subFn = mockFunctionSubCallback();
|
|
174
|
+
const mockEmployee = {
|
|
175
|
+
$apiName: Employee.apiName,
|
|
176
|
+
$primaryKey: 50030
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
// Create a function query that depends on a specific employee object
|
|
180
|
+
const subscription = store.functions.observe({
|
|
181
|
+
queryDef: addOne,
|
|
182
|
+
params: {
|
|
183
|
+
n: 2
|
|
184
|
+
},
|
|
185
|
+
dependsOnObjects: [mockEmployee],
|
|
186
|
+
dedupeInterval: 0
|
|
187
|
+
}, subFn);
|
|
188
|
+
await waitForCall(subFn, 2);
|
|
189
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
190
|
+
status: "loaded",
|
|
191
|
+
result: 3
|
|
192
|
+
}));
|
|
193
|
+
subFn.next.mockClear();
|
|
194
|
+
let functionQuery;
|
|
195
|
+
for (const cacheKey of store.queries.keys()) {
|
|
196
|
+
if (cacheKey.type === "function") {
|
|
197
|
+
functionQuery = store.queries.peek(cacheKey);
|
|
198
|
+
break;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
const changes = createChangedObjects();
|
|
202
|
+
changes.modifiedObjects.set(Employee.apiName, createMockObjectHolder(Employee.apiName, 50030));
|
|
203
|
+
expect(functionQuery).toBeDefined();
|
|
204
|
+
const revalidatePromise = functionQuery.maybeUpdateAndRevalidate(changes, undefined);
|
|
205
|
+
expect(revalidatePromise).toBeInstanceOf(Promise);
|
|
206
|
+
await revalidatePromise;
|
|
207
|
+
await vi.waitFor(() => {
|
|
208
|
+
expect(subFn.next).toHaveBeenCalled();
|
|
209
|
+
});
|
|
210
|
+
subscription.unsubscribe();
|
|
211
|
+
});
|
|
212
|
+
it("dependsOnObjects does NOT trigger refetch for different object", async () => {
|
|
213
|
+
const subFn = mockFunctionSubCallback();
|
|
214
|
+
const mockEmployee = {
|
|
215
|
+
$apiName: Employee.apiName,
|
|
216
|
+
$primaryKey: 50030
|
|
217
|
+
};
|
|
218
|
+
|
|
219
|
+
// Create a function query that depends on a specific employee object
|
|
220
|
+
const subscription = store.functions.observe({
|
|
221
|
+
queryDef: addOne,
|
|
222
|
+
params: {
|
|
223
|
+
n: 2
|
|
224
|
+
},
|
|
225
|
+
dependsOnObjects: [mockEmployee],
|
|
226
|
+
dedupeInterval: 0
|
|
227
|
+
}, subFn);
|
|
228
|
+
await waitForCall(subFn, 2);
|
|
229
|
+
expect(subFn.next).toHaveBeenLastCalledWith(expect.objectContaining({
|
|
230
|
+
status: "loaded",
|
|
231
|
+
result: 3
|
|
232
|
+
}));
|
|
233
|
+
let functionQuery;
|
|
234
|
+
for (const cacheKey of store.queries.keys()) {
|
|
235
|
+
if (cacheKey.type === "function") {
|
|
236
|
+
functionQuery = store.queries.peek(cacheKey);
|
|
237
|
+
break;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
const changes = createChangedObjects();
|
|
241
|
+
changes.modifiedObjects.set(Employee.apiName, createMockObjectHolder(Employee.apiName, 99999) // Different primary key
|
|
242
|
+
);
|
|
243
|
+
expect(functionQuery).toBeDefined();
|
|
244
|
+
const result = functionQuery.maybeUpdateAndRevalidate(changes, undefined);
|
|
245
|
+
expect(result).toBeUndefined();
|
|
246
|
+
subscription.unsubscribe();
|
|
247
|
+
});
|
|
248
|
+
it("dependsOnObjects triggers refetch for added objects", async () => {
|
|
249
|
+
const subFn = mockFunctionSubCallback();
|
|
250
|
+
const mockEmployee = {
|
|
251
|
+
$apiName: Employee.apiName,
|
|
252
|
+
$primaryKey: 50030
|
|
253
|
+
};
|
|
254
|
+
const subscription = store.functions.observe({
|
|
255
|
+
queryDef: addOne,
|
|
256
|
+
params: {
|
|
257
|
+
n: 2
|
|
258
|
+
},
|
|
259
|
+
dependsOnObjects: [mockEmployee],
|
|
260
|
+
dedupeInterval: 0
|
|
261
|
+
}, subFn);
|
|
262
|
+
await waitForCall(subFn, 2);
|
|
263
|
+
let functionQuery;
|
|
264
|
+
for (const cacheKey of store.queries.keys()) {
|
|
265
|
+
if (cacheKey.type === "function") {
|
|
266
|
+
functionQuery = store.queries.peek(cacheKey);
|
|
267
|
+
break;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
const changes = createChangedObjects();
|
|
271
|
+
changes.addedObjects.set(Employee.apiName, createMockObjectHolder(Employee.apiName, 50030));
|
|
272
|
+
expect(functionQuery).toBeDefined();
|
|
273
|
+
const revalidatePromise = functionQuery.maybeUpdateAndRevalidate(changes, undefined);
|
|
274
|
+
expect(revalidatePromise).toBeInstanceOf(Promise);
|
|
275
|
+
subscription.unsubscribe();
|
|
276
|
+
});
|
|
277
|
+
});
|
|
278
|
+
//# sourceMappingURL=FunctionQuery.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FunctionQuery.test.js","names":["addOne","Employee","LegacyFauxFoundry","startNodeApiServer","afterEach","beforeAll","beforeEach","describe","expect","it","vi","createClient","createChangedObjects","Store","mockFunctionSubCallback","next","fn","error","complete","createMockObjectHolder","apiName","primaryKey","$apiName","$primaryKey","waitForCall","mock","count","waitFor","toHaveBeenCalledTimes","client","store","testSetup","apiServer","close","undefined","clearAllMocks","subFn","subscription","functions","observe","queryDef","params","n","dedupeInterval","toHaveBeenLastCalledWith","objectContaining","status","result","unsubscribe","mockClear","invalidateFunction","dependsOn","invalidateObjectType","subFn1","subFn2","sub1","sub2","mockEmployee","dependsOnObjects","functionQuery","cacheKey","queries","keys","type","peek","changes","modifiedObjects","set","toBeDefined","revalidatePromise","maybeUpdateAndRevalidate","toBeInstanceOf","Promise","toHaveBeenCalled","toBeUndefined","addedObjects"],"sources":["FunctionQuery.test.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 { addOne, Employee } from \"@osdk/client.test.ontology\";\nimport { LegacyFauxFoundry, startNodeApiServer } from \"@osdk/shared.test\";\nimport type { MockedObject } from \"vitest\";\nimport {\n afterEach,\n beforeAll,\n beforeEach,\n describe,\n expect,\n it,\n vi,\n} from \"vitest\";\nimport type { Client } from \"../../../Client.js\";\nimport { createClient } from \"../../../createClient.js\";\nimport type { ObjectHolder } from \"../../../object/convertWireToOsdkObjects/ObjectHolder.js\";\nimport type { FunctionPayload } from \"../../FunctionPayload.js\";\nimport type { Observer } from \"../../ObservableClient/common.js\";\nimport { createChangedObjects } from \"../Changes.js\";\nimport { Store } from \"../Store.js\";\nimport type { FunctionQuery } from \"./FunctionQuery.js\";\n\nfunction mockFunctionSubCallback(): MockedObject<\n Observer<FunctionPayload | undefined>\n> {\n return {\n next: vi.fn(),\n error: vi.fn(),\n complete: vi.fn(),\n };\n}\n\nfunction createMockObjectHolder(\n apiName: string,\n primaryKey: unknown,\n): ObjectHolder {\n return {\n $apiName: apiName,\n $primaryKey: primaryKey,\n } as ObjectHolder;\n}\n\nasync function waitForCall(\n mock: MockedObject<Observer<FunctionPayload | undefined>>,\n count = 1,\n) {\n await vi.waitFor(() => {\n expect(mock.next).toHaveBeenCalledTimes(count);\n });\n}\n\ndescribe(\"FunctionQuery\", () => {\n let client: Client;\n let store: Store;\n\n beforeAll(() => {\n const testSetup = startNodeApiServer(new LegacyFauxFoundry(), createClient);\n ({ client } = testSetup);\n return () => {\n testSetup.apiServer.close();\n };\n });\n\n beforeEach(() => {\n store = new Store(client);\n return () => {\n store = undefined!;\n };\n });\n\n afterEach(() => {\n vi.clearAllMocks();\n });\n\n it(\"observes function execution and returns result\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 1);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({ status: \"loading\" }),\n );\n\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({\n status: \"loaded\",\n result: 3,\n }),\n );\n\n subscription.unsubscribe();\n });\n\n it(\"invalidates function and re-fetches\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({\n status: \"loaded\",\n result: 3,\n }),\n );\n\n subFn.next.mockClear();\n\n // Invalidate the function\n await store.invalidateFunction(addOne, { n: 2 });\n\n // Wait for refetch to complete - gets loading then loaded\n await vi.waitFor(() => {\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({\n status: \"loaded\",\n result: 3,\n }),\n );\n });\n\n subscription.unsubscribe();\n });\n\n it(\"dependsOn triggers refetch on object type invalidation\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dependsOn: [Employee.apiName],\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({ status: \"loaded\", result: 3 }),\n );\n\n subFn.next.mockClear();\n\n // Invalidate Employee object type - should trigger function refetch\n await store.invalidateObjectType(Employee, undefined);\n\n // Should refetch\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({ status: \"loaded\", result: 3 }),\n );\n\n subscription.unsubscribe();\n });\n\n it(\"cache key deduplicates same function calls\", async () => {\n const subFn1 = mockFunctionSubCallback();\n const subFn2 = mockFunctionSubCallback();\n\n const sub1 = store.functions.observe(\n { queryDef: addOne, params: { n: 2 }, dedupeInterval: 0 },\n subFn1,\n );\n\n // Wait for first subscription to load\n await waitForCall(subFn1, 2);\n\n // Second subscription with same params should reuse cached result\n const sub2 = store.functions.observe(\n { queryDef: addOne, params: { n: 2 }, dedupeInterval: 0 },\n subFn2,\n );\n\n // Second subscriber should get the result\n await vi.waitFor(() => {\n expect(subFn2.next).toHaveBeenLastCalledWith(\n expect.objectContaining({\n result: 3,\n }),\n );\n });\n\n sub1.unsubscribe();\n sub2.unsubscribe();\n });\n\n it(\"dependsOnObjects triggers refetch when specific object is modified\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const mockEmployee = {\n $apiName: Employee.apiName,\n $primaryKey: 50030,\n };\n\n // Create a function query that depends on a specific employee object\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dependsOnObjects: [mockEmployee],\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({ status: \"loaded\", result: 3 }),\n );\n\n subFn.next.mockClear();\n\n let functionQuery: FunctionQuery | undefined;\n for (const cacheKey of store.queries.keys()) {\n if (cacheKey.type === \"function\") {\n functionQuery = store.queries.peek(cacheKey) as FunctionQuery;\n break;\n }\n }\n\n const changes = createChangedObjects();\n changes.modifiedObjects.set(\n Employee.apiName,\n createMockObjectHolder(Employee.apiName, 50030),\n );\n\n expect(functionQuery).toBeDefined();\n const revalidatePromise = functionQuery!.maybeUpdateAndRevalidate(\n changes,\n undefined,\n );\n\n expect(revalidatePromise).toBeInstanceOf(Promise);\n await revalidatePromise;\n\n await vi.waitFor(() => {\n expect(subFn.next).toHaveBeenCalled();\n });\n\n subscription.unsubscribe();\n });\n\n it(\"dependsOnObjects does NOT trigger refetch for different object\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const mockEmployee = {\n $apiName: Employee.apiName,\n $primaryKey: 50030,\n };\n\n // Create a function query that depends on a specific employee object\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dependsOnObjects: [mockEmployee],\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 2);\n expect(subFn.next).toHaveBeenLastCalledWith(\n expect.objectContaining({ status: \"loaded\", result: 3 }),\n );\n\n let functionQuery: FunctionQuery | undefined;\n for (const cacheKey of store.queries.keys()) {\n if (cacheKey.type === \"function\") {\n functionQuery = store.queries.peek(cacheKey) as FunctionQuery;\n break;\n }\n }\n\n const changes = createChangedObjects();\n changes.modifiedObjects.set(\n Employee.apiName,\n createMockObjectHolder(Employee.apiName, 99999), // Different primary key\n );\n\n expect(functionQuery).toBeDefined();\n const result = functionQuery!.maybeUpdateAndRevalidate(changes, undefined);\n\n expect(result).toBeUndefined();\n\n subscription.unsubscribe();\n });\n\n it(\"dependsOnObjects triggers refetch for added objects\", async () => {\n const subFn = mockFunctionSubCallback();\n\n const mockEmployee = {\n $apiName: Employee.apiName,\n $primaryKey: 50030,\n };\n\n const subscription = store.functions.observe(\n {\n queryDef: addOne,\n params: { n: 2 },\n dependsOnObjects: [mockEmployee],\n dedupeInterval: 0,\n },\n subFn,\n );\n\n await waitForCall(subFn, 2);\n\n let functionQuery: FunctionQuery | undefined;\n for (const cacheKey of store.queries.keys()) {\n if (cacheKey.type === \"function\") {\n functionQuery = store.queries.peek(cacheKey) as FunctionQuery;\n break;\n }\n }\n\n const changes = createChangedObjects();\n changes.addedObjects.set(\n Employee.apiName,\n createMockObjectHolder(Employee.apiName, 50030),\n );\n\n expect(functionQuery).toBeDefined();\n const revalidatePromise = functionQuery!.maybeUpdateAndRevalidate(\n changes,\n undefined,\n );\n\n expect(revalidatePromise).toBeInstanceOf(Promise);\n\n subscription.unsubscribe();\n });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2025 Palantir Technologies, Inc. All rights reserved.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { AbstractHelper } from "../AbstractHelper.js";
|
|
18
|
+
import { PARAMS_IDX } from "./FunctionCacheKey.js";
|
|
19
|
+
import { FunctionParamsCanonicalizer } from "./FunctionParamsCanonicalizer.js";
|
|
20
|
+
import { FunctionQuery } from "./FunctionQuery.js";
|
|
21
|
+
export class FunctionsHelper extends AbstractHelper {
|
|
22
|
+
paramsCanonicalizer = new FunctionParamsCanonicalizer();
|
|
23
|
+
constructor(store, cacheKeys) {
|
|
24
|
+
super(store, cacheKeys);
|
|
25
|
+
}
|
|
26
|
+
observe(options, subFn) {
|
|
27
|
+
return super.observe(options, subFn);
|
|
28
|
+
}
|
|
29
|
+
getQuery(options) {
|
|
30
|
+
const {
|
|
31
|
+
queryDef,
|
|
32
|
+
params,
|
|
33
|
+
...observeOpts
|
|
34
|
+
} = options;
|
|
35
|
+
const apiName = queryDef.apiName;
|
|
36
|
+
const version = queryDef.isFixedVersion ? queryDef.version : undefined;
|
|
37
|
+
const canonicalParams = this.paramsCanonicalizer.canonicalize(params);
|
|
38
|
+
const functionCacheKey = this.cacheKeys.get("function", apiName, version, canonicalParams);
|
|
39
|
+
return this.store.queries.get(functionCacheKey, () => new FunctionQuery(this.store, this.store.subjects.get(functionCacheKey), queryDef, params, functionCacheKey, observeOpts));
|
|
40
|
+
}
|
|
41
|
+
async invalidateFunction(apiName, params) {
|
|
42
|
+
const functionApiName = typeof apiName === "string" ? apiName : apiName.apiName;
|
|
43
|
+
let canonicalParams;
|
|
44
|
+
if (params !== undefined) {
|
|
45
|
+
canonicalParams = this.paramsCanonicalizer.canonicalize(params);
|
|
46
|
+
}
|
|
47
|
+
const promises = [];
|
|
48
|
+
for (const cacheKey of this.store.queries.keys()) {
|
|
49
|
+
if (cacheKey.type !== "function") {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
const query = this.store.queries.peek(cacheKey);
|
|
53
|
+
if (!query) {
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// Check if apiName matches
|
|
58
|
+
if (query.apiName !== functionApiName) {
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// If params provided, check for exact match
|
|
63
|
+
if (canonicalParams !== undefined) {
|
|
64
|
+
const queryParams = cacheKey.otherKeys[PARAMS_IDX];
|
|
65
|
+
if (queryParams !== canonicalParams) {
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// Invalidate this query
|
|
71
|
+
promises.push(query.revalidate(true));
|
|
72
|
+
}
|
|
73
|
+
await Promise.allSettled(promises);
|
|
74
|
+
}
|
|
75
|
+
async invalidateFunctionsByObject(apiName, primaryKey) {
|
|
76
|
+
const promises = [];
|
|
77
|
+
for (const cacheKey of this.store.queries.keys()) {
|
|
78
|
+
if (cacheKey.type !== "function") {
|
|
79
|
+
continue;
|
|
80
|
+
}
|
|
81
|
+
const query = this.store.queries.peek(cacheKey);
|
|
82
|
+
if (!query) {
|
|
83
|
+
continue;
|
|
84
|
+
}
|
|
85
|
+
if (query.dependsOnObject(apiName, primaryKey)) {
|
|
86
|
+
promises.push(query.revalidate(true));
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
await Promise.allSettled(promises);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=FunctionsHelper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FunctionsHelper.js","names":["AbstractHelper","PARAMS_IDX","FunctionParamsCanonicalizer","FunctionQuery","FunctionsHelper","paramsCanonicalizer","constructor","store","cacheKeys","observe","options","subFn","getQuery","queryDef","params","observeOpts","apiName","version","isFixedVersion","undefined","canonicalParams","canonicalize","functionCacheKey","get","queries","subjects","invalidateFunction","functionApiName","promises","cacheKey","keys","type","query","peek","queryParams","otherKeys","push","revalidate","Promise","allSettled","invalidateFunctionsByObject","primaryKey","dependsOnObject"],"sources":["FunctionsHelper.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 { QueryDefinition } from \"@osdk/api\";\nimport type { FunctionPayload } from \"../../FunctionPayload.js\";\nimport type { Observer } from \"../../ObservableClient/common.js\";\nimport { AbstractHelper } from \"../AbstractHelper.js\";\nimport type { CacheKeys } from \"../CacheKeys.js\";\nimport type { Canonical } from \"../Canonical.js\";\nimport type { KnownCacheKey } from \"../KnownCacheKey.js\";\nimport type { QuerySubscription } from \"../QuerySubscription.js\";\nimport type { Store } from \"../Store.js\";\nimport { type FunctionCacheKey, PARAMS_IDX } from \"./FunctionCacheKey.js\";\nimport type { CanonicalFunctionParams } from \"./FunctionParamsCanonicalizer.js\";\nimport { FunctionParamsCanonicalizer } from \"./FunctionParamsCanonicalizer.js\";\nimport { type FunctionObserveOptions, FunctionQuery } from \"./FunctionQuery.js\";\n\ntype PrimaryKeyValue = string | number;\ntype FunctionParams = Record<string, unknown>;\n\nexport interface ObserveFunctionOptions extends FunctionObserveOptions {\n queryDef: QueryDefinition<unknown>;\n params?: FunctionParams;\n}\n\nexport class FunctionsHelper extends AbstractHelper<\n FunctionQuery,\n ObserveFunctionOptions\n> {\n readonly paramsCanonicalizer: FunctionParamsCanonicalizer =\n new FunctionParamsCanonicalizer();\n\n constructor(store: Store, cacheKeys: CacheKeys<KnownCacheKey>) {\n super(store, cacheKeys);\n }\n\n observe(\n options: ObserveFunctionOptions,\n subFn: Observer<FunctionPayload>,\n ): QuerySubscription<FunctionQuery> {\n return super.observe(options, subFn);\n }\n\n getQuery(options: ObserveFunctionOptions): FunctionQuery {\n const { queryDef, params, ...observeOpts } = options;\n const apiName = queryDef.apiName;\n const version = queryDef.isFixedVersion ? queryDef.version : undefined;\n\n const canonicalParams = this.paramsCanonicalizer.canonicalize(params);\n\n const functionCacheKey = this.cacheKeys.get<FunctionCacheKey>(\n \"function\",\n apiName,\n version,\n canonicalParams,\n );\n\n return this.store.queries.get(functionCacheKey, () =>\n new FunctionQuery(\n this.store,\n this.store.subjects.get(functionCacheKey),\n queryDef,\n params,\n functionCacheKey,\n observeOpts,\n ));\n }\n\n async invalidateFunction(\n apiName: string | QueryDefinition<unknown>,\n params?: FunctionParams,\n ): Promise<void> {\n const functionApiName = typeof apiName === \"string\"\n ? apiName\n : apiName.apiName;\n\n let canonicalParams: Canonical<CanonicalFunctionParams> | undefined;\n if (params !== undefined) {\n canonicalParams = this.paramsCanonicalizer.canonicalize(params);\n }\n\n const promises: Array<Promise<void>> = [];\n\n for (const cacheKey of this.store.queries.keys()) {\n if (cacheKey.type !== \"function\") {\n continue;\n }\n\n const query = this.store.queries.peek(cacheKey) as\n | FunctionQuery\n | undefined;\n if (!query) {\n continue;\n }\n\n // Check if apiName matches\n if (query.apiName !== functionApiName) {\n continue;\n }\n\n // If params provided, check for exact match\n if (canonicalParams !== undefined) {\n const queryCacheKey = cacheKey as FunctionCacheKey;\n const queryParams = queryCacheKey.otherKeys[PARAMS_IDX];\n if (queryParams !== canonicalParams) {\n continue;\n }\n }\n\n // Invalidate this query\n promises.push(query.revalidate(true));\n }\n\n await Promise.allSettled(promises);\n }\n\n async invalidateFunctionsByObject(\n apiName: string,\n primaryKey: PrimaryKeyValue,\n ): Promise<void> {\n const promises: Array<Promise<void>> = [];\n\n for (const cacheKey of this.store.queries.keys()) {\n if (cacheKey.type !== \"function\") {\n continue;\n }\n\n const query = this.store.queries.peek(cacheKey) as\n | FunctionQuery\n | undefined;\n if (!query) {\n continue;\n }\n\n if (query.dependsOnObject(apiName, primaryKey)) {\n promises.push(query.revalidate(true));\n }\n }\n\n await Promise.allSettled(promises);\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -93,7 +93,8 @@ export class SpecificLinkQuery extends BaseListQuery {
|
|
|
93
93
|
// Add orderBy to the query parameters if specified
|
|
94
94
|
const queryParams = {
|
|
95
95
|
$pageSize: this.options.pageSize || 100,
|
|
96
|
-
$nextPageToken: this.nextPageToken
|
|
96
|
+
$nextPageToken: this.nextPageToken,
|
|
97
|
+
$includeRid: true
|
|
97
98
|
};
|
|
98
99
|
|
|
99
100
|
// Include orderBy if it has entries
|