ts-packages 1.0.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (781) hide show
  1. package/biome.json +53 -0
  2. package/organize-imports.sh +87 -0
  3. package/package.json +25 -8
  4. package/packages/cache/README.md +791 -0
  5. package/packages/cache/dist/cjs/adapters/memcache/MemcacheCache.d.ts +18 -0
  6. package/packages/cache/dist/cjs/adapters/memcache/MemcacheCache.js +173 -0
  7. package/packages/cache/dist/cjs/adapters/memcache/index.d.ts +1 -0
  8. package/packages/cache/dist/cjs/adapters/memcache/index.js +5 -0
  9. package/packages/cache/dist/cjs/adapters/memory/MemoryCache.d.ts +63 -0
  10. package/packages/cache/dist/cjs/adapters/memory/MemoryCache.js +331 -0
  11. package/packages/cache/dist/cjs/adapters/memory/index.d.ts +1 -0
  12. package/packages/cache/dist/cjs/adapters/memory/index.js +5 -0
  13. package/packages/cache/dist/cjs/adapters/redis/RedisCache.d.ts +67 -0
  14. package/packages/cache/dist/cjs/adapters/redis/RedisCache.js +383 -0
  15. package/packages/cache/dist/cjs/adapters/redis/index.d.ts +1 -0
  16. package/packages/cache/dist/cjs/adapters/redis/index.js +5 -0
  17. package/packages/cache/dist/cjs/core/BaseCache.d.ts +78 -0
  18. package/packages/cache/dist/cjs/core/BaseCache.js +147 -0
  19. package/packages/cache/dist/cjs/core/factory.d.ts +16 -0
  20. package/packages/cache/dist/cjs/core/factory.js +82 -0
  21. package/packages/cache/dist/cjs/core/interfaces/ICache.d.ts +58 -0
  22. package/packages/cache/dist/cjs/core/interfaces/ICache.js +2 -0
  23. package/packages/cache/dist/cjs/core/interfaces/ISession.d.ts +30 -0
  24. package/packages/cache/dist/cjs/core/interfaces/ISession.js +2 -0
  25. package/packages/cache/dist/cjs/core/interfaces/index.d.ts +2 -0
  26. package/packages/cache/dist/cjs/core/interfaces/index.js +2 -0
  27. package/packages/cache/dist/cjs/errors/CacheError.d.ts +12 -0
  28. package/packages/cache/dist/cjs/errors/CacheError.js +12 -0
  29. package/packages/cache/dist/cjs/errors/cacheErrorCodes.d.ts +22 -0
  30. package/packages/cache/dist/cjs/errors/cacheErrorCodes.js +24 -0
  31. package/packages/cache/dist/cjs/errors/index.d.ts +1 -0
  32. package/packages/cache/dist/cjs/errors/index.js +8 -0
  33. package/packages/cache/dist/cjs/index.d.ts +10 -0
  34. package/packages/cache/dist/cjs/index.js +27 -0
  35. package/packages/cache/dist/cjs/middleware/express/cacheMiddleware.d.ts +22 -0
  36. package/packages/cache/dist/cjs/middleware/express/cacheMiddleware.js +116 -0
  37. package/packages/cache/dist/cjs/middleware/express/index.d.ts +1 -0
  38. package/packages/cache/dist/cjs/middleware/express/index.js +7 -0
  39. package/packages/cache/dist/cjs/session/SessionStore.d.ts +57 -0
  40. package/packages/cache/dist/cjs/session/SessionStore.js +217 -0
  41. package/packages/cache/dist/cjs/session/index.d.ts +2 -0
  42. package/packages/cache/dist/cjs/session/index.js +5 -0
  43. package/packages/cache/dist/cjs/types.d.ts +102 -0
  44. package/packages/cache/dist/cjs/types.js +2 -0
  45. package/packages/cache/dist/esm/adapters/memcache/MemcacheCache.d.ts +18 -0
  46. package/packages/cache/dist/esm/adapters/memcache/MemcacheCache.js +166 -0
  47. package/packages/cache/dist/esm/adapters/memcache/index.d.ts +1 -0
  48. package/packages/cache/dist/esm/adapters/memcache/index.js +1 -0
  49. package/packages/cache/dist/esm/adapters/memory/MemoryCache.d.ts +63 -0
  50. package/packages/cache/dist/esm/adapters/memory/MemoryCache.js +327 -0
  51. package/packages/cache/dist/esm/adapters/memory/index.d.ts +1 -0
  52. package/packages/cache/dist/esm/adapters/memory/index.js +1 -0
  53. package/packages/cache/dist/esm/adapters/redis/RedisCache.d.ts +67 -0
  54. package/packages/cache/dist/esm/adapters/redis/RedisCache.js +379 -0
  55. package/packages/cache/dist/esm/adapters/redis/index.d.ts +1 -0
  56. package/packages/cache/dist/esm/adapters/redis/index.js +1 -0
  57. package/packages/cache/dist/esm/core/BaseCache.d.ts +78 -0
  58. package/packages/cache/dist/esm/core/BaseCache.js +143 -0
  59. package/packages/cache/dist/esm/core/factory.d.ts +16 -0
  60. package/packages/cache/dist/esm/core/factory.js +78 -0
  61. package/packages/cache/dist/esm/core/interfaces/ICache.d.ts +58 -0
  62. package/packages/cache/dist/esm/core/interfaces/ICache.js +1 -0
  63. package/packages/cache/dist/esm/core/interfaces/ISession.d.ts +30 -0
  64. package/packages/cache/dist/esm/core/interfaces/ISession.js +1 -0
  65. package/packages/cache/dist/esm/core/interfaces/index.d.ts +2 -0
  66. package/packages/cache/dist/esm/core/interfaces/index.js +1 -0
  67. package/packages/cache/dist/esm/errors/CacheError.d.ts +12 -0
  68. package/packages/cache/dist/esm/errors/CacheError.js +8 -0
  69. package/packages/cache/dist/esm/errors/cacheErrorCodes.d.ts +22 -0
  70. package/packages/cache/dist/esm/errors/cacheErrorCodes.js +21 -0
  71. package/packages/cache/dist/esm/errors/index.d.ts +1 -0
  72. package/packages/cache/dist/esm/errors/index.js +4 -0
  73. package/packages/cache/dist/esm/index.d.ts +10 -0
  74. package/packages/cache/dist/esm/index.js +14 -0
  75. package/packages/cache/dist/esm/middleware/express/cacheMiddleware.d.ts +22 -0
  76. package/packages/cache/dist/esm/middleware/express/cacheMiddleware.js +111 -0
  77. package/packages/cache/dist/esm/middleware/express/index.d.ts +1 -0
  78. package/packages/cache/dist/esm/middleware/express/index.js +1 -0
  79. package/packages/cache/dist/esm/session/SessionStore.d.ts +57 -0
  80. package/packages/cache/dist/esm/session/SessionStore.js +213 -0
  81. package/packages/cache/dist/esm/session/index.d.ts +2 -0
  82. package/packages/cache/dist/esm/session/index.js +1 -0
  83. package/packages/cache/dist/esm/types.d.ts +102 -0
  84. package/packages/cache/dist/esm/types.js +1 -0
  85. package/packages/cache/dist/types/adapters/memcache/MemcacheCache.d.ts +18 -0
  86. package/packages/cache/dist/types/adapters/memcache/index.d.ts +1 -0
  87. package/packages/cache/dist/types/adapters/memory/MemoryCache.d.ts +63 -0
  88. package/packages/cache/dist/types/adapters/memory/index.d.ts +1 -0
  89. package/packages/cache/dist/types/adapters/redis/RedisCache.d.ts +67 -0
  90. package/packages/cache/dist/types/adapters/redis/index.d.ts +1 -0
  91. package/packages/cache/dist/types/core/BaseCache.d.ts +78 -0
  92. package/packages/cache/dist/types/core/factory.d.ts +16 -0
  93. package/packages/cache/dist/types/core/interfaces/ICache.d.ts +58 -0
  94. package/packages/cache/dist/types/core/interfaces/ISession.d.ts +30 -0
  95. package/packages/cache/dist/types/core/interfaces/index.d.ts +2 -0
  96. package/packages/cache/dist/types/errors/CacheError.d.ts +12 -0
  97. package/packages/cache/dist/types/errors/cacheErrorCodes.d.ts +22 -0
  98. package/packages/cache/dist/types/errors/index.d.ts +1 -0
  99. package/packages/cache/dist/types/index.d.ts +10 -0
  100. package/packages/cache/dist/types/middleware/express/cacheMiddleware.d.ts +22 -0
  101. package/packages/cache/dist/types/middleware/express/index.d.ts +1 -0
  102. package/packages/cache/dist/types/session/SessionStore.d.ts +57 -0
  103. package/packages/cache/dist/types/session/index.d.ts +2 -0
  104. package/packages/cache/dist/types/types.d.ts +102 -0
  105. package/packages/cache/node_modules/.bin/rimraf +21 -0
  106. package/packages/cache/node_modules/.bin/tsc +21 -0
  107. package/packages/cache/node_modules/.bin/tsserver +21 -0
  108. package/packages/cache/package.json +52 -0
  109. package/packages/cache/src/adapters/memcache/MemcacheCache.ts +179 -0
  110. package/packages/cache/src/adapters/memcache/index.ts +1 -0
  111. package/packages/cache/src/adapters/memory/MemoryCache.ts +354 -0
  112. package/packages/cache/src/adapters/memory/index.ts +1 -0
  113. package/packages/cache/src/adapters/redis/RedisCache.ts +404 -0
  114. package/packages/cache/src/adapters/redis/index.ts +1 -0
  115. package/packages/cache/src/core/BaseCache.ts +176 -0
  116. package/packages/cache/src/core/factory.ts +103 -0
  117. package/packages/cache/src/core/interfaces/ICache.ts +71 -0
  118. package/packages/cache/src/core/interfaces/ISession.ts +36 -0
  119. package/packages/cache/src/core/interfaces/index.ts +2 -0
  120. package/packages/cache/src/errors/CacheError.ts +21 -0
  121. package/packages/cache/src/errors/cacheErrorCodes.ts +24 -0
  122. package/packages/cache/src/errors/index.ts +6 -0
  123. package/packages/cache/src/index.ts +40 -0
  124. package/packages/cache/src/middleware/express/cacheMiddleware.ts +145 -0
  125. package/packages/cache/src/middleware/express/index.ts +5 -0
  126. package/packages/cache/src/session/SessionStore.ts +236 -0
  127. package/packages/cache/src/session/index.ts +2 -0
  128. package/packages/cache/src/types.ts +111 -0
  129. package/packages/cache/tsconfig.base.json +17 -0
  130. package/packages/cache/tsconfig.cjs.json +10 -0
  131. package/packages/cache/tsconfig.esm.json +10 -0
  132. package/packages/errors-utils/README.md +197 -0
  133. package/packages/errors-utils/dist/cjs/constants/errorCodes.d.ts +37 -0
  134. package/packages/errors-utils/dist/cjs/constants/errorCodes.js +69 -0
  135. package/packages/errors-utils/dist/cjs/constants/errorMessages.d.ts +9 -0
  136. package/packages/errors-utils/dist/cjs/constants/errorMessages.js +77 -0
  137. package/packages/errors-utils/dist/cjs/constants/index.d.ts +2 -0
  138. package/packages/errors-utils/dist/cjs/constants/index.js +18 -0
  139. package/packages/errors-utils/dist/cjs/error/AppError.d.ts +15 -0
  140. package/packages/errors-utils/dist/cjs/error/AppError.js +26 -0
  141. package/packages/errors-utils/dist/cjs/error/BadRequestError.d.ts +4 -0
  142. package/packages/errors-utils/dist/cjs/error/BadRequestError.js +12 -0
  143. package/packages/errors-utils/dist/cjs/error/ConflictError.d.ts +4 -0
  144. package/packages/errors-utils/dist/cjs/error/ConflictError.js +12 -0
  145. package/packages/errors-utils/dist/cjs/error/CryptoIntegrityError.d.ts +4 -0
  146. package/packages/errors-utils/dist/cjs/error/CryptoIntegrityError.js +11 -0
  147. package/packages/errors-utils/dist/cjs/error/ForbiddenError.d.ts +4 -0
  148. package/packages/errors-utils/dist/cjs/error/ForbiddenError.js +12 -0
  149. package/packages/errors-utils/dist/cjs/error/HTTPError.d.ts +6 -0
  150. package/packages/errors-utils/dist/cjs/error/HTTPError.js +11 -0
  151. package/packages/errors-utils/dist/cjs/error/InternalServerError.d.ts +5 -0
  152. package/packages/errors-utils/dist/cjs/error/InternalServerError.js +12 -0
  153. package/packages/errors-utils/dist/cjs/error/NotFoundError.d.ts +4 -0
  154. package/packages/errors-utils/dist/cjs/error/NotFoundError.js +12 -0
  155. package/packages/errors-utils/dist/cjs/error/ServiceUnavailableError.d.ts +4 -0
  156. package/packages/errors-utils/dist/cjs/error/ServiceUnavailableError.js +11 -0
  157. package/packages/errors-utils/dist/cjs/error/TokenExpiredError.d.ts +4 -0
  158. package/packages/errors-utils/dist/cjs/error/TokenExpiredError.js +12 -0
  159. package/packages/errors-utils/dist/cjs/error/TokenMalformedError.d.ts +4 -0
  160. package/packages/errors-utils/dist/cjs/error/TokenMalformedError.js +12 -0
  161. package/packages/errors-utils/dist/cjs/error/TooManyRequestsError.d.ts +5 -0
  162. package/packages/errors-utils/dist/cjs/error/TooManyRequestsError.js +12 -0
  163. package/packages/errors-utils/dist/cjs/error/UnauthorizedError.d.ts +4 -0
  164. package/packages/errors-utils/dist/cjs/error/UnauthorizedError.js +12 -0
  165. package/packages/errors-utils/dist/cjs/error/ValidationError.d.ts +4 -0
  166. package/packages/errors-utils/dist/cjs/error/ValidationError.js +12 -0
  167. package/packages/errors-utils/dist/cjs/error/index.d.ts +14 -0
  168. package/packages/errors-utils/dist/cjs/error/index.js +39 -0
  169. package/packages/errors-utils/dist/cjs/errorRegistry/errorRegistry.d.ts +19 -0
  170. package/packages/errors-utils/dist/cjs/errorRegistry/errorRegistry.js +63 -0
  171. package/packages/errors-utils/dist/cjs/errorRegistry/index.d.ts +3 -0
  172. package/packages/errors-utils/dist/cjs/errorRegistry/index.js +6 -0
  173. package/packages/errors-utils/dist/cjs/index.d.ts +4 -0
  174. package/packages/errors-utils/dist/cjs/index.js +29 -0
  175. package/packages/errors-utils/dist/cjs/middleware/express/errorConverter.middleware.d.ts +2 -0
  176. package/packages/errors-utils/dist/cjs/middleware/express/errorConverter.middleware.js +39 -0
  177. package/packages/errors-utils/dist/cjs/middleware/express/errorHandler.middleware.d.ts +2 -0
  178. package/packages/errors-utils/dist/cjs/middleware/express/errorHandler.middleware.js +19 -0
  179. package/packages/errors-utils/dist/cjs/middleware/express/index.d.ts +2 -0
  180. package/packages/errors-utils/dist/cjs/middleware/express/index.js +18 -0
  181. package/packages/errors-utils/dist/esm/constants/errorCodes.d.ts +37 -0
  182. package/packages/errors-utils/dist/esm/constants/errorCodes.js +66 -0
  183. package/packages/errors-utils/dist/esm/constants/errorMessages.d.ts +9 -0
  184. package/packages/errors-utils/dist/esm/constants/errorMessages.js +74 -0
  185. package/packages/errors-utils/dist/esm/constants/index.d.ts +2 -0
  186. package/packages/errors-utils/dist/esm/constants/index.js +2 -0
  187. package/packages/errors-utils/dist/esm/error/AppError.d.ts +15 -0
  188. package/packages/errors-utils/dist/esm/error/AppError.js +22 -0
  189. package/packages/errors-utils/dist/esm/error/BadRequestError.d.ts +4 -0
  190. package/packages/errors-utils/dist/esm/error/BadRequestError.js +8 -0
  191. package/packages/errors-utils/dist/esm/error/ConflictError.d.ts +4 -0
  192. package/packages/errors-utils/dist/esm/error/ConflictError.js +8 -0
  193. package/packages/errors-utils/dist/esm/error/CryptoIntegrityError.d.ts +4 -0
  194. package/packages/errors-utils/dist/esm/error/CryptoIntegrityError.js +7 -0
  195. package/packages/errors-utils/dist/esm/error/ForbiddenError.d.ts +4 -0
  196. package/packages/errors-utils/dist/esm/error/ForbiddenError.js +8 -0
  197. package/packages/errors-utils/dist/esm/error/HTTPError.d.ts +6 -0
  198. package/packages/errors-utils/dist/esm/error/HTTPError.js +7 -0
  199. package/packages/errors-utils/dist/esm/error/InternalServerError.d.ts +5 -0
  200. package/packages/errors-utils/dist/esm/error/InternalServerError.js +8 -0
  201. package/packages/errors-utils/dist/esm/error/NotFoundError.d.ts +4 -0
  202. package/packages/errors-utils/dist/esm/error/NotFoundError.js +8 -0
  203. package/packages/errors-utils/dist/esm/error/ServiceUnavailableError.d.ts +4 -0
  204. package/packages/errors-utils/dist/esm/error/ServiceUnavailableError.js +7 -0
  205. package/packages/errors-utils/dist/esm/error/TokenExpiredError.d.ts +4 -0
  206. package/packages/errors-utils/dist/esm/error/TokenExpiredError.js +8 -0
  207. package/packages/errors-utils/dist/esm/error/TokenMalformedError.d.ts +4 -0
  208. package/packages/errors-utils/dist/esm/error/TokenMalformedError.js +8 -0
  209. package/packages/errors-utils/dist/esm/error/TooManyRequestsError.d.ts +5 -0
  210. package/packages/errors-utils/dist/esm/error/TooManyRequestsError.js +8 -0
  211. package/packages/errors-utils/dist/esm/error/UnauthorizedError.d.ts +4 -0
  212. package/packages/errors-utils/dist/esm/error/UnauthorizedError.js +8 -0
  213. package/packages/errors-utils/dist/esm/error/ValidationError.d.ts +4 -0
  214. package/packages/errors-utils/dist/esm/error/ValidationError.js +8 -0
  215. package/packages/errors-utils/dist/esm/error/index.d.ts +14 -0
  216. package/packages/errors-utils/dist/esm/error/index.js +23 -0
  217. package/packages/errors-utils/dist/esm/errorRegistry/errorRegistry.d.ts +19 -0
  218. package/packages/errors-utils/dist/esm/errorRegistry/errorRegistry.js +59 -0
  219. package/packages/errors-utils/dist/esm/errorRegistry/index.d.ts +3 -0
  220. package/packages/errors-utils/dist/esm/errorRegistry/index.js +3 -0
  221. package/packages/errors-utils/dist/esm/index.d.ts +4 -0
  222. package/packages/errors-utils/dist/esm/index.js +13 -0
  223. package/packages/errors-utils/dist/esm/middleware/express/errorConverter.middleware.d.ts +2 -0
  224. package/packages/errors-utils/dist/esm/middleware/express/errorConverter.middleware.js +36 -0
  225. package/packages/errors-utils/dist/esm/middleware/express/errorHandler.middleware.d.ts +2 -0
  226. package/packages/errors-utils/dist/esm/middleware/express/errorHandler.middleware.js +16 -0
  227. package/packages/errors-utils/dist/esm/middleware/express/index.d.ts +2 -0
  228. package/packages/errors-utils/dist/esm/middleware/express/index.js +2 -0
  229. package/packages/errors-utils/dist/types/constants/errorCodes.d.ts +37 -0
  230. package/packages/errors-utils/dist/types/constants/errorMessages.d.ts +9 -0
  231. package/packages/errors-utils/dist/types/constants/index.d.ts +2 -0
  232. package/packages/errors-utils/dist/types/error/AppError.d.ts +15 -0
  233. package/packages/errors-utils/dist/types/error/BadRequestError.d.ts +4 -0
  234. package/packages/errors-utils/dist/types/error/ConflictError.d.ts +4 -0
  235. package/packages/errors-utils/dist/types/error/CryptoIntegrityError.d.ts +4 -0
  236. package/packages/errors-utils/dist/types/error/ForbiddenError.d.ts +4 -0
  237. package/packages/errors-utils/dist/types/error/HTTPError.d.ts +6 -0
  238. package/packages/errors-utils/dist/types/error/InternalServerError.d.ts +5 -0
  239. package/packages/errors-utils/dist/types/error/NotFoundError.d.ts +4 -0
  240. package/packages/errors-utils/dist/types/error/ServiceUnavailableError.d.ts +4 -0
  241. package/packages/errors-utils/dist/types/error/TokenExpiredError.d.ts +4 -0
  242. package/packages/errors-utils/dist/types/error/TokenMalformedError.d.ts +4 -0
  243. package/packages/errors-utils/dist/types/error/TooManyRequestsError.d.ts +5 -0
  244. package/packages/errors-utils/dist/types/error/UnauthorizedError.d.ts +4 -0
  245. package/packages/errors-utils/dist/types/error/ValidationError.d.ts +4 -0
  246. package/packages/errors-utils/dist/types/error/index.d.ts +14 -0
  247. package/packages/errors-utils/dist/types/errorRegistry/errorRegistry.d.ts +19 -0
  248. package/packages/errors-utils/dist/types/errorRegistry/index.d.ts +3 -0
  249. package/packages/errors-utils/dist/types/index.d.ts +4 -0
  250. package/packages/errors-utils/dist/types/middleware/express/errorConverter.middleware.d.ts +2 -0
  251. package/packages/errors-utils/dist/types/middleware/express/errorHandler.middleware.d.ts +2 -0
  252. package/packages/errors-utils/dist/types/middleware/express/index.d.ts +2 -0
  253. package/packages/errors-utils/node_modules/.bin/rimraf +21 -0
  254. package/packages/errors-utils/node_modules/.bin/tsc +21 -0
  255. package/packages/errors-utils/node_modules/.bin/tsserver +21 -0
  256. package/packages/errors-utils/package.json +42 -0
  257. package/packages/errors-utils/src/constants/errorCodes.ts +78 -0
  258. package/packages/errors-utils/src/constants/errorMessages.ts +94 -0
  259. package/packages/errors-utils/src/constants/index.ts +2 -0
  260. package/packages/errors-utils/src/error/AppError.ts +36 -0
  261. package/packages/errors-utils/src/error/BadRequestError.ts +14 -0
  262. package/packages/errors-utils/src/error/ConflictError.ts +14 -0
  263. package/packages/errors-utils/src/error/CryptoIntegrityError.ts +8 -0
  264. package/packages/errors-utils/src/error/ForbiddenError.ts +14 -0
  265. package/packages/errors-utils/src/error/HTTPError.ts +17 -0
  266. package/packages/errors-utils/src/error/InternalServerError.ts +18 -0
  267. package/packages/errors-utils/src/error/NotFoundError.ts +14 -0
  268. package/packages/errors-utils/src/error/ServiceUnavailableError.ts +8 -0
  269. package/packages/errors-utils/src/error/TokenExpiredError.ts +14 -0
  270. package/packages/errors-utils/src/error/TokenMalformedError.ts +14 -0
  271. package/packages/errors-utils/src/error/TooManyRequestsError.ts +13 -0
  272. package/packages/errors-utils/src/error/UnauthorizedError.ts +14 -0
  273. package/packages/errors-utils/src/error/ValidationError.ts +14 -0
  274. package/packages/errors-utils/src/error/index.ts +26 -0
  275. package/packages/errors-utils/src/errorRegistry/errorRegistry.ts +74 -0
  276. package/packages/errors-utils/src/errorRegistry/index.ts +4 -0
  277. package/packages/errors-utils/src/index.ts +13 -0
  278. package/packages/errors-utils/src/middleware/express/errorConverter.middleware.ts +52 -0
  279. package/packages/errors-utils/src/middleware/express/errorHandler.middleware.ts +32 -0
  280. package/packages/errors-utils/src/middleware/express/index.ts +2 -0
  281. package/packages/errors-utils/tsconfig.base.json +17 -0
  282. package/packages/errors-utils/tsconfig.cjs.json +9 -0
  283. package/packages/errors-utils/tsconfig.esm.json +9 -0
  284. package/packages/errors-utils/tsconfig.json +21 -0
  285. package/packages/js-extensions/README.md +218 -0
  286. package/packages/js-extensions/dist/cjs/array/array-extensions.d.ts +1 -0
  287. package/packages/js-extensions/dist/cjs/array/array-extensions.js +154 -0
  288. package/packages/js-extensions/dist/cjs/array/index.d.ts +1 -0
  289. package/packages/js-extensions/dist/cjs/array/index.js +5 -0
  290. package/packages/js-extensions/dist/cjs/core/index.d.ts +2 -0
  291. package/packages/js-extensions/dist/cjs/core/index.js +19 -0
  292. package/packages/js-extensions/dist/cjs/core/performance.d.ts +17 -0
  293. package/packages/js-extensions/dist/cjs/core/performance.js +82 -0
  294. package/packages/js-extensions/dist/cjs/core/validation.d.ts +4 -0
  295. package/packages/js-extensions/dist/cjs/core/validation.js +31 -0
  296. package/packages/js-extensions/dist/cjs/core/version.d.ts +1 -0
  297. package/packages/js-extensions/dist/cjs/core/version.js +9 -0
  298. package/packages/js-extensions/dist/cjs/extensions/index.d.ts +4 -0
  299. package/packages/js-extensions/dist/cjs/extensions/index.js +21 -0
  300. package/packages/js-extensions/dist/cjs/index.d.ts +61 -0
  301. package/packages/js-extensions/dist/cjs/index.js +77 -0
  302. package/packages/js-extensions/dist/cjs/init/index.d.ts +2 -0
  303. package/packages/js-extensions/dist/cjs/init/index.js +19 -0
  304. package/packages/js-extensions/dist/cjs/init/initializer.d.ts +3 -0
  305. package/packages/js-extensions/dist/cjs/init/initializer.js +28 -0
  306. package/packages/js-extensions/dist/cjs/init/options.d.ts +3 -0
  307. package/packages/js-extensions/dist/cjs/init/options.js +23 -0
  308. package/packages/js-extensions/dist/cjs/number/index.d.ts +1 -0
  309. package/packages/js-extensions/dist/cjs/number/index.js +5 -0
  310. package/packages/js-extensions/dist/cjs/number/number-extensions.d.ts +1 -0
  311. package/packages/js-extensions/dist/cjs/number/number-extensions.js +125 -0
  312. package/packages/js-extensions/dist/cjs/object/index.d.ts +1 -0
  313. package/packages/js-extensions/dist/cjs/object/index.js +5 -0
  314. package/packages/js-extensions/dist/cjs/object/object-extensions.d.ts +1 -0
  315. package/packages/js-extensions/dist/cjs/object/object-extensions.js +146 -0
  316. package/packages/js-extensions/dist/cjs/string/index.d.ts +1 -0
  317. package/packages/js-extensions/dist/cjs/string/index.js +5 -0
  318. package/packages/js-extensions/dist/cjs/string/string-extensions.d.ts +1 -0
  319. package/packages/js-extensions/dist/cjs/string/string-extensions.js +123 -0
  320. package/packages/js-extensions/dist/cjs/types/extension-types.d.ts +9 -0
  321. package/packages/js-extensions/dist/cjs/types/extension-types.js +2 -0
  322. package/packages/js-extensions/dist/cjs/types/global-augmentations.d.ts +72 -0
  323. package/packages/js-extensions/dist/cjs/types/global-augmentations.js +2 -0
  324. package/packages/js-extensions/dist/cjs/types/index.d.ts +2 -0
  325. package/packages/js-extensions/dist/cjs/types/index.js +19 -0
  326. package/packages/js-extensions/dist/cjs/utils/config.d.ts +4 -0
  327. package/packages/js-extensions/dist/cjs/utils/config.js +25 -0
  328. package/packages/js-extensions/dist/cjs/utils/defineExtension.d.ts +1 -0
  329. package/packages/js-extensions/dist/cjs/utils/defineExtension.js +13 -0
  330. package/packages/js-extensions/dist/cjs/utils/helpers.d.ts +5 -0
  331. package/packages/js-extensions/dist/cjs/utils/helpers.js +37 -0
  332. package/packages/js-extensions/dist/cjs/utils/index.d.ts +3 -0
  333. package/packages/js-extensions/dist/cjs/utils/index.js +20 -0
  334. package/packages/js-extensions/dist/esm/array/array-extensions.d.ts +1 -0
  335. package/packages/js-extensions/dist/esm/array/array-extensions.js +151 -0
  336. package/packages/js-extensions/dist/esm/array/index.d.ts +1 -0
  337. package/packages/js-extensions/dist/esm/array/index.js +1 -0
  338. package/packages/js-extensions/dist/esm/core/index.d.ts +2 -0
  339. package/packages/js-extensions/dist/esm/core/index.js +3 -0
  340. package/packages/js-extensions/dist/esm/core/performance.d.ts +17 -0
  341. package/packages/js-extensions/dist/esm/core/performance.js +74 -0
  342. package/packages/js-extensions/dist/esm/core/validation.d.ts +4 -0
  343. package/packages/js-extensions/dist/esm/core/validation.js +25 -0
  344. package/packages/js-extensions/dist/esm/core/version.d.ts +1 -0
  345. package/packages/js-extensions/dist/esm/core/version.js +5 -0
  346. package/packages/js-extensions/dist/esm/extensions/index.d.ts +4 -0
  347. package/packages/js-extensions/dist/esm/extensions/index.js +5 -0
  348. package/packages/js-extensions/dist/esm/index.d.ts +61 -0
  349. package/packages/js-extensions/dist/esm/index.js +68 -0
  350. package/packages/js-extensions/dist/esm/init/index.d.ts +2 -0
  351. package/packages/js-extensions/dist/esm/init/index.js +3 -0
  352. package/packages/js-extensions/dist/esm/init/initializer.d.ts +3 -0
  353. package/packages/js-extensions/dist/esm/init/initializer.js +24 -0
  354. package/packages/js-extensions/dist/esm/init/options.d.ts +3 -0
  355. package/packages/js-extensions/dist/esm/init/options.js +19 -0
  356. package/packages/js-extensions/dist/esm/number/index.d.ts +1 -0
  357. package/packages/js-extensions/dist/esm/number/index.js +1 -0
  358. package/packages/js-extensions/dist/esm/number/number-extensions.d.ts +1 -0
  359. package/packages/js-extensions/dist/esm/number/number-extensions.js +122 -0
  360. package/packages/js-extensions/dist/esm/object/index.d.ts +1 -0
  361. package/packages/js-extensions/dist/esm/object/index.js +1 -0
  362. package/packages/js-extensions/dist/esm/object/object-extensions.d.ts +1 -0
  363. package/packages/js-extensions/dist/esm/object/object-extensions.js +143 -0
  364. package/packages/js-extensions/dist/esm/string/index.d.ts +1 -0
  365. package/packages/js-extensions/dist/esm/string/index.js +1 -0
  366. package/packages/js-extensions/dist/esm/string/string-extensions.d.ts +1 -0
  367. package/packages/js-extensions/dist/esm/string/string-extensions.js +120 -0
  368. package/packages/js-extensions/dist/esm/types/extension-types.d.ts +9 -0
  369. package/packages/js-extensions/dist/esm/types/extension-types.js +1 -0
  370. package/packages/js-extensions/dist/esm/types/global-augmentations.d.ts +72 -0
  371. package/packages/js-extensions/dist/esm/types/global-augmentations.js +1 -0
  372. package/packages/js-extensions/dist/esm/types/index.d.ts +2 -0
  373. package/packages/js-extensions/dist/esm/types/index.js +3 -0
  374. package/packages/js-extensions/dist/esm/utils/config.d.ts +4 -0
  375. package/packages/js-extensions/dist/esm/utils/config.js +20 -0
  376. package/packages/js-extensions/dist/esm/utils/defineExtension.d.ts +1 -0
  377. package/packages/js-extensions/dist/esm/utils/defineExtension.js +10 -0
  378. package/packages/js-extensions/dist/esm/utils/helpers.d.ts +5 -0
  379. package/packages/js-extensions/dist/esm/utils/helpers.js +30 -0
  380. package/packages/js-extensions/dist/esm/utils/index.d.ts +3 -0
  381. package/packages/js-extensions/dist/esm/utils/index.js +4 -0
  382. package/packages/js-extensions/dist/types/array/array-extensions.d.ts +1 -0
  383. package/packages/js-extensions/dist/types/array/index.d.ts +1 -0
  384. package/packages/js-extensions/dist/types/core/index.d.ts +2 -0
  385. package/packages/js-extensions/dist/types/core/performance.d.ts +17 -0
  386. package/packages/js-extensions/dist/types/core/validation.d.ts +4 -0
  387. package/packages/js-extensions/dist/types/core/version.d.ts +1 -0
  388. package/packages/js-extensions/dist/types/extensions/index.d.ts +4 -0
  389. package/packages/js-extensions/dist/types/index.d.ts +61 -0
  390. package/packages/js-extensions/dist/types/init/index.d.ts +2 -0
  391. package/packages/js-extensions/dist/types/init/initializer.d.ts +3 -0
  392. package/packages/js-extensions/dist/types/init/options.d.ts +3 -0
  393. package/packages/js-extensions/dist/types/number/index.d.ts +1 -0
  394. package/packages/js-extensions/dist/types/number/number-extensions.d.ts +1 -0
  395. package/packages/js-extensions/dist/types/object/index.d.ts +1 -0
  396. package/packages/js-extensions/dist/types/object/object-extensions.d.ts +1 -0
  397. package/packages/js-extensions/dist/types/string/index.d.ts +1 -0
  398. package/packages/js-extensions/dist/types/string/string-extensions.d.ts +1 -0
  399. package/packages/js-extensions/dist/types/types/extension-types.d.ts +9 -0
  400. package/packages/js-extensions/dist/types/types/global-augmentations.d.ts +72 -0
  401. package/packages/js-extensions/dist/types/types/index.d.ts +2 -0
  402. package/packages/js-extensions/dist/types/utils/config.d.ts +4 -0
  403. package/packages/js-extensions/dist/types/utils/defineExtension.d.ts +1 -0
  404. package/packages/js-extensions/dist/types/utils/helpers.d.ts +5 -0
  405. package/packages/js-extensions/dist/types/utils/index.d.ts +3 -0
  406. package/packages/js-extensions/node_modules/.bin/rimraf +21 -0
  407. package/packages/js-extensions/node_modules/.bin/tsc +21 -0
  408. package/packages/js-extensions/node_modules/.bin/tsserver +21 -0
  409. package/packages/js-extensions/package.json +48 -0
  410. package/packages/js-extensions/src/array/array-extensions.ts +292 -0
  411. package/packages/js-extensions/src/array/index.ts +1 -0
  412. package/packages/js-extensions/src/core/index.ts +3 -0
  413. package/packages/js-extensions/src/core/performance.ts +103 -0
  414. package/packages/js-extensions/src/core/validation.ts +42 -0
  415. package/packages/js-extensions/src/core/version.ts +7 -0
  416. package/packages/js-extensions/src/extensions/index.ts +5 -0
  417. package/packages/js-extensions/src/index.ts +122 -0
  418. package/packages/js-extensions/src/init/index.ts +3 -0
  419. package/packages/js-extensions/src/init/initializer.ts +32 -0
  420. package/packages/js-extensions/src/init/options.ts +32 -0
  421. package/packages/js-extensions/src/number/index.ts +1 -0
  422. package/packages/js-extensions/src/number/number-extensions.ts +129 -0
  423. package/packages/js-extensions/src/object/index.ts +1 -0
  424. package/packages/js-extensions/src/object/object-extensions.ts +143 -0
  425. package/packages/js-extensions/src/string/index.ts +1 -0
  426. package/packages/js-extensions/src/string/string-extensions.ts +142 -0
  427. package/packages/js-extensions/src/types/extension-types.ts +12 -0
  428. package/packages/js-extensions/src/types/global-augmentations.ts +81 -0
  429. package/packages/js-extensions/src/types/index.ts +3 -0
  430. package/packages/js-extensions/src/utils/config.ts +33 -0
  431. package/packages/js-extensions/src/utils/defineExtension.ts +14 -0
  432. package/packages/js-extensions/src/utils/helpers.ts +35 -0
  433. package/packages/js-extensions/src/utils/index.ts +4 -0
  434. package/packages/js-extensions/tsconfig.base.json +18 -0
  435. package/packages/js-extensions/tsconfig.cjs.json +9 -0
  436. package/packages/js-extensions/tsconfig.esm.json +9 -0
  437. package/packages/js-extensions/tsconfig.json +22 -0
  438. package/packages/response-utils/README.md +189 -95
  439. package/packages/response-utils/dist/cjs/adapters/express/ExpressResponder.d.ts +18 -0
  440. package/packages/response-utils/dist/cjs/adapters/express/ExpressResponder.js +46 -0
  441. package/packages/response-utils/dist/cjs/constants/httpStatus.d.ts +54 -0
  442. package/packages/response-utils/dist/cjs/constants/httpStatus.js +34 -0
  443. package/packages/response-utils/dist/cjs/core/BaseResponder.d.ts +31 -0
  444. package/packages/response-utils/dist/cjs/core/BaseResponder.js +116 -0
  445. package/packages/response-utils/dist/cjs/core/config.d.ts +15 -0
  446. package/packages/response-utils/dist/cjs/core/config.js +15 -0
  447. package/packages/response-utils/dist/cjs/core/factory.d.ts +3 -0
  448. package/packages/response-utils/dist/cjs/core/factory.js +10 -0
  449. package/packages/response-utils/dist/cjs/core/types.d.ts +32 -0
  450. package/packages/response-utils/dist/cjs/core/types.js +2 -0
  451. package/packages/response-utils/dist/cjs/index.d.ts +8 -0
  452. package/packages/response-utils/dist/cjs/index.js +32 -0
  453. package/packages/response-utils/dist/cjs/legacy.d.ts +19 -0
  454. package/packages/response-utils/dist/cjs/legacy.js +23 -0
  455. package/packages/response-utils/dist/cjs/middleware/express/expressMiddleware.d.ts +3 -0
  456. package/packages/response-utils/dist/cjs/middleware/express/expressMiddleware.js +13 -0
  457. package/packages/response-utils/dist/esm/adapters/express/ExpressResponder.d.ts +18 -0
  458. package/packages/response-utils/dist/esm/adapters/express/ExpressResponder.js +42 -0
  459. package/packages/response-utils/dist/esm/constants/httpStatus.d.ts +54 -0
  460. package/packages/response-utils/dist/esm/constants/httpStatus.js +31 -0
  461. package/packages/response-utils/dist/esm/core/BaseResponder.d.ts +31 -0
  462. package/packages/response-utils/dist/esm/core/BaseResponder.js +112 -0
  463. package/packages/response-utils/dist/esm/core/config.d.ts +15 -0
  464. package/packages/response-utils/dist/esm/core/config.js +12 -0
  465. package/packages/response-utils/dist/esm/core/factory.d.ts +3 -0
  466. package/packages/response-utils/dist/esm/core/factory.js +6 -0
  467. package/packages/response-utils/dist/esm/core/types.d.ts +32 -0
  468. package/packages/response-utils/dist/esm/core/types.js +1 -0
  469. package/packages/response-utils/dist/esm/index.d.ts +8 -0
  470. package/packages/response-utils/dist/esm/index.js +10 -0
  471. package/packages/response-utils/dist/esm/legacy.d.ts +19 -0
  472. package/packages/response-utils/dist/esm/legacy.js +18 -0
  473. package/packages/response-utils/dist/esm/middleware/express/expressMiddleware.d.ts +3 -0
  474. package/packages/response-utils/dist/esm/middleware/express/expressMiddleware.js +9 -0
  475. package/packages/response-utils/dist/types/adapters/express/ExpressResponder.d.ts +18 -0
  476. package/packages/response-utils/dist/types/constants/httpStatus.d.ts +54 -0
  477. package/packages/response-utils/dist/types/core/BaseResponder.d.ts +31 -0
  478. package/packages/response-utils/dist/types/core/config.d.ts +15 -0
  479. package/packages/response-utils/dist/types/core/factory.d.ts +3 -0
  480. package/packages/response-utils/dist/types/core/types.d.ts +32 -0
  481. package/packages/response-utils/dist/types/index.d.ts +8 -0
  482. package/packages/response-utils/dist/types/legacy.d.ts +19 -0
  483. package/packages/response-utils/dist/types/middleware/express/expressMiddleware.d.ts +3 -0
  484. package/packages/response-utils/node_modules/.bin/rimraf +21 -0
  485. package/packages/response-utils/node_modules/.bin/tsc +21 -0
  486. package/packages/response-utils/node_modules/.bin/tsserver +21 -0
  487. package/packages/response-utils/package.json +38 -10
  488. package/packages/response-utils/src/adapters/express/ExpressResponder.ts +64 -0
  489. package/packages/response-utils/src/constants/httpStatus.ts +42 -0
  490. package/packages/response-utils/src/core/BaseResponder.ts +198 -0
  491. package/packages/response-utils/src/core/config.ts +29 -0
  492. package/packages/response-utils/src/core/factory.ts +11 -0
  493. package/packages/response-utils/src/core/types.ts +34 -0
  494. package/packages/response-utils/src/index.ts +13 -168
  495. package/packages/response-utils/src/middleware/express/expressMiddleware.ts +14 -0
  496. package/packages/response-utils/tsconfig.base.json +11 -0
  497. package/packages/response-utils/tsconfig.cjs.json +9 -0
  498. package/packages/response-utils/tsconfig.esm.json +9 -0
  499. package/packages/security/README.md +298 -86
  500. package/packages/security/dist/cjs/core/crypto/cryptoManager.d.ts +111 -0
  501. package/packages/security/dist/cjs/core/crypto/cryptoManager.js +208 -0
  502. package/packages/security/dist/cjs/core/crypto/decrypt.d.ts +1 -0
  503. package/packages/security/dist/cjs/core/crypto/decrypt.js +21 -0
  504. package/packages/security/dist/cjs/core/crypto/encrypt.d.ts +1 -0
  505. package/packages/security/dist/cjs/core/crypto/encrypt.js +16 -0
  506. package/packages/security/dist/cjs/core/crypto/hmac.d.ts +8 -0
  507. package/packages/security/dist/cjs/core/crypto/hmac.js +24 -0
  508. package/packages/security/dist/cjs/core/crypto/index.d.ts +5 -0
  509. package/packages/security/dist/cjs/core/crypto/index.js +28 -0
  510. package/packages/security/dist/cjs/core/crypto/random.d.ts +8 -0
  511. package/packages/security/dist/cjs/core/crypto/random.js +21 -0
  512. package/packages/security/dist/cjs/core/jwt/decode.d.ts +12 -0
  513. package/packages/security/dist/cjs/core/jwt/decode.js +28 -0
  514. package/packages/security/dist/cjs/core/jwt/extractToken.d.ts +11 -0
  515. package/packages/security/dist/cjs/core/jwt/extractToken.js +54 -0
  516. package/packages/security/dist/cjs/core/jwt/generateTokens.d.ts +4 -0
  517. package/packages/security/dist/cjs/core/jwt/generateTokens.js +37 -0
  518. package/packages/security/dist/cjs/core/jwt/index.d.ts +8 -0
  519. package/packages/security/dist/cjs/core/jwt/index.js +24 -0
  520. package/packages/security/dist/cjs/core/jwt/jwtManager.d.ts +43 -0
  521. package/packages/security/dist/cjs/core/jwt/jwtManager.js +188 -0
  522. package/packages/security/dist/cjs/core/jwt/parseDuration.d.ts +1 -0
  523. package/packages/security/dist/cjs/core/jwt/parseDuration.js +30 -0
  524. package/packages/security/dist/cjs/core/jwt/signToken.d.ts +2 -0
  525. package/packages/security/dist/cjs/core/jwt/signToken.js +27 -0
  526. package/packages/security/dist/cjs/core/jwt/types.d.ts +22 -0
  527. package/packages/security/dist/cjs/core/jwt/types.js +2 -0
  528. package/packages/security/dist/cjs/core/jwt/validateToken.d.ts +16 -0
  529. package/packages/security/dist/cjs/core/jwt/validateToken.js +46 -0
  530. package/packages/security/dist/cjs/core/jwt/verify.d.ts +18 -0
  531. package/packages/security/dist/cjs/core/jwt/verify.js +89 -0
  532. package/packages/security/dist/cjs/core/password/hash.d.ts +10 -0
  533. package/packages/security/dist/cjs/core/password/hash.js +45 -0
  534. package/packages/security/dist/cjs/core/password/index.d.ts +3 -0
  535. package/packages/security/dist/cjs/core/password/index.js +19 -0
  536. package/packages/security/dist/cjs/core/password/passwordManager.d.ts +29 -0
  537. package/packages/security/dist/cjs/core/password/passwordManager.js +212 -0
  538. package/packages/security/dist/cjs/core/password/strength.d.ts +2 -0
  539. package/packages/security/dist/cjs/core/password/strength.js +27 -0
  540. package/packages/security/dist/cjs/core/password/types.d.ts +7 -0
  541. package/packages/security/dist/cjs/core/password/types.js +2 -0
  542. package/packages/security/dist/cjs/core/password/utils.d.ts +16 -0
  543. package/packages/security/dist/cjs/core/password/utils.js +53 -0
  544. package/packages/security/dist/cjs/core/password/verify.d.ts +10 -0
  545. package/packages/security/dist/cjs/core/password/verify.js +46 -0
  546. package/packages/security/dist/cjs/index.d.ts +40 -0
  547. package/packages/security/dist/cjs/index.js +56 -0
  548. package/packages/security/dist/cjs/interfaces/jwt.interface.d.ts +47 -0
  549. package/packages/security/dist/cjs/interfaces/jwt.interface.js +2 -0
  550. package/packages/security/dist/cjs/interfaces/password.interface.d.ts +60 -0
  551. package/packages/security/dist/cjs/interfaces/password.interface.js +2 -0
  552. package/packages/security/dist/esm/core/crypto/cryptoManager.d.ts +111 -0
  553. package/packages/security/dist/esm/core/crypto/cryptoManager.js +203 -0
  554. package/packages/security/dist/esm/core/crypto/decrypt.d.ts +1 -0
  555. package/packages/security/dist/esm/core/crypto/decrypt.js +14 -0
  556. package/packages/security/dist/esm/core/crypto/encrypt.d.ts +1 -0
  557. package/packages/security/dist/esm/core/crypto/encrypt.js +9 -0
  558. package/packages/security/dist/esm/core/crypto/hmac.d.ts +8 -0
  559. package/packages/security/dist/esm/core/crypto/hmac.js +16 -0
  560. package/packages/security/dist/esm/core/crypto/index.d.ts +5 -0
  561. package/packages/security/dist/esm/core/crypto/index.js +5 -0
  562. package/packages/security/dist/esm/core/crypto/random.d.ts +8 -0
  563. package/packages/security/dist/esm/core/crypto/random.js +13 -0
  564. package/packages/security/dist/esm/core/jwt/decode.d.ts +12 -0
  565. package/packages/security/dist/esm/core/jwt/decode.js +24 -0
  566. package/packages/security/dist/esm/core/jwt/extractToken.d.ts +11 -0
  567. package/packages/security/dist/esm/core/jwt/extractToken.js +51 -0
  568. package/packages/security/dist/esm/core/jwt/generateTokens.d.ts +4 -0
  569. package/packages/security/dist/esm/core/jwt/generateTokens.js +32 -0
  570. package/packages/security/dist/esm/core/jwt/index.d.ts +8 -0
  571. package/packages/security/dist/esm/core/jwt/index.js +8 -0
  572. package/packages/security/dist/esm/core/jwt/jwtManager.d.ts +43 -0
  573. package/packages/security/dist/esm/core/jwt/jwtManager.js +181 -0
  574. package/packages/security/dist/esm/core/jwt/parseDuration.d.ts +1 -0
  575. package/packages/security/dist/esm/core/jwt/parseDuration.js +27 -0
  576. package/packages/security/dist/esm/core/jwt/signToken.d.ts +2 -0
  577. package/packages/security/dist/esm/core/jwt/signToken.js +23 -0
  578. package/packages/security/dist/esm/core/jwt/types.d.ts +22 -0
  579. package/packages/security/dist/esm/core/jwt/types.js +1 -0
  580. package/packages/security/dist/esm/core/jwt/validateToken.d.ts +16 -0
  581. package/packages/security/dist/esm/core/jwt/validateToken.js +42 -0
  582. package/packages/security/dist/esm/core/jwt/verify.d.ts +18 -0
  583. package/packages/security/dist/esm/core/jwt/verify.js +82 -0
  584. package/packages/security/dist/esm/core/password/hash.d.ts +10 -0
  585. package/packages/security/dist/esm/core/password/hash.js +35 -0
  586. package/packages/security/dist/esm/core/password/index.d.ts +3 -0
  587. package/packages/security/dist/esm/core/password/index.js +3 -0
  588. package/packages/security/dist/esm/core/password/passwordManager.d.ts +29 -0
  589. package/packages/security/dist/esm/core/password/passwordManager.js +205 -0
  590. package/packages/security/dist/esm/core/password/strength.d.ts +2 -0
  591. package/packages/security/dist/esm/core/password/strength.js +23 -0
  592. package/packages/security/dist/esm/core/password/types.d.ts +7 -0
  593. package/packages/security/dist/esm/core/password/types.js +1 -0
  594. package/packages/security/dist/esm/core/password/utils.d.ts +16 -0
  595. package/packages/security/dist/esm/core/password/utils.js +44 -0
  596. package/packages/security/dist/esm/core/password/verify.d.ts +10 -0
  597. package/packages/security/dist/esm/core/password/verify.js +36 -0
  598. package/packages/security/dist/esm/index.d.ts +40 -0
  599. package/packages/security/dist/esm/index.js +13 -0
  600. package/packages/security/dist/esm/interfaces/jwt.interface.d.ts +47 -0
  601. package/packages/security/dist/esm/interfaces/jwt.interface.js +1 -0
  602. package/packages/security/dist/esm/interfaces/password.interface.d.ts +60 -0
  603. package/packages/security/dist/esm/interfaces/password.interface.js +1 -0
  604. package/packages/security/dist/types/core/crypto/cryptoManager.d.ts +111 -0
  605. package/packages/security/dist/types/core/crypto/decrypt.d.ts +1 -0
  606. package/packages/security/dist/types/core/crypto/encrypt.d.ts +1 -0
  607. package/packages/security/dist/types/core/crypto/hmac.d.ts +8 -0
  608. package/packages/security/dist/types/core/crypto/index.d.ts +5 -0
  609. package/packages/security/dist/types/core/crypto/random.d.ts +8 -0
  610. package/packages/security/dist/types/core/jwt/decode.d.ts +12 -0
  611. package/packages/security/dist/types/core/jwt/extractToken.d.ts +11 -0
  612. package/packages/security/dist/types/core/jwt/generateTokens.d.ts +4 -0
  613. package/packages/security/dist/types/core/jwt/index.d.ts +8 -0
  614. package/packages/security/dist/types/core/jwt/jwtManager.d.ts +43 -0
  615. package/packages/security/dist/types/core/jwt/parseDuration.d.ts +1 -0
  616. package/packages/security/dist/types/core/jwt/signToken.d.ts +2 -0
  617. package/packages/security/dist/types/core/jwt/types.d.ts +22 -0
  618. package/packages/security/dist/types/core/jwt/validateToken.d.ts +16 -0
  619. package/packages/security/dist/types/core/jwt/verify.d.ts +18 -0
  620. package/packages/security/dist/types/core/password/hash.d.ts +10 -0
  621. package/packages/security/dist/types/core/password/index.d.ts +3 -0
  622. package/packages/security/dist/types/core/password/passwordManager.d.ts +29 -0
  623. package/packages/security/dist/types/core/password/strength.d.ts +2 -0
  624. package/packages/security/dist/types/core/password/types.d.ts +7 -0
  625. package/packages/security/dist/types/core/password/utils.d.ts +16 -0
  626. package/packages/security/dist/types/core/password/verify.d.ts +10 -0
  627. package/packages/security/dist/types/index.d.ts +40 -0
  628. package/packages/security/dist/types/interfaces/jwt.interface.d.ts +47 -0
  629. package/packages/security/dist/types/interfaces/password.interface.d.ts +60 -0
  630. package/packages/security/node_modules/.bin/bcrypt +21 -0
  631. package/packages/security/node_modules/.bin/rimraf +21 -0
  632. package/packages/security/node_modules/.bin/tsc +21 -0
  633. package/packages/security/node_modules/.bin/tsserver +21 -0
  634. package/packages/security/package.json +23 -4
  635. package/packages/security/src/core/crypto/cryptoManager.ts +324 -0
  636. package/packages/security/src/core/crypto/decrypt.ts +20 -0
  637. package/packages/security/src/core/crypto/encrypt.ts +14 -0
  638. package/packages/security/src/core/crypto/hmac.ts +23 -0
  639. package/packages/security/src/core/crypto/index.ts +5 -0
  640. package/packages/security/src/core/crypto/random.ts +15 -0
  641. package/packages/security/src/core/jwt/decode.ts +28 -0
  642. package/packages/security/src/core/jwt/extractToken.ts +59 -0
  643. package/packages/security/src/core/jwt/generateTokens.ts +51 -0
  644. package/packages/security/src/core/jwt/index.ts +8 -0
  645. package/packages/security/src/core/jwt/jwtManager.ts +233 -0
  646. package/packages/security/src/core/jwt/parseDuration.ts +34 -0
  647. package/packages/security/src/core/jwt/signToken.ts +32 -0
  648. package/packages/security/src/core/jwt/types.ts +29 -0
  649. package/packages/security/src/core/jwt/validateToken.ts +60 -0
  650. package/packages/security/src/core/jwt/verify.ts +117 -0
  651. package/packages/security/src/core/password/hash.ts +46 -0
  652. package/packages/security/src/core/password/index.ts +3 -0
  653. package/packages/security/src/core/password/passwordManager.ts +244 -0
  654. package/packages/security/src/core/password/strength.ts +40 -0
  655. package/packages/security/src/core/password/types.ts +7 -0
  656. package/packages/security/src/core/password/utils.ts +47 -0
  657. package/packages/security/src/core/password/verify.ts +49 -0
  658. package/packages/security/src/index.ts +21 -39
  659. package/packages/security/src/interfaces/jwt.interface.ts +58 -0
  660. package/packages/security/src/interfaces/password.interface.ts +54 -0
  661. package/packages/security/tsconfig.base.json +17 -0
  662. package/packages/security/tsconfig.cjs.json +9 -0
  663. package/packages/security/tsconfig.esm.json +9 -0
  664. package/packages/server-utils/README.md +412 -49
  665. package/packages/server-utils/dist/cjs/core/health.d.ts +5 -0
  666. package/packages/server-utils/dist/cjs/core/health.js +45 -0
  667. package/packages/server-utils/dist/cjs/core/periodic-health.d.ts +11 -0
  668. package/packages/server-utils/dist/cjs/core/periodic-health.js +68 -0
  669. package/packages/server-utils/dist/cjs/core/server.d.ts +73 -0
  670. package/packages/server-utils/dist/cjs/core/server.js +437 -0
  671. package/packages/server-utils/dist/cjs/core/shutdown.d.ts +5 -0
  672. package/packages/server-utils/dist/cjs/core/shutdown.js +58 -0
  673. package/packages/server-utils/dist/cjs/index.d.ts +46 -0
  674. package/packages/server-utils/dist/cjs/index.js +91 -0
  675. package/packages/server-utils/dist/cjs/middleware/auth.middleware.d.ts +6 -0
  676. package/packages/server-utils/dist/cjs/middleware/auth.middleware.js +44 -0
  677. package/packages/server-utils/dist/cjs/middleware/cache.middleware.d.ts +2 -0
  678. package/packages/server-utils/dist/cjs/middleware/cache.middleware.js +58 -0
  679. package/packages/server-utils/dist/cjs/middleware/errorHandler.middleware.d.ts +2 -0
  680. package/packages/server-utils/dist/cjs/middleware/errorHandler.middleware.js +47 -0
  681. package/packages/server-utils/dist/cjs/middleware/index.d.ts +10 -0
  682. package/packages/server-utils/dist/cjs/middleware/index.js +40 -0
  683. package/packages/server-utils/dist/cjs/middleware/logging.middleware.d.ts +2 -0
  684. package/packages/server-utils/dist/cjs/middleware/logging.middleware.js +19 -0
  685. package/packages/server-utils/dist/cjs/middleware/plugins.middleware.d.ts +14 -0
  686. package/packages/server-utils/dist/cjs/middleware/plugins.middleware.js +58 -0
  687. package/packages/server-utils/dist/cjs/middleware/rateLimiter.middleware.d.ts +8 -0
  688. package/packages/server-utils/dist/cjs/middleware/rateLimiter.middleware.js +35 -0
  689. package/packages/server-utils/dist/cjs/middleware/requestId.middleware.d.ts +2 -0
  690. package/packages/server-utils/dist/cjs/middleware/requestId.middleware.js +12 -0
  691. package/packages/server-utils/dist/cjs/middleware/session.middleware.d.ts +2 -0
  692. package/packages/server-utils/dist/cjs/middleware/session.middleware.js +53 -0
  693. package/packages/server-utils/dist/cjs/middleware/validation.middleware.d.ts +11 -0
  694. package/packages/server-utils/dist/cjs/middleware/validation.middleware.js +67 -0
  695. package/packages/server-utils/dist/cjs/types/index.d.ts +87 -0
  696. package/packages/server-utils/dist/cjs/types/index.js +2 -0
  697. package/packages/server-utils/dist/cjs/utils/utils.d.ts +3 -0
  698. package/packages/server-utils/dist/cjs/utils/utils.js +43 -0
  699. package/packages/server-utils/dist/esm/core/health.d.ts +5 -0
  700. package/packages/server-utils/dist/esm/core/health.js +40 -0
  701. package/packages/server-utils/dist/esm/core/periodic-health.d.ts +11 -0
  702. package/packages/server-utils/dist/esm/core/periodic-health.js +64 -0
  703. package/packages/server-utils/dist/esm/core/server.d.ts +73 -0
  704. package/packages/server-utils/dist/esm/core/server.js +396 -0
  705. package/packages/server-utils/dist/esm/core/shutdown.d.ts +5 -0
  706. package/packages/server-utils/dist/esm/core/shutdown.js +53 -0
  707. package/packages/server-utils/dist/esm/index.d.ts +46 -0
  708. package/packages/server-utils/dist/esm/index.js +58 -0
  709. package/packages/server-utils/dist/esm/middleware/auth.middleware.d.ts +6 -0
  710. package/packages/server-utils/dist/esm/middleware/auth.middleware.js +41 -0
  711. package/packages/server-utils/dist/esm/middleware/cache.middleware.d.ts +2 -0
  712. package/packages/server-utils/dist/esm/middleware/cache.middleware.js +55 -0
  713. package/packages/server-utils/dist/esm/middleware/errorHandler.middleware.d.ts +2 -0
  714. package/packages/server-utils/dist/esm/middleware/errorHandler.middleware.js +44 -0
  715. package/packages/server-utils/dist/esm/middleware/index.d.ts +10 -0
  716. package/packages/server-utils/dist/esm/middleware/index.js +20 -0
  717. package/packages/server-utils/dist/esm/middleware/logging.middleware.d.ts +2 -0
  718. package/packages/server-utils/dist/esm/middleware/logging.middleware.js +16 -0
  719. package/packages/server-utils/dist/esm/middleware/plugins.middleware.d.ts +14 -0
  720. package/packages/server-utils/dist/esm/middleware/plugins.middleware.js +47 -0
  721. package/packages/server-utils/dist/esm/middleware/rateLimiter.middleware.d.ts +8 -0
  722. package/packages/server-utils/dist/esm/middleware/rateLimiter.middleware.js +32 -0
  723. package/packages/server-utils/dist/esm/middleware/requestId.middleware.d.ts +2 -0
  724. package/packages/server-utils/dist/esm/middleware/requestId.middleware.js +9 -0
  725. package/packages/server-utils/dist/esm/middleware/session.middleware.d.ts +2 -0
  726. package/packages/server-utils/dist/esm/middleware/session.middleware.js +50 -0
  727. package/packages/server-utils/dist/esm/middleware/validation.middleware.d.ts +11 -0
  728. package/packages/server-utils/dist/esm/middleware/validation.middleware.js +64 -0
  729. package/packages/server-utils/dist/esm/types/index.d.ts +87 -0
  730. package/packages/server-utils/dist/esm/types/index.js +1 -0
  731. package/packages/server-utils/dist/esm/utils/utils.d.ts +3 -0
  732. package/packages/server-utils/dist/esm/utils/utils.js +38 -0
  733. package/packages/server-utils/dist/types/core/health.d.ts +5 -0
  734. package/packages/server-utils/dist/types/core/periodic-health.d.ts +11 -0
  735. package/packages/server-utils/dist/types/core/server.d.ts +73 -0
  736. package/packages/server-utils/dist/types/core/shutdown.d.ts +5 -0
  737. package/packages/server-utils/dist/types/index.d.ts +46 -0
  738. package/packages/server-utils/dist/types/middleware/auth.middleware.d.ts +6 -0
  739. package/packages/server-utils/dist/types/middleware/cache.middleware.d.ts +2 -0
  740. package/packages/server-utils/dist/types/middleware/errorHandler.middleware.d.ts +2 -0
  741. package/packages/server-utils/dist/types/middleware/index.d.ts +10 -0
  742. package/packages/server-utils/dist/types/middleware/logging.middleware.d.ts +2 -0
  743. package/packages/server-utils/dist/types/middleware/plugins.middleware.d.ts +14 -0
  744. package/packages/server-utils/dist/types/middleware/rateLimiter.middleware.d.ts +8 -0
  745. package/packages/server-utils/dist/types/middleware/requestId.middleware.d.ts +2 -0
  746. package/packages/server-utils/dist/types/middleware/session.middleware.d.ts +2 -0
  747. package/packages/server-utils/dist/types/middleware/validation.middleware.d.ts +11 -0
  748. package/packages/server-utils/dist/types/types/index.d.ts +87 -0
  749. package/packages/server-utils/dist/types/utils/utils.d.ts +3 -0
  750. package/packages/server-utils/node_modules/.bin/rimraf +21 -0
  751. package/packages/server-utils/node_modules/.bin/tsc +21 -0
  752. package/packages/server-utils/node_modules/.bin/tsserver +21 -0
  753. package/packages/server-utils/package.json +30 -6
  754. package/packages/server-utils/src/core/health.ts +58 -0
  755. package/packages/server-utils/src/core/periodic-health.ts +88 -0
  756. package/packages/server-utils/src/core/server.ts +650 -0
  757. package/packages/server-utils/src/core/shutdown.ts +78 -0
  758. package/packages/server-utils/src/express-augment.d.ts +35 -0
  759. package/packages/server-utils/src/index.ts +132 -95
  760. package/packages/server-utils/src/middleware/auth.middleware.ts +79 -0
  761. package/packages/server-utils/src/middleware/cache.middleware.ts +68 -0
  762. package/packages/server-utils/src/middleware/errorHandler.middleware.ts +59 -0
  763. package/packages/server-utils/src/middleware/index.ts +46 -0
  764. package/packages/server-utils/src/middleware/logging.middleware.ts +29 -0
  765. package/packages/server-utils/src/middleware/plugins.middleware.ts +64 -0
  766. package/packages/server-utils/src/middleware/rateLimiter.middleware.ts +59 -0
  767. package/packages/server-utils/src/middleware/requestId.middleware.ts +16 -0
  768. package/packages/server-utils/src/middleware/session.middleware.ts +69 -0
  769. package/packages/server-utils/src/middleware/validation.middleware.ts +100 -0
  770. package/packages/server-utils/src/types/index.ts +114 -0
  771. package/packages/server-utils/src/utils/utils.ts +43 -0
  772. package/packages/server-utils/tsconfig.base.json +17 -0
  773. package/packages/server-utils/tsconfig.cjs.json +9 -0
  774. package/packages/server-utils/tsconfig.esm.json +9 -0
  775. package/packages/server-utils/src/health.ts +0 -47
  776. package/packages/server-utils/src/middleware.ts +0 -275
  777. package/packages/server-utils/src/server.ts +0 -320
  778. package/packages/server-utils/src/shutdown.ts +0 -60
  779. package/packages/server-utils/src/types.ts +0 -64
  780. package/packages/server-utils/src/utils.ts +0 -34
  781. /package/packages/{response-utils → cache}/tsconfig.json +0 -0
@@ -1,6 +1,8 @@
1
1
  # @naman_deep_singh/server-utils
2
2
 
3
- Extensible server utilities for Express.js microservices with multi-protocol support and TypeScript.
3
+ **Version:** 1.5.1 (with integrated cache & session support)
4
+
5
+ Extensible server utilities for Express.js microservices with multi-protocol support, integrated caching, session management, and TypeScript.
4
6
 
5
7
  ## Installation
6
8
 
@@ -11,17 +13,19 @@ npm install @naman_deep_singh/server-utils
11
13
  ## Features
12
14
 
13
15
  - ✅ **Multi-protocol support** - HTTP, gRPC, JSON-RPC, WebSockets, Webhooks
16
+ - ✅ **Integrated caching** - Redis, Memcache, in-memory with automatic fallback
17
+ - ✅ **Session management** - Distributed session store with configurable TTL
14
18
  - ✅ **Express.js integration** with middleware collection
15
- - ✅ **Graceful shutdown** handling
16
- - ✅ **Health checks** with custom checks support
19
+ - ✅ **Graceful shutdown** handling with cache/session cleanup
20
+ - ✅ **Health checks** with custom checks and cache health integration
17
21
  - ✅ **TypeScript support** with full type safety
18
- - ✅ **Hybrid exports** - use named imports or namespace imports
19
- - ✅ **Plugin architecture** for extensibility
20
- - ✅ **Built-in middleware** - logging, validation, rate limiting, auth
22
+
23
+ - ✅ **Built-in middleware** - logging, validation, rate limiting, auth, caching, sessions
24
+
21
25
 
22
26
  ## Quick Start
23
27
 
24
- ### Named Imports
28
+ ### Basic Usage
25
29
  ```typescript
26
30
  import { createServer } from '@naman_deep_singh/server-utils';
27
31
 
@@ -40,13 +44,6 @@ server.app.get('/users', (req, res) => {
40
44
  await server.start();
41
45
  ```
42
46
 
43
- ### Namespace Import
44
- ```typescript
45
- import ServerUtils from '@naman_deep_singh/server-utils';
46
-
47
- const server = ServerUtils.createServer('My API', '1.0.0');
48
- ```
49
-
50
47
  ## Multi-Protocol Support
51
48
 
52
49
  ### HTTP + Express Routes
@@ -127,17 +124,13 @@ server.addWebhook({
127
124
 
128
125
  ## Built-in Middleware
129
126
 
127
+
130
128
  ### Logging Middleware
131
129
  ```typescript
132
- import { createLoggingMiddleware, withLogging } from '@naman_deep_singh/server-utils';
130
+ import { createLoggingMiddleware } from '@naman_deep_singh/server-utils';
133
131
 
134
132
  // Direct usage
135
133
  server.app.use(createLoggingMiddleware('detailed'));
136
-
137
- // Plugin usage
138
- const server = createServerWithPlugins('My API', '1.0.0', [
139
- withLogging('detailed')
140
- ]);
141
134
  ```
142
135
 
143
136
  ### Validation Middleware
@@ -165,41 +158,45 @@ server.app.use('/api', rateLimit({
165
158
  }));
166
159
  ```
167
160
 
161
+
168
162
  ### Authentication Middleware
169
163
  ```typescript
170
164
  import { requireAuth } from '@naman_deep_singh/server-utils';
171
165
 
172
166
  server.app.use('/protected', requireAuth({
173
- tokenExtractor: (req) => req.headers.authorization?.substring(7),
174
- tokenValidator: async (token) => {
175
- // Verify JWT token
176
- return jwt.verify(token, process.env.JWT_SECRET);
167
+ secret: process.env.JWT_SECRET!,
168
+ unauthorizedMessage: 'Invalid or expired token'
169
+ }));
170
+ ```
171
+
172
+ **Advanced Configuration:**
173
+ ```typescript
174
+ import { createAuthMiddleware } from '@naman_deep_singh/server-utils';
175
+
176
+ server.app.use('/api', createAuthMiddleware({
177
+ secret: process.env.JWT_SECRET!,
178
+ unauthorizedMessage: 'Access denied',
179
+ tokenExtractor: (req) => {
180
+ // Custom token extraction logic
181
+ // By default, uses sophisticated extractToken from @naman_deep_singh/security
182
+ // that checks Authorization headers, cookies, query params, and body
183
+ return req.headers.authorization?.substring(7);
177
184
  }
178
185
  }));
179
186
  ```
180
187
 
181
188
  ## Health Checks
182
189
 
190
+
191
+ ### Basic Health Check
183
192
  ```typescript
184
- import { addHealthCheck } from '@naman_deep_singh/server-utils';
185
-
186
- addHealthCheck(server.app, '/health', {
187
- customChecks: [
188
- {
189
- name: 'database',
190
- check: async () => {
191
- // Check database connection
192
- return await db.ping();
193
- }
194
- },
195
- {
196
- name: 'redis',
197
- check: async () => {
198
- return await redis.ping() === 'PONG';
199
- }
200
- }
201
- ]
202
- });
193
+ import { createHealthCheck } from '@naman_deep_singh/server-utils';
194
+
195
+ // The health check is automatically enabled when healthCheck is not false
196
+ // Health endpoint is available at /health by default
197
+
198
+ // If you need to customize or disable it:
199
+ server.app.get('/health', createHealthCheck());
203
200
  ```
204
201
 
205
202
  ## Server Management
@@ -246,12 +243,84 @@ interface ServerConfig {
246
243
  }
247
244
  ```
248
245
 
246
+ ## Environment Utilities
247
+
248
+ ```typescript
249
+ import { getEnv, getEnvNumber, getEnvBoolean } from '@naman_deep_singh/server-utils';
250
+
251
+ // Get string environment variable
252
+ const dbUrl = getEnv('DATABASE_URL'); // Throws if missing
253
+ const dbUrl = getEnv('DATABASE_URL', 'localhost'); // With default
254
+
255
+ // Get number environment variable
256
+ const port = getEnvNumber('PORT', 3000);
257
+ const maxConnections = getEnvNumber('MAX_CONNECTIONS'); // Throws if missing
258
+
259
+ // Get boolean environment variable
260
+ const enableLogging = getEnvBoolean('ENABLE_LOGGING', true);
261
+ const isProduction = getEnvBoolean('NODE_ENV'); // Must be 'true' or 'false'
262
+ ```
263
+
264
+ ## Periodic Health Monitoring
265
+
266
+ ```typescript
267
+ import { PeriodicHealthMonitor } from '@naman_deep_singh/server-utils';
268
+
269
+ const server = createServer('My API', '1.0.0', {
270
+ periodicHealthCheck: {
271
+ enabled: true,
272
+ interval: 30000, // 30 seconds
273
+ services: [
274
+ {
275
+ name: 'database',
276
+ url: 'http://localhost:5432/health',
277
+ timeout: 5000
278
+ },
279
+ {
280
+ name: 'redis',
281
+ url: 'http://localhost:6379/ping'
282
+ }
283
+ ]
284
+ }
285
+ });
286
+
287
+ // Manual health check
288
+ const monitor = new PeriodicHealthMonitor(config, 'My Service');
289
+ monitor.start();
290
+ const status = await monitor.getHealthStatus();
291
+ console.log(status); // { database: true, redis: false }
292
+ ```
293
+
294
+ ## Express Re-exports
295
+
296
+ ```typescript
297
+ // Import Express types and classes directly from server-utils
298
+ import { Request, Response, NextFunction, Router, Application } from '@naman_deep_singh/server-utils';
299
+ import type { RequestHandler, ErrorRequestHandler } from '@naman_deep_singh/server-utils';
300
+
301
+ // No need to install Express separately in your services
302
+
303
+ ## TypeScript Notes
304
+
305
+ - This package includes TypeScript augmentations for Express `Request` and `Application` that expose runtime helpers used by the middleware (for example `req.cache`, `req.sessionStore`, `req.getSession`, and `req.createSession`). Installing and importing `@naman_deep_singh/server-utils` in your project will surface these types automatically.
306
+ - Middleware that attaches runtime props uses `unknown` internally and runtime guards — prefer the provided helpers rather than casting `req` to `any`.
307
+
308
+ ```
309
+
249
310
  ## API Reference
250
311
 
251
312
  ### Core Functions
252
313
  - `createServer(name?, version?, config?)` - Create server instance
253
314
  - `ExpressServer` - Server class for advanced usage
254
315
 
316
+ ### Environment Utilities
317
+ - `getEnv(key, defaultValue?)` - Get string environment variable
318
+ - `getEnvNumber(key, defaultValue?)` - Get number environment variable
319
+ - `getEnvBoolean(key, defaultValue?)` - Get boolean environment variable
320
+
321
+ ### Health Monitoring
322
+ - `PeriodicHealthMonitor` - Automated service health checking
323
+
255
324
  ### Middleware Functions
256
325
  - `createLoggingMiddleware(format?)` - Request logging
257
326
  - `createErrorHandler()` - Error handling
@@ -260,8 +329,10 @@ interface ServerConfig {
260
329
  - `createAuthMiddleware(config)` - Authentication
261
330
 
262
331
  ### Health & Monitoring
263
- - `createHealthCheck(config?)` - Health check endpoint
332
+ - `createHealthCheck(config?)` - Create health check middleware
333
+ - `withHealthCheck(path?, config?)` - Health check plugin
264
334
  - `addHealthCheck(app, path?, config?)` - Add health check to app
335
+ - `PeriodicHealthMonitor` - Automated service health checking
265
336
 
266
337
  ### Graceful Shutdown
267
338
  - `createGracefulShutdown(server, config?)` - Setup graceful shutdown
@@ -270,12 +341,304 @@ interface ServerConfig {
270
341
  ## Dependencies
271
342
 
272
343
  ### Required
273
- - **express** - Web framework
274
- - **cors** - CORS middleware
275
- - **helmet** - Security middleware
276
- - **cookie-parser** - Cookie parsing
344
+ - **express** - Web framework (v5.1.0+)
277
345
 
278
346
  ### Optional (for specific features)
347
+ - **cors** - CORS middleware (if using CORS)
348
+ - **helmet** - Security middleware (if using Helmet)
349
+ - **cookie-parser** - Cookie parsing (if using cookies)
279
350
  - **@grpc/grpc-js** - For gRPC support
280
351
  - **jayson** - For JSON-RPC support
281
- - **socket.io** - For WebSocket support
352
+ - **socket.io** - For WebSocket support
353
+
354
+ ## Response Format
355
+
356
+ All middleware responses follow the consistent format:
357
+
358
+ ```json
359
+ {
360
+ "success": true/false,
361
+ "message": "Operation message",
362
+ "data": {...} | undefined,
363
+ "error": {
364
+ "message": "Error message",
365
+ "details": {...}
366
+ } | null,
367
+ "meta": {...} | null
368
+ }
369
+ ```
370
+
371
+ ### Integration with @naman_deep_singh/response-utils
372
+
373
+ For advanced error handling, use with `@naman_deep_singh/errors-utils`:
374
+
375
+ ```typescript
376
+ import { expressErrorHandler } from '@naman_deep_singh/errors-utils';
377
+
378
+ // Replace basic error handler with advanced one
379
+ server.app.use(expressErrorHandler);
380
+ ```
381
+
382
+ ### Integration with @naman_deep_singh/response-utils
383
+
384
+ For consistent API responses, use with `@naman_deep_singh/response-utils`:
385
+
386
+ ```typescript
387
+ import { responderMiddleware } from '@naman_deep_singh/response-utils';
388
+
389
+ server.app.use(responderMiddleware());
390
+
391
+ // Now use responder in routes
392
+ server.app.get('/users', (req, res) => {
393
+ const responder = (res as any).responder();
394
+ return responder.okAndSend({ users: [] });
395
+ });
396
+ ```
397
+
398
+ ## Cache & Session Integration
399
+
400
+ Built-in support for distributed caching and session management (disabled by default).
401
+
402
+ ### Enable Redis Cache
403
+
404
+ ```typescript
405
+ const server = createServer('My API', '1.0.0', {
406
+ port: 3000,
407
+ cache: {
408
+ enabled: true,
409
+ adapter: 'redis',
410
+ options: {
411
+ host: 'localhost',
412
+ port: 6379,
413
+ password: 'your_password'
414
+ },
415
+ defaultTTL: 3600 // seconds
416
+ }
417
+ });
418
+
419
+ // Access cache in routes
420
+ server.app.get('/user/:id', async (req, res) => {
421
+ const key = `user:${req.params.id}`;
422
+ const cached = await (req as any).cache.get(key);
423
+ if (cached) return res.json(cached);
424
+
425
+ // Fetch from DB, then cache
426
+ const user = { id: req.params.id, name: 'John' };
427
+ await (req as any).cache.set(key, user, 3600);
428
+ return res.json(user);
429
+ });
430
+ ```
431
+
432
+ ### Enable Redis Cluster Cache
433
+
434
+ ```typescript
435
+ const server = createServer('My API', '1.0.0', {
436
+ port: 3000,
437
+ cache: {
438
+ enabled: true,
439
+ adapter: 'redis',
440
+ options: {
441
+ cluster: [
442
+ { host: 'redis-node-1', port: 6379 },
443
+ { host: 'redis-node-2', port: 6379 },
444
+ { host: 'redis-node-3', port: 6379 }
445
+ ]
446
+ }
447
+ }
448
+ });
449
+ ```
450
+
451
+ ### Enable Memcache
452
+
453
+ ```typescript
454
+ const server = createServer('My API', '1.0.0', {
455
+ port: 3000,
456
+ cache: {
457
+ enabled: true,
458
+ adapter: 'memcache',
459
+ options: {
460
+ servers: ['localhost:11211', 'localhost:11212']
461
+ }
462
+ }
463
+ });
464
+ ```
465
+
466
+ ### Enable Sessions
467
+
468
+ ```typescript
469
+ const server = createServer('My API', '1.0.0', {
470
+ port: 3000,
471
+ cache: {
472
+ enabled: true,
473
+ adapter: 'redis',
474
+ options: { host: 'localhost', port: 6379 }
475
+ },
476
+ session: {
477
+ enabled: true,
478
+ cookieName: 'my_app.sid', // Defaults to {servername}.sid
479
+ ttl: 3600, // 1 hour
480
+ cookieOptions: {
481
+ httpOnly: true,
482
+ secure: true, // HTTPS only
483
+ sameSite: 'strict'
484
+ }
485
+ }
486
+ });
487
+
488
+ // Use sessions in routes
489
+ server.app.post('/login', async (req, res) => {
490
+ const sessionStore = (req.app as any).locals.sessionStore;
491
+ const sessionId = Math.random().toString(36).substring(7);
492
+
493
+ await sessionStore.create(sessionId, {
494
+ userId: 123,
495
+ username: 'john_doe',
496
+ loginTime: new Date()
497
+ });
498
+
499
+ res.cookie((req.app as any).locals.sessionCookieName, sessionId, {
500
+ httpOnly: true,
501
+ secure: true
502
+ });
503
+
504
+ return res.json({ message: 'Logged in' });
505
+ });
506
+
507
+ server.app.get('/profile', async (req, res) => {
508
+ const sessionId = (req as any).sessionId;
509
+ if (!sessionId) return res.status(401).json({ error: 'No session' });
510
+
511
+ const session = await (req as any).getSession();
512
+ if (!session) return res.status(401).json({ error: 'Session expired' });
513
+
514
+ return res.json({ user: session.username, loginTime: session.loginTime });
515
+ });
516
+ ```
517
+
518
+ ### Per-Route Response Caching
519
+
520
+ ```typescript
521
+ import { cacheResponse } from '@naman_deep_singh/server-utils';
522
+
523
+ // Cache GET response for 1 hour (3600 seconds)
524
+ server.app.get('/api/posts', cacheResponse(3600), (req, res) => {
525
+ // This endpoint's response is cached
526
+ res.json({ posts: [...] });
527
+ });
528
+
529
+ // Cache with default TTL from server config
530
+ server.app.get('/api/trending', cacheResponse(), (req, res) => {
531
+ res.json({ trending: [...] });
532
+ });
533
+ ```
534
+
535
+ ### Health Check with Cache Status
536
+
537
+ ```typescript
538
+ const server = createServer('My API', '1.0.0', {
539
+ healthCheck: '/health', // Automatic health endpoint
540
+ cache: { enabled: true, adapter: 'redis', ... }
541
+ });
542
+
543
+ // Health endpoint now includes cache status
544
+ // GET /health returns:
545
+ // {
546
+ // "status": "healthy",
547
+ // "service": "My API",
548
+ // "version": "1.0.0",
549
+ // "uptime": 12345,
550
+ // "timestamp": "2025-12-12T...",
551
+ // "cache": {
552
+ // "isAlive": true,
553
+ // "adapter": "redis",
554
+ // "timestamp": "2025-12-12T..."
555
+ // }
556
+ // }
557
+ ```
558
+
559
+ ### Cache Configuration Options
560
+
561
+ All configuration is optional — cache and session are disabled by default:
562
+
563
+ ```typescript
564
+ interface CacheConfig {
565
+ enabled?: boolean; // Default: false
566
+ adapter?: 'redis' | 'memcache' | 'memory'; // Default: 'memory'
567
+ options?: {
568
+ // Redis single instance
569
+ host?: string; // Default: 'localhost'
570
+ port?: number; // Default: 6379
571
+ username?: string;
572
+ password?: string;
573
+ db?: number; // 0-15
574
+ tls?: boolean;
575
+
576
+ // Redis cluster
577
+ cluster?: Array<{ host: string; port: number }> | {
578
+ nodes: Array<{ host: string; port: number }>;
579
+ options?: { maxRedirections?: number; ... };
580
+ };
581
+
582
+ // Memcache
583
+ servers?: string | string[]; // e.g., 'localhost:11211'
584
+
585
+ namespace?: string; // Key prefix
586
+ ttl?: number; // Default TTL in seconds
587
+ };
588
+ defaultTTL?: number; // Fallback TTL for routes
589
+ }
590
+
591
+ interface SessionConfig {
592
+ enabled?: boolean; // Default: false
593
+ cookieName?: string; // Default: {servername}.sid
594
+ ttl?: number; // Default: 3600 (1 hour)
595
+ cookieOptions?: {
596
+ path?: string;
597
+ httpOnly?: boolean; // Default: true
598
+ secure?: boolean; // HTTPS only
599
+ sameSite?: 'lax' | 'strict' | 'none';
600
+ };
601
+ }
602
+ ```
603
+
604
+ ### Graceful Shutdown
605
+
606
+ Cache and session stores are automatically closed on graceful shutdown:
607
+
608
+ ```typescript
609
+ const server = createServer('My API', '1.0.0', {
610
+ gracefulShutdown: true, // Enabled by default
611
+ cache: { enabled: true, adapter: 'redis', ... },
612
+ session: { enabled: true, ... }
613
+ });
614
+
615
+ // On SIGTERM/SIGINT, server will:
616
+ // 1. Stop accepting requests
617
+ // 2. Close cache connection (Redis/Memcache)
618
+ // 3. Close session store
619
+ // 4. Exit gracefully
620
+ ```
621
+
622
+ ## Feature Flags
623
+
624
+ All major features can be toggled independently:
625
+
626
+ ```typescript
627
+ const server = createServer('My API', '1.0.0', {
628
+ port: 3000,
629
+ cors: true, // Default: true
630
+ helmet: true, // Default: true
631
+ json: true, // Default: true
632
+ cookieParser: false, // Default: false
633
+ healthCheck: '/health', // Default: true
634
+ gracefulShutdown: true, // Default: true
635
+ cache: { enabled: false }, // Default: disabled
636
+ session: { enabled: false }, // Default: disabled
637
+ socketIO: { enabled: false }, // Default: disabled
638
+ periodicHealthCheck: { // Default: disabled
639
+ enabled: false,
640
+ interval: 30000,
641
+ services: [...]
642
+ }
643
+ });
644
+ ```
@@ -0,0 +1,5 @@
1
+ import type { Application, RequestHandler } from 'express';
2
+ import type { HealthCheckConfig, ServerPlugin } from '../types';
3
+ export declare function createHealthCheck(config?: HealthCheckConfig): RequestHandler;
4
+ export declare function withHealthCheck(path?: string, config?: HealthCheckConfig): ServerPlugin;
5
+ export declare function addHealthCheck(app: Application, path?: string, config?: HealthCheckConfig): void;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createHealthCheck = createHealthCheck;
4
+ exports.withHealthCheck = withHealthCheck;
5
+ exports.addHealthCheck = addHealthCheck;
6
+ function createHealthCheck(config = {}) {
7
+ const { customChecks = [] } = config;
8
+ return async (_req, res) => {
9
+ try {
10
+ const checks = {
11
+ server: true,
12
+ timestamp: Date.now(),
13
+ };
14
+ // Run custom health checks
15
+ for (const check of customChecks) {
16
+ try {
17
+ checks[check.name] = await check.check();
18
+ }
19
+ catch (_error) {
20
+ checks[check.name] = false;
21
+ }
22
+ }
23
+ const isHealthy = Object.values(checks).every((status) => status === true || typeof status === 'number');
24
+ res.status(isHealthy ? 200 : 503).json({
25
+ status: isHealthy ? 'healthy' : 'unhealthy',
26
+ checks,
27
+ });
28
+ }
29
+ catch (_error) {
30
+ res.status(503).json({
31
+ status: 'unhealthy',
32
+ error: 'Health check failed',
33
+ });
34
+ }
35
+ };
36
+ }
37
+ function withHealthCheck(path = '/health', config = {}) {
38
+ return (app) => {
39
+ app.get(path, createHealthCheck(config));
40
+ };
41
+ }
42
+ // Convenience function for direct use
43
+ function addHealthCheck(app, path = '/health', config = {}) {
44
+ app.get(path, createHealthCheck(config));
45
+ }
@@ -0,0 +1,11 @@
1
+ import type { PeriodicHealthCheckConfig } from '../types';
2
+ export declare class PeriodicHealthMonitor {
3
+ private intervals;
4
+ private config;
5
+ private serviceName;
6
+ constructor(config: PeriodicHealthCheckConfig, serviceName: string);
7
+ start(): void;
8
+ stop(): void;
9
+ private checkServiceHealth;
10
+ getHealthStatus(): Promise<Record<string, boolean>>;
11
+ }
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PeriodicHealthMonitor = void 0;
4
+ class PeriodicHealthMonitor {
5
+ constructor(config, serviceName) {
6
+ this.intervals = [];
7
+ this.config = config;
8
+ this.serviceName = serviceName;
9
+ }
10
+ start() {
11
+ if (!this.config.enabled || !this.config.services?.length) {
12
+ return;
13
+ }
14
+ const interval = this.config.interval || 30000;
15
+ this.config.services.forEach((service) => {
16
+ const intervalId = setInterval(async () => {
17
+ await this.checkServiceHealth(service);
18
+ }, interval);
19
+ this.intervals.push(intervalId);
20
+ });
21
+ console.log(`📊 ${this.serviceName}: Periodic health monitoring enabled (${interval}ms interval) for ${this.config.services.length} service(s)`);
22
+ }
23
+ stop() {
24
+ this.intervals.forEach((interval) => clearInterval(interval));
25
+ this.intervals = [];
26
+ console.log(`🛑 ${this.serviceName}: Periodic health monitoring stopped`);
27
+ }
28
+ async checkServiceHealth(service) {
29
+ try {
30
+ const controller = new AbortController();
31
+ const timeout = service.timeout || 5000;
32
+ const timeoutId = setTimeout(() => controller.abort(), timeout);
33
+ const response = await fetch(service.url, {
34
+ method: 'GET',
35
+ signal: controller.signal,
36
+ headers: {
37
+ 'User-Agent': `${this.serviceName}-health-monitor`,
38
+ },
39
+ });
40
+ clearTimeout(timeoutId);
41
+ if (response.ok) {
42
+ console.log(`🟢 ${service.name} is healthy`);
43
+ return true;
44
+ }
45
+ else {
46
+ console.log(`🔴 ${service.name} returned ${response.status}`);
47
+ return false;
48
+ }
49
+ }
50
+ catch (error) {
51
+ const errorMessage = error instanceof Error ? error.message : 'Unknown error';
52
+ console.log(`🔴 ${service.name} health check failed: ${errorMessage}`);
53
+ return false;
54
+ }
55
+ }
56
+ // Get current health status of all services
57
+ async getHealthStatus() {
58
+ if (!this.config.services?.length) {
59
+ return {};
60
+ }
61
+ const results = {};
62
+ await Promise.all(this.config.services.map(async (service) => {
63
+ results[service.name] = await this.checkServiceHealth(service);
64
+ }));
65
+ return results;
66
+ }
67
+ }
68
+ exports.PeriodicHealthMonitor = PeriodicHealthMonitor;