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
@@ -0,0 +1,695 @@
1
+ # @naman_deep_singh/cache
2
+
3
+ **Version:** 1.3.2 (with Redis Clustering support)
4
+
5
+ A flexible, extensible caching layer with support for Redis, Memcache, and in-memory caches. Includes session management, health checks, and Express middleware.
6
+
7
+ ## Features
8
+
9
+ - 🚀 **Multiple Adapters**: Redis, Memcache, and in-memory cache support
10
+ - 🔄 **Automatic Fallback**: Gracefully fall back to in-memory cache if primary adapter fails
11
+ - 📦 **Namespacing**: Organize cache keys with optional prefixes to prevent collisions
12
+ - 🎯 **Generic Types**: Full TypeScript support with generics for type-safe caching
13
+ - 📊 **Statistics**: Track cache hits, misses, sets, and deletes
14
+ - 💾 **Session Management**: Built-in SessionStore wrapper for session handling
15
+ - 🌐 **Express Middleware**: Pre-built middleware for session management and response caching
16
+ - ⚡ **Async/Await**: Modern async API throughout
17
+ - 🔌 **Production Ready**: Error handling, health checks, and connection management
18
+
19
+ ## Installation
20
+
21
+ ```bash
22
+ npm install @naman_deep_singh/cache redis memcached
23
+ ```
24
+
25
+ ### Peer Dependencies
26
+
27
+ - `redis` (for Redis adapter)
28
+ - `memcached` (for Memcache adapter)
29
+
30
+ Both are optional if you're only using the memory adapter.
31
+
32
+ ## Quick Start
33
+
34
+ ### Using the Factory
35
+
36
+ ```typescript
37
+ import { CacheFactory, SessionStore } from '@naman_deep_singh/cache';
38
+
39
+ // Create a Redis cache
40
+ const cache = CacheFactory.create({
41
+ adapter: 'redis',
42
+ host: 'localhost',
43
+ port: 6379,
44
+ namespace: 'myapp',
45
+ ttl: 3600
46
+ });
47
+
48
+ // Or with fallback support
49
+ const cacheWithFallback = await CacheFactory.createWithFallback({
50
+ adapter: 'redis',
51
+ host: 'localhost',
52
+ port: 6379,
53
+ fallback: true // Falls back to memory cache if Redis fails
54
+ });
55
+ ```
56
+
57
+ ### Basic Cache Operations
58
+
59
+ All adapters (Redis, Memcache, Memory) implement the same `ICache<T>` interface and work identically:
60
+
61
+ ```typescript
62
+ // Set a value (with TTL in seconds)
63
+ await cache.set('user:123', { id: 123, name: 'John' }, 3600); // 1 hour
64
+
65
+ // Get a value
66
+ const user = await cache.get('user:123');
67
+ console.log(user); // { id: 123, name: 'John' } or null if not found
68
+
69
+ // Check existence
70
+ const exists = await cache.exists('user:123'); // true or false
71
+
72
+ // Delete a value
73
+ const deleted = await cache.delete('user:123'); // true if existed, false otherwise
74
+
75
+ // Clear all cache (respects namespace)
76
+ await cache.clear();
77
+
78
+ // Increment/Decrement (for numeric values)
79
+ await cache.set('visits', 0);
80
+ const visits = await cache.increment('visits'); // 1
81
+ const decremented = await cache.decrement('visits'); // 0
82
+ await cache.increment('visits', 5); // increment by 5 -> 5
83
+ await cache.decrement('counter', 2); // decrement by 2
84
+
85
+ // Batch get operations
86
+ const users = await cache.getMultiple(['user:1', 'user:2', 'user:3']);
87
+ // Returns: { 'user:1': userData1, 'user:2': null, 'user:3': userData3 }
88
+
89
+ // Batch set operations
90
+ await cache.setMultiple({
91
+ 'user:1': user1,
92
+ 'user:2': user2,
93
+ 'user:3': user3
94
+ }, 3600); // All with same TTL
95
+
96
+ // Batch delete operations
97
+ const deletedCount = await cache.deleteMultiple(['user:1', 'user:2', 'user:3']);
98
+ console.log(`Deleted ${deletedCount} keys`);
99
+
100
+ // Get cache statistics
101
+ const stats = await cache.getStats();
102
+ console.log(`Cache hits: ${stats.hits}`);
103
+ console.log(`Cache misses: ${stats.misses}`);
104
+ console.log(`Total sets: ${stats.sets}`);
105
+ console.log(`Total deletes: ${stats.deletes}`);
106
+
107
+ // Health check (verify connection)
108
+ const health = await cache.isAlive();
109
+ console.log(`Cache status:`, health);
110
+ // { isAlive: true, adapter: 'redis', timestamp: Date, error?: undefined }
111
+
112
+ // Close connection (cleanup)
113
+ await cache.close();
114
+ ```
115
+
116
+ ## Session Management
117
+
118
+ SessionStore provides a convenient wrapper around any cache adapter for session handling.
119
+
120
+ ```typescript
121
+ import { CacheFactory, SessionStore } from '@naman_deep_singh/cache';
122
+
123
+ // Create cache (any adapter works the same way)
124
+ const cache = CacheFactory.create({
125
+ adapter: 'redis', // or 'memcache' or 'memory'
126
+ host: 'localhost',
127
+ port: 6379,
128
+ namespace: 'sessions'
129
+ });
130
+
131
+ // Initialize session store
132
+ const sessionStore = new SessionStore(cache, {
133
+ ttl: 86400, // 24 hours default
134
+ serialize: (data) => JSON.stringify(data),
135
+ deserialize: (data) => JSON.parse(data)
136
+ });
137
+
138
+ // Create a new session
139
+ await sessionStore.create('session:abc123', {
140
+ userId: 123,
141
+ username: 'john',
142
+ roles: ['admin'],
143
+ permissions: ['read', 'write']
144
+ });
145
+
146
+ // Retrieve session data
147
+ const session = await sessionStore.get('session:abc123');
148
+ console.log(session); // { userId: 123, username: 'john', ... }
149
+
150
+ // Check if session exists
151
+ const sessionExists = await sessionStore.exists('session:abc123'); // true
152
+
153
+ // Update/merge session data
154
+ await sessionStore.update('session:abc123', {
155
+ lastActivity: new Date(),
156
+ permissions: ['read', 'write', 'delete']
157
+ });
158
+
159
+ // Extend session expiry (keep user logged in)
160
+ await sessionStore.extend('session:abc123', 86400); // 24 more hours
161
+
162
+ // Get session and extend in one operation (useful for every request)
163
+ const sessionData = await sessionStore.getAndExtend('session:abc123');
164
+
165
+ // Get multiple sessions
166
+ const sessions = await sessionStore.getMultiple([
167
+ 'session:user1',
168
+ 'session:user2',
169
+ 'session:user3'
170
+ ]);
171
+
172
+ // Delete a single session (logout)
173
+ const deleted = await sessionStore.delete('session:abc123'); // true if existed
174
+
175
+ // Delete multiple sessions
176
+ const deletedCount = await sessionStore.deleteMultiple([
177
+ 'session:user1',
178
+ 'session:user2'
179
+ ]);
180
+
181
+ // Clear all sessions (e.g., on server maintenance)
182
+ await sessionStore.clear();
183
+ ```
184
+
185
+ ## Adapters
186
+
187
+ All adapters implement the same `ICache<T>` interface and can be used interchangeably. Switching between adapters requires only changing the configuration!
188
+
189
+ ### Redis Cache
190
+
191
+ ```typescript
192
+ import { RedisCache } from '@naman_deep_singh/cache';
193
+
194
+ const cache = new RedisCache({
195
+ adapter: 'redis',
196
+ host: 'localhost',
197
+ port: 6379,
198
+ username: 'default', // Optional, for auth
199
+ password: 'your_password', // Optional
200
+ db: 0, // Optional, database number (0-15)
201
+ tls: false, // Optional, enable TLS/SSL
202
+ namespace: 'myapp', // Optional, key prefix
203
+ ttl: 3600 // Default TTL in seconds
204
+ });
205
+
206
+ // All ICache methods available
207
+ await cache.set('key', value);
208
+ await cache.get('key');
209
+ await cache.delete('key');
210
+ // ... and all other methods
211
+ ```
212
+
213
+ ### Redis Cluster Support
214
+
215
+ ```typescript
216
+ import { CacheFactory } from '@naman_deep_singh/cache';
217
+
218
+ // Single cluster configuration with array notation
219
+ const clusterCache = CacheFactory.create({
220
+ adapter: 'redis',
221
+ cluster: [
222
+ { host: 'redis-node-1.example.com', port: 6379 },
223
+ { host: 'redis-node-2.example.com', port: 6379 },
224
+ { host: 'redis-node-3.example.com', port: 6379 }
225
+ ],
226
+ namespace: 'myapp',
227
+ ttl: 3600
228
+ });
229
+
230
+ // Or with detailed cluster config
231
+ const clusterCacheAlt = CacheFactory.create({
232
+ adapter: 'redis',
233
+ cluster: {
234
+ nodes: [
235
+ { host: 'redis-node-1.example.com', port: 6379 },
236
+ { host: 'redis-node-2.example.com', port: 6379 }
237
+ ],
238
+ options: {
239
+ enableReadyCheck: true,
240
+ maxRedirections: 3,
241
+ retryDelayOnFailover: 100,
242
+ retryDelayOnClusterDown: 300
243
+ }
244
+ }
245
+ });
246
+
247
+ // Use exactly like single instance - same ICache interface
248
+ await clusterCache.set('key', value);
249
+ const data = await clusterCache.get('key');
250
+ await clusterCache.delete('key');
251
+
252
+ // Cluster automatically handles key distribution across nodes
253
+ // No changes needed to your application logic
254
+ ```
255
+
256
+ **Note:** Cannot mix single-instance (`host`/`port`) and cluster (`cluster`) config. Choose one or the other.
257
+
258
+ ### Memcache Adapter
259
+
260
+ ```typescript
261
+ import { MemcacheCache } from '@naman_deep_singh/cache';
262
+
263
+ const cache = new MemcacheCache({
264
+ adapter: 'memcache',
265
+ servers: 'localhost:11211', // Single server as string
266
+ // OR
267
+ // servers: ['localhost:11211', 'localhost:11212'], // Multiple servers
268
+ username: 'user', // Optional
269
+ password: 'pass', // Optional
270
+ namespace: 'myapp', // Optional, key prefix
271
+ ttl: 3600 // Default TTL in seconds
272
+ });
273
+
274
+ // Same ICache interface as Redis
275
+ await cache.set('key', value);
276
+ await cache.get('key');
277
+ await cache.delete('key');
278
+ // ... and all other methods
279
+ ```
280
+
281
+ ### Memory Cache (For Development/Testing)
282
+
283
+ ```typescript
284
+ import { MemoryCache } from '@naman_deep_singh/cache';
285
+
286
+ const cache = new MemoryCache({
287
+ adapter: 'memory',
288
+ namespace: 'myapp', // Optional, key prefix
289
+ ttl: 3600, // Default TTL in seconds
290
+ maxSize: 1000 // Optional, max items (oldest removed when exceeded)
291
+ });
292
+
293
+ // Same ICache interface - perfect for testing without external dependencies
294
+ await cache.set('key', value);
295
+ await cache.get('key');
296
+ await cache.delete('key');
297
+ // ... and all other methods
298
+
299
+ // Note: Memory cache automatically cleans up expired items every 30 seconds
300
+ ```
301
+
302
+ ### Using Adapters Interchangeably
303
+
304
+ ```typescript
305
+ // Development: use memory cache
306
+ let cache: ICache;
307
+ if (process.env.NODE_ENV === 'development') {
308
+ cache = new MemoryCache({ adapter: 'memory' });
309
+ } else if (process.env.REDIS_URL) {
310
+ cache = new RedisCache({ adapter: 'redis', host: 'localhost' });
311
+ } else {
312
+ cache = new MemcacheCache({ adapter: 'memcache', servers: 'localhost:11211' });
313
+ }
314
+
315
+ // All subsequent code works the same regardless of adapter
316
+ await cache.set('user:1', userData);
317
+ const user = await cache.get('user:1');
318
+ const health = await cache.isAlive();
319
+ ```
320
+
321
+ ## Express Middleware
322
+
323
+ ### Session Management Middleware
324
+
325
+ ```typescript
326
+ import express from 'express';
327
+ import cookieParser from 'cookie-parser';
328
+ import { CacheFactory, SessionStore, cacheSessionMiddleware } from '@naman_deep_singh/cache';
329
+
330
+ const app = express();
331
+ app.use(cookieParser());
332
+
333
+ const cache = CacheFactory.create({
334
+ adapter: 'redis',
335
+ host: 'localhost',
336
+ port: 6379,
337
+ namespace: 'sessions'
338
+ });
339
+
340
+ const sessionStore = new SessionStore(cache);
341
+
342
+ app.use(
343
+ cacheSessionMiddleware(sessionStore, {
344
+ sessionIdHeader: 'x-session-id', // Or use cookie
345
+ sessionDataKey: 'session' // req.session
346
+ })
347
+ );
348
+
349
+ app.get('/profile', (req, res) => {
350
+ const session = (req as any).session;
351
+ if (!session) {
352
+ return res.status(401).json({ error: 'No session' });
353
+ }
354
+ res.json({ user: session });
355
+ });
356
+ ```
357
+
358
+ ### Cache Health Check Middleware
359
+
360
+ Expose cache health status at a dedicated endpoint:
361
+
362
+ ```typescript
363
+ import { CacheFactory, cacheHealthCheckMiddleware } from '@naman_deep_singh/cache';
364
+
365
+ const cache = CacheFactory.create({
366
+ adapter: 'redis',
367
+ host: 'localhost'
368
+ });
369
+
370
+ // Add middleware
371
+ app.use(cacheHealthCheckMiddleware(cache, '/.health/cache'));
372
+
373
+ // Usage:
374
+ // GET /.health/cache
375
+ // Response:
376
+ // {
377
+ // "isAlive": true,
378
+ // "adapter": "redis",
379
+ // "timestamp": "2024-01-01T12:00:00.000Z"
380
+ // }
381
+ ```
382
+
383
+ ### Response Caching Middleware
384
+
385
+ Automatically cache HTTP responses for GET requests:
386
+
387
+ ```typescript
388
+ import { CacheFactory, cacheResponseMiddleware } from '@naman_deep_singh/cache';
389
+
390
+ const cache = CacheFactory.create({
391
+ adapter: 'redis',
392
+ host: 'localhost'
393
+ });
394
+
395
+ // Add middleware
396
+ app.use(
397
+ cacheResponseMiddleware(cache, {
398
+ ttl: 300, // Cache for 5 minutes
399
+ keyPrefix: 'response:', // All keys start with this
400
+ excludeStatusCodes: [404, 500, 502, 503] // Don't cache errors
401
+ })
402
+ );
403
+
404
+ // Usage in routes
405
+ app.get('/api/users', (req, res) => {
406
+ // First request: fetches from database, caches response
407
+ // Subsequent requests: returns from cache
408
+ res.json({ users: [...] });
409
+ // Response headers will include X-Cache: HIT or MISS
410
+ });
411
+
412
+ app.get('/api/data', async (req, res) => {
413
+ // Expensive operation
414
+ const data = await expensiveQuery();
415
+ res.json(data);
416
+ // X-Cache: MISS (first time)
417
+ // X-Cache: HIT (subsequent requests within 5 minutes)
418
+ });
419
+
420
+ // Client can check cache status
421
+ app.get('/api/stats', (req, res) => {
422
+ // Not cached (responses with statusCode >= 300)
423
+ res.status(201).json({ created: true });
424
+ // X-Cache: MISS
425
+ });
426
+ ```
427
+
428
+ ## Error Handling
429
+
430
+ ```typescript
431
+ import { CacheError } from '@naman_deep_singh/cache';
432
+
433
+ try {
434
+ await cache.get('key');
435
+ } catch (err) {
436
+ if (err instanceof CacheError) {
437
+ console.log(`Error: ${err.message}`);
438
+ console.log(`Code: ${err.code}`);
439
+ console.log(`Adapter: ${err.adapter}`);
440
+ console.log(`Original error:`, err.originalError);
441
+ }
442
+ }
443
+
444
+ // Error codes:
445
+ // - CACHE_ERROR: Generic cache error
446
+ // - REDIS_CONNECTION_ERROR: Failed to connect to Redis
447
+ // - REDIS_GET_ERROR, REDIS_SET_ERROR, etc.
448
+ // - MEMCACHE_CONNECTION_ERROR: Failed to connect to Memcache
449
+ // - MEMCACHE_GET_ERROR, MEMCACHE_SET_ERROR, etc.
450
+ // - MEMORY_GET_ERROR, MEMORY_SET_ERROR, etc.
451
+ // - SESSION_NOT_FOUND: Session doesn't exist
452
+ // - SESSION_CREATE_ERROR, SESSION_UPDATE_ERROR, etc.
453
+ ```
454
+
455
+ ## Complete API Reference
456
+
457
+ ### ICache<T> Interface
458
+
459
+ Every adapter implements this interface:
460
+
461
+ ```typescript
462
+ interface ICache<T = unknown> {
463
+ // Single item operations
464
+ get(key: string): Promise<T | null>;
465
+ set(key: string, value: T, ttl?: number): Promise<void>;
466
+ delete(key: string): Promise<boolean>;
467
+ exists(key: string): Promise<boolean>;
468
+
469
+ // Batch operations
470
+ getMultiple(keys: string[]): Promise<Record<string, T | null>>;
471
+ setMultiple(data: Record<string, T>, ttl?: number): Promise<void>;
472
+ deleteMultiple(keys: string[]): Promise<number>;
473
+
474
+ // Numeric operations
475
+ increment(key: string, amount?: number): Promise<number>;
476
+ decrement(key: string, amount?: number): Promise<number>;
477
+
478
+ // Utility operations
479
+ clear(): Promise<void>;
480
+ getStats?(): Promise<CacheStats>;
481
+ isAlive(): Promise<HealthCheckResponse>;
482
+ close(): Promise<void>;
483
+ }
484
+ ```
485
+
486
+ ### CacheFactory
487
+
488
+ ```typescript
489
+ // Create a cache instance
490
+ const cache = CacheFactory.create({
491
+ adapter: 'redis' | 'memcache' | 'memory',
492
+ // ... adapter-specific config
493
+ });
494
+
495
+ // Create with automatic fallback to memory cache
496
+ const cacheWithFallback = await CacheFactory.createWithFallback({
497
+ adapter: 'redis',
498
+ // ... config
499
+ fallback: true // Falls back to memory if primary fails
500
+ });
501
+ ```
502
+
503
+ ### SessionStore
504
+
505
+ ```typescript
506
+ const sessionStore = new SessionStore(cache, {
507
+ ttl: 3600,
508
+ serialize: (data) => JSON.stringify(data),
509
+ deserialize: (data) => JSON.parse(data)
510
+ });
511
+
512
+ // Methods
513
+ await sessionStore.create(sessionId, data, ttl?);
514
+ await sessionStore.get(sessionId);
515
+ await sessionStore.update(sessionId, partialData);
516
+ await sessionStore.delete(sessionId);
517
+ await sessionStore.exists(sessionId);
518
+ await sessionStore.extend(sessionId, ttl?);
519
+ await sessionStore.getAndExtend(sessionId, ttl?);
520
+ await sessionStore.getMultiple(sessionIds);
521
+ await sessionStore.deleteMultiple(sessionIds);
522
+ await sessionStore.clear();
523
+ ```
524
+
525
+ ## Configuration Examples
526
+
527
+ ### Development
528
+
529
+ ```typescript
530
+ const cache = CacheFactory.create({
531
+ adapter: 'memory',
532
+ namespace: 'dev',
533
+ ttl: 600
534
+ });
535
+ ```
536
+
537
+ ### Production with Fallback
538
+
539
+ ```typescript
540
+ const cache = await CacheFactory.createWithFallback({
541
+ adapter: 'redis',
542
+ host: process.env.REDIS_HOST,
543
+ port: parseInt(process.env.REDIS_PORT),
544
+ password: process.env.REDIS_PASSWORD,
545
+ db: 0,
546
+ namespace: 'prod',
547
+ ttl: 3600,
548
+ fallback: true
549
+ });
550
+ ```
551
+
552
+ ### Multi-Tenant with Namespacing
553
+
554
+ ```typescript
555
+ const getTenantCache = (tenantId: string) => {
556
+ return CacheFactory.create({
557
+ adapter: 'redis',
558
+ host: 'localhost',
559
+ namespace: `tenant:${tenantId}`,
560
+ ttl: 3600
561
+ });
562
+ };
563
+
564
+ const tenant1Cache = getTenantCache('tenant-1');
565
+ const tenant2Cache = getTenantCache('tenant-2');
566
+
567
+ // Keys are isolated: tenant-1:key vs tenant-2:key
568
+ ```
569
+
570
+ ## Connecting and Disconnecting
571
+
572
+ ### Redis
573
+
574
+ ```typescript
575
+ const cache = new RedisCache({
576
+ adapter: 'redis',
577
+ host: 'localhost'
578
+ });
579
+
580
+ // Automatically connects on first use or explicitly:
581
+ // await (cache as any).connect();
582
+
583
+ // Close when done
584
+ await cache.close();
585
+ ```
586
+
587
+ ### Memcache
588
+
589
+ ```typescript
590
+ const cache = new MemcacheCache({
591
+ adapter: 'memcache',
592
+ servers: ['localhost:11211']
593
+ });
594
+
595
+ // Automatically connects
596
+ // Close when done
597
+ await cache.close();
598
+ ```
599
+
600
+ ## Adapter Comparison
601
+
602
+ All adapters implement the same `ICache<T>` interface and work identically. Choose based on your needs:
603
+
604
+ | Feature | Redis | Memcache | Memory |
605
+ |---------|-------|----------|--------|
606
+ | **Type** | External service | External service | In-process |
607
+ | **Setup** | Requires Redis server | Requires Memcache server | No setup needed |
608
+ | **Persistence** | Optional (configurable) | No persistence | Lost on restart |
609
+ | **Scalability** | Excellent (supports millions) | Good (scalable across servers) | Limited to RAM |
610
+ | **Best For** | Production (distributed systems) | High-traffic scenarios | Development & testing |
611
+ | **Cost** | Free (open source) | Free (open source) | Free |
612
+ | **Performance** | Fast | Very Fast | Fastest (in-memory) |
613
+ | **Cluster Support** | Yes (v1.2+) | Yes | N/A |
614
+ | **Authentication** | Username/Password/TLS | Optional | N/A |
615
+
616
+ ### When to Use Each
617
+
618
+ ```typescript
619
+ // Development: quick setup, no dependencies
620
+ const devCache = CacheFactory.create({ adapter: 'memory' });
621
+
622
+ // Testing: mock external services
623
+ const testCache = CacheFactory.create({ adapter: 'memory' });
624
+
625
+ // Production single instance: single server, high performance
626
+ const prodCache = CacheFactory.create({
627
+ adapter: 'redis',
628
+ host: process.env.REDIS_HOST,
629
+ port: process.env.REDIS_PORT ? parseInt(process.env.REDIS_PORT) : 6379,
630
+ password: process.env.REDIS_PASSWORD
631
+ });
632
+
633
+ // Production cluster: distributed Redis cluster
634
+ const clusterCache = CacheFactory.create({
635
+ adapter: 'redis',
636
+ cluster: [
637
+ { host: 'redis-node-1', port: 6379 },
638
+ { host: 'redis-node-2', port: 6379 },
639
+ { host: 'redis-node-3', port: 6379 }
640
+ ]
641
+ });
642
+
643
+ // High-traffic with Memcache multi-server
644
+ const memcacheCache = CacheFactory.create({
645
+ adapter: 'memcache',
646
+ servers: ['memcache1:11211', 'memcache2:11211']
647
+ });
648
+ ```
649
+
650
+ ## Best Practices
651
+
652
+ 1. **Use Namespacing**: Always use namespaces in multi-tenant or complex applications to prevent key collisions.
653
+
654
+ 2. **Set Appropriate TTLs**: Balance cache size and data freshness.
655
+
656
+ 3. **Handle Cache Failures**: Use try-catch or fallback options to handle cache adapter failures gracefully.
657
+
658
+ 4. **Monitor Cache Health**: Use `isAlive()` in health check endpoints.
659
+
660
+ 5. **Clean Up Resources**: Always call `close()` when shutting down.
661
+
662
+ 6. **Use Batch Operations**: For multiple operations, prefer `getMultiple` and `setMultiple` over loops.
663
+
664
+ 7. **Session Security**: Use secure headers/cookies for session IDs in production.
665
+
666
+ 8. **Error Logging**: Log `CacheError` instances with their codes for debugging.
667
+
668
+ ## Types
669
+
670
+ See [types.ts](./src/types.ts) for detailed type definitions:
671
+
672
+ - `CacheConfig` - Cache configuration
673
+ - `RedisCacheConfig` - Redis-specific config
674
+ - `MemcacheCacheConfig` - Memcache-specific config
675
+ - `MemoryCacheConfig` - Memory cache config
676
+ - `SessionData` - Session data structure
677
+ - `SessionOptions` - Session store options
678
+ - `CacheStats` - Cache statistics
679
+ - `HealthCheckResponse` - Health check response
680
+ - `ICache<T>` - Cache interface
681
+ - `ISession` - Session interface
682
+
683
+ ## License
684
+
685
+ ISC
686
+
687
+ ## Author
688
+
689
+ Naman Deep Singh
690
+
691
+ ## TypeScript Notes
692
+
693
+ - The package provides strong generics for `ICache<T>` and `SessionStore` so you can store typed values safely.
694
+ - Middleware in this package may attach runtime properties (for example session data) to `Request` objects in Express. If you're using TypeScript, import the package into your project so the included type augmentations are picked up automatically — no need to cast `req` to `any` in most cases.
695
+