@expo/entity 0.44.0 → 0.46.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (614) hide show
  1. package/build/{AuthorizationResultBasedEntityAssociationLoader.d.ts → src/AuthorizationResultBasedEntityAssociationLoader.d.ts} +4 -4
  2. package/build/{AuthorizationResultBasedEntityAssociationLoader.js → src/AuthorizationResultBasedEntityAssociationLoader.js} +2 -1
  3. package/build/src/AuthorizationResultBasedEntityAssociationLoader.js.map +1 -0
  4. package/build/{AuthorizationResultBasedEntityLoader.d.ts → src/AuthorizationResultBasedEntityLoader.d.ts} +8 -8
  5. package/build/{AuthorizationResultBasedEntityLoader.js → src/AuthorizationResultBasedEntityLoader.js} +10 -5
  6. package/build/src/AuthorizationResultBasedEntityLoader.js.map +1 -0
  7. package/build/{AuthorizationResultBasedEntityMutator.d.ts → src/AuthorizationResultBasedEntityMutator.d.ts} +11 -11
  8. package/build/{AuthorizationResultBasedEntityMutator.js → src/AuthorizationResultBasedEntityMutator.js} +2 -2
  9. package/build/src/AuthorizationResultBasedEntityMutator.js.map +1 -0
  10. package/build/{ComposedEntityCacheAdapter.d.ts → src/ComposedEntityCacheAdapter.d.ts} +2 -2
  11. package/build/{ComposedEntityCacheAdapter.js → src/ComposedEntityCacheAdapter.js} +2 -1
  12. package/build/src/ComposedEntityCacheAdapter.js.map +1 -0
  13. package/build/{ComposedSecondaryEntityCache.d.ts → src/ComposedSecondaryEntityCache.d.ts} +1 -1
  14. package/build/{ComposedSecondaryEntityCache.js → src/ComposedSecondaryEntityCache.js} +2 -1
  15. package/build/src/ComposedSecondaryEntityCache.js.map +1 -0
  16. package/build/{EnforcingEntityAssociationLoader.d.ts → src/EnforcingEntityAssociationLoader.d.ts} +5 -5
  17. package/build/{EnforcingEntityAssociationLoader.js → src/EnforcingEntityAssociationLoader.js} +2 -1
  18. package/build/src/EnforcingEntityAssociationLoader.js.map +1 -0
  19. package/build/{EnforcingEntityCreator.d.ts → src/EnforcingEntityCreator.d.ts} +4 -4
  20. package/build/{EnforcingEntityCreator.js → src/EnforcingEntityCreator.js} +2 -1
  21. package/build/src/EnforcingEntityCreator.js.map +1 -0
  22. package/build/{EnforcingEntityDeleter.d.ts → src/EnforcingEntityDeleter.d.ts} +4 -4
  23. package/build/{EnforcingEntityDeleter.js → src/EnforcingEntityDeleter.js} +2 -1
  24. package/build/src/EnforcingEntityDeleter.js.map +1 -0
  25. package/build/{EnforcingEntityLoader.d.ts → src/EnforcingEntityLoader.d.ts} +5 -5
  26. package/build/{EnforcingEntityLoader.js → src/EnforcingEntityLoader.js} +2 -1
  27. package/build/src/EnforcingEntityLoader.js.map +1 -0
  28. package/build/{EnforcingEntityUpdater.d.ts → src/EnforcingEntityUpdater.d.ts} +4 -4
  29. package/build/{EnforcingEntityUpdater.js → src/EnforcingEntityUpdater.js} +2 -1
  30. package/build/src/EnforcingEntityUpdater.js.map +1 -0
  31. package/build/{Entity.d.ts → src/Entity.d.ts} +7 -7
  32. package/build/{Entity.js → src/Entity.js} +13 -15
  33. package/build/src/Entity.js.map +1 -0
  34. package/build/{EntityAssociationLoader.d.ts → src/EntityAssociationLoader.d.ts} +5 -5
  35. package/build/{EntityAssociationLoader.js → src/EntityAssociationLoader.js} +6 -8
  36. package/build/src/EntityAssociationLoader.js.map +1 -0
  37. package/build/{EntityCompanion.d.ts → src/EntityCompanion.d.ts} +10 -10
  38. package/build/{EntityCompanion.js → src/EntityCompanion.js} +6 -8
  39. package/build/src/EntityCompanion.js.map +1 -0
  40. package/build/{EntityCompanionProvider.d.ts → src/EntityCompanionProvider.d.ts} +12 -12
  41. package/build/{EntityCompanionProvider.js → src/EntityCompanionProvider.js} +6 -5
  42. package/build/src/EntityCompanionProvider.js.map +1 -0
  43. package/build/{EntityConfiguration.d.ts → src/EntityConfiguration.d.ts} +2 -2
  44. package/build/{EntityConfiguration.js → src/EntityConfiguration.js} +2 -2
  45. package/build/src/EntityConfiguration.js.map +1 -0
  46. package/build/{EntityCreator.d.ts → src/EntityCreator.d.ts} +5 -5
  47. package/build/{EntityCreator.js → src/EntityCreator.js} +4 -6
  48. package/build/{EntityCreator.js.map → src/EntityCreator.js.map} +1 -1
  49. package/build/{EntityDatabaseAdapter.d.ts → src/EntityDatabaseAdapter.d.ts} +2 -2
  50. package/build/{EntityDatabaseAdapter.js → src/EntityDatabaseAdapter.js} +2 -2
  51. package/build/src/EntityDatabaseAdapter.js.map +1 -0
  52. package/build/{EntityDeleter.d.ts → src/EntityDeleter.d.ts} +5 -5
  53. package/build/{EntityDeleter.js → src/EntityDeleter.js} +4 -6
  54. package/build/{EntityDeleter.js.map → src/EntityDeleter.js.map} +1 -1
  55. package/build/{EntityFieldDefinition.d.ts → src/EntityFieldDefinition.d.ts} +3 -3
  56. package/build/src/EntityFieldDefinition.js.map +1 -0
  57. package/build/src/EntityFields.js.map +1 -0
  58. package/build/{EntityLoader.d.ts → src/EntityLoader.d.ts} +7 -7
  59. package/build/{EntityLoader.js → src/EntityLoader.js} +4 -6
  60. package/build/{EntityLoader.js.map → src/EntityLoader.js.map} +1 -1
  61. package/build/{EntityLoaderFactory.d.ts → src/EntityLoaderFactory.d.ts} +8 -8
  62. package/build/src/EntityLoaderFactory.js +29 -0
  63. package/build/src/EntityLoaderFactory.js.map +1 -0
  64. package/build/{EntityLoaderUtils.d.ts → src/EntityLoaderUtils.d.ts} +7 -7
  65. package/build/{EntityLoaderUtils.js → src/EntityLoaderUtils.js} +2 -1
  66. package/build/src/EntityLoaderUtils.js.map +1 -0
  67. package/build/{EntityMutationInfo.d.ts → src/EntityMutationInfo.d.ts} +2 -2
  68. package/build/src/EntityMutationInfo.js.map +1 -0
  69. package/build/{EntityMutationTriggerConfiguration.d.ts → src/EntityMutationTriggerConfiguration.d.ts} +3 -3
  70. package/build/src/EntityMutationTriggerConfiguration.js.map +1 -0
  71. package/build/{EntityMutationValidator.d.ts → src/EntityMutationValidator.d.ts} +3 -3
  72. package/build/{EntityMutationValidator.js → src/EntityMutationValidator.js} +2 -1
  73. package/build/src/EntityMutationValidator.js.map +1 -0
  74. package/build/{EntityMutatorFactory.d.ts → src/EntityMutatorFactory.d.ts} +12 -12
  75. package/build/{EntityMutatorFactory.js → src/EntityMutatorFactory.js} +2 -1
  76. package/build/src/EntityMutatorFactory.js.map +1 -0
  77. package/build/{EntityPrivacyPolicy.d.ts → src/EntityPrivacyPolicy.d.ts} +6 -6
  78. package/build/{EntityPrivacyPolicy.js → src/EntityPrivacyPolicy.js} +8 -11
  79. package/build/{EntityPrivacyPolicy.js.map → src/EntityPrivacyPolicy.js.map} +1 -1
  80. package/build/{EntityQueryContext.d.ts → src/EntityQueryContext.d.ts} +1 -1
  81. package/build/src/EntityQueryContext.js.map +1 -0
  82. package/build/{EntityQueryContextProvider.d.ts → src/EntityQueryContextProvider.d.ts} +2 -2
  83. package/build/{EntityQueryContextProvider.js → src/EntityQueryContextProvider.js} +2 -1
  84. package/build/src/EntityQueryContextProvider.js.map +1 -0
  85. package/build/{EntitySecondaryCacheLoader.d.ts → src/EntitySecondaryCacheLoader.d.ts} +5 -5
  86. package/build/{EntitySecondaryCacheLoader.js → src/EntitySecondaryCacheLoader.js} +2 -1
  87. package/build/src/EntitySecondaryCacheLoader.js.map +1 -0
  88. package/build/{EntityUpdater.d.ts → src/EntityUpdater.d.ts} +5 -5
  89. package/build/{EntityUpdater.js → src/EntityUpdater.js} +4 -6
  90. package/build/{EntityUpdater.js.map → src/EntityUpdater.js.map} +1 -1
  91. package/build/{GenericEntityCacheAdapter.d.ts → src/GenericEntityCacheAdapter.d.ts} +3 -3
  92. package/build/{GenericEntityCacheAdapter.js → src/GenericEntityCacheAdapter.js} +2 -1
  93. package/build/src/GenericEntityCacheAdapter.js.map +1 -0
  94. package/build/{GenericSecondaryEntityCache.d.ts → src/GenericSecondaryEntityCache.d.ts} +2 -2
  95. package/build/{GenericSecondaryEntityCache.js → src/GenericSecondaryEntityCache.js} +2 -1
  96. package/build/src/GenericSecondaryEntityCache.js.map +1 -0
  97. package/build/{IEntityCacheAdapter.d.ts → src/IEntityCacheAdapter.d.ts} +1 -1
  98. package/build/src/IEntityCacheAdapter.js.map +1 -0
  99. package/build/{IEntityCacheAdapterProvider.d.ts → src/IEntityCacheAdapterProvider.d.ts} +3 -3
  100. package/build/src/IEntityCacheAdapterProvider.js.map +1 -0
  101. package/build/{IEntityDatabaseAdapterProvider.d.ts → src/IEntityDatabaseAdapterProvider.d.ts} +3 -3
  102. package/build/src/IEntityDatabaseAdapterProvider.js.map +1 -0
  103. package/build/{IEntityGenericCacher.d.ts → src/IEntityGenericCacher.d.ts} +1 -1
  104. package/build/src/IEntityGenericCacher.js.map +1 -0
  105. package/build/{ReadonlyEntity.d.ts → src/ReadonlyEntity.d.ts} +8 -8
  106. package/build/{ReadonlyEntity.js → src/ReadonlyEntity.js} +9 -8
  107. package/build/src/ReadonlyEntity.js.map +1 -0
  108. package/build/{ViewerContext.d.ts → src/ViewerContext.d.ts} +5 -5
  109. package/build/{ViewerContext.js → src/ViewerContext.js} +4 -6
  110. package/build/{ViewerContext.js.map → src/ViewerContext.js.map} +1 -1
  111. package/build/{ViewerScopedEntityCompanion.d.ts → src/ViewerScopedEntityCompanion.d.ts} +9 -9
  112. package/build/{ViewerScopedEntityCompanion.js → src/ViewerScopedEntityCompanion.js} +6 -8
  113. package/build/{ViewerScopedEntityCompanion.js.map → src/ViewerScopedEntityCompanion.js.map} +1 -1
  114. package/build/{ViewerScopedEntityCompanionProvider.d.ts → src/ViewerScopedEntityCompanionProvider.d.ts} +6 -6
  115. package/build/{ViewerScopedEntityCompanionProvider.js → src/ViewerScopedEntityCompanionProvider.js} +4 -6
  116. package/build/src/ViewerScopedEntityCompanionProvider.js.map +1 -0
  117. package/build/{ViewerScopedEntityLoaderFactory.d.ts → src/ViewerScopedEntityLoaderFactory.d.ts} +6 -6
  118. package/build/{ViewerScopedEntityLoaderFactory.js → src/ViewerScopedEntityLoaderFactory.js} +2 -1
  119. package/build/src/ViewerScopedEntityLoaderFactory.js.map +1 -0
  120. package/build/{ViewerScopedEntityMutatorFactory.d.ts → src/ViewerScopedEntityMutatorFactory.d.ts} +6 -6
  121. package/build/{ViewerScopedEntityMutatorFactory.js → src/ViewerScopedEntityMutatorFactory.js} +2 -1
  122. package/build/src/ViewerScopedEntityMutatorFactory.js.map +1 -0
  123. package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.d.ts +1 -0
  124. package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js +240 -0
  125. package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js.map +1 -0
  126. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.d.ts +26 -0
  127. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js +109 -0
  128. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js.map +1 -0
  129. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.d.ts +1 -0
  130. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js +590 -0
  131. package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js.map +1 -0
  132. package/build/src/__tests__/ComposedCacheAdapter-test.d.ts +1 -0
  133. package/build/src/__tests__/ComposedCacheAdapter-test.js +259 -0
  134. package/build/src/__tests__/ComposedCacheAdapter-test.js.map +1 -0
  135. package/build/src/__tests__/ComposedSecondaryEntityCache-test.d.ts +1 -0
  136. package/build/src/__tests__/ComposedSecondaryEntityCache-test.js +67 -0
  137. package/build/src/__tests__/ComposedSecondaryEntityCache-test.js.map +1 -0
  138. package/build/src/__tests__/EnforcingEntityAssociationLoader-test.d.ts +1 -0
  139. package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js +113 -0
  140. package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js.map +1 -0
  141. package/build/src/__tests__/EnforcingEntityLoader-test.d.ts +1 -0
  142. package/build/src/__tests__/EnforcingEntityLoader-test.js +316 -0
  143. package/build/src/__tests__/EnforcingEntityLoader-test.js.map +1 -0
  144. package/build/src/__tests__/Entity-test.d.ts +1 -0
  145. package/build/src/__tests__/Entity-test.js +92 -0
  146. package/build/src/__tests__/Entity-test.js.map +1 -0
  147. package/build/src/__tests__/EntityAssociationLoader-test.d.ts +1 -0
  148. package/build/src/__tests__/EntityAssociationLoader-test.js +28 -0
  149. package/build/src/__tests__/EntityAssociationLoader-test.js.map +1 -0
  150. package/build/src/__tests__/EntityCommonUseCases-test.d.ts +1 -0
  151. package/build/src/__tests__/EntityCommonUseCases-test.js +111 -0
  152. package/build/src/__tests__/EntityCommonUseCases-test.js.map +1 -0
  153. package/build/src/__tests__/EntityCompanion-test.d.ts +1 -0
  154. package/build/src/__tests__/EntityCompanion-test.js +42 -0
  155. package/build/src/__tests__/EntityCompanion-test.js.map +1 -0
  156. package/build/src/__tests__/EntityCompanionProvider-test.d.ts +1 -0
  157. package/build/src/__tests__/EntityCompanionProvider-test.js +53 -0
  158. package/build/src/__tests__/EntityCompanionProvider-test.js.map +1 -0
  159. package/build/src/__tests__/EntityConfiguration-test.d.ts +1 -0
  160. package/build/src/__tests__/EntityConfiguration-test.js +164 -0
  161. package/build/src/__tests__/EntityConfiguration-test.js.map +1 -0
  162. package/build/src/__tests__/EntityDatabaseAdapter-test.d.ts +1 -0
  163. package/build/src/__tests__/EntityDatabaseAdapter-test.js +189 -0
  164. package/build/src/__tests__/EntityDatabaseAdapter-test.js.map +1 -0
  165. package/build/src/__tests__/EntityEdges-test.d.ts +1 -0
  166. package/build/src/__tests__/EntityEdges-test.js +680 -0
  167. package/build/src/__tests__/EntityEdges-test.js.map +1 -0
  168. package/build/src/__tests__/EntityFields-test.d.ts +1 -0
  169. package/build/src/__tests__/EntityFields-test.js +61 -0
  170. package/build/src/__tests__/EntityFields-test.js.map +1 -0
  171. package/build/src/__tests__/EntityLoader-test.d.ts +1 -0
  172. package/build/src/__tests__/EntityLoader-test.js +34 -0
  173. package/build/src/__tests__/EntityLoader-test.js.map +1 -0
  174. package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.d.ts +1 -0
  175. package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js +71 -0
  176. package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js.map +1 -0
  177. package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.d.ts +1 -0
  178. package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js +54 -0
  179. package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js.map +1 -0
  180. package/build/src/__tests__/EntityMutator-test.d.ts +1 -0
  181. package/build/src/__tests__/EntityMutator-test.js +721 -0
  182. package/build/src/__tests__/EntityMutator-test.js.map +1 -0
  183. package/build/src/__tests__/EntityPrivacyPolicy-test.d.ts +1 -0
  184. package/build/src/__tests__/EntityPrivacyPolicy-test.js +429 -0
  185. package/build/src/__tests__/EntityPrivacyPolicy-test.js.map +1 -0
  186. package/build/src/__tests__/EntityQueryContext-test.d.ts +1 -0
  187. package/build/src/__tests__/EntityQueryContext-test.js +181 -0
  188. package/build/src/__tests__/EntityQueryContext-test.js.map +1 -0
  189. package/build/src/__tests__/EntitySecondaryCacheLoader-test.d.ts +1 -0
  190. package/build/src/__tests__/EntitySecondaryCacheLoader-test.js +58 -0
  191. package/build/src/__tests__/EntitySecondaryCacheLoader-test.js.map +1 -0
  192. package/build/src/__tests__/EntitySelfReferentialEdges-test.d.ts +1 -0
  193. package/build/src/__tests__/EntitySelfReferentialEdges-test.js +196 -0
  194. package/build/src/__tests__/EntitySelfReferentialEdges-test.js.map +1 -0
  195. package/build/src/__tests__/GenericEntityCacheAdapter-test.d.ts +1 -0
  196. package/build/src/__tests__/GenericEntityCacheAdapter-test.js +95 -0
  197. package/build/src/__tests__/GenericEntityCacheAdapter-test.js.map +1 -0
  198. package/build/src/__tests__/ReadonlyEntity-test.d.ts +1 -0
  199. package/build/src/__tests__/ReadonlyEntity-test.js +209 -0
  200. package/build/src/__tests__/ReadonlyEntity-test.js.map +1 -0
  201. package/build/src/__tests__/ViewerContext-test.d.ts +1 -0
  202. package/build/src/__tests__/ViewerContext-test.js +28 -0
  203. package/build/src/__tests__/ViewerContext-test.js.map +1 -0
  204. package/build/src/__tests__/ViewerScopedEntityCompanion-test.d.ts +1 -0
  205. package/build/src/__tests__/ViewerScopedEntityCompanion-test.js +18 -0
  206. package/build/src/__tests__/ViewerScopedEntityCompanion-test.js.map +1 -0
  207. package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.d.ts +1 -0
  208. package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js +18 -0
  209. package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js.map +1 -0
  210. package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.d.ts +1 -0
  211. package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js +21 -0
  212. package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js.map +1 -0
  213. package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.d.ts +1 -0
  214. package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js +20 -0
  215. package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js.map +1 -0
  216. package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.d.ts +1 -0
  217. package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js +121 -0
  218. package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js.map +1 -0
  219. package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.d.ts +1 -0
  220. package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js +119 -0
  221. package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js.map +1 -0
  222. package/build/src/__tests__/entityUtils-test.d.ts +1 -0
  223. package/build/src/__tests__/entityUtils-test.js +88 -0
  224. package/build/src/__tests__/entityUtils-test.js.map +1 -0
  225. package/build/src/entityUtils.js.map +1 -0
  226. package/build/{errors → src/errors}/EntityCacheAdapterError.d.ts +2 -2
  227. package/build/src/errors/EntityCacheAdapterError.js +13 -0
  228. package/build/src/errors/EntityCacheAdapterError.js.map +1 -0
  229. package/build/{errors → src/errors}/EntityDatabaseAdapterError.d.ts +2 -2
  230. package/build/{errors → src/errors}/EntityDatabaseAdapterError.js +4 -37
  231. package/build/src/errors/EntityDatabaseAdapterError.js.map +1 -0
  232. package/build/{errors → src/errors}/EntityError.d.ts +1 -1
  233. package/build/{errors → src/errors}/EntityError.js +2 -2
  234. package/build/src/errors/EntityError.js.map +1 -0
  235. package/build/{errors → src/errors}/EntityInvalidFieldValueError.d.ts +5 -5
  236. package/build/src/errors/EntityInvalidFieldValueError.js +13 -0
  237. package/build/src/errors/EntityInvalidFieldValueError.js.map +1 -0
  238. package/build/{errors → src/errors}/EntityNotAuthorizedError.d.ts +4 -4
  239. package/build/src/errors/EntityNotAuthorizedError.js +16 -0
  240. package/build/src/errors/EntityNotAuthorizedError.js.map +1 -0
  241. package/build/src/errors/EntityNotFoundError.d.ts +17 -0
  242. package/build/src/errors/EntityNotFoundError.js +18 -0
  243. package/build/src/errors/EntityNotFoundError.js.map +1 -0
  244. package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.d.ts +1 -0
  245. package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js +21 -0
  246. package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js.map +1 -0
  247. package/build/src/index.d.ts +76 -0
  248. package/build/src/index.js +94 -0
  249. package/build/src/index.js.map +1 -0
  250. package/build/{internal → src/internal}/CompositeFieldHolder.d.ts +1 -1
  251. package/build/src/internal/CompositeFieldHolder.js.map +1 -0
  252. package/build/src/internal/CompositeFieldValueMap.js.map +1 -0
  253. package/build/{internal → src/internal}/EntityDataManager.d.ts +5 -5
  254. package/build/{internal → src/internal}/EntityDataManager.js +2 -1
  255. package/build/src/internal/EntityDataManager.js.map +1 -0
  256. package/build/{internal → src/internal}/EntityFieldTransformationUtils.d.ts +1 -1
  257. package/build/src/internal/EntityFieldTransformationUtils.js.map +1 -0
  258. package/build/{internal → src/internal}/EntityLoadInterfaces.d.ts +1 -1
  259. package/build/src/internal/EntityLoadInterfaces.js.map +1 -0
  260. package/build/{internal → src/internal}/EntityTableDataCoordinator.d.ts +9 -9
  261. package/build/{internal → src/internal}/EntityTableDataCoordinator.js +5 -7
  262. package/build/{internal → src/internal}/EntityTableDataCoordinator.js.map +1 -1
  263. package/build/{internal → src/internal}/ReadThroughEntityCache.d.ts +3 -3
  264. package/build/{internal → src/internal}/ReadThroughEntityCache.js +2 -2
  265. package/build/src/internal/ReadThroughEntityCache.js.map +1 -0
  266. package/build/{internal → src/internal}/SingleFieldHolder.d.ts +1 -1
  267. package/build/src/internal/SingleFieldHolder.js.map +1 -0
  268. package/build/src/internal/__tests__/CompositeFieldHolder-test.d.ts +1 -0
  269. package/build/src/internal/__tests__/CompositeFieldHolder-test.js +25 -0
  270. package/build/src/internal/__tests__/CompositeFieldHolder-test.js.map +1 -0
  271. package/build/src/internal/__tests__/CompositeFieldValueMap-test.d.ts +1 -0
  272. package/build/src/internal/__tests__/CompositeFieldValueMap-test.js +40 -0
  273. package/build/src/internal/__tests__/CompositeFieldValueMap-test.js.map +1 -0
  274. package/build/src/internal/__tests__/EntityDataManager-test.d.ts +1 -0
  275. package/build/src/internal/__tests__/EntityDataManager-test.js +666 -0
  276. package/build/src/internal/__tests__/EntityDataManager-test.js.map +1 -0
  277. package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.d.ts +1 -0
  278. package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js +135 -0
  279. package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js.map +1 -0
  280. package/build/src/internal/__tests__/ReadThroughEntityCache-test.d.ts +1 -0
  281. package/build/src/internal/__tests__/ReadThroughEntityCache-test.js +217 -0
  282. package/build/src/internal/__tests__/ReadThroughEntityCache-test.js.map +1 -0
  283. package/build/{metrics → src/metrics}/EntityMetricsUtils.d.ts +1 -1
  284. package/build/src/metrics/EntityMetricsUtils.js.map +1 -0
  285. package/build/{metrics → src/metrics}/IEntityMetricsAdapter.d.ts +1 -1
  286. package/build/src/metrics/IEntityMetricsAdapter.js.map +1 -0
  287. package/build/{metrics → src/metrics}/NoOpEntityMetricsAdapter.d.ts +2 -2
  288. package/build/{metrics → src/metrics}/NoOpEntityMetricsAdapter.js +2 -1
  289. package/build/src/metrics/NoOpEntityMetricsAdapter.js.map +1 -0
  290. package/build/{rules → src/rules}/AlwaysAllowPrivacyPolicyRule.d.ts +4 -4
  291. package/build/src/rules/AlwaysAllowPrivacyPolicyRule.js +14 -0
  292. package/build/src/rules/AlwaysAllowPrivacyPolicyRule.js.map +1 -0
  293. package/build/{rules → src/rules}/AlwaysDenyPrivacyPolicyRule.d.ts +4 -4
  294. package/build/src/rules/AlwaysDenyPrivacyPolicyRule.js +14 -0
  295. package/build/src/rules/AlwaysDenyPrivacyPolicyRule.js.map +1 -0
  296. package/build/{rules → src/rules}/AlwaysSkipPrivacyPolicyRule.d.ts +4 -4
  297. package/build/src/rules/AlwaysSkipPrivacyPolicyRule.js +14 -0
  298. package/build/src/rules/AlwaysSkipPrivacyPolicyRule.js.map +1 -0
  299. package/build/{rules → src/rules}/PrivacyPolicyRule.d.ts +3 -3
  300. package/build/{rules → src/rules}/PrivacyPolicyRule.js +2 -2
  301. package/build/src/rules/PrivacyPolicyRule.js.map +1 -0
  302. package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.d.ts +1 -0
  303. package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js +18 -0
  304. package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js.map +1 -0
  305. package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.d.ts +1 -0
  306. package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js +18 -0
  307. package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js.map +1 -0
  308. package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.d.ts +1 -0
  309. package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js +18 -0
  310. package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js.map +1 -0
  311. package/build/src/utils/EntityCreationUtils.d.ts +14 -0
  312. package/build/src/utils/EntityCreationUtils.js +54 -0
  313. package/build/src/utils/EntityCreationUtils.js.map +1 -0
  314. package/build/{utils → src/utils}/EntityPrivacyUtils.d.ts +4 -4
  315. package/build/{utils → src/utils}/EntityPrivacyUtils.js +4 -7
  316. package/build/{utils → src/utils}/EntityPrivacyUtils.js.map +1 -1
  317. package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.d.ts +28 -0
  318. package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js +53 -0
  319. package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js.map +1 -0
  320. package/build/src/utils/__testfixtures__/SimpleTestEntity.d.ts +20 -0
  321. package/build/src/utils/__testfixtures__/SimpleTestEntity.js +46 -0
  322. package/build/src/utils/__testfixtures__/SimpleTestEntity.js.map +1 -0
  323. package/build/src/utils/__testfixtures__/StubCacheAdapter.d.ts +29 -0
  324. package/build/src/utils/__testfixtures__/StubCacheAdapter.js +103 -0
  325. package/build/src/utils/__testfixtures__/StubCacheAdapter.js.map +1 -0
  326. package/build/src/utils/__testfixtures__/StubDatabaseAdapter.d.ts +26 -0
  327. package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js +173 -0
  328. package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js.map +1 -0
  329. package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.d.ts +7 -0
  330. package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js +12 -0
  331. package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js.map +1 -0
  332. package/build/src/utils/__testfixtures__/StubQueryContextProvider.d.ts +7 -0
  333. package/build/src/utils/__testfixtures__/StubQueryContextProvider.js +17 -0
  334. package/build/src/utils/__testfixtures__/StubQueryContextProvider.js.map +1 -0
  335. package/build/src/utils/__testfixtures__/TSMockitoExtensions.d.ts +9 -0
  336. package/build/src/utils/__testfixtures__/TSMockitoExtensions.js +65 -0
  337. package/build/src/utils/__testfixtures__/TSMockitoExtensions.js.map +1 -0
  338. package/build/src/utils/__testfixtures__/TestEntity.d.ts +30 -0
  339. package/build/src/utils/__testfixtures__/TestEntity.js +96 -0
  340. package/build/src/utils/__testfixtures__/TestEntity.js.map +1 -0
  341. package/build/src/utils/__testfixtures__/TestEntity2.d.ts +20 -0
  342. package/build/src/utils/__testfixtures__/TestEntity2.js +49 -0
  343. package/build/src/utils/__testfixtures__/TestEntity2.js.map +1 -0
  344. package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.d.ts +36 -0
  345. package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js +80 -0
  346. package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js.map +1 -0
  347. package/build/src/utils/__testfixtures__/TestViewerContext.d.ts +3 -0
  348. package/build/src/utils/__testfixtures__/TestViewerContext.js +8 -0
  349. package/build/src/utils/__testfixtures__/TestViewerContext.js.map +1 -0
  350. package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.d.ts +7 -0
  351. package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js +33 -0
  352. package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js.map +1 -0
  353. package/build/src/utils/__testfixtures__/describeFieldTestCase.d.ts +2 -0
  354. package/build/src/utils/__testfixtures__/describeFieldTestCase.js +19 -0
  355. package/build/src/utils/__testfixtures__/describeFieldTestCase.js.map +1 -0
  356. package/build/src/utils/__tests__/EntityCreationUtils-test.d.ts +1 -0
  357. package/build/src/utils/__tests__/EntityCreationUtils-test.js +144 -0
  358. package/build/src/utils/__tests__/EntityCreationUtils-test.js.map +1 -0
  359. package/build/src/utils/__tests__/EntityPrivacyUtils-test.d.ts +1 -0
  360. package/build/src/utils/__tests__/EntityPrivacyUtils-test.js +460 -0
  361. package/build/src/utils/__tests__/EntityPrivacyUtils-test.js.map +1 -0
  362. package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.d.ts +1 -0
  363. package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js +180 -0
  364. package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js.map +1 -0
  365. package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.d.ts +1 -0
  366. package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js +27 -0
  367. package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js.map +1 -0
  368. package/build/src/utils/collections/SerializableKeyMap.js.map +1 -0
  369. package/build/src/utils/collections/__tests__/SerializableKeyMap-test.d.ts +5 -0
  370. package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js +99 -0
  371. package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js.map +1 -0
  372. package/build/src/utils/collections/__tests__/maps-test.d.ts +1 -0
  373. package/build/src/utils/collections/__tests__/maps-test.js +121 -0
  374. package/build/src/utils/collections/__tests__/maps-test.js.map +1 -0
  375. package/build/src/utils/collections/__tests__/sets-test.d.ts +1 -0
  376. package/build/src/utils/collections/__tests__/sets-test.js +19 -0
  377. package/build/src/utils/collections/__tests__/sets-test.js.map +1 -0
  378. package/build/src/utils/collections/maps.js.map +1 -0
  379. package/build/src/utils/collections/sets.js.map +1 -0
  380. package/build/{utils → src/utils}/mergeEntityMutationTriggerConfigurations.d.ts +3 -3
  381. package/build/src/utils/mergeEntityMutationTriggerConfigurations.js.map +1 -0
  382. package/build/tsconfig.tsbuildinfo +1 -0
  383. package/package.json +11 -23
  384. package/src/AuthorizationResultBasedEntityAssociationLoader.ts +4 -4
  385. package/src/AuthorizationResultBasedEntityLoader.ts +20 -13
  386. package/src/AuthorizationResultBasedEntityMutator.ts +15 -14
  387. package/src/ComposedEntityCacheAdapter.ts +3 -3
  388. package/src/ComposedSecondaryEntityCache.ts +1 -1
  389. package/src/EnforcingEntityAssociationLoader.ts +6 -5
  390. package/src/EnforcingEntityCreator.ts +4 -4
  391. package/src/EnforcingEntityDeleter.ts +4 -4
  392. package/src/EnforcingEntityLoader.ts +5 -5
  393. package/src/EnforcingEntityUpdater.ts +4 -4
  394. package/src/Entity.ts +10 -10
  395. package/src/EntityAssociationLoader.ts +5 -5
  396. package/src/EntityCompanion.ts +10 -10
  397. package/src/EntityCompanionProvider.ts +13 -13
  398. package/src/EntityConfiguration.ts +3 -3
  399. package/src/EntityCreator.ts +5 -5
  400. package/src/EntityDatabaseAdapter.ts +3 -3
  401. package/src/EntityDeleter.ts +5 -5
  402. package/src/EntityFieldDefinition.ts +3 -3
  403. package/src/EntityLoader.ts +7 -7
  404. package/src/EntityLoaderFactory.ts +9 -9
  405. package/src/EntityLoaderUtils.ts +7 -7
  406. package/src/EntityMutationInfo.ts +2 -2
  407. package/src/EntityMutationTriggerConfiguration.ts +3 -3
  408. package/src/EntityMutationValidator.ts +3 -3
  409. package/src/EntityMutatorFactory.ts +12 -12
  410. package/src/EntityPrivacyPolicy.ts +7 -6
  411. package/src/EntityQueryContext.ts +1 -1
  412. package/src/EntityQueryContextProvider.ts +3 -3
  413. package/src/EntitySecondaryCacheLoader.ts +5 -5
  414. package/src/EntityUpdater.ts +5 -5
  415. package/src/GenericEntityCacheAdapter.ts +3 -3
  416. package/src/GenericSecondaryEntityCache.ts +2 -2
  417. package/src/IEntityCacheAdapter.ts +1 -1
  418. package/src/IEntityCacheAdapterProvider.ts +3 -3
  419. package/src/IEntityDatabaseAdapterProvider.ts +3 -3
  420. package/src/IEntityGenericCacher.ts +1 -1
  421. package/src/ReadonlyEntity.ts +10 -10
  422. package/src/ViewerContext.ts +6 -6
  423. package/src/ViewerScopedEntityCompanion.ts +9 -9
  424. package/src/ViewerScopedEntityCompanionProvider.ts +6 -6
  425. package/src/ViewerScopedEntityLoaderFactory.ts +6 -6
  426. package/src/ViewerScopedEntityMutatorFactory.ts +6 -6
  427. package/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.ts +5 -4
  428. package/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.ts +14 -18
  429. package/src/__tests__/AuthorizationResultBasedEntityLoader-test.ts +18 -16
  430. package/src/__tests__/ComposedCacheAdapter-test.ts +5 -3
  431. package/src/__tests__/ComposedSecondaryEntityCache-test.ts +2 -1
  432. package/src/__tests__/EnforcingEntityAssociationLoader-test.ts +4 -3
  433. package/src/__tests__/EnforcingEntityLoader-test.ts +4 -3
  434. package/src/__tests__/Entity-test.ts +8 -6
  435. package/src/__tests__/EntityAssociationLoader-test.ts +7 -5
  436. package/src/__tests__/EntityCommonUseCases-test.ts +10 -9
  437. package/src/__tests__/EntityCompanion-test.ts +13 -11
  438. package/src/__tests__/EntityCompanionProvider-test.ts +7 -5
  439. package/src/__tests__/EntityConfiguration-test.ts +3 -1
  440. package/src/__tests__/EntityDatabaseAdapter-test.ts +9 -7
  441. package/src/__tests__/EntityEdges-test.ts +10 -8
  442. package/src/__tests__/EntityFields-test.ts +8 -7
  443. package/src/__tests__/EntityLoader-test.ts +8 -6
  444. package/src/__tests__/EntityMutator-MutationCacheConsistency-test.ts +8 -6
  445. package/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.ts +5 -3
  446. package/src/__tests__/EntityMutator-test.ts +33 -29
  447. package/src/__tests__/EntityPrivacyPolicy-test.ts +19 -16
  448. package/src/__tests__/EntityQueryContext-test.ts +7 -6
  449. package/src/__tests__/EntitySecondaryCacheLoader-test.ts +5 -3
  450. package/src/__tests__/EntitySelfReferentialEdges-test.ts +7 -5
  451. package/src/__tests__/GenericEntityCacheAdapter-test.ts +4 -3
  452. package/src/__tests__/ReadonlyEntity-test.ts +10 -9
  453. package/src/__tests__/ViewerContext-test.ts +3 -1
  454. package/src/__tests__/ViewerScopedEntityCompanion-test.ts +10 -8
  455. package/src/__tests__/ViewerScopedEntityCompanionProvider-test.ts +7 -6
  456. package/src/__tests__/ViewerScopedEntityLoaderFactory-test.ts +5 -4
  457. package/src/__tests__/ViewerScopedEntityMutatorFactory-test.ts +8 -6
  458. package/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.ts +15 -13
  459. package/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.ts +7 -5
  460. package/src/__tests__/entityUtils-test.ts +3 -2
  461. package/src/errors/EntityCacheAdapterError.ts +2 -2
  462. package/src/errors/EntityDatabaseAdapterError.ts +2 -2
  463. package/src/errors/EntityError.ts +1 -1
  464. package/src/errors/EntityInvalidFieldValueError.ts +5 -5
  465. package/src/errors/EntityNotAuthorizedError.ts +4 -4
  466. package/src/errors/EntityNotFoundError.ts +56 -9
  467. package/src/errors/__tests__/EntityDatabaseAdapterError-test.ts +29 -0
  468. package/src/index.ts +40 -54
  469. package/src/internal/CompositeFieldHolder.ts +2 -1
  470. package/src/internal/EntityDataManager.ts +7 -5
  471. package/src/internal/EntityFieldTransformationUtils.ts +1 -1
  472. package/src/internal/EntityLoadInterfaces.ts +1 -1
  473. package/src/internal/EntityTableDataCoordinator.ts +10 -10
  474. package/src/internal/ReadThroughEntityCache.ts +3 -3
  475. package/src/internal/SingleFieldHolder.ts +1 -1
  476. package/src/internal/__tests__/CompositeFieldHolder-test.ts +2 -0
  477. package/src/internal/__tests__/CompositeFieldValueMap-test.ts +2 -0
  478. package/src/internal/__tests__/EntityDataManager-test.ts +34 -31
  479. package/src/internal/__tests__/EntityFieldTransformationUtils-test.ts +5 -3
  480. package/src/internal/__tests__/ReadThroughEntityCache-test.ts +5 -4
  481. package/src/metrics/EntityMetricsUtils.ts +3 -2
  482. package/src/metrics/IEntityMetricsAdapter.ts +1 -1
  483. package/src/metrics/NoOpEntityMetricsAdapter.ts +3 -2
  484. package/src/rules/AlwaysAllowPrivacyPolicyRule.ts +4 -4
  485. package/src/rules/AlwaysDenyPrivacyPolicyRule.ts +4 -4
  486. package/src/rules/AlwaysSkipPrivacyPolicyRule.ts +4 -4
  487. package/src/rules/PrivacyPolicyRule.ts +3 -3
  488. package/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.ts +3 -3
  489. package/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.ts +3 -3
  490. package/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.ts +3 -3
  491. package/src/utils/EntityCreationUtils.ts +143 -0
  492. package/src/utils/EntityPrivacyUtils.ts +5 -5
  493. package/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.ts +5 -3
  494. package/src/utils/__testfixtures__/SimpleTestEntity.ts +6 -6
  495. package/src/utils/__testfixtures__/StubCacheAdapter.ts +4 -4
  496. package/src/utils/__testfixtures__/StubDatabaseAdapter.ts +8 -7
  497. package/src/utils/__testfixtures__/StubDatabaseAdapterProvider.ts +5 -5
  498. package/src/utils/__testfixtures__/StubQueryContextProvider.ts +2 -2
  499. package/src/utils/__testfixtures__/TestEntity.ts +7 -7
  500. package/src/utils/__testfixtures__/TestEntity2.ts +6 -6
  501. package/src/utils/__testfixtures__/TestEntityWithMutationTriggers.ts +6 -10
  502. package/src/utils/__testfixtures__/TestViewerContext.ts +2 -2
  503. package/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.ts +5 -5
  504. package/src/utils/__testfixtures__/describeFieldTestCase.ts +3 -1
  505. package/src/utils/__tests__/EntityCreationUtils-test.ts +356 -0
  506. package/src/utils/__tests__/EntityPrivacyUtils-test.ts +15 -13
  507. package/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.ts +10 -8
  508. package/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.ts +2 -0
  509. package/src/utils/collections/__tests__/SerializableKeyMap-test.ts +2 -0
  510. package/src/utils/collections/__tests__/maps-test.ts +3 -1
  511. package/src/utils/collections/__tests__/sets-test.ts +2 -0
  512. package/src/utils/mergeEntityMutationTriggerConfigurations.ts +3 -3
  513. package/build/AuthorizationResultBasedEntityAssociationLoader.js.map +0 -1
  514. package/build/AuthorizationResultBasedEntityLoader.js.map +0 -1
  515. package/build/AuthorizationResultBasedEntityMutator.js.map +0 -1
  516. package/build/ComposedEntityCacheAdapter.js.map +0 -1
  517. package/build/ComposedSecondaryEntityCache.js.map +0 -1
  518. package/build/EnforcingEntityAssociationLoader.js.map +0 -1
  519. package/build/EnforcingEntityCreator.js.map +0 -1
  520. package/build/EnforcingEntityDeleter.js.map +0 -1
  521. package/build/EnforcingEntityLoader.js.map +0 -1
  522. package/build/EnforcingEntityUpdater.js.map +0 -1
  523. package/build/Entity.js.map +0 -1
  524. package/build/EntityAssociationLoader.js.map +0 -1
  525. package/build/EntityCompanion.js.map +0 -1
  526. package/build/EntityCompanionProvider.js.map +0 -1
  527. package/build/EntityConfiguration.js.map +0 -1
  528. package/build/EntityDatabaseAdapter.js.map +0 -1
  529. package/build/EntityFieldDefinition.js.map +0 -1
  530. package/build/EntityFields.js.map +0 -1
  531. package/build/EntityLoaderFactory.js +0 -31
  532. package/build/EntityLoaderFactory.js.map +0 -1
  533. package/build/EntityLoaderUtils.js.map +0 -1
  534. package/build/EntityMutationInfo.js.map +0 -1
  535. package/build/EntityMutationTriggerConfiguration.js.map +0 -1
  536. package/build/EntityMutationValidator.js.map +0 -1
  537. package/build/EntityMutatorFactory.js.map +0 -1
  538. package/build/EntityQueryContext.js.map +0 -1
  539. package/build/EntityQueryContextProvider.js.map +0 -1
  540. package/build/EntitySecondaryCacheLoader.js.map +0 -1
  541. package/build/GenericEntityCacheAdapter.js.map +0 -1
  542. package/build/GenericSecondaryEntityCache.js.map +0 -1
  543. package/build/IEntityCacheAdapter.js.map +0 -1
  544. package/build/IEntityCacheAdapterProvider.js.map +0 -1
  545. package/build/IEntityDatabaseAdapterProvider.js.map +0 -1
  546. package/build/IEntityGenericCacher.js.map +0 -1
  547. package/build/ReadonlyEntity.js.map +0 -1
  548. package/build/ViewerScopedEntityCompanionProvider.js.map +0 -1
  549. package/build/ViewerScopedEntityLoaderFactory.js.map +0 -1
  550. package/build/ViewerScopedEntityMutatorFactory.js.map +0 -1
  551. package/build/entityUtils.js.map +0 -1
  552. package/build/errors/EntityCacheAdapterError.js +0 -46
  553. package/build/errors/EntityCacheAdapterError.js.map +0 -1
  554. package/build/errors/EntityDatabaseAdapterError.js.map +0 -1
  555. package/build/errors/EntityError.js.map +0 -1
  556. package/build/errors/EntityInvalidFieldValueError.js +0 -45
  557. package/build/errors/EntityInvalidFieldValueError.js.map +0 -1
  558. package/build/errors/EntityNotAuthorizedError.js +0 -48
  559. package/build/errors/EntityNotAuthorizedError.js.map +0 -1
  560. package/build/errors/EntityNotFoundError.d.ts +0 -10
  561. package/build/errors/EntityNotFoundError.js +0 -45
  562. package/build/errors/EntityNotFoundError.js.map +0 -1
  563. package/build/index.d.ts +0 -90
  564. package/build/index.js +0 -154
  565. package/build/index.js.map +0 -1
  566. package/build/internal/CompositeFieldHolder.js.map +0 -1
  567. package/build/internal/CompositeFieldValueMap.js.map +0 -1
  568. package/build/internal/EntityDataManager.js.map +0 -1
  569. package/build/internal/EntityFieldTransformationUtils.js.map +0 -1
  570. package/build/internal/EntityLoadInterfaces.js.map +0 -1
  571. package/build/internal/ReadThroughEntityCache.js.map +0 -1
  572. package/build/internal/SingleFieldHolder.js.map +0 -1
  573. package/build/metrics/EntityMetricsUtils.js.map +0 -1
  574. package/build/metrics/IEntityMetricsAdapter.js.map +0 -1
  575. package/build/metrics/NoOpEntityMetricsAdapter.js.map +0 -1
  576. package/build/rules/AlwaysAllowPrivacyPolicyRule.js +0 -46
  577. package/build/rules/AlwaysAllowPrivacyPolicyRule.js.map +0 -1
  578. package/build/rules/AlwaysDenyPrivacyPolicyRule.js +0 -46
  579. package/build/rules/AlwaysDenyPrivacyPolicyRule.js.map +0 -1
  580. package/build/rules/AlwaysSkipPrivacyPolicyRule.js +0 -46
  581. package/build/rules/AlwaysSkipPrivacyPolicyRule.js.map +0 -1
  582. package/build/rules/PrivacyPolicyRule.js.map +0 -1
  583. package/build/tsconfig.build.tsbuildinfo +0 -1
  584. package/build/utils/collections/SerializableKeyMap.js.map +0 -1
  585. package/build/utils/collections/maps.js.map +0 -1
  586. package/build/utils/collections/sets.js.map +0 -1
  587. package/build/utils/mergeEntityMutationTriggerConfigurations.js.map +0 -1
  588. /package/build/{EntityFieldDefinition.js → src/EntityFieldDefinition.js} +0 -0
  589. /package/build/{EntityFields.d.ts → src/EntityFields.d.ts} +0 -0
  590. /package/build/{EntityFields.js → src/EntityFields.js} +0 -0
  591. /package/build/{EntityMutationInfo.js → src/EntityMutationInfo.js} +0 -0
  592. /package/build/{EntityMutationTriggerConfiguration.js → src/EntityMutationTriggerConfiguration.js} +0 -0
  593. /package/build/{EntityQueryContext.js → src/EntityQueryContext.js} +0 -0
  594. /package/build/{IEntityCacheAdapter.js → src/IEntityCacheAdapter.js} +0 -0
  595. /package/build/{IEntityCacheAdapterProvider.js → src/IEntityCacheAdapterProvider.js} +0 -0
  596. /package/build/{IEntityDatabaseAdapterProvider.js → src/IEntityDatabaseAdapterProvider.js} +0 -0
  597. /package/build/{IEntityGenericCacher.js → src/IEntityGenericCacher.js} +0 -0
  598. /package/build/{entityUtils.d.ts → src/entityUtils.d.ts} +0 -0
  599. /package/build/{entityUtils.js → src/entityUtils.js} +0 -0
  600. /package/build/{internal → src/internal}/CompositeFieldHolder.js +0 -0
  601. /package/build/{internal → src/internal}/CompositeFieldValueMap.d.ts +0 -0
  602. /package/build/{internal → src/internal}/CompositeFieldValueMap.js +0 -0
  603. /package/build/{internal → src/internal}/EntityFieldTransformationUtils.js +0 -0
  604. /package/build/{internal → src/internal}/EntityLoadInterfaces.js +0 -0
  605. /package/build/{internal → src/internal}/SingleFieldHolder.js +0 -0
  606. /package/build/{metrics → src/metrics}/EntityMetricsUtils.js +0 -0
  607. /package/build/{metrics → src/metrics}/IEntityMetricsAdapter.js +0 -0
  608. /package/build/{utils → src/utils}/collections/SerializableKeyMap.d.ts +0 -0
  609. /package/build/{utils → src/utils}/collections/SerializableKeyMap.js +0 -0
  610. /package/build/{utils → src/utils}/collections/maps.d.ts +0 -0
  611. /package/build/{utils → src/utils}/collections/maps.js +0 -0
  612. /package/build/{utils → src/utils}/collections/sets.d.ts +0 -0
  613. /package/build/{utils → src/utils}/collections/sets.js +0 -0
  614. /package/build/{utils → src/utils}/mergeEntityMutationTriggerConfigurations.js +0 -0
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InMemoryFullCacheStubCacheAdapter = exports.InMemoryFullCacheStubCacheAdapterProvider = exports.DOES_NOT_EXIST = exports.NoCacheStubCacheAdapter = exports.NoCacheStubCacheAdapterProvider = void 0;
7
+ const invariant_1 = __importDefault(require("invariant"));
8
+ const ReadThroughEntityCache_1 = require("../../internal/ReadThroughEntityCache");
9
+ class NoCacheStubCacheAdapterProvider {
10
+ getCacheAdapter(_entityConfiguration) {
11
+ return new NoCacheStubCacheAdapter();
12
+ }
13
+ }
14
+ exports.NoCacheStubCacheAdapterProvider = NoCacheStubCacheAdapterProvider;
15
+ class NoCacheStubCacheAdapter {
16
+ async loadManyAsync(key, values) {
17
+ return values.reduce((acc, v) => {
18
+ acc.set(v, {
19
+ status: ReadThroughEntityCache_1.CacheStatus.MISS,
20
+ });
21
+ return acc;
22
+ }, key.vendNewLoadValueMap());
23
+ }
24
+ async cacheManyAsync(_key, _objectMap) { }
25
+ async cacheDBMissesAsync(_key, _values) { }
26
+ async invalidateManyAsync(_key, _values) { }
27
+ }
28
+ exports.NoCacheStubCacheAdapter = NoCacheStubCacheAdapter;
29
+ // Sentinel value we store in the in-memory cache to negatively cache a database miss.
30
+ // The sentinel value is distinct from any (positively) cached value.
31
+ exports.DOES_NOT_EXIST = Symbol('inMemoryCacheDoesNotExistValue');
32
+ class InMemoryFullCacheStubCacheAdapterProvider {
33
+ cache = new Map();
34
+ getCacheAdapter(entityConfiguration) {
35
+ return new InMemoryFullCacheStubCacheAdapter(entityConfiguration, this.cache);
36
+ }
37
+ }
38
+ exports.InMemoryFullCacheStubCacheAdapterProvider = InMemoryFullCacheStubCacheAdapterProvider;
39
+ class InMemoryFullCacheStubCacheAdapter {
40
+ entityConfiguration;
41
+ cache;
42
+ constructor(entityConfiguration, cache) {
43
+ this.entityConfiguration = entityConfiguration;
44
+ this.cache = cache;
45
+ }
46
+ async loadManyAsync(key, values) {
47
+ const results = key.vendNewLoadValueMap();
48
+ values.forEach((value) => {
49
+ const cacheKey = this.createCacheKey(key, value);
50
+ if (!this.cache.has(cacheKey)) {
51
+ results.set(value, {
52
+ status: ReadThroughEntityCache_1.CacheStatus.MISS,
53
+ });
54
+ }
55
+ else {
56
+ const objectForFieldValue = this.cache.get(cacheKey);
57
+ (0, invariant_1.default)(objectForFieldValue !== undefined, 'should have set value for key');
58
+ if (objectForFieldValue === exports.DOES_NOT_EXIST) {
59
+ results.set(value, {
60
+ status: ReadThroughEntityCache_1.CacheStatus.NEGATIVE,
61
+ });
62
+ }
63
+ else {
64
+ results.set(value, {
65
+ status: ReadThroughEntityCache_1.CacheStatus.HIT,
66
+ item: objectForFieldValue,
67
+ });
68
+ }
69
+ }
70
+ });
71
+ return results;
72
+ }
73
+ async cacheManyAsync(key, objectMap) {
74
+ objectMap.forEach((obj, value) => {
75
+ const cacheKey = this.createCacheKey(key, value);
76
+ this.cache.set(cacheKey, obj);
77
+ });
78
+ }
79
+ async cacheDBMissesAsync(key, values) {
80
+ values.forEach((value) => {
81
+ const cacheKey = this.createCacheKey(key, value);
82
+ this.cache.set(cacheKey, exports.DOES_NOT_EXIST);
83
+ });
84
+ }
85
+ async invalidateManyAsync(key, values) {
86
+ values.forEach((value) => {
87
+ const cacheKey = this.createCacheKey(key, value);
88
+ this.cache.delete(cacheKey);
89
+ });
90
+ }
91
+ createCacheKey(key, value) {
92
+ const cacheKeyType = key.getLoadMethodType();
93
+ const parts = key.createCacheKeyPartsForLoadValue(this.entityConfiguration, value);
94
+ return [
95
+ this.entityConfiguration.tableName,
96
+ cacheKeyType,
97
+ `v${this.entityConfiguration.cacheKeyVersion}`,
98
+ ...parts,
99
+ ].join(':');
100
+ }
101
+ }
102
+ exports.InMemoryFullCacheStubCacheAdapter = InMemoryFullCacheStubCacheAdapter;
103
+ //# sourceMappingURL=StubCacheAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StubCacheAdapter.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubCacheAdapter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { EntityConfiguration } from '../../EntityConfiguration';
2
+ import { EntityDatabaseAdapter, TableFieldMultiValueEqualityCondition, TableFieldSingleValueEqualityCondition, TableQuerySelectionModifiers } from '../../EntityDatabaseAdapter';
3
+ import { FieldTransformerMap } from '../../internal/EntityFieldTransformationUtils';
4
+ export declare class StubDatabaseAdapter<TFields extends Record<string, any>, TIDField extends keyof TFields> extends EntityDatabaseAdapter<TFields, TIDField> {
5
+ private readonly entityConfiguration2;
6
+ private readonly dataStore;
7
+ constructor(entityConfiguration2: EntityConfiguration<TFields, TIDField>, dataStore: Map<string, Readonly<{
8
+ [key: string]: any;
9
+ }>[]>);
10
+ static convertFieldObjectsToDataStore<TFields extends Record<string, any>, TIDField extends keyof TFields>(entityConfiguration: EntityConfiguration<TFields, TIDField>, dataStore: Map<string, Readonly<TFields>[]>): Map<string, Readonly<{
11
+ [key: string]: any;
12
+ }>[]>;
13
+ getObjectCollectionForTable(tableName: string): {
14
+ [key: string]: any;
15
+ }[];
16
+ protected getFieldTransformerMap(): FieldTransformerMap;
17
+ private static uniqBy;
18
+ protected fetchManyWhereInternalAsync(_queryInterface: any, tableName: string, tableColumns: readonly string[], tableTuples: (readonly any[])[]): Promise<object[]>;
19
+ private static compareByOrderBys;
20
+ protected fetchManyByFieldEqualityConjunctionInternalAsync(_queryInterface: any, tableName: string, tableFieldSingleValueEqualityOperands: TableFieldSingleValueEqualityCondition[], tableFieldMultiValueEqualityOperands: TableFieldMultiValueEqualityCondition[], querySelectionModifiers: TableQuerySelectionModifiers): Promise<object[]>;
21
+ protected fetchManyByRawWhereClauseInternalAsync(_queryInterface: any, _tableName: string, _rawWhereClause: string, _bindings: object | any[], _querySelectionModifiers: TableQuerySelectionModifiers): Promise<object[]>;
22
+ private generateRandomID;
23
+ protected insertInternalAsync(_queryInterface: any, tableName: string, object: object): Promise<object[]>;
24
+ protected updateInternalAsync(_queryInterface: any, tableName: string, tableIdField: string, id: any, object: object): Promise<object[]>;
25
+ protected deleteInternalAsync(_queryInterface: any, tableName: string, tableIdField: string, id: any): Promise<number>;
26
+ }
@@ -0,0 +1,173 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.StubDatabaseAdapter = void 0;
7
+ const invariant_1 = __importDefault(require("invariant"));
8
+ const uuidv7_1 = require("uuidv7");
9
+ const EntityDatabaseAdapter_1 = require("../../EntityDatabaseAdapter");
10
+ const EntityFields_1 = require("../../EntityFields");
11
+ const EntityFieldTransformationUtils_1 = require("../../internal/EntityFieldTransformationUtils");
12
+ const maps_1 = require("../collections/maps");
13
+ class StubDatabaseAdapter extends EntityDatabaseAdapter_1.EntityDatabaseAdapter {
14
+ entityConfiguration2;
15
+ dataStore;
16
+ constructor(entityConfiguration2, dataStore) {
17
+ super(entityConfiguration2);
18
+ this.entityConfiguration2 = entityConfiguration2;
19
+ this.dataStore = dataStore;
20
+ }
21
+ static convertFieldObjectsToDataStore(entityConfiguration, dataStore) {
22
+ return (0, maps_1.mapMap)(dataStore, (objectsForTable) => objectsForTable.map((objectForTable) => (0, EntityFieldTransformationUtils_1.transformFieldsToDatabaseObject)(entityConfiguration, new Map(), objectForTable)));
23
+ }
24
+ getObjectCollectionForTable(tableName) {
25
+ return (0, maps_1.computeIfAbsent)(this.dataStore, tableName, () => []);
26
+ }
27
+ getFieldTransformerMap() {
28
+ return new Map();
29
+ }
30
+ static uniqBy(a, keyExtractor) {
31
+ const seen = new Set();
32
+ return a.filter((item) => {
33
+ const k = keyExtractor(item);
34
+ if (seen.has(k)) {
35
+ return false;
36
+ }
37
+ seen.add(k);
38
+ return true;
39
+ });
40
+ }
41
+ async fetchManyWhereInternalAsync(_queryInterface, tableName, tableColumns, tableTuples) {
42
+ const objectCollection = this.getObjectCollectionForTable(tableName);
43
+ const results = StubDatabaseAdapter.uniqBy(tableTuples, (tuple) => tuple.join(':')).reduce((acc, tableTuple) => {
44
+ return acc.concat(objectCollection.filter((obj) => {
45
+ return tableColumns.every((tableColumn, index) => {
46
+ return obj[tableColumn] === tableTuple[index];
47
+ });
48
+ }));
49
+ }, []);
50
+ return [...results];
51
+ }
52
+ static compareByOrderBys(orderBys, objectA, objectB) {
53
+ if (orderBys.length === 0) {
54
+ return 0;
55
+ }
56
+ const currentOrderBy = orderBys[0];
57
+ const aField = objectA[currentOrderBy.columnName];
58
+ const bField = objectB[currentOrderBy.columnName];
59
+ switch (currentOrderBy.order) {
60
+ case EntityDatabaseAdapter_1.OrderByOrdering.DESCENDING: {
61
+ // simulate NULLS FIRST for DESC
62
+ if (aField === null && bField === null) {
63
+ return 0;
64
+ }
65
+ else if (aField === null) {
66
+ return -1;
67
+ }
68
+ else if (bField === null) {
69
+ return 1;
70
+ }
71
+ return aField > bField
72
+ ? -1
73
+ : aField < bField
74
+ ? 1
75
+ : this.compareByOrderBys(orderBys.slice(1), objectA, objectB);
76
+ }
77
+ case EntityDatabaseAdapter_1.OrderByOrdering.ASCENDING: {
78
+ // simulate NULLS LAST for ASC
79
+ if (aField === null && bField === null) {
80
+ return 0;
81
+ }
82
+ else if (bField === null) {
83
+ return -1;
84
+ }
85
+ else if (aField === null) {
86
+ return 1;
87
+ }
88
+ return bField > aField
89
+ ? -1
90
+ : bField < aField
91
+ ? 1
92
+ : this.compareByOrderBys(orderBys.slice(1), objectA, objectB);
93
+ }
94
+ }
95
+ }
96
+ async fetchManyByFieldEqualityConjunctionInternalAsync(_queryInterface, tableName, tableFieldSingleValueEqualityOperands, tableFieldMultiValueEqualityOperands, querySelectionModifiers) {
97
+ let filteredObjects = this.getObjectCollectionForTable(tableName);
98
+ for (const { tableField, tableValue } of tableFieldSingleValueEqualityOperands) {
99
+ filteredObjects = filteredObjects.filter((obj) => obj[tableField] === tableValue);
100
+ }
101
+ for (const { tableField, tableValues } of tableFieldMultiValueEqualityOperands) {
102
+ filteredObjects = filteredObjects.filter((obj) => tableValues.includes(obj[tableField]));
103
+ }
104
+ const orderBy = querySelectionModifiers.orderBy;
105
+ if (orderBy !== undefined) {
106
+ filteredObjects = filteredObjects.sort((a, b) => StubDatabaseAdapter.compareByOrderBys(orderBy, a, b));
107
+ }
108
+ const offset = querySelectionModifiers.offset;
109
+ if (offset !== undefined) {
110
+ filteredObjects = filteredObjects.slice(offset);
111
+ }
112
+ const limit = querySelectionModifiers.limit;
113
+ if (limit !== undefined) {
114
+ filteredObjects = filteredObjects.slice(0, 0 + limit);
115
+ }
116
+ return filteredObjects;
117
+ }
118
+ fetchManyByRawWhereClauseInternalAsync(_queryInterface, _tableName, _rawWhereClause, _bindings, _querySelectionModifiers) {
119
+ throw new Error('Raw WHERE clauses not supported for StubDatabaseAdapter');
120
+ }
121
+ generateRandomID() {
122
+ const idSchemaField = this.entityConfiguration2.schema.get(this.entityConfiguration2.idField);
123
+ (0, invariant_1.default)(idSchemaField, `No schema field found for ${String(this.entityConfiguration2.idField)}`);
124
+ if (idSchemaField instanceof EntityFields_1.StringField) {
125
+ return (0, uuidv7_1.uuidv7)();
126
+ }
127
+ else if (idSchemaField instanceof EntityFields_1.IntField) {
128
+ return Math.floor(Math.random() * Number.MAX_SAFE_INTEGER);
129
+ }
130
+ else {
131
+ throw new Error(`Unsupported ID type for StubDatabaseAdapter: ${idSchemaField.constructor.name}`);
132
+ }
133
+ }
134
+ async insertInternalAsync(_queryInterface, tableName, object) {
135
+ const objectCollection = this.getObjectCollectionForTable(tableName);
136
+ const idField = (0, EntityFieldTransformationUtils_1.getDatabaseFieldForEntityField)(this.entityConfiguration2, this.entityConfiguration2.idField);
137
+ const objectToInsert = {
138
+ [idField]: this.generateRandomID(),
139
+ ...object,
140
+ };
141
+ objectCollection.push(objectToInsert);
142
+ return [objectToInsert];
143
+ }
144
+ async updateInternalAsync(_queryInterface, tableName, tableIdField, id, object) {
145
+ // SQL does not support empty updates, mirror behavior here for better test simulation
146
+ if (Object.keys(object).length === 0) {
147
+ throw new Error(`Empty update (${tableIdField} = ${id})`);
148
+ }
149
+ const objectCollection = this.getObjectCollectionForTable(tableName);
150
+ const objectIndex = objectCollection.findIndex((obj) => {
151
+ return obj[tableIdField] === id;
152
+ });
153
+ (0, invariant_1.default)(objectIndex >= 0, 'should exist');
154
+ objectCollection[objectIndex] = {
155
+ ...objectCollection[objectIndex],
156
+ ...object,
157
+ };
158
+ return [objectCollection[objectIndex]];
159
+ }
160
+ async deleteInternalAsync(_queryInterface, tableName, tableIdField, id) {
161
+ const objectCollection = this.getObjectCollectionForTable(tableName);
162
+ const objectIndex = objectCollection.findIndex((obj) => {
163
+ return obj[tableIdField] === id;
164
+ });
165
+ if (objectIndex < 0) {
166
+ return 0;
167
+ }
168
+ objectCollection.splice(objectIndex, 1);
169
+ return 1;
170
+ }
171
+ }
172
+ exports.StubDatabaseAdapter = StubDatabaseAdapter;
173
+ //# sourceMappingURL=StubDatabaseAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StubDatabaseAdapter.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubDatabaseAdapter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { EntityConfiguration } from '../../EntityConfiguration';
2
+ import { EntityDatabaseAdapter } from '../../EntityDatabaseAdapter';
3
+ import { IEntityDatabaseAdapterProvider } from '../../IEntityDatabaseAdapterProvider';
4
+ export declare class StubDatabaseAdapterProvider implements IEntityDatabaseAdapterProvider {
5
+ private readonly objectCollection;
6
+ getDatabaseAdapter<TFields extends Record<string, any>, TIDField extends keyof TFields>(entityConfiguration: EntityConfiguration<TFields, TIDField>): EntityDatabaseAdapter<TFields, TIDField>;
7
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StubDatabaseAdapterProvider = void 0;
4
+ const StubDatabaseAdapter_1 = require("../__testfixtures__/StubDatabaseAdapter");
5
+ class StubDatabaseAdapterProvider {
6
+ objectCollection = new Map();
7
+ getDatabaseAdapter(entityConfiguration) {
8
+ return new StubDatabaseAdapter_1.StubDatabaseAdapter(entityConfiguration, this.objectCollection);
9
+ }
10
+ }
11
+ exports.StubDatabaseAdapterProvider = StubDatabaseAdapterProvider;
12
+ //# sourceMappingURL=StubDatabaseAdapterProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StubDatabaseAdapterProvider.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubDatabaseAdapterProvider.ts"],"names":[],"mappings":";;;AAGA,iFAA8E;AAE9E,MAAa,2BAA2B;IACrB,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAC;IAE9C,kBAAkB,CAChB,mBAA2D;QAE3D,OAAO,IAAI,yCAAmB,CAAC,mBAAmB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7E,CAAC;CACF;AARD,kEAQC"}
@@ -0,0 +1,7 @@
1
+ import { TransactionConfig } from '../../EntityQueryContext';
2
+ import { EntityQueryContextProvider } from '../../EntityQueryContextProvider';
3
+ export declare class StubQueryContextProvider extends EntityQueryContextProvider {
4
+ protected getQueryInterface(): any;
5
+ protected createTransactionRunner<T>(_transactionConfig?: TransactionConfig): (transactionScope: (queryInterface: any) => Promise<T>) => Promise<T>;
6
+ protected createNestedTransactionRunner<T>(_outerQueryInterface: any): (transactionScope: (queryInterface: any) => Promise<T>) => Promise<T>;
7
+ }
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StubQueryContextProvider = void 0;
4
+ const EntityQueryContextProvider_1 = require("../../EntityQueryContextProvider");
5
+ class StubQueryContextProvider extends EntityQueryContextProvider_1.EntityQueryContextProvider {
6
+ getQueryInterface() {
7
+ return {};
8
+ }
9
+ createTransactionRunner(_transactionConfig) {
10
+ return (transactionScope) => Promise.resolve(transactionScope({}));
11
+ }
12
+ createNestedTransactionRunner(_outerQueryInterface) {
13
+ return (transactionScope) => Promise.resolve(transactionScope({}));
14
+ }
15
+ }
16
+ exports.StubQueryContextProvider = StubQueryContextProvider;
17
+ //# sourceMappingURL=StubQueryContextProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StubQueryContextProvider.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/StubQueryContextProvider.ts"],"names":[],"mappings":";;;AACA,iFAA8E;AAE9E,MAAa,wBAAyB,SAAQ,uDAA0B;IAC5D,iBAAiB;QACzB,OAAO,EAAE,CAAC;IACZ,CAAC;IAES,uBAAuB,CAC/B,kBAAsC;QAEtC,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;IACrE,CAAC;IAES,6BAA6B,CACrC,oBAAyB;QAEzB,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;IACrE,CAAC;CACF;AAhBD,4DAgBC"}
@@ -0,0 +1,9 @@
1
+ import { Matcher } from 'ts-mockito/lib/matcher/type/Matcher';
2
+ export declare function isEqualWithEntityAware(expected: any, actual: any): boolean;
3
+ export declare class DeepEqualEntityAwareMatcher<T> extends Matcher {
4
+ private readonly expectedValue;
5
+ constructor(expectedValue: T);
6
+ match(value: any): boolean;
7
+ toString(): string;
8
+ }
9
+ export declare function deepEqualEntityAware<T>(expectedValue: T): T;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DeepEqualEntityAwareMatcher = void 0;
7
+ exports.isEqualWithEntityAware = isEqualWithEntityAware;
8
+ exports.deepEqualEntityAware = deepEqualEntityAware;
9
+ const isEqualWith_1 = __importDefault(require("lodash/isEqualWith"));
10
+ const Matcher_1 = require("ts-mockito/lib/matcher/type/Matcher");
11
+ const CompositeFieldHolder_1 = require("../../internal/CompositeFieldHolder");
12
+ const SingleFieldHolder_1 = require("../../internal/SingleFieldHolder");
13
+ const SerializableKeyMap_1 = require("../collections/SerializableKeyMap");
14
+ function isEqualWithEntityAware(expected, actual) {
15
+ return (0, isEqualWith_1.default)(expected, actual, (expected, actual) => {
16
+ if (expected instanceof Matcher_1.Matcher) {
17
+ return expected.match(actual);
18
+ }
19
+ if (expected instanceof SingleFieldHolder_1.SingleFieldHolder && actual instanceof SingleFieldHolder_1.SingleFieldHolder) {
20
+ return expected.fieldName === actual.fieldName;
21
+ }
22
+ if (expected instanceof SingleFieldHolder_1.SingleFieldValueHolder && actual instanceof SingleFieldHolder_1.SingleFieldValueHolder) {
23
+ return expected.fieldValue === actual.fieldValue;
24
+ }
25
+ if (expected instanceof CompositeFieldHolder_1.CompositeFieldHolder && actual instanceof CompositeFieldHolder_1.CompositeFieldHolder) {
26
+ return expected.serialize() === actual.serialize();
27
+ }
28
+ if (expected instanceof CompositeFieldHolder_1.CompositeFieldValueHolder &&
29
+ actual instanceof CompositeFieldHolder_1.CompositeFieldValueHolder) {
30
+ return expected.serialize() === actual.serialize();
31
+ }
32
+ if (expected instanceof SerializableKeyMap_1.SerializableKeyMap && actual instanceof SerializableKeyMap_1.SerializableKeyMap) {
33
+ for (const [key, value] of expected.entries()) {
34
+ if (!actual.has(key) || !(0, isEqualWith_1.default)(value, actual.get(key))) {
35
+ return false;
36
+ }
37
+ }
38
+ return true;
39
+ }
40
+ return undefined;
41
+ });
42
+ }
43
+ class DeepEqualEntityAwareMatcher extends Matcher_1.Matcher {
44
+ expectedValue;
45
+ constructor(expectedValue) {
46
+ super();
47
+ this.expectedValue = expectedValue;
48
+ }
49
+ match(value) {
50
+ return isEqualWithEntityAware(this.expectedValue, value);
51
+ }
52
+ toString() {
53
+ if (this.expectedValue instanceof Array) {
54
+ return `deepEqualEntityAware([${this.expectedValue}])`;
55
+ }
56
+ else {
57
+ return `deepEqualEntityAware(${this.expectedValue})`;
58
+ }
59
+ }
60
+ }
61
+ exports.DeepEqualEntityAwareMatcher = DeepEqualEntityAwareMatcher;
62
+ function deepEqualEntityAware(expectedValue) {
63
+ return new DeepEqualEntityAwareMatcher(expectedValue);
64
+ }
65
+ //# sourceMappingURL=TSMockitoExtensions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TSMockitoExtensions.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/TSMockitoExtensions.ts"],"names":[],"mappings":";;;;;;AAUA,wDAoCC;AAoBD,oDAEC;AApED,qEAA6C;AAC7C,iEAA8D;AAE9D,8EAG6C;AAC7C,wEAA6F;AAC7F,0EAAuE;AAEvE,SAAgB,sBAAsB,CAAC,QAAa,EAAE,MAAW;IAC/D,OAAO,IAAA,qBAAW,EAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAa,EAAE,MAAW,EAAuB,EAAE;QACvF,IAAI,QAAQ,YAAY,iBAAO,EAAE,CAAC;YAChC,OAAO,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,QAAQ,YAAY,qCAAiB,IAAI,MAAM,YAAY,qCAAiB,EAAE,CAAC;YACjF,OAAO,QAAQ,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,CAAC;QACjD,CAAC;QAED,IAAI,QAAQ,YAAY,0CAAsB,IAAI,MAAM,YAAY,0CAAsB,EAAE,CAAC;YAC3F,OAAO,QAAQ,CAAC,UAAU,KAAK,MAAM,CAAC,UAAU,CAAC;QACnD,CAAC;QAED,IAAI,QAAQ,YAAY,2CAAoB,IAAI,MAAM,YAAY,2CAAoB,EAAE,CAAC;YACvF,OAAO,QAAQ,CAAC,SAAS,EAAE,KAAK,MAAM,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC;QAED,IACE,QAAQ,YAAY,gDAAyB;YAC7C,MAAM,YAAY,gDAAyB,EAC3C,CAAC;YACD,OAAO,QAAQ,CAAC,SAAS,EAAE,KAAK,MAAM,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,QAAQ,YAAY,uCAAkB,IAAI,MAAM,YAAY,uCAAkB,EAAE,CAAC;YACnF,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,IAAA,qBAAW,EAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC7D,OAAO,KAAK,CAAC;gBACf,CAAC;YACH,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAa,2BAA+B,SAAQ,iBAAO;IAC5B;IAA7B,YAA6B,aAAgB;QAC3C,KAAK,EAAE,CAAC;QADmB,kBAAa,GAAb,aAAa,CAAG;IAE7C,CAAC;IAEe,KAAK,CAAC,KAAU;QAC9B,OAAO,sBAAsB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAEe,QAAQ;QACtB,IAAI,IAAI,CAAC,aAAa,YAAY,KAAK,EAAE,CAAC;YACxC,OAAO,yBAAyB,IAAI,CAAC,aAAa,IAAI,CAAC;QACzD,CAAC;aAAM,CAAC;YACN,OAAO,wBAAwB,IAAI,CAAC,aAAa,GAAG,CAAC;QACvD,CAAC;IACH,CAAC;CACF;AAhBD,kEAgBC;AAED,SAAgB,oBAAoB,CAAI,aAAgB;IACtD,OAAO,IAAI,2BAA2B,CAAC,aAAa,CAAQ,CAAC;AAC/D,CAAC"}
@@ -0,0 +1,30 @@
1
+ import { Result } from '@expo/results';
2
+ import { Entity } from '../../Entity';
3
+ import { EntityCompanionDefinition } from '../../EntityCompanionProvider';
4
+ import { EntityConfiguration } from '../../EntityConfiguration';
5
+ import { EntityPrivacyPolicy } from '../../EntityPrivacyPolicy';
6
+ import { ViewerContext } from '../../ViewerContext';
7
+ import { AlwaysAllowPrivacyPolicyRule } from '../../rules/AlwaysAllowPrivacyPolicyRule';
8
+ export type TestFields = {
9
+ customIdField: string;
10
+ testIndexedField: string;
11
+ stringField: string;
12
+ intField: number;
13
+ dateField: Date;
14
+ nullableField: string | null;
15
+ };
16
+ export declare const testEntityConfiguration: EntityConfiguration<TestFields, "customIdField">;
17
+ export declare class TestEntityPrivacyPolicy extends EntityPrivacyPolicy<TestFields, 'customIdField', ViewerContext, TestEntity> {
18
+ protected readonly readRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
19
+ protected readonly createRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
20
+ protected readonly updateRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
21
+ protected readonly deleteRules: AlwaysAllowPrivacyPolicyRule<TestFields, "customIdField", ViewerContext, TestEntity, keyof TestFields>[];
22
+ }
23
+ export declare class TestEntity extends Entity<TestFields, 'customIdField', ViewerContext> {
24
+ static defineCompanionDefinition(): EntityCompanionDefinition<TestFields, 'customIdField', ViewerContext, TestEntity, TestEntityPrivacyPolicy>;
25
+ getBlah(): string;
26
+ static helloAsync(viewerContext: ViewerContext, testValue: string): Promise<Result<TestEntity>>;
27
+ static returnErrorAsync(_viewerContext: ViewerContext): Promise<Result<TestEntity>>;
28
+ static throwErrorAsync(_viewerContext: ViewerContext): Promise<Result<TestEntity>>;
29
+ static nonResultAsync(_viewerContext: ViewerContext, testValue: string): Promise<string>;
30
+ }
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TestEntity = exports.TestEntityPrivacyPolicy = exports.testEntityConfiguration = void 0;
4
+ const results_1 = require("@expo/results");
5
+ const Entity_1 = require("../../Entity");
6
+ const EntityConfiguration_1 = require("../../EntityConfiguration");
7
+ const EntityFields_1 = require("../../EntityFields");
8
+ const EntityPrivacyPolicy_1 = require("../../EntityPrivacyPolicy");
9
+ const AlwaysAllowPrivacyPolicyRule_1 = require("../../rules/AlwaysAllowPrivacyPolicyRule");
10
+ exports.testEntityConfiguration = new EntityConfiguration_1.EntityConfiguration({
11
+ idField: 'customIdField',
12
+ tableName: 'test_entity_should_not_write_to_db',
13
+ schema: {
14
+ customIdField: new EntityFields_1.UUIDField({
15
+ columnName: 'custom_id',
16
+ cache: true,
17
+ }),
18
+ testIndexedField: new EntityFields_1.StringField({
19
+ columnName: 'test_index',
20
+ cache: true,
21
+ }),
22
+ stringField: new EntityFields_1.StringField({
23
+ columnName: 'string_field',
24
+ }),
25
+ intField: new EntityFields_1.IntField({
26
+ columnName: 'number_field',
27
+ }),
28
+ dateField: new EntityFields_1.DateField({
29
+ columnName: 'date_field',
30
+ }),
31
+ nullableField: new EntityFields_1.StringField({
32
+ columnName: 'nullable_field',
33
+ }),
34
+ },
35
+ databaseAdapterFlavor: 'postgres',
36
+ cacheAdapterFlavor: 'redis',
37
+ compositeFieldDefinitions: [
38
+ { compositeField: ['stringField', 'intField'], cache: false },
39
+ { compositeField: ['stringField', 'testIndexedField'], cache: true },
40
+ { compositeField: ['nullableField', 'testIndexedField'], cache: true },
41
+ ],
42
+ });
43
+ class TestEntityPrivacyPolicy extends EntityPrivacyPolicy_1.EntityPrivacyPolicy {
44
+ readRules = [
45
+ new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
46
+ ];
47
+ createRules = [
48
+ new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
49
+ ];
50
+ updateRules = [
51
+ new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
52
+ ];
53
+ deleteRules = [
54
+ new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
55
+ ];
56
+ }
57
+ exports.TestEntityPrivacyPolicy = TestEntityPrivacyPolicy;
58
+ class TestEntity extends Entity_1.Entity {
59
+ static defineCompanionDefinition() {
60
+ return {
61
+ entityClass: TestEntity,
62
+ entityConfiguration: exports.testEntityConfiguration,
63
+ privacyPolicyClass: TestEntityPrivacyPolicy,
64
+ };
65
+ }
66
+ getBlah() {
67
+ return 'Hello World!';
68
+ }
69
+ static async helloAsync(viewerContext, testValue) {
70
+ const fields = {
71
+ customIdField: testValue,
72
+ testIndexedField: 'hello',
73
+ stringField: 'hello',
74
+ intField: 1,
75
+ dateField: new Date(),
76
+ nullableField: null,
77
+ };
78
+ return (0, results_1.result)(new TestEntity({
79
+ viewerContext,
80
+ id: testValue,
81
+ databaseFields: fields,
82
+ selectedFields: fields,
83
+ }));
84
+ }
85
+ static async returnErrorAsync(_viewerContext) {
86
+ return (0, results_1.result)(new Error('return entity'));
87
+ }
88
+ static async throwErrorAsync(_viewerContext) {
89
+ throw new Error('threw entity');
90
+ }
91
+ static async nonResultAsync(_viewerContext, testValue) {
92
+ return testValue;
93
+ }
94
+ }
95
+ exports.TestEntity = TestEntity;
96
+ //# sourceMappingURL=TestEntity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TestEntity.js","sourceRoot":"","sources":["../../../../src/utils/__testfixtures__/TestEntity.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { Entity } from '../../Entity';
2
+ import { EntityCompanionDefinition } from '../../EntityCompanionProvider';
3
+ import { EntityConfiguration } from '../../EntityConfiguration';
4
+ import { EntityPrivacyPolicy } from '../../EntityPrivacyPolicy';
5
+ import { ViewerContext } from '../../ViewerContext';
6
+ import { AlwaysAllowPrivacyPolicyRule } from '../../rules/AlwaysAllowPrivacyPolicyRule';
7
+ export type Test2Fields = {
8
+ id: string;
9
+ foreignKey: string;
10
+ };
11
+ export declare const testEntity2Configuration: EntityConfiguration<Test2Fields, "id">;
12
+ export declare class TestEntity2PrivacyPolicy extends EntityPrivacyPolicy<Test2Fields, 'id', ViewerContext, TestEntity2> {
13
+ protected readonly readRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
14
+ protected readonly createRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
15
+ protected readonly updateRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
16
+ protected readonly deleteRules: AlwaysAllowPrivacyPolicyRule<Test2Fields, "id", ViewerContext, TestEntity2, keyof Test2Fields>[];
17
+ }
18
+ export declare class TestEntity2 extends Entity<Test2Fields, 'id', ViewerContext> {
19
+ static defineCompanionDefinition(): EntityCompanionDefinition<Test2Fields, 'id', ViewerContext, TestEntity2, TestEntity2PrivacyPolicy>;
20
+ }