@osdk/client 2.8.0-beta.2 → 2.8.0-beta.4
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 +26 -0
- package/build/browser/internal/conversions/modernToLegacyWhereClause.js +1 -1
- package/build/browser/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
- package/build/browser/objectSet/createObjectSet.js +0 -4
- package/build/browser/objectSet/createObjectSet.js.map +1 -1
- package/build/browser/observable/ObservableClient.js.map +1 -1
- package/build/browser/observable/internal/AbstractHelper.js +19 -1
- package/build/browser/observable/internal/AbstractHelper.js.map +1 -1
- package/build/browser/observable/internal/ListQueryView.js +115 -0
- package/build/browser/observable/internal/ListQueryView.js.map +1 -0
- package/build/browser/observable/internal/ObservableClientImpl.js +23 -5
- package/build/browser/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/browser/observable/internal/Query.js +7 -5
- package/build/browser/observable/internal/Query.js.map +1 -1
- package/build/browser/observable/internal/Store.test.js +83 -1
- package/build/browser/observable/internal/Store.test.js.map +1 -1
- package/build/browser/observable/internal/base-list/BaseListQuery.js +72 -0
- package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -1
- package/build/browser/observable/internal/function/FunctionQuery.js +27 -1
- package/build/browser/observable/internal/function/FunctionQuery.js.map +1 -1
- package/build/browser/observable/internal/function/FunctionsHelper.js +2 -1
- package/build/browser/observable/internal/function/FunctionsHelper.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/list/ListQuery.js +2 -2
- package/build/browser/observable/internal/list/ListQuery.js.map +1 -1
- package/build/browser/observable/internal/objectset/ObjectSetQuery.js +1 -1
- package/build/browser/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
- package/build/browser/public/unstable-do-not-use.js +1 -0
- package/build/browser/public/unstable-do-not-use.js.map +1 -1
- package/build/browser/util/UserAgent.js +2 -2
- package/build/cjs/{chunk-XUFF6M4V.cjs → chunk-O22QYBFF.cjs} +132 -131
- package/build/cjs/chunk-O22QYBFF.cjs.map +1 -0
- package/build/cjs/{chunk-II23HDVV.cjs → chunk-RKC3366I.cjs} +65 -65
- package/build/cjs/{chunk-II23HDVV.cjs.map → chunk-RKC3366I.cjs.map} +1 -1
- package/build/cjs/index.cjs +8 -8
- package/build/cjs/public/internal.cjs +8 -8
- package/build/cjs/public/unstable-do-not-use.cjs +244 -68
- package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
- package/build/cjs/public/unstable-do-not-use.d.cts +13 -5
- package/build/esm/internal/conversions/modernToLegacyWhereClause.js +1 -1
- package/build/esm/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
- package/build/esm/objectSet/createObjectSet.js +0 -4
- package/build/esm/objectSet/createObjectSet.js.map +1 -1
- package/build/esm/observable/ObservableClient.js.map +1 -1
- package/build/esm/observable/internal/AbstractHelper.js +19 -1
- package/build/esm/observable/internal/AbstractHelper.js.map +1 -1
- package/build/esm/observable/internal/ListQueryView.js +115 -0
- package/build/esm/observable/internal/ListQueryView.js.map +1 -0
- package/build/esm/observable/internal/ObservableClientImpl.js +23 -5
- package/build/esm/observable/internal/ObservableClientImpl.js.map +1 -1
- package/build/esm/observable/internal/Query.js +7 -5
- package/build/esm/observable/internal/Query.js.map +1 -1
- package/build/esm/observable/internal/Store.test.js +83 -1
- package/build/esm/observable/internal/Store.test.js.map +1 -1
- package/build/esm/observable/internal/base-list/BaseListQuery.js +72 -0
- package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -1
- package/build/esm/observable/internal/function/FunctionQuery.js +27 -1
- package/build/esm/observable/internal/function/FunctionQuery.js.map +1 -1
- package/build/esm/observable/internal/function/FunctionsHelper.js +2 -1
- package/build/esm/observable/internal/function/FunctionsHelper.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/list/ListQuery.js +2 -2
- package/build/esm/observable/internal/list/ListQuery.js.map +1 -1
- package/build/esm/observable/internal/objectset/ObjectSetQuery.js +1 -1
- package/build/esm/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
- package/build/esm/public/unstable-do-not-use.js +1 -0
- package/build/esm/public/unstable-do-not-use.js.map +1 -1
- package/build/esm/util/UserAgent.js +2 -2
- package/build/types/objectSet/createObjectSet.d.ts +5 -1
- package/build/types/objectSet/createObjectSet.d.ts.map +1 -1
- package/build/types/observable/ObservableClient.d.ts +6 -2
- package/build/types/observable/ObservableClient.d.ts.map +1 -1
- package/build/types/observable/internal/AbstractHelper.d.ts +1 -1
- package/build/types/observable/internal/AbstractHelper.d.ts.map +1 -1
- package/build/types/observable/internal/ListQueryView.d.ts +21 -0
- package/build/types/observable/internal/ListQueryView.d.ts.map +1 -0
- package/build/types/observable/internal/Query.d.ts.map +1 -1
- package/build/types/observable/internal/Store.test.d.ts.map +1 -1
- package/build/types/observable/internal/base-list/BaseListQuery.d.ts +46 -2
- package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -1
- package/build/types/observable/internal/function/FunctionQuery.d.ts +1 -1
- package/build/types/observable/internal/function/FunctionQuery.d.ts.map +1 -1
- package/build/types/observable/internal/function/FunctionsHelper.d.ts +1 -0
- package/build/types/observable/internal/function/FunctionsHelper.d.ts.map +1 -1
- package/build/types/public/unstable-do-not-use.d.ts +1 -0
- package/build/types/public/unstable-do-not-use.d.ts.map +1 -1
- package/package.json +5 -5
- package/build/cjs/chunk-XUFF6M4V.cjs.map +0 -1
|
@@ -23,6 +23,16 @@ import { NoOpSortingStrategy } from "../sorting/SortingStrategy.js";
|
|
|
23
23
|
import { createCollectionConnectable } from "./createCollectionConnectable.js";
|
|
24
24
|
import { removeDuplicates } from "./removeDuplicates.js";
|
|
25
25
|
|
|
26
|
+
/**
|
|
27
|
+
* Base shape for list-like payloads (ListPayload, SpecificLinkPayload, etc.)
|
|
28
|
+
* Used to constrain PAYLOAD so we can safely access these properties
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Options that include pageSize for list-like queries.
|
|
33
|
+
* This allows BaseListQuery to access pageSize without type casting.
|
|
34
|
+
*/
|
|
35
|
+
|
|
26
36
|
/**
|
|
27
37
|
* Base class for collection-based queries (lists and links)
|
|
28
38
|
* Provides common functionality for working with collections of objects
|
|
@@ -52,6 +62,12 @@ export class BaseListQuery extends Query {
|
|
|
52
62
|
* @protected
|
|
53
63
|
*/
|
|
54
64
|
|
|
65
|
+
/**
|
|
66
|
+
* Per-subscriber page sizes for fetch optimization.
|
|
67
|
+
* Tracks each view's pageSize so we can recalculate max when views unsubscribe.
|
|
68
|
+
*/
|
|
69
|
+
#subscriberPageSizes = new Map();
|
|
70
|
+
|
|
55
71
|
//
|
|
56
72
|
// Shared Implementations
|
|
57
73
|
//
|
|
@@ -244,6 +260,62 @@ export class BaseListQuery extends Query {
|
|
|
244
260
|
return this.pendingFetch;
|
|
245
261
|
};
|
|
246
262
|
|
|
263
|
+
/**
|
|
264
|
+
* Register a subscriber's pageSize for fetch optimization.
|
|
265
|
+
* The query will fetch with the max pageSize across all subscribers.
|
|
266
|
+
*/
|
|
267
|
+
registerFetchPageSize(viewId, pageSize) {
|
|
268
|
+
this.#subscriberPageSizes.set(viewId, pageSize);
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
/**
|
|
272
|
+
* Unregister a subscriber's pageSize when they unsubscribe.
|
|
273
|
+
* Allows the effective pageSize to decrease when high-pageSize subscribers leave.
|
|
274
|
+
*/
|
|
275
|
+
unregisterFetchPageSize(viewId) {
|
|
276
|
+
this.#subscriberPageSizes.delete(viewId);
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
/**
|
|
280
|
+
* Get the effective fetch pageSize (max across all subscribers).
|
|
281
|
+
* Falls back to options.pageSize or 100 if no subscribers have registered.
|
|
282
|
+
*/
|
|
283
|
+
getEffectiveFetchPageSize() {
|
|
284
|
+
if (this.#subscriberPageSizes.size > 0) {
|
|
285
|
+
return Math.max(...this.#subscriberPageSizes.values());
|
|
286
|
+
}
|
|
287
|
+
return this.options.pageSize ?? 100;
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
/**
|
|
291
|
+
* Get the current number of loaded items in the cache.
|
|
292
|
+
*/
|
|
293
|
+
getLoadedCount() {
|
|
294
|
+
const {
|
|
295
|
+
retVal
|
|
296
|
+
} = this.store.batch({}, batch => {
|
|
297
|
+
return batch.read(this.cacheKey)?.value?.data.length ?? 0;
|
|
298
|
+
});
|
|
299
|
+
return retVal;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
/**
|
|
303
|
+
* Check if there are more pages available on the server.
|
|
304
|
+
*/
|
|
305
|
+
hasMorePages() {
|
|
306
|
+
return this.nextPageToken != null;
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
/**
|
|
310
|
+
* Notify all subscribers of a change (used when view limits change
|
|
311
|
+
* but no new data needs to be fetched).
|
|
312
|
+
*/
|
|
313
|
+
notifySubscribers() {
|
|
314
|
+
this.store.batch({}, batch => {
|
|
315
|
+
this.registerCacheChanges(batch);
|
|
316
|
+
});
|
|
317
|
+
}
|
|
318
|
+
|
|
247
319
|
/**
|
|
248
320
|
* Minimum number of results to load initially
|
|
249
321
|
* May be overridden by subclasses for specific collection types
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseListQuery.js","names":["deepEqual","DEBUG_ONLY__cacheKeysToString","isObjectInstance","RDP_IDX","Query","NoOpSortingStrategy","createCollectionConnectable","removeDuplicates","BaseListQuery","sortingStrategy","rdpConfig","cacheKey","otherKeys","_updateList","items","status","batch","append","totalCount","process","env","NODE_ENV","logger","child","methodName","debug","JSON","stringify","objectCacheKeys","length","store","objects","storeOsdkInstances","retainReleaseAppend","_sortCacheKeys","writeToStore","data","entry","read","value","write","ret","registerCacheChanges","#retainReleaseAppend","existingList","optimisticWrite","objectCacheKey","cacheKeys","release","retain","_dispose","createPayload","params","resolvedList","resolvedData","isOptimistic","fetchMore","hasMore","nextPageToken","lastUpdated","_createConnectable","subject","subjects","_preFetch","undefined","pendingPageFetch","pendingFetch","finally","Promise","resolve","setStatus","fetchPageAndUpdate","abortController","signal","then","minResultsToLoad","_fetchAndStore","count","aborted","hadPreviousPage","result","fetchPageData","currentTotalCount","retVal","finalStatus","objectKeys","error","handleFetchError","_error","_status","existingTotalCount","sortCacheKeys","updateCollection","options","createWebsocketSubscription","objectSet","sub","info","websocketSubscription","subscribe","onChange","onOswChange","bind","onError","onOswError","onOutOfDate","onOswOutOfDate","onSuccessfulSubscription","onOswSuccessfulSubscription","add","unsubscribe","subscriptionClosed","errors","object","state","onOswRemoved","get","$objectType","$apiName","$primaryKey","delete"],"sources":["BaseListQuery.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 ObjectSet,\n ObjectTypeDefinition,\n Osdk,\n PageResult,\n} from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport type { Connectable, Observable, Subscription } from \"rxjs\";\nimport type {\n CommonObserveOptions,\n Status,\n} from \"../../ObservableClient/common.js\";\nimport type { BatchContext } from \"../BatchContext.js\";\nimport { type CacheKey, DEBUG_ONLY__cacheKeysToString } from \"../CacheKey.js\";\nimport type { Canonical } from \"../Canonical.js\";\nimport { isObjectInstance } from \"../isObjectInstance.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { RDP_IDX } from \"../list/ListCacheKey.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { Query } from \"../Query.js\";\nimport type { Rdp } from \"../RdpCanonicalizer.js\";\nimport type { SortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport { NoOpSortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type { ObjectUpdate } from \"../types/ObjectUpdate.js\";\nimport type {\n CollectionConnectableParams,\n CollectionStorageData,\n} from \"./BaseCollectionQuery.js\";\nimport { createCollectionConnectable } from \"./createCollectionConnectable.js\";\nimport { removeDuplicates } from \"./removeDuplicates.js\";\n\n/**\n * Base class for collection-based queries (lists and links)\n * Provides common functionality for working with collections of objects\n */\nexport abstract class BaseListQuery<\n KEY extends CacheKey<any, CollectionStorageData, any, any>,\n PAYLOAD,\n O extends CommonObserveOptions,\n> extends Query<KEY, PAYLOAD, O> {\n /**\n * The sorting strategy to use for this collection\n * @protected\n */\n protected sortingStrategy: SortingStrategy = new NoOpSortingStrategy();\n\n /**\n * Get RDP configuration from the cache key\n */\n public get rdpConfig(): Canonical<Rdp> | null {\n return this.cacheKey.otherKeys[RDP_IDX];\n }\n\n // Collection-specific behavior is implemented by subclasses\n /**\n * Token for the next page of results\n * @protected\n */\n protected nextPageToken?: string;\n\n /**\n * Promise tracking an in-progress page fetch\n * @protected\n */\n protected pendingPageFetch?: Promise<void>;\n\n protected currentTotalCount?: string;\n\n //\n // Shared Implementations\n //\n\n /**\n * Standard method to update a list of objects\n * Handles common list update patterns for both ListQuery and SpecificLinkQuery\n *\n * @param items Objects or cache keys to add to the list\n * @param status Status to set for the list\n * @param batch Batch context to use\n * @param append Whether to append to the existing list or replace it\n * @param totalCount Optional total count from API response\n * @returns The updated entry\n */\n public _updateList<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n status: Status,\n batch: BatchContext,\n append: boolean = false,\n totalCount?: string,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger\n ?.child({ methodName: \"updateList\" })\n .debug(\n `{status: ${status}, append: ${append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n this.rdpConfig,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n objectCacheKeys = this.#retainReleaseAppend(batch, append, objectCacheKeys);\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n return this.writeToStore(\n { data: objectCacheKeys, totalCount },\n status,\n batch,\n );\n }\n\n /**\n * Common implementation for writing to store for collection-based queries\n * @param data The collection data to write to the store\n * @param status The status to set\n * @param batch The batch context\n */\n writeToStore(\n data: CollectionStorageData,\n status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(data, entry.value)) {\n // Check if both data AND status are the same\n if (entry.status === status) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal and status unchanged (${status}), skipping update`,\n );\n }\n // Return the existing entry without writing to avoid unnecessary notifications\n return entry;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal, just updating status from ${entry.status} to ${status}`,\n );\n }\n // Keep the same value but update status and lastUpdated\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `{status: ${status}},`,\n DEBUG_ONLY__cacheKeysToString(data.data),\n );\n }\n\n const ret = batch.write(this.cacheKey, data, status);\n this.registerCacheChanges(batch);\n return ret;\n }\n\n /**\n * Register changes to the cache based on the specific collection type\n * Implemented by subclasses to handle specific change registration\n */\n protected abstract registerCacheChanges(batch: BatchContext): void;\n\n /**\n * Common method for managing object reference counting and appending results\n * Used by collection queries when updating object references\n *\n * @param batch The batch context to use\n * @param append Whether to append to existing objects or replace them\n * @param objectCacheKeys Array of object cache keys to process\n * @returns The final array of object cache keys after retain/release/append\n */\n #retainReleaseAppend(\n batch: BatchContext,\n append: boolean,\n objectCacheKeys: ObjectCacheKey[],\n ): ObjectCacheKey[] {\n const existingList = batch.read(this.cacheKey);\n\n // whether its append or update we need to retain all the new objects\n if (!batch.optimisticWrite) {\n if (!append) {\n // we need to release all the old objects\n // N.B. the store keeps the cache keys around for a bit so we don't\n // need to worry about them being GC'd before we re-retain them\n for (const objectCacheKey of existingList?.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n\n for (const objectCacheKey of objectCacheKeys) {\n this.store.cacheKeys.retain(objectCacheKey);\n }\n }\n\n if (append) {\n objectCacheKeys = [\n ...existingList?.value?.data ?? [],\n ...objectCacheKeys,\n ];\n }\n return objectCacheKeys;\n }\n\n _dispose(): void {\n this.store.batch({}, (batch) => {\n const entry = batch.read(this.cacheKey);\n if (entry) {\n for (const objectCacheKey of entry.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n });\n }\n\n /**\n * Creates a payload from collection parameters\n * Default implementation that covers common fields for all collection types\n * Subclasses may override to add type-specific fields if needed\n *\n * @param params Common collection parameters\n * @returns A typed payload for the specific collection type\n */\n protected createPayload(\n params: CollectionConnectableParams,\n ): PAYLOAD {\n return {\n resolvedList: params.resolvedData,\n isOptimistic: params.isOptimistic,\n fetchMore: this.fetchMore,\n hasMore: this.nextPageToken != null,\n status: params.status,\n lastUpdated: params.lastUpdated,\n totalCount: params.totalCount,\n } as unknown as PAYLOAD; // Type assertion needed since we don't know exact subtype\n }\n\n /**\n * Creates a connectable observable for this collection\n * Common implementation shared by all collection types\n *\n * @param subject The subject to connect to\n * @returns A connectable observable of the collection's payload type\n */\n protected _createConnectable(\n subject: Observable<SubjectPayload<KEY>>,\n ): Connectable<PAYLOAD> {\n return createCollectionConnectable<KEY, PAYLOAD>(\n subject,\n this.store.subjects,\n (params) => this.createPayload(params),\n );\n }\n\n /**\n * @override Reset pagination state before a fetch\n */\n protected _preFetch(): void {\n this.nextPageToken = undefined;\n super._preFetch();\n }\n\n /**\n * Common fetchMore implementation for pagination\n * Handles pending request management and loading states\n */\n fetchMore = (): Promise<void> => {\n if (this.pendingPageFetch) {\n return this.pendingPageFetch;\n }\n\n if (this.pendingFetch) {\n this.pendingPageFetch = (async () => {\n await this.pendingFetch;\n await this.fetchMore();\n })().finally(() => {\n this.pendingPageFetch = undefined;\n });\n return this.pendingPageFetch;\n }\n\n if (this.nextPageToken == null) {\n return Promise.resolve(undefined);\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loading\", batch);\n });\n\n this.pendingFetch = this.fetchPageAndUpdate(\n \"loaded\",\n this.abortController?.signal,\n ).then(() => void 0).finally(() => {\n this.pendingFetch = undefined;\n });\n return this.pendingFetch;\n };\n\n /**\n * Minimum number of results to load initially\n * May be overridden by subclasses for specific collection types\n * @protected\n */\n protected minResultsToLoad: number = 0;\n\n /**\n * Common _fetchAndStore implementation for pagination\n * Uses fetchPageAndUpdate to load the initial set of data\n * Will load multiple pages if necessary to reach minResultsToLoad\n */\n protected async _fetchAndStore(): Promise<void> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).debug(\n \"fetching pages\",\n );\n }\n\n // Keep fetching pages until we have the minimum number of results or no more pages\n while (true) {\n const entry = await this.fetchPageAndUpdate(\n \"loading\",\n this.abortController?.signal,\n );\n\n if (!entry) {\n // we were aborted\n return;\n }\n\n // Check if we have enough results or no more pages\n const count = entry.value?.data.length || 0;\n if (count >= this.minResultsToLoad || this.nextPageToken == null) {\n break;\n }\n\n await Promise.resolve();\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loaded\", batch);\n });\n\n return Promise.resolve();\n }\n\n /**\n * Template method for fetching a page of data and updating the store\n * Provides common error handling and abort signal checking\n *\n * @param status The status to set for the entry\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the updated entry or undefined if aborted\n */\n protected async fetchPageAndUpdate(\n status: Status,\n signal: AbortSignal | undefined,\n ): Promise<Entry<KEY> | undefined> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).debug(\n `Fetching data with status: ${status}`,\n );\n }\n\n // Early abort check\n if (signal?.aborted) {\n return undefined;\n }\n\n try {\n const hadPreviousPage = this.nextPageToken != null;\n\n // Call the subclass-specific implementation to fetch data\n const result = await this.fetchPageData(signal);\n\n this.currentTotalCount = result.totalCount;\n\n // Check for abort again after fetch\n if (signal?.aborted) {\n return undefined;\n }\n\n // Store the fetched data using batch operations\n const { retVal } = this.store.batch({}, (batch) => {\n const append = hadPreviousPage;\n const finalStatus = result.nextPageToken ? status : \"loaded\";\n\n const objectKeys = this.store.objects.storeOsdkInstances(\n result.data,\n batch,\n this.rdpConfig,\n );\n\n return this._updateList(\n objectKeys,\n finalStatus,\n batch,\n append,\n this.currentTotalCount,\n );\n });\n\n return retVal;\n } catch (error: unknown) {\n // Log any errors that occur\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).error(\n \"Error fetching data\",\n error,\n );\n }\n\n // For unexpected errors, write error status if not aborted\n if (!signal?.aborted) {\n const { retVal } = this.store.batch({}, (batch) => {\n return this.handleFetchError(error, status, batch);\n });\n return retVal;\n }\n\n // If aborted, just return undefined\n return undefined;\n }\n }\n\n /**\n * Abstract method that subclasses implement for their specific data fetching logic\n *\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the fetched data\n */\n protected abstract fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>>;\n\n /**\n * Handle fetch errors by setting appropriate error state\n * Default implementation that subclasses can override\n *\n * @param error The error that occurred\n * @param status The intended status if successful\n * @param batch The batch context to use\n * @returns The updated entry with error status\n */\n protected handleFetchError(\n _error: unknown,\n _status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const existingTotalCount = batch.read(this.cacheKey)?.value?.totalCount;\n return this.writeToStore(\n { data: [], totalCount: existingTotalCount },\n \"error\",\n batch,\n );\n }\n\n /**\n * Sort the collection items using the configured sorting strategy\n * @param objectCacheKeys - The cache keys to sort\n * @param batch - The batch context\n * @returns Sorted array of cache keys\n */\n protected _sortCacheKeys(\n objectCacheKeys: ObjectCacheKey[],\n batch: BatchContext,\n ): ObjectCacheKey[] {\n return this.sortingStrategy.sortCacheKeys(objectCacheKeys, batch);\n }\n\n /**\n * Unified method for updating collection data in the store\n * Handles storing, sorting, deduplication, and reference counting\n *\n * @param items - Either object cache keys or object instances to update\n * @param options - Configuration options for the update\n * @param batch - The batch context to use\n * @returns The updated entry\n */\n protected updateCollection<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n options: {\n append?: boolean;\n status: Status;\n },\n batch: BatchContext,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"updateCollection\" })\n : this.logger;\n\n logger?.debug(\n `{status: ${options.status}, append: ${options.append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n // Step 1: Convert items to object cache keys if needed\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n this.rdpConfig,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n // Step 2: Handle retain/release/append logic\n objectCacheKeys = this.#retainReleaseAppend(\n batch,\n options.append ?? false,\n objectCacheKeys,\n );\n\n // Step 3: Sort using the configured sorting strategy\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n\n // Step 4: Remove duplicates\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n // Step 5: Write to store\n const existingTotalCount = batch.read(this.cacheKey)?.value?.totalCount;\n return this.writeToStore(\n { data: objectCacheKeys, totalCount: existingTotalCount },\n options.status,\n batch,\n );\n }\n\n //\n // Shared Websocket Subscription Methods\n //\n\n /**\n * Create standard websocket subscription handlers for an ObjectSet.\n * Subclasses can override individual handlers for custom behavior.\n *\n * @param objectSet The ObjectSet to subscribe to\n * @param sub The parent subscription to add cleanup to\n * @param methodName The method name for logging purposes\n */\n protected createWebsocketSubscription(\n objectSet: ObjectSet<any>,\n sub: Subscription,\n methodName: string = \"registerStreamUpdates\",\n ): void {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName })\n : this.logger;\n\n if (process.env.NODE_ENV !== \"production\") {\n logger?.child({ methodName }).info(\"Subscribing from websocket\");\n }\n\n try {\n const websocketSubscription = 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 }).info(\"Unsubscribing from websocket\");\n }\n websocketSubscription.unsubscribe();\n });\n } catch (error) {\n if (this.logger) {\n this.logger.child({ methodName })\n .error(\"Failed to register stream updates\", error);\n }\n this.onOswError({ subscriptionClosed: true, error });\n }\n }\n\n /**\n * Handler called when websocket subscription is successfully established.\n */\n protected onOswSuccessfulSubscription(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onSuccessfulSubscription\" }).debug(\"\");\n }\n }\n\n /**\n * Handler called when subscribed data becomes out of date.\n */\n protected onOswOutOfDate(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onOutOfDate\" }).debug(\"\");\n }\n }\n\n /**\n * Handler called when websocket subscription encounters an error.\n */\n protected onOswError(errors: {\n subscriptionClosed: boolean;\n error: unknown;\n }): void {\n if (this.logger) {\n this.logger?.child({ methodName: \"onError\" }).error(\n \"subscription errors\",\n errors,\n );\n }\n }\n\n /**\n * Handler called when an object in the subscribed set is added or updated.\n * Default implementation stores the object with RDP config if available.\n *\n * @param update The object update notification\n */\n protected onOswChange(\n { object, 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 object,\n );\n }\n\n if (state === \"ADDED_OR_UPDATED\") {\n this.store.batch({}, (batch) => {\n this.store.objects.storeOsdkInstances(\n [object as Osdk.Instance<ObjectTypeDefinition>],\n batch,\n this.rdpConfig, // Safe - null for queries without RDPs\n );\n });\n } else if (state === \"REMOVED\") {\n this.onOswRemoved(object);\n }\n }\n\n /**\n * Handler called when an object is removed from the subscribed set.\n * Default implementation deletes the object from cache.\n * ListQuery overrides this for list-specific removal logic.\n *\n * @param object The removed object\n */\n protected onOswRemoved(\n object: Osdk.Instance<ObjectTypeDefinition, never, string, {}>,\n ): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onRemoved\" }).debug(\n \"Removing object\",\n object,\n );\n }\n\n this.store.batch({}, (batch) => {\n const objectCacheKey = this.store.cacheKeys.get(\n \"object\",\n object.$objectType ?? object.$apiName,\n object.$primaryKey,\n );\n batch.delete(objectCacheKey, \"loaded\");\n });\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"BaseListQuery.js","names":["deepEqual","DEBUG_ONLY__cacheKeysToString","isObjectInstance","RDP_IDX","Query","NoOpSortingStrategy","createCollectionConnectable","removeDuplicates","BaseListQuery","sortingStrategy","rdpConfig","cacheKey","otherKeys","subscriberPageSizes","Map","_updateList","items","status","batch","append","totalCount","process","env","NODE_ENV","logger","child","methodName","debug","JSON","stringify","objectCacheKeys","length","store","objects","storeOsdkInstances","retainReleaseAppend","_sortCacheKeys","writeToStore","data","entry","read","value","write","ret","registerCacheChanges","#retainReleaseAppend","existingList","optimisticWrite","objectCacheKey","cacheKeys","release","retain","_dispose","createPayload","params","resolvedList","resolvedData","isOptimistic","fetchMore","hasMore","nextPageToken","lastUpdated","_createConnectable","subject","subjects","_preFetch","undefined","pendingPageFetch","pendingFetch","finally","Promise","resolve","setStatus","fetchPageAndUpdate","abortController","signal","then","registerFetchPageSize","viewId","pageSize","set","unregisterFetchPageSize","delete","getEffectiveFetchPageSize","size","Math","max","values","options","getLoadedCount","retVal","hasMorePages","notifySubscribers","minResultsToLoad","_fetchAndStore","count","aborted","hadPreviousPage","result","fetchPageData","currentTotalCount","finalStatus","objectKeys","error","handleFetchError","_error","_status","existingTotalCount","sortCacheKeys","updateCollection","createWebsocketSubscription","objectSet","sub","info","websocketSubscription","subscribe","onChange","onOswChange","bind","onError","onOswError","onOutOfDate","onOswOutOfDate","onSuccessfulSubscription","onOswSuccessfulSubscription","add","unsubscribe","subscriptionClosed","errors","object","state","onOswRemoved","get","$objectType","$apiName","$primaryKey"],"sources":["BaseListQuery.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 ObjectSet,\n ObjectTypeDefinition,\n Osdk,\n PageResult,\n} from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport type { Connectable, Observable, Subscription } from \"rxjs\";\nimport type {\n CommonObserveOptions,\n Status,\n} from \"../../ObservableClient/common.js\";\nimport type { BatchContext } from \"../BatchContext.js\";\nimport { type CacheKey, DEBUG_ONLY__cacheKeysToString } from \"../CacheKey.js\";\nimport type { Canonical } from \"../Canonical.js\";\nimport { isObjectInstance } from \"../isObjectInstance.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { RDP_IDX } from \"../list/ListCacheKey.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { Query } from \"../Query.js\";\nimport type { Rdp } from \"../RdpCanonicalizer.js\";\nimport type { SortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport { NoOpSortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type { ObjectUpdate } from \"../types/ObjectUpdate.js\";\nimport type {\n CollectionConnectableParams,\n CollectionStorageData,\n} from \"./BaseCollectionQuery.js\";\nimport { createCollectionConnectable } from \"./createCollectionConnectable.js\";\nimport { removeDuplicates } from \"./removeDuplicates.js\";\n\n/**\n * Base shape for list-like payloads (ListPayload, SpecificLinkPayload, etc.)\n * Used to constrain PAYLOAD so we can safely access these properties\n */\nexport interface BaseListPayloadShape {\n resolvedList: readonly unknown[];\n hasMore: boolean;\n fetchMore: () => Promise<void>;\n}\n\n/**\n * Options that include pageSize for list-like queries.\n * This allows BaseListQuery to access pageSize without type casting.\n */\nexport interface BaseListQueryOptions extends CommonObserveOptions {\n pageSize?: number;\n}\n\n/**\n * Base class for collection-based queries (lists and links)\n * Provides common functionality for working with collections of objects\n */\nexport abstract class BaseListQuery<\n KEY extends CacheKey<any, CollectionStorageData, any, any>,\n PAYLOAD extends BaseListPayloadShape,\n O extends BaseListQueryOptions,\n> extends Query<KEY, PAYLOAD, O> {\n /**\n * The sorting strategy to use for this collection\n * @protected\n */\n protected sortingStrategy: SortingStrategy = new NoOpSortingStrategy();\n\n /**\n * Get RDP configuration from the cache key\n */\n public get rdpConfig(): Canonical<Rdp> | null {\n return this.cacheKey.otherKeys[RDP_IDX];\n }\n\n // Collection-specific behavior is implemented by subclasses\n /**\n * Token for the next page of results\n * @protected\n */\n protected nextPageToken?: string;\n\n /**\n * Promise tracking an in-progress page fetch\n * @protected\n */\n protected pendingPageFetch?: Promise<void>;\n\n protected currentTotalCount?: string;\n\n /**\n * Per-subscriber page sizes for fetch optimization.\n * Tracks each view's pageSize so we can recalculate max when views unsubscribe.\n */\n #subscriberPageSizes: Map<string, number> = new Map();\n\n //\n // Shared Implementations\n //\n\n /**\n * Standard method to update a list of objects\n * Handles common list update patterns for both ListQuery and SpecificLinkQuery\n *\n * @param items Objects or cache keys to add to the list\n * @param status Status to set for the list\n * @param batch Batch context to use\n * @param append Whether to append to the existing list or replace it\n * @param totalCount Optional total count from API response\n * @returns The updated entry\n */\n public _updateList<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n status: Status,\n batch: BatchContext,\n append: boolean = false,\n totalCount?: string,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger\n ?.child({ methodName: \"updateList\" })\n .debug(\n `{status: ${status}, append: ${append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n this.rdpConfig,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n objectCacheKeys = this.#retainReleaseAppend(batch, append, objectCacheKeys);\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n return this.writeToStore(\n { data: objectCacheKeys, totalCount },\n status,\n batch,\n );\n }\n\n /**\n * Common implementation for writing to store for collection-based queries\n * @param data The collection data to write to the store\n * @param status The status to set\n * @param batch The batch context\n */\n writeToStore(\n data: CollectionStorageData,\n status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(data, entry.value)) {\n // Check if both data AND status are the same\n if (entry.status === status) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal and status unchanged (${status}), skipping update`,\n );\n }\n // Return the existing entry without writing to avoid unnecessary notifications\n return entry;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal, just updating status from ${entry.status} to ${status}`,\n );\n }\n // Keep the same value but update status and lastUpdated\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `{status: ${status}},`,\n DEBUG_ONLY__cacheKeysToString(data.data),\n );\n }\n\n const ret = batch.write(this.cacheKey, data, status);\n this.registerCacheChanges(batch);\n return ret;\n }\n\n /**\n * Register changes to the cache based on the specific collection type\n * Implemented by subclasses to handle specific change registration\n */\n protected abstract registerCacheChanges(batch: BatchContext): void;\n\n /**\n * Common method for managing object reference counting and appending results\n * Used by collection queries when updating object references\n *\n * @param batch The batch context to use\n * @param append Whether to append to existing objects or replace them\n * @param objectCacheKeys Array of object cache keys to process\n * @returns The final array of object cache keys after retain/release/append\n */\n #retainReleaseAppend(\n batch: BatchContext,\n append: boolean,\n objectCacheKeys: ObjectCacheKey[],\n ): ObjectCacheKey[] {\n const existingList = batch.read(this.cacheKey);\n\n // whether its append or update we need to retain all the new objects\n if (!batch.optimisticWrite) {\n if (!append) {\n // we need to release all the old objects\n // N.B. the store keeps the cache keys around for a bit so we don't\n // need to worry about them being GC'd before we re-retain them\n for (const objectCacheKey of existingList?.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n\n for (const objectCacheKey of objectCacheKeys) {\n this.store.cacheKeys.retain(objectCacheKey);\n }\n }\n\n if (append) {\n objectCacheKeys = [\n ...existingList?.value?.data ?? [],\n ...objectCacheKeys,\n ];\n }\n return objectCacheKeys;\n }\n\n _dispose(): void {\n this.store.batch({}, (batch) => {\n const entry = batch.read(this.cacheKey);\n if (entry) {\n for (const objectCacheKey of entry.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n });\n }\n\n /**\n * Creates a payload from collection parameters\n * Default implementation that covers common fields for all collection types\n * Subclasses may override to add type-specific fields if needed\n *\n * @param params Common collection parameters\n * @returns A typed payload for the specific collection type\n */\n protected createPayload(\n params: CollectionConnectableParams,\n ): PAYLOAD {\n return {\n resolvedList: params.resolvedData,\n isOptimistic: params.isOptimistic,\n fetchMore: this.fetchMore,\n hasMore: this.nextPageToken != null,\n status: params.status,\n lastUpdated: params.lastUpdated,\n totalCount: params.totalCount,\n } as unknown as PAYLOAD; // Type assertion needed since we don't know exact subtype\n }\n\n /**\n * Creates a connectable observable for this collection\n * Common implementation shared by all collection types\n *\n * @param subject The subject to connect to\n * @returns A connectable observable of the collection's payload type\n */\n protected _createConnectable(\n subject: Observable<SubjectPayload<KEY>>,\n ): Connectable<PAYLOAD> {\n return createCollectionConnectable<KEY, PAYLOAD>(\n subject,\n this.store.subjects,\n (params) => this.createPayload(params),\n );\n }\n\n /**\n * @override Reset pagination state before a fetch\n */\n protected _preFetch(): void {\n this.nextPageToken = undefined;\n super._preFetch();\n }\n\n /**\n * Common fetchMore implementation for pagination\n * Handles pending request management and loading states\n */\n fetchMore = (): Promise<void> => {\n if (this.pendingPageFetch) {\n return this.pendingPageFetch;\n }\n\n if (this.pendingFetch) {\n this.pendingPageFetch = (async () => {\n await this.pendingFetch;\n await this.fetchMore();\n })().finally(() => {\n this.pendingPageFetch = undefined;\n });\n return this.pendingPageFetch;\n }\n\n if (this.nextPageToken == null) {\n return Promise.resolve(undefined);\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loading\", batch);\n });\n\n this.pendingFetch = this.fetchPageAndUpdate(\n \"loaded\",\n this.abortController?.signal,\n ).then(() => void 0).finally(() => {\n this.pendingFetch = undefined;\n });\n return this.pendingFetch;\n };\n\n /**\n * Register a subscriber's pageSize for fetch optimization.\n * The query will fetch with the max pageSize across all subscribers.\n */\n registerFetchPageSize(viewId: string, pageSize: number): void {\n this.#subscriberPageSizes.set(viewId, pageSize);\n }\n\n /**\n * Unregister a subscriber's pageSize when they unsubscribe.\n * Allows the effective pageSize to decrease when high-pageSize subscribers leave.\n */\n unregisterFetchPageSize(viewId: string): void {\n this.#subscriberPageSizes.delete(viewId);\n }\n\n /**\n * Get the effective fetch pageSize (max across all subscribers).\n * Falls back to options.pageSize or 100 if no subscribers have registered.\n */\n getEffectiveFetchPageSize(): number {\n if (this.#subscriberPageSizes.size > 0) {\n return Math.max(...this.#subscriberPageSizes.values());\n }\n return this.options.pageSize ?? 100;\n }\n\n /**\n * Get the current number of loaded items in the cache.\n */\n getLoadedCount(): number {\n const { retVal } = this.store.batch({}, (batch) => {\n return batch.read(this.cacheKey)?.value?.data.length ?? 0;\n });\n return retVal;\n }\n\n /**\n * Check if there are more pages available on the server.\n */\n hasMorePages(): boolean {\n return this.nextPageToken != null;\n }\n\n /**\n * Notify all subscribers of a change (used when view limits change\n * but no new data needs to be fetched).\n */\n notifySubscribers(): void {\n this.store.batch({}, (batch) => {\n this.registerCacheChanges(batch);\n });\n }\n\n /**\n * Minimum number of results to load initially\n * May be overridden by subclasses for specific collection types\n * @protected\n */\n protected minResultsToLoad: number = 0;\n\n /**\n * Common _fetchAndStore implementation for pagination\n * Uses fetchPageAndUpdate to load the initial set of data\n * Will load multiple pages if necessary to reach minResultsToLoad\n */\n protected async _fetchAndStore(): Promise<void> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).debug(\n \"fetching pages\",\n );\n }\n\n // Keep fetching pages until we have the minimum number of results or no more pages\n while (true) {\n const entry = await this.fetchPageAndUpdate(\n \"loading\",\n this.abortController?.signal,\n );\n\n if (!entry) {\n // we were aborted\n return;\n }\n\n // Check if we have enough results or no more pages\n const count = entry.value?.data.length || 0;\n if (count >= this.minResultsToLoad || this.nextPageToken == null) {\n break;\n }\n\n await Promise.resolve();\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loaded\", batch);\n });\n\n return Promise.resolve();\n }\n\n /**\n * Template method for fetching a page of data and updating the store\n * Provides common error handling and abort signal checking\n *\n * @param status The status to set for the entry\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the updated entry or undefined if aborted\n */\n protected async fetchPageAndUpdate(\n status: Status,\n signal: AbortSignal | undefined,\n ): Promise<Entry<KEY> | undefined> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).debug(\n `Fetching data with status: ${status}`,\n );\n }\n\n // Early abort check\n if (signal?.aborted) {\n return undefined;\n }\n\n try {\n const hadPreviousPage = this.nextPageToken != null;\n\n // Call the subclass-specific implementation to fetch data\n const result = await this.fetchPageData(signal);\n\n this.currentTotalCount = result.totalCount;\n\n // Check for abort again after fetch\n if (signal?.aborted) {\n return undefined;\n }\n\n // Store the fetched data using batch operations\n const { retVal } = this.store.batch({}, (batch) => {\n const append = hadPreviousPage;\n const finalStatus = result.nextPageToken ? status : \"loaded\";\n\n const objectKeys = this.store.objects.storeOsdkInstances(\n result.data,\n batch,\n this.rdpConfig,\n );\n\n return this._updateList(\n objectKeys,\n finalStatus,\n batch,\n append,\n this.currentTotalCount,\n );\n });\n\n return retVal;\n } catch (error: unknown) {\n // Log any errors that occur\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).error(\n \"Error fetching data\",\n error,\n );\n }\n\n // For unexpected errors, write error status if not aborted\n if (!signal?.aborted) {\n const { retVal } = this.store.batch({}, (batch) => {\n return this.handleFetchError(error, status, batch);\n });\n return retVal;\n }\n\n // If aborted, just return undefined\n return undefined;\n }\n }\n\n /**\n * Abstract method that subclasses implement for their specific data fetching logic\n *\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the fetched data\n */\n protected abstract fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>>;\n\n /**\n * Handle fetch errors by setting appropriate error state\n * Default implementation that subclasses can override\n *\n * @param error The error that occurred\n * @param status The intended status if successful\n * @param batch The batch context to use\n * @returns The updated entry with error status\n */\n protected handleFetchError(\n _error: unknown,\n _status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const existingTotalCount = batch.read(this.cacheKey)?.value?.totalCount;\n return this.writeToStore(\n { data: [], totalCount: existingTotalCount },\n \"error\",\n batch,\n );\n }\n\n /**\n * Sort the collection items using the configured sorting strategy\n * @param objectCacheKeys - The cache keys to sort\n * @param batch - The batch context\n * @returns Sorted array of cache keys\n */\n protected _sortCacheKeys(\n objectCacheKeys: ObjectCacheKey[],\n batch: BatchContext,\n ): ObjectCacheKey[] {\n return this.sortingStrategy.sortCacheKeys(objectCacheKeys, batch);\n }\n\n /**\n * Unified method for updating collection data in the store\n * Handles storing, sorting, deduplication, and reference counting\n *\n * @param items - Either object cache keys or object instances to update\n * @param options - Configuration options for the update\n * @param batch - The batch context to use\n * @returns The updated entry\n */\n protected updateCollection<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n options: {\n append?: boolean;\n status: Status;\n },\n batch: BatchContext,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"updateCollection\" })\n : this.logger;\n\n logger?.debug(\n `{status: ${options.status}, append: ${options.append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n // Step 1: Convert items to object cache keys if needed\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n this.rdpConfig,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n // Step 2: Handle retain/release/append logic\n objectCacheKeys = this.#retainReleaseAppend(\n batch,\n options.append ?? false,\n objectCacheKeys,\n );\n\n // Step 3: Sort using the configured sorting strategy\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n\n // Step 4: Remove duplicates\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n // Step 5: Write to store\n const existingTotalCount = batch.read(this.cacheKey)?.value?.totalCount;\n return this.writeToStore(\n { data: objectCacheKeys, totalCount: existingTotalCount },\n options.status,\n batch,\n );\n }\n\n //\n // Shared Websocket Subscription Methods\n //\n\n /**\n * Create standard websocket subscription handlers for an ObjectSet.\n * Subclasses can override individual handlers for custom behavior.\n *\n * @param objectSet The ObjectSet to subscribe to\n * @param sub The parent subscription to add cleanup to\n * @param methodName The method name for logging purposes\n */\n protected createWebsocketSubscription(\n objectSet: ObjectSet<any>,\n sub: Subscription,\n methodName: string = \"registerStreamUpdates\",\n ): void {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName })\n : this.logger;\n\n if (process.env.NODE_ENV !== \"production\") {\n logger?.child({ methodName }).info(\"Subscribing from websocket\");\n }\n\n try {\n const websocketSubscription = 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 }).info(\"Unsubscribing from websocket\");\n }\n websocketSubscription.unsubscribe();\n });\n } catch (error) {\n if (this.logger) {\n this.logger.child({ methodName })\n .error(\"Failed to register stream updates\", error);\n }\n this.onOswError({ subscriptionClosed: true, error });\n }\n }\n\n /**\n * Handler called when websocket subscription is successfully established.\n */\n protected onOswSuccessfulSubscription(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onSuccessfulSubscription\" }).debug(\"\");\n }\n }\n\n /**\n * Handler called when subscribed data becomes out of date.\n */\n protected onOswOutOfDate(): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onOutOfDate\" }).debug(\"\");\n }\n }\n\n /**\n * Handler called when websocket subscription encounters an error.\n */\n protected onOswError(errors: {\n subscriptionClosed: boolean;\n error: unknown;\n }): void {\n if (this.logger) {\n this.logger?.child({ methodName: \"onError\" }).error(\n \"subscription errors\",\n errors,\n );\n }\n }\n\n /**\n * Handler called when an object in the subscribed set is added or updated.\n * Default implementation stores the object with RDP config if available.\n *\n * @param update The object update notification\n */\n protected onOswChange(\n { object, 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 object,\n );\n }\n\n if (state === \"ADDED_OR_UPDATED\") {\n this.store.batch({}, (batch) => {\n this.store.objects.storeOsdkInstances(\n [object as Osdk.Instance<ObjectTypeDefinition>],\n batch,\n this.rdpConfig, // Safe - null for queries without RDPs\n );\n });\n } else if (state === \"REMOVED\") {\n this.onOswRemoved(object);\n }\n }\n\n /**\n * Handler called when an object is removed from the subscribed set.\n * Default implementation deletes the object from cache.\n * ListQuery overrides this for list-specific removal logic.\n *\n * @param object The removed object\n */\n protected onOswRemoved(\n object: Osdk.Instance<ObjectTypeDefinition, never, string, {}>,\n ): void {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"onRemoved\" }).debug(\n \"Removing object\",\n object,\n );\n }\n\n this.store.batch({}, (batch) => {\n const objectCacheKey = this.store.cacheKeys.get(\n \"object\",\n object.$objectType ?? object.$apiName,\n object.$primaryKey,\n );\n batch.delete(objectCacheKey, \"loaded\");\n });\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -25,7 +25,7 @@ export class FunctionQuery extends Query {
|
|
|
25
25
|
#dependsOn;
|
|
26
26
|
#dependsOnObjects;
|
|
27
27
|
#queryDef;
|
|
28
|
-
constructor(store, subject, queryDef, params, cacheKey, opts) {
|
|
28
|
+
constructor(store, subject, queryDef, params, cacheKey, opts, objectSetTypesPromise) {
|
|
29
29
|
super(store, subject, opts, cacheKey, process.env.NODE_ENV !== "production" ? store.client[additionalContext].logger?.child({}, {
|
|
30
30
|
msgPrefix: `FunctionQuery<${cacheKey.otherKeys.map(x => JSON.stringify(x)).join(", ")}>`
|
|
31
31
|
}) : undefined);
|
|
@@ -35,6 +35,32 @@ export class FunctionQuery extends Query {
|
|
|
35
35
|
this.#dependsOn = opts.dependsOn;
|
|
36
36
|
this.#dependsOnObjects = opts.dependsOnObjects;
|
|
37
37
|
this.#queryDef = queryDef;
|
|
38
|
+
|
|
39
|
+
// Handle async ObjectSet type resolution
|
|
40
|
+
if (objectSetTypesPromise) {
|
|
41
|
+
objectSetTypesPromise.then(types => {
|
|
42
|
+
if (this.abortController?.signal.aborted) return;
|
|
43
|
+
let addedNewTypes = false;
|
|
44
|
+
for (const type of types) {
|
|
45
|
+
if (!this.#dependsOn) {
|
|
46
|
+
this.#dependsOn = [];
|
|
47
|
+
}
|
|
48
|
+
if (!this.#dependsOn.includes(type)) {
|
|
49
|
+
this.#dependsOn.push(type);
|
|
50
|
+
addedNewTypes = true;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
// Revalidate to catch any changes that occurred during async resolution
|
|
54
|
+
if (addedNewTypes) {
|
|
55
|
+
void this.revalidate(true);
|
|
56
|
+
}
|
|
57
|
+
}).catch(error => {
|
|
58
|
+
if (this.abortController?.signal.aborted) return;
|
|
59
|
+
if (process.env.NODE_ENV !== "production") {
|
|
60
|
+
this.logger?.error("Failed to extract ObjectSet types", error);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
38
64
|
}
|
|
39
65
|
_createConnectable(subject) {
|
|
40
66
|
return connectable(subject.pipe(map(x => {
|
|
@@ -1 +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":[]}
|
|
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","objectSetTypesPromise","process","env","NODE_ENV","client","logger","child","msgPrefix","otherKeys","x","JSON","stringify","join","undefined","isFixedVersion","then","types","abortController","signal","aborted","addedNewTypes","type","includes","push","revalidate","catch","error","_createConnectable","pipe","value","status","result","lastUpdated","executedAt","connector","_fetchAndStore","methodName","debug","Date","now","batch","writeToStore","e","Error","String","data","write","read","invalidateObjectType","objectType","changes","registerFunction","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 objectSetTypesPromise?: Promise<string[]>,\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 // Handle async ObjectSet type resolution\n if (objectSetTypesPromise) {\n objectSetTypesPromise\n .then(types => {\n if (this.abortController?.signal.aborted) return;\n\n let addedNewTypes = false;\n for (const type of types) {\n if (!this.#dependsOn) {\n this.#dependsOn = [];\n }\n if (!this.#dependsOn.includes(type)) {\n this.#dependsOn.push(type);\n addedNewTypes = true;\n }\n }\n // Revalidate to catch any changes that occurred during async resolution\n if (addedNewTypes) {\n void this.revalidate(true);\n }\n })\n .catch((error: unknown) => {\n if (this.abortController?.signal.aborted) return;\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.error(\"Failed to extract ObjectSet types\", error);\n }\n });\n }\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":[]}
|
|
@@ -30,13 +30,14 @@ export class FunctionsHelper extends AbstractHelper {
|
|
|
30
30
|
const {
|
|
31
31
|
queryDef,
|
|
32
32
|
params,
|
|
33
|
+
objectSetTypesPromise,
|
|
33
34
|
...observeOpts
|
|
34
35
|
} = options;
|
|
35
36
|
const apiName = queryDef.apiName;
|
|
36
37
|
const version = queryDef.isFixedVersion ? queryDef.version : undefined;
|
|
37
38
|
const canonicalParams = this.paramsCanonicalizer.canonicalize(params);
|
|
38
39
|
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
|
+
return this.store.queries.get(functionCacheKey, () => new FunctionQuery(this.store, this.store.subjects.get(functionCacheKey), queryDef, params, functionCacheKey, observeOpts, objectSetTypesPromise));
|
|
40
41
|
}
|
|
41
42
|
async invalidateFunction(apiName, params) {
|
|
42
43
|
const functionApiName = typeof apiName === "string" ? apiName : apiName.apiName;
|
|
@@ -1 +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":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKA,SAASA,cAAc,QAAQ,sBAAsB;AAMrD,SAAgCC,UAAU,QAAQ,uBAAuB;AAEzE,SAASC,2BAA2B,QAAQ,kCAAkC;AAC9E,SAAsCC,aAAa,QAAQ,oBAAoB;
|
|
1
|
+
{"version":3,"file":"FunctionsHelper.js","names":["AbstractHelper","PARAMS_IDX","FunctionParamsCanonicalizer","FunctionQuery","FunctionsHelper","paramsCanonicalizer","constructor","store","cacheKeys","observe","options","subFn","getQuery","queryDef","params","objectSetTypesPromise","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 objectSetTypesPromise?: Promise<string[]>;\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, objectSetTypesPromise, ...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 objectSetTypesPromise,\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":[]}
|
|
@@ -92,7 +92,7 @@ export class SpecificLinkQuery extends BaseListQuery {
|
|
|
92
92
|
// Fetch the linked objects with pagination
|
|
93
93
|
// Add orderBy to the query parameters if specified
|
|
94
94
|
const queryParams = {
|
|
95
|
-
$pageSize: this.
|
|
95
|
+
$pageSize: this.getEffectiveFetchPageSize(),
|
|
96
96
|
$nextPageToken: this.nextPageToken,
|
|
97
97
|
$includeRid: true
|
|
98
98
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SpecificLinkQuery.js","names":["deepEqual","additionalContext","BaseListQuery","OrderBySortingStrategy","tombstone","SpecificLinkQuery","sourceApiName","sourcePk","linkName","whereClause","orderBy","registerCacheChanges","batch","changes","modified","add","cacheKey","constructor","store","subject","opts","process","env","NODE_ENV","client","logger","child","msgPrefix","otherKeys","map","x","JSON","stringify","join","undefined","fetchPageData","signal","sourceObjectDef","type","apiName","sourceMetadata","ontologyProvider","getObjectDefinition","Object","keys","length","linkDef","links","targetType","Error","sortingStrategy","sourceQuery","where","primaryKeyApiName","linkQuery","pivotTo","aborted","queryParams","$pageSize","options","pageSize","$nextPageToken","nextPageToken","$includeRid","$orderBy","$where","response","fetchPage","deleteFromStore","status","entry","read","value","methodName","debug","write","ret","delete","deleted","maybeUpdateAndRevalidate","has","revalidate","Promise","resolve","invalidateObjectType","objectType","promise","isSpecificLinkCacheKey","key"],"sources":["SpecificLinkQuery.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 ObjectTypeDefinition,\n Osdk,\n PageResult,\n PrimaryKeyType,\n WhereClause,\n} from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport { type Subject } from \"rxjs\";\nimport { additionalContext } from \"../../../Client.js\";\nimport type { SpecificLinkPayload } from \"../../LinkPayload.js\";\nimport type { Status } from \"../../ObservableClient/common.js\";\nimport type { ObserveLinks } from \"../../ObservableClient/ObserveLink.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 } from \"../Changes.js\";\nimport type { Entry } from \"../Layer.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 { tombstone } from \"../tombstone.js\";\nimport type { SpecificLinkCacheKey } from \"./SpecificLinkCacheKey.js\";\n\n/**\n * Query implementation for retrieving linked objects from a specific object.\n * - Stores links as ObjectCacheKey[] references\n * - Creates indirect dependencies on linked objects\n * - Supports filtering and sorting of linked collections\n * - Handles proper invalidation of related objects\n */\nexport class SpecificLinkQuery extends BaseListQuery<\n SpecificLinkCacheKey,\n SpecificLinkPayload,\n ObserveLinks.Options<ObjectTypeDefinition, string>\n> {\n #sourceApiName: string;\n #sourcePk: PrimaryKeyType<ObjectTypeDefinition>;\n #linkName: string;\n #whereClause: Canonical<SimpleWhereClause>;\n #orderBy: Canonical<Record<string, \"asc\" | \"desc\" | undefined>>;\n\n /**\n * Register changes to the cache specific to SpecificLinkQuery\n */\n protected registerCacheChanges(batch: BatchContext): void {\n batch.changes.modified.add(this.cacheKey);\n }\n\n constructor(\n store: Store,\n subject: Subject<SubjectPayload<SpecificLinkCacheKey>>,\n cacheKey: SpecificLinkCacheKey,\n opts: ObserveLinks.Options<\n ObjectTypeDefinition,\n string\n >,\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: `SpecificLinkQuery<${\n cacheKey.otherKeys.map(x => JSON.stringify(x)).join(\", \")\n }>`,\n })\n )\n : undefined,\n );\n\n // Extract the necessary parameters from the cache key\n [\n this.#sourceApiName,\n this.#sourcePk,\n this.#linkName,\n this.#whereClause,\n this.#orderBy,\n ] = cacheKey.otherKeys;\n }\n\n // _fetchAndStore is now implemented in BaseCollectionQuery\n\n /**\n * Implements fetchPageData from the BaseCollectionQuery template method pattern\n * Fetches a page of linked objects\n */\n protected async fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>> {\n // Use the client API to create a query that pivots to linked objects\n const client = this.store.client;\n\n // First, get metadata for the source object to know the primary key field name\n const sourceObjectDef = {\n type: \"object\",\n apiName: this.#sourceApiName,\n } as ObjectTypeDefinition;\n\n // Use the client's ontologyProvider to get metadata, which has built-in caching\n const sourceMetadata = await client[additionalContext].ontologyProvider\n .getObjectDefinition(this.#sourceApiName);\n\n // Initialize sorting strategy with the link's target object type\n if (this.#orderBy && Object.keys(this.#orderBy).length > 0) {\n const linkDef = sourceMetadata.links?.[this.#linkName];\n if (!linkDef?.targetType) {\n throw new Error(\n `Missing link definition or targetType for link '${this.#linkName}' on object type '${this.#sourceApiName}'`,\n );\n }\n this.sortingStrategy = new OrderBySortingStrategy(\n linkDef.targetType,\n this.#orderBy,\n );\n }\n\n // Query for the specific source object\n const sourceQuery = client(sourceObjectDef).where({\n [sourceMetadata.primaryKeyApiName]: this.#sourcePk,\n } as WhereClause<any>);\n\n // Pivot to the linked objects\n const linkQuery = sourceQuery.pivotTo(this.#linkName);\n\n // Check for abort signal again before fetching\n if (signal?.aborted) {\n throw new Error(\"Aborted\");\n }\n\n // Fetch the linked objects with pagination\n // Add orderBy to the query parameters if specified\n const queryParams: {\n $pageSize: number;\n $nextPageToken: string | undefined;\n $includeRid: true;\n $orderBy?: Record<string, \"asc\" | \"desc\" | undefined>;\n $where?: Record<string, unknown>;\n } = {\n $pageSize: this.options.pageSize || 100,\n $nextPageToken: this.nextPageToken,\n $includeRid: true,\n };\n\n // Include orderBy if it has entries\n if (this.#orderBy && Object.keys(this.#orderBy).length > 0) {\n queryParams.$orderBy = this.#orderBy;\n }\n\n // Include whereClause if it has entries\n if (this.#whereClause && Object.keys(this.#whereClause).length > 0) {\n queryParams.$where = this.#whereClause;\n }\n\n const response = await linkQuery.fetchPage(queryParams);\n\n // Store the next page token for pagination\n this.nextPageToken = response.nextPageToken;\n\n return response;\n }\n\n /**\n * Removes a link query from the store\n */\n deleteFromStore(\n status: Status,\n batch: BatchContext,\n ): Entry<SpecificLinkCacheKey> | undefined {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(tombstone, entry.value)) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"deleteFromStore\" }).debug(\n `Links were already deleted, just setting status`,\n );\n }\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"deleteFromStore\" }).debug(\n JSON.stringify({ status }),\n );\n }\n\n // If there is no entry then there is nothing to do\n if (!entry || !entry.value) {\n return;\n }\n\n const ret = batch.delete(this.cacheKey, status);\n batch.changes.deleted.add(this.cacheKey);\n\n return ret;\n }\n\n /**\n * Implements Query.maybeUpdateAndRevalidate to handle cache invalidation\n */\n maybeUpdateAndRevalidate = async (\n changes: Changes,\n _optimisticId: OptimisticId | undefined,\n ): Promise<void> => {\n // TODO: Implement proper invalidation logic for linked objects\n // This would check if any of the linked objects have changed,\n // or if the source object's links might have changed\n\n // For now, simply check if this specific link cache key was modified\n if (changes.modified.has(this.cacheKey)) {\n return this.revalidate(true);\n }\n\n // No relevant changes were detected\n return Promise.resolve();\n };\n\n invalidateObjectType = (\n objectType: string,\n changes: Changes | undefined,\n ): Promise<void> => {\n // We need to invalidate links in two cases:\n // 1. When the source object type matches the apiName (direct invalidation)\n // 2. When the target object type might be the invalidated type (affected by target changes)\n\n // For case 1 - direct source object type match\n if (this.#sourceApiName === objectType) {\n changes?.modified.add(this.cacheKey);\n return this.revalidate(true);\n } else {\n // For case 2 - check if the link's target type matches the invalidated type\n // We need to use the ontology provider to get the link metadata\n // Since this is async, we'll collect all the metadata check promises\n return (async () => {\n // Get the source object metadata to determine link target type\n const sourceMetadata = await this.store.client[additionalContext]\n .ontologyProvider\n .getObjectDefinition(this.#sourceApiName);\n\n const linkDef = sourceMetadata.links?.[this.#linkName];\n if (!linkDef || linkDef.targetType !== objectType) return;\n\n const promise = this.revalidate(true);\n changes?.modified.add(this.cacheKey);\n return promise;\n })();\n }\n };\n}\n\n/**\n * Type guard to check if a cache key is a SpecificLinkCacheKey\n */\nexport function isSpecificLinkCacheKey(\n key: CacheKey,\n): key is SpecificLinkCacheKey {\n return key.type === \"specificLink\";\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"SpecificLinkQuery.js","names":["deepEqual","additionalContext","BaseListQuery","OrderBySortingStrategy","tombstone","SpecificLinkQuery","sourceApiName","sourcePk","linkName","whereClause","orderBy","registerCacheChanges","batch","changes","modified","add","cacheKey","constructor","store","subject","opts","process","env","NODE_ENV","client","logger","child","msgPrefix","otherKeys","map","x","JSON","stringify","join","undefined","fetchPageData","signal","sourceObjectDef","type","apiName","sourceMetadata","ontologyProvider","getObjectDefinition","Object","keys","length","linkDef","links","targetType","Error","sortingStrategy","sourceQuery","where","primaryKeyApiName","linkQuery","pivotTo","aborted","queryParams","$pageSize","getEffectiveFetchPageSize","$nextPageToken","nextPageToken","$includeRid","$orderBy","$where","response","fetchPage","deleteFromStore","status","entry","read","value","methodName","debug","write","ret","delete","deleted","maybeUpdateAndRevalidate","has","revalidate","Promise","resolve","invalidateObjectType","objectType","promise","isSpecificLinkCacheKey","key"],"sources":["SpecificLinkQuery.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 ObjectTypeDefinition,\n Osdk,\n PageResult,\n PrimaryKeyType,\n WhereClause,\n} from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport { type Subject } from \"rxjs\";\nimport { additionalContext } from \"../../../Client.js\";\nimport type { SpecificLinkPayload } from \"../../LinkPayload.js\";\nimport type { Status } from \"../../ObservableClient/common.js\";\nimport type { ObserveLinks } from \"../../ObservableClient/ObserveLink.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 } from \"../Changes.js\";\nimport type { Entry } from \"../Layer.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 { tombstone } from \"../tombstone.js\";\nimport type { SpecificLinkCacheKey } from \"./SpecificLinkCacheKey.js\";\n\n/**\n * Query implementation for retrieving linked objects from a specific object.\n * - Stores links as ObjectCacheKey[] references\n * - Creates indirect dependencies on linked objects\n * - Supports filtering and sorting of linked collections\n * - Handles proper invalidation of related objects\n */\nexport class SpecificLinkQuery extends BaseListQuery<\n SpecificLinkCacheKey,\n SpecificLinkPayload,\n ObserveLinks.Options<ObjectTypeDefinition, string>\n> {\n #sourceApiName: string;\n #sourcePk: PrimaryKeyType<ObjectTypeDefinition>;\n #linkName: string;\n #whereClause: Canonical<SimpleWhereClause>;\n #orderBy: Canonical<Record<string, \"asc\" | \"desc\" | undefined>>;\n\n /**\n * Register changes to the cache specific to SpecificLinkQuery\n */\n protected registerCacheChanges(batch: BatchContext): void {\n batch.changes.modified.add(this.cacheKey);\n }\n\n constructor(\n store: Store,\n subject: Subject<SubjectPayload<SpecificLinkCacheKey>>,\n cacheKey: SpecificLinkCacheKey,\n opts: ObserveLinks.Options<\n ObjectTypeDefinition,\n string\n >,\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: `SpecificLinkQuery<${\n cacheKey.otherKeys.map(x => JSON.stringify(x)).join(\", \")\n }>`,\n })\n )\n : undefined,\n );\n\n // Extract the necessary parameters from the cache key\n [\n this.#sourceApiName,\n this.#sourcePk,\n this.#linkName,\n this.#whereClause,\n this.#orderBy,\n ] = cacheKey.otherKeys;\n }\n\n // _fetchAndStore is now implemented in BaseCollectionQuery\n\n /**\n * Implements fetchPageData from the BaseCollectionQuery template method pattern\n * Fetches a page of linked objects\n */\n protected async fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>> {\n // Use the client API to create a query that pivots to linked objects\n const client = this.store.client;\n\n // First, get metadata for the source object to know the primary key field name\n const sourceObjectDef = {\n type: \"object\",\n apiName: this.#sourceApiName,\n } as ObjectTypeDefinition;\n\n // Use the client's ontologyProvider to get metadata, which has built-in caching\n const sourceMetadata = await client[additionalContext].ontologyProvider\n .getObjectDefinition(this.#sourceApiName);\n\n // Initialize sorting strategy with the link's target object type\n if (this.#orderBy && Object.keys(this.#orderBy).length > 0) {\n const linkDef = sourceMetadata.links?.[this.#linkName];\n if (!linkDef?.targetType) {\n throw new Error(\n `Missing link definition or targetType for link '${this.#linkName}' on object type '${this.#sourceApiName}'`,\n );\n }\n this.sortingStrategy = new OrderBySortingStrategy(\n linkDef.targetType,\n this.#orderBy,\n );\n }\n\n // Query for the specific source object\n const sourceQuery = client(sourceObjectDef).where({\n [sourceMetadata.primaryKeyApiName]: this.#sourcePk,\n } as WhereClause<any>);\n\n // Pivot to the linked objects\n const linkQuery = sourceQuery.pivotTo(this.#linkName);\n\n // Check for abort signal again before fetching\n if (signal?.aborted) {\n throw new Error(\"Aborted\");\n }\n\n // Fetch the linked objects with pagination\n // Add orderBy to the query parameters if specified\n const queryParams: {\n $pageSize: number;\n $nextPageToken: string | undefined;\n $includeRid: true;\n $orderBy?: Record<string, \"asc\" | \"desc\" | undefined>;\n $where?: Record<string, unknown>;\n } = {\n $pageSize: this.getEffectiveFetchPageSize(),\n $nextPageToken: this.nextPageToken,\n $includeRid: true,\n };\n\n // Include orderBy if it has entries\n if (this.#orderBy && Object.keys(this.#orderBy).length > 0) {\n queryParams.$orderBy = this.#orderBy;\n }\n\n // Include whereClause if it has entries\n if (this.#whereClause && Object.keys(this.#whereClause).length > 0) {\n queryParams.$where = this.#whereClause;\n }\n\n const response = await linkQuery.fetchPage(queryParams);\n\n // Store the next page token for pagination\n this.nextPageToken = response.nextPageToken;\n\n return response;\n }\n\n /**\n * Removes a link query from the store\n */\n deleteFromStore(\n status: Status,\n batch: BatchContext,\n ): Entry<SpecificLinkCacheKey> | undefined {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(tombstone, entry.value)) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"deleteFromStore\" }).debug(\n `Links were already deleted, just setting status`,\n );\n }\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"deleteFromStore\" }).debug(\n JSON.stringify({ status }),\n );\n }\n\n // If there is no entry then there is nothing to do\n if (!entry || !entry.value) {\n return;\n }\n\n const ret = batch.delete(this.cacheKey, status);\n batch.changes.deleted.add(this.cacheKey);\n\n return ret;\n }\n\n /**\n * Implements Query.maybeUpdateAndRevalidate to handle cache invalidation\n */\n maybeUpdateAndRevalidate = async (\n changes: Changes,\n _optimisticId: OptimisticId | undefined,\n ): Promise<void> => {\n // TODO: Implement proper invalidation logic for linked objects\n // This would check if any of the linked objects have changed,\n // or if the source object's links might have changed\n\n // For now, simply check if this specific link cache key was modified\n if (changes.modified.has(this.cacheKey)) {\n return this.revalidate(true);\n }\n\n // No relevant changes were detected\n return Promise.resolve();\n };\n\n invalidateObjectType = (\n objectType: string,\n changes: Changes | undefined,\n ): Promise<void> => {\n // We need to invalidate links in two cases:\n // 1. When the source object type matches the apiName (direct invalidation)\n // 2. When the target object type might be the invalidated type (affected by target changes)\n\n // For case 1 - direct source object type match\n if (this.#sourceApiName === objectType) {\n changes?.modified.add(this.cacheKey);\n return this.revalidate(true);\n } else {\n // For case 2 - check if the link's target type matches the invalidated type\n // We need to use the ontology provider to get the link metadata\n // Since this is async, we'll collect all the metadata check promises\n return (async () => {\n // Get the source object metadata to determine link target type\n const sourceMetadata = await this.store.client[additionalContext]\n .ontologyProvider\n .getObjectDefinition(this.#sourceApiName);\n\n const linkDef = sourceMetadata.links?.[this.#linkName];\n if (!linkDef || linkDef.targetType !== objectType) return;\n\n const promise = this.revalidate(true);\n changes?.modified.add(this.cacheKey);\n return promise;\n })();\n }\n };\n}\n\n/**\n * Type guard to check if a cache key is a SpecificLinkCacheKey\n */\nexport function isSpecificLinkCacheKey(\n key: CacheKey,\n): key is SpecificLinkCacheKey {\n return key.type === \"specificLink\";\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AASA,OAAOA,SAAS,MAAM,iBAAiB;AAEvC,SAASC,iBAAiB,QAAQ,oBAAoB;AAItD,SAASC,aAAa,QAAQ,+BAA+B;AAQ7D,SAASC,sBAAsB,QAAQ,+BAA+B;AAGtE,SAASC,SAAS,QAAQ,iBAAiB;AAG3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,iBAAiB,SAASH,aAAa,CAIlD;EACA,CAACI,aAAa;EACd,CAACC,QAAQ;EACT,CAACC,QAAQ;EACT,CAACC,WAAW;EACZ,CAACC,OAAO;;EAER;AACF;AACA;EACYC,oBAAoBA,CAACC,KAAmB,EAAQ;IACxDA,KAAK,CAACC,OAAO,CAACC,QAAQ,CAACC,GAAG,CAAC,IAAI,CAACC,QAAQ,CAAC;EAC3C;EAEAC,WAAWA,CACTC,KAAY,EACZC,OAAsD,EACtDH,QAA8B,EAC9BI,IAGC,EACD;IACA,KAAK,CACHF,KAAK,EACLC,OAAO,EACPC,IAAI,EACJJ,QAAQ,EACRK,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,GAEjCL,KAAK,CAACM,MAAM,CAACvB,iBAAiB,CAAC,CAACwB,MAAM,EAAEC,KAAK,CAAC,CAAC,CAAC,EAAE;MAChDC,SAAS,EAAE,qBACTX,QAAQ,CAACY,SAAS,CAACC,GAAG,CAACC,CAAC,IAAIC,IAAI,CAACC,SAAS,CAACF,CAAC,CAAC,CAAC,CAACG,IAAI,CAAC,IAAI,CAAC;IAE7D,CAAC,CAAC,GAEFC,SACN,CAAC;;IAED;IACA,CACE,IAAI,CAAC,CAAC5B,aAAa,EACnB,IAAI,CAAC,CAACC,QAAQ,EACd,IAAI,CAAC,CAACC,QAAQ,EACd,IAAI,CAAC,CAACC,WAAW,EACjB,IAAI,CAAC,CAACC,OAAO,CACd,GAAGM,QAAQ,CAACY,SAAS;EACxB;;EAEA;;EAEA;AACF;AACA;AACA;EACE,MAAgBO,aAAaA,CAC3BC,MAA+B,EACU;IACzC;IACA,MAAMZ,MAAM,GAAG,IAAI,CAACN,KAAK,CAACM,MAAM;;IAEhC;IACA,MAAMa,eAAe,GAAG;MACtBC,IAAI,EAAE,QAAQ;MACdC,OAAO,EAAE,IAAI,CAAC,CAACjC;IACjB,CAAyB;;IAEzB;IACA,MAAMkC,cAAc,GAAG,MAAMhB,MAAM,CAACvB,iBAAiB,CAAC,CAACwC,gBAAgB,CACpEC,mBAAmB,CAAC,IAAI,CAAC,CAACpC,aAAa,CAAC;;IAE3C;IACA,IAAI,IAAI,CAAC,CAACI,OAAO,IAAIiC,MAAM,CAACC,IAAI,CAAC,IAAI,CAAC,CAAClC,OAAO,CAAC,CAACmC,MAAM,GAAG,CAAC,EAAE;MAC1D,MAAMC,OAAO,GAAGN,cAAc,CAACO,KAAK,GAAG,IAAI,CAAC,CAACvC,QAAQ,CAAC;MACtD,IAAI,CAACsC,OAAO,EAAEE,UAAU,EAAE;QACxB,MAAM,IAAIC,KAAK,CACb,mDAAmD,IAAI,CAAC,CAACzC,QAAQ,qBAAqB,IAAI,CAAC,CAACF,aAAa,GAC3G,CAAC;MACH;MACA,IAAI,CAAC4C,eAAe,GAAG,IAAI/C,sBAAsB,CAC/C2C,OAAO,CAACE,UAAU,EAClB,IAAI,CAAC,CAACtC,OACR,CAAC;IACH;;IAEA;IACA,MAAMyC,WAAW,GAAG3B,MAAM,CAACa,eAAe,CAAC,CAACe,KAAK,CAAC;MAChD,CAACZ,cAAc,CAACa,iBAAiB,GAAG,IAAI,CAAC,CAAC9C;IAC5C,CAAqB,CAAC;;IAEtB;IACA,MAAM+C,SAAS,GAAGH,WAAW,CAACI,OAAO,CAAC,IAAI,CAAC,CAAC/C,QAAQ,CAAC;;IAErD;IACA,IAAI4B,MAAM,EAAEoB,OAAO,EAAE;MACnB,MAAM,IAAIP,KAAK,CAAC,SAAS,CAAC;IAC5B;;IAEA;IACA;IACA,MAAMQ,WAML,GAAG;MACFC,SAAS,EAAE,IAAI,CAACC,yBAAyB,CAAC,CAAC;MAC3CC,cAAc,EAAE,IAAI,CAACC,aAAa;MAClCC,WAAW,EAAE;IACf,CAAC;;IAED;IACA,IAAI,IAAI,CAAC,CAACpD,OAAO,IAAIiC,MAAM,CAACC,IAAI,CAAC,IAAI,CAAC,CAAClC,OAAO,CAAC,CAACmC,MAAM,GAAG,CAAC,EAAE;MAC1DY,WAAW,CAACM,QAAQ,GAAG,IAAI,CAAC,CAACrD,OAAO;IACtC;;IAEA;IACA,IAAI,IAAI,CAAC,CAACD,WAAW,IAAIkC,MAAM,CAACC,IAAI,CAAC,IAAI,CAAC,CAACnC,WAAW,CAAC,CAACoC,MAAM,GAAG,CAAC,EAAE;MAClEY,WAAW,CAACO,MAAM,GAAG,IAAI,CAAC,CAACvD,WAAW;IACxC;IAEA,MAAMwD,QAAQ,GAAG,MAAMX,SAAS,CAACY,SAAS,CAACT,WAAW,CAAC;;IAEvD;IACA,IAAI,CAACI,aAAa,GAAGI,QAAQ,CAACJ,aAAa;IAE3C,OAAOI,QAAQ;EACjB;;EAEA;AACF;AACA;EACEE,eAAeA,CACbC,MAAc,EACdxD,KAAmB,EACsB;IACzC,MAAMyD,KAAK,GAAGzD,KAAK,CAAC0D,IAAI,CAAC,IAAI,CAACtD,QAAQ,CAAC;IAEvC,IAAIqD,KAAK,IAAIrE,SAAS,CAACI,SAAS,EAAEiE,KAAK,CAACE,KAAK,CAAC,EAAE;MAC9C,IAAIlD,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;QACzC,IAAI,CAACE,MAAM,EAAEC,KAAK,CAAC;UAAE8C,UAAU,EAAE;QAAkB,CAAC,CAAC,CAACC,KAAK,CACzD,iDACF,CAAC;MACH;MACA,OAAO7D,KAAK,CAAC8D,KAAK,CAAC,IAAI,CAAC1D,QAAQ,EAAEqD,KAAK,CAACE,KAAK,EAAEH,MAAM,CAAC;IACxD;IAEA,IAAI/C,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;MACzC,IAAI,CAACE,MAAM,EAAEC,KAAK,CAAC;QAAE8C,UAAU,EAAE;MAAkB,CAAC,CAAC,CAACC,KAAK,CACzD1C,IAAI,CAACC,SAAS,CAAC;QAAEoC;MAAO,CAAC,CAC3B,CAAC;IACH;;IAEA;IACA,IAAI,CAACC,KAAK,IAAI,CAACA,KAAK,CAACE,KAAK,EAAE;MAC1B;IACF;IAEA,MAAMI,GAAG,GAAG/D,KAAK,CAACgE,MAAM,CAAC,IAAI,CAAC5D,QAAQ,EAAEoD,MAAM,CAAC;IAC/CxD,KAAK,CAACC,OAAO,CAACgE,OAAO,CAAC9D,GAAG,CAAC,IAAI,CAACC,QAAQ,CAAC;IAExC,OAAO2D,GAAG;EACZ;;EAEA;AACF;AACA;EACEG,wBAAwB,GAAG,MACzBjE,OAAgB,IAEE;IAClB;IACA;IACA;;IAEA;IACA,IAAIA,OAAO,CAACC,QAAQ,CAACiE,GAAG,CAAC,IAAI,CAAC/D,QAAQ,CAAC,EAAE;MACvC,OAAO,IAAI,CAACgE,UAAU,CAAC,IAAI,CAAC;IAC9B;;IAEA;IACA,OAAOC,OAAO,CAACC,OAAO,CAAC,CAAC;EAC1B,CAAC;EAEDC,oBAAoB,GAAGA,CACrBC,UAAkB,EAClBvE,OAA4B,KACV;IAClB;IACA;IACA;;IAEA;IACA,IAAI,IAAI,CAAC,CAACP,aAAa,KAAK8E,UAAU,EAAE;MACtCvE,OAAO,EAAEC,QAAQ,CAACC,GAAG,CAAC,IAAI,CAACC,QAAQ,CAAC;MACpC,OAAO,IAAI,CAACgE,UAAU,CAAC,IAAI,CAAC;IAC9B,CAAC,MAAM;MACL;MACA;MACA;MACA,OAAO,CAAC,YAAY;QAClB;QACA,MAAMxC,cAAc,GAAG,MAAM,IAAI,CAACtB,KAAK,CAACM,MAAM,CAACvB,iBAAiB,CAAC,CAC9DwC,gBAAgB,CAChBC,mBAAmB,CAAC,IAAI,CAAC,CAACpC,aAAa,CAAC;QAE3C,MAAMwC,OAAO,GAAGN,cAAc,CAACO,KAAK,GAAG,IAAI,CAAC,CAACvC,QAAQ,CAAC;QACtD,IAAI,CAACsC,OAAO,IAAIA,OAAO,CAACE,UAAU,KAAKoC,UAAU,EAAE;QAEnD,MAAMC,OAAO,GAAG,IAAI,CAACL,UAAU,CAAC,IAAI,CAAC;QACrCnE,OAAO,EAAEC,QAAQ,CAACC,GAAG,CAAC,IAAI,CAACC,QAAQ,CAAC;QACpC,OAAOqE,OAAO;MAChB,CAAC,EAAE,CAAC;IACN;EACF,CAAC;AACH;;AAEA;AACA;AACA;AACA,OAAO,SAASC,sBAAsBA,CACpCC,GAAa,EACgB;EAC7B,OAAOA,GAAG,CAACjD,IAAI,KAAK,cAAc;AACpC","ignoreList":[]}
|
|
@@ -100,10 +100,10 @@ export class ListQuery extends BaseListQuery {
|
|
|
100
100
|
this.sortingStrategy = new OrderBySortingStrategy(resultType.apiName, this.#orderBy);
|
|
101
101
|
}
|
|
102
102
|
|
|
103
|
-
// Fetch the data with pagination
|
|
103
|
+
// Fetch the data with pagination using effective pageSize (max of all subscribers)
|
|
104
104
|
const resp = await this.#objectSet.fetchPage({
|
|
105
105
|
$nextPageToken: this.nextPageToken,
|
|
106
|
-
$pageSize: this.
|
|
106
|
+
$pageSize: this.getEffectiveFetchPageSize(),
|
|
107
107
|
$includeRid: true,
|
|
108
108
|
// For now this keeps the shared test code from falling apart
|
|
109
109
|
// but shouldn't be needed ideally
|