@osdk/client 2.6.0-beta.9 → 2.7.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (107) hide show
  1. package/CHANGELOG.md +144 -0
  2. package/build/browser/MinimalClientContext.js.map +1 -1
  3. package/build/browser/createClient.js +1 -1
  4. package/build/browser/createClient.js.map +1 -1
  5. package/build/browser/createClient.test.js +19 -1
  6. package/build/browser/createClient.test.js.map +1 -1
  7. package/build/browser/createMinimalClient.js +2 -2
  8. package/build/browser/createMinimalClient.js.map +1 -1
  9. package/build/browser/object/aggregate.js +2 -1
  10. package/build/browser/object/aggregate.js.map +1 -1
  11. package/build/browser/object/fetchPage.js +8 -3
  12. package/build/browser/object/fetchPage.js.map +1 -1
  13. package/build/browser/objectSet/createObjectSet.js +3 -3
  14. package/build/browser/objectSet/createObjectSet.js.map +1 -1
  15. package/build/browser/observable/ObservableClient.js.map +1 -1
  16. package/build/browser/observable/internal/base-list/BaseListQuery.js +4 -2
  17. package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -1
  18. package/build/browser/observable/internal/getObjectTypesThatInvalidate.test.js +1 -1
  19. package/build/browser/observable/internal/getObjectTypesThatInvalidate.test.js.map +1 -1
  20. package/build/browser/observable/internal/list/ListQuery.js +7 -2
  21. package/build/browser/observable/internal/list/ListQuery.js.map +1 -1
  22. package/build/browser/observable/internal/list/ListQuery.test.js +277 -0
  23. package/build/browser/observable/internal/list/ListQuery.test.js.map +1 -0
  24. package/build/browser/observable/internal/list/ListQueryOptions.js.map +1 -1
  25. package/build/browser/observable/internal/objectset/ObjectSetQuery.js +7 -1
  26. package/build/browser/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
  27. package/build/browser/observable/internal/objectset/ObjectSetQueryOptions.js.map +1 -1
  28. package/build/browser/observable/internal/testUtils.js +3 -1
  29. package/build/browser/observable/internal/testUtils.js.map +1 -1
  30. package/build/browser/queries/applyQuery.js +7 -12
  31. package/build/browser/queries/applyQuery.js.map +1 -1
  32. package/build/browser/queries/types.js.map +1 -1
  33. package/build/browser/util/UserAgent.js +2 -2
  34. package/build/browser/util/extractObjectOrInterfaceType.js +1 -1
  35. package/build/browser/util/extractObjectOrInterfaceType.js.map +1 -1
  36. package/build/browser/util/extractObjectOrInterfaceType.test.js +2 -2
  37. package/build/browser/util/extractObjectOrInterfaceType.test.js.map +1 -1
  38. package/build/cjs/{Client-CF85LpFu.d.cts → Client-DaUJl7jZ.d.cts} +1 -1
  39. package/build/cjs/{chunk-DZE6IAUU.cjs → chunk-VDAI3GGL.cjs} +53 -32
  40. package/build/cjs/chunk-VDAI3GGL.cjs.map +1 -0
  41. package/build/cjs/{chunk-S4JPAF56.cjs → chunk-WQL7SQ7H.cjs} +76 -80
  42. package/build/cjs/chunk-WQL7SQ7H.cjs.map +1 -0
  43. package/build/cjs/{createClient-mOlFts15.d.cts → createClient-CPUYdECn.d.cts} +1 -1
  44. package/build/cjs/index.cjs +8 -8
  45. package/build/cjs/index.d.cts +2 -2
  46. package/build/cjs/public/internal.cjs +8 -8
  47. package/build/cjs/public/internal.d.cts +1 -1
  48. package/build/cjs/public/unstable-do-not-use.cjs +50 -36
  49. package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
  50. package/build/cjs/public/unstable-do-not-use.d.cts +33 -2
  51. package/build/esm/MinimalClientContext.js.map +1 -1
  52. package/build/esm/createClient.js +1 -1
  53. package/build/esm/createClient.js.map +1 -1
  54. package/build/esm/createClient.test.js +19 -1
  55. package/build/esm/createClient.test.js.map +1 -1
  56. package/build/esm/createMinimalClient.js +2 -2
  57. package/build/esm/createMinimalClient.js.map +1 -1
  58. package/build/esm/object/aggregate.js +2 -1
  59. package/build/esm/object/aggregate.js.map +1 -1
  60. package/build/esm/object/fetchPage.js +8 -3
  61. package/build/esm/object/fetchPage.js.map +1 -1
  62. package/build/esm/objectSet/createObjectSet.js +3 -3
  63. package/build/esm/objectSet/createObjectSet.js.map +1 -1
  64. package/build/esm/observable/ObservableClient.js.map +1 -1
  65. package/build/esm/observable/internal/base-list/BaseListQuery.js +4 -2
  66. package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -1
  67. package/build/esm/observable/internal/getObjectTypesThatInvalidate.test.js +1 -1
  68. package/build/esm/observable/internal/getObjectTypesThatInvalidate.test.js.map +1 -1
  69. package/build/esm/observable/internal/list/ListQuery.js +7 -2
  70. package/build/esm/observable/internal/list/ListQuery.js.map +1 -1
  71. package/build/esm/observable/internal/list/ListQuery.test.js +277 -0
  72. package/build/esm/observable/internal/list/ListQuery.test.js.map +1 -0
  73. package/build/esm/observable/internal/list/ListQueryOptions.js.map +1 -1
  74. package/build/esm/observable/internal/objectset/ObjectSetQuery.js +7 -1
  75. package/build/esm/observable/internal/objectset/ObjectSetQuery.js.map +1 -1
  76. package/build/esm/observable/internal/objectset/ObjectSetQueryOptions.js.map +1 -1
  77. package/build/esm/observable/internal/testUtils.js +3 -1
  78. package/build/esm/observable/internal/testUtils.js.map +1 -1
  79. package/build/esm/queries/applyQuery.js +7 -12
  80. package/build/esm/queries/applyQuery.js.map +1 -1
  81. package/build/esm/queries/types.js.map +1 -1
  82. package/build/esm/util/UserAgent.js +2 -2
  83. package/build/esm/util/extractObjectOrInterfaceType.js +1 -1
  84. package/build/esm/util/extractObjectOrInterfaceType.js.map +1 -1
  85. package/build/esm/util/extractObjectOrInterfaceType.test.js +2 -2
  86. package/build/esm/util/extractObjectOrInterfaceType.test.js.map +1 -1
  87. package/build/types/MinimalClientContext.d.ts +2 -2
  88. package/build/types/MinimalClientContext.d.ts.map +1 -1
  89. package/build/types/observable/ObservableClient.d.ts +16 -0
  90. package/build/types/observable/ObservableClient.d.ts.map +1 -1
  91. package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -1
  92. package/build/types/observable/internal/list/ListQuery.d.ts.map +1 -1
  93. package/build/types/observable/internal/list/ListQuery.test.d.ts +1 -0
  94. package/build/types/observable/internal/list/ListQuery.test.d.ts.map +1 -0
  95. package/build/types/observable/internal/list/ListQueryOptions.d.ts +1 -0
  96. package/build/types/observable/internal/list/ListQueryOptions.d.ts.map +1 -1
  97. package/build/types/observable/internal/objectset/ObjectSetQuery.d.ts.map +1 -1
  98. package/build/types/observable/internal/objectset/ObjectSetQueryOptions.d.ts +15 -0
  99. package/build/types/observable/internal/objectset/ObjectSetQueryOptions.d.ts.map +1 -1
  100. package/build/types/observable/internal/testUtils.d.ts +1 -1
  101. package/build/types/observable/internal/testUtils.d.ts.map +1 -1
  102. package/build/types/queries/applyQuery.d.ts.map +1 -1
  103. package/build/types/queries/types.d.ts +1 -1
  104. package/build/types/queries/types.d.ts.map +1 -1
  105. package/package.json +14 -14
  106. package/build/cjs/chunk-DZE6IAUU.cjs.map +0 -1
  107. package/build/cjs/chunk-S4JPAF56.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"fetchPage.js","names":["OntologiesV2","extractNamespace","addUserAgentAndRequestContextHeaders","extractObjectOrInterfaceType","extractRdpDefinition","resolveBaseObjectSetType","augment","type","properties","apiName","objectSetToSearchJsonV2","objectSet","expectedApiName","existingWhere","undefined","objectType","Error","interfaceType","where","value","resolveInterfaceObjectSet","interfaceTypeApiName","args","$includeAllBaseObjectProperties","objectSets","includeAllBaseObjectProperties","fetchStaticRidPage","client","rids","useSnapshot","requestBody","applyFetchArgs","objects","select","$select","excludeRid","$includeRid","snapshot","result","OntologyObjectSets","loadMultipleObjectTypes","osdkMetadata","ontologyRid","preview","Promise","resolve","data","objectFactory2","interfaceToObjectTypeMappings","nextPageToken","totalCount","fetchInterfacePage","$__UNSTABLE_useOldInterfaceApis","baseRequestBody","augmentedProperties","augmentedSharedPropertyTypes","otherInterfaceTypes","selectedObjectTypes","selectedSharedPropertyTypes","length","remapped","remapPropertyNames","Array","from","OntologyInterfaces","search","objectFactory","extractedInterfaceTypeApiName","resolvedInterfaceObjectSet","buildAndRemapRequestBody","branch","fetchPageInternal","fetchObjectPage","fetchPageWithErrorsInternal","e","error","fetchPage","fetchPageWithErrors","baseBody","objectOrInterface","propertyNames","objApiNamespace","map","name","fieldApiNamespace","fieldShortName","body","_client","$nextPageToken","pageToken","$pageSize","pageSize","orderBy","$orderBy","orderType","fields","orderByEntries","Object","entries","fieldNames","field","remappedFields","direction","index","ontologyProvider","getObjectDefinition","catch","r","load"],"sources":["fetchPage.ts"],"sourcesContent":["/*\n * Copyright 2023 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 Augment,\n Augments,\n FetchPageArgs,\n FetchPageResult,\n InterfaceDefinition,\n NullabilityAdherence,\n ObjectOrInterfaceDefinition,\n ObjectSetArgs,\n ObjectTypeDefinition,\n PropertyKeys,\n Result,\n} from \"@osdk/api\";\nimport type { PageSize, PageToken } from \"@osdk/foundry.core\";\nimport type {\n LoadObjectSetV2MultipleObjectTypesRequest,\n ObjectSet,\n OntologyObjectV2,\n SearchJsonQueryV2,\n SearchObjectsForInterfaceRequest,\n SearchOrderByV2,\n} from \"@osdk/foundry.ontologies\";\nimport * as OntologiesV2 from \"@osdk/foundry.ontologies\";\nimport { extractNamespace } from \"../internal/conversions/extractNamespace.js\";\nimport type { MinimalClient } from \"../MinimalClientContext.js\";\nimport { addUserAgentAndRequestContextHeaders } from \"../util/addUserAgentAndRequestContextHeaders.js\";\nimport { extractObjectOrInterfaceType } from \"../util/extractObjectOrInterfaceType.js\";\nimport { extractRdpDefinition } from \"../util/extractRdpDefinition.js\";\nimport { resolveBaseObjectSetType } from \"../util/objectSetUtils.js\";\n\nexport function augment<\n Q extends ObjectOrInterfaceDefinition,\n T extends PropertyKeys<Q>,\n>(\n type: Q,\n ...properties: T[]\n): Augment<Q, T> {\n return { [type.apiName]: properties } as any;\n}\n\n/** @internal */\nexport function objectSetToSearchJsonV2(\n objectSet: ObjectSet,\n expectedApiName: string,\n existingWhere: SearchJsonQueryV2 | undefined = undefined,\n): SearchJsonQueryV2 | undefined {\n if (objectSet.type === \"base\" || objectSet.type === \"interfaceBase\") {\n if (objectSet.type === \"base\" && objectSet.objectType !== expectedApiName) {\n throw new Error(\n `Expected objectSet.objectType to be ${expectedApiName}, but got ${objectSet.objectType}`,\n );\n }\n if (\n objectSet.type === \"interfaceBase\"\n && objectSet.interfaceType !== expectedApiName\n ) {\n throw new Error(\n `Expected objectSet.objectType to be ${expectedApiName}, but got ${objectSet.interfaceType}`,\n );\n }\n\n return existingWhere;\n }\n\n if (objectSet.type === \"filter\") {\n return objectSetToSearchJsonV2(\n objectSet.objectSet,\n expectedApiName,\n existingWhere == null ? objectSet.where : {\n type: \"and\",\n value: [existingWhere, objectSet.where],\n },\n );\n }\n\n throw new Error(`Unsupported objectSet type: ${objectSet.type}`);\n}\n\n/** @internal */\nexport function resolveInterfaceObjectSet(\n objectSet: ObjectSet,\n interfaceTypeApiName: string,\n args: FetchPageArgs<any, any, any, any, any, any>,\n): ObjectSet {\n return args?.$includeAllBaseObjectProperties\n ? {\n type: \"intersect\",\n objectSets: [objectSet, {\n type: \"interfaceBase\",\n interfaceType: interfaceTypeApiName,\n includeAllBaseObjectProperties: true,\n }],\n }\n : objectSet;\n}\n\n/** @internal */\nexport async function fetchStaticRidPage<\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n rids: readonly string[],\n args: FetchPageArgs<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n any,\n S,\n T\n >,\n useSnapshot: boolean = false,\n): Promise<\n FetchPageResult<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n S,\n T\n >\n> {\n const requestBody = await applyFetchArgs(\n args,\n {\n objectSet: {\n type: \"static\",\n objects: rids as string[],\n },\n select: ((args?.$select as string[] | undefined) ?? []),\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n } as LoadObjectSetV2MultipleObjectTypesRequest,\n client,\n { type: \"object\", apiName: \"\" },\n );\n\n const result = await OntologiesV2.OntologyObjectSets.loadMultipleObjectTypes(\n addUserAgentAndRequestContextHeaders(client, { osdkMetadata: undefined }),\n await client.ontologyRid,\n requestBody,\n { preview: true },\n );\n\n return Promise.resolve({\n data: await client.objectFactory2(\n client,\n result.data,\n undefined,\n {},\n !args.$includeRid,\n args.$select,\n false,\n result.interfaceToObjectTypeMappings,\n ),\n nextPageToken: result.nextPageToken,\n totalCount: result.totalCount,\n }) as unknown as Promise<\n FetchPageResult<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n S,\n T\n >\n >;\n}\n\nasync function fetchInterfacePage<\n Q extends InterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n interfaceType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet,\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T>> {\n if (args.$__UNSTABLE_useOldInterfaceApis) {\n const baseRequestBody: SearchObjectsForInterfaceRequest = {\n augmentedProperties: {},\n augmentedSharedPropertyTypes: {},\n otherInterfaceTypes: [],\n selectedObjectTypes: [],\n selectedSharedPropertyTypes: args.$select ? [...args.$select] : [],\n where: objectSetToSearchJsonV2(objectSet, interfaceType.apiName),\n };\n\n const requestBody = await applyFetchArgs(\n args,\n baseRequestBody,\n client,\n interfaceType,\n );\n\n if (requestBody.selectedSharedPropertyTypes.length > 0) {\n const remapped = remapPropertyNames(\n interfaceType,\n requestBody.selectedSharedPropertyTypes,\n );\n requestBody.selectedSharedPropertyTypes = Array.from(remapped);\n }\n\n const result = await OntologiesV2.OntologyInterfaces\n .search(\n addUserAgentAndRequestContextHeaders(client, interfaceType),\n await client.ontologyRid,\n interfaceType.apiName,\n requestBody,\n { preview: true },\n );\n\n result.data = await client.objectFactory(\n client,\n result.data as OntologyObjectV2[], // drop readonly\n interfaceType.apiName,\n !args.$includeRid,\n await extractRdpDefinition(client, objectSet),\n );\n return result as any;\n }\n\n const extractedInterfaceTypeApiName = (await extractObjectOrInterfaceType(\n client,\n objectSet,\n ))?.apiName ?? interfaceType.apiName;\n const resolvedInterfaceObjectSet = resolveInterfaceObjectSet(\n objectSet,\n extractedInterfaceTypeApiName,\n args,\n );\n const requestBody = await buildAndRemapRequestBody(\n args,\n {\n objectSet: resolvedInterfaceObjectSet,\n select: args?.$select ? [...args.$select] : [],\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n },\n client,\n interfaceType,\n );\n\n const result = await OntologiesV2.OntologyObjectSets.loadMultipleObjectTypes(\n addUserAgentAndRequestContextHeaders(client, interfaceType),\n await client.ontologyRid,\n requestBody,\n { preview: true, branch: client.branch },\n );\n\n return Promise.resolve({\n data: await client.objectFactory2(\n client,\n result.data,\n extractedInterfaceTypeApiName,\n {},\n !args.$includeRid,\n args.$select,\n false,\n result.interfaceToObjectTypeMappings,\n ),\n nextPageToken: result.nextPageToken,\n totalCount: result.totalCount,\n }) as unknown as Promise<FetchPageResult<Q, L, R, S, T>>;\n}\n\n/** @internal */\nexport async function fetchPageInternal<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L>,\n>(\n client: MinimalClient,\n objectType: Q,\n objectSet: ObjectSet,\n args: FetchPageArgs<Q, L, R, A, S, T, never, ORDER_BY_OPTIONS> = {},\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>> {\n if (objectType.type === \"interface\") {\n return await fetchInterfacePage(\n client,\n objectType,\n args as FetchPageArgs<\n InterfaceDefinition,\n L,\n R,\n A,\n S,\n T,\n never,\n ORDER_BY_OPTIONS\n >,\n objectSet,\n useSnapshot,\n ) as any; // fixme\n } else {\n return await fetchObjectPage(\n client,\n objectType,\n args as FetchPageArgs<\n ObjectTypeDefinition,\n L,\n R,\n A,\n S,\n T,\n never,\n ORDER_BY_OPTIONS\n >,\n objectSet,\n useSnapshot,\n ) as any; // fixme\n }\n}\n\n/** @internal */\nexport async function fetchPageWithErrorsInternal<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n objectSet: ObjectSet,\n args: FetchPageArgs<Q, L, R, A, S, T> = {},\n): Promise<Result<FetchPageResult<Q, L, R, S, T>>> {\n try {\n const result = await fetchPageInternal(client, objectType, objectSet, args);\n return { value: result };\n } catch (e) {\n if (e instanceof Error) {\n return { error: e };\n }\n return { error: e as Error };\n }\n}\n\n/**\n * @param client\n * @param objectType\n * @param args\n * @param objectSet\n * @returns\n * @internal\n */\nexport async function fetchPage<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet = resolveBaseObjectSetType(objectType),\n): Promise<FetchPageResult<Q, L, R, S, T>> {\n return fetchPageInternal(client, objectType, objectSet, args);\n}\n\n/** @internal */\nexport async function fetchPageWithErrors<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet = resolveBaseObjectSetType(objectType),\n): Promise<Result<FetchPageResult<Q, L, R, S, T>>> {\n return fetchPageWithErrorsInternal(client, objectType, objectSet, args);\n}\n\n/** @internal */\nasync function buildAndRemapRequestBody<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n RequestBody extends {\n orderBy?: SearchOrderByV2;\n pageToken?: PageToken;\n pageSize?: PageSize;\n select?: readonly string[];\n selectedSharedPropertyTypes?: readonly string[];\n },\n>(\n args: FetchPageArgs<Q, L, R, A, S, T>,\n baseBody: RequestBody,\n client: MinimalClient,\n objectType: Q,\n): Promise<RequestBody> {\n const requestBody = await applyFetchArgs(\n args,\n baseBody,\n client,\n objectType,\n );\n\n if (requestBody.select != null && requestBody.select.length > 0) {\n const remapped = remapPropertyNames(\n objectType,\n requestBody.select,\n );\n return { ...requestBody, select: remapped };\n }\n\n return requestBody;\n}\n\n/** @internal */\nexport function remapPropertyNames(\n objectOrInterface: ObjectOrInterfaceDefinition | undefined,\n propertyNames: readonly string[],\n): readonly string[] {\n if (objectOrInterface == null) {\n return propertyNames;\n }\n\n if (objectOrInterface.type === \"interface\") {\n const [objApiNamespace] = extractNamespace(objectOrInterface.apiName);\n return propertyNames.map(name => {\n const [fieldApiNamespace, fieldShortName] = extractNamespace(name);\n return (fieldApiNamespace == null && objApiNamespace != null)\n ? `${objApiNamespace}.${fieldShortName}`\n : name;\n });\n }\n\n return propertyNames;\n}\n\nasync function applyFetchArgs<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n X extends {\n orderBy?: SearchOrderByV2;\n pageToken?: PageToken;\n pageSize?: PageSize;\n },\n>(\n args: FetchPageArgs<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n ObjectSetArgs.OrderByOptions<any>\n >,\n body: X,\n _client: MinimalClient,\n objectType: Q,\n): Promise<X> {\n if (args?.$nextPageToken) {\n body.pageToken = args.$nextPageToken;\n }\n\n if (args?.$pageSize != null) {\n body.pageSize = args.$pageSize;\n }\n\n const orderBy = args?.$orderBy;\n if (orderBy) {\n if (orderBy === \"relevance\") {\n body.orderBy = { orderType: \"relevance\", fields: [] };\n } else {\n const orderByEntries = Object.entries(orderBy);\n const fieldNames = orderByEntries.map(([field]) => field);\n const remappedFields = remapPropertyNames(\n objectType,\n fieldNames,\n );\n\n body.orderBy = {\n fields: orderByEntries.map(([, direction], index) => ({\n field: remappedFields[index],\n direction,\n })),\n };\n }\n }\n\n return body;\n}\n\n/** @internal */\nexport async function fetchObjectPage<\n Q extends ObjectTypeDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L>,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, Augments, S, T, never, ORDER_BY_OPTIONS>,\n objectSet: ObjectSet,\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>> {\n // For simple object fetches, since we know the object type up front\n // we can parallelize network requests for loading metadata and loading the actual objects\n // In our object factory we await and block on loading the metadata, which if this call finishes, should already be cached on the client\n // We have an empty catch here so that if this call errors before we await later, we won't have an unhandled promise rejection that would crash the process\n // Swallowing the error is ok because we await the metadata load in the objectFactory later anyways which eventually bubbles up the error to the user\n void client.ontologyProvider.getObjectDefinition(objectType.apiName).catch(\n () => {},\n );\n\n const requestBody = await buildAndRemapRequestBody(\n args,\n {\n objectSet,\n select: args?.$select ? [...args.$select] : [],\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n },\n client,\n objectType,\n );\n\n const r = await OntologiesV2.OntologyObjectSets.load(\n addUserAgentAndRequestContextHeaders(client, objectType),\n await client.ontologyRid,\n requestBody,\n { branch: client.branch },\n );\n\n return Promise.resolve({\n data: await client.objectFactory(\n client,\n r.data as OntologyObjectV2[],\n undefined,\n undefined,\n await extractRdpDefinition(client, objectSet),\n args.$select,\n false,\n ),\n nextPageToken: r.nextPageToken,\n totalCount: r.totalCount,\n }) as unknown as Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>>;\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"fetchPage.js","names":["OntologiesV2","extractNamespace","addUserAgentAndRequestContextHeaders","extractObjectOrInterfaceType","extractRdpDefinition","resolveBaseObjectSetType","augment","type","properties","apiName","objectSetToSearchJsonV2","objectSet","expectedApiName","existingWhere","undefined","objectType","Error","interfaceType","where","value","resolveInterfaceObjectSet","interfaceTypeApiName","args","$includeAllBaseObjectProperties","objectSets","includeAllBaseObjectProperties","fetchStaticRidPage","client","rids","useSnapshot","requestBody","applyFetchArgs","objects","select","$select","excludeRid","$includeRid","snapshot","result","OntologyObjectSets","loadMultipleObjectTypes","osdkMetadata","ontologyRid","preview","transactionId","Promise","resolve","data","objectFactory2","interfaceToObjectTypeMappings","nextPageToken","totalCount","fetchInterfacePage","$__UNSTABLE_useOldInterfaceApis","baseRequestBody","augmentedProperties","augmentedSharedPropertyTypes","augmentedInterfacePropertyTypes","otherInterfaceTypes","selectedObjectTypes","selectedSharedPropertyTypes","selectedInterfacePropertyTypes","length","remapped","remapPropertyNames","Array","from","OntologyInterfaces","search","objectFactory","extractedInterfaceTypeApiName","resolvedInterfaceObjectSet","buildAndRemapRequestBody","branch","fetchPageInternal","fetchObjectPage","fetchPageWithErrorsInternal","e","error","fetchPage","fetchPageWithErrors","baseBody","objectOrInterface","propertyNames","objApiNamespace","map","name","fieldApiNamespace","fieldShortName","body","_client","$nextPageToken","pageToken","$pageSize","pageSize","orderBy","$orderBy","orderType","fields","orderByEntries","Object","entries","fieldNames","field","remappedFields","direction","index","ontologyProvider","getObjectDefinition","catch","r","load"],"sources":["fetchPage.ts"],"sourcesContent":["/*\n * Copyright 2023 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 Augment,\n Augments,\n FetchPageArgs,\n FetchPageResult,\n InterfaceDefinition,\n NullabilityAdherence,\n ObjectOrInterfaceDefinition,\n ObjectSetArgs,\n ObjectTypeDefinition,\n PropertyKeys,\n Result,\n} from \"@osdk/api\";\nimport type { PageSize, PageToken } from \"@osdk/foundry.core\";\nimport type {\n LoadObjectSetV2MultipleObjectTypesRequest,\n ObjectSet,\n OntologyObjectV2,\n SearchJsonQueryV2,\n SearchObjectsForInterfaceRequest,\n SearchOrderByV2,\n} from \"@osdk/foundry.ontologies\";\nimport * as OntologiesV2 from \"@osdk/foundry.ontologies\";\nimport { extractNamespace } from \"../internal/conversions/extractNamespace.js\";\nimport type { MinimalClient } from \"../MinimalClientContext.js\";\nimport { addUserAgentAndRequestContextHeaders } from \"../util/addUserAgentAndRequestContextHeaders.js\";\nimport { extractObjectOrInterfaceType } from \"../util/extractObjectOrInterfaceType.js\";\nimport { extractRdpDefinition } from \"../util/extractRdpDefinition.js\";\nimport { resolveBaseObjectSetType } from \"../util/objectSetUtils.js\";\n\nexport function augment<\n Q extends ObjectOrInterfaceDefinition,\n T extends PropertyKeys<Q>,\n>(\n type: Q,\n ...properties: T[]\n): Augment<Q, T> {\n return { [type.apiName]: properties } as any;\n}\n\n/** @internal */\nexport function objectSetToSearchJsonV2(\n objectSet: ObjectSet,\n expectedApiName: string,\n existingWhere: SearchJsonQueryV2 | undefined = undefined,\n): SearchJsonQueryV2 | undefined {\n if (objectSet.type === \"base\" || objectSet.type === \"interfaceBase\") {\n if (objectSet.type === \"base\" && objectSet.objectType !== expectedApiName) {\n throw new Error(\n `Expected objectSet.objectType to be ${expectedApiName}, but got ${objectSet.objectType}`,\n );\n }\n if (\n objectSet.type === \"interfaceBase\"\n && objectSet.interfaceType !== expectedApiName\n ) {\n throw new Error(\n `Expected objectSet.objectType to be ${expectedApiName}, but got ${objectSet.interfaceType}`,\n );\n }\n\n return existingWhere;\n }\n\n if (objectSet.type === \"filter\") {\n return objectSetToSearchJsonV2(\n objectSet.objectSet,\n expectedApiName,\n existingWhere == null ? objectSet.where : {\n type: \"and\",\n value: [existingWhere, objectSet.where],\n },\n );\n }\n\n throw new Error(`Unsupported objectSet type: ${objectSet.type}`);\n}\n\n/** @internal */\nexport function resolveInterfaceObjectSet(\n objectSet: ObjectSet,\n interfaceTypeApiName: string,\n args: FetchPageArgs<any, any, any, any, any, any>,\n): ObjectSet {\n return args?.$includeAllBaseObjectProperties\n ? {\n type: \"intersect\",\n objectSets: [objectSet, {\n type: \"interfaceBase\",\n interfaceType: interfaceTypeApiName,\n includeAllBaseObjectProperties: true,\n }],\n }\n : objectSet;\n}\n\n/** @internal */\nexport async function fetchStaticRidPage<\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n rids: readonly string[],\n args: FetchPageArgs<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n any,\n S,\n T\n >,\n useSnapshot: boolean = false,\n): Promise<\n FetchPageResult<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n S,\n T\n >\n> {\n const requestBody = await applyFetchArgs(\n args,\n {\n objectSet: {\n type: \"static\",\n objects: rids as string[],\n },\n select: ((args?.$select as string[] | undefined) ?? []),\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n } as LoadObjectSetV2MultipleObjectTypesRequest,\n client,\n { type: \"object\", apiName: \"\" },\n );\n\n const result = await OntologiesV2.OntologyObjectSets.loadMultipleObjectTypes(\n addUserAgentAndRequestContextHeaders(client, { osdkMetadata: undefined }),\n await client.ontologyRid,\n requestBody,\n { preview: true, transactionId: client.transactionId },\n );\n\n return Promise.resolve({\n data: await client.objectFactory2(\n client,\n result.data,\n undefined,\n {},\n !args.$includeRid,\n args.$select,\n false,\n result.interfaceToObjectTypeMappings,\n ),\n nextPageToken: result.nextPageToken,\n totalCount: result.totalCount,\n }) as unknown as Promise<\n FetchPageResult<\n ObjectOrInterfaceDefinition,\n PropertyKeys<ObjectOrInterfaceDefinition>,\n R,\n S,\n T\n >\n >;\n}\n\nasync function fetchInterfacePage<\n Q extends InterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n interfaceType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet,\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T>> {\n if (args.$__UNSTABLE_useOldInterfaceApis) {\n const baseRequestBody: SearchObjectsForInterfaceRequest = {\n augmentedProperties: {},\n augmentedSharedPropertyTypes: {},\n augmentedInterfacePropertyTypes: {},\n otherInterfaceTypes: [],\n selectedObjectTypes: [],\n selectedSharedPropertyTypes: args.$select ? [...args.$select] : [],\n selectedInterfacePropertyTypes: [],\n where: objectSetToSearchJsonV2(objectSet, interfaceType.apiName),\n };\n\n const requestBody = await applyFetchArgs(\n args,\n baseRequestBody,\n client,\n interfaceType,\n );\n\n if (requestBody.selectedSharedPropertyTypes.length > 0) {\n const remapped = remapPropertyNames(\n interfaceType,\n requestBody.selectedSharedPropertyTypes,\n );\n requestBody.selectedSharedPropertyTypes = Array.from(remapped);\n }\n\n const result = await OntologiesV2.OntologyInterfaces\n .search(\n addUserAgentAndRequestContextHeaders(client, interfaceType),\n await client.ontologyRid,\n interfaceType.apiName,\n requestBody,\n { preview: true },\n );\n\n result.data = await client.objectFactory(\n client,\n result.data as OntologyObjectV2[], // drop readonly\n interfaceType.apiName,\n !args.$includeRid,\n await extractRdpDefinition(client, objectSet),\n );\n return result as any;\n }\n\n const extractedInterfaceTypeApiName = (await extractObjectOrInterfaceType(\n client,\n objectSet,\n ))?.apiName ?? interfaceType.apiName;\n const resolvedInterfaceObjectSet = resolveInterfaceObjectSet(\n objectSet,\n extractedInterfaceTypeApiName,\n args,\n );\n const requestBody = await buildAndRemapRequestBody(\n args,\n {\n objectSet: resolvedInterfaceObjectSet,\n select: args?.$select ? [...args.$select] : [],\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n },\n client,\n interfaceType,\n );\n\n const result = await OntologiesV2.OntologyObjectSets.loadMultipleObjectTypes(\n addUserAgentAndRequestContextHeaders(client, interfaceType),\n await client.ontologyRid,\n requestBody,\n {\n preview: true,\n branch: client.branch,\n transactionId: client.transactionId,\n },\n );\n\n return Promise.resolve({\n data: await client.objectFactory2(\n client,\n result.data,\n extractedInterfaceTypeApiName,\n {},\n !args.$includeRid,\n args.$select,\n false,\n result.interfaceToObjectTypeMappings,\n ),\n nextPageToken: result.nextPageToken,\n totalCount: result.totalCount,\n }) as unknown as Promise<FetchPageResult<Q, L, R, S, T>>;\n}\n\n/** @internal */\nexport async function fetchPageInternal<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L>,\n>(\n client: MinimalClient,\n objectType: Q,\n objectSet: ObjectSet,\n args: FetchPageArgs<Q, L, R, A, S, T, never, ORDER_BY_OPTIONS> = {},\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>> {\n if (objectType.type === \"interface\") {\n return await fetchInterfacePage(\n client,\n objectType,\n args as FetchPageArgs<\n InterfaceDefinition,\n L,\n R,\n A,\n S,\n T,\n never,\n ORDER_BY_OPTIONS\n >,\n objectSet,\n useSnapshot,\n ) as any; // fixme\n } else {\n return await fetchObjectPage(\n client,\n objectType,\n args as FetchPageArgs<\n ObjectTypeDefinition,\n L,\n R,\n A,\n S,\n T,\n never,\n ORDER_BY_OPTIONS\n >,\n objectSet,\n useSnapshot,\n ) as any; // fixme\n }\n}\n\n/** @internal */\nexport async function fetchPageWithErrorsInternal<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n objectSet: ObjectSet,\n args: FetchPageArgs<Q, L, R, A, S, T> = {},\n): Promise<Result<FetchPageResult<Q, L, R, S, T>>> {\n try {\n const result = await fetchPageInternal(client, objectType, objectSet, args);\n return { value: result };\n } catch (e) {\n if (e instanceof Error) {\n return { error: e };\n }\n return { error: e as Error };\n }\n}\n\n/**\n * @param client\n * @param objectType\n * @param args\n * @param objectSet\n * @returns\n * @internal\n */\nexport async function fetchPage<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet = resolveBaseObjectSetType(objectType),\n): Promise<FetchPageResult<Q, L, R, S, T>> {\n return fetchPageInternal(client, objectType, objectSet, args);\n}\n\n/** @internal */\nexport async function fetchPageWithErrors<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, any, S, T>,\n objectSet: ObjectSet = resolveBaseObjectSetType(objectType),\n): Promise<Result<FetchPageResult<Q, L, R, S, T>>> {\n return fetchPageWithErrorsInternal(client, objectType, objectSet, args);\n}\n\n/** @internal */\nasync function buildAndRemapRequestBody<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n RequestBody extends {\n orderBy?: SearchOrderByV2;\n pageToken?: PageToken;\n pageSize?: PageSize;\n select?: readonly string[];\n selectedSharedPropertyTypes?: readonly string[];\n },\n>(\n args: FetchPageArgs<Q, L, R, A, S, T>,\n baseBody: RequestBody,\n client: MinimalClient,\n objectType: Q,\n): Promise<RequestBody> {\n const requestBody = await applyFetchArgs(\n args,\n baseBody,\n client,\n objectType,\n );\n\n if (requestBody.select != null && requestBody.select.length > 0) {\n const remapped = remapPropertyNames(\n objectType,\n requestBody.select,\n );\n return { ...requestBody, select: remapped };\n }\n\n return requestBody;\n}\n\n/** @internal */\nexport function remapPropertyNames(\n objectOrInterface: ObjectOrInterfaceDefinition | undefined,\n propertyNames: readonly string[],\n): readonly string[] {\n if (objectOrInterface == null) {\n return propertyNames;\n }\n\n if (objectOrInterface.type === \"interface\") {\n const [objApiNamespace] = extractNamespace(objectOrInterface.apiName);\n return propertyNames.map(name => {\n const [fieldApiNamespace, fieldShortName] = extractNamespace(name);\n return (fieldApiNamespace == null && objApiNamespace != null)\n ? `${objApiNamespace}.${fieldShortName}`\n : name;\n });\n }\n\n return propertyNames;\n}\n\nasync function applyFetchArgs<\n Q extends ObjectOrInterfaceDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n A extends Augments,\n S extends NullabilityAdherence,\n T extends boolean,\n X extends {\n orderBy?: SearchOrderByV2;\n pageToken?: PageToken;\n pageSize?: PageSize;\n },\n>(\n args: FetchPageArgs<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n ObjectSetArgs.OrderByOptions<any>\n >,\n body: X,\n _client: MinimalClient,\n objectType: Q,\n): Promise<X> {\n if (args?.$nextPageToken) {\n body.pageToken = args.$nextPageToken;\n }\n\n if (args?.$pageSize != null) {\n body.pageSize = args.$pageSize;\n }\n\n const orderBy = args?.$orderBy;\n if (orderBy) {\n if (orderBy === \"relevance\") {\n body.orderBy = { orderType: \"relevance\", fields: [] };\n } else {\n const orderByEntries = Object.entries(orderBy);\n const fieldNames = orderByEntries.map(([field]) => field);\n const remappedFields = remapPropertyNames(\n objectType,\n fieldNames,\n );\n\n body.orderBy = {\n fields: orderByEntries.map(([, direction], index) => ({\n field: remappedFields[index],\n direction,\n })),\n };\n }\n }\n\n return body;\n}\n\n/** @internal */\nexport async function fetchObjectPage<\n Q extends ObjectTypeDefinition,\n L extends PropertyKeys<Q>,\n R extends boolean,\n S extends NullabilityAdherence,\n T extends boolean,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L>,\n>(\n client: MinimalClient,\n objectType: Q,\n args: FetchPageArgs<Q, L, R, Augments, S, T, never, ORDER_BY_OPTIONS>,\n objectSet: ObjectSet,\n useSnapshot: boolean = false,\n): Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>> {\n // For simple object fetches, since we know the object type up front\n // we can parallelize network requests for loading metadata and loading the actual objects\n // In our object factory we await and block on loading the metadata, which if this call finishes, should already be cached on the client\n // We have an empty catch here so that if this call errors before we await later, we won't have an unhandled promise rejection that would crash the process\n // Swallowing the error is ok because we await the metadata load in the objectFactory later anyways which eventually bubbles up the error to the user\n void client.ontologyProvider.getObjectDefinition(objectType.apiName).catch(\n () => {},\n );\n\n const requestBody = await buildAndRemapRequestBody(\n args,\n {\n objectSet,\n select: args?.$select ? [...args.$select] : [],\n excludeRid: !args?.$includeRid,\n snapshot: useSnapshot,\n },\n client,\n objectType,\n );\n\n const r = await OntologiesV2.OntologyObjectSets.load(\n addUserAgentAndRequestContextHeaders(client, objectType),\n await client.ontologyRid,\n requestBody,\n { branch: client.branch, transactionId: client.transactionId },\n );\n\n return Promise.resolve({\n data: await client.objectFactory(\n client,\n r.data as OntologyObjectV2[],\n undefined,\n undefined,\n await extractRdpDefinition(client, objectSet),\n args.$select,\n false,\n ),\n nextPageToken: r.nextPageToken,\n totalCount: r.totalCount,\n }) as unknown as Promise<FetchPageResult<Q, L, R, S, T, ORDER_BY_OPTIONS>>;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -147,10 +147,10 @@ export function createObjectSet(objectType, clientCtx, objectSet = resolveBaseOb
147
147
  objectSet: objectSet
148
148
  });
149
149
  },
150
- asType: objectTypeDef => {
151
- const existingMapping = clientCtx.asTypeInterfaceOrObjectMapping[objectTypeDef.apiName];
150
+ narrowToType: objectTypeDef => {
151
+ const existingMapping = clientCtx.narrowTypeInterfaceOrObjectMapping[objectTypeDef.apiName];
152
152
  !(!existingMapping || existingMapping === objectTypeDef.type) ? process.env.NODE_ENV !== "production" ? invariant(false, `${objectTypeDef.apiName} was previously used as an ${existingMapping}, but now used as a ${objectTypeDef.type}.`) : invariant(false) : void 0;
153
- clientCtx.asTypeInterfaceOrObjectMapping[objectTypeDef.apiName] = objectTypeDef.type;
153
+ clientCtx.narrowTypeInterfaceOrObjectMapping[objectTypeDef.apiName] = objectTypeDef.type;
154
154
  return clientCtx.objectSetFactory(objectTypeDef, clientCtx, {
155
155
  type: "asType",
156
156
  objectSet: objectSet,
@@ -1 +1 @@
1
- {"version":3,"file":"createObjectSet.js","names":["invariant","createWithPropertiesObjectSet","modernToLegacyWhereClause","aggregate","fetchPageInternal","fetchPageWithErrorsInternal","fetchSingle","fetchSingleWithErrors","augmentRequestContext","resolveBaseObjectSetType","isWireObjectSet","ObjectSetListenerWebsocket","isObjectTypeDefinition","def","type","isObjectSet","o","objectSetDefinitions","get","getWireObjectSet","objectSet","WeakMap","createObjectSet","objectType","clientCtx","base","bind","globalThis","finalMethodCall","fetchPage","fetchPageWithErrors","where","clause","objectSetFactory","pivotTo","createSearchAround","union","objectSets","map","os","intersect","subtract","nearestNeighbors","query","numNeighbors","property","nearestNeighborsQuery","isTextQuery","propertyIdentifier","apiName","asyncIter","args","$nextPageToken","undefined","result","$pageSize","nextPageToken","obj","data","fetchOne","primaryKey","options","createWithPk","fetchOneWithErrors","subscribe","listener","opts","pendingSubscribe","getInstance","properties","unsubscribe","withProperties","definitionMap","Map","derivedProperties","key","Object","keys","derivedPropertyDefinition","asType","objectTypeDef","existingMapping","asTypeInterfaceOrObjectMapping","process","env","NODE_ENV","entityType","$objectSetInternals","link","interfaceLink","set","objDef","ontologyProvider","getObjectDefinition","withPk","field","primaryKeyApiName","value"],"sources":["createObjectSet.ts"],"sourcesContent":["/*\n * Copyright 2023 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 AsyncIterArgs,\n Augments,\n FetchPageResult,\n InterfaceDefinition,\n LinkedType,\n LinkNames,\n NullabilityAdherence,\n ObjectOrInterfaceDefinition,\n ObjectSet,\n ObjectSetArgs,\n ObjectTypeDefinition,\n Osdk,\n PrimaryKeyType,\n PropertyKeys,\n Result,\n SelectArg,\n SingleOsdkResult,\n} from \"@osdk/api\";\nimport type { MinimalObjectSet } from \"@osdk/api/unstable\";\nimport type {\n DerivedPropertyDefinition,\n ObjectSet as WireObjectSet,\n PropertyApiName,\n} from \"@osdk/foundry.ontologies\";\nimport invariant from \"tiny-invariant\";\nimport { createWithPropertiesObjectSet } from \"../derivedProperties/createWithPropertiesObjectSet.js\";\nimport { modernToLegacyWhereClause } from \"../internal/conversions/modernToLegacyWhereClause.js\";\nimport type { MinimalClient } from \"../MinimalClientContext.js\";\nimport { aggregate } from \"../object/aggregate.js\";\nimport {\n fetchPageInternal,\n fetchPageWithErrorsInternal,\n} from \"../object/fetchPage.js\";\nimport { fetchSingle, fetchSingleWithErrors } from \"../object/fetchSingle.js\";\nimport { augmentRequestContext } from \"../util/augmentRequestContext.js\";\nimport { resolveBaseObjectSetType } from \"../util/objectSetUtils.js\";\nimport { isWireObjectSet } from \"../util/WireObjectSet.js\";\nimport { ObjectSetListenerWebsocket } from \"./ObjectSetListenerWebsocket.js\";\n\nfunction isObjectTypeDefinition(\n def: ObjectOrInterfaceDefinition,\n): def is ObjectTypeDefinition {\n return def.type === \"object\";\n}\n\n/* @internal */\nexport function isObjectSet(o: any): o is ObjectSet<any> {\n return o != null && typeof o === \"object\"\n && isWireObjectSet(objectSetDefinitions.get(o));\n}\n\n/** @internal */\nexport function getWireObjectSet(\n objectSet: ObjectSet<any> | MinimalObjectSet<any>,\n): WireObjectSet {\n return objectSetDefinitions.get(objectSet)!;\n}\n\n/** @internal exported for internal use only */\nexport const objectSetDefinitions = new WeakMap<\n any,\n WireObjectSet\n>();\n\n/** @internal */\nexport function createObjectSet<Q extends ObjectOrInterfaceDefinition>(\n objectType: Q,\n clientCtx: MinimalClient,\n objectSet: WireObjectSet = resolveBaseObjectSetType(objectType),\n): ObjectSet<Q> {\n const base: ObjectSet<Q> = {\n aggregate: (aggregate<Q, any>).bind(\n globalThis,\n augmentRequestContext(clientCtx, _ => ({ finalMethodCall: \"aggregate\" })),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"aggregate\"],\n\n fetchPage: fetchPageInternal.bind(\n globalThis,\n augmentRequestContext(clientCtx, _ => ({ finalMethodCall: \"fetchPage\" })),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"fetchPage\"],\n\n fetchPageWithErrors: fetchPageWithErrorsInternal.bind(\n globalThis,\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchPageWithErrors\" }),\n ),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"fetchPageWithErrors\"],\n\n where: (clause) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"filter\",\n objectSet: objectSet,\n where: modernToLegacyWhereClause(clause, objectType),\n });\n },\n\n pivotTo: function<L extends LinkNames<Q>>(\n type: L,\n ): ObjectSet<LinkedType<Q, L>> {\n return createSearchAround(type)();\n },\n\n union: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"union\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n intersect: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"intersect\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n subtract: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"subtract\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n nearestNeighbors: (query, numNeighbors, property) => {\n const nearestNeighborsQuery = isTextQuery(query)\n ? { \"type\": \"text\" as const, \"value\": query }\n : { \"type\": \"vector\" as const, \"value\": query };\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n {\n type: \"nearestNeighbors\",\n objectSet,\n propertyIdentifier: {\n type: \"property\",\n apiName: property as PropertyApiName,\n },\n numNeighbors,\n query: nearestNeighborsQuery,\n },\n ) as ObjectSet<Q>;\n },\n\n asyncIter: async function*<\n L extends PropertyKeys<Q>,\n R extends boolean,\n const A extends Augments,\n S extends NullabilityAdherence = NullabilityAdherence.Default,\n T extends boolean = false,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L> = never,\n >(\n args?: AsyncIterArgs<Q, L, R, A, S, T, never, ORDER_BY_OPTIONS>,\n ): AsyncIterableIterator<\n SingleOsdkResult<Q, L, R, S, {}, T, ORDER_BY_OPTIONS>\n > {\n let $nextPageToken: string | undefined = undefined;\n do {\n const result: FetchPageResult<\n Q,\n L,\n R,\n S,\n T,\n ORDER_BY_OPTIONS\n > = await fetchPageInternal(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"asyncIter\" }),\n ),\n objectType,\n objectSet,\n { ...args, $pageSize: 10000, $nextPageToken },\n true,\n );\n $nextPageToken = result.nextPageToken;\n\n for (const obj of result.data) {\n yield obj as SingleOsdkResult<Q, L, R, S, {}, T, ORDER_BY_OPTIONS>;\n }\n } while ($nextPageToken != null);\n },\n\n fetchOne: (isObjectTypeDefinition(objectType)\n ? async <A extends SelectArg<Q>>(\n primaryKey: PrimaryKeyType<Q>,\n options: A,\n ) => {\n return await fetchSingle(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchOne\" }),\n ),\n objectType,\n options,\n await createWithPk(\n clientCtx,\n objectType,\n objectSet,\n primaryKey,\n ),\n ) as Osdk<Q>;\n }\n : undefined) as ObjectSet<Q>[\"fetchOne\"],\n\n fetchOneWithErrors: (isObjectTypeDefinition(objectType)\n ? async <A extends SelectArg<Q>>(\n primaryKey: Q extends ObjectTypeDefinition ? PrimaryKeyType<Q>\n : never,\n options: A,\n ) => {\n return await fetchSingleWithErrors(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchOneWithErrors\" }),\n ),\n objectType,\n options,\n await createWithPk(\n clientCtx,\n objectType,\n objectSet,\n primaryKey,\n ),\n ) as Result<Osdk<Q>>;\n }\n : undefined) as ObjectSet<Q>[\"fetchOneWithErrors\"],\n\n subscribe: (\n listener,\n opts,\n ) => {\n const pendingSubscribe = ObjectSetListenerWebsocket.getInstance(\n clientCtx,\n ).subscribe(\n objectType,\n objectSet,\n listener,\n opts?.properties,\n );\n\n return { unsubscribe: async () => (await pendingSubscribe)() };\n },\n\n withProperties: (clause) => {\n const definitionMap = new Map<any, DerivedPropertyDefinition>();\n\n const derivedProperties: Record<string, DerivedPropertyDefinition> = {};\n for (const key of Object.keys(clause)) {\n const derivedPropertyDefinition = clause\n [key](createWithPropertiesObjectSet(\n objectType,\n { type: \"methodInput\" },\n definitionMap,\n true,\n ));\n derivedProperties[key] = definitionMap.get(\n derivedPropertyDefinition,\n )!;\n }\n\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n {\n type: \"withProperties\",\n derivedProperties: derivedProperties,\n objectSet: objectSet,\n },\n );\n },\n\n asType: (objectTypeDef: ObjectTypeDefinition | InterfaceDefinition) => {\n const existingMapping =\n clientCtx.asTypeInterfaceOrObjectMapping[objectTypeDef.apiName];\n invariant(\n !existingMapping || existingMapping === objectTypeDef.type,\n `${objectTypeDef.apiName} was previously used as an ${existingMapping}, but now used as a ${objectTypeDef.type}.`,\n );\n clientCtx.asTypeInterfaceOrObjectMapping[objectTypeDef.apiName] =\n objectTypeDef.type;\n\n return clientCtx.objectSetFactory(\n objectTypeDef,\n clientCtx,\n {\n type: \"asType\",\n objectSet: objectSet,\n entityType: objectTypeDef.apiName,\n },\n );\n },\n\n $objectSetInternals: {\n def: objectType,\n },\n };\n\n function createSearchAround<L extends LinkNames<Q>>(link: L) {\n return () => {\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n objectType.type === \"object\"\n ? {\n type: \"searchAround\",\n objectSet,\n link,\n }\n : {\n type: \"interfaceLinkSearchAround\",\n objectSet,\n interfaceLink: link,\n },\n );\n };\n }\n\n objectSetDefinitions.set(base, objectSet);\n\n // we are using a type assertion because the marker symbol defined in BaseObjectSet isn't actually used\n // at runtime.\n return base as ObjectSet<Q>;\n}\n\nasync function createWithPk(\n clientCtx: MinimalClient,\n objectType: ObjectTypeDefinition,\n objectSet: WireObjectSet,\n primaryKey: PrimaryKeyType<ObjectTypeDefinition>,\n) {\n const objDef = await clientCtx.ontologyProvider.getObjectDefinition(\n objectType.apiName,\n );\n\n const withPk: WireObjectSet = {\n type: \"filter\",\n objectSet: objectSet,\n where: {\n type: \"eq\",\n field: objDef.primaryKeyApiName,\n value: primaryKey,\n },\n };\n return withPk;\n}\n\nfunction isTextQuery(query: string | number[]): query is string {\n return typeof query === \"string\";\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"createObjectSet.js","names":["invariant","createWithPropertiesObjectSet","modernToLegacyWhereClause","aggregate","fetchPageInternal","fetchPageWithErrorsInternal","fetchSingle","fetchSingleWithErrors","augmentRequestContext","resolveBaseObjectSetType","isWireObjectSet","ObjectSetListenerWebsocket","isObjectTypeDefinition","def","type","isObjectSet","o","objectSetDefinitions","get","getWireObjectSet","objectSet","WeakMap","createObjectSet","objectType","clientCtx","base","bind","globalThis","finalMethodCall","fetchPage","fetchPageWithErrors","where","clause","objectSetFactory","pivotTo","createSearchAround","union","objectSets","map","os","intersect","subtract","nearestNeighbors","query","numNeighbors","property","nearestNeighborsQuery","isTextQuery","propertyIdentifier","apiName","asyncIter","args","$nextPageToken","undefined","result","$pageSize","nextPageToken","obj","data","fetchOne","primaryKey","options","createWithPk","fetchOneWithErrors","subscribe","listener","opts","pendingSubscribe","getInstance","properties","unsubscribe","withProperties","definitionMap","Map","derivedProperties","key","Object","keys","derivedPropertyDefinition","narrowToType","objectTypeDef","existingMapping","narrowTypeInterfaceOrObjectMapping","process","env","NODE_ENV","entityType","$objectSetInternals","link","interfaceLink","set","objDef","ontologyProvider","getObjectDefinition","withPk","field","primaryKeyApiName","value"],"sources":["createObjectSet.ts"],"sourcesContent":["/*\n * Copyright 2023 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 AsyncIterArgs,\n Augments,\n FetchPageResult,\n InterfaceDefinition,\n LinkedType,\n LinkNames,\n NullabilityAdherence,\n ObjectOrInterfaceDefinition,\n ObjectSet,\n ObjectSetArgs,\n ObjectTypeDefinition,\n Osdk,\n PrimaryKeyType,\n PropertyKeys,\n Result,\n SelectArg,\n SingleOsdkResult,\n} from \"@osdk/api\";\nimport type { MinimalObjectSet } from \"@osdk/api/unstable\";\nimport type {\n DerivedPropertyDefinition,\n ObjectSet as WireObjectSet,\n PropertyApiName,\n} from \"@osdk/foundry.ontologies\";\nimport invariant from \"tiny-invariant\";\nimport { createWithPropertiesObjectSet } from \"../derivedProperties/createWithPropertiesObjectSet.js\";\nimport { modernToLegacyWhereClause } from \"../internal/conversions/modernToLegacyWhereClause.js\";\nimport type { MinimalClient } from \"../MinimalClientContext.js\";\nimport { aggregate } from \"../object/aggregate.js\";\nimport {\n fetchPageInternal,\n fetchPageWithErrorsInternal,\n} from \"../object/fetchPage.js\";\nimport { fetchSingle, fetchSingleWithErrors } from \"../object/fetchSingle.js\";\nimport { augmentRequestContext } from \"../util/augmentRequestContext.js\";\nimport { resolveBaseObjectSetType } from \"../util/objectSetUtils.js\";\nimport { isWireObjectSet } from \"../util/WireObjectSet.js\";\nimport { ObjectSetListenerWebsocket } from \"./ObjectSetListenerWebsocket.js\";\n\nfunction isObjectTypeDefinition(\n def: ObjectOrInterfaceDefinition,\n): def is ObjectTypeDefinition {\n return def.type === \"object\";\n}\n\n/* @internal */\nexport function isObjectSet(o: any): o is ObjectSet<any> {\n return o != null && typeof o === \"object\"\n && isWireObjectSet(objectSetDefinitions.get(o));\n}\n\n/** @internal */\nexport function getWireObjectSet(\n objectSet: ObjectSet<any> | MinimalObjectSet<any>,\n): WireObjectSet {\n return objectSetDefinitions.get(objectSet)!;\n}\n\n/** @internal exported for internal use only */\nexport const objectSetDefinitions = new WeakMap<\n any,\n WireObjectSet\n>();\n\n/** @internal */\nexport function createObjectSet<Q extends ObjectOrInterfaceDefinition>(\n objectType: Q,\n clientCtx: MinimalClient,\n objectSet: WireObjectSet = resolveBaseObjectSetType(objectType),\n): ObjectSet<Q> {\n const base: ObjectSet<Q> = {\n aggregate: (aggregate<Q, any>).bind(\n globalThis,\n augmentRequestContext(clientCtx, _ => ({ finalMethodCall: \"aggregate\" })),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"aggregate\"],\n\n fetchPage: fetchPageInternal.bind(\n globalThis,\n augmentRequestContext(clientCtx, _ => ({ finalMethodCall: \"fetchPage\" })),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"fetchPage\"],\n\n fetchPageWithErrors: fetchPageWithErrorsInternal.bind(\n globalThis,\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchPageWithErrors\" }),\n ),\n objectType,\n objectSet,\n ) as ObjectSet<Q>[\"fetchPageWithErrors\"],\n\n where: (clause) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"filter\",\n objectSet: objectSet,\n where: modernToLegacyWhereClause(clause, objectType),\n });\n },\n\n pivotTo: function<L extends LinkNames<Q>>(\n type: L,\n ): ObjectSet<LinkedType<Q, L>> {\n return createSearchAround(type)();\n },\n\n union: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"union\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n intersect: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"intersect\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n subtract: (...objectSets) => {\n return clientCtx.objectSetFactory(objectType, clientCtx, {\n type: \"subtract\",\n objectSets: [\n objectSet,\n ...objectSets.map(os => objectSetDefinitions.get(os)!),\n ],\n });\n },\n\n nearestNeighbors: (query, numNeighbors, property) => {\n const nearestNeighborsQuery = isTextQuery(query)\n ? { \"type\": \"text\" as const, \"value\": query }\n : { \"type\": \"vector\" as const, \"value\": query };\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n {\n type: \"nearestNeighbors\",\n objectSet,\n propertyIdentifier: {\n type: \"property\",\n apiName: property as PropertyApiName,\n },\n numNeighbors,\n query: nearestNeighborsQuery,\n },\n ) as ObjectSet<Q>;\n },\n\n asyncIter: async function*<\n L extends PropertyKeys<Q>,\n R extends boolean,\n const A extends Augments,\n S extends NullabilityAdherence = NullabilityAdherence.Default,\n T extends boolean = false,\n ORDER_BY_OPTIONS extends ObjectSetArgs.OrderByOptions<L> = never,\n >(\n args?: AsyncIterArgs<Q, L, R, A, S, T, never, ORDER_BY_OPTIONS>,\n ): AsyncIterableIterator<\n SingleOsdkResult<Q, L, R, S, {}, T, ORDER_BY_OPTIONS>\n > {\n let $nextPageToken: string | undefined = undefined;\n do {\n const result: FetchPageResult<\n Q,\n L,\n R,\n S,\n T,\n ORDER_BY_OPTIONS\n > = await fetchPageInternal(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"asyncIter\" }),\n ),\n objectType,\n objectSet,\n { ...args, $pageSize: 10000, $nextPageToken },\n true,\n );\n $nextPageToken = result.nextPageToken;\n\n for (const obj of result.data) {\n yield obj as SingleOsdkResult<Q, L, R, S, {}, T, ORDER_BY_OPTIONS>;\n }\n } while ($nextPageToken != null);\n },\n\n fetchOne: (isObjectTypeDefinition(objectType)\n ? async <A extends SelectArg<Q>>(\n primaryKey: PrimaryKeyType<Q>,\n options: A,\n ) => {\n return await fetchSingle(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchOne\" }),\n ),\n objectType,\n options,\n await createWithPk(\n clientCtx,\n objectType,\n objectSet,\n primaryKey,\n ),\n ) as Osdk<Q>;\n }\n : undefined) as ObjectSet<Q>[\"fetchOne\"],\n\n fetchOneWithErrors: (isObjectTypeDefinition(objectType)\n ? async <A extends SelectArg<Q>>(\n primaryKey: Q extends ObjectTypeDefinition ? PrimaryKeyType<Q>\n : never,\n options: A,\n ) => {\n return await fetchSingleWithErrors(\n augmentRequestContext(\n clientCtx,\n _ => ({ finalMethodCall: \"fetchOneWithErrors\" }),\n ),\n objectType,\n options,\n await createWithPk(\n clientCtx,\n objectType,\n objectSet,\n primaryKey,\n ),\n ) as Result<Osdk<Q>>;\n }\n : undefined) as ObjectSet<Q>[\"fetchOneWithErrors\"],\n\n subscribe: (\n listener,\n opts,\n ) => {\n const pendingSubscribe = ObjectSetListenerWebsocket.getInstance(\n clientCtx,\n ).subscribe(\n objectType,\n objectSet,\n listener,\n opts?.properties,\n );\n\n return { unsubscribe: async () => (await pendingSubscribe)() };\n },\n\n withProperties: (clause) => {\n const definitionMap = new Map<any, DerivedPropertyDefinition>();\n\n const derivedProperties: Record<string, DerivedPropertyDefinition> = {};\n for (const key of Object.keys(clause)) {\n const derivedPropertyDefinition = clause\n [key](createWithPropertiesObjectSet(\n objectType,\n { type: \"methodInput\" },\n definitionMap,\n true,\n ));\n derivedProperties[key] = definitionMap.get(\n derivedPropertyDefinition,\n )!;\n }\n\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n {\n type: \"withProperties\",\n derivedProperties: derivedProperties,\n objectSet: objectSet,\n },\n );\n },\n\n narrowToType: (\n objectTypeDef: ObjectTypeDefinition | InterfaceDefinition,\n ) => {\n const existingMapping =\n clientCtx.narrowTypeInterfaceOrObjectMapping[objectTypeDef.apiName];\n invariant(\n !existingMapping || existingMapping === objectTypeDef.type,\n `${objectTypeDef.apiName} was previously used as an ${existingMapping}, but now used as a ${objectTypeDef.type}.`,\n );\n clientCtx.narrowTypeInterfaceOrObjectMapping[objectTypeDef.apiName] =\n objectTypeDef.type;\n\n return clientCtx.objectSetFactory(\n objectTypeDef,\n clientCtx,\n {\n type: \"asType\",\n objectSet: objectSet,\n entityType: objectTypeDef.apiName,\n },\n );\n },\n\n $objectSetInternals: {\n def: objectType,\n },\n };\n\n function createSearchAround<L extends LinkNames<Q>>(link: L) {\n return () => {\n return clientCtx.objectSetFactory(\n objectType,\n clientCtx,\n objectType.type === \"object\"\n ? {\n type: \"searchAround\",\n objectSet,\n link,\n }\n : {\n type: \"interfaceLinkSearchAround\",\n objectSet,\n interfaceLink: link,\n },\n );\n };\n }\n\n objectSetDefinitions.set(base, objectSet);\n\n // we are using a type assertion because the marker symbol defined in BaseObjectSet isn't actually used\n // at runtime.\n return base as ObjectSet<Q>;\n}\n\nasync function createWithPk(\n clientCtx: MinimalClient,\n objectType: ObjectTypeDefinition,\n objectSet: WireObjectSet,\n primaryKey: PrimaryKeyType<ObjectTypeDefinition>,\n) {\n const objDef = await clientCtx.ontologyProvider.getObjectDefinition(\n objectType.apiName,\n );\n\n const withPk: WireObjectSet = {\n type: \"filter\",\n objectSet: objectSet,\n where: {\n type: \"eq\",\n field: objDef.primaryKeyApiName,\n value: primaryKey,\n },\n };\n return withPk;\n}\n\nfunction isTextQuery(query: string | number[]): query is string {\n return typeof query === \"string\";\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"ObservableClient.js","names":["createFetchHeaderMutator","additionalContext","createClientFromContext","OBSERVABLE_USER_AGENT","ObservableClientImpl","Store","ObservableClient","createObservableClient","client","tweakedClient","fetch","headers","set","get","filter","x","length","join"],"sources":["ObservableClient.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 ActionDefinition,\n ActionValidationResponse,\n AggregateOpts,\n AggregationsResults,\n DerivedProperty,\n InterfaceDefinition,\n ObjectOrInterfaceDefinition,\n ObjectSet,\n ObjectTypeDefinition,\n Osdk,\n PrimaryKeyType,\n PropertyKeys,\n SimplePropertyDef,\n WhereClause,\n WirePropertyTypes,\n} from \"@osdk/api\";\nimport { createFetchHeaderMutator } from \"@osdk/shared.net.fetch\";\nimport type { ActionSignatureFromDef } from \"../actions/applyAction.js\";\nimport { additionalContext, type Client } from \"../Client.js\";\nimport { createClientFromContext } from \"../createClient.js\";\nimport { OBSERVABLE_USER_AGENT } from \"../util/UserAgent.js\";\nimport type { Canonical } from \"./internal/Canonical.js\";\nimport type { ObserveObjectSetOptions } from \"./internal/objectset/ObjectSetQueryOptions.js\";\nimport { ObservableClientImpl } from \"./internal/ObservableClientImpl.js\";\nimport { Store } from \"./internal/Store.js\";\nimport type {\n CommonObserveOptions,\n InvalidationMode,\n ObserveOptions,\n Observer,\n Status,\n} from \"./ObservableClient/common.js\";\nimport type { ObserveLinks } from \"./ObservableClient/ObserveLink.js\";\nimport type { OptimisticBuilder } from \"./OptimisticBuilder.js\";\n\nexport namespace ObservableClient {\n export interface ApplyActionOptions {\n optimisticUpdate?: (ctx: OptimisticBuilder) => void;\n }\n}\n\nexport interface ObserveObjectOptions<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> extends ObserveOptions {\n apiName: T[\"apiName\"] | T;\n pk: PrimaryKeyType<T>;\n select?: PropertyKeys<T>[];\n}\n\nexport type OrderBy<Q extends ObjectTypeDefinition | InterfaceDefinition> = {\n [K in PropertyKeys<Q>]?: \"asc\" | \"desc\" | undefined;\n};\n\nexport interface ObserveListOptions<\n Q extends ObjectOrInterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n> extends CommonObserveOptions, ObserveOptions {\n type: Pick<Q, \"apiName\" | \"type\">;\n where?: WhereClause<Q, RDPs>;\n pageSize?: number;\n orderBy?: OrderBy<Q>;\n invalidationMode?: InvalidationMode;\n expectedLength?: number;\n streamUpdates?: boolean;\n withProperties?: DerivedProperty.Clause<Q>;\n intersectWith?: Array<{\n where: WhereClause<Q, RDPs>;\n }>;\n pivotTo?: string;\n}\n\n// TODO: Rename this from `ObserveObjectArgs` => `ObserveObjectCallbackArgs`. Not doing it now to reduce churn\n// in repo.\nexport interface ObserveObjectArgs<T extends ObjectTypeDefinition> {\n object: Osdk.Instance<T> | undefined;\n isOptimistic: boolean;\n status: Status;\n lastUpdated: number;\n}\n\n// TODO: Rename this from `ObserveObjectsArgs` => `ObserveObjectsCallbackArgs`. Not doing it now to reduce churn\nexport interface ObserveObjectsArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> {\n resolvedList: Array<Osdk.Instance<T>>;\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n}\n\nexport interface ObserveObjectSetArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<\n string,\n WirePropertyTypes | undefined | Array<WirePropertyTypes>\n > = {},\n> {\n resolvedList: Array<\n Osdk.Instance<T, \"$allBaseProperties\", PropertyKeys<T>, RDPs>\n >;\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n objectSet: ObjectSet<T, RDPs>;\n}\n\nexport interface ObserveAggregationOptions<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n RDPs extends Record<string, SimplePropertyDef> = {},\n> extends CommonObserveOptions, ObserveOptions {\n type: T;\n where?: WhereClause<T, RDPs>;\n withProperties?: DerivedProperty.Clause<T>;\n intersectWith?: Array<{\n where: WhereClause<T, RDPs>;\n }>;\n aggregate: A;\n}\n\nexport interface ObserveAggregationArgs<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n> {\n result: AggregationsResults<T, A> | undefined;\n status: Status;\n lastUpdated: number;\n error?: Error;\n}\n\n/**\n * User facing callback args for `observeLink`\n */\nexport interface ObserveLinkCallbackArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> {\n resolvedList: Osdk.Instance<T>[];\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n}\n\n/**\n * Public interface for reactive data management with automatic updates.\n *\n * The ObservableClient provides a reactive data layer with:\n * - Real-time object and collection observation\n * - Automatic cache updates when data changes\n * - Optimistic updates for immediate UI feedback\n * - Pagination support for large collections\n * - Link traversal for relationship navigation\n */\nexport interface ObservableClient extends ObserveLinks {\n /**\n * Observe a single object with automatic updates when it changes.\n *\n * @param apiName - The object type definition or name\n * @param pk - The object's primary key\n * @param options - Observation options including deduplication interval\n * @param subFn - Observer that receives object state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * The observer will receive:\n * - Initial loading state if data not cached\n * - Loaded state with the object data\n * - Updates when the object changes\n * - Error state if fetch fails\n */\n observeObject<T extends ObjectTypeDefinition>(\n apiName: T[\"apiName\"] | T,\n pk: PrimaryKeyType<T>,\n options: ObserveOptions,\n subFn: Observer<ObserveObjectArgs<T>>,\n ): Unsubscribable;\n\n /**\n * Observe a filtered and sorted collection of objects.\n *\n * @param options - Filter, sort, and pagination options\n * @param subFn - Observer that receives collection state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports:\n * - Filtering with where clauses\n * - Sorting with orderBy\n * - Pagination via fetchMore() in the payload\n * - Automatic updates when any matching object changes\n */\n observeList<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n options: ObserveListOptions<T, RDPs>,\n subFn: Observer<ObserveObjectsArgs<T>>,\n ): Unsubscribable;\n\n /**\n * Observe an ObjectSet with automatic updates when matching objects change.\n *\n * @param baseObjectSet - The base ObjectSet to observe\n * @param options - Options for transforming and observing the ObjectSet\n * @param subFn - Observer that receives ObjectSet state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports all ObjectSet operations:\n * - Filtering with where clauses\n * - Derived properties with withProperties\n * - Set operations (union, intersect, subtract)\n * - Link traversal with pivotTo\n * - Sorting and pagination\n */\n observeObjectSet<\n T extends ObjectTypeDefinition,\n RDPs extends Record<\n string,\n WirePropertyTypes | undefined | Array<WirePropertyTypes>\n > = {},\n >(\n baseObjectSet: ObjectSet<T>,\n options: ObserveObjectSetOptions<T, RDPs>,\n subFn: Observer<ObserveObjectSetArgs<T, RDPs>>,\n ): Unsubscribable;\n\n /**\n * Observe an aggregation query with automatic updates when underlying data changes.\n *\n * @param options - Aggregation configuration including where, aggregate spec, and derived properties\n * @param subFn - Observer that receives aggregation result updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports:\n * - Filtering with where clauses\n * - Derived properties (RDPs) via withProperties\n * - Set intersections\n * - GroupBy and metric aggregations\n * - Automatic updates when source data changes\n */\n observeAggregation<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n options: ObserveAggregationOptions<T, A, RDPs>,\n subFn: Observer<ObserveAggregationArgs<T, A>>,\n ): Unsubscribable;\n\n /**\n * Execute an action with optional optimistic updates.\n *\n * @param action - Action definition to execute\n * @param args - Arguments for the action\n * @param opts - Options including optimistic updates\n * @returns Promise that resolves when the action completes\n *\n * When providing optimistic updates:\n * - Changes appear immediately in the UI\n * - Server request still happens in background\n * - On success, server data replaces optimistic data\n * - On failure, optimistic changes automatically roll back\n */\n applyAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args:\n | Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]\n | Array<Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]>,\n opts?: ObservableClient.ApplyActionOptions,\n ) => Promise<unknown>;\n\n /**\n * Validate action parameters without executing the action.\n *\n * @param action - Action definition to validate\n * @param args - Arguments to validate\n * @returns Promise with validation result\n *\n * Use this to:\n * - Pre-validate forms before submission\n * - Display warnings or errors in the UI\n * - Enable/disable action buttons based on validity\n */\n validateAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args: Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0],\n ) => Promise<ActionValidationResponse>;\n\n /**\n * Invalidates the entire cache, forcing all queries to refetch.\n * Use sparingly as this can cause significant network traffic.\n */\n invalidateAll(): Promise<void>;\n\n /**\n * Invalidates specific objects in the cache.\n * @param objects - Single object or array of objects to invalidate\n */\n invalidateObjects(\n objects:\n | Osdk.Instance<ObjectTypeDefinition>\n | ReadonlyArray<Osdk.Instance<ObjectTypeDefinition>>,\n ): Promise<void>;\n\n /**\n * Invalidates all cached data for a specific object type.\n * This includes:\n * - All objects of the specified type\n * - All lists containing objects of this type\n * - All links where the source is of this type\n *\n * @param type - Object type definition or API name string\n * @returns Promise that resolves when invalidation is complete\n */\n invalidateObjectType<T extends ObjectTypeDefinition>(\n type: T | T[\"apiName\"],\n ): Promise<void>;\n\n canonicalizeWhereClause: <\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n where: WhereClause<T, RDPs>,\n ) => Canonical<WhereClause<T, RDPs>>;\n}\n\nexport function createObservableClient(client: Client): ObservableClient {\n // First we need a modified client that adds an extra header so we know its\n // an observable client\n const tweakedClient = createClientFromContext({\n ...client[additionalContext],\n\n fetch: createFetchHeaderMutator(\n client[additionalContext].fetch,\n (headers) => {\n headers.set(\n \"Fetch-User-Agent\",\n [\n headers.get(\"Fetch-User-Agent\"),\n OBSERVABLE_USER_AGENT,\n ].filter(x => x && x?.length > 0).join(\" \"),\n );\n return headers;\n },\n ),\n });\n\n // Then we use that client instead. Because the `client` does not hold\n // any real state, this whole thing works.\n return new ObservableClientImpl(new Store(tweakedClient));\n}\n\nexport interface Unsubscribable {\n unsubscribe: () => void;\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAmBA,SAASA,wBAAwB,QAAQ,wBAAwB;AAEjE,SAASC,iBAAiB,QAAqB,cAAc;AAC7D,SAASC,uBAAuB,QAAQ,oBAAoB;AAC5D,SAASC,qBAAqB,QAAQ,sBAAsB;AAG5D,SAASC,oBAAoB,QAAQ,oCAAoC;AACzE,SAASC,KAAK,QAAQ,qBAAqB;AAAC,WAW3BC,gBAAgB;AAoCjC;AACA;;AAQA;;AAsDA;AACA;AACA;;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA4KA,OAAO,SAASC,sBAAsBA,CAACC,MAAc,EAAoB;EACvE;EACA;EACA,MAAMC,aAAa,GAAGP,uBAAuB,CAAC;IAC5C,GAAGM,MAAM,CAACP,iBAAiB,CAAC;IAE5BS,KAAK,EAAEV,wBAAwB,CAC7BQ,MAAM,CAACP,iBAAiB,CAAC,CAACS,KAAK,EAC9BC,OAAO,IAAK;MACXA,OAAO,CAACC,GAAG,CACT,kBAAkB,EAClB,CACED,OAAO,CAACE,GAAG,CAAC,kBAAkB,CAAC,EAC/BV,qBAAqB,CACtB,CAACW,MAAM,CAACC,CAAC,IAAIA,CAAC,IAAIA,CAAC,EAAEC,MAAM,GAAG,CAAC,CAAC,CAACC,IAAI,CAAC,GAAG,CAC5C,CAAC;MACD,OAAON,OAAO;IAChB,CACF;EACF,CAAC,CAAC;;EAEF;EACA;EACA,OAAO,IAAIP,oBAAoB,CAAC,IAAIC,KAAK,CAACI,aAAa,CAAC,CAAC;AAC3D","ignoreList":[]}
1
+ {"version":3,"file":"ObservableClient.js","names":["createFetchHeaderMutator","additionalContext","createClientFromContext","OBSERVABLE_USER_AGENT","ObservableClientImpl","Store","ObservableClient","createObservableClient","client","tweakedClient","fetch","headers","set","get","filter","x","length","join"],"sources":["ObservableClient.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 ActionDefinition,\n ActionValidationResponse,\n AggregateOpts,\n AggregationsResults,\n DerivedProperty,\n InterfaceDefinition,\n ObjectOrInterfaceDefinition,\n ObjectSet,\n ObjectTypeDefinition,\n Osdk,\n PrimaryKeyType,\n PropertyKeys,\n SimplePropertyDef,\n WhereClause,\n WirePropertyTypes,\n} from \"@osdk/api\";\nimport { createFetchHeaderMutator } from \"@osdk/shared.net.fetch\";\nimport type { ActionSignatureFromDef } from \"../actions/applyAction.js\";\nimport { additionalContext, type Client } from \"../Client.js\";\nimport { createClientFromContext } from \"../createClient.js\";\nimport { OBSERVABLE_USER_AGENT } from \"../util/UserAgent.js\";\nimport type { Canonical } from \"./internal/Canonical.js\";\nimport type { ObserveObjectSetOptions } from \"./internal/objectset/ObjectSetQueryOptions.js\";\nimport { ObservableClientImpl } from \"./internal/ObservableClientImpl.js\";\nimport { Store } from \"./internal/Store.js\";\nimport type {\n CommonObserveOptions,\n InvalidationMode,\n ObserveOptions,\n Observer,\n Status,\n} from \"./ObservableClient/common.js\";\nimport type { ObserveLinks } from \"./ObservableClient/ObserveLink.js\";\nimport type { OptimisticBuilder } from \"./OptimisticBuilder.js\";\n\nexport namespace ObservableClient {\n export interface ApplyActionOptions {\n optimisticUpdate?: (ctx: OptimisticBuilder) => void;\n }\n}\n\nexport interface ObserveObjectOptions<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> extends ObserveOptions {\n apiName: T[\"apiName\"] | T;\n pk: PrimaryKeyType<T>;\n select?: PropertyKeys<T>[];\n}\n\nexport type OrderBy<Q extends ObjectTypeDefinition | InterfaceDefinition> = {\n [K in PropertyKeys<Q>]?: \"asc\" | \"desc\" | undefined;\n};\n\nexport interface ObserveListOptions<\n Q extends ObjectOrInterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n> extends CommonObserveOptions, ObserveOptions {\n type: Pick<Q, \"apiName\" | \"type\">;\n where?: WhereClause<Q, RDPs>;\n pageSize?: number;\n orderBy?: OrderBy<Q>;\n invalidationMode?: InvalidationMode;\n expectedLength?: number;\n streamUpdates?: boolean;\n withProperties?: DerivedProperty.Clause<Q>;\n\n /**\n * Automatically fetch additional pages on initial load.\n *\n * - `true`: Fetch all available pages automatically\n * - `number`: Fetch pages until at least this many items are loaded\n * - `undefined` (default): Only fetch the first page, user must call fetchMore()\n *\n * @example\n * // Fetch all todos at once\n * observeList({ type: Todo, autoFetchMore: true }, observer)\n *\n * @example\n * // Fetch at least 100 todos\n * observeList({ type: Todo, autoFetchMore: 100, pageSize: 25 }, observer)\n */\n autoFetchMore?: boolean | number;\n intersectWith?: Array<{\n where: WhereClause<Q, RDPs>;\n }>;\n pivotTo?: string;\n}\n\n// TODO: Rename this from `ObserveObjectArgs` => `ObserveObjectCallbackArgs`. Not doing it now to reduce churn\n// in repo.\nexport interface ObserveObjectArgs<T extends ObjectTypeDefinition> {\n object: Osdk.Instance<T> | undefined;\n isOptimistic: boolean;\n status: Status;\n lastUpdated: number;\n}\n\n// TODO: Rename this from `ObserveObjectsArgs` => `ObserveObjectsCallbackArgs`. Not doing it now to reduce churn\nexport interface ObserveObjectsArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> {\n resolvedList: Array<Osdk.Instance<T>>;\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n}\n\nexport interface ObserveObjectSetArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<\n string,\n WirePropertyTypes | undefined | Array<WirePropertyTypes>\n > = {},\n> {\n resolvedList: Array<\n Osdk.Instance<T, \"$allBaseProperties\", PropertyKeys<T>, RDPs>\n >;\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n objectSet: ObjectSet<T, RDPs>;\n}\n\nexport interface ObserveAggregationOptions<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n RDPs extends Record<string, SimplePropertyDef> = {},\n> extends CommonObserveOptions, ObserveOptions {\n type: T;\n where?: WhereClause<T, RDPs>;\n withProperties?: DerivedProperty.Clause<T>;\n intersectWith?: Array<{\n where: WhereClause<T, RDPs>;\n }>;\n aggregate: A;\n}\n\nexport interface ObserveAggregationArgs<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n> {\n result: AggregationsResults<T, A> | undefined;\n status: Status;\n lastUpdated: number;\n error?: Error;\n}\n\n/**\n * User facing callback args for `observeLink`\n */\nexport interface ObserveLinkCallbackArgs<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n> {\n resolvedList: Osdk.Instance<T>[];\n isOptimistic: boolean;\n lastUpdated: number;\n fetchMore: () => Promise<void>;\n hasMore: boolean;\n status: Status;\n}\n\n/**\n * Public interface for reactive data management with automatic updates.\n *\n * The ObservableClient provides a reactive data layer with:\n * - Real-time object and collection observation\n * - Automatic cache updates when data changes\n * - Optimistic updates for immediate UI feedback\n * - Pagination support for large collections\n * - Link traversal for relationship navigation\n */\nexport interface ObservableClient extends ObserveLinks {\n /**\n * Observe a single object with automatic updates when it changes.\n *\n * @param apiName - The object type definition or name\n * @param pk - The object's primary key\n * @param options - Observation options including deduplication interval\n * @param subFn - Observer that receives object state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * The observer will receive:\n * - Initial loading state if data not cached\n * - Loaded state with the object data\n * - Updates when the object changes\n * - Error state if fetch fails\n */\n observeObject<T extends ObjectTypeDefinition>(\n apiName: T[\"apiName\"] | T,\n pk: PrimaryKeyType<T>,\n options: ObserveOptions,\n subFn: Observer<ObserveObjectArgs<T>>,\n ): Unsubscribable;\n\n /**\n * Observe a filtered and sorted collection of objects.\n *\n * @param options - Filter, sort, and pagination options\n * @param subFn - Observer that receives collection state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports:\n * - Filtering with where clauses\n * - Sorting with orderBy\n * - Pagination via fetchMore() in the payload\n * - Automatic updates when any matching object changes\n */\n observeList<\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n options: ObserveListOptions<T, RDPs>,\n subFn: Observer<ObserveObjectsArgs<T>>,\n ): Unsubscribable;\n\n /**\n * Observe an ObjectSet with automatic updates when matching objects change.\n *\n * @param baseObjectSet - The base ObjectSet to observe\n * @param options - Options for transforming and observing the ObjectSet\n * @param subFn - Observer that receives ObjectSet state updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports all ObjectSet operations:\n * - Filtering with where clauses\n * - Derived properties with withProperties\n * - Set operations (union, intersect, subtract)\n * - Link traversal with pivotTo\n * - Sorting and pagination\n */\n observeObjectSet<\n T extends ObjectTypeDefinition,\n RDPs extends Record<\n string,\n WirePropertyTypes | undefined | Array<WirePropertyTypes>\n > = {},\n >(\n baseObjectSet: ObjectSet<T>,\n options: ObserveObjectSetOptions<T, RDPs>,\n subFn: Observer<ObserveObjectSetArgs<T, RDPs>>,\n ): Unsubscribable;\n\n /**\n * Observe an aggregation query with automatic updates when underlying data changes.\n *\n * @param options - Aggregation configuration including where, aggregate spec, and derived properties\n * @param subFn - Observer that receives aggregation result updates\n * @returns Subscription that can be unsubscribed to stop updates\n *\n * Supports:\n * - Filtering with where clauses\n * - Derived properties (RDPs) via withProperties\n * - Set intersections\n * - GroupBy and metric aggregations\n * - Automatic updates when source data changes\n */\n observeAggregation<\n T extends ObjectOrInterfaceDefinition,\n A extends AggregateOpts<T>,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n options: ObserveAggregationOptions<T, A, RDPs>,\n subFn: Observer<ObserveAggregationArgs<T, A>>,\n ): Unsubscribable;\n\n /**\n * Execute an action with optional optimistic updates.\n *\n * @param action - Action definition to execute\n * @param args - Arguments for the action\n * @param opts - Options including optimistic updates\n * @returns Promise that resolves when the action completes\n *\n * When providing optimistic updates:\n * - Changes appear immediately in the UI\n * - Server request still happens in background\n * - On success, server data replaces optimistic data\n * - On failure, optimistic changes automatically roll back\n */\n applyAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args:\n | Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]\n | Array<Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]>,\n opts?: ObservableClient.ApplyActionOptions,\n ) => Promise<unknown>;\n\n /**\n * Validate action parameters without executing the action.\n *\n * @param action - Action definition to validate\n * @param args - Arguments to validate\n * @returns Promise with validation result\n *\n * Use this to:\n * - Pre-validate forms before submission\n * - Display warnings or errors in the UI\n * - Enable/disable action buttons based on validity\n */\n validateAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args: Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0],\n ) => Promise<ActionValidationResponse>;\n\n /**\n * Invalidates the entire cache, forcing all queries to refetch.\n * Use sparingly as this can cause significant network traffic.\n */\n invalidateAll(): Promise<void>;\n\n /**\n * Invalidates specific objects in the cache.\n * @param objects - Single object or array of objects to invalidate\n */\n invalidateObjects(\n objects:\n | Osdk.Instance<ObjectTypeDefinition>\n | ReadonlyArray<Osdk.Instance<ObjectTypeDefinition>>,\n ): Promise<void>;\n\n /**\n * Invalidates all cached data for a specific object type.\n * This includes:\n * - All objects of the specified type\n * - All lists containing objects of this type\n * - All links where the source is of this type\n *\n * @param type - Object type definition or API name string\n * @returns Promise that resolves when invalidation is complete\n */\n invalidateObjectType<T extends ObjectTypeDefinition>(\n type: T | T[\"apiName\"],\n ): Promise<void>;\n\n canonicalizeWhereClause: <\n T extends ObjectTypeDefinition | InterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n where: WhereClause<T, RDPs>,\n ) => Canonical<WhereClause<T, RDPs>>;\n}\n\nexport function createObservableClient(client: Client): ObservableClient {\n // First we need a modified client that adds an extra header so we know its\n // an observable client\n const tweakedClient = createClientFromContext({\n ...client[additionalContext],\n\n fetch: createFetchHeaderMutator(\n client[additionalContext].fetch,\n (headers) => {\n headers.set(\n \"Fetch-User-Agent\",\n [\n headers.get(\"Fetch-User-Agent\"),\n OBSERVABLE_USER_AGENT,\n ].filter(x => x && x?.length > 0).join(\" \"),\n );\n return headers;\n },\n ),\n });\n\n // Then we use that client instead. Because the `client` does not hold\n // any real state, this whole thing works.\n return new ObservableClientImpl(new Store(tweakedClient));\n}\n\nexport interface Unsubscribable {\n unsubscribe: () => void;\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAmBA,SAASA,wBAAwB,QAAQ,wBAAwB;AAEjE,SAASC,iBAAiB,QAAqB,cAAc;AAC7D,SAASC,uBAAuB,QAAQ,oBAAoB;AAC5D,SAASC,qBAAqB,QAAQ,sBAAsB;AAG5D,SAASC,oBAAoB,QAAQ,oCAAoC;AACzE,SAASC,KAAK,QAAQ,qBAAqB;AAAC,WAW3BC,gBAAgB;AAqDjC;AACA;;AAQA;;AAsDA;AACA;AACA;;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA4KA,OAAO,SAASC,sBAAsBA,CAACC,MAAc,EAAoB;EACvE;EACA;EACA,MAAMC,aAAa,GAAGP,uBAAuB,CAAC;IAC5C,GAAGM,MAAM,CAACP,iBAAiB,CAAC;IAE5BS,KAAK,EAAEV,wBAAwB,CAC7BQ,MAAM,CAACP,iBAAiB,CAAC,CAACS,KAAK,EAC9BC,OAAO,IAAK;MACXA,OAAO,CAACC,GAAG,CACT,kBAAkB,EAClB,CACED,OAAO,CAACE,GAAG,CAAC,kBAAkB,CAAC,EAC/BV,qBAAqB,CACtB,CAACW,MAAM,CAACC,CAAC,IAAIA,CAAC,IAAIA,CAAC,EAAEC,MAAM,GAAG,CAAC,CAAC,CAACC,IAAI,CAAC,GAAG,CAC5C,CAAC;MACD,OAAON,OAAO;IAChB,CACF;EACF,CAAC,CAAC;;EAEF;EACA;EACA,OAAO,IAAIP,oBAAoB,CAAC,IAAIC,KAAK,CAACI,aAAa,CAAC,CAAC;AAC3D","ignoreList":[]}
@@ -273,6 +273,7 @@ export class BaseListQuery extends Query {
273
273
  if (count >= this.minResultsToLoad || this.nextPageToken == null) {
274
274
  break;
275
275
  }
276
+ await Promise.resolve();
276
277
  }
277
278
  this.store.batch({}, batch => {
278
279
  this.setStatus("loaded", batch);
@@ -300,6 +301,8 @@ export class BaseListQuery extends Query {
300
301
  return undefined;
301
302
  }
302
303
  try {
304
+ const hadPreviousPage = this.nextPageToken != null;
305
+
303
306
  // Call the subclass-specific implementation to fetch data
304
307
  const result = await this.fetchPageData(signal);
305
308
 
@@ -312,10 +315,9 @@ export class BaseListQuery extends Query {
312
315
  const {
313
316
  retVal
314
317
  } = this.store.batch({}, batch => {
315
- const append = this.nextPageToken != null;
316
318
  const finalStatus = result.nextPageToken ? status : "loaded";
317
319
  const objectKeys = this.store.objects.storeOsdkInstances(result.data, batch, this.rdpConfig);
318
- return this._updateList(objectKeys, finalStatus, batch, append);
320
+ return this._updateList(objectKeys, finalStatus, batch, hadPreviousPage);
319
321
  });
320
322
  return retVal;
321
323
  } catch (error) {
@@ -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","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","result","fetchPageData","retVal","finalStatus","objectKeys","error","handleFetchError","_error","_status","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","$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 //\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 * @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 ): 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({ data: objectCacheKeys }, status, batch);\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 } 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.pendingPageFetch = 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\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 // Call the subclass-specific implementation to fetch data\n const result = await this.fetchPageData(signal);\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 = this.nextPageToken != null;\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 );\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 // Default implementation writes an empty list with error status\n // Most subclasses should be able to use this\n return this.writeToStore({ data: [] }, \"error\", batch);\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 return this.writeToStore({ data: objectCacheKeys }, options.status, batch);\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.$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","_updateList","items","status","batch","append","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","retVal","finalStatus","objectKeys","error","handleFetchError","_error","_status","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","$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 //\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 * @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 ): 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({ data: objectCacheKeys }, status, batch);\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 } 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.pendingPageFetch = 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 // 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 );\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 // Default implementation writes an empty list with error status\n // Most subclasses should be able to use this\n return this.writeToStore({ data: [] }, \"error\", batch);\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 return this.writeToStore({ data: objectCacheKeys }, options.status, batch);\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.$apiName,\n object.$primaryKey,\n );\n batch.delete(objectCacheKey, \"loaded\");\n });\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -346,7 +346,7 @@ describe(getObjectTypesThatInvalidate, () => {
346
346
  type: "static",
347
347
  objects: []
348
348
  }, {
349
- type: "asType",
349
+ type: "narrowToType",
350
350
  objectSet: {
351
351
  type: "base",
352
352
  objectType: "Employee"