@intellegens/cornerstone-client 0.0.9999-alpha-41 → 0.0.9999-alpha-43

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 (233) hide show
  1. package/dist/adapters/collection-view-adapter.d.ts +123 -0
  2. package/dist/adapters/collection-view-adapter.integration.test.d.ts +1 -0
  3. package/dist/adapters/collection-view-adapter.integration.test.js +141 -0
  4. package/dist/adapters/collection-view-adapter.js +352 -0
  5. package/dist/adapters/index.d.ts +2 -2
  6. package/dist/adapters/index.js +2 -2
  7. package/dist/adapters/search-adapter.d.ts +83 -0
  8. package/dist/adapters/search-adapter.js +284 -0
  9. package/dist/data/api/dto/crud/crud-metadata-dto.js +1 -0
  10. package/dist/data/api/dto/crud/index.d.ts +1 -1
  11. package/dist/data/api/dto/crud/index.js +1 -1
  12. package/dist/data/api/dto/index.d.ts +1 -1
  13. package/dist/data/api/dto/index.js +1 -1
  14. package/dist/data/api/dto/property-path-dto.d.ts +4 -0
  15. package/dist/data/api/dto/property-path-dto.js +1 -0
  16. package/dist/data/api/dto/read/index.d.ts +10 -10
  17. package/dist/data/api/dto/read/index.js +10 -10
  18. package/dist/data/api/dto/read/read-metadata-dto.d.ts +8 -0
  19. package/dist/data/api/dto/read/read-metadata-dto.js +1 -0
  20. package/dist/data/api/dto/read/read-selected-definition-dto.d.ts +18 -0
  21. package/dist/data/api/dto/read/read-selected-definition-dto.js +1 -0
  22. package/dist/data/api/dto/read/read-selected-nested-collection-criteria-dto.d.ts +22 -0
  23. package/dist/data/api/dto/read/read-selected-nested-collection-criteria-dto.js +1 -0
  24. package/dist/data/api/dto/read/read-selected-nested-criteria-dto.d.ts +18 -0
  25. package/dist/data/api/dto/read/read-selected-nested-criteria-dto.js +1 -0
  26. package/dist/data/api/dto/read/read-selected-ordering-definition-dto.d.ts +7 -0
  27. package/dist/data/api/dto/read/read-selected-ordering-definition-dto.js +1 -0
  28. package/dist/data/api/dto/read/read-selected-ordering-property-definition-dto.d.ts +14 -0
  29. package/dist/data/api/dto/read/read-selected-ordering-property-definition-dto.js +1 -0
  30. package/dist/data/api/dto/read/read-selected-pagination-definition-dto.d.ts +13 -0
  31. package/dist/data/api/dto/read/read-selected-pagination-definition-dto.js +1 -0
  32. package/dist/data/api/dto/read/read-selected-search-definition-builder.d.ts +167 -0
  33. package/dist/data/api/dto/read/read-selected-search-definition-builder.js +267 -0
  34. package/dist/data/api/dto/read/read-selected-search-definition-dto.d.ts +33 -0
  35. package/dist/data/api/dto/read/read-selected-search-definition-dto.js +1 -0
  36. package/dist/data/api/dto/read/read-selected-search-property-definition-dto.d.ts +114 -0
  37. package/dist/data/api/dto/read/read-selected-search-property-definition-dto.js +1 -0
  38. package/dist/data/api/dto/read-options-dto.d.ts +8 -0
  39. package/dist/data/api/dto/read-options-dto.js +1 -0
  40. package/dist/data/api/dto/read-result-dto.d.ts +12 -0
  41. package/dist/data/api/dto/read-result-dto.js +1 -0
  42. package/dist/data/api/dto/read-result-metadata-dto.d.ts +8 -0
  43. package/dist/data/api/dto/read-result-metadata-dto.js +1 -0
  44. package/dist/data/api/dto/response/api-error-dto.d.ts +17 -0
  45. package/dist/data/api/dto/response/api-error-dto.js +1 -0
  46. package/dist/data/api/dto/response/api-error-response-dto.d.ts +11 -0
  47. package/dist/data/api/dto/response/api-error-response-dto.js +1 -0
  48. package/dist/data/api/dto/response/api-response-dto.d.ts +3 -0
  49. package/dist/data/api/dto/response/api-response-dto.js +1 -0
  50. package/dist/data/api/dto/response/api-success-response-dto.d.ts +13 -0
  51. package/dist/data/api/dto/response/api-success-response-dto.js +1 -0
  52. package/dist/data/api/dto/response/index.d.ts +5 -5
  53. package/dist/data/api/dto/response/index.js +5 -5
  54. package/dist/data/api/dto/response/metadata-dto.d.ts +25 -0
  55. package/dist/data/api/dto/response/metadata-dto.js +1 -0
  56. package/dist/data/api/enum/read/index.d.ts +5 -5
  57. package/dist/data/api/enum/read/index.js +5 -5
  58. package/dist/data/api/enum/read/read-selected-collection-operator.d.ts +16 -0
  59. package/dist/data/api/enum/read/read-selected-collection-operator.js +17 -0
  60. package/dist/data/api/enum/read/read-selected-comparison-operator.d.ts +69 -0
  61. package/dist/data/api/enum/read/read-selected-comparison-operator.js +76 -0
  62. package/dist/data/api/enum/read/read-selected-logical-operator.d.ts +15 -0
  63. package/dist/data/api/enum/read/read-selected-logical-operator.js +16 -0
  64. package/dist/data/api/enum/read/read-selected-ordering-direction.d.ts +13 -0
  65. package/dist/data/api/enum/read/read-selected-ordering-direction.js +14 -0
  66. package/dist/data/api/enum/read/read-selected-property-type.d.ts +66 -0
  67. package/dist/data/api/enum/read/read-selected-property-type.js +75 -0
  68. package/dist/data/api/enum/response/error-code.d.ts +14 -0
  69. package/dist/data/api/enum/response/error-code.js +15 -0
  70. package/dist/data/api/enum/response/index.d.ts +1 -1
  71. package/dist/data/api/enum/response/index.js +1 -1
  72. package/dist/data/api/interface/icommon-identifiable.d.ts +7 -0
  73. package/dist/data/api/interface/icommon-identifiable.js +1 -0
  74. package/dist/data/api/interface/iconcurrency-safe.d.ts +9 -0
  75. package/dist/data/api/interface/iconcurrency-safe.js +1 -0
  76. package/dist/data/api/interface/iidentifiable-secondary.d.ts +9 -0
  77. package/dist/data/api/interface/iidentifiable-secondary.js +1 -0
  78. package/dist/data/api/interface/iidentifiable.d.ts +11 -0
  79. package/dist/data/api/interface/iidentifiable.js +1 -0
  80. package/dist/data/api/interface/index.d.ts +4 -3
  81. package/dist/data/api/interface/index.js +4 -3
  82. package/dist/data/auth/dto/claim-dto.d.ts +4 -0
  83. package/dist/data/auth/dto/claim-dto.js +1 -0
  84. package/dist/data/auth/dto/index.d.ts +6 -5
  85. package/dist/data/auth/dto/index.js +6 -5
  86. package/dist/data/auth/dto/register-request-dto.d.ts +4 -0
  87. package/dist/data/auth/dto/register-request-dto.js +1 -0
  88. package/dist/data/auth/dto/role-dto.d.ts +5 -0
  89. package/dist/data/auth/dto/role-dto.js +1 -0
  90. package/dist/data/auth/dto/role-with-claims-dto.d.ts +5 -0
  91. package/dist/data/auth/dto/role-with-claims-dto.js +1 -0
  92. package/dist/data/auth/dto/sign-in-request-dto.d.ts +4 -0
  93. package/dist/data/auth/dto/sign-in-request-dto.js +1 -0
  94. package/dist/data/auth/dto/tokens-dto.d.ts +4 -0
  95. package/dist/data/auth/dto/tokens-dto.js +1 -0
  96. package/dist/data/auth/dto/user-dto.d.ts +16 -0
  97. package/dist/data/auth/dto/user-dto.js +1 -0
  98. package/dist/data/auth/dto/user-info-dto.d.ts +14 -0
  99. package/dist/data/auth/dto/user-info-dto.js +1 -0
  100. package/dist/services/api/api-crud-controller-client.d.ts +62 -0
  101. package/dist/services/api/api-crud-controller-client.integration.test.d.ts +1 -0
  102. package/dist/services/api/api-crud-controller-client.integration.test.js +34 -0
  103. package/dist/services/api/api-crud-controller-client.js +133 -0
  104. package/dist/services/api/api-initialization-service.d.ts +106 -0
  105. package/dist/services/api/api-initialization-service.js +207 -0
  106. package/dist/services/api/api-read-controller-client.d.ts +62 -0
  107. package/dist/services/api/api-read-controller-client.integration.test.d.ts +1 -0
  108. package/dist/services/api/api-read-controller-client.integration.test.js +59 -0
  109. package/dist/services/api/api-read-controller-client.js +129 -0
  110. package/dist/services/api/http-service/fetch-http-service.d.ts +7 -0
  111. package/dist/services/api/http-service/fetch-http-service.integration.test.d.ts +1 -0
  112. package/dist/services/api/http-service/fetch-http-service.integration.test.js +52 -0
  113. package/dist/services/api/http-service/fetch-http-service.js +29 -0
  114. package/dist/services/api/http-service/http-request-config.d.ts +10 -0
  115. package/dist/services/api/http-service/http-request-config.js +1 -0
  116. package/dist/services/api/http-service/http-response.d.ts +11 -0
  117. package/dist/services/api/http-service/http-response.js +3 -0
  118. package/dist/services/api/http-service/http-service.d.ts +5 -0
  119. package/dist/services/api/http-service/http-service.js +5 -0
  120. package/dist/services/api/http-service/ihttp-service.d.ts +13 -0
  121. package/dist/services/api/http-service/ihttp-service.js +3 -0
  122. package/dist/services/api/http-service/index.d.ts +5 -0
  123. package/dist/services/api/http-service/index.js +5 -0
  124. package/dist/services/api/index.d.ts +5 -5
  125. package/dist/services/api/index.js +5 -5
  126. package/dist/services/api/user-management-controller-client.d.ts +80 -0
  127. package/dist/services/api/user-management-controller-client.integration.test.d.ts +1 -0
  128. package/dist/services/api/user-management-controller-client.integration.test.js +60 -0
  129. package/dist/services/api/user-management-controller-client.js +291 -0
  130. package/dist/services/auth/client/auth-service.d.ts +75 -0
  131. package/dist/services/auth/client/auth-service.js +200 -0
  132. package/dist/services/auth/client/authorization-management-controller-client.d.ts +48 -0
  133. package/dist/services/auth/client/authorization-management-controller-client.integration.test.d.ts +1 -0
  134. package/dist/services/auth/client/authorization-management-controller-client.integration.test.js +89 -0
  135. package/dist/services/auth/client/authorization-management-controller-client.js +148 -0
  136. package/dist/services/auth/client/index.d.ts +2 -2
  137. package/dist/services/auth/client/index.js +2 -2
  138. package/dist/utils/authorization.d.ts +17 -0
  139. package/dist/utils/authorization.js +45 -0
  140. package/dist/utils/events.d.ts +19 -0
  141. package/dist/utils/events.js +12 -0
  142. package/dist/utils/index.d.ts +2 -0
  143. package/dist/utils/index.js +2 -0
  144. package/dist/utils/result.d.ts +21 -0
  145. package/dist/utils/result.js +16 -0
  146. package/dist/utils/search.d.ts +34 -0
  147. package/dist/utils/search.js +106 -0
  148. package/package.json +6 -6
  149. package/src/adapters/collection-view-adapter.integration.test.ts +172 -0
  150. package/src/adapters/collection-view-adapter.ts +458 -0
  151. package/src/adapters/index.ts +2 -2
  152. package/src/adapters/search-adapter.ts +374 -0
  153. package/src/data/api/dto/crud/crud-metadata-dto.ts +4 -0
  154. package/src/data/api/dto/crud/index.ts +1 -1
  155. package/src/data/api/dto/index.ts +1 -1
  156. package/src/data/api/dto/read/index.ts +10 -10
  157. package/src/data/api/dto/read/{ReadSelectedSearchDefinitionBuilder.ts → read-selected-search-definition-builder.ts} +4 -4
  158. package/src/data/api/dto/{ReadResultDto.ts → read-result-dto.ts} +1 -1
  159. package/src/data/api/dto/response/{ApiErrorDto.ts → api-error-dto.ts} +1 -1
  160. package/src/data/api/dto/response/index.ts +5 -5
  161. package/src/data/api/enum/read/index.ts +5 -5
  162. package/src/data/api/enum/response/{ErrorCode.ts → error-code.ts} +1 -0
  163. package/src/data/api/enum/response/index.ts +1 -1
  164. package/src/data/api/interface/{ICommonIdentifiable.ts → icommon-identifiable.ts} +1 -1
  165. package/src/data/api/interface/{IConcurrencySafe.ts → iconcurrency-safe.ts} +1 -1
  166. package/src/data/api/interface/{IIdentifiable.ts → iidentifiable.ts} +1 -1
  167. package/src/data/api/interface/index.ts +4 -3
  168. package/src/data/auth/dto/index.ts +6 -5
  169. package/src/data/auth/dto/role-with-claims-dto.ts +6 -0
  170. package/src/data/auth/dto/{UserDto.ts → user-dto.ts} +5 -6
  171. package/src/services/api/{ApiCrudControllerClient/index.integration.test.ts → api-crud-controller-client.integration.test.ts} +1 -1
  172. package/src/services/api/{ApiCrudControllerClient/index.ts → api-crud-controller-client.ts} +62 -7
  173. package/src/services/api/{ApiInitializationService/index.ts → api-initialization-service.ts} +2 -4
  174. package/src/services/api/{ApiReadControllerClient/index.integration.test.ts → api-read-controller-client.integration.test.ts} +1 -1
  175. package/src/services/api/{ApiReadControllerClient/index.ts → api-read-controller-client.ts} +55 -6
  176. package/src/services/api/{HttpService/FetchHttpService.integration.test.ts → http-service/fetch-http-service.integration.test.ts} +1 -1
  177. package/src/services/api/http-service/http-service.ts +6 -0
  178. package/src/services/api/http-service/index.ts +5 -0
  179. package/src/services/api/index.ts +5 -5
  180. package/src/services/api/{UserManagementControllerClient/index.integration.test.ts → user-management-controller-client.integration.test.ts} +1 -1
  181. package/src/services/api/user-management-controller-client.ts +322 -0
  182. package/src/services/auth/client/index.ts +2 -2
  183. package/src/utils/events.ts +29 -0
  184. package/src/utils/index.ts +2 -0
  185. package/demo/index.ts +0 -29
  186. package/demo/public_html/favicon.ico +0 -0
  187. package/demo/public_html/index.html +0 -105
  188. package/demo/public_html/websettings.json +0 -3
  189. package/src/adapters/CollectionViewAdapter/index.integration.test.ts +0 -197
  190. package/src/adapters/CollectionViewAdapter/index.ts +0 -477
  191. package/src/adapters/SearchAdapter/index.ts +0 -302
  192. package/src/services/api/HttpService/index.ts +0 -12
  193. package/src/services/api/UserManagementControllerClient/index.ts +0 -134
  194. /package/{src/data/api/dto/crud/CrudMetadataDto.ts → dist/data/api/dto/crud/crud-metadata-dto.d.ts} +0 -0
  195. /package/src/data/api/dto/{PropertyPathDto.ts → property-path-dto.ts} +0 -0
  196. /package/src/data/api/dto/read/{ReadMetadataDto.ts → read-metadata-dto.ts} +0 -0
  197. /package/src/data/api/dto/read/{ReadSelectedDefinitionDto.ts → read-selected-definition-dto.ts} +0 -0
  198. /package/src/data/api/dto/read/{ReadSelectedNestedCollectionCriteriaDto.ts → read-selected-nested-collection-criteria-dto.ts} +0 -0
  199. /package/src/data/api/dto/read/{ReadSelectedNestedCriteriaDto.ts → read-selected-nested-criteria-dto.ts} +0 -0
  200. /package/src/data/api/dto/read/{ReadSelectedOrderingDefinitionDto.ts → read-selected-ordering-definition-dto.ts} +0 -0
  201. /package/src/data/api/dto/read/{ReadSelectedOrderingPropertyDefinitionDto.ts → read-selected-ordering-property-definition-dto.ts} +0 -0
  202. /package/src/data/api/dto/read/{ReadSelectedPaginationDefinitionDto.ts → read-selected-pagination-definition-dto.ts} +0 -0
  203. /package/src/data/api/dto/read/{ReadSelectedSearchDefinitionDto.ts → read-selected-search-definition-dto.ts} +0 -0
  204. /package/src/data/api/dto/read/{ReadSelectedSearchPropertyDefinitionDto.ts → read-selected-search-property-definition-dto.ts} +0 -0
  205. /package/src/data/api/dto/{ReadOptionsDto.ts → read-options-dto.ts} +0 -0
  206. /package/src/data/api/dto/{ReadResultMetadataDto.ts → read-result-metadata-dto.ts} +0 -0
  207. /package/src/data/api/dto/response/{ApiErrorResponseDto.ts → api-error-response-dto.ts} +0 -0
  208. /package/src/data/api/dto/response/{ApiResponseDto.ts → api-response-dto.ts} +0 -0
  209. /package/src/data/api/dto/response/{ApiSuccessResponseDto.ts → api-success-response-dto.ts} +0 -0
  210. /package/src/data/api/dto/response/{MetadataDto.ts → metadata-dto.ts} +0 -0
  211. /package/src/data/api/enum/read/{ReadSelectedCollectionOperator.ts → read-selected-collection-operator.ts} +0 -0
  212. /package/src/data/api/enum/read/{ReadSelectedComparisonOperator.ts → read-selected-comparison-operator.ts} +0 -0
  213. /package/src/data/api/enum/read/{ReadSelectedLogicalOperator.ts → read-selected-logical-operator.ts} +0 -0
  214. /package/src/data/api/enum/read/{ReadSelectedOrderingDirection.ts → read-selected-ordering-direction.ts} +0 -0
  215. /package/src/data/api/enum/read/{ReadSelectedPropertyType.ts → read-selected-property-type.ts} +0 -0
  216. /package/src/data/api/interface/{IIdentifiableSecondary.ts → iidentifiable-secondary.ts} +0 -0
  217. /package/src/data/auth/dto/{ClaimDto.ts → claim-dto.ts} +0 -0
  218. /package/src/data/auth/dto/{RegisterRequestDto.ts → register-request-dto.ts} +0 -0
  219. /package/src/data/auth/dto/{RoleDto.ts → role-dto.ts} +0 -0
  220. /package/src/data/auth/dto/{SignInRequestDto.ts → sign-in-request-dto.ts} +0 -0
  221. /package/src/data/auth/dto/{TokensDto.ts → tokens-dto.ts} +0 -0
  222. /package/src/data/auth/dto/{UserInfoDto.ts → user-info-dto.ts} +0 -0
  223. /package/src/services/api/{HttpService → http-service}/README.md +0 -0
  224. /package/src/services/api/{HttpService/FetchHttpService.ts → http-service/fetch-http-service.ts} +0 -0
  225. /package/src/services/api/{HttpService/HttpRequestConfig.ts → http-service/http-request-config.ts} +0 -0
  226. /package/src/services/api/{HttpService/HttpResponse.ts → http-service/http-response.ts} +0 -0
  227. /package/src/services/api/{HttpService/IHttpService.ts → http-service/ihttp-service.ts} +0 -0
  228. /package/src/services/auth/client/{AuthService/index.ts → auth-service.ts} +0 -0
  229. /package/src/services/auth/client/{AuthorizationManagementControllerClient/index.integration.test.ts → authorization-management-controller-client.integration.test.ts} +0 -0
  230. /package/src/services/auth/client/{AuthorizationManagementControllerClient/index.ts → authorization-management-controller-client.ts} +0 -0
  231. /package/src/utils/{authorization/index.ts → authorization.ts} +0 -0
  232. /package/src/utils/{result/index.ts → result.ts} +0 -0
  233. /package/src/utils/{search/index.ts → search.ts} +0 -0
@@ -0,0 +1,167 @@
1
+ import { ReadSelectedComparisonOperator, ReadSelectedPropertyType } from '../../..';
2
+ import { ReadSelectedSearchDefinitionDto } from './read-selected-search-definition-dto';
3
+ /**
4
+ * Builder class for constructing ReadSelectedSearchDefinitionDto with a fluent API.
5
+ *
6
+ * @example
7
+ * // Simple AND search with property criteria
8
+ * const search = SearchBuilder.and<User>()
9
+ * .whereString('name', ReadSelectedComparisonOperator.IContains, 'John')
10
+ * .whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
11
+ * .build();
12
+ *
13
+ * @example
14
+ * // OR search with nested criteria (specify nested type for intellisense)
15
+ * const search = SearchBuilder.or<User>()
16
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'active')
17
+ * .nested<Address>('address', nested =>
18
+ * nested.whereString('city', ReadSelectedComparisonOperator.Equal, 'NYC')
19
+ * )
20
+ * .build();
21
+ *
22
+ * @example
23
+ * // Complex nested search with collection criteria
24
+ * const search = SearchBuilder.and<Order>()
25
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'pending')
26
+ * .any<OrderItem>('items', itemSearch =>
27
+ * itemSearch.whereNumber('quantity', ReadSelectedComparisonOperator.GreaterThan, 5)
28
+ * )
29
+ * .group(sub => sub.or()
30
+ * .whereString('priority', ReadSelectedComparisonOperator.Equal, 'high')
31
+ * .whereString('priority', ReadSelectedComparisonOperator.Equal, 'urgent')
32
+ * )
33
+ * .build();
34
+ */
35
+ export declare class SearchBuilder<T> {
36
+ private _logicalOperator;
37
+ private _searches;
38
+ private _propertyCriteria;
39
+ private _nestedCriteria;
40
+ private _nestedCollectionCriteria;
41
+ private constructor();
42
+ /**
43
+ * Creates a new builder with AND logical operator.
44
+ * All criteria added to this builder will be combined with AND.
45
+ */
46
+ static and<T>(): SearchBuilder<T>;
47
+ /**
48
+ * Creates a new builder with OR logical operator.
49
+ * All criteria added to this builder will be combined with OR.
50
+ */
51
+ static or<T>(): SearchBuilder<T>;
52
+ /**
53
+ * Sets the logical operator to AND.
54
+ */
55
+ and(): this;
56
+ /**
57
+ * Sets the logical operator to OR.
58
+ */
59
+ or(): this;
60
+ /**
61
+ * Adds a property comparison criterion.
62
+ *
63
+ * @param propertyName - The property to compare
64
+ * @param comparisonOperator - The comparison operator to use
65
+ * @param value - The value to compare against
66
+ * @param valueType - The type of the value
67
+ */
68
+ where<K extends keyof T>(propertyName: K, comparisonOperator: ReadSelectedComparisonOperator, value: unknown, valueType: ReadSelectedPropertyType): this;
69
+ /**
70
+ * Adds a string property comparison with common string operations.
71
+ */
72
+ whereString<K extends keyof T>(propertyName: K, comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.Contains | ReadSelectedComparisonOperator.StartsWith | ReadSelectedComparisonOperator.EndsWith | ReadSelectedComparisonOperator.IContains | ReadSelectedComparisonOperator.IStartsWith | ReadSelectedComparisonOperator.IEndsWith | ReadSelectedComparisonOperator.IEqual | ReadSelectedComparisonOperator.INotEqual, value: string): this;
73
+ /**
74
+ * Adds a number property comparison.
75
+ */
76
+ whereNumber<K extends keyof T>(propertyName: K, comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.LessThan | ReadSelectedComparisonOperator.LessOrEqual | ReadSelectedComparisonOperator.GreaterThan | ReadSelectedComparisonOperator.GreaterOrEqual, value: number, valueType?: ReadSelectedPropertyType.Int | ReadSelectedPropertyType.Short | ReadSelectedPropertyType.Long | ReadSelectedPropertyType.Decimal | ReadSelectedPropertyType.Double | ReadSelectedPropertyType.Float): this;
77
+ /**
78
+ * Adds a boolean property comparison.
79
+ */
80
+ whereBool<K extends keyof T>(propertyName: K, comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual, value: boolean): this;
81
+ /**
82
+ * Adds a date/time property comparison.
83
+ */
84
+ whereDate<K extends keyof T>(propertyName: K, comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.LessThan | ReadSelectedComparisonOperator.LessOrEqual | ReadSelectedComparisonOperator.GreaterThan | ReadSelectedComparisonOperator.GreaterOrEqual, value: string | Date, valueType?: ReadSelectedPropertyType.DateTime | ReadSelectedPropertyType.DateTimeOffset | ReadSelectedPropertyType.DateOnly | ReadSelectedPropertyType.TimeOnly | ReadSelectedPropertyType.TimeSpan): this;
85
+ /**
86
+ * Adds an isNull check for a property.
87
+ */
88
+ whereNull<K extends keyof T>(propertyName: K): this;
89
+ /**
90
+ * Adds an isNotNull check for a property.
91
+ */
92
+ whereNotNull<K extends keyof T>(propertyName: K): this;
93
+ /**
94
+ * Adds criteria for a nested object property (navigation property).
95
+ *
96
+ * @param propertyName - The navigation property name
97
+ * @param builderFn - A function that receives a new builder for the nested type
98
+ *
99
+ * @example
100
+ * // With explicit type for proper intellisense
101
+ * SearchBuilder.and<VehicleDto>()
102
+ * .nested<PersonDto>('driver', nested =>
103
+ * nested.whereString('name', ReadSelectedComparisonOperator.Contains, 'Alice')
104
+ * )
105
+ * .build();
106
+ */
107
+ nested<TNested, K extends keyof T = keyof T>(propertyName: K, builderFn: (builder: SearchBuilder<TNested>) => SearchBuilder<TNested>): this;
108
+ /**
109
+ * Adds criteria for a collection property with Any quantifier.
110
+ * Matches if at least one element in the collection satisfies the criteria.
111
+ *
112
+ * @param propertyName - The collection property name
113
+ * @param builderFn - A function that receives a new builder for the collection element type
114
+ *
115
+ * @example
116
+ * // With explicit type for proper intellisense
117
+ * SearchBuilder.and<VehicleDto>()
118
+ * .any<PersonDto>('passengers', passengers =>
119
+ * passengers.whereString('name', ReadSelectedComparisonOperator.Contains, 'Bob')
120
+ * )
121
+ * .build();
122
+ */
123
+ any<TElement, K extends keyof T = keyof T>(propertyName: K, builderFn: (builder: SearchBuilder<TElement>) => SearchBuilder<TElement>): this;
124
+ /**
125
+ * Adds criteria for a collection property with All quantifier.
126
+ * Matches if all elements in the collection satisfy the criteria.
127
+ *
128
+ * @param propertyName - The collection property name
129
+ * @param builderFn - A function that receives a new builder for the collection element type
130
+ *
131
+ * @example
132
+ * // With explicit type for proper intellisense
133
+ * SearchBuilder.and<VehicleDto>()
134
+ * .all<PersonDto>('passengers', passengers =>
135
+ * passengers.whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
136
+ * )
137
+ * .build();
138
+ */
139
+ all<TElement, K extends keyof T = keyof T>(propertyName: K, builderFn: (builder: SearchBuilder<TElement>) => SearchBuilder<TElement>): this;
140
+ /**
141
+ * Adds a nested search group. Use this for complex logical groupings.
142
+ *
143
+ * @param builderFn - A function that receives a new builder for creating the nested search
144
+ *
145
+ * @example
146
+ * // (name contains 'John') AND ((age > 18) OR (status = 'verified'))
147
+ * SearchBuilder.and<User>()
148
+ * .whereString('name', ReadSelectedComparisonOperator.IContains, 'John')
149
+ * .group(sub => sub.or()
150
+ * .whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
151
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'verified')
152
+ * )
153
+ * .build();
154
+ */
155
+ group(builderFn: (builder: SearchBuilder<T>) => SearchBuilder<T>): this;
156
+ /**
157
+ * Adds an existing search definition as a nested search.
158
+ *
159
+ * @param search - An existing ReadSelectedSearchDefinitionDto
160
+ */
161
+ addSearch(search: ReadSelectedSearchDefinitionDto<T>): this;
162
+ /**
163
+ * Builds and returns the ReadSelectedSearchDefinitionDto.
164
+ */
165
+ build(): ReadSelectedSearchDefinitionDto<T>;
166
+ private toPascalCase;
167
+ }
@@ -0,0 +1,267 @@
1
+ import { ReadSelectedCollectionOperator, ReadSelectedComparisonOperator, ReadSelectedLogicalOperator, ReadSelectedPropertyType } from '../../..';
2
+ /**
3
+ * Builder class for constructing ReadSelectedSearchDefinitionDto with a fluent API.
4
+ *
5
+ * @example
6
+ * // Simple AND search with property criteria
7
+ * const search = SearchBuilder.and<User>()
8
+ * .whereString('name', ReadSelectedComparisonOperator.IContains, 'John')
9
+ * .whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
10
+ * .build();
11
+ *
12
+ * @example
13
+ * // OR search with nested criteria (specify nested type for intellisense)
14
+ * const search = SearchBuilder.or<User>()
15
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'active')
16
+ * .nested<Address>('address', nested =>
17
+ * nested.whereString('city', ReadSelectedComparisonOperator.Equal, 'NYC')
18
+ * )
19
+ * .build();
20
+ *
21
+ * @example
22
+ * // Complex nested search with collection criteria
23
+ * const search = SearchBuilder.and<Order>()
24
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'pending')
25
+ * .any<OrderItem>('items', itemSearch =>
26
+ * itemSearch.whereNumber('quantity', ReadSelectedComparisonOperator.GreaterThan, 5)
27
+ * )
28
+ * .group(sub => sub.or()
29
+ * .whereString('priority', ReadSelectedComparisonOperator.Equal, 'high')
30
+ * .whereString('priority', ReadSelectedComparisonOperator.Equal, 'urgent')
31
+ * )
32
+ * .build();
33
+ */
34
+ export class SearchBuilder {
35
+ _logicalOperator;
36
+ _searches = [];
37
+ _propertyCriteria = [];
38
+ _nestedCriteria = [];
39
+ _nestedCollectionCriteria = [];
40
+ constructor(logicalOperator) {
41
+ this._logicalOperator = logicalOperator;
42
+ }
43
+ /**
44
+ * Creates a new builder with AND logical operator.
45
+ * All criteria added to this builder will be combined with AND.
46
+ */
47
+ static and() {
48
+ return new SearchBuilder(ReadSelectedLogicalOperator.And);
49
+ }
50
+ /**
51
+ * Creates a new builder with OR logical operator.
52
+ * All criteria added to this builder will be combined with OR.
53
+ */
54
+ static or() {
55
+ return new SearchBuilder(ReadSelectedLogicalOperator.Or);
56
+ }
57
+ /**
58
+ * Sets the logical operator to AND.
59
+ */
60
+ and() {
61
+ this._logicalOperator = ReadSelectedLogicalOperator.And;
62
+ return this;
63
+ }
64
+ /**
65
+ * Sets the logical operator to OR.
66
+ */
67
+ or() {
68
+ this._logicalOperator = ReadSelectedLogicalOperator.Or;
69
+ return this;
70
+ }
71
+ /**
72
+ * Adds a property comparison criterion.
73
+ *
74
+ * @param propertyName - The property to compare
75
+ * @param comparisonOperator - The comparison operator to use
76
+ * @param value - The value to compare against
77
+ * @param valueType - The type of the value
78
+ */
79
+ where(propertyName, comparisonOperator, value, valueType) {
80
+ this._propertyCriteria.push({
81
+ propertyName: this.toPascalCase(propertyName),
82
+ comparisonOperator,
83
+ value,
84
+ valueType,
85
+ });
86
+ return this;
87
+ }
88
+ /**
89
+ * Adds a string property comparison with common string operations.
90
+ */
91
+ whereString(propertyName, comparisonOperator, value) {
92
+ return this.where(propertyName, comparisonOperator, value, ReadSelectedPropertyType.String);
93
+ }
94
+ /**
95
+ * Adds a number property comparison.
96
+ */
97
+ whereNumber(propertyName, comparisonOperator, value, valueType = ReadSelectedPropertyType.Int) {
98
+ return this.where(propertyName, comparisonOperator, value, valueType);
99
+ }
100
+ /**
101
+ * Adds a boolean property comparison.
102
+ */
103
+ whereBool(propertyName, comparisonOperator, value) {
104
+ return this.where(propertyName, comparisonOperator, value, ReadSelectedPropertyType.Bool);
105
+ }
106
+ /**
107
+ * Adds a date/time property comparison.
108
+ */
109
+ whereDate(propertyName, comparisonOperator, value, valueType = ReadSelectedPropertyType.DateTime) {
110
+ const stringValue = value instanceof Date ? value.toISOString() : value;
111
+ return this.where(propertyName, comparisonOperator, stringValue, valueType);
112
+ }
113
+ /**
114
+ * Adds an isNull check for a property.
115
+ */
116
+ whereNull(propertyName) {
117
+ this._propertyCriteria.push({
118
+ propertyName: this.toPascalCase(propertyName),
119
+ comparisonOperator: ReadSelectedComparisonOperator.IsNull,
120
+ value: null,
121
+ valueType: ReadSelectedPropertyType.String,
122
+ });
123
+ return this;
124
+ }
125
+ /**
126
+ * Adds an isNotNull check for a property.
127
+ */
128
+ whereNotNull(propertyName) {
129
+ this._propertyCriteria.push({
130
+ propertyName: this.toPascalCase(propertyName),
131
+ comparisonOperator: ReadSelectedComparisonOperator.IsNotNull,
132
+ value: null,
133
+ valueType: ReadSelectedPropertyType.String,
134
+ });
135
+ return this;
136
+ }
137
+ /**
138
+ * Adds criteria for a nested object property (navigation property).
139
+ *
140
+ * @param propertyName - The navigation property name
141
+ * @param builderFn - A function that receives a new builder for the nested type
142
+ *
143
+ * @example
144
+ * // With explicit type for proper intellisense
145
+ * SearchBuilder.and<VehicleDto>()
146
+ * .nested<PersonDto>('driver', nested =>
147
+ * nested.whereString('name', ReadSelectedComparisonOperator.Contains, 'Alice')
148
+ * )
149
+ * .build();
150
+ */
151
+ nested(propertyName, builderFn) {
152
+ const nestedBuilder = SearchBuilder.and();
153
+ const configuredBuilder = builderFn(nestedBuilder);
154
+ this._nestedCriteria.push({
155
+ propertyName: this.toPascalCase(propertyName),
156
+ criteria: configuredBuilder.build(),
157
+ });
158
+ return this;
159
+ }
160
+ /**
161
+ * Adds criteria for a collection property with Any quantifier.
162
+ * Matches if at least one element in the collection satisfies the criteria.
163
+ *
164
+ * @param propertyName - The collection property name
165
+ * @param builderFn - A function that receives a new builder for the collection element type
166
+ *
167
+ * @example
168
+ * // With explicit type for proper intellisense
169
+ * SearchBuilder.and<VehicleDto>()
170
+ * .any<PersonDto>('passengers', passengers =>
171
+ * passengers.whereString('name', ReadSelectedComparisonOperator.Contains, 'Bob')
172
+ * )
173
+ * .build();
174
+ */
175
+ any(propertyName, builderFn) {
176
+ const nestedBuilder = SearchBuilder.and();
177
+ const configuredBuilder = builderFn(nestedBuilder);
178
+ this._nestedCollectionCriteria.push({
179
+ propertyName: this.toPascalCase(propertyName),
180
+ collectionOperator: ReadSelectedCollectionOperator.Any,
181
+ criteria: configuredBuilder.build(),
182
+ });
183
+ return this;
184
+ }
185
+ /**
186
+ * Adds criteria for a collection property with All quantifier.
187
+ * Matches if all elements in the collection satisfy the criteria.
188
+ *
189
+ * @param propertyName - The collection property name
190
+ * @param builderFn - A function that receives a new builder for the collection element type
191
+ *
192
+ * @example
193
+ * // With explicit type for proper intellisense
194
+ * SearchBuilder.and<VehicleDto>()
195
+ * .all<PersonDto>('passengers', passengers =>
196
+ * passengers.whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
197
+ * )
198
+ * .build();
199
+ */
200
+ all(propertyName, builderFn) {
201
+ const nestedBuilder = SearchBuilder.and();
202
+ const configuredBuilder = builderFn(nestedBuilder);
203
+ this._nestedCollectionCriteria.push({
204
+ propertyName: this.toPascalCase(propertyName),
205
+ collectionOperator: ReadSelectedCollectionOperator.All,
206
+ criteria: configuredBuilder.build(),
207
+ });
208
+ return this;
209
+ }
210
+ /**
211
+ * Adds a nested search group. Use this for complex logical groupings.
212
+ *
213
+ * @param builderFn - A function that receives a new builder for creating the nested search
214
+ *
215
+ * @example
216
+ * // (name contains 'John') AND ((age > 18) OR (status = 'verified'))
217
+ * SearchBuilder.and<User>()
218
+ * .whereString('name', ReadSelectedComparisonOperator.IContains, 'John')
219
+ * .group(sub => sub.or()
220
+ * .whereNumber('age', ReadSelectedComparisonOperator.GreaterThan, 18)
221
+ * .whereString('status', ReadSelectedComparisonOperator.Equal, 'verified')
222
+ * )
223
+ * .build();
224
+ */
225
+ group(builderFn) {
226
+ const nestedBuilder = SearchBuilder.and();
227
+ const configuredBuilder = builderFn(nestedBuilder);
228
+ this._searches.push(configuredBuilder.build());
229
+ return this;
230
+ }
231
+ /**
232
+ * Adds an existing search definition as a nested search.
233
+ *
234
+ * @param search - An existing ReadSelectedSearchDefinitionDto
235
+ */
236
+ addSearch(search) {
237
+ this._searches.push(search);
238
+ return this;
239
+ }
240
+ /**
241
+ * Builds and returns the ReadSelectedSearchDefinitionDto.
242
+ */
243
+ build() {
244
+ const result = {
245
+ logicalOperator: this._logicalOperator,
246
+ };
247
+ if (this._searches.length > 0) {
248
+ result.searches = this._searches;
249
+ }
250
+ if (this._propertyCriteria.length > 0) {
251
+ result.propertyCriteria = this._propertyCriteria;
252
+ }
253
+ if (this._nestedCriteria.length > 0) {
254
+ result.nestedCriteria = this._nestedCriteria;
255
+ }
256
+ if (this._nestedCollectionCriteria.length > 0) {
257
+ result.nestedCollectionCriteria = this._nestedCollectionCriteria;
258
+ }
259
+ return result;
260
+ }
261
+ toPascalCase(str) {
262
+ if (typeof str !== 'string') {
263
+ return str.toString();
264
+ }
265
+ return str.charAt(0).toUpperCase() + str.slice(1);
266
+ }
267
+ }
@@ -0,0 +1,33 @@
1
+ import { ReadSelectedLogicalOperator, ReadSelectedNestedCollectionCriteriaDto, ReadSelectedNestedCriteriaDto, ReadSelectedSearchPropertyDefinitionDto } from '../../..';
2
+ /**
3
+ * Defines the search criteria for a controller using a recursive structure.
4
+ *
5
+ * This DTO supports complex search queries with:
6
+ * - Logical operators (AND/OR) to combine multiple criteria
7
+ * - Direct property value comparisons via `propertyCriteria`
8
+ * - Nested searches via `searches` for recursive query composition
9
+ * - Navigation into nested objects via `nestedCriteria`
10
+ * - Collection quantifier queries (Any/All) via `nestedCollectionCriteria`
11
+ */
12
+ export type ReadSelectedSearchDefinitionDto<T> = {
13
+ /**
14
+ * The logical operator to combine all criteria at this level.
15
+ */
16
+ logicalOperator: ReadSelectedLogicalOperator;
17
+ /**
18
+ * Recursive nested search definitions combined with the logical operator.
19
+ */
20
+ searches?: ReadSelectedSearchDefinitionDto<T>[];
21
+ /**
22
+ * Direct property value comparison criteria.
23
+ */
24
+ propertyCriteria?: ReadSelectedSearchPropertyDefinitionDto<T, keyof T>[];
25
+ /**
26
+ * Criteria for searching within nested object properties.
27
+ */
28
+ nestedCriteria?: ReadSelectedNestedCriteriaDto<T, keyof T>[];
29
+ /**
30
+ * Criteria for searching within collection properties using Any/All quantifiers.
31
+ */
32
+ nestedCollectionCriteria?: ReadSelectedNestedCollectionCriteriaDto<T, keyof T>[];
33
+ };
@@ -0,0 +1,114 @@
1
+ import { ReadSelectedComparisonOperator, ReadSelectedPropertyType } from '../../..';
2
+ /**
3
+ * Defines a direct property value comparison criteria for searching.
4
+ *
5
+ * This DTO represents a leaf-level search criterion that compares a single property
6
+ * against a value using a comparison operator. For nested property searches, use
7
+ * `ReadSelectedNestedCriteriaDto` or `ReadSelectedNestedCollectionCriteriaDto`.
8
+ */
9
+ export type ReadSelectedSearchPropertyDefinitionDto<T, TPropertyName extends keyof T> = Partial_ReadSelectedSearchPropertyDefinition_IndependentProperties<T, TPropertyName> & Partial_ReadSelectedSearchPropertyDefinition_TypedValueProperty & Partial_ReadSelectedSearchPropertyDefinition_TypedComparisonOperators;
10
+ /**
11
+ * Defines independent properties
12
+ */
13
+ type Partial_ReadSelectedSearchPropertyDefinition_IndependentProperties<T, TPropertyName extends keyof T> = {
14
+ /**
15
+ * The name of the property to compare.
16
+ *
17
+ * This must be a direct property on the target type, not a nested property path.
18
+ * Use nested criteria DTOs for navigation.
19
+ */
20
+ propertyName: TPropertyName;
21
+ /**
22
+ * The comparison operator to use for the search.
23
+ */
24
+ comparisonOperator: ReadSelectedComparisonOperator;
25
+ /**
26
+ * The type of the property value being searched.
27
+ */
28
+ valueType: ReadSelectedPropertyType;
29
+ /**
30
+ * The value to compare against.
31
+ */
32
+ value: unknown;
33
+ };
34
+ /**
35
+ * Defines the dependence between the .valueType and the type of the .value properties
36
+ */
37
+ type Partial_ReadSelectedSearchPropertyDefinition_TypedValueProperty = {
38
+ /**
39
+ * The type of the property value being searched.
40
+ */
41
+ valueType: ReadSelectedPropertyType.Bool;
42
+ /**
43
+ * The value to use for the search.
44
+ */
45
+ value: boolean;
46
+ } | {
47
+ /**
48
+ * The type of the property value being searched.
49
+ */
50
+ valueType: ReadSelectedPropertyType.Int | ReadSelectedPropertyType.Short | ReadSelectedPropertyType.Long | ReadSelectedPropertyType.Decimal | ReadSelectedPropertyType.Double | ReadSelectedPropertyType.Float;
51
+ /**
52
+ * The value to use for the search.
53
+ */
54
+ value: number;
55
+ } | {
56
+ /**
57
+ * The type of the property value being searched.
58
+ */
59
+ valueType: ReadSelectedPropertyType.String;
60
+ /**
61
+ * The value to use for the search.
62
+ */
63
+ value: string;
64
+ } | {
65
+ /**
66
+ * The type of the property value being searched.
67
+ */
68
+ valueType: ReadSelectedPropertyType.DateTime | ReadSelectedPropertyType.DateTimeOffset | ReadSelectedPropertyType.TimeSpan | ReadSelectedPropertyType.DateOnly | ReadSelectedPropertyType.TimeOnly;
69
+ /**
70
+ * The value to use for the search.
71
+ */
72
+ value: string;
73
+ };
74
+ /**
75
+ * Defines the dependence between the .valueType and the type of the .comparisonOperator properties
76
+ */
77
+ type Partial_ReadSelectedSearchPropertyDefinition_TypedComparisonOperators = {
78
+ /**
79
+ * The type of the property value being searched.
80
+ */
81
+ valueType: ReadSelectedPropertyType.Bool;
82
+ /**
83
+ * The comparison operator to use for the search.
84
+ */
85
+ comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual;
86
+ } | {
87
+ /**
88
+ * The type of the property value being searched.
89
+ */
90
+ valueType: ReadSelectedPropertyType.Int | ReadSelectedPropertyType.Short | ReadSelectedPropertyType.Long | ReadSelectedPropertyType.Decimal | ReadSelectedPropertyType.Double | ReadSelectedPropertyType.Float;
91
+ /**
92
+ * The comparison operator to use for the search.
93
+ */
94
+ comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.LessThan | ReadSelectedComparisonOperator.LessOrEqual | ReadSelectedComparisonOperator.GreaterThan | ReadSelectedComparisonOperator.GreaterOrEqual;
95
+ } | {
96
+ /**
97
+ * The type of the property value being searched.
98
+ */
99
+ valueType: ReadSelectedPropertyType.String;
100
+ /**
101
+ * The comparison operator to use for the search.
102
+ */
103
+ comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.Contains | ReadSelectedComparisonOperator.StartsWith | ReadSelectedComparisonOperator.EndsWith | ReadSelectedComparisonOperator.IContains | ReadSelectedComparisonOperator.IStartsWith | ReadSelectedComparisonOperator.IEndsWith | ReadSelectedComparisonOperator.IEqual | ReadSelectedComparisonOperator.INotEqual;
104
+ } | {
105
+ /**
106
+ * The type of the property value being searched.
107
+ */
108
+ valueType: ReadSelectedPropertyType.DateTime | ReadSelectedPropertyType.DateTimeOffset | ReadSelectedPropertyType.TimeSpan | ReadSelectedPropertyType.DateOnly | ReadSelectedPropertyType.TimeOnly;
109
+ /**
110
+ * The comparison operator to use for the search.
111
+ */
112
+ comparisonOperator: ReadSelectedComparisonOperator.Equal | ReadSelectedComparisonOperator.NotEqual | ReadSelectedComparisonOperator.LessThan | ReadSelectedComparisonOperator.LessOrEqual | ReadSelectedComparisonOperator.GreaterThan | ReadSelectedComparisonOperator.GreaterOrEqual;
113
+ };
114
+ export {};
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Options for configuring read operations.
3
+ *
4
+ * @property {boolean} includeTotalCount - Whether to include the total count of items in the response.
5
+ */
6
+ export type ReadOptionsDto = {
7
+ includeTotalCount: boolean;
8
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,12 @@
1
+ import { ReadResultMetadataDto } from './read-result-metadata-dto';
2
+ /**
3
+ * Represents a read result containing a collection of results and metadata.
4
+ *
5
+ * @template T The type of result in the collection.
6
+ * @property {T[]} items - The collection of results returned.
7
+ * @property {ReadResultMetadata} metadata - Metadata about the paginated result.
8
+ */
9
+ export type ReadResultDto<T> = {
10
+ results: T[];
11
+ metadata: ReadResultMetadataDto;
12
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Metadata associated with a paginated read result.
3
+ *
4
+ * @property {number} [totalCount] - The total number of items available.
5
+ */
6
+ export type ReadResultMetadataDto = {
7
+ totalCount?: number;
8
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,17 @@
1
+ import { EmptyMetadataDto, ErrorCode, ValidationFailedMetadataDto } from '../../..';
2
+ /**
3
+ * Default, empty metadata.
4
+ */
5
+ export type ApiErrorDto<TMetadata extends ApiErrorMetadataDto = ApiErrorMetadataDto> = {
6
+ message: string;
7
+ details?: string;
8
+ traceId?: string;
9
+ timestamp?: string;
10
+ } & TMetadata;
11
+ export type ApiErrorMetadataDto = {
12
+ code: ErrorCode.ValidationFailed;
13
+ metadata: ValidationFailedMetadataDto;
14
+ } | {
15
+ code: Exclude<ErrorCode, ErrorCode.ValidationFailed>;
16
+ metadata: EmptyMetadataDto;
17
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,11 @@
1
+ import { ApiErrorDto, ApiErrorMetadataDto } from '../../..';
2
+ /**
3
+ * Represents an API response containing an error and empty metadata.
4
+ */
5
+ export type ApiErrorResponseDto<TErrorMetadata extends ApiErrorMetadataDto = ApiErrorMetadataDto> = {
6
+ ok: false;
7
+ /**
8
+ * The error object containing information about the error
9
+ */
10
+ error: ApiErrorDto<TErrorMetadata>;
11
+ };
@@ -0,0 +1,3 @@
1
+ import { ApiErrorMetadataDto, ApiErrorResponseDto, ApiSuccessResponseDto } from '../../../../data';
2
+ import { Result } from '../../../../utils/result';
3
+ export type ApiResponseDto<T, TMetadata extends object, TErrorMetadata extends ApiErrorMetadataDto = ApiErrorMetadataDto> = Result<ApiSuccessResponseDto<T, TMetadata>, ApiErrorResponseDto<TErrorMetadata>>;
@@ -0,0 +1 @@
1
+ export {};