@elsikora/nestjs-crud-automator 1.8.0-dev.2 → 1.9.0-dev.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1015) hide show
  1. package/README.md +253 -290
  2. package/dist/cjs/class/api/index.d.ts +1 -1
  3. package/dist/cjs/class/api/service-base.class.d.ts +2 -3
  4. package/dist/cjs/class/api/service-base.class.js.map +1 -1
  5. package/dist/cjs/class/index.d.ts +4 -3
  6. package/dist/cjs/class/metadata-storage.class.d.ts +2 -2
  7. package/dist/cjs/class/metadata-storage.class.js +1 -0
  8. package/dist/cjs/class/metadata-storage.class.js.map +1 -1
  9. package/dist/cjs/class/utility/dto/property/factory/boolean.class.d.ts +4 -3
  10. package/dist/cjs/class/utility/dto/property/factory/boolean.class.js.map +1 -1
  11. package/dist/cjs/class/utility/dto/property/factory/date.class.d.ts +4 -3
  12. package/dist/cjs/class/utility/dto/property/factory/date.class.js.map +1 -1
  13. package/dist/cjs/class/utility/dto/property/factory/enum.class.d.ts +4 -3
  14. package/dist/cjs/class/utility/dto/property/factory/enum.class.js.map +1 -1
  15. package/dist/cjs/class/utility/dto/property/factory/index.d.ts +8 -6
  16. package/dist/cjs/class/utility/dto/property/factory/number.class.d.ts +5 -4
  17. package/dist/cjs/class/utility/dto/property/factory/number.class.js +1 -3
  18. package/dist/cjs/class/utility/dto/property/factory/number.class.js.map +1 -1
  19. package/dist/cjs/class/utility/dto/property/factory/object.class.d.ts +6 -4
  20. package/dist/cjs/class/utility/dto/property/factory/object.class.js +2 -1
  21. package/dist/cjs/class/utility/dto/property/factory/object.class.js.map +1 -1
  22. package/dist/cjs/class/utility/dto/property/factory/relation.class.d.ts +5 -4
  23. package/dist/cjs/class/utility/dto/property/factory/relation.class.js +0 -3
  24. package/dist/cjs/class/utility/dto/property/factory/relation.class.js.map +1 -1
  25. package/dist/cjs/class/utility/dto/property/factory/string.class.d.ts +4 -3
  26. package/dist/cjs/class/utility/dto/property/factory/string.class.js.map +1 -1
  27. package/dist/cjs/class/utility/dto/property/factory/uuid.class.d.ts +4 -3
  28. package/dist/cjs/class/utility/dto/property/factory/uuid.class.js.map +1 -1
  29. package/dist/cjs/class/utility/dto/strategy/body.class.d.ts +3 -3
  30. package/dist/cjs/class/utility/dto/strategy/body.class.js +1 -4
  31. package/dist/cjs/class/utility/dto/strategy/body.class.js.map +1 -1
  32. package/dist/cjs/class/utility/dto/strategy/index.d.ts +4 -4
  33. package/dist/cjs/class/utility/dto/strategy/query.class.d.ts +3 -3
  34. package/dist/cjs/class/utility/dto/strategy/query.class.js +0 -3
  35. package/dist/cjs/class/utility/dto/strategy/query.class.js.map +1 -1
  36. package/dist/cjs/class/utility/dto/strategy/request.class.d.ts +3 -3
  37. package/dist/cjs/class/utility/dto/strategy/request.class.js +0 -3
  38. package/dist/cjs/class/utility/dto/strategy/request.class.js.map +1 -1
  39. package/dist/cjs/class/utility/dto/strategy/response.class.d.ts +3 -3
  40. package/dist/cjs/class/utility/dto/strategy/response.class.js +0 -3
  41. package/dist/cjs/class/utility/dto/strategy/response.class.js.map +1 -1
  42. package/dist/cjs/constant/decorator/api/function.constant.d.ts +1 -1
  43. package/dist/cjs/constant/decorator/api/function.constant.js +0 -15
  44. package/dist/cjs/constant/decorator/api/function.constant.js.map +1 -1
  45. package/dist/cjs/constant/decorator/api/index.d.ts +3 -3
  46. package/dist/cjs/constant/dto/index.d.ts +3 -3
  47. package/dist/cjs/constant/dto/list.constant.d.ts +1 -2
  48. package/dist/cjs/constant/dto/list.constant.js +1 -3
  49. package/dist/cjs/constant/dto/list.constant.js.map +1 -1
  50. package/dist/cjs/constant/factory/dto/get-list-query.constant.d.ts +1 -0
  51. package/dist/cjs/constant/factory/dto/get-list-query.constant.js +2 -0
  52. package/dist/cjs/constant/factory/dto/get-list-query.constant.js.map +1 -1
  53. package/dist/cjs/constant/factory/dto/index.d.ts +1 -1
  54. package/dist/cjs/constant/index.d.ts +8 -6
  55. package/dist/cjs/constant/interface/api/index.d.ts +2 -2
  56. package/dist/cjs/constant/interface/api/property/index.d.ts +2 -2
  57. package/dist/cjs/constant/utility/dto/constant.d.ts +3 -2
  58. package/dist/cjs/constant/utility/dto/constant.js +6 -10
  59. package/dist/cjs/constant/utility/dto/constant.js.map +1 -1
  60. package/dist/cjs/constant/utility/dto/index.d.ts +2 -0
  61. package/dist/cjs/constant/validator/has-paired-custom-suffixes-fields.constant.d.ts +5 -0
  62. package/dist/cjs/constant/validator/has-paired-custom-suffixes-fields.constant.js +89 -0
  63. package/dist/cjs/constant/validator/has-paired-custom-suffixes-fields.constant.js.map +1 -0
  64. package/dist/cjs/constant/validator/index.d.ts +1 -0
  65. package/dist/cjs/decorator/api/controller.decorator.d.ts +3 -2
  66. package/dist/cjs/decorator/api/controller.decorator.js.map +1 -1
  67. package/dist/cjs/decorator/api/function/create.decorator.d.ts +7 -1
  68. package/dist/cjs/decorator/api/function/create.decorator.js +12 -16
  69. package/dist/cjs/decorator/api/function/create.decorator.js.map +1 -1
  70. package/dist/cjs/decorator/api/function/decorator.d.ts +10 -3
  71. package/dist/cjs/decorator/api/function/decorator.js +7 -3
  72. package/dist/cjs/decorator/api/function/decorator.js.map +1 -1
  73. package/dist/cjs/decorator/api/function/delete.decorator.d.ts +7 -1
  74. package/dist/cjs/decorator/api/function/delete.decorator.js +12 -16
  75. package/dist/cjs/decorator/api/function/delete.decorator.js.map +1 -1
  76. package/dist/cjs/decorator/api/function/get-list.decorator.d.ts +8 -2
  77. package/dist/cjs/decorator/api/function/get-list.decorator.js +12 -16
  78. package/dist/cjs/decorator/api/function/get-list.decorator.js.map +1 -1
  79. package/dist/cjs/decorator/api/function/get-many.decorator.d.ts +7 -1
  80. package/dist/cjs/decorator/api/function/get-many.decorator.js +13 -16
  81. package/dist/cjs/decorator/api/function/get-many.decorator.js.map +1 -1
  82. package/dist/cjs/decorator/api/function/get.decorator.d.ts +7 -1
  83. package/dist/cjs/decorator/api/function/get.decorator.js +13 -16
  84. package/dist/cjs/decorator/api/function/get.decorator.js.map +1 -1
  85. package/dist/cjs/decorator/api/function/index.d.ts +7 -7
  86. package/dist/cjs/decorator/api/function/update.decorator.d.ts +7 -1
  87. package/dist/cjs/decorator/api/function/update.decorator.js +12 -16
  88. package/dist/cjs/decorator/api/function/update.decorator.js.map +1 -1
  89. package/dist/cjs/decorator/api/index.d.ts +5 -5
  90. package/dist/cjs/decorator/api/method.decorator.d.ts +8 -1
  91. package/dist/cjs/decorator/api/method.decorator.js +9 -6
  92. package/dist/cjs/decorator/api/method.decorator.js.map +1 -1
  93. package/dist/cjs/decorator/api/property/boolean.decorator.d.ts +52 -1
  94. package/dist/cjs/decorator/api/property/boolean.decorator.js +99 -7
  95. package/dist/cjs/decorator/api/property/boolean.decorator.js.map +1 -1
  96. package/dist/cjs/decorator/api/property/copy.decorator.d.ts +16 -0
  97. package/dist/cjs/decorator/api/property/copy.decorator.js +49 -0
  98. package/dist/cjs/decorator/api/property/copy.decorator.js.map +1 -0
  99. package/dist/cjs/decorator/api/property/date.decorator.d.ts +56 -1
  100. package/dist/cjs/decorator/api/property/date.decorator.js +132 -7
  101. package/dist/cjs/decorator/api/property/date.decorator.js.map +1 -1
  102. package/dist/cjs/decorator/api/property/describe.decorator.d.ts +82 -1
  103. package/dist/cjs/decorator/api/property/describe.decorator.js +81 -16
  104. package/dist/cjs/decorator/api/property/describe.decorator.js.map +1 -1
  105. package/dist/cjs/decorator/api/property/enum.decorator.d.ts +75 -1
  106. package/dist/cjs/decorator/api/property/enum.decorator.js +112 -0
  107. package/dist/cjs/decorator/api/property/enum.decorator.js.map +1 -1
  108. package/dist/cjs/decorator/api/property/index.d.ts +9 -7
  109. package/dist/cjs/decorator/api/property/number.decorator.d.ts +67 -1
  110. package/dist/cjs/decorator/api/property/number.decorator.js +152 -12
  111. package/dist/cjs/decorator/api/property/number.decorator.js.map +1 -1
  112. package/dist/cjs/decorator/api/property/object.decorator.d.ts +27 -1
  113. package/dist/cjs/decorator/api/property/object.decorator.js +145 -3
  114. package/dist/cjs/decorator/api/property/object.decorator.js.map +1 -1
  115. package/dist/cjs/decorator/api/property/string.decorator.d.ts +68 -1
  116. package/dist/cjs/decorator/api/property/string.decorator.js +131 -14
  117. package/dist/cjs/decorator/api/property/string.decorator.js.map +1 -1
  118. package/dist/cjs/decorator/api/property/uuid.decorator.d.ts +42 -1
  119. package/dist/cjs/decorator/api/property/uuid.decorator.js +92 -7
  120. package/dist/cjs/decorator/api/property/uuid.decorator.js.map +1 -1
  121. package/dist/cjs/decorator/api/service.decorator.d.ts +8 -2
  122. package/dist/cjs/decorator/api/service.decorator.js +10 -6
  123. package/dist/cjs/decorator/api/service.decorator.js.map +1 -1
  124. package/dist/cjs/enum/decorator/api/controller/index.d.ts +2 -2
  125. package/dist/cjs/enum/decorator/api/function/index.d.ts +1 -1
  126. package/dist/cjs/enum/decorator/api/index.d.ts +7 -7
  127. package/dist/cjs/enum/decorator/api/property/date/index.d.ts +2 -2
  128. package/dist/cjs/enum/decorator/api/property/index.d.ts +5 -5
  129. package/dist/cjs/enum/index.d.ts +6 -4
  130. package/dist/cjs/enum/utility/index.d.ts +1 -1
  131. package/dist/cjs/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.d.ts +5 -0
  132. package/dist/cjs/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.js +9 -0
  133. package/dist/cjs/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.js.map +1 -0
  134. package/dist/cjs/enum/validator/index.d.ts +2 -0
  135. package/dist/cjs/enum/validator/must-match-one-of-schemas-error-type.enum.d.ts +6 -0
  136. package/dist/cjs/enum/validator/must-match-one-of-schemas-error-type.enum.js +10 -0
  137. package/dist/cjs/enum/validator/must-match-one-of-schemas-error-type.enum.js.map +1 -0
  138. package/dist/cjs/factory/api/controller.factory.d.ts +4 -3
  139. package/dist/cjs/factory/api/controller.factory.js +11 -15
  140. package/dist/cjs/factory/api/controller.factory.js.map +1 -1
  141. package/dist/cjs/factory/api/index.d.ts +1 -1
  142. package/dist/cjs/index.d.ts +10 -10
  143. package/dist/cjs/index.js +132 -0
  144. package/dist/cjs/index.js.map +1 -1
  145. package/dist/cjs/interceptor/index.d.ts +1 -1
  146. package/dist/cjs/interface/api-authentication-request.interface.d.ts +1 -1
  147. package/dist/cjs/interface/api-request-validator.interface.d.ts +3 -2
  148. package/dist/cjs/interface/class/dto/index.d.ts +1 -1
  149. package/dist/cjs/interface/class/dto/strategy.interface.d.ts +2 -2
  150. package/dist/cjs/interface/class/index.d.ts +2 -2
  151. package/dist/cjs/interface/decorator/api/controller/base.interface.d.ts +1 -1
  152. package/dist/cjs/interface/decorator/api/controller/index.d.ts +3 -3
  153. package/dist/cjs/interface/decorator/api/controller/properties/route/authentication.interface.d.ts +1 -1
  154. package/dist/cjs/interface/decorator/api/controller/properties/route/auto-dto-config.interface.d.ts +1 -1
  155. package/dist/cjs/interface/decorator/api/controller/properties/route/base-request.interface.d.ts +3 -3
  156. package/dist/cjs/interface/decorator/api/controller/properties/route/base-response.interface.d.ts +2 -2
  157. package/dist/cjs/interface/decorator/api/controller/properties/route/base.interface.d.ts +2 -4
  158. package/dist/cjs/interface/decorator/api/controller/properties/route/index.d.ts +7 -7
  159. package/dist/cjs/interface/decorator/api/controller/properties/route/with-auto-dto.interface.d.ts +2 -3
  160. package/dist/cjs/interface/decorator/api/controller/properties/route/with-dto.interface.d.ts +2 -2
  161. package/dist/cjs/interface/decorator/api/controller/properties.interface.d.ts +3 -3
  162. package/dist/cjs/interface/decorator/api/function/create-executor-properties.interface.d.ts +2 -2
  163. package/dist/cjs/interface/decorator/api/function/delete-executor-properties.interface.d.ts +2 -2
  164. package/dist/cjs/interface/decorator/api/function/get-executor-properties.interface.d.ts +2 -2
  165. package/dist/cjs/interface/decorator/api/function/get-list-executor-properties.interface.d.ts +2 -2
  166. package/dist/cjs/interface/decorator/api/function/get-many-executor-properties.interface.d.ts +2 -2
  167. package/dist/cjs/interface/decorator/api/function/index.d.ts +7 -7
  168. package/dist/cjs/interface/decorator/api/function/properties.interface.d.ts +1 -1
  169. package/dist/cjs/interface/decorator/api/function/update-executor-properties.interface.d.ts +2 -2
  170. package/dist/cjs/interface/decorator/api/index.d.ts +5 -5
  171. package/dist/cjs/interface/decorator/api/method/index.d.ts +2 -2
  172. package/dist/cjs/interface/decorator/api/method/properties.interface.d.ts +2 -4
  173. package/dist/cjs/interface/dto-generate-factory.interface.d.ts +5 -4
  174. package/dist/cjs/interface/entity/index.d.ts +2 -2
  175. package/dist/cjs/interface/entity/interface.d.ts +2 -2
  176. package/dist/cjs/interface/index.d.ts +10 -8
  177. package/dist/cjs/interface/utility/api/controller/index.d.ts +1 -1
  178. package/dist/cjs/interface/utility/error-string-properties.interface.d.ts +1 -1
  179. package/dist/cjs/interface/utility/get-entity-columns-properties.interface.d.ts +1 -1
  180. package/dist/cjs/interface/utility/index.d.ts +3 -2
  181. package/dist/cjs/interface/validator/index.d.ts +1 -0
  182. package/dist/cjs/interface/validator/must-match-one-of-schemas-discriminator-config.interface.d.ts +6 -0
  183. package/dist/cjs/type/api-request-transformer.type.d.ts +3 -3
  184. package/dist/cjs/type/class/controller/index.d.ts +1 -1
  185. package/dist/cjs/type/class/controller/method.type.d.ts +2 -2
  186. package/dist/cjs/type/class/index.d.ts +3 -3
  187. package/dist/cjs/type/class/metadata.type.d.ts +1 -1
  188. package/dist/cjs/type/decorator/api/controller/constructor.type.d.ts +1 -1
  189. package/dist/cjs/type/decorator/api/controller/get-list-query.type.d.ts +2 -2
  190. package/dist/cjs/type/decorator/api/controller/index.d.ts +5 -5
  191. package/dist/cjs/type/decorator/api/controller/properties/route/base-request-relations.type.d.ts +1 -1
  192. package/dist/cjs/type/decorator/api/controller/properties/route/base-request-transformers.type.d.ts +2 -2
  193. package/dist/cjs/type/decorator/api/controller/properties/route/base-response-transformers.type.d.ts +2 -2
  194. package/dist/cjs/type/decorator/api/controller/properties/route/index.d.ts +3 -3
  195. package/dist/cjs/type/decorator/api/controller/properties-route.type.d.ts +2 -2
  196. package/dist/cjs/type/decorator/api/controller/transformer-config.type.d.ts +2 -2
  197. package/dist/cjs/type/decorator/api/filter/extracted-allowed-types.type.d.ts +1 -1
  198. package/dist/cjs/type/decorator/api/filter/index.d.ts +4 -4
  199. package/dist/cjs/type/decorator/api/filter/order-by.type.d.ts +1 -1
  200. package/dist/cjs/type/decorator/api/function/index.d.ts +9 -9
  201. package/dist/cjs/type/decorator/api/function/properties.type.d.ts +1 -1
  202. package/dist/cjs/type/decorator/api/property/base/array/index.d.ts +2 -2
  203. package/dist/cjs/type/decorator/api/property/base/index.d.ts +4 -4
  204. package/dist/cjs/type/decorator/api/property/base/properties.type.d.ts +2 -4
  205. package/dist/cjs/type/decorator/api/property/date-properties.type.d.ts +2 -2
  206. package/dist/cjs/type/decorator/api/property/describe/array/index.d.ts +2 -2
  207. package/dist/cjs/type/decorator/api/property/describe/base-properties.type.d.ts +1 -1
  208. package/dist/cjs/type/decorator/api/property/describe/boolean-properties.type.d.ts +3 -3
  209. package/dist/cjs/type/decorator/api/property/describe/date-properties.type.d.ts +3 -3
  210. package/dist/cjs/type/decorator/api/property/describe/dto/body-properties.type.d.ts +2 -2
  211. package/dist/cjs/type/decorator/api/property/describe/dto/index.d.ts +6 -5
  212. package/dist/cjs/type/decorator/api/property/describe/dto/properties.type.d.ts +1 -1
  213. package/dist/cjs/type/decorator/api/property/describe/dto/query/index.d.ts +2 -2
  214. package/dist/cjs/type/decorator/api/property/describe/dto/query/properties.type.d.ts +2 -3
  215. package/dist/cjs/type/decorator/api/property/describe/dto/request-properties.type.d.ts +2 -2
  216. package/dist/cjs/type/decorator/api/property/describe/dto/response-properties.type.d.ts +2 -2
  217. package/dist/cjs/type/decorator/api/property/describe/enum-properties.type.d.ts +3 -3
  218. package/dist/cjs/type/decorator/api/property/describe/index.d.ts +14 -13
  219. package/dist/cjs/type/decorator/api/property/describe/number-properties.type.d.ts +4 -4
  220. package/dist/cjs/type/decorator/api/property/describe/object/dynamic-with-discriminator-properties.type.d.ts +15 -0
  221. package/dist/cjs/type/decorator/api/property/describe/object/index.d.ts +4 -0
  222. package/dist/cjs/type/decorator/api/property/describe/object/properties.type.d.ts +4 -0
  223. package/dist/cjs/type/decorator/api/property/describe/object/with-discriminator-properties.type.d.ts +14 -0
  224. package/dist/cjs/type/decorator/api/property/describe/{object-properties.type.d.ts → object/without-discriminator-properties.type.d.ts} +4 -4
  225. package/dist/cjs/type/decorator/api/property/describe/properties/base-dto-properties.type.d.ts +1 -1
  226. package/dist/cjs/type/decorator/api/property/describe/properties/base-properties.type.d.ts +2 -2
  227. package/dist/cjs/type/decorator/api/property/describe/properties/index.d.ts +2 -2
  228. package/dist/cjs/type/decorator/api/property/describe/properties.type.d.ts +8 -8
  229. package/dist/cjs/type/decorator/api/property/describe/relation-properties.type.d.ts +2 -2
  230. package/dist/cjs/type/decorator/api/property/describe/string-properties.type.d.ts +4 -4
  231. package/dist/cjs/type/decorator/api/property/describe/uuid-properties.type.d.ts +3 -3
  232. package/dist/cjs/type/decorator/api/property/enum-properties.type.d.ts +1 -1
  233. package/dist/cjs/type/decorator/api/property/index.d.ts +8 -6
  234. package/dist/cjs/type/decorator/api/property/number-properties.type.d.ts +3 -3
  235. package/dist/cjs/type/decorator/api/property/object/dynamic-with-discriminator-properties.type.d.ts +16 -0
  236. package/dist/cjs/type/decorator/api/property/object/index.d.ts +4 -0
  237. package/dist/cjs/type/decorator/api/property/object/properties.type.d.ts +4 -0
  238. package/dist/cjs/type/decorator/api/property/object/with-discriminator-properties.type.d.ts +15 -0
  239. package/dist/cjs/type/decorator/api/property/{object-properties.type.d.ts → object/without-discriminator-properties.type.d.ts} +4 -2
  240. package/dist/cjs/type/decorator/api/property/string-properties.type.d.ts +2 -2
  241. package/dist/cjs/type/decorator/api/property/uuid-properties.type.d.ts +1 -1
  242. package/dist/cjs/type/decorator/api/service/index.d.ts +2 -2
  243. package/dist/cjs/type/decorator/api/service/keys.type.d.ts +1 -1
  244. package/dist/cjs/type/factory/api/controller/index.d.ts +4 -4
  245. package/dist/cjs/type/factory/api/controller/method-map.type.d.ts +4 -3
  246. package/dist/cjs/type/factory/api/controller/method-name-map.type.d.ts +2 -2
  247. package/dist/cjs/type/factory/api/controller/method-name.type.d.ts +3 -3
  248. package/dist/cjs/type/factory/api/controller/target-methods.type.d.ts +4 -4
  249. package/dist/cjs/type/index.d.ts +10 -5
  250. package/dist/cjs/type/utility/api/controller/transform-data/data.type.d.ts +1 -1
  251. package/dist/cjs/type/utility/api/controller/transform-data/index.d.ts +3 -3
  252. package/dist/cjs/type/utility/api/controller/transform-data/is-validation-properties.type.d.ts +2 -2
  253. package/dist/cjs/type/utility/api/controller/transform-data/object-to-transform.type.d.ts +2 -2
  254. package/dist/cjs/type/utility/date-range-keys.type.d.ts +1 -1
  255. package/dist/cjs/type/utility/dto/generate-allowed-combination.type.d.ts +1 -1
  256. package/dist/cjs/type/utility/dto/generate-is-allowed-combination.type.d.ts +2 -2
  257. package/dist/cjs/type/utility/dto/index.d.ts +2 -2
  258. package/dist/cjs/type/utility/filter-keys.type.d.ts +1 -1
  259. package/dist/cjs/type/utility/index.d.ts +7 -7
  260. package/dist/cjs/type/validator/has-paired-custom-suffixes-fields/index.d.ts +2 -0
  261. package/dist/cjs/type/validator/has-paired-custom-suffixes-fields/operation-config.type.d.ts +7 -0
  262. package/dist/cjs/type/validator/has-paired-custom-suffixes-fields/validation-context.type.d.ts +5 -0
  263. package/dist/cjs/utility/api/controller/apply-decorators.utility.d.ts +18 -3
  264. package/dist/cjs/utility/api/controller/apply-decorators.utility.js +15 -4
  265. package/dist/cjs/utility/api/controller/apply-decorators.utility.js.map +1 -1
  266. package/dist/cjs/utility/api/controller/apply-metadata.utility.d.ts +17 -3
  267. package/dist/cjs/utility/api/controller/apply-metadata.utility.js +21 -12
  268. package/dist/cjs/utility/api/controller/apply-metadata.utility.js.map +1 -1
  269. package/dist/cjs/utility/api/controller/get-list/index.d.ts +2 -2
  270. package/dist/cjs/utility/api/controller/get-list/transform-filter.utility.d.ts +10 -1
  271. package/dist/cjs/utility/api/controller/get-list/transform-filter.utility.js +9 -3
  272. package/dist/cjs/utility/api/controller/get-list/transform-filter.utility.js.map +1 -1
  273. package/dist/cjs/utility/api/controller/get-list/transform-operation.utility.d.ts +8 -1
  274. package/dist/cjs/utility/api/controller/get-list/transform-operation.utility.js +8 -1
  275. package/dist/cjs/utility/api/controller/get-list/transform-operation.utility.js.map +1 -1
  276. package/dist/cjs/utility/api/controller/get-method-name.utility.d.ts +7 -1
  277. package/dist/cjs/utility/api/controller/get-method-name.utility.js +6 -0
  278. package/dist/cjs/utility/api/controller/get-method-name.utility.js.map +1 -1
  279. package/dist/cjs/utility/api/controller/get-primary-column.utility.d.ts +10 -1
  280. package/dist/cjs/utility/api/controller/get-primary-column.utility.js +8 -0
  281. package/dist/cjs/utility/api/controller/get-primary-column.utility.js.map +1 -1
  282. package/dist/cjs/utility/api/controller/handle-request-relations.utility.d.ts +17 -2
  283. package/dist/cjs/utility/api/controller/handle-request-relations.utility.js +15 -5
  284. package/dist/cjs/utility/api/controller/handle-request-relations.utility.js.map +1 -1
  285. package/dist/cjs/utility/api/controller/index.d.ts +10 -9
  286. package/dist/cjs/utility/api/controller/transform-data.utility.d.ts +15 -3
  287. package/dist/cjs/utility/api/controller/transform-data.utility.js +52 -3
  288. package/dist/cjs/utility/api/controller/transform-data.utility.js.map +1 -1
  289. package/dist/cjs/utility/api/controller/validate-request.utility.d.ts +12 -2
  290. package/dist/cjs/utility/api/controller/validate-request.utility.js +9 -0
  291. package/dist/cjs/utility/api/controller/validate-request.utility.js.map +1 -1
  292. package/dist/cjs/utility/api/controller/write-dto-swagger.utility.d.ts +17 -3
  293. package/dist/cjs/utility/api/controller/write-dto-swagger.utility.js +20 -11
  294. package/dist/cjs/utility/api/controller/write-dto-swagger.utility.js.map +1 -1
  295. package/dist/cjs/utility/api/controller/write-method.utility.d.ts +16 -2
  296. package/dist/cjs/utility/api/controller/write-method.utility.js +14 -1
  297. package/dist/cjs/utility/api/controller/write-method.utility.js.map +1 -1
  298. package/dist/cjs/utility/api/filter-order-by-from-entity.utility.d.ts +16 -3
  299. package/dist/cjs/utility/api/filter-order-by-from-entity.utility.js +14 -1
  300. package/dist/cjs/utility/api/filter-order-by-from-entity.utility.js.map +1 -1
  301. package/dist/cjs/utility/api/index.d.ts +2 -2
  302. package/dist/cjs/utility/camel-case-string.utility.d.ts +5 -0
  303. package/dist/cjs/utility/camel-case-string.utility.js +5 -0
  304. package/dist/cjs/utility/camel-case-string.utility.js.map +1 -1
  305. package/dist/cjs/utility/capitalize-string.utility.d.ts +5 -0
  306. package/dist/cjs/utility/capitalize-string.utility.js +5 -0
  307. package/dist/cjs/utility/capitalize-string.utility.js.map +1 -1
  308. package/dist/cjs/utility/dto/analize.utility.d.ts +7 -1
  309. package/dist/cjs/utility/dto/analize.utility.js +6 -16
  310. package/dist/cjs/utility/dto/analize.utility.js.map +1 -1
  311. package/dist/cjs/utility/dto/build-decorator.utility.d.ts +19 -4
  312. package/dist/cjs/utility/dto/build-decorator.utility.js +17 -5
  313. package/dist/cjs/utility/dto/build-decorator.utility.js.map +1 -1
  314. package/dist/cjs/utility/dto/generate-decorator.utility.d.ts +19 -4
  315. package/dist/cjs/utility/dto/generate-decorator.utility.js +16 -2
  316. package/dist/cjs/utility/dto/generate-decorator.utility.js.map +1 -1
  317. package/dist/cjs/utility/dto/generate-dynamic.utility.d.ts +21 -0
  318. package/dist/cjs/utility/dto/generate-dynamic.utility.js +94 -0
  319. package/dist/cjs/utility/dto/generate-dynamic.utility.js.map +1 -0
  320. package/dist/cjs/utility/dto/generate-exception.utility.d.ts +7 -0
  321. package/dist/cjs/utility/dto/generate-exception.utility.js +8 -5
  322. package/dist/cjs/utility/dto/generate-exception.utility.js.map +1 -1
  323. package/dist/cjs/utility/dto/generate-filter-decorator.utility.d.ts +11 -2
  324. package/dist/cjs/utility/dto/generate-filter-decorator.utility.js +9 -3
  325. package/dist/cjs/utility/dto/generate-filter-decorator.utility.js.map +1 -1
  326. package/dist/cjs/utility/dto/generate-get-list-response.utility.d.ts +9 -0
  327. package/dist/cjs/utility/dto/generate-get-list-response.utility.js +25 -19
  328. package/dist/cjs/utility/dto/generate-get-list-response.utility.js.map +1 -1
  329. package/dist/cjs/utility/dto/generate-relation-response.utility.d.ts +12 -2
  330. package/dist/cjs/utility/dto/generate-relation-response.utility.js +10 -0
  331. package/dist/cjs/utility/dto/generate-relation-response.utility.js.map +1 -1
  332. package/dist/cjs/utility/dto/generate.utility.d.ts +17 -2
  333. package/dist/cjs/utility/dto/generate.utility.js +39 -11
  334. package/dist/cjs/utility/dto/generate.utility.js.map +1 -1
  335. package/dist/cjs/utility/dto/get-decorator-config.utility.d.ts +15 -2
  336. package/dist/cjs/utility/dto/get-decorator-config.utility.js +13 -0
  337. package/dist/cjs/utility/dto/get-decorator-config.utility.js.map +1 -1
  338. package/dist/cjs/utility/dto/get-get-list-query-base-class.utility.d.ts +13 -2
  339. package/dist/cjs/utility/dto/get-get-list-query-base-class.utility.js +16 -11
  340. package/dist/cjs/utility/dto/get-get-list-query-base-class.utility.js.map +1 -1
  341. package/dist/cjs/utility/dto/handle-date-property.utility.d.ts +9 -1
  342. package/dist/cjs/utility/dto/handle-date-property.utility.js +8 -3
  343. package/dist/cjs/utility/dto/handle-date-property.utility.js.map +1 -1
  344. package/dist/cjs/utility/dto/index.d.ts +16 -12
  345. package/dist/cjs/utility/dto/is-property-exposed-for-guard.utility.d.ts +10 -2
  346. package/dist/cjs/utility/dto/is-property-exposed-for-guard.utility.js +8 -0
  347. package/dist/cjs/utility/dto/is-property-exposed-for-guard.utility.js.map +1 -1
  348. package/dist/cjs/utility/dto/is-property-should-be-marked.utility.d.ts +12 -2
  349. package/dist/cjs/utility/dto/is-property-should-be-marked.utility.js +10 -3
  350. package/dist/cjs/utility/dto/is-property-should-be-marked.utility.js.map +1 -1
  351. package/dist/cjs/utility/dto/is-should-be-generated.utility.d.ts +11 -1
  352. package/dist/cjs/utility/dto/is-should-be-generated.utility.js +10 -3
  353. package/dist/cjs/utility/dto/is-should-be-generated.utility.js.map +1 -1
  354. package/dist/cjs/utility/dto/validate-property-config.utility.d.ts +1 -1
  355. package/dist/cjs/utility/error-exception.utility.d.ts +5 -0
  356. package/dist/cjs/utility/error-exception.utility.js +5 -0
  357. package/dist/cjs/utility/error-exception.utility.js.map +1 -1
  358. package/dist/cjs/utility/error-string.utility.d.ts +8 -1
  359. package/dist/cjs/utility/error-string.utility.js +6 -0
  360. package/dist/cjs/utility/error-string.utility.js.map +1 -1
  361. package/dist/cjs/utility/generate-entity-information.utility.d.ts +8 -1
  362. package/dist/cjs/utility/generate-entity-information.utility.js +7 -17
  363. package/dist/cjs/utility/generate-entity-information.utility.js.map +1 -1
  364. package/dist/cjs/utility/get-entity-columns.utility.d.ts +7 -1
  365. package/dist/cjs/utility/get-entity-columns.utility.js +6 -0
  366. package/dist/cjs/utility/get-entity-columns.utility.js.map +1 -1
  367. package/dist/cjs/utility/index.d.ts +10 -10
  368. package/dist/cjs/utility/is-error-of-type.utility.d.ts +7 -1
  369. package/dist/cjs/utility/is-error-of-type.utility.js +7 -16
  370. package/dist/cjs/utility/is-error-of-type.utility.js.map +1 -1
  371. package/dist/cjs/utility/logger.utility.d.ts +4 -0
  372. package/dist/cjs/utility/logger.utility.js +4 -0
  373. package/dist/cjs/utility/logger.utility.js.map +1 -1
  374. package/dist/cjs/validator/all-or-none-of-listed-properties.validator.d.ts +1 -1
  375. package/dist/cjs/validator/all-or-none-of-listed-properties.validator.js +3 -3
  376. package/dist/cjs/validator/all-or-none-of-listed-properties.validator.js.map +1 -1
  377. package/dist/cjs/validator/has-at-least-one-and-only-one-of-listed-properties.validator.d.ts +1 -1
  378. package/dist/cjs/validator/has-at-least-one-and-only-one-of-listed-properties.validator.js +3 -3
  379. package/dist/cjs/validator/has-at-least-one-and-only-one-of-listed-properties.validator.js.map +1 -1
  380. package/dist/cjs/validator/has-at-least-one-of-listed-properties.validator.d.ts +1 -1
  381. package/dist/cjs/validator/has-at-least-one-of-listed-properties.validator.js +3 -3
  382. package/dist/cjs/validator/has-at-least-one-of-listed-properties.validator.js.map +1 -1
  383. package/dist/cjs/validator/has-at-least-one-property.validator.d.ts +1 -1
  384. package/dist/cjs/validator/has-at-least-one-property.validator.js +3 -3
  385. package/dist/cjs/validator/has-at-least-one-property.validator.js.map +1 -1
  386. package/dist/cjs/validator/has-paired-custom-suffixes-fields.validator.d.ts +12 -1
  387. package/dist/cjs/validator/has-paired-custom-suffixes-fields.validator.js +25 -95
  388. package/dist/cjs/validator/has-paired-custom-suffixes-fields.validator.js.map +1 -1
  389. package/dist/cjs/validator/index.d.ts +8 -6
  390. package/dist/cjs/validator/is-regular-expression.validator.d.ts +6 -1
  391. package/dist/cjs/validator/is-regular-expression.validator.js +8 -3
  392. package/dist/cjs/validator/is-regular-expression.validator.js.map +1 -1
  393. package/dist/cjs/validator/must-match-one-of-schemas.validator.d.ts +36 -0
  394. package/dist/cjs/validator/must-match-one-of-schemas.validator.js +190 -0
  395. package/dist/cjs/validator/must-match-one-of-schemas.validator.js.map +1 -0
  396. package/dist/cjs/validator/only-one-of-listed-properties.validator.d.ts +1 -1
  397. package/dist/cjs/validator/only-one-of-listed-properties.validator.js +3 -3
  398. package/dist/cjs/validator/only-one-of-listed-properties.validator.js.map +1 -1
  399. package/dist/esm/class/api/index.d.ts +1 -1
  400. package/dist/esm/class/api/service-base.class.d.ts +2 -3
  401. package/dist/esm/class/api/service-base.class.js.map +1 -0
  402. package/dist/esm/class/index.d.ts +4 -3
  403. package/dist/esm/class/metadata-storage.class.d.ts +2 -2
  404. package/dist/esm/{src/class → class}/metadata-storage.class.js +1 -0
  405. package/dist/esm/class/metadata-storage.class.js.map +1 -0
  406. package/dist/esm/class/utility/dto/property/factory/boolean.class.d.ts +4 -3
  407. package/dist/esm/class/utility/dto/property/factory/boolean.class.js.map +1 -0
  408. package/dist/esm/class/utility/dto/property/factory/date.class.d.ts +4 -3
  409. package/dist/esm/class/utility/dto/property/factory/date.class.js.map +1 -0
  410. package/dist/esm/class/utility/dto/property/factory/enum.class.d.ts +4 -3
  411. package/dist/esm/class/utility/dto/property/factory/enum.class.js.map +1 -0
  412. package/dist/esm/class/utility/dto/property/factory/index.d.ts +8 -6
  413. package/dist/esm/class/utility/dto/property/factory/number.class.d.ts +5 -4
  414. package/dist/esm/{src/class → class}/utility/dto/property/factory/number.class.js +1 -3
  415. package/dist/esm/class/utility/dto/property/factory/number.class.js.map +1 -0
  416. package/dist/esm/class/utility/dto/property/factory/object.class.d.ts +6 -4
  417. package/dist/esm/{src/class → class}/utility/dto/property/factory/object.class.js +2 -1
  418. package/dist/esm/class/utility/dto/property/factory/object.class.js.map +1 -0
  419. package/dist/esm/class/utility/dto/property/factory/relation.class.d.ts +5 -4
  420. package/dist/esm/{src/class → class}/utility/dto/property/factory/relation.class.js +0 -3
  421. package/dist/esm/class/utility/dto/property/factory/relation.class.js.map +1 -0
  422. package/dist/esm/class/utility/dto/property/factory/string.class.d.ts +4 -3
  423. package/dist/esm/class/utility/dto/property/factory/string.class.js.map +1 -0
  424. package/dist/esm/class/utility/dto/property/factory/uuid.class.d.ts +4 -3
  425. package/dist/esm/class/utility/dto/property/factory/uuid.class.js.map +1 -0
  426. package/dist/esm/class/utility/dto/strategy/body.class.d.ts +3 -3
  427. package/dist/esm/{src/class → class}/utility/dto/strategy/body.class.js +1 -4
  428. package/dist/esm/class/utility/dto/strategy/body.class.js.map +1 -0
  429. package/dist/esm/class/utility/dto/strategy/index.d.ts +4 -4
  430. package/dist/esm/class/utility/dto/strategy/query.class.d.ts +3 -3
  431. package/dist/esm/{src/class → class}/utility/dto/strategy/query.class.js +0 -3
  432. package/dist/esm/class/utility/dto/strategy/query.class.js.map +1 -0
  433. package/dist/esm/class/utility/dto/strategy/request.class.d.ts +3 -3
  434. package/dist/esm/{src/class → class}/utility/dto/strategy/request.class.js +0 -3
  435. package/dist/esm/class/utility/dto/strategy/request.class.js.map +1 -0
  436. package/dist/esm/class/utility/dto/strategy/response.class.d.ts +3 -3
  437. package/dist/esm/{src/class → class}/utility/dto/strategy/response.class.js +0 -3
  438. package/dist/esm/class/utility/dto/strategy/response.class.js.map +1 -0
  439. package/dist/esm/constant/date.constant.js.map +1 -0
  440. package/dist/esm/constant/decorator/api/controller.constant.js.map +1 -0
  441. package/dist/esm/constant/decorator/api/function.constant.d.ts +1 -1
  442. package/dist/esm/constant/decorator/api/function.constant.js +9 -0
  443. package/dist/esm/constant/decorator/api/function.constant.js.map +1 -0
  444. package/dist/esm/constant/decorator/api/index.d.ts +3 -3
  445. package/dist/esm/constant/decorator/api/property-describe.constant.js.map +1 -0
  446. package/dist/esm/constant/dto/exception.constant.js.map +1 -0
  447. package/dist/esm/constant/dto/index.d.ts +3 -3
  448. package/dist/esm/constant/dto/list.constant.d.ts +1 -2
  449. package/dist/esm/{src/constant → constant}/dto/list.constant.js +1 -1
  450. package/dist/esm/constant/dto/list.constant.js.map +1 -0
  451. package/dist/esm/constant/dto/transformer-value.constant.js.map +1 -0
  452. package/dist/esm/constant/factory/dto/get-list-query.constant.d.ts +1 -0
  453. package/dist/esm/{src/constant → constant}/factory/dto/get-list-query.constant.js +2 -0
  454. package/dist/esm/constant/factory/dto/get-list-query.constant.js.map +1 -0
  455. package/dist/esm/constant/factory/dto/index.d.ts +1 -1
  456. package/dist/esm/constant/index.d.ts +8 -6
  457. package/dist/esm/constant/interface/api/filter.constant.js.map +1 -0
  458. package/dist/esm/constant/interface/api/index.d.ts +2 -2
  459. package/dist/esm/constant/interface/api/property/index.d.ts +2 -2
  460. package/dist/esm/constant/interface/api/property/string.constant.js.map +1 -0
  461. package/dist/esm/constant/interface/api/property/wallet.constant.js.map +1 -0
  462. package/dist/esm/constant/number.constant.js.map +1 -0
  463. package/dist/esm/constant/utility/dto/constant.d.ts +3 -2
  464. package/dist/esm/{src/constant → constant}/utility/dto/constant.js +6 -10
  465. package/dist/esm/constant/utility/dto/constant.js.map +1 -0
  466. package/dist/esm/constant/utility/dto/generate.constant.js.map +1 -0
  467. package/dist/esm/constant/utility/dto/index.d.ts +2 -0
  468. package/dist/esm/constant/validator/has-paired-custom-suffixes-fields.constant.d.ts +5 -0
  469. package/dist/esm/constant/validator/has-paired-custom-suffixes-fields.constant.js +87 -0
  470. package/dist/esm/constant/validator/has-paired-custom-suffixes-fields.constant.js.map +1 -0
  471. package/dist/esm/constant/validator/index.d.ts +1 -0
  472. package/dist/esm/decorator/api/controller.decorator.d.ts +3 -2
  473. package/dist/esm/decorator/api/controller.decorator.js.map +1 -0
  474. package/dist/esm/decorator/api/function/create.decorator.d.ts +7 -1
  475. package/dist/esm/{src/decorator → decorator}/api/function/create.decorator.js +12 -16
  476. package/dist/esm/decorator/api/function/create.decorator.js.map +1 -0
  477. package/dist/esm/decorator/api/function/decorator.d.ts +10 -3
  478. package/dist/esm/{src/decorator → decorator}/api/function/decorator.js +7 -3
  479. package/dist/esm/decorator/api/function/decorator.js.map +1 -0
  480. package/dist/esm/decorator/api/function/delete.decorator.d.ts +7 -1
  481. package/dist/esm/{src/decorator → decorator}/api/function/delete.decorator.js +12 -16
  482. package/dist/esm/decorator/api/function/delete.decorator.js.map +1 -0
  483. package/dist/esm/decorator/api/function/get-list.decorator.d.ts +8 -2
  484. package/dist/esm/{src/decorator → decorator}/api/function/get-list.decorator.js +12 -16
  485. package/dist/esm/decorator/api/function/get-list.decorator.js.map +1 -0
  486. package/dist/esm/decorator/api/function/get-many.decorator.d.ts +7 -1
  487. package/dist/esm/{src/decorator → decorator}/api/function/get-many.decorator.js +13 -16
  488. package/dist/esm/decorator/api/function/get-many.decorator.js.map +1 -0
  489. package/dist/esm/decorator/api/function/get.decorator.d.ts +7 -1
  490. package/dist/esm/{src/decorator → decorator}/api/function/get.decorator.js +13 -16
  491. package/dist/esm/decorator/api/function/get.decorator.js.map +1 -0
  492. package/dist/esm/decorator/api/function/index.d.ts +7 -7
  493. package/dist/esm/decorator/api/function/update.decorator.d.ts +7 -1
  494. package/dist/esm/{src/decorator → decorator}/api/function/update.decorator.js +12 -16
  495. package/dist/esm/decorator/api/function/update.decorator.js.map +1 -0
  496. package/dist/esm/decorator/api/index.d.ts +5 -5
  497. package/dist/esm/decorator/api/method.decorator.d.ts +8 -1
  498. package/dist/esm/{src/decorator → decorator}/api/method.decorator.js +9 -6
  499. package/dist/esm/decorator/api/method.decorator.js.map +1 -0
  500. package/dist/esm/decorator/api/property/boolean.decorator.d.ts +52 -1
  501. package/dist/esm/{src/decorator → decorator}/api/property/boolean.decorator.js +99 -7
  502. package/dist/esm/decorator/api/property/boolean.decorator.js.map +1 -0
  503. package/dist/esm/decorator/api/property/copy.decorator.d.ts +16 -0
  504. package/dist/esm/decorator/api/property/copy.decorator.js +47 -0
  505. package/dist/esm/decorator/api/property/copy.decorator.js.map +1 -0
  506. package/dist/esm/decorator/api/property/date.decorator.d.ts +56 -1
  507. package/dist/esm/{src/decorator → decorator}/api/property/date.decorator.js +132 -7
  508. package/dist/esm/decorator/api/property/date.decorator.js.map +1 -0
  509. package/dist/esm/decorator/api/property/describe.decorator.d.ts +82 -1
  510. package/dist/esm/decorator/api/property/describe.decorator.js +94 -0
  511. package/dist/esm/decorator/api/property/describe.decorator.js.map +1 -0
  512. package/dist/esm/decorator/api/property/enum.decorator.d.ts +75 -1
  513. package/dist/esm/{src/decorator → decorator}/api/property/enum.decorator.js +112 -0
  514. package/dist/esm/decorator/api/property/enum.decorator.js.map +1 -0
  515. package/dist/esm/decorator/api/property/index.d.ts +9 -7
  516. package/dist/esm/decorator/api/property/number.decorator.d.ts +67 -1
  517. package/dist/esm/{src/decorator → decorator}/api/property/number.decorator.js +152 -12
  518. package/dist/esm/decorator/api/property/number.decorator.js.map +1 -0
  519. package/dist/esm/decorator/api/property/object.decorator.d.ts +27 -1
  520. package/dist/esm/decorator/api/property/object.decorator.js +246 -0
  521. package/dist/esm/decorator/api/property/object.decorator.js.map +1 -0
  522. package/dist/esm/decorator/api/property/string.decorator.d.ts +68 -1
  523. package/dist/esm/{src/decorator → decorator}/api/property/string.decorator.js +132 -15
  524. package/dist/esm/decorator/api/property/string.decorator.js.map +1 -0
  525. package/dist/esm/decorator/api/property/uuid.decorator.d.ts +42 -1
  526. package/dist/esm/{src/decorator → decorator}/api/property/uuid.decorator.js +92 -7
  527. package/dist/esm/decorator/api/property/uuid.decorator.js.map +1 -0
  528. package/dist/esm/decorator/api/service.decorator.d.ts +8 -2
  529. package/dist/esm/{src/decorator → decorator}/api/service.decorator.js +10 -6
  530. package/dist/esm/decorator/api/service.decorator.js.map +1 -0
  531. package/dist/esm/enum/decorator/api/action.enum.js.map +1 -0
  532. package/dist/esm/enum/decorator/api/authentication-type.enum.js.map +1 -0
  533. package/dist/esm/enum/decorator/api/controller/index.d.ts +2 -2
  534. package/dist/esm/enum/decorator/api/controller/load-relations-strategy.enum.js.map +1 -0
  535. package/dist/esm/enum/decorator/api/controller/request-transformer-type.enum.js.map +1 -0
  536. package/dist/esm/enum/decorator/api/dto-type.enum.js.map +1 -0
  537. package/dist/esm/enum/decorator/api/function/index.d.ts +1 -1
  538. package/dist/esm/enum/decorator/api/function/type.enum.js.map +1 -0
  539. package/dist/esm/enum/decorator/api/index.d.ts +7 -7
  540. package/dist/esm/enum/decorator/api/property/data-type.enum.js.map +1 -0
  541. package/dist/esm/enum/decorator/api/property/date/identifier.enum.js.map +1 -0
  542. package/dist/esm/enum/decorator/api/property/date/index.d.ts +2 -2
  543. package/dist/esm/enum/decorator/api/property/date/type.enum.js.map +1 -0
  544. package/dist/esm/enum/decorator/api/property/desribe-type.enum.js.map +1 -0
  545. package/dist/esm/enum/decorator/api/property/index.d.ts +5 -5
  546. package/dist/esm/enum/decorator/api/property/number-type.enum.js.map +1 -0
  547. package/dist/esm/enum/decorator/api/property/string-type.enum.js.map +1 -0
  548. package/dist/esm/enum/decorator/api/route-type.enum.js.map +1 -0
  549. package/dist/esm/enum/exception.enum.js.map +1 -0
  550. package/dist/esm/enum/filter-operation.enum.js.map +1 -0
  551. package/dist/esm/enum/filter-order-direction.enum.js.map +1 -0
  552. package/dist/esm/enum/index.d.ts +6 -4
  553. package/dist/esm/enum/utility/error-string-action.enum.js.map +1 -0
  554. package/dist/esm/enum/utility/index.d.ts +1 -1
  555. package/dist/esm/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.d.ts +5 -0
  556. package/dist/esm/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.js +9 -0
  557. package/dist/esm/enum/validator/has-paired-custom-suffixes-fields-argument-type.enum.js.map +1 -0
  558. package/dist/esm/enum/validator/index.d.ts +2 -0
  559. package/dist/esm/enum/validator/must-match-one-of-schemas-error-type.enum.d.ts +6 -0
  560. package/dist/esm/enum/validator/must-match-one-of-schemas-error-type.enum.js +10 -0
  561. package/dist/esm/enum/validator/must-match-one-of-schemas-error-type.enum.js.map +1 -0
  562. package/dist/esm/factory/api/controller.factory.d.ts +4 -3
  563. package/dist/esm/{src/factory → factory}/api/controller.factory.js +12 -16
  564. package/dist/esm/factory/api/controller.factory.js.map +1 -0
  565. package/dist/esm/factory/api/index.d.ts +1 -1
  566. package/dist/esm/index.d.ts +10 -10
  567. package/dist/esm/{src/index.js → index.js} +31 -0
  568. package/dist/esm/{src/index.js.map → index.js.map} +1 -1
  569. package/dist/esm/{src/interceptor → interceptor}/correlation-id-response-body.interceptor.js +1 -1
  570. package/dist/esm/interceptor/correlation-id-response-body.interceptor.js.map +1 -0
  571. package/dist/esm/interceptor/index.d.ts +1 -1
  572. package/dist/esm/interface/api-authentication-request.interface.d.ts +1 -1
  573. package/dist/esm/interface/api-request-validator.interface.d.ts +3 -2
  574. package/dist/esm/interface/class/dto/index.d.ts +1 -1
  575. package/dist/esm/interface/class/dto/strategy.interface.d.ts +2 -2
  576. package/dist/esm/interface/class/index.d.ts +2 -2
  577. package/dist/esm/interface/decorator/api/controller/base.interface.d.ts +1 -1
  578. package/dist/esm/interface/decorator/api/controller/index.d.ts +3 -3
  579. package/dist/esm/interface/decorator/api/controller/properties/route/authentication.interface.d.ts +1 -1
  580. package/dist/esm/interface/decorator/api/controller/properties/route/auto-dto-config.interface.d.ts +1 -1
  581. package/dist/esm/interface/decorator/api/controller/properties/route/base-request.interface.d.ts +3 -3
  582. package/dist/esm/interface/decorator/api/controller/properties/route/base-response.interface.d.ts +2 -2
  583. package/dist/esm/interface/decorator/api/controller/properties/route/base.interface.d.ts +2 -4
  584. package/dist/esm/interface/decorator/api/controller/properties/route/index.d.ts +7 -7
  585. package/dist/esm/interface/decorator/api/controller/properties/route/with-auto-dto.interface.d.ts +2 -3
  586. package/dist/esm/interface/decorator/api/controller/properties/route/with-dto.interface.d.ts +2 -2
  587. package/dist/esm/interface/decorator/api/controller/properties.interface.d.ts +3 -3
  588. package/dist/esm/interface/decorator/api/function/create-executor-properties.interface.d.ts +2 -2
  589. package/dist/esm/interface/decorator/api/function/delete-executor-properties.interface.d.ts +2 -2
  590. package/dist/esm/interface/decorator/api/function/get-executor-properties.interface.d.ts +2 -2
  591. package/dist/esm/interface/decorator/api/function/get-list-executor-properties.interface.d.ts +2 -2
  592. package/dist/esm/interface/decorator/api/function/get-many-executor-properties.interface.d.ts +2 -2
  593. package/dist/esm/interface/decorator/api/function/index.d.ts +7 -7
  594. package/dist/esm/interface/decorator/api/function/properties.interface.d.ts +1 -1
  595. package/dist/esm/interface/decorator/api/function/update-executor-properties.interface.d.ts +2 -2
  596. package/dist/esm/interface/decorator/api/index.d.ts +5 -5
  597. package/dist/esm/interface/decorator/api/method/index.d.ts +2 -2
  598. package/dist/esm/interface/decorator/api/method/properties.interface.d.ts +2 -4
  599. package/dist/esm/interface/dto-generate-factory.interface.d.ts +5 -4
  600. package/dist/esm/interface/entity/index.d.ts +2 -2
  601. package/dist/esm/interface/entity/interface.d.ts +2 -2
  602. package/dist/esm/interface/index.d.ts +10 -8
  603. package/dist/esm/interface/utility/api/controller/index.d.ts +1 -1
  604. package/dist/esm/interface/utility/error-string-properties.interface.d.ts +1 -1
  605. package/dist/esm/interface/utility/get-entity-columns-properties.interface.d.ts +1 -1
  606. package/dist/esm/interface/utility/index.d.ts +3 -2
  607. package/dist/esm/interface/validator/index.d.ts +1 -0
  608. package/dist/esm/interface/validator/must-match-one-of-schemas-discriminator-config.interface.d.ts +6 -0
  609. package/dist/esm/type/api-request-transformer.type.d.ts +3 -3
  610. package/dist/esm/type/class/controller/index.d.ts +1 -1
  611. package/dist/esm/type/class/controller/method.type.d.ts +2 -2
  612. package/dist/esm/type/class/index.d.ts +3 -3
  613. package/dist/esm/type/class/metadata.type.d.ts +1 -1
  614. package/dist/esm/type/decorator/api/controller/constructor.type.d.ts +1 -1
  615. package/dist/esm/type/decorator/api/controller/get-list-query.type.d.ts +2 -2
  616. package/dist/esm/type/decorator/api/controller/index.d.ts +5 -5
  617. package/dist/esm/type/decorator/api/controller/properties/route/base-request-relations.type.d.ts +1 -1
  618. package/dist/esm/type/decorator/api/controller/properties/route/base-request-transformers.type.d.ts +2 -2
  619. package/dist/esm/type/decorator/api/controller/properties/route/base-response-transformers.type.d.ts +2 -2
  620. package/dist/esm/type/decorator/api/controller/properties/route/index.d.ts +3 -3
  621. package/dist/esm/type/decorator/api/controller/properties-route.type.d.ts +2 -2
  622. package/dist/esm/type/decorator/api/controller/transformer-config.type.d.ts +2 -2
  623. package/dist/esm/type/decorator/api/filter/extracted-allowed-types.type.d.ts +1 -1
  624. package/dist/esm/type/decorator/api/filter/index.d.ts +4 -4
  625. package/dist/esm/type/decorator/api/filter/order-by.type.d.ts +1 -1
  626. package/dist/esm/type/decorator/api/function/index.d.ts +9 -9
  627. package/dist/esm/type/decorator/api/function/properties.type.d.ts +1 -1
  628. package/dist/esm/type/decorator/api/property/base/array/index.d.ts +2 -2
  629. package/dist/esm/type/decorator/api/property/base/index.d.ts +4 -4
  630. package/dist/esm/type/decorator/api/property/base/properties.type.d.ts +2 -4
  631. package/dist/esm/type/decorator/api/property/date-properties.type.d.ts +2 -2
  632. package/dist/esm/type/decorator/api/property/describe/array/index.d.ts +2 -2
  633. package/dist/esm/type/decorator/api/property/describe/base-properties.type.d.ts +1 -1
  634. package/dist/esm/type/decorator/api/property/describe/boolean-properties.type.d.ts +3 -3
  635. package/dist/esm/type/decorator/api/property/describe/date-properties.type.d.ts +3 -3
  636. package/dist/esm/type/decorator/api/property/describe/dto/body-properties.type.d.ts +2 -2
  637. package/dist/esm/type/decorator/api/property/describe/dto/index.d.ts +6 -5
  638. package/dist/esm/type/decorator/api/property/describe/dto/properties.type.d.ts +1 -1
  639. package/dist/esm/type/decorator/api/property/describe/dto/query/index.d.ts +2 -2
  640. package/dist/esm/type/decorator/api/property/describe/dto/query/properties.type.d.ts +2 -3
  641. package/dist/esm/type/decorator/api/property/describe/dto/request-properties.type.d.ts +2 -2
  642. package/dist/esm/type/decorator/api/property/describe/dto/response-properties.type.d.ts +2 -2
  643. package/dist/esm/type/decorator/api/property/describe/enum-properties.type.d.ts +3 -3
  644. package/dist/esm/type/decorator/api/property/describe/index.d.ts +14 -13
  645. package/dist/esm/type/decorator/api/property/describe/number-properties.type.d.ts +4 -4
  646. package/dist/esm/type/decorator/api/property/describe/object/dynamic-with-discriminator-properties.type.d.ts +15 -0
  647. package/dist/esm/type/decorator/api/property/describe/object/index.d.ts +4 -0
  648. package/dist/esm/type/decorator/api/property/describe/object/properties.type.d.ts +4 -0
  649. package/dist/esm/type/decorator/api/property/describe/object/with-discriminator-properties.type.d.ts +14 -0
  650. package/dist/esm/type/decorator/api/property/describe/{object-properties.type.d.ts → object/without-discriminator-properties.type.d.ts} +4 -4
  651. package/dist/esm/type/decorator/api/property/describe/properties/base-dto-properties.type.d.ts +1 -1
  652. package/dist/esm/type/decorator/api/property/describe/properties/base-properties.type.d.ts +2 -2
  653. package/dist/esm/type/decorator/api/property/describe/properties/index.d.ts +2 -2
  654. package/dist/esm/type/decorator/api/property/describe/properties.type.d.ts +8 -8
  655. package/dist/esm/type/decorator/api/property/describe/relation-properties.type.d.ts +2 -2
  656. package/dist/esm/type/decorator/api/property/describe/string-properties.type.d.ts +4 -4
  657. package/dist/esm/type/decorator/api/property/describe/uuid-properties.type.d.ts +3 -3
  658. package/dist/esm/type/decorator/api/property/enum-properties.type.d.ts +1 -1
  659. package/dist/esm/type/decorator/api/property/index.d.ts +8 -6
  660. package/dist/esm/type/decorator/api/property/number-properties.type.d.ts +3 -3
  661. package/dist/esm/type/decorator/api/property/object/dynamic-with-discriminator-properties.type.d.ts +16 -0
  662. package/dist/esm/type/decorator/api/property/object/index.d.ts +4 -0
  663. package/dist/esm/type/decorator/api/property/object/properties.type.d.ts +4 -0
  664. package/dist/esm/type/decorator/api/property/object/with-discriminator-properties.type.d.ts +15 -0
  665. package/dist/esm/type/decorator/api/property/{object-properties.type.d.ts → object/without-discriminator-properties.type.d.ts} +4 -2
  666. package/dist/esm/type/decorator/api/property/string-properties.type.d.ts +2 -2
  667. package/dist/esm/type/decorator/api/property/uuid-properties.type.d.ts +1 -1
  668. package/dist/esm/type/decorator/api/service/index.d.ts +2 -2
  669. package/dist/esm/type/decorator/api/service/keys.type.d.ts +1 -1
  670. package/dist/esm/type/factory/api/controller/index.d.ts +4 -4
  671. package/dist/esm/type/factory/api/controller/method-map.type.d.ts +4 -3
  672. package/dist/esm/type/factory/api/controller/method-name-map.type.d.ts +2 -2
  673. package/dist/esm/type/factory/api/controller/method-name.type.d.ts +3 -3
  674. package/dist/esm/type/factory/api/controller/target-methods.type.d.ts +4 -4
  675. package/dist/esm/type/index.d.ts +10 -5
  676. package/dist/esm/type/utility/api/controller/transform-data/data.type.d.ts +1 -1
  677. package/dist/esm/type/utility/api/controller/transform-data/index.d.ts +3 -3
  678. package/dist/esm/type/utility/api/controller/transform-data/is-validation-properties.type.d.ts +2 -2
  679. package/dist/esm/type/utility/api/controller/transform-data/object-to-transform.type.d.ts +2 -2
  680. package/dist/esm/type/utility/date-range-keys.type.d.ts +1 -1
  681. package/dist/esm/type/utility/dto/generate-allowed-combination.type.d.ts +1 -1
  682. package/dist/esm/type/utility/dto/generate-is-allowed-combination.type.d.ts +2 -2
  683. package/dist/esm/type/utility/dto/index.d.ts +2 -2
  684. package/dist/esm/type/utility/filter-keys.type.d.ts +1 -1
  685. package/dist/esm/type/utility/index.d.ts +7 -7
  686. package/dist/esm/type/validator/has-paired-custom-suffixes-fields/index.d.ts +2 -0
  687. package/dist/esm/type/validator/has-paired-custom-suffixes-fields/operation-config.type.d.ts +7 -0
  688. package/dist/esm/type/validator/has-paired-custom-suffixes-fields/validation-context.type.d.ts +5 -0
  689. package/dist/esm/utility/api/controller/apply-decorators.utility.d.ts +18 -3
  690. package/dist/esm/{src/utility → utility}/api/controller/apply-decorators.utility.js +15 -4
  691. package/dist/esm/utility/api/controller/apply-decorators.utility.js.map +1 -0
  692. package/dist/esm/utility/api/controller/apply-metadata.utility.d.ts +17 -3
  693. package/dist/esm/{src/utility → utility}/api/controller/apply-metadata.utility.js +22 -13
  694. package/dist/esm/utility/api/controller/apply-metadata.utility.js.map +1 -0
  695. package/dist/esm/utility/api/controller/get-list/index.d.ts +2 -2
  696. package/dist/esm/utility/api/controller/get-list/transform-filter.utility.d.ts +10 -1
  697. package/dist/esm/{src/utility → utility}/api/controller/get-list/transform-filter.utility.js +9 -3
  698. package/dist/esm/utility/api/controller/get-list/transform-filter.utility.js.map +1 -0
  699. package/dist/esm/utility/api/controller/get-list/transform-operation.utility.d.ts +8 -1
  700. package/dist/esm/{src/utility → utility}/api/controller/get-list/transform-operation.utility.js +8 -1
  701. package/dist/esm/utility/api/controller/get-list/transform-operation.utility.js.map +1 -0
  702. package/dist/esm/utility/api/controller/get-method-name.utility.d.ts +7 -1
  703. package/dist/esm/{src/utility → utility}/api/controller/get-method-name.utility.js +6 -0
  704. package/dist/esm/utility/api/controller/get-method-name.utility.js.map +1 -0
  705. package/dist/esm/utility/api/controller/get-primary-column.utility.d.ts +10 -1
  706. package/dist/esm/utility/api/controller/get-primary-column.utility.js +21 -0
  707. package/dist/esm/utility/api/controller/get-primary-column.utility.js.map +1 -0
  708. package/dist/esm/utility/api/controller/handle-request-relations.utility.d.ts +17 -2
  709. package/dist/esm/{src/utility → utility}/api/controller/handle-request-relations.utility.js +15 -5
  710. package/dist/esm/utility/api/controller/handle-request-relations.utility.js.map +1 -0
  711. package/dist/esm/utility/api/controller/index.d.ts +10 -9
  712. package/dist/esm/utility/api/controller/transform-data.utility.d.ts +15 -3
  713. package/dist/esm/{src/utility → utility}/api/controller/transform-data.utility.js +52 -3
  714. package/dist/esm/utility/api/controller/transform-data.utility.js.map +1 -0
  715. package/dist/esm/utility/api/controller/validate-request.utility.d.ts +12 -2
  716. package/dist/esm/{src/utility → utility}/api/controller/validate-request.utility.js +9 -0
  717. package/dist/esm/utility/api/controller/validate-request.utility.js.map +1 -0
  718. package/dist/esm/utility/api/controller/write-dto-swagger.utility.d.ts +17 -3
  719. package/dist/esm/{src/utility → utility}/api/controller/write-dto-swagger.utility.js +21 -12
  720. package/dist/esm/utility/api/controller/write-dto-swagger.utility.js.map +1 -0
  721. package/dist/esm/utility/api/controller/write-method.utility.d.ts +16 -2
  722. package/dist/esm/utility/api/controller/write-method.utility.js +31 -0
  723. package/dist/esm/utility/api/controller/write-method.utility.js.map +1 -0
  724. package/dist/esm/utility/api/filter-order-by-from-entity.utility.d.ts +16 -3
  725. package/dist/esm/{src/utility → utility}/api/filter-order-by-from-entity.utility.js +14 -1
  726. package/dist/esm/utility/api/filter-order-by-from-entity.utility.js.map +1 -0
  727. package/dist/esm/utility/api/index.d.ts +2 -2
  728. package/dist/esm/utility/camel-case-string.utility.d.ts +5 -0
  729. package/dist/esm/{src/utility → utility}/camel-case-string.utility.js +5 -0
  730. package/dist/esm/utility/camel-case-string.utility.js.map +1 -0
  731. package/dist/esm/utility/capitalize-string.utility.d.ts +5 -0
  732. package/dist/esm/{src/utility → utility}/capitalize-string.utility.js +5 -0
  733. package/dist/esm/utility/capitalize-string.utility.js.map +1 -0
  734. package/dist/esm/utility/dto/analize.utility.d.ts +7 -1
  735. package/dist/esm/utility/dto/analize.utility.js +15 -0
  736. package/dist/esm/utility/dto/analize.utility.js.map +1 -0
  737. package/dist/esm/utility/dto/build-decorator.utility.d.ts +19 -4
  738. package/dist/esm/{src/utility → utility}/dto/build-decorator.utility.js +17 -5
  739. package/dist/esm/utility/dto/build-decorator.utility.js.map +1 -0
  740. package/dist/esm/utility/dto/generate-decorator.utility.d.ts +19 -4
  741. package/dist/esm/utility/dto/generate-decorator.utility.js +27 -0
  742. package/dist/esm/utility/dto/generate-decorator.utility.js.map +1 -0
  743. package/dist/esm/utility/dto/generate-dynamic.utility.d.ts +21 -0
  744. package/dist/esm/utility/dto/generate-dynamic.utility.js +92 -0
  745. package/dist/esm/utility/dto/generate-dynamic.utility.js.map +1 -0
  746. package/dist/esm/utility/dto/generate-exception.utility.d.ts +7 -0
  747. package/dist/esm/{src/utility → utility}/dto/generate-exception.utility.js +9 -6
  748. package/dist/esm/utility/dto/generate-exception.utility.js.map +1 -0
  749. package/dist/esm/utility/dto/generate-filter-decorator.utility.d.ts +11 -2
  750. package/dist/esm/{src/utility → utility}/dto/generate-filter-decorator.utility.js +9 -3
  751. package/dist/esm/utility/dto/generate-filter-decorator.utility.js.map +1 -0
  752. package/dist/esm/utility/dto/generate-get-list-response.utility.d.ts +9 -0
  753. package/dist/esm/{src/utility → utility}/dto/generate-get-list-response.utility.js +12 -6
  754. package/dist/esm/utility/dto/generate-get-list-response.utility.js.map +1 -0
  755. package/dist/esm/utility/dto/generate-relation-response.utility.d.ts +12 -2
  756. package/dist/esm/{src/utility → utility}/dto/generate-relation-response.utility.js +11 -1
  757. package/dist/esm/utility/dto/generate-relation-response.utility.js.map +1 -0
  758. package/dist/esm/utility/dto/generate.utility.d.ts +17 -2
  759. package/dist/esm/{src/utility → utility}/dto/generate.utility.js +39 -11
  760. package/dist/esm/utility/dto/generate.utility.js.map +1 -0
  761. package/dist/esm/utility/dto/get-decorator-config.utility.d.ts +15 -2
  762. package/dist/esm/{src/utility → utility}/dto/get-decorator-config.utility.js +13 -0
  763. package/dist/esm/utility/dto/get-decorator-config.utility.js.map +1 -0
  764. package/dist/esm/utility/dto/get-get-list-query-base-class.utility.d.ts +13 -2
  765. package/dist/esm/{src/utility → utility}/dto/get-get-list-query-base-class.utility.js +17 -12
  766. package/dist/esm/utility/dto/get-get-list-query-base-class.utility.js.map +1 -0
  767. package/dist/esm/utility/dto/handle-date-property.utility.d.ts +9 -1
  768. package/dist/esm/{src/utility → utility}/dto/handle-date-property.utility.js +8 -3
  769. package/dist/esm/utility/dto/handle-date-property.utility.js.map +1 -0
  770. package/dist/esm/utility/dto/index.d.ts +16 -12
  771. package/dist/esm/utility/dto/is-property-exposed-for-guard.utility.d.ts +10 -2
  772. package/dist/esm/{src/utility → utility}/dto/is-property-exposed-for-guard.utility.js +8 -0
  773. package/dist/esm/utility/dto/is-property-exposed-for-guard.utility.js.map +1 -0
  774. package/dist/esm/utility/dto/is-property-should-be-marked.utility.d.ts +12 -2
  775. package/dist/esm/{src/utility → utility}/dto/is-property-should-be-marked.utility.js +10 -3
  776. package/dist/esm/utility/dto/is-property-should-be-marked.utility.js.map +1 -0
  777. package/dist/esm/utility/dto/is-should-be-generated.utility.d.ts +11 -1
  778. package/dist/esm/{src/utility → utility}/dto/is-should-be-generated.utility.js +10 -3
  779. package/dist/esm/utility/dto/is-should-be-generated.utility.js.map +1 -0
  780. package/dist/esm/utility/dto/validate-property-config.utility.d.ts +1 -1
  781. package/dist/esm/utility/dto/validate-property-config.utility.js.map +1 -0
  782. package/dist/esm/utility/error-exception.utility.d.ts +5 -0
  783. package/dist/esm/{src/utility → utility}/error-exception.utility.js +5 -0
  784. package/dist/esm/utility/error-exception.utility.js.map +1 -0
  785. package/dist/esm/utility/error-string.utility.d.ts +8 -1
  786. package/dist/esm/utility/error-string.utility.js +12 -0
  787. package/dist/esm/utility/error-string.utility.js.map +1 -0
  788. package/dist/esm/utility/generate-entity-information.utility.d.ts +8 -1
  789. package/dist/esm/{src/utility → utility}/generate-entity-information.utility.js +7 -17
  790. package/dist/esm/utility/generate-entity-information.utility.js.map +1 -0
  791. package/dist/esm/utility/get-entity-columns.utility.d.ts +7 -1
  792. package/dist/esm/{src/utility → utility}/get-entity-columns.utility.js +6 -0
  793. package/dist/esm/utility/get-entity-columns.utility.js.map +1 -0
  794. package/dist/esm/utility/index.d.ts +10 -10
  795. package/dist/esm/utility/is-error-of-type.utility.d.ts +7 -1
  796. package/dist/esm/{src/utility → utility}/is-error-of-type.utility.js +7 -16
  797. package/dist/esm/utility/is-error-of-type.utility.js.map +1 -0
  798. package/dist/esm/utility/logger.utility.d.ts +4 -0
  799. package/dist/esm/{src/utility → utility}/logger.utility.js +5 -1
  800. package/dist/esm/utility/logger.utility.js.map +1 -0
  801. package/dist/esm/validator/all-or-none-of-listed-properties.validator.d.ts +1 -1
  802. package/dist/esm/{src/validator → validator}/all-or-none-of-listed-properties.validator.js +5 -5
  803. package/dist/esm/validator/all-or-none-of-listed-properties.validator.js.map +1 -0
  804. package/dist/esm/validator/has-at-least-one-and-only-one-of-listed-properties.validator.d.ts +1 -1
  805. package/dist/esm/{src/validator → validator}/has-at-least-one-and-only-one-of-listed-properties.validator.js +5 -5
  806. package/dist/esm/validator/has-at-least-one-and-only-one-of-listed-properties.validator.js.map +1 -0
  807. package/dist/esm/validator/has-at-least-one-of-listed-properties.validator.d.ts +1 -1
  808. package/dist/esm/{src/validator → validator}/has-at-least-one-of-listed-properties.validator.js +5 -5
  809. package/dist/esm/validator/has-at-least-one-of-listed-properties.validator.js.map +1 -0
  810. package/dist/esm/validator/has-at-least-one-property.validator.d.ts +1 -1
  811. package/dist/esm/{src/validator → validator}/has-at-least-one-property.validator.js +5 -5
  812. package/dist/esm/validator/has-at-least-one-property.validator.js.map +1 -0
  813. package/dist/esm/validator/has-paired-custom-suffixes-fields.validator.d.ts +12 -1
  814. package/dist/esm/{src/validator → validator}/has-paired-custom-suffixes-fields.validator.js +27 -97
  815. package/dist/esm/validator/has-paired-custom-suffixes-fields.validator.js.map +1 -0
  816. package/dist/esm/validator/index.d.ts +8 -6
  817. package/dist/esm/validator/is-regular-expression.validator.d.ts +6 -1
  818. package/dist/esm/validator/is-regular-expression.validator.js +30 -0
  819. package/dist/esm/validator/is-regular-expression.validator.js.map +1 -0
  820. package/dist/esm/validator/must-match-one-of-schemas.validator.d.ts +36 -0
  821. package/dist/esm/validator/must-match-one-of-schemas.validator.js +188 -0
  822. package/dist/esm/validator/must-match-one-of-schemas.validator.js.map +1 -0
  823. package/dist/esm/validator/only-one-of-listed-properties.validator.d.ts +1 -1
  824. package/dist/esm/{src/validator → validator}/only-one-of-listed-properties.validator.js +5 -5
  825. package/dist/esm/validator/only-one-of-listed-properties.validator.js.map +1 -0
  826. package/package.json +4 -2
  827. package/dist/cjs/class/utility/dto/index.d.ts +0 -2
  828. package/dist/cjs/class/utility/dto/property/index.d.ts +0 -1
  829. package/dist/cjs/class/utility/index.d.ts +0 -1
  830. package/dist/cjs/constant/decorator/index.d.ts +0 -1
  831. package/dist/cjs/constant/factory/index.d.ts +0 -1
  832. package/dist/cjs/constant/interface/index.d.ts +0 -1
  833. package/dist/cjs/decorator/index.d.ts +0 -1
  834. package/dist/cjs/enum/decorator/index.d.ts +0 -1
  835. package/dist/cjs/factory/index.d.ts +0 -1
  836. package/dist/cjs/interface/decorator/api/controller/properties/index.d.ts +0 -1
  837. package/dist/cjs/interface/decorator/index.d.ts +0 -1
  838. package/dist/cjs/interface/utility/api/index.d.ts +0 -1
  839. package/dist/cjs/type/decorator/api/controller/properties/index.d.ts +0 -1
  840. package/dist/cjs/type/decorator/api/index.d.ts +0 -5
  841. package/dist/cjs/type/decorator/index.d.ts +0 -1
  842. package/dist/cjs/type/factory/api/index.d.ts +0 -1
  843. package/dist/cjs/type/factory/index.d.ts +0 -1
  844. package/dist/cjs/type/utility/api/controller/index.d.ts +0 -1
  845. package/dist/cjs/type/utility/api/index.d.ts +0 -1
  846. package/dist/esm/class/utility/dto/index.d.ts +0 -2
  847. package/dist/esm/class/utility/dto/property/index.d.ts +0 -1
  848. package/dist/esm/class/utility/index.d.ts +0 -1
  849. package/dist/esm/constant/decorator/index.d.ts +0 -1
  850. package/dist/esm/constant/factory/index.d.ts +0 -1
  851. package/dist/esm/constant/interface/index.d.ts +0 -1
  852. package/dist/esm/decorator/index.d.ts +0 -1
  853. package/dist/esm/enum/decorator/index.d.ts +0 -1
  854. package/dist/esm/factory/index.d.ts +0 -1
  855. package/dist/esm/interface/decorator/api/controller/properties/index.d.ts +0 -1
  856. package/dist/esm/interface/decorator/index.d.ts +0 -1
  857. package/dist/esm/interface/utility/api/index.d.ts +0 -1
  858. package/dist/esm/src/class/api/service-base.class.js.map +0 -1
  859. package/dist/esm/src/class/metadata-storage.class.js.map +0 -1
  860. package/dist/esm/src/class/utility/dto/property/factory/boolean.class.js.map +0 -1
  861. package/dist/esm/src/class/utility/dto/property/factory/date.class.js.map +0 -1
  862. package/dist/esm/src/class/utility/dto/property/factory/enum.class.js.map +0 -1
  863. package/dist/esm/src/class/utility/dto/property/factory/number.class.js.map +0 -1
  864. package/dist/esm/src/class/utility/dto/property/factory/object.class.js.map +0 -1
  865. package/dist/esm/src/class/utility/dto/property/factory/relation.class.js.map +0 -1
  866. package/dist/esm/src/class/utility/dto/property/factory/string.class.js.map +0 -1
  867. package/dist/esm/src/class/utility/dto/property/factory/uuid.class.js.map +0 -1
  868. package/dist/esm/src/class/utility/dto/strategy/body.class.js.map +0 -1
  869. package/dist/esm/src/class/utility/dto/strategy/query.class.js.map +0 -1
  870. package/dist/esm/src/class/utility/dto/strategy/request.class.js.map +0 -1
  871. package/dist/esm/src/class/utility/dto/strategy/response.class.js.map +0 -1
  872. package/dist/esm/src/constant/date.constant.js.map +0 -1
  873. package/dist/esm/src/constant/decorator/api/controller.constant.js.map +0 -1
  874. package/dist/esm/src/constant/decorator/api/function.constant.js +0 -24
  875. package/dist/esm/src/constant/decorator/api/function.constant.js.map +0 -1
  876. package/dist/esm/src/constant/decorator/api/property-describe.constant.js.map +0 -1
  877. package/dist/esm/src/constant/dto/exception.constant.js.map +0 -1
  878. package/dist/esm/src/constant/dto/list.constant.js.map +0 -1
  879. package/dist/esm/src/constant/dto/transformer-value.constant.js.map +0 -1
  880. package/dist/esm/src/constant/factory/dto/get-list-query.constant.js.map +0 -1
  881. package/dist/esm/src/constant/interface/api/filter.constant.js.map +0 -1
  882. package/dist/esm/src/constant/interface/api/property/string.constant.js.map +0 -1
  883. package/dist/esm/src/constant/interface/api/property/wallet.constant.js.map +0 -1
  884. package/dist/esm/src/constant/number.constant.js.map +0 -1
  885. package/dist/esm/src/constant/utility/dto/constant.js.map +0 -1
  886. package/dist/esm/src/constant/utility/dto/generate.constant.js.map +0 -1
  887. package/dist/esm/src/decorator/api/controller.decorator.js.map +0 -1
  888. package/dist/esm/src/decorator/api/function/create.decorator.js.map +0 -1
  889. package/dist/esm/src/decorator/api/function/decorator.js.map +0 -1
  890. package/dist/esm/src/decorator/api/function/delete.decorator.js.map +0 -1
  891. package/dist/esm/src/decorator/api/function/get-list.decorator.js.map +0 -1
  892. package/dist/esm/src/decorator/api/function/get-many.decorator.js.map +0 -1
  893. package/dist/esm/src/decorator/api/function/get.decorator.js.map +0 -1
  894. package/dist/esm/src/decorator/api/function/update.decorator.js.map +0 -1
  895. package/dist/esm/src/decorator/api/method.decorator.js.map +0 -1
  896. package/dist/esm/src/decorator/api/property/boolean.decorator.js.map +0 -1
  897. package/dist/esm/src/decorator/api/property/date.decorator.js.map +0 -1
  898. package/dist/esm/src/decorator/api/property/describe.decorator.js +0 -29
  899. package/dist/esm/src/decorator/api/property/describe.decorator.js.map +0 -1
  900. package/dist/esm/src/decorator/api/property/enum.decorator.js.map +0 -1
  901. package/dist/esm/src/decorator/api/property/number.decorator.js.map +0 -1
  902. package/dist/esm/src/decorator/api/property/object.decorator.js +0 -104
  903. package/dist/esm/src/decorator/api/property/object.decorator.js.map +0 -1
  904. package/dist/esm/src/decorator/api/property/string.decorator.js.map +0 -1
  905. package/dist/esm/src/decorator/api/property/uuid.decorator.js.map +0 -1
  906. package/dist/esm/src/decorator/api/service.decorator.js.map +0 -1
  907. package/dist/esm/src/enum/decorator/api/action.enum.js.map +0 -1
  908. package/dist/esm/src/enum/decorator/api/authentication-type.enum.js.map +0 -1
  909. package/dist/esm/src/enum/decorator/api/controller/load-relations-strategy.enum.js.map +0 -1
  910. package/dist/esm/src/enum/decorator/api/controller/request-transformer-type.enum.js.map +0 -1
  911. package/dist/esm/src/enum/decorator/api/dto-type.enum.js.map +0 -1
  912. package/dist/esm/src/enum/decorator/api/function/type.enum.js.map +0 -1
  913. package/dist/esm/src/enum/decorator/api/property/data-type.enum.js.map +0 -1
  914. package/dist/esm/src/enum/decorator/api/property/date/identifier.enum.js.map +0 -1
  915. package/dist/esm/src/enum/decorator/api/property/date/type.enum.js.map +0 -1
  916. package/dist/esm/src/enum/decorator/api/property/desribe-type.enum.js.map +0 -1
  917. package/dist/esm/src/enum/decorator/api/property/number-type.enum.js.map +0 -1
  918. package/dist/esm/src/enum/decorator/api/property/string-type.enum.js.map +0 -1
  919. package/dist/esm/src/enum/decorator/api/route-type.enum.js.map +0 -1
  920. package/dist/esm/src/enum/exception.enum.js.map +0 -1
  921. package/dist/esm/src/enum/filter-operation.enum.js.map +0 -1
  922. package/dist/esm/src/enum/filter-order-direction.enum.js.map +0 -1
  923. package/dist/esm/src/enum/utility/error-string-action.enum.js.map +0 -1
  924. package/dist/esm/src/factory/api/controller.factory.js.map +0 -1
  925. package/dist/esm/src/interceptor/correlation-id-response-body.interceptor.js.map +0 -1
  926. package/dist/esm/src/utility/api/controller/apply-decorators.utility.js.map +0 -1
  927. package/dist/esm/src/utility/api/controller/apply-metadata.utility.js.map +0 -1
  928. package/dist/esm/src/utility/api/controller/get-list/transform-filter.utility.js.map +0 -1
  929. package/dist/esm/src/utility/api/controller/get-list/transform-operation.utility.js.map +0 -1
  930. package/dist/esm/src/utility/api/controller/get-method-name.utility.js.map +0 -1
  931. package/dist/esm/src/utility/api/controller/get-primary-column.utility.js +0 -13
  932. package/dist/esm/src/utility/api/controller/get-primary-column.utility.js.map +0 -1
  933. package/dist/esm/src/utility/api/controller/handle-request-relations.utility.js.map +0 -1
  934. package/dist/esm/src/utility/api/controller/transform-data.utility.js.map +0 -1
  935. package/dist/esm/src/utility/api/controller/validate-request.utility.js.map +0 -1
  936. package/dist/esm/src/utility/api/controller/write-dto-swagger.utility.js.map +0 -1
  937. package/dist/esm/src/utility/api/controller/write-method.utility.js +0 -18
  938. package/dist/esm/src/utility/api/controller/write-method.utility.js.map +0 -1
  939. package/dist/esm/src/utility/api/filter-order-by-from-entity.utility.js.map +0 -1
  940. package/dist/esm/src/utility/camel-case-string.utility.js.map +0 -1
  941. package/dist/esm/src/utility/capitalize-string.utility.js.map +0 -1
  942. package/dist/esm/src/utility/dto/analize.utility.js +0 -25
  943. package/dist/esm/src/utility/dto/analize.utility.js.map +0 -1
  944. package/dist/esm/src/utility/dto/build-decorator.utility.js.map +0 -1
  945. package/dist/esm/src/utility/dto/generate-decorator.utility.js +0 -13
  946. package/dist/esm/src/utility/dto/generate-decorator.utility.js.map +0 -1
  947. package/dist/esm/src/utility/dto/generate-exception.utility.js.map +0 -1
  948. package/dist/esm/src/utility/dto/generate-filter-decorator.utility.js.map +0 -1
  949. package/dist/esm/src/utility/dto/generate-get-list-response.utility.js.map +0 -1
  950. package/dist/esm/src/utility/dto/generate-relation-response.utility.js.map +0 -1
  951. package/dist/esm/src/utility/dto/generate.utility.js.map +0 -1
  952. package/dist/esm/src/utility/dto/get-decorator-config.utility.js.map +0 -1
  953. package/dist/esm/src/utility/dto/get-get-list-query-base-class.utility.js.map +0 -1
  954. package/dist/esm/src/utility/dto/handle-date-property.utility.js.map +0 -1
  955. package/dist/esm/src/utility/dto/is-property-exposed-for-guard.utility.js.map +0 -1
  956. package/dist/esm/src/utility/dto/is-property-should-be-marked.utility.js.map +0 -1
  957. package/dist/esm/src/utility/dto/is-should-be-generated.utility.js.map +0 -1
  958. package/dist/esm/src/utility/dto/validate-property-config.utility.js.map +0 -1
  959. package/dist/esm/src/utility/error-exception.utility.js.map +0 -1
  960. package/dist/esm/src/utility/error-string.utility.js +0 -6
  961. package/dist/esm/src/utility/error-string.utility.js.map +0 -1
  962. package/dist/esm/src/utility/generate-entity-information.utility.js.map +0 -1
  963. package/dist/esm/src/utility/get-entity-columns.utility.js.map +0 -1
  964. package/dist/esm/src/utility/is-error-of-type.utility.js.map +0 -1
  965. package/dist/esm/src/utility/logger.utility.js.map +0 -1
  966. package/dist/esm/src/validator/all-or-none-of-listed-properties.validator.js.map +0 -1
  967. package/dist/esm/src/validator/has-at-least-one-and-only-one-of-listed-properties.validator.js.map +0 -1
  968. package/dist/esm/src/validator/has-at-least-one-of-listed-properties.validator.js.map +0 -1
  969. package/dist/esm/src/validator/has-at-least-one-property.validator.js.map +0 -1
  970. package/dist/esm/src/validator/has-paired-custom-suffixes-fields.validator.js.map +0 -1
  971. package/dist/esm/src/validator/is-regular-expression.validator.js +0 -25
  972. package/dist/esm/src/validator/is-regular-expression.validator.js.map +0 -1
  973. package/dist/esm/src/validator/only-one-of-listed-properties.validator.js.map +0 -1
  974. package/dist/esm/type/decorator/api/controller/properties/index.d.ts +0 -1
  975. package/dist/esm/type/decorator/api/index.d.ts +0 -5
  976. package/dist/esm/type/decorator/index.d.ts +0 -1
  977. package/dist/esm/type/factory/api/index.d.ts +0 -1
  978. package/dist/esm/type/factory/index.d.ts +0 -1
  979. package/dist/esm/type/utility/api/controller/index.d.ts +0 -1
  980. package/dist/esm/type/utility/api/index.d.ts +0 -1
  981. /package/dist/esm/{src/class → class}/api/service-base.class.js +0 -0
  982. /package/dist/esm/{src/class → class}/utility/dto/property/factory/boolean.class.js +0 -0
  983. /package/dist/esm/{src/class → class}/utility/dto/property/factory/date.class.js +0 -0
  984. /package/dist/esm/{src/class → class}/utility/dto/property/factory/enum.class.js +0 -0
  985. /package/dist/esm/{src/class → class}/utility/dto/property/factory/string.class.js +0 -0
  986. /package/dist/esm/{src/class → class}/utility/dto/property/factory/uuid.class.js +0 -0
  987. /package/dist/esm/{src/constant → constant}/date.constant.js +0 -0
  988. /package/dist/esm/{src/constant → constant}/decorator/api/controller.constant.js +0 -0
  989. /package/dist/esm/{src/constant → constant}/decorator/api/property-describe.constant.js +0 -0
  990. /package/dist/esm/{src/constant → constant}/dto/exception.constant.js +0 -0
  991. /package/dist/esm/{src/constant → constant}/dto/transformer-value.constant.js +0 -0
  992. /package/dist/esm/{src/constant → constant}/interface/api/filter.constant.js +0 -0
  993. /package/dist/esm/{src/constant → constant}/interface/api/property/string.constant.js +0 -0
  994. /package/dist/esm/{src/constant → constant}/interface/api/property/wallet.constant.js +0 -0
  995. /package/dist/esm/{src/constant → constant}/number.constant.js +0 -0
  996. /package/dist/esm/{src/constant → constant}/utility/dto/generate.constant.js +0 -0
  997. /package/dist/esm/{src/decorator → decorator}/api/controller.decorator.js +0 -0
  998. /package/dist/esm/{src/enum → enum}/decorator/api/action.enum.js +0 -0
  999. /package/dist/esm/{src/enum → enum}/decorator/api/authentication-type.enum.js +0 -0
  1000. /package/dist/esm/{src/enum → enum}/decorator/api/controller/load-relations-strategy.enum.js +0 -0
  1001. /package/dist/esm/{src/enum → enum}/decorator/api/controller/request-transformer-type.enum.js +0 -0
  1002. /package/dist/esm/{src/enum → enum}/decorator/api/dto-type.enum.js +0 -0
  1003. /package/dist/esm/{src/enum → enum}/decorator/api/function/type.enum.js +0 -0
  1004. /package/dist/esm/{src/enum → enum}/decorator/api/property/data-type.enum.js +0 -0
  1005. /package/dist/esm/{src/enum → enum}/decorator/api/property/date/identifier.enum.js +0 -0
  1006. /package/dist/esm/{src/enum → enum}/decorator/api/property/date/type.enum.js +0 -0
  1007. /package/dist/esm/{src/enum → enum}/decorator/api/property/desribe-type.enum.js +0 -0
  1008. /package/dist/esm/{src/enum → enum}/decorator/api/property/number-type.enum.js +0 -0
  1009. /package/dist/esm/{src/enum → enum}/decorator/api/property/string-type.enum.js +0 -0
  1010. /package/dist/esm/{src/enum → enum}/decorator/api/route-type.enum.js +0 -0
  1011. /package/dist/esm/{src/enum → enum}/exception.enum.js +0 -0
  1012. /package/dist/esm/{src/enum → enum}/filter-operation.enum.js +0 -0
  1013. /package/dist/esm/{src/enum → enum}/filter-order-direction.enum.js +0 -0
  1014. /package/dist/esm/{src/enum → enum}/utility/error-string-action.enum.js +0 -0
  1015. /package/dist/esm/{src/utility → utility}/dto/validate-property-config.utility.js +0 -0
@@ -1,9 +1,3 @@
1
- import { applyDecorators } from '@nestjs/common';
2
- import { ApiProperty, ApiResponseProperty } from '@nestjs/swagger';
3
- import { Expose, Exclude, Type, Transform } from 'class-transformer';
4
- import { isInt, IsOptional, IsArray, ArrayMinSize, ArrayMaxSize, ArrayNotEmpty, IsInt, IsNumber, IsDivisibleBy, Min, Max } from 'class-validator';
5
- import random from 'lodash/random';
6
- import '../../../constant/decorator/api/function.constant.js';
7
1
  import { NUMBER_CONSTANT } from '../../../constant/number.constant.js';
8
2
  import '../../../enum/decorator/api/action.enum.js';
9
3
  import '../../../enum/decorator/api/authentication-type.enum.js';
@@ -18,10 +12,78 @@ import '../../../enum/decorator/api/property/desribe-type.enum.js';
18
12
  import { EApiPropertyNumberType } from '../../../enum/decorator/api/property/number-type.enum.js';
19
13
  import '../../../enum/decorator/api/property/string-type.enum.js';
20
14
  import '../../../enum/decorator/api/route-type.enum.js';
21
- import '../../../enum/exception.enum.js';
22
- import '../../../enum/filter-order-direction.enum.js';
23
- import '../../../enum/utility/error-string-action.enum.js';
15
+ import { applyDecorators } from '@nestjs/common';
16
+ import { ApiProperty, ApiResponseProperty } from '@nestjs/swagger';
17
+ import { Expose, Exclude, Type, Transform } from 'class-transformer';
18
+ import { isInt, IsOptional, IsArray, ArrayMinSize, ArrayMaxSize, ArrayNotEmpty, IsInt, IsNumber, IsDivisibleBy, Min, Max } from 'class-validator';
19
+ import random from 'lodash/random';
24
20
 
21
+ /**
22
+ * Creates a decorator that applies NestJS Swagger and class-validator/class-transformer decorators
23
+ * for number properties in DTOs.
24
+ *
25
+ * This decorator handles number properties with support for:
26
+ * - Integer and double/float formats
27
+ * - Single numbers or arrays of numbers
28
+ * - Response/Request specific decorators
29
+ * - Min/max value constraints
30
+ * - Multiple-of validation
31
+ * - Automatic transformation from string to number
32
+ * - Range validation
33
+ *
34
+ * The decorator can automatically generate an example value within the specified range
35
+ * if one is not provided, and applies appropriate validation rules based on the configuration.
36
+ * @param {TApiPropertyNumberProperties} properties - Configuration options for the number property
37
+ * @returns {Function} A decorator function that can be applied to a class property
38
+ * @example
39
+ * ```typescript
40
+ * // Simple integer property
41
+ * class ProductDto {
42
+ * @ApiPropertyNumber({
43
+ * entity: { name: 'Product' },
44
+ * description: 'quantity',
45
+ * format: EApiPropertyNumberType.INTEGER,
46
+ * isRequired: true,
47
+ * minimum: 1,
48
+ * maximum: 100,
49
+ * exampleValue: 10
50
+ * })
51
+ * quantity: number;
52
+ * }
53
+ *
54
+ * // Float property with multiple-of validation
55
+ * class PriceDto {
56
+ * @ApiPropertyNumber({
57
+ * entity: { name: 'Price' },
58
+ * description: 'amount',
59
+ * format: EApiPropertyNumberType.DOUBLE,
60
+ * isRequired: true,
61
+ * minimum: 0.01,
62
+ * maximum: 999999.99,
63
+ * multipleOf: 0.01,
64
+ * exampleValue: 29.99
65
+ * })
66
+ * amount: number;
67
+ * }
68
+ *
69
+ * // Array of numbers
70
+ * class PointsDto {
71
+ * @ApiPropertyNumber({
72
+ * entity: { name: 'Coordinate' },
73
+ * description: 'values',
74
+ * format: EApiPropertyNumberType.INTEGER,
75
+ * isArray: true,
76
+ * minItems: 2,
77
+ * maxItems: 3,
78
+ * isUniqueItems: true,
79
+ * minimum: -180,
80
+ * maximum: 180,
81
+ * exampleValue: [45, 90, 135]
82
+ * })
83
+ * coordinates: number[];
84
+ * }
85
+ * ```
86
+ */
25
87
  function ApiPropertyNumber(properties) {
26
88
  if (properties.exampleValue === undefined) {
27
89
  properties.exampleValue = random(properties.minimum, properties.maximum);
@@ -31,6 +93,14 @@ function ApiPropertyNumber(properties) {
31
93
  const decorators = buildDecorators(properties, apiPropertyOptions);
32
94
  return applyDecorators(...decorators);
33
95
  }
96
+ /**
97
+ * Builds the API property options object from the provided property configuration.
98
+ * Sets up number-specific properties including format, min/max values, example value,
99
+ * and multiple-of constraint.
100
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
101
+ * @returns {ApiPropertyOptions} The Swagger API property options object
102
+ * @private
103
+ */
34
104
  function buildApiPropertyOptions(properties) {
35
105
  const apiPropertyOptions = {
36
106
  description: `${String(properties.entity.name)} ${properties.description ?? ""}`,
@@ -52,16 +122,32 @@ function buildApiPropertyOptions(properties) {
52
122
  }
53
123
  apiPropertyOptions.minimum = properties.minimum;
54
124
  apiPropertyOptions.maximum = properties.maximum;
55
- if ((properties.isResponse === false || properties.isResponse === undefined) && properties.multipleOf !== undefined) {
125
+ if ((properties.isResponse === false || properties.isResponse === undefined) && properties.multipleOf != undefined) {
56
126
  apiPropertyOptions.multipleOf = properties.multipleOf;
57
127
  }
58
128
  return apiPropertyOptions;
59
129
  }
130
+ /**
131
+ * Builds all the necessary decorators for the number property based on the configuration.
132
+ * Combines API property decorators, response decorators, request decorators, format decorators,
133
+ * transform decorators, and number validation decorators.
134
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
135
+ * @param {ApiPropertyOptions} apiPropertyOptions - The Swagger API property options
136
+ * @returns {Array<PropertyDecorator>} An array of decorators to apply to the property
137
+ * @private
138
+ */
60
139
  function buildDecorators(properties, apiPropertyOptions) {
61
140
  const decorators = [ApiProperty(apiPropertyOptions)];
62
141
  decorators.push(...buildResponseDecorators(properties), ...buildRequestDecorators(properties), ...buildFormatDecorators(properties), ...buildTransformDecorators(properties), ...buildNumberValidationDecorators(properties));
63
142
  return decorators;
64
143
  }
144
+ /**
145
+ * Builds decorators for number format validation based on the specified format type.
146
+ * Handles integer and double/float formats with appropriate validators.
147
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
148
+ * @returns {Array<PropertyDecorator>} An array of format-specific validation decorators
149
+ * @private
150
+ */
65
151
  function buildFormatDecorators(properties) {
66
152
  const decorators = [];
67
153
  const isArray = properties.isArray ?? false;
@@ -85,15 +171,29 @@ function buildFormatDecorators(properties) {
85
171
  }
86
172
  return decorators;
87
173
  }
174
+ /**
175
+ * Builds decorators for number-specific validation including multiple-of constraint,
176
+ * minimum value, and maximum value validation.
177
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
178
+ * @returns {Array<PropertyDecorator>} An array of number validation decorators
179
+ * @private
180
+ */
88
181
  function buildNumberValidationDecorators(properties) {
89
182
  const decorators = [];
90
183
  const isArray = properties.isArray ?? false;
91
- if ((properties.isResponse === false || properties.isResponse === undefined) && properties.multipleOf !== undefined) {
184
+ if ((properties.isResponse === false || properties.isResponse === undefined) && properties.multipleOf != undefined) {
92
185
  // eslint-disable-next-line @elsikora/typescript/naming-convention
93
186
  decorators.push(IsDivisibleBy(properties.multipleOf, { each: isArray }), Min(properties.minimum, { each: isArray }), Max(properties.maximum, { each: isArray }));
94
187
  }
95
188
  return decorators;
96
189
  }
190
+ /**
191
+ * Builds decorators for request validation including optional status,
192
+ * array validation, and size constraints for number properties.
193
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
194
+ * @returns {Array<PropertyDecorator>} An array of request validation decorators
195
+ * @private
196
+ */
97
197
  function buildRequestDecorators(properties) {
98
198
  const decorators = [];
99
199
  if (properties.isResponse === false || properties.isResponse === undefined) {
@@ -109,6 +209,13 @@ function buildRequestDecorators(properties) {
109
209
  }
110
210
  return decorators;
111
211
  }
212
+ /**
213
+ * Builds decorators for response serialization including API response property,
214
+ * expose, and exclude decorators for number properties.
215
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
216
+ * @returns {Array<PropertyDecorator>} An array of response serialization decorators
217
+ * @private
218
+ */
112
219
  function buildResponseDecorators(properties) {
113
220
  const decorators = [];
114
221
  if (properties.isResponse) {
@@ -122,6 +229,13 @@ function buildResponseDecorators(properties) {
122
229
  }
123
230
  return decorators;
124
231
  }
232
+ /**
233
+ * Builds decorators for type transformation from string to number.
234
+ * Handles both single values and arrays with appropriate transformers.
235
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
236
+ * @returns {Array<PropertyDecorator>} An array of type transformation decorators
237
+ * @private
238
+ */
125
239
  function buildTransformDecorators(properties) {
126
240
  const decorators = [];
127
241
  if (!properties.isResponse) {
@@ -134,6 +248,13 @@ function buildTransformDecorators(properties) {
134
248
  }
135
249
  return decorators;
136
250
  }
251
+ /**
252
+ * Determines the appropriate Swagger format for the number property.
253
+ * Maps integer types to int32/int64 based on value range, and handles double format.
254
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
255
+ * @returns {string} The Swagger format string
256
+ * @private
257
+ */
137
258
  function getFormat(properties) {
138
259
  switch (properties.format) {
139
260
  case EApiPropertyNumberType.DOUBLE: {
@@ -147,6 +268,13 @@ function getFormat(properties) {
147
268
  }
148
269
  }
149
270
  }
271
+ /**
272
+ * Determines the appropriate Swagger data type for the number property.
273
+ * Maps formatter types to the corresponding API property data types.
274
+ * @param {TApiPropertyNumberProperties} properties - The property configuration
275
+ * @returns {EApiPropertyDataType.INTEGER | EApiPropertyDataType.NUMBER} The Swagger data type
276
+ * @private
277
+ */
150
278
  function getType(properties) {
151
279
  switch (properties.format) {
152
280
  case EApiPropertyNumberType.DOUBLE: {
@@ -157,12 +285,24 @@ function getType(properties) {
157
285
  }
158
286
  }
159
287
  }
288
+ /**
289
+ * Validates the configuration options for the API property number.
290
+ * Performs extensive validation including:
291
+ * - Min/max values consistency
292
+ * - Multiple-of constraints and example value compatibility
293
+ * - Example values within min/max range
294
+ * - Array options consistency (min/max items, unique items)
295
+ * @param {TApiPropertyNumberProperties} properties - The property configuration to validate
296
+ * @returns {void}
297
+ * @throws {Error} If the configuration is invalid with detailed error messages
298
+ * @private
299
+ */
160
300
  function validateOptions(properties) {
161
301
  const errors = [];
162
302
  if (properties.minimum > properties.maximum) {
163
303
  errors.push("'minimum' is greater than maximum");
164
304
  }
165
- if (properties.multipleOf !== undefined) {
305
+ if (properties.multipleOf != undefined) {
166
306
  if (Array.isArray(properties.exampleValue)) {
167
307
  for (const example of properties.exampleValue) {
168
308
  if (!isInt(example / properties.multipleOf)) {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"number.decorator.js","sources":["../../../../../../src/decorator/api/property/number.decorator.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
@@ -1,2 +1,28 @@
1
- import type { TApiPropertyObjectProperties } from "../../../type/decorator/api/property/object-properties.type";
1
+ import type { TApiPropertyObjectProperties } from '../../../type/decorator/api/property/index';
2
+ /**
3
+ * Creates a decorator that applies NestJS Swagger and class-validator/class-transformer decorators
4
+ * for object properties in DTOs.
5
+ *
6
+ * This decorator handles complex object properties with support for:
7
+ * - Single type objects
8
+ * - Polymorphic objects (with discriminator)
9
+ * - Arrays of objects
10
+ * - Response/Request specific decorators
11
+ * - Validation rules
12
+ * - Transformation rules
13
+ * @param {TApiPropertyObjectProperties} options - Configuration options for the object property
14
+ * @returns {Function} A decorator function that can be applied to a class property
15
+ * @example
16
+ * ```typescript
17
+ * class UserDto {
18
+ * @ApiPropertyObject({
19
+ * entity: { name: 'Address' },
20
+ * type: AddressDto,
21
+ * isRequired: true,
22
+ * shouldValidateNested: true
23
+ * })
24
+ * address: AddressDto;
25
+ * }
26
+ * ```
27
+ */
2
28
  export declare function ApiPropertyObject(options: TApiPropertyObjectProperties): <Y>(target: object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
@@ -0,0 +1,246 @@
1
+ import { applyDecorators } from '@nestjs/common';
2
+ import { getSchemaPath, ApiProperty, ApiResponseProperty } from '@nestjs/swagger';
3
+ import { MustMatchOneOfSchemasValidator } from '../../../validator/must-match-one-of-schemas.validator.js';
4
+ import { Expose, Exclude, Type } from 'class-transformer';
5
+ import { IsOptional, IsArray, ArrayMinSize, ArrayMaxSize, ArrayNotEmpty, ValidateNested } from 'class-validator';
6
+
7
+ /**
8
+ * Creates a decorator that applies NestJS Swagger and class-validator/class-transformer decorators
9
+ * for object properties in DTOs.
10
+ *
11
+ * This decorator handles complex object properties with support for:
12
+ * - Single type objects
13
+ * - Polymorphic objects (with discriminator)
14
+ * - Arrays of objects
15
+ * - Response/Request specific decorators
16
+ * - Validation rules
17
+ * - Transformation rules
18
+ * @param {TApiPropertyObjectProperties} options - Configuration options for the object property
19
+ * @returns {Function} A decorator function that can be applied to a class property
20
+ * @example
21
+ * ```typescript
22
+ * class UserDto {
23
+ * @ApiPropertyObject({
24
+ * entity: { name: 'Address' },
25
+ * type: AddressDto,
26
+ * isRequired: true,
27
+ * shouldValidateNested: true
28
+ * })
29
+ * address: AddressDto;
30
+ * }
31
+ * ```
32
+ */
33
+ function ApiPropertyObject(options) {
34
+ validateOptions(options);
35
+ const apiPropertyOptions = buildApiPropertyOptions(options);
36
+ const decorators = buildDecorators(options, apiPropertyOptions);
37
+ return applyDecorators(...decorators);
38
+ }
39
+ /**
40
+ * Builds the API property options object from the provided property configuration.
41
+ * Handles different scenarios including single type, multiple types, dynamically generated types, and arrays.
42
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
43
+ * @returns {ApiPropertyOptions} The Swagger API property options object
44
+ * @private
45
+ */
46
+ function buildApiPropertyOptions(properties) {
47
+ const apiPropertyOptions = {
48
+ description: `${String(properties.entity.name)} ${properties.description ?? ""}`,
49
+ // eslint-disable-next-line @elsikora/typescript/naming-convention
50
+ nullable: properties.isNullable,
51
+ };
52
+ if (Array.isArray(properties.type)) {
53
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-function-type
54
+ apiPropertyOptions.oneOf = properties.type.map((type) => {
55
+ return { $ref: getSchemaPath(type) };
56
+ });
57
+ if (properties.discriminator) {
58
+ apiPropertyOptions.discriminator = {
59
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-function-type
60
+ mapping: Object.fromEntries(Object.keys(properties.discriminator.mapping).map((key) => [key, getSchemaPath(properties.discriminator?.mapping[key])])),
61
+ propertyName: properties.discriminator.propertyName,
62
+ };
63
+ }
64
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-assignment
65
+ apiPropertyOptions.type = "object";
66
+ }
67
+ else if ("isDynamicallyGenerated" in properties && properties.isDynamicallyGenerated) {
68
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-function-type
69
+ apiPropertyOptions.oneOf = Object.entries(properties.generatedDTOs).map(([_key, value]) => {
70
+ return { $ref: getSchemaPath(value) };
71
+ });
72
+ if (properties.discriminator) {
73
+ apiPropertyOptions.discriminator = {
74
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-function-type
75
+ mapping: Object.fromEntries(Object.keys(properties.discriminator.mapping).map((key) => [key, getSchemaPath(properties.generatedDTOs[key])])),
76
+ propertyName: properties.discriminator.propertyName,
77
+ };
78
+ }
79
+ // eslint-disable-next-line @elsikora/typescript/no-unsafe-assignment
80
+ apiPropertyOptions.type = "object";
81
+ }
82
+ else {
83
+ apiPropertyOptions.type = properties.type;
84
+ }
85
+ apiPropertyOptions.required = properties.isResponse === false || properties.isResponse === undefined ? properties.isRequired : false;
86
+ if (properties.additionalProperties) {
87
+ apiPropertyOptions.additionalProperties = properties.additionalProperties;
88
+ }
89
+ if (properties.isArray) {
90
+ apiPropertyOptions.isArray = true;
91
+ apiPropertyOptions.minItems = properties.minItems;
92
+ apiPropertyOptions.maxItems = properties.maxItems;
93
+ apiPropertyOptions.uniqueItems = properties.isUniqueItems;
94
+ apiPropertyOptions.description = `Array of ${String(properties.entity.name)} ${properties.description ?? ""}`;
95
+ }
96
+ return apiPropertyOptions;
97
+ }
98
+ /**
99
+ * Builds all the necessary decorators for the property based on the configuration.
100
+ * Combines API property decorators, response decorators, request decorators, transform decorators,
101
+ * and validation decorators.
102
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
103
+ * @param {ApiPropertyOptions} apiPropertyOptions - The Swagger API property options
104
+ * @returns {Array<PropertyDecorator>} An array of decorators to apply to the property
105
+ * @private
106
+ */
107
+ function buildDecorators(properties, apiPropertyOptions) {
108
+ const decorators = [ApiProperty(apiPropertyOptions)];
109
+ decorators.push(...buildResponseDecorators(properties), ...buildRequestDecorators(properties), ...buildTransformDecorators(properties), ...buildObjectValidationDecorators(properties));
110
+ return decorators;
111
+ }
112
+ /**
113
+ * Builds decorators for validation of nested objects.
114
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
115
+ * @returns {Array<PropertyDecorator>} An array of object validation decorators
116
+ * @private
117
+ */
118
+ function buildObjectValidationDecorators(properties) {
119
+ const decorators = [];
120
+ const isArray = properties.isArray ?? false;
121
+ if (!properties.isResponse && properties.shouldValidateNested) {
122
+ // eslint-disable-next-line @elsikora/typescript/naming-convention
123
+ decorators.push(ValidateNested({ each: isArray }));
124
+ }
125
+ return decorators;
126
+ }
127
+ /**
128
+ * Builds decorators for request validation including optional status,
129
+ * array validation, and size constraints.
130
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
131
+ * @returns {Array<PropertyDecorator>} An array of request validation decorators
132
+ * @private
133
+ */
134
+ function buildRequestDecorators(properties) {
135
+ const decorators = [];
136
+ if (properties.isResponse === false || properties.isResponse === undefined) {
137
+ if (!properties.isRequired) {
138
+ decorators.push(IsOptional());
139
+ }
140
+ if (properties.isArray === true) {
141
+ decorators.push(IsArray(), ArrayMinSize(properties.minItems), ArrayMaxSize(properties.maxItems));
142
+ if (properties.minItems > 0) {
143
+ decorators.push(ArrayNotEmpty());
144
+ }
145
+ }
146
+ }
147
+ return decorators;
148
+ }
149
+ /**
150
+ * Builds decorators for response serialization including API response property,
151
+ * expose, and exclude decorators.
152
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
153
+ * @returns {Array<PropertyDecorator>} An array of response serialization decorators
154
+ * @private
155
+ */
156
+ function buildResponseDecorators(properties) {
157
+ const decorators = [];
158
+ if (properties.isResponse) {
159
+ decorators.push(ApiResponseProperty());
160
+ if (properties.isExpose === undefined || properties.isExpose) {
161
+ decorators.push(Expose());
162
+ }
163
+ else {
164
+ decorators.push(Exclude());
165
+ }
166
+ }
167
+ return decorators;
168
+ }
169
+ /**
170
+ * Builds decorators for type transformation including handling of discriminator-based
171
+ * polymorphic objects.
172
+ * @param {TApiPropertyObjectProperties} properties - The property configuration
173
+ * @returns {Array<PropertyDecorator>} An array of type transformation decorators
174
+ * @private
175
+ */
176
+ function buildTransformDecorators(properties) {
177
+ const decorators = [];
178
+ if (Array.isArray(properties.type) && properties.discriminator) {
179
+ decorators.push(MustMatchOneOfSchemasValidator({
180
+ discriminator: properties.discriminator,
181
+ schemas: properties.type,
182
+ }), Type(() => Object, {
183
+ discriminator: {
184
+ property: properties.discriminator.propertyName,
185
+ subTypes: Object.entries(properties.discriminator.mapping).map(([key, value]) => {
186
+ return { name: key, value };
187
+ }),
188
+ },
189
+ // eslint-disable-next-line @elsikora/typescript/naming-convention
190
+ keepDiscriminatorProperty: properties.discriminator.shouldKeepDiscriminatorProperty,
191
+ }));
192
+ }
193
+ else if ("isDynamicallyGenerated" in properties && properties.isDynamicallyGenerated) {
194
+ decorators.push(MustMatchOneOfSchemasValidator({
195
+ discriminator: properties.discriminator,
196
+ schemas: properties.generatedDTOs,
197
+ }), Type(() => Object, {
198
+ discriminator: {
199
+ property: properties.discriminator.propertyName,
200
+ subTypes: Object.entries(properties.discriminator.mapping).map(([key, value]) => {
201
+ return { name: key, value: properties.generatedDTOs[value] };
202
+ }),
203
+ },
204
+ // eslint-disable-next-line @elsikora/typescript/naming-convention
205
+ keepDiscriminatorProperty: properties.discriminator.shouldKeepDiscriminatorProperty,
206
+ }));
207
+ }
208
+ else {
209
+ decorators.push(Type(() => properties.type));
210
+ }
211
+ return decorators;
212
+ }
213
+ /**
214
+ * Validates the configuration options for the API property object.
215
+ * Throws an error if the configuration is invalid.
216
+ * @param {TApiPropertyObjectProperties} properties - The property configuration to validate
217
+ * @returns {void}
218
+ * @throws {Error} If the configuration is invalid
219
+ * @private
220
+ */
221
+ function validateOptions(properties) {
222
+ const errors = [];
223
+ if (properties.isArray && !properties.shouldValidateNested && !properties.isResponse) {
224
+ errors.push("Array property must be 'shouldValidateNested'");
225
+ }
226
+ if (properties.isArray === true) {
227
+ if (properties.minItems > properties.maxItems) {
228
+ errors.push("'minItems' is greater than 'maxItems'");
229
+ }
230
+ if (properties.minItems < 0) {
231
+ errors.push("'minItems' is less than 0");
232
+ }
233
+ if (properties.maxItems < 0) {
234
+ errors.push("'maxItems' is less than 0");
235
+ }
236
+ if (properties.isUniqueItems && properties.maxItems <= 1) {
237
+ errors.push("'uniqueItems' is true but 'maxItems' is less than or equal to 1");
238
+ }
239
+ }
240
+ if (errors.length > 0) {
241
+ throw new Error(`ApiPropertyObject error: ${errors.join("\n")}`);
242
+ }
243
+ }
244
+
245
+ export { ApiPropertyObject };
246
+ //# sourceMappingURL=object.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"object.decorator.js","sources":["../../../../../../src/decorator/api/property/object.decorator.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
@@ -1,2 +1,69 @@
1
- import type { TApiPropertyStringProperties } from "../../../type/decorator/api/property/string-properties.type";
1
+ import type { TApiPropertyStringProperties } from '../../../type/decorator/api/property/index';
2
+ /**
3
+ * Creates a decorator that applies NestJS Swagger and class-validator/class-transformer decorators
4
+ * for string properties in DTOs.
5
+ *
6
+ * This decorator handles string properties with support for:
7
+ * - Various string formats (email, URL, UUID, IP, date, etc.)
8
+ * - Single strings or arrays of strings
9
+ * - Response/Request specific decorators
10
+ * - Pattern validation with regex
11
+ * - Length validation
12
+ * - Case sensitivity options (uppercase, lowercase)
13
+ * - Transformation rules
14
+ *
15
+ * The decorator applies appropriate validation rules based on the format and configuration.
16
+ * @param {TApiPropertyStringProperties} properties - Configuration options for the string property
17
+ * @returns {Function} A decorator function that can be applied to a class property
18
+ * @example
19
+ * ```typescript
20
+ * // Simple string property
21
+ * class UserDto {
22
+ * @ApiPropertyString({
23
+ * entity: { name: 'User' },
24
+ * description: 'name',
25
+ * format: EApiPropertyStringType.STRING,
26
+ * isRequired: true,
27
+ * minLength: 2,
28
+ * maxLength: 100,
29
+ * pattern: '/^[a-zA-Z ]+$/',
30
+ * exampleValue: 'John Doe'
31
+ * })
32
+ * name: string;
33
+ * }
34
+ *
35
+ * // Email format
36
+ * class ContactDto {
37
+ * @ApiPropertyString({
38
+ * entity: { name: 'Contact' },
39
+ * description: 'email address',
40
+ * format: EApiPropertyStringType.EMAIL,
41
+ * isRequired: true,
42
+ * minLength: 5,
43
+ * maxLength: 255,
44
+ * pattern: '/^[\\w-\\.]+@([\\w-]+\\.)+[\\w-]{2,4}$/',
45
+ * exampleValue: 'user@example.com'
46
+ * })
47
+ * email: string;
48
+ * }
49
+ *
50
+ * // Array of URLs
51
+ * class WebsitesDto {
52
+ * @ApiPropertyString({
53
+ * entity: { name: 'Website' },
54
+ * description: 'links',
55
+ * format: EApiPropertyStringType.URL,
56
+ * isArray: true,
57
+ * minItems: 1,
58
+ * maxItems: 5,
59
+ * isUniqueItems: true,
60
+ * minLength: 10,
61
+ * maxLength: 2000,
62
+ * pattern: '/^https?:\\/\\/[\\w\\-]+(\\.[\\w\\-]+)+[/#?]?.*$/',
63
+ * exampleValue: ['https://example.com', 'https://another-example.org']
64
+ * })
65
+ * websites: string[];
66
+ * }
67
+ * ```
68
+ */
2
69
  export declare function ApiPropertyString(properties: TApiPropertyStringProperties): <Y>(target: object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;