ts-packages 1.0.0 → 2.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 (752) 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 +695 -0
  5. package/packages/cache/dist/cjs/adapters/memcache/MemcacheCache.d.ts +71 -0
  6. package/packages/cache/dist/cjs/adapters/memcache/MemcacheCache.js +379 -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 +277 -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 +325 -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 +138 -0
  19. package/packages/cache/dist/cjs/core/factory.d.ts +16 -0
  20. package/packages/cache/dist/cjs/core/factory.js +60 -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 +9 -0
  28. package/packages/cache/dist/cjs/errors/CacheError.js +17 -0
  29. package/packages/cache/dist/cjs/errors/index.d.ts +1 -0
  30. package/packages/cache/dist/cjs/errors/index.js +5 -0
  31. package/packages/cache/dist/cjs/index.d.ts +10 -0
  32. package/packages/cache/dist/cjs/index.js +27 -0
  33. package/packages/cache/dist/cjs/middleware/express/cacheMiddleware.d.ts +22 -0
  34. package/packages/cache/dist/cjs/middleware/express/cacheMiddleware.js +116 -0
  35. package/packages/cache/dist/cjs/middleware/express/index.d.ts +1 -0
  36. package/packages/cache/dist/cjs/middleware/express/index.js +7 -0
  37. package/packages/cache/dist/cjs/session/SessionStore.d.ts +57 -0
  38. package/packages/cache/dist/cjs/session/SessionStore.js +161 -0
  39. package/packages/cache/dist/cjs/session/index.d.ts +2 -0
  40. package/packages/cache/dist/cjs/session/index.js +5 -0
  41. package/packages/cache/dist/cjs/types.d.ts +102 -0
  42. package/packages/cache/dist/cjs/types.js +2 -0
  43. package/packages/cache/dist/esm/adapters/memcache/MemcacheCache.d.ts +71 -0
  44. package/packages/cache/dist/esm/adapters/memcache/MemcacheCache.js +372 -0
  45. package/packages/cache/dist/esm/adapters/memcache/index.d.ts +1 -0
  46. package/packages/cache/dist/esm/adapters/memcache/index.js +1 -0
  47. package/packages/cache/dist/esm/adapters/memory/MemoryCache.d.ts +63 -0
  48. package/packages/cache/dist/esm/adapters/memory/MemoryCache.js +273 -0
  49. package/packages/cache/dist/esm/adapters/memory/index.d.ts +1 -0
  50. package/packages/cache/dist/esm/adapters/memory/index.js +1 -0
  51. package/packages/cache/dist/esm/adapters/redis/RedisCache.d.ts +67 -0
  52. package/packages/cache/dist/esm/adapters/redis/RedisCache.js +321 -0
  53. package/packages/cache/dist/esm/adapters/redis/index.d.ts +1 -0
  54. package/packages/cache/dist/esm/adapters/redis/index.js +1 -0
  55. package/packages/cache/dist/esm/core/BaseCache.d.ts +78 -0
  56. package/packages/cache/dist/esm/core/BaseCache.js +134 -0
  57. package/packages/cache/dist/esm/core/factory.d.ts +16 -0
  58. package/packages/cache/dist/esm/core/factory.js +56 -0
  59. package/packages/cache/dist/esm/core/interfaces/ICache.d.ts +58 -0
  60. package/packages/cache/dist/esm/core/interfaces/ICache.js +1 -0
  61. package/packages/cache/dist/esm/core/interfaces/ISession.d.ts +30 -0
  62. package/packages/cache/dist/esm/core/interfaces/ISession.js +1 -0
  63. package/packages/cache/dist/esm/core/interfaces/index.d.ts +2 -0
  64. package/packages/cache/dist/esm/core/interfaces/index.js +1 -0
  65. package/packages/cache/dist/esm/errors/CacheError.d.ts +9 -0
  66. package/packages/cache/dist/esm/errors/CacheError.js +13 -0
  67. package/packages/cache/dist/esm/errors/index.d.ts +1 -0
  68. package/packages/cache/dist/esm/errors/index.js +1 -0
  69. package/packages/cache/dist/esm/index.d.ts +10 -0
  70. package/packages/cache/dist/esm/index.js +14 -0
  71. package/packages/cache/dist/esm/middleware/express/cacheMiddleware.d.ts +22 -0
  72. package/packages/cache/dist/esm/middleware/express/cacheMiddleware.js +111 -0
  73. package/packages/cache/dist/esm/middleware/express/index.d.ts +1 -0
  74. package/packages/cache/dist/esm/middleware/express/index.js +1 -0
  75. package/packages/cache/dist/esm/session/SessionStore.d.ts +57 -0
  76. package/packages/cache/dist/esm/session/SessionStore.js +157 -0
  77. package/packages/cache/dist/esm/session/index.d.ts +2 -0
  78. package/packages/cache/dist/esm/session/index.js +1 -0
  79. package/packages/cache/dist/esm/types.d.ts +102 -0
  80. package/packages/cache/dist/esm/types.js +1 -0
  81. package/packages/cache/dist/types/adapters/memcache/MemcacheCache.d.ts +71 -0
  82. package/packages/cache/dist/types/adapters/memcache/index.d.ts +1 -0
  83. package/packages/cache/dist/types/adapters/memory/MemoryCache.d.ts +63 -0
  84. package/packages/cache/dist/types/adapters/memory/index.d.ts +1 -0
  85. package/packages/cache/dist/types/adapters/redis/RedisCache.d.ts +67 -0
  86. package/packages/cache/dist/types/adapters/redis/index.d.ts +1 -0
  87. package/packages/cache/dist/types/core/BaseCache.d.ts +78 -0
  88. package/packages/cache/dist/types/core/factory.d.ts +16 -0
  89. package/packages/cache/dist/types/core/interfaces/ICache.d.ts +58 -0
  90. package/packages/cache/dist/types/core/interfaces/ISession.d.ts +30 -0
  91. package/packages/cache/dist/types/core/interfaces/index.d.ts +2 -0
  92. package/packages/cache/dist/types/errors/CacheError.d.ts +9 -0
  93. package/packages/cache/dist/types/errors/index.d.ts +1 -0
  94. package/packages/cache/dist/types/index.d.ts +10 -0
  95. package/packages/cache/dist/types/middleware/express/cacheMiddleware.d.ts +22 -0
  96. package/packages/cache/dist/types/middleware/express/index.d.ts +1 -0
  97. package/packages/cache/dist/types/session/SessionStore.d.ts +57 -0
  98. package/packages/cache/dist/types/session/index.d.ts +2 -0
  99. package/packages/cache/dist/types/types.d.ts +102 -0
  100. package/packages/cache/node_modules/.bin/rimraf +21 -0
  101. package/packages/cache/node_modules/.bin/tsc +21 -0
  102. package/packages/cache/node_modules/.bin/tsserver +21 -0
  103. package/packages/cache/package.json +50 -0
  104. package/packages/cache/src/adapters/memcache/MemcacheCache.ts +452 -0
  105. package/packages/cache/src/adapters/memcache/index.ts +1 -0
  106. package/packages/cache/src/adapters/memory/MemoryCache.ts +355 -0
  107. package/packages/cache/src/adapters/memory/index.ts +1 -0
  108. package/packages/cache/src/adapters/redis/RedisCache.ts +406 -0
  109. package/packages/cache/src/adapters/redis/index.ts +1 -0
  110. package/packages/cache/src/core/BaseCache.ts +177 -0
  111. package/packages/cache/src/core/factory.ts +92 -0
  112. package/packages/cache/src/core/interfaces/ICache.ts +71 -0
  113. package/packages/cache/src/core/interfaces/ISession.ts +36 -0
  114. package/packages/cache/src/core/interfaces/index.ts +2 -0
  115. package/packages/cache/src/errors/CacheError.ts +22 -0
  116. package/packages/cache/src/errors/index.ts +1 -0
  117. package/packages/cache/src/index.ts +40 -0
  118. package/packages/cache/src/middleware/express/cacheMiddleware.ts +145 -0
  119. package/packages/cache/src/middleware/express/index.ts +5 -0
  120. package/packages/cache/src/session/SessionStore.ts +236 -0
  121. package/packages/cache/src/session/index.ts +2 -0
  122. package/packages/cache/src/types.ts +111 -0
  123. package/packages/cache/tsconfig.base.json +17 -0
  124. package/packages/cache/tsconfig.cjs.json +10 -0
  125. package/packages/cache/tsconfig.esm.json +10 -0
  126. package/packages/errors-utils/README.md +200 -0
  127. package/packages/errors-utils/dist/cjs/constants/errorCodes.d.ts +32 -0
  128. package/packages/errors-utils/dist/cjs/constants/errorCodes.js +34 -0
  129. package/packages/errors-utils/dist/cjs/constants/errorMessages.d.ts +2 -0
  130. package/packages/errors-utils/dist/cjs/constants/errorMessages.js +34 -0
  131. package/packages/errors-utils/dist/cjs/constants/index.d.ts +2 -0
  132. package/packages/errors-utils/dist/cjs/constants/index.js +18 -0
  133. package/packages/errors-utils/dist/cjs/error/AppError.d.ts +15 -0
  134. package/packages/errors-utils/dist/cjs/error/AppError.js +26 -0
  135. package/packages/errors-utils/dist/cjs/error/BadRequestError.d.ts +4 -0
  136. package/packages/errors-utils/dist/cjs/error/BadRequestError.js +12 -0
  137. package/packages/errors-utils/dist/cjs/error/ConflictError.d.ts +4 -0
  138. package/packages/errors-utils/dist/cjs/error/ConflictError.js +12 -0
  139. package/packages/errors-utils/dist/cjs/error/CryptoIntegrityError.d.ts +4 -0
  140. package/packages/errors-utils/dist/cjs/error/CryptoIntegrityError.js +11 -0
  141. package/packages/errors-utils/dist/cjs/error/ForbiddenError.d.ts +4 -0
  142. package/packages/errors-utils/dist/cjs/error/ForbiddenError.js +12 -0
  143. package/packages/errors-utils/dist/cjs/error/HTTPError.d.ts +6 -0
  144. package/packages/errors-utils/dist/cjs/error/HTTPError.js +11 -0
  145. package/packages/errors-utils/dist/cjs/error/InternalServerError.d.ts +5 -0
  146. package/packages/errors-utils/dist/cjs/error/InternalServerError.js +12 -0
  147. package/packages/errors-utils/dist/cjs/error/NotFoundError.d.ts +4 -0
  148. package/packages/errors-utils/dist/cjs/error/NotFoundError.js +12 -0
  149. package/packages/errors-utils/dist/cjs/error/RateLimitError.d.ts +4 -0
  150. package/packages/errors-utils/dist/cjs/error/RateLimitError.js +11 -0
  151. package/packages/errors-utils/dist/cjs/error/TokenExpiredError.d.ts +4 -0
  152. package/packages/errors-utils/dist/cjs/error/TokenExpiredError.js +12 -0
  153. package/packages/errors-utils/dist/cjs/error/TokenMalformedError.d.ts +4 -0
  154. package/packages/errors-utils/dist/cjs/error/TokenMalformedError.js +12 -0
  155. package/packages/errors-utils/dist/cjs/error/TooManyRequestsError.d.ts +5 -0
  156. package/packages/errors-utils/dist/cjs/error/TooManyRequestsError.js +12 -0
  157. package/packages/errors-utils/dist/cjs/error/UnauthorizedError.d.ts +5 -0
  158. package/packages/errors-utils/dist/cjs/error/UnauthorizedError.js +12 -0
  159. package/packages/errors-utils/dist/cjs/error/ValidationError.d.ts +4 -0
  160. package/packages/errors-utils/dist/cjs/error/ValidationError.js +12 -0
  161. package/packages/errors-utils/dist/cjs/index.d.ts +10 -0
  162. package/packages/errors-utils/dist/cjs/index.js +26 -0
  163. package/packages/errors-utils/dist/cjs/middleware/express/errorConverter.d.ts +2 -0
  164. package/packages/errors-utils/dist/cjs/middleware/express/errorConverter.js +39 -0
  165. package/packages/errors-utils/dist/cjs/middleware/express/errorHandler.d.ts +2 -0
  166. package/packages/errors-utils/dist/cjs/middleware/express/errorHandler.js +19 -0
  167. package/packages/errors-utils/dist/cjs/middleware/express/index.d.ts +2 -0
  168. package/packages/errors-utils/dist/cjs/middleware/express/index.js +18 -0
  169. package/packages/errors-utils/dist/cjs/utils/mapAppErrorToResponder.d.ts +3 -0
  170. package/packages/errors-utils/dist/cjs/utils/mapAppErrorToResponder.js +27 -0
  171. package/packages/errors-utils/dist/esm/constants/errorCodes.d.ts +32 -0
  172. package/packages/errors-utils/dist/esm/constants/errorCodes.js +31 -0
  173. package/packages/errors-utils/dist/esm/constants/errorMessages.d.ts +2 -0
  174. package/packages/errors-utils/dist/esm/constants/errorMessages.js +31 -0
  175. package/packages/errors-utils/dist/esm/constants/index.d.ts +2 -0
  176. package/packages/errors-utils/dist/esm/constants/index.js +2 -0
  177. package/packages/errors-utils/dist/esm/error/AppError.d.ts +15 -0
  178. package/packages/errors-utils/dist/esm/error/AppError.js +22 -0
  179. package/packages/errors-utils/dist/esm/error/BadRequestError.d.ts +4 -0
  180. package/packages/errors-utils/dist/esm/error/BadRequestError.js +8 -0
  181. package/packages/errors-utils/dist/esm/error/ConflictError.d.ts +4 -0
  182. package/packages/errors-utils/dist/esm/error/ConflictError.js +8 -0
  183. package/packages/errors-utils/dist/esm/error/CryptoIntegrityError.d.ts +4 -0
  184. package/packages/errors-utils/dist/esm/error/CryptoIntegrityError.js +7 -0
  185. package/packages/errors-utils/dist/esm/error/ForbiddenError.d.ts +4 -0
  186. package/packages/errors-utils/dist/esm/error/ForbiddenError.js +8 -0
  187. package/packages/errors-utils/dist/esm/error/HTTPError.d.ts +6 -0
  188. package/packages/errors-utils/dist/esm/error/HTTPError.js +7 -0
  189. package/packages/errors-utils/dist/esm/error/InternalServerError.d.ts +5 -0
  190. package/packages/errors-utils/dist/esm/error/InternalServerError.js +8 -0
  191. package/packages/errors-utils/dist/esm/error/NotFoundError.d.ts +4 -0
  192. package/packages/errors-utils/dist/esm/error/NotFoundError.js +8 -0
  193. package/packages/errors-utils/dist/esm/error/RateLimitError.d.ts +4 -0
  194. package/packages/errors-utils/dist/esm/error/RateLimitError.js +7 -0
  195. package/packages/errors-utils/dist/esm/error/TokenExpiredError.d.ts +4 -0
  196. package/packages/errors-utils/dist/esm/error/TokenExpiredError.js +8 -0
  197. package/packages/errors-utils/dist/esm/error/TokenMalformedError.d.ts +4 -0
  198. package/packages/errors-utils/dist/esm/error/TokenMalformedError.js +8 -0
  199. package/packages/errors-utils/dist/esm/error/TooManyRequestsError.d.ts +5 -0
  200. package/packages/errors-utils/dist/esm/error/TooManyRequestsError.js +8 -0
  201. package/packages/errors-utils/dist/esm/error/UnauthorizedError.d.ts +5 -0
  202. package/packages/errors-utils/dist/esm/error/UnauthorizedError.js +8 -0
  203. package/packages/errors-utils/dist/esm/error/ValidationError.d.ts +4 -0
  204. package/packages/errors-utils/dist/esm/error/ValidationError.js +8 -0
  205. package/packages/errors-utils/dist/esm/index.d.ts +10 -0
  206. package/packages/errors-utils/dist/esm/index.js +10 -0
  207. package/packages/errors-utils/dist/esm/middleware/express/errorConverter.d.ts +2 -0
  208. package/packages/errors-utils/dist/esm/middleware/express/errorConverter.js +36 -0
  209. package/packages/errors-utils/dist/esm/middleware/express/errorHandler.d.ts +2 -0
  210. package/packages/errors-utils/dist/esm/middleware/express/errorHandler.js +16 -0
  211. package/packages/errors-utils/dist/esm/middleware/express/index.d.ts +2 -0
  212. package/packages/errors-utils/dist/esm/middleware/express/index.js +2 -0
  213. package/packages/errors-utils/dist/esm/utils/mapAppErrorToResponder.d.ts +3 -0
  214. package/packages/errors-utils/dist/esm/utils/mapAppErrorToResponder.js +24 -0
  215. package/packages/errors-utils/dist/types/constants/errorCodes.d.ts +32 -0
  216. package/packages/errors-utils/dist/types/constants/errorMessages.d.ts +2 -0
  217. package/packages/errors-utils/dist/types/constants/index.d.ts +2 -0
  218. package/packages/errors-utils/dist/types/error/AppError.d.ts +15 -0
  219. package/packages/errors-utils/dist/types/error/BadRequestError.d.ts +4 -0
  220. package/packages/errors-utils/dist/types/error/ConflictError.d.ts +4 -0
  221. package/packages/errors-utils/dist/types/error/CryptoIntegrityError.d.ts +4 -0
  222. package/packages/errors-utils/dist/types/error/ForbiddenError.d.ts +4 -0
  223. package/packages/errors-utils/dist/types/error/HTTPError.d.ts +6 -0
  224. package/packages/errors-utils/dist/types/error/InternalServerError.d.ts +5 -0
  225. package/packages/errors-utils/dist/types/error/NotFoundError.d.ts +4 -0
  226. package/packages/errors-utils/dist/types/error/RateLimitError.d.ts +4 -0
  227. package/packages/errors-utils/dist/types/error/TokenExpiredError.d.ts +4 -0
  228. package/packages/errors-utils/dist/types/error/TokenMalformedError.d.ts +4 -0
  229. package/packages/errors-utils/dist/types/error/TooManyRequestsError.d.ts +5 -0
  230. package/packages/errors-utils/dist/types/error/UnauthorizedError.d.ts +5 -0
  231. package/packages/errors-utils/dist/types/error/ValidationError.d.ts +4 -0
  232. package/packages/errors-utils/dist/types/index.d.ts +10 -0
  233. package/packages/errors-utils/dist/types/middleware/express/errorConverter.d.ts +2 -0
  234. package/packages/errors-utils/dist/types/middleware/express/errorHandler.d.ts +2 -0
  235. package/packages/errors-utils/dist/types/middleware/express/index.d.ts +2 -0
  236. package/packages/errors-utils/dist/types/utils/mapAppErrorToResponder.d.ts +3 -0
  237. package/packages/errors-utils/node_modules/.bin/rimraf +21 -0
  238. package/packages/errors-utils/node_modules/.bin/tsc +21 -0
  239. package/packages/errors-utils/node_modules/.bin/tsserver +21 -0
  240. package/packages/errors-utils/package.json +42 -0
  241. package/packages/errors-utils/src/constants/errorCodes.ts +37 -0
  242. package/packages/errors-utils/src/constants/errorMessages.ts +37 -0
  243. package/packages/errors-utils/src/constants/index.ts +2 -0
  244. package/packages/errors-utils/src/error/AppError.ts +35 -0
  245. package/packages/errors-utils/src/error/BadRequestError.ts +14 -0
  246. package/packages/errors-utils/src/error/ConflictError.ts +14 -0
  247. package/packages/errors-utils/src/error/CryptoIntegrityError.ts +8 -0
  248. package/packages/errors-utils/src/error/ForbiddenError.ts +14 -0
  249. package/packages/errors-utils/src/error/HTTPError.ts +17 -0
  250. package/packages/errors-utils/src/error/InternalServerError.ts +18 -0
  251. package/packages/errors-utils/src/error/NotFoundError.ts +14 -0
  252. package/packages/errors-utils/src/error/RateLimitError.ts +8 -0
  253. package/packages/errors-utils/src/error/TokenExpiredError.ts +14 -0
  254. package/packages/errors-utils/src/error/TokenMalformedError.ts +14 -0
  255. package/packages/errors-utils/src/error/TooManyRequestsError.ts +13 -0
  256. package/packages/errors-utils/src/error/UnauthorizedError.ts +14 -0
  257. package/packages/errors-utils/src/error/ValidationError.ts +14 -0
  258. package/packages/errors-utils/src/index.ts +11 -0
  259. package/packages/errors-utils/src/middleware/express/errorConverter.ts +52 -0
  260. package/packages/errors-utils/src/middleware/express/errorHandler.ts +32 -0
  261. package/packages/errors-utils/src/middleware/express/index.ts +2 -0
  262. package/packages/errors-utils/src/utils/mapAppErrorToResponder.ts +38 -0
  263. package/packages/errors-utils/tsconfig.base.json +17 -0
  264. package/packages/errors-utils/tsconfig.cjs.json +9 -0
  265. package/packages/errors-utils/tsconfig.esm.json +9 -0
  266. package/packages/errors-utils/tsconfig.json +21 -0
  267. package/packages/js-extensions/README.md +469 -0
  268. package/packages/js-extensions/dist/cjs/array/array-extensions.d.ts +1 -0
  269. package/packages/js-extensions/dist/cjs/array/array-extensions.js +120 -0
  270. package/packages/js-extensions/dist/cjs/array/index.d.ts +1 -0
  271. package/packages/js-extensions/dist/cjs/array/index.js +5 -0
  272. package/packages/js-extensions/dist/cjs/core/index.d.ts +2 -0
  273. package/packages/js-extensions/dist/cjs/core/index.js +19 -0
  274. package/packages/js-extensions/dist/cjs/core/performance.d.ts +16 -0
  275. package/packages/js-extensions/dist/cjs/core/performance.js +76 -0
  276. package/packages/js-extensions/dist/cjs/core/validation.d.ts +4 -0
  277. package/packages/js-extensions/dist/cjs/core/validation.js +31 -0
  278. package/packages/js-extensions/dist/cjs/extensions/index.d.ts +4 -0
  279. package/packages/js-extensions/dist/cjs/extensions/index.js +21 -0
  280. package/packages/js-extensions/dist/cjs/index.d.ts +60 -0
  281. package/packages/js-extensions/dist/cjs/index.js +76 -0
  282. package/packages/js-extensions/dist/cjs/init/index.d.ts +2 -0
  283. package/packages/js-extensions/dist/cjs/init/index.js +19 -0
  284. package/packages/js-extensions/dist/cjs/init/initializer.d.ts +3 -0
  285. package/packages/js-extensions/dist/cjs/init/initializer.js +28 -0
  286. package/packages/js-extensions/dist/cjs/init/options.d.ts +3 -0
  287. package/packages/js-extensions/dist/cjs/init/options.js +23 -0
  288. package/packages/js-extensions/dist/cjs/number/index.d.ts +1 -0
  289. package/packages/js-extensions/dist/cjs/number/index.js +5 -0
  290. package/packages/js-extensions/dist/cjs/number/number-extensions.d.ts +1 -0
  291. package/packages/js-extensions/dist/cjs/number/number-extensions.js +137 -0
  292. package/packages/js-extensions/dist/cjs/object/index.d.ts +1 -0
  293. package/packages/js-extensions/dist/cjs/object/index.js +5 -0
  294. package/packages/js-extensions/dist/cjs/object/object-extensions.d.ts +1 -0
  295. package/packages/js-extensions/dist/cjs/object/object-extensions.js +147 -0
  296. package/packages/js-extensions/dist/cjs/string/index.d.ts +1 -0
  297. package/packages/js-extensions/dist/cjs/string/index.js +5 -0
  298. package/packages/js-extensions/dist/cjs/string/string-extensions.d.ts +1 -0
  299. package/packages/js-extensions/dist/cjs/string/string-extensions.js +100 -0
  300. package/packages/js-extensions/dist/cjs/types/extension-types.d.ts +9 -0
  301. package/packages/js-extensions/dist/cjs/types/extension-types.js +2 -0
  302. package/packages/js-extensions/dist/cjs/types/global-augmentations.d.ts +71 -0
  303. package/packages/js-extensions/dist/cjs/types/global-augmentations.js +2 -0
  304. package/packages/js-extensions/dist/cjs/types/index.d.ts +2 -0
  305. package/packages/js-extensions/dist/cjs/types/index.js +19 -0
  306. package/packages/js-extensions/dist/cjs/utils/config.d.ts +4 -0
  307. package/packages/js-extensions/dist/cjs/utils/config.js +25 -0
  308. package/packages/js-extensions/dist/cjs/utils/helpers.d.ts +5 -0
  309. package/packages/js-extensions/dist/cjs/utils/helpers.js +37 -0
  310. package/packages/js-extensions/dist/cjs/utils/index.d.ts +2 -0
  311. package/packages/js-extensions/dist/cjs/utils/index.js +19 -0
  312. package/packages/js-extensions/dist/esm/array/array-extensions.d.ts +1 -0
  313. package/packages/js-extensions/dist/esm/array/array-extensions.js +117 -0
  314. package/packages/js-extensions/dist/esm/array/index.d.ts +1 -0
  315. package/packages/js-extensions/dist/esm/array/index.js +1 -0
  316. package/packages/js-extensions/dist/esm/core/index.d.ts +2 -0
  317. package/packages/js-extensions/dist/esm/core/index.js +3 -0
  318. package/packages/js-extensions/dist/esm/core/performance.d.ts +16 -0
  319. package/packages/js-extensions/dist/esm/core/performance.js +69 -0
  320. package/packages/js-extensions/dist/esm/core/validation.d.ts +4 -0
  321. package/packages/js-extensions/dist/esm/core/validation.js +25 -0
  322. package/packages/js-extensions/dist/esm/extensions/index.d.ts +4 -0
  323. package/packages/js-extensions/dist/esm/extensions/index.js +5 -0
  324. package/packages/js-extensions/dist/esm/index.d.ts +60 -0
  325. package/packages/js-extensions/dist/esm/index.js +67 -0
  326. package/packages/js-extensions/dist/esm/init/index.d.ts +2 -0
  327. package/packages/js-extensions/dist/esm/init/index.js +3 -0
  328. package/packages/js-extensions/dist/esm/init/initializer.d.ts +3 -0
  329. package/packages/js-extensions/dist/esm/init/initializer.js +24 -0
  330. package/packages/js-extensions/dist/esm/init/options.d.ts +3 -0
  331. package/packages/js-extensions/dist/esm/init/options.js +19 -0
  332. package/packages/js-extensions/dist/esm/number/index.d.ts +1 -0
  333. package/packages/js-extensions/dist/esm/number/index.js +1 -0
  334. package/packages/js-extensions/dist/esm/number/number-extensions.d.ts +1 -0
  335. package/packages/js-extensions/dist/esm/number/number-extensions.js +134 -0
  336. package/packages/js-extensions/dist/esm/object/index.d.ts +1 -0
  337. package/packages/js-extensions/dist/esm/object/index.js +1 -0
  338. package/packages/js-extensions/dist/esm/object/object-extensions.d.ts +1 -0
  339. package/packages/js-extensions/dist/esm/object/object-extensions.js +144 -0
  340. package/packages/js-extensions/dist/esm/string/index.d.ts +1 -0
  341. package/packages/js-extensions/dist/esm/string/index.js +1 -0
  342. package/packages/js-extensions/dist/esm/string/string-extensions.d.ts +1 -0
  343. package/packages/js-extensions/dist/esm/string/string-extensions.js +97 -0
  344. package/packages/js-extensions/dist/esm/types/extension-types.d.ts +9 -0
  345. package/packages/js-extensions/dist/esm/types/extension-types.js +1 -0
  346. package/packages/js-extensions/dist/esm/types/global-augmentations.d.ts +71 -0
  347. package/packages/js-extensions/dist/esm/types/global-augmentations.js +1 -0
  348. package/packages/js-extensions/dist/esm/types/index.d.ts +2 -0
  349. package/packages/js-extensions/dist/esm/types/index.js +3 -0
  350. package/packages/js-extensions/dist/esm/utils/config.d.ts +4 -0
  351. package/packages/js-extensions/dist/esm/utils/config.js +20 -0
  352. package/packages/js-extensions/dist/esm/utils/helpers.d.ts +5 -0
  353. package/packages/js-extensions/dist/esm/utils/helpers.js +30 -0
  354. package/packages/js-extensions/dist/esm/utils/index.d.ts +2 -0
  355. package/packages/js-extensions/dist/esm/utils/index.js +3 -0
  356. package/packages/js-extensions/dist/types/array/array-extensions.d.ts +1 -0
  357. package/packages/js-extensions/dist/types/array/index.d.ts +1 -0
  358. package/packages/js-extensions/dist/types/core/index.d.ts +2 -0
  359. package/packages/js-extensions/dist/types/core/performance.d.ts +16 -0
  360. package/packages/js-extensions/dist/types/core/validation.d.ts +4 -0
  361. package/packages/js-extensions/dist/types/extensions/index.d.ts +4 -0
  362. package/packages/js-extensions/dist/types/index.d.ts +60 -0
  363. package/packages/js-extensions/dist/types/init/index.d.ts +2 -0
  364. package/packages/js-extensions/dist/types/init/initializer.d.ts +3 -0
  365. package/packages/js-extensions/dist/types/init/options.d.ts +3 -0
  366. package/packages/js-extensions/dist/types/number/index.d.ts +1 -0
  367. package/packages/js-extensions/dist/types/number/number-extensions.d.ts +1 -0
  368. package/packages/js-extensions/dist/types/object/index.d.ts +1 -0
  369. package/packages/js-extensions/dist/types/object/object-extensions.d.ts +1 -0
  370. package/packages/js-extensions/dist/types/string/index.d.ts +1 -0
  371. package/packages/js-extensions/dist/types/string/string-extensions.d.ts +1 -0
  372. package/packages/js-extensions/dist/types/types/extension-types.d.ts +9 -0
  373. package/packages/js-extensions/dist/types/types/global-augmentations.d.ts +71 -0
  374. package/packages/js-extensions/dist/types/types/index.d.ts +2 -0
  375. package/packages/js-extensions/dist/types/utils/config.d.ts +4 -0
  376. package/packages/js-extensions/dist/types/utils/helpers.d.ts +5 -0
  377. package/packages/js-extensions/dist/types/utils/index.d.ts +2 -0
  378. package/packages/js-extensions/node_modules/.bin/rimraf +21 -0
  379. package/packages/js-extensions/node_modules/.bin/tsc +21 -0
  380. package/packages/js-extensions/node_modules/.bin/tsserver +21 -0
  381. package/packages/js-extensions/package.json +44 -0
  382. package/packages/js-extensions/src/array/array-extensions.ts +174 -0
  383. package/packages/js-extensions/src/array/index.ts +1 -0
  384. package/packages/js-extensions/src/core/index.ts +3 -0
  385. package/packages/js-extensions/src/core/performance.ts +92 -0
  386. package/packages/js-extensions/src/core/validation.ts +42 -0
  387. package/packages/js-extensions/src/extensions/index.ts +5 -0
  388. package/packages/js-extensions/src/index.ts +120 -0
  389. package/packages/js-extensions/src/init/index.ts +3 -0
  390. package/packages/js-extensions/src/init/initializer.ts +32 -0
  391. package/packages/js-extensions/src/init/options.ts +32 -0
  392. package/packages/js-extensions/src/number/index.ts +1 -0
  393. package/packages/js-extensions/src/number/number-extensions.ts +162 -0
  394. package/packages/js-extensions/src/object/index.ts +1 -0
  395. package/packages/js-extensions/src/object/object-extensions.ts +171 -0
  396. package/packages/js-extensions/src/string/index.ts +1 -0
  397. package/packages/js-extensions/src/string/string-extensions.ts +138 -0
  398. package/packages/js-extensions/src/types/extension-types.ts +12 -0
  399. package/packages/js-extensions/src/types/global-augmentations.ts +80 -0
  400. package/packages/js-extensions/src/types/index.ts +3 -0
  401. package/packages/js-extensions/src/utils/config.ts +33 -0
  402. package/packages/js-extensions/src/utils/helpers.ts +35 -0
  403. package/packages/js-extensions/src/utils/index.ts +3 -0
  404. package/packages/js-extensions/tsconfig.base.json +18 -0
  405. package/packages/js-extensions/tsconfig.cjs.json +9 -0
  406. package/packages/js-extensions/tsconfig.esm.json +9 -0
  407. package/packages/js-extensions/tsconfig.json +22 -0
  408. package/packages/response-utils/README.md +211 -75
  409. package/packages/response-utils/dist/cjs/adapters/express/ExpressResponder.d.ts +18 -0
  410. package/packages/response-utils/dist/cjs/adapters/express/ExpressResponder.js +46 -0
  411. package/packages/response-utils/dist/cjs/constants/httpStatus.d.ts +54 -0
  412. package/packages/response-utils/dist/cjs/constants/httpStatus.js +34 -0
  413. package/packages/response-utils/dist/cjs/core/BaseResponder.d.ts +31 -0
  414. package/packages/response-utils/dist/cjs/core/BaseResponder.js +100 -0
  415. package/packages/response-utils/dist/cjs/core/config.d.ts +15 -0
  416. package/packages/response-utils/dist/cjs/core/config.js +15 -0
  417. package/packages/response-utils/dist/cjs/core/factory.d.ts +3 -0
  418. package/packages/response-utils/dist/cjs/core/factory.js +10 -0
  419. package/packages/response-utils/dist/cjs/core/types.d.ts +32 -0
  420. package/packages/response-utils/dist/cjs/core/types.js +2 -0
  421. package/packages/response-utils/dist/cjs/index.d.ts +9 -0
  422. package/packages/response-utils/dist/cjs/index.js +56 -0
  423. package/packages/response-utils/dist/cjs/legacy.d.ts +19 -0
  424. package/packages/response-utils/dist/cjs/legacy.js +23 -0
  425. package/packages/response-utils/dist/cjs/middleware/express/expressMiddleware.d.ts +3 -0
  426. package/packages/response-utils/dist/cjs/middleware/express/expressMiddleware.js +13 -0
  427. package/packages/response-utils/dist/esm/adapters/express/ExpressResponder.d.ts +18 -0
  428. package/packages/response-utils/dist/esm/adapters/express/ExpressResponder.js +42 -0
  429. package/packages/response-utils/dist/esm/constants/httpStatus.d.ts +54 -0
  430. package/packages/response-utils/dist/esm/constants/httpStatus.js +31 -0
  431. package/packages/response-utils/dist/esm/core/BaseResponder.d.ts +31 -0
  432. package/packages/response-utils/dist/esm/core/BaseResponder.js +96 -0
  433. package/packages/response-utils/dist/esm/core/config.d.ts +15 -0
  434. package/packages/response-utils/dist/esm/core/config.js +12 -0
  435. package/packages/response-utils/dist/esm/core/factory.d.ts +3 -0
  436. package/packages/response-utils/dist/esm/core/factory.js +6 -0
  437. package/packages/response-utils/dist/esm/core/types.d.ts +32 -0
  438. package/packages/response-utils/dist/esm/core/types.js +1 -0
  439. package/packages/response-utils/dist/esm/index.d.ts +9 -0
  440. package/packages/response-utils/dist/esm/index.js +12 -0
  441. package/packages/response-utils/dist/esm/legacy.d.ts +19 -0
  442. package/packages/response-utils/dist/esm/legacy.js +18 -0
  443. package/packages/response-utils/dist/esm/middleware/express/expressMiddleware.d.ts +3 -0
  444. package/packages/response-utils/dist/esm/middleware/express/expressMiddleware.js +9 -0
  445. package/packages/response-utils/dist/types/adapters/express/ExpressResponder.d.ts +18 -0
  446. package/packages/response-utils/dist/types/constants/httpStatus.d.ts +54 -0
  447. package/packages/response-utils/dist/types/core/BaseResponder.d.ts +31 -0
  448. package/packages/response-utils/dist/types/core/config.d.ts +15 -0
  449. package/packages/response-utils/dist/types/core/factory.d.ts +3 -0
  450. package/packages/response-utils/dist/types/core/types.d.ts +32 -0
  451. package/packages/response-utils/dist/types/index.d.ts +9 -0
  452. package/packages/response-utils/dist/types/legacy.d.ts +19 -0
  453. package/packages/response-utils/dist/types/middleware/express/expressMiddleware.d.ts +3 -0
  454. package/packages/response-utils/node_modules/.bin/rimraf +21 -0
  455. package/packages/response-utils/node_modules/.bin/tsc +21 -0
  456. package/packages/response-utils/node_modules/.bin/tsserver +21 -0
  457. package/packages/response-utils/package.json +38 -10
  458. package/packages/response-utils/src/adapters/express/ExpressResponder.ts +64 -0
  459. package/packages/response-utils/src/constants/httpStatus.ts +42 -0
  460. package/packages/response-utils/src/core/BaseResponder.ts +177 -0
  461. package/packages/response-utils/src/core/config.ts +29 -0
  462. package/packages/response-utils/src/core/factory.ts +11 -0
  463. package/packages/response-utils/src/core/types.ts +34 -0
  464. package/packages/response-utils/src/index.ts +16 -168
  465. package/packages/response-utils/src/legacy.ts +30 -0
  466. package/packages/response-utils/src/middleware/express/expressMiddleware.ts +14 -0
  467. package/packages/response-utils/tsconfig.base.json +11 -0
  468. package/packages/response-utils/tsconfig.cjs.json +9 -0
  469. package/packages/response-utils/tsconfig.esm.json +9 -0
  470. package/packages/security/README.md +485 -71
  471. package/packages/security/dist/cjs/core/crypto/cryptoManager.d.ts +111 -0
  472. package/packages/security/dist/cjs/core/crypto/cryptoManager.js +191 -0
  473. package/packages/security/dist/cjs/core/crypto/decrypt.d.ts +1 -0
  474. package/packages/security/dist/cjs/core/crypto/decrypt.js +21 -0
  475. package/packages/security/dist/cjs/core/crypto/encrypt.d.ts +1 -0
  476. package/packages/security/dist/cjs/core/crypto/encrypt.js +16 -0
  477. package/packages/security/dist/cjs/core/crypto/hmac.d.ts +8 -0
  478. package/packages/security/dist/cjs/core/crypto/hmac.js +24 -0
  479. package/packages/security/dist/cjs/core/crypto/index.d.ts +5 -0
  480. package/packages/security/dist/cjs/core/crypto/index.js +28 -0
  481. package/packages/security/dist/cjs/core/crypto/random.d.ts +8 -0
  482. package/packages/security/dist/cjs/core/crypto/random.js +21 -0
  483. package/packages/security/dist/cjs/core/jwt/decode.d.ts +12 -0
  484. package/packages/security/dist/cjs/core/jwt/decode.js +25 -0
  485. package/packages/security/dist/cjs/core/jwt/extractToken.d.ts +11 -0
  486. package/packages/security/dist/cjs/core/jwt/extractToken.js +54 -0
  487. package/packages/security/dist/cjs/core/jwt/generateTokens.d.ts +4 -0
  488. package/packages/security/dist/cjs/core/jwt/generateTokens.js +34 -0
  489. package/packages/security/dist/cjs/core/jwt/index.d.ts +8 -0
  490. package/packages/security/dist/cjs/core/jwt/index.js +24 -0
  491. package/packages/security/dist/cjs/core/jwt/jwtManager.d.ts +67 -0
  492. package/packages/security/dist/cjs/core/jwt/jwtManager.js +303 -0
  493. package/packages/security/dist/cjs/core/jwt/parseDuration.d.ts +1 -0
  494. package/packages/security/dist/cjs/core/jwt/parseDuration.js +29 -0
  495. package/packages/security/dist/cjs/core/jwt/signToken.d.ts +2 -0
  496. package/packages/security/dist/cjs/core/jwt/signToken.js +26 -0
  497. package/packages/security/dist/cjs/core/jwt/types.d.ts +22 -0
  498. package/packages/security/dist/cjs/core/jwt/types.js +2 -0
  499. package/packages/security/dist/cjs/core/jwt/validateToken.d.ts +13 -0
  500. package/packages/security/dist/cjs/core/jwt/validateToken.js +37 -0
  501. package/packages/security/dist/cjs/core/jwt/verify.d.ts +19 -0
  502. package/packages/security/dist/cjs/core/jwt/verify.js +44 -0
  503. package/packages/security/dist/cjs/core/password/hash.d.ts +10 -0
  504. package/packages/security/dist/cjs/core/password/hash.js +45 -0
  505. package/packages/security/dist/cjs/core/password/index.d.ts +3 -0
  506. package/packages/security/dist/cjs/core/password/index.js +19 -0
  507. package/packages/security/dist/cjs/core/password/passwordManager.d.ts +29 -0
  508. package/packages/security/dist/cjs/core/password/passwordManager.js +256 -0
  509. package/packages/security/dist/cjs/core/password/strength.d.ts +2 -0
  510. package/packages/security/dist/cjs/core/password/strength.js +21 -0
  511. package/packages/security/dist/cjs/core/password/types.d.ts +7 -0
  512. package/packages/security/dist/cjs/core/password/types.js +2 -0
  513. package/packages/security/dist/cjs/core/password/utils.d.ts +4 -0
  514. package/packages/security/dist/cjs/core/password/utils.js +38 -0
  515. package/packages/security/dist/cjs/core/password/verify.d.ts +10 -0
  516. package/packages/security/dist/cjs/core/password/verify.js +46 -0
  517. package/packages/security/dist/cjs/index.d.ts +45 -0
  518. package/packages/security/dist/cjs/index.js +56 -0
  519. package/packages/security/dist/cjs/interfaces/jwt.interface.d.ts +47 -0
  520. package/packages/security/dist/cjs/interfaces/jwt.interface.js +2 -0
  521. package/packages/security/dist/cjs/interfaces/password.interface.d.ts +60 -0
  522. package/packages/security/dist/cjs/interfaces/password.interface.js +2 -0
  523. package/packages/security/dist/esm/core/crypto/cryptoManager.d.ts +111 -0
  524. package/packages/security/dist/esm/core/crypto/cryptoManager.js +186 -0
  525. package/packages/security/dist/esm/core/crypto/decrypt.d.ts +1 -0
  526. package/packages/security/dist/esm/core/crypto/decrypt.js +14 -0
  527. package/packages/security/dist/esm/core/crypto/encrypt.d.ts +1 -0
  528. package/packages/security/dist/esm/core/crypto/encrypt.js +9 -0
  529. package/packages/security/dist/esm/core/crypto/hmac.d.ts +8 -0
  530. package/packages/security/dist/esm/core/crypto/hmac.js +16 -0
  531. package/packages/security/dist/esm/core/crypto/index.d.ts +5 -0
  532. package/packages/security/dist/esm/core/crypto/index.js +5 -0
  533. package/packages/security/dist/esm/core/crypto/random.d.ts +8 -0
  534. package/packages/security/dist/esm/core/crypto/random.js +13 -0
  535. package/packages/security/dist/esm/core/jwt/decode.d.ts +12 -0
  536. package/packages/security/dist/esm/core/jwt/decode.js +21 -0
  537. package/packages/security/dist/esm/core/jwt/extractToken.d.ts +11 -0
  538. package/packages/security/dist/esm/core/jwt/extractToken.js +51 -0
  539. package/packages/security/dist/esm/core/jwt/generateTokens.d.ts +4 -0
  540. package/packages/security/dist/esm/core/jwt/generateTokens.js +29 -0
  541. package/packages/security/dist/esm/core/jwt/index.d.ts +8 -0
  542. package/packages/security/dist/esm/core/jwt/index.js +8 -0
  543. package/packages/security/dist/esm/core/jwt/jwtManager.d.ts +67 -0
  544. package/packages/security/dist/esm/core/jwt/jwtManager.js +296 -0
  545. package/packages/security/dist/esm/core/jwt/parseDuration.d.ts +1 -0
  546. package/packages/security/dist/esm/core/jwt/parseDuration.js +26 -0
  547. package/packages/security/dist/esm/core/jwt/signToken.d.ts +2 -0
  548. package/packages/security/dist/esm/core/jwt/signToken.js +22 -0
  549. package/packages/security/dist/esm/core/jwt/types.d.ts +22 -0
  550. package/packages/security/dist/esm/core/jwt/types.js +1 -0
  551. package/packages/security/dist/esm/core/jwt/validateToken.d.ts +13 -0
  552. package/packages/security/dist/esm/core/jwt/validateToken.js +33 -0
  553. package/packages/security/dist/esm/core/jwt/verify.d.ts +19 -0
  554. package/packages/security/dist/esm/core/jwt/verify.js +37 -0
  555. package/packages/security/dist/esm/core/password/hash.d.ts +10 -0
  556. package/packages/security/dist/esm/core/password/hash.js +35 -0
  557. package/packages/security/dist/esm/core/password/index.d.ts +3 -0
  558. package/packages/security/dist/esm/core/password/index.js +3 -0
  559. package/packages/security/dist/esm/core/password/passwordManager.d.ts +29 -0
  560. package/packages/security/dist/esm/core/password/passwordManager.js +249 -0
  561. package/packages/security/dist/esm/core/password/strength.d.ts +2 -0
  562. package/packages/security/dist/esm/core/password/strength.js +17 -0
  563. package/packages/security/dist/esm/core/password/types.d.ts +7 -0
  564. package/packages/security/dist/esm/core/password/types.js +1 -0
  565. package/packages/security/dist/esm/core/password/utils.d.ts +4 -0
  566. package/packages/security/dist/esm/core/password/utils.js +29 -0
  567. package/packages/security/dist/esm/core/password/verify.d.ts +10 -0
  568. package/packages/security/dist/esm/core/password/verify.js +36 -0
  569. package/packages/security/dist/esm/index.d.ts +45 -0
  570. package/packages/security/dist/esm/index.js +13 -0
  571. package/packages/security/dist/esm/interfaces/jwt.interface.d.ts +47 -0
  572. package/packages/security/dist/esm/interfaces/jwt.interface.js +1 -0
  573. package/packages/security/dist/esm/interfaces/password.interface.d.ts +60 -0
  574. package/packages/security/dist/esm/interfaces/password.interface.js +1 -0
  575. package/packages/security/dist/types/core/crypto/cryptoManager.d.ts +111 -0
  576. package/packages/security/dist/types/core/crypto/decrypt.d.ts +1 -0
  577. package/packages/security/dist/types/core/crypto/encrypt.d.ts +1 -0
  578. package/packages/security/dist/types/core/crypto/hmac.d.ts +8 -0
  579. package/packages/security/dist/types/core/crypto/index.d.ts +5 -0
  580. package/packages/security/dist/types/core/crypto/random.d.ts +8 -0
  581. package/packages/security/dist/types/core/jwt/decode.d.ts +12 -0
  582. package/packages/security/dist/types/core/jwt/extractToken.d.ts +11 -0
  583. package/packages/security/dist/types/core/jwt/generateTokens.d.ts +4 -0
  584. package/packages/security/dist/types/core/jwt/index.d.ts +8 -0
  585. package/packages/security/dist/types/core/jwt/jwtManager.d.ts +67 -0
  586. package/packages/security/dist/types/core/jwt/parseDuration.d.ts +1 -0
  587. package/packages/security/dist/types/core/jwt/signToken.d.ts +2 -0
  588. package/packages/security/dist/types/core/jwt/types.d.ts +22 -0
  589. package/packages/security/dist/types/core/jwt/validateToken.d.ts +13 -0
  590. package/packages/security/dist/types/core/jwt/verify.d.ts +19 -0
  591. package/packages/security/dist/types/core/password/hash.d.ts +10 -0
  592. package/packages/security/dist/types/core/password/index.d.ts +3 -0
  593. package/packages/security/dist/types/core/password/passwordManager.d.ts +29 -0
  594. package/packages/security/dist/types/core/password/strength.d.ts +2 -0
  595. package/packages/security/dist/types/core/password/types.d.ts +7 -0
  596. package/packages/security/dist/types/core/password/utils.d.ts +4 -0
  597. package/packages/security/dist/types/core/password/verify.d.ts +10 -0
  598. package/packages/security/dist/types/index.d.ts +45 -0
  599. package/packages/security/dist/types/interfaces/jwt.interface.d.ts +47 -0
  600. package/packages/security/dist/types/interfaces/password.interface.d.ts +60 -0
  601. package/packages/security/node_modules/.bin/bcrypt +21 -0
  602. package/packages/security/node_modules/.bin/rimraf +21 -0
  603. package/packages/security/node_modules/.bin/tsc +21 -0
  604. package/packages/security/node_modules/.bin/tsserver +21 -0
  605. package/packages/security/package.json +23 -4
  606. package/packages/security/src/core/crypto/cryptoManager.ts +292 -0
  607. package/packages/security/src/core/crypto/decrypt.ts +20 -0
  608. package/packages/security/src/core/crypto/encrypt.ts +14 -0
  609. package/packages/security/src/core/crypto/hmac.ts +23 -0
  610. package/packages/security/src/core/crypto/index.ts +5 -0
  611. package/packages/security/src/core/crypto/random.ts +15 -0
  612. package/packages/security/src/core/jwt/decode.ts +25 -0
  613. package/packages/security/src/core/jwt/extractToken.ts +59 -0
  614. package/packages/security/src/core/jwt/generateTokens.ts +48 -0
  615. package/packages/security/src/core/jwt/index.ts +8 -0
  616. package/packages/security/src/core/jwt/jwtManager.ts +385 -0
  617. package/packages/security/src/core/jwt/parseDuration.ts +32 -0
  618. package/packages/security/src/core/jwt/signToken.ts +31 -0
  619. package/packages/security/src/core/jwt/types.ts +29 -0
  620. package/packages/security/src/core/jwt/validateToken.ts +52 -0
  621. package/packages/security/src/core/jwt/verify.ts +55 -0
  622. package/packages/security/src/core/password/hash.ts +40 -0
  623. package/packages/security/src/core/password/index.ts +3 -0
  624. package/packages/security/src/core/password/passwordManager.ts +314 -0
  625. package/packages/security/src/core/password/strength.ts +35 -0
  626. package/packages/security/src/core/password/types.ts +7 -0
  627. package/packages/security/src/core/password/utils.ts +31 -0
  628. package/packages/security/src/core/password/verify.ts +47 -0
  629. package/packages/security/src/index.ts +21 -39
  630. package/packages/security/src/interfaces/jwt.interface.ts +58 -0
  631. package/packages/security/src/interfaces/password.interface.ts +54 -0
  632. package/packages/security/tsconfig.base.json +17 -0
  633. package/packages/security/tsconfig.cjs.json +9 -0
  634. package/packages/security/tsconfig.esm.json +9 -0
  635. package/packages/server-utils/README.md +412 -49
  636. package/packages/server-utils/dist/cjs/core/health.d.ts +5 -0
  637. package/packages/server-utils/dist/cjs/core/health.js +45 -0
  638. package/packages/server-utils/dist/cjs/core/periodic-health.d.ts +11 -0
  639. package/packages/server-utils/dist/cjs/core/periodic-health.js +68 -0
  640. package/packages/server-utils/dist/cjs/core/server.d.ts +73 -0
  641. package/packages/server-utils/dist/cjs/core/server.js +437 -0
  642. package/packages/server-utils/dist/cjs/core/shutdown.d.ts +5 -0
  643. package/packages/server-utils/dist/cjs/core/shutdown.js +58 -0
  644. package/packages/server-utils/dist/cjs/index.d.ts +46 -0
  645. package/packages/server-utils/dist/cjs/index.js +91 -0
  646. package/packages/server-utils/dist/cjs/middleware/auth.middleware.d.ts +7 -0
  647. package/packages/server-utils/dist/cjs/middleware/auth.middleware.js +41 -0
  648. package/packages/server-utils/dist/cjs/middleware/cache.middleware.d.ts +2 -0
  649. package/packages/server-utils/dist/cjs/middleware/cache.middleware.js +58 -0
  650. package/packages/server-utils/dist/cjs/middleware/errorHandler.middleware.d.ts +2 -0
  651. package/packages/server-utils/dist/cjs/middleware/errorHandler.middleware.js +30 -0
  652. package/packages/server-utils/dist/cjs/middleware/index.d.ts +10 -0
  653. package/packages/server-utils/dist/cjs/middleware/index.js +40 -0
  654. package/packages/server-utils/dist/cjs/middleware/logging.middleware.d.ts +2 -0
  655. package/packages/server-utils/dist/cjs/middleware/logging.middleware.js +19 -0
  656. package/packages/server-utils/dist/cjs/middleware/plugins.middleware.d.ts +14 -0
  657. package/packages/server-utils/dist/cjs/middleware/plugins.middleware.js +58 -0
  658. package/packages/server-utils/dist/cjs/middleware/rateLimiter.middleware.d.ts +8 -0
  659. package/packages/server-utils/dist/cjs/middleware/rateLimiter.middleware.js +35 -0
  660. package/packages/server-utils/dist/cjs/middleware/requestId.middleware.d.ts +2 -0
  661. package/packages/server-utils/dist/cjs/middleware/requestId.middleware.js +12 -0
  662. package/packages/server-utils/dist/cjs/middleware/session.middleware.d.ts +2 -0
  663. package/packages/server-utils/dist/cjs/middleware/session.middleware.js +53 -0
  664. package/packages/server-utils/dist/cjs/middleware/validation.middleware.d.ts +11 -0
  665. package/packages/server-utils/dist/cjs/middleware/validation.middleware.js +67 -0
  666. package/packages/server-utils/dist/cjs/types/index.d.ts +87 -0
  667. package/packages/server-utils/dist/cjs/types/index.js +2 -0
  668. package/packages/server-utils/dist/cjs/utils/utils.d.ts +3 -0
  669. package/packages/server-utils/dist/cjs/utils/utils.js +43 -0
  670. package/packages/server-utils/dist/esm/core/health.d.ts +5 -0
  671. package/packages/server-utils/dist/esm/core/health.js +40 -0
  672. package/packages/server-utils/dist/esm/core/periodic-health.d.ts +11 -0
  673. package/packages/server-utils/dist/esm/core/periodic-health.js +64 -0
  674. package/packages/server-utils/dist/esm/core/server.d.ts +73 -0
  675. package/packages/server-utils/dist/esm/core/server.js +396 -0
  676. package/packages/server-utils/dist/esm/core/shutdown.d.ts +5 -0
  677. package/packages/server-utils/dist/esm/core/shutdown.js +53 -0
  678. package/packages/server-utils/dist/esm/index.d.ts +46 -0
  679. package/packages/server-utils/dist/esm/index.js +58 -0
  680. package/packages/server-utils/dist/esm/middleware/auth.middleware.d.ts +7 -0
  681. package/packages/server-utils/dist/esm/middleware/auth.middleware.js +38 -0
  682. package/packages/server-utils/dist/esm/middleware/cache.middleware.d.ts +2 -0
  683. package/packages/server-utils/dist/esm/middleware/cache.middleware.js +55 -0
  684. package/packages/server-utils/dist/esm/middleware/errorHandler.middleware.d.ts +2 -0
  685. package/packages/server-utils/dist/esm/middleware/errorHandler.middleware.js +27 -0
  686. package/packages/server-utils/dist/esm/middleware/index.d.ts +10 -0
  687. package/packages/server-utils/dist/esm/middleware/index.js +20 -0
  688. package/packages/server-utils/dist/esm/middleware/logging.middleware.d.ts +2 -0
  689. package/packages/server-utils/dist/esm/middleware/logging.middleware.js +16 -0
  690. package/packages/server-utils/dist/esm/middleware/plugins.middleware.d.ts +14 -0
  691. package/packages/server-utils/dist/esm/middleware/plugins.middleware.js +47 -0
  692. package/packages/server-utils/dist/esm/middleware/rateLimiter.middleware.d.ts +8 -0
  693. package/packages/server-utils/dist/esm/middleware/rateLimiter.middleware.js +32 -0
  694. package/packages/server-utils/dist/esm/middleware/requestId.middleware.d.ts +2 -0
  695. package/packages/server-utils/dist/esm/middleware/requestId.middleware.js +9 -0
  696. package/packages/server-utils/dist/esm/middleware/session.middleware.d.ts +2 -0
  697. package/packages/server-utils/dist/esm/middleware/session.middleware.js +50 -0
  698. package/packages/server-utils/dist/esm/middleware/validation.middleware.d.ts +11 -0
  699. package/packages/server-utils/dist/esm/middleware/validation.middleware.js +64 -0
  700. package/packages/server-utils/dist/esm/types/index.d.ts +87 -0
  701. package/packages/server-utils/dist/esm/types/index.js +1 -0
  702. package/packages/server-utils/dist/esm/utils/utils.d.ts +3 -0
  703. package/packages/server-utils/dist/esm/utils/utils.js +38 -0
  704. package/packages/server-utils/dist/types/core/health.d.ts +5 -0
  705. package/packages/server-utils/dist/types/core/periodic-health.d.ts +11 -0
  706. package/packages/server-utils/dist/types/core/server.d.ts +73 -0
  707. package/packages/server-utils/dist/types/core/shutdown.d.ts +5 -0
  708. package/packages/server-utils/dist/types/index.d.ts +46 -0
  709. package/packages/server-utils/dist/types/middleware/auth.middleware.d.ts +7 -0
  710. package/packages/server-utils/dist/types/middleware/cache.middleware.d.ts +2 -0
  711. package/packages/server-utils/dist/types/middleware/errorHandler.middleware.d.ts +2 -0
  712. package/packages/server-utils/dist/types/middleware/index.d.ts +10 -0
  713. package/packages/server-utils/dist/types/middleware/logging.middleware.d.ts +2 -0
  714. package/packages/server-utils/dist/types/middleware/plugins.middleware.d.ts +14 -0
  715. package/packages/server-utils/dist/types/middleware/rateLimiter.middleware.d.ts +8 -0
  716. package/packages/server-utils/dist/types/middleware/requestId.middleware.d.ts +2 -0
  717. package/packages/server-utils/dist/types/middleware/session.middleware.d.ts +2 -0
  718. package/packages/server-utils/dist/types/middleware/validation.middleware.d.ts +11 -0
  719. package/packages/server-utils/dist/types/types/index.d.ts +87 -0
  720. package/packages/server-utils/dist/types/utils/utils.d.ts +3 -0
  721. package/packages/server-utils/node_modules/.bin/rimraf +21 -0
  722. package/packages/server-utils/node_modules/.bin/tsc +21 -0
  723. package/packages/server-utils/node_modules/.bin/tsserver +21 -0
  724. package/packages/server-utils/package.json +30 -6
  725. package/packages/server-utils/src/core/health.ts +58 -0
  726. package/packages/server-utils/src/core/periodic-health.ts +88 -0
  727. package/packages/server-utils/src/core/server.ts +650 -0
  728. package/packages/server-utils/src/core/shutdown.ts +78 -0
  729. package/packages/server-utils/src/express-augment.d.ts +35 -0
  730. package/packages/server-utils/src/index.ts +132 -95
  731. package/packages/server-utils/src/middleware/auth.middleware.ts +66 -0
  732. package/packages/server-utils/src/middleware/cache.middleware.ts +68 -0
  733. package/packages/server-utils/src/middleware/errorHandler.middleware.ts +44 -0
  734. package/packages/server-utils/src/middleware/index.ts +46 -0
  735. package/packages/server-utils/src/middleware/logging.middleware.ts +29 -0
  736. package/packages/server-utils/src/middleware/plugins.middleware.ts +64 -0
  737. package/packages/server-utils/src/middleware/rateLimiter.middleware.ts +59 -0
  738. package/packages/server-utils/src/middleware/requestId.middleware.ts +16 -0
  739. package/packages/server-utils/src/middleware/session.middleware.ts +66 -0
  740. package/packages/server-utils/src/middleware/validation.middleware.ts +101 -0
  741. package/packages/server-utils/src/types/index.ts +114 -0
  742. package/packages/server-utils/src/utils/utils.ts +43 -0
  743. package/packages/server-utils/tsconfig.base.json +17 -0
  744. package/packages/server-utils/tsconfig.cjs.json +9 -0
  745. package/packages/server-utils/tsconfig.esm.json +9 -0
  746. package/packages/server-utils/src/health.ts +0 -47
  747. package/packages/server-utils/src/middleware.ts +0 -275
  748. package/packages/server-utils/src/server.ts +0 -320
  749. package/packages/server-utils/src/shutdown.ts +0 -60
  750. package/packages/server-utils/src/types.ts +0 -64
  751. package/packages/server-utils/src/utils.ts +0 -34
  752. /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.4.3 (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;