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,116 +1,530 @@
1
1
  # @naman_deep_singh/security
2
2
 
3
- Security utilities for password hashing and JWT token management with TypeScript support.
3
+ **Version:** 1.3.3
4
4
 
5
- ## Installation
5
+ A complete, lightweight security toolkit for Node.js & TypeScript providing:
6
+
7
+ 🔐 **Password hashing & validation** with bcrypt (async/sync, peppered variants)
8
+ 🔑 **JWT signing & verification** (no deprecated expiresIn, with caching)
9
+ 🧮 **Duration parser** ("15m", "7d", etc.)
10
+ 🪪 **Token generator** (access + refresh pair with branded types)
11
+ ♻️ **Refresh token rotation** helper
12
+ 🧰 **Robust token extraction** (Headers, Cookies, Query, Body, WebSocket)
13
+ 🧩 **Safe & strict JWT decode** utilities
14
+ 🔒 **AES-256-GCM encryption/decryption** with HMAC and random utilities
15
+ 🚨 **Standardized error handling** with @naman_deep_singh/errors-utils
16
+
17
+ ✔ **Fully typed** with TypeScript
18
+ ✔ **Branded token types** for compile-time safety (AccessToken/RefreshToken)
19
+ ✔ **Class-based managers** for advanced features (PasswordManager, JWTManager, CryptoManager)
20
+ ✔ **Functional exports** for simple use cases
21
+ ✔ **Password strength checking** and validation
22
+ ✔ **Token caching** for performance
23
+ ✔ **Consistent errors** across your application ecosystem
24
+ ✔ **Works in both ESM and CommonJS**
6
25
 
7
26
  ```bash
27
+ 📦 Installation
8
28
  npm install @naman_deep_singh/security
9
29
  ```
10
30
 
11
- ## Features
31
+ 🔧 Features
32
+
33
+ 🔥 Password Hashing — secure & async (bcrypt with 10 salt rounds)
34
+ 🔥 Password Validation & Strength Checking
35
+ 🔥 Password Generation with configurable requirements
36
+ 🔥 Peppered hashing variants
37
+ 🔥 Synchronous & asynchronous versions
38
+
39
+ 🔥 Custom Expiry JWT — manual exp support using duration strings
40
+ 🔥 Token Pair Generation (accessToken + refreshToken)
41
+ 🔥 Refresh Token Rotation
42
+ 🔥 Safe & Unsafe JWT Verification
43
+ 🔥 Strict vs Flexible Decoding
44
+ 🔥 Universal Token Extraction (Headers, Cookies, Query, Body, WebSocket)
45
+ 🔥 Token caching for performance
46
+
47
+ 🔥 AES-256-GCM Encryption/Decryption
48
+ 🔥 HMAC signing and verification
49
+ 🔥 Cryptographically secure random generation
50
+
51
+ 🔥 Production-grade types and error handling
52
+
53
+ 📘 Quick Start
54
+
55
+ ### Functional Approach (Simple)
56
+ ```typescript
57
+ import {
58
+ hashPassword,
59
+ verifyPassword,
60
+ generateTokens,
61
+ verifyToken,
62
+ safeVerifyToken,
63
+ extractToken,
64
+ encrypt,
65
+ decrypt
66
+ } from "@naman_deep_singh/security";
67
+
68
+ // Password operations
69
+ const hashed = await hashPassword("mypassword");
70
+ const isValid = await verifyPassword("mypassword", hashed);
71
+
72
+ // JWT operations
73
+ const tokens = generateTokens(
74
+ { userId: 42 },
75
+ process.env.ACCESS_SECRET!,
76
+ process.env.REFRESH_SECRET!,
77
+ "15m",
78
+ "7d"
79
+ );
80
+
81
+ const result = safeVerifyToken(tokens.accessToken, process.env.ACCESS_SECRET!);
82
+
83
+ // Crypto operations
84
+ const encrypted = encrypt("sensitive data", "secret-key");
85
+ const decrypted = decrypt(encrypted, "secret-key");
86
+ ```
87
+
88
+ ### Class-Based Approach (Advanced)
89
+ ```typescript
90
+ import { PasswordManager, JWTManager, CryptoManager } from "@naman_deep_singh/security";
91
+
92
+ // Password Manager with validation
93
+ const passwordManager = new PasswordManager({
94
+ minLength: 12,
95
+ requireUppercase: true,
96
+ requireNumbers: true,
97
+ requireSpecialChars: true
98
+ });
99
+
100
+ const validation = passwordManager.validate("MySecurePass123!");
101
+ if (validation.isValid) {
102
+ const hashed = await passwordManager.hash("MySecurePass123!");
103
+ }
104
+
105
+ // JWT Manager with caching
106
+ const jwtManager = new JWTManager({
107
+ accessSecret: process.env.ACCESS_SECRET!,
108
+ refreshSecret: process.env.REFRESH_SECRET!,
109
+ accessExpiry: "15m",
110
+ refreshExpiry: "7d",
111
+ enableCaching: true
112
+ });
113
+
114
+ const tokens = await jwtManager.generateTokens({ userId: 42 });
115
+ const payload = await jwtManager.verifyAccessToken(tokens.accessToken);
116
+
117
+ // Crypto Manager
118
+ const cryptoManager = new CryptoManager("your-secret-key");
119
+ const encrypted = cryptoManager.encrypt("data");
120
+ const decrypted = cryptoManager.decrypt(encrypted);
121
+ ```
122
+
123
+ 📚 API Documentation
124
+
125
+ Below is a complete reference with full usage examples.
126
+
127
+ ## 🧂 1. Password Utilities
128
+
129
+ ### Functional Exports
130
+ ```typescript
131
+ // Async hashing
132
+ const hashed = await hashPassword("mypassword"); // Uses 10 salt rounds by default
133
+ const hashed = await hashPassword("mypassword", 12); // Custom salt rounds
134
+
135
+ // Sync hashing
136
+ const hashedSync = hashPasswordSync("mypassword");
137
+ const hashedSync = hashPasswordSync("mypassword", 12);
138
+
139
+ // Peppered variants
140
+ const hashedPeppered = await hashPasswordWithPepper("mypassword", "pepper");
141
+ const hashedPepperedSync = hashPasswordWithPepperSync("mypassword", "pepper");
12
142
 
13
- - ✅ **Password hashing** with bcrypt (salt rounds: 10)
14
- - **JWT token management** with configurable expiration
15
- - **TypeScript support** with full type safety
16
- - ✅ **Hybrid exports** - use named imports or namespace imports
17
- - ✅ **Backward compatibility** with legacy function names
18
- - ✅ **Async/await support** for all operations
143
+ // Verification
144
+ const isValid = await verifyPassword("mypassword", hashed);
145
+ const isValidSync = verifyPasswordSync("mypassword", hashed);
19
146
 
20
- ## Usage
147
+ // Peppered verification
148
+ const isValidPeppered = await verifyPasswordWithPepper("mypassword", "pepper", hashed);
149
+ const isValidPepperedSync = verifyPasswordWithPepperSync("mypassword", "pepper", hashed);
150
+ ```
21
151
 
22
- ### Named Imports (Tree-shakable)
152
+ ### PasswordManager Class
23
153
  ```typescript
24
- import { hashPassword, verifyPassword, generateToken, verifyToken } from '@naman_deep_singh/security';
154
+ const passwordManager = new PasswordManager({
155
+ saltRounds: 12,
156
+ minLength: 8,
157
+ maxLength: 128,
158
+ requireUppercase: true,
159
+ requireLowercase: true,
160
+ requireNumbers: true,
161
+ requireSpecialChars: false,
162
+ customRules: [
163
+ { test: (pwd) => !pwd.includes('password'), message: 'Cannot contain "password"' }
164
+ ]
165
+ });
166
+
167
+ // Hash with validation
168
+ const result = await passwordManager.hash("MySecurePass123!");
169
+ // Returns: { hash: "$2a$...", salt: "..." }
170
+
171
+ // Verify
172
+ const isValid = await passwordManager.verify("MySecurePass123!", result.hash, result.salt);
173
+
174
+ // Validate password
175
+ const validation = passwordManager.validate("MySecurePass123!");
176
+ /*
177
+ Returns: {
178
+ isValid: true,
179
+ errors: [],
180
+ strength: { score: 4, label: 'strong', feedback: [...], suggestions: [...] }
181
+ }
182
+ */
25
183
 
26
- // Password hashing
27
- const hashedPassword = await hashPassword('mypassword');
28
- const isValid = await verifyPassword('mypassword', hashedPassword);
184
+ // Generate secure password
185
+ const generatedPassword = passwordManager.generate(16, {
186
+ requireUppercase: true,
187
+ requireNumbers: true,
188
+ requireSpecialChars: true
189
+ });
29
190
 
30
- // JWT tokens
31
- const token = generateToken({ userId: 1, role: 'admin' }, 'your-secret-key', '24h');
32
- const decoded = verifyToken(token, 'your-secret-key');
191
+ // Check strength
192
+ const strength = passwordManager.checkStrength("MySecurePass123!");
193
+ /*
194
+ Returns: {
195
+ score: 4,
196
+ label: 'strong',
197
+ feedback: [],
198
+ suggestions: ["Your password is very secure"]
199
+ }
200
+ */
33
201
  ```
34
202
 
35
- ### Namespace Import
203
+ ## 🔑 2. JWT Utilities
204
+
205
+ ### Functional Exports
36
206
  ```typescript
37
- import SecurityUtils from '@naman_deep_singh/security';
207
+ // Sign token with duration string
208
+ const token = signToken(
209
+ { userId: 1, role: "admin" },
210
+ process.env.JWT_SECRET!,
211
+ "1h" // Duration string: "15m", "2h", "7d", "30s"
212
+ );
213
+
214
+ // Parse duration to seconds
215
+ parseDuration("15m"); // 900
216
+ parseDuration("2h"); // 7200
217
+ parseDuration("7d"); // 604800
218
+
219
+ // Generate token pair
220
+ const tokens = generateTokens(
221
+ { userId: 42 },
222
+ process.env.ACCESS_SECRET!,
223
+ process.env.REFRESH_SECRET!,
224
+ "15m",
225
+ "7d"
226
+ );
227
+ // Returns: { accessToken: AccessToken, refreshToken: RefreshToken }
228
+
229
+ // Rotate refresh token
230
+ const newRefreshToken = rotateRefreshToken(
231
+ oldRefreshToken,
232
+ process.env.REFRESH_SECRET!
233
+ );
234
+
235
+ // Verify token (throws on error)
236
+ const payload = verifyToken(token, process.env.ACCESS_SECRET!);
237
+
238
+ // Safe verify (never throws)
239
+ const result = safeVerifyToken(token, process.env.ACCESS_SECRET!);
240
+ /*
241
+ Returns: {
242
+ valid: true,
243
+ payload: { userId: 1, ... },
244
+ error?: undefined
245
+ }
246
+ */
247
+
248
+ // Decode without verification
249
+ const decoded = decodeToken(token); // Flexible: null | string | JwtPayload
250
+ const payload = decodeTokenStrict(token); // Throws if not object
38
251
 
39
- const hashedPassword = await SecurityUtils.hashPassword('mypassword');
40
- const token = SecurityUtils.generateToken({ userId: 1 }, 'secret');
252
+ // Extract token from various sources
253
+ const token = extractToken({
254
+ header: req.headers.authorization, // "Bearer <token>"
255
+ cookies: req.cookies, // { token: "...", accessToken: "..." }
256
+ query: req.query, // { token: "..." }
257
+ body: req.body, // { token: "..." }
258
+ wsMessage: message // string or { token: "..." }
259
+ });
41
260
  ```
42
261
 
43
- ### Backward Compatibility
262
+ ### JWTManager Class
44
263
  ```typescript
45
- import { comparePassword, signToken } from '@naman_deep_singh/security';
264
+ const jwtManager = new JWTManager({
265
+ accessSecret: process.env.ACCESS_SECRET!,
266
+ refreshSecret: process.env.REFRESH_SECRET!,
267
+ accessExpiry: "15m",
268
+ refreshExpiry: "7d",
269
+ enableCaching: true, // Optional caching
270
+ maxCacheSize: 100 // Default 100
271
+ });
272
+
273
+ // Generate tokens
274
+ const tokens = await jwtManager.generateTokens({ userId: 42 });
275
+
276
+ // Verify tokens
277
+ const accessPayload = await jwtManager.verifyAccessToken(tokens.accessToken);
278
+ const refreshPayload = await jwtManager.verifyRefreshToken(tokens.refreshToken);
279
+
280
+ // Rotate refresh token
281
+ const newRefreshToken = await jwtManager.rotateRefreshToken(oldRefreshToken);
282
+
283
+ // Decode token
284
+ const decoded = jwtManager.decodeToken(token);
285
+
286
+ // Extract from header
287
+ const token = jwtManager.extractTokenFromHeader("Bearer eyJ...");
46
288
 
47
- // Legacy function names still work
48
- const isValid = await comparePassword('password', 'hash');
49
- const token = signToken({ userId: 1 }, 'secret');
289
+ // Validate without throwing
290
+ const isValid = jwtManager.validateToken(token, secret);
291
+
292
+ // Check expiration
293
+ const isExpired = jwtManager.isTokenExpired(token);
294
+ const expiresAt = jwtManager.getTokenExpiration(token);
295
+
296
+ // Cache management
297
+ jwtManager.clearCache();
298
+ const stats = jwtManager.getCacheStats(); // { size: 5, maxSize: 100 }
50
299
  ```
51
300
 
52
- ## API Reference
301
+ ## 🔒 3. Crypto Utilities
53
302
 
54
- ### Password Functions
55
- - `hashPassword(password: string): Promise<string>` - Hash a password using bcrypt with salt rounds 10
56
- - `verifyPassword(password: string, hash: string): Promise<boolean>` - Verify password against hash
57
- - `comparePassword(password: string, hash: string): Promise<boolean>` - Alias for verifyPassword (backward compatibility)
303
+ ### Functional Exports
304
+ ```typescript
305
+ // AES-256-GCM Encryption
306
+ const encrypted = encrypt("sensitive data", "your-secret-key");
307
+ // Returns: "iv:encrypted_data"
58
308
 
59
- ### JWT Functions
60
- - `generateToken(payload: Record<string, unknown>, secret: Secret, expiresIn?: string): string` - Generate JWT token
61
- - `verifyToken(token: string, secret: Secret): string | JwtPayload` - Verify and decode JWT token
62
- - `signToken(payload: Record<string, unknown>, secret: Secret, expiresIn?: string): string` - Alias for generateToken (backward compatibility)
309
+ const decrypted = decrypt(encrypted, "your-secret-key");
310
+ // Returns: "sensitive data"
63
311
 
64
- ## Examples
312
+ // HMAC
313
+ const hmac = createHMAC("data", "secret-key");
314
+ const isValidHMAC = verifyHMAC("data", hmac, "secret-key");
65
315
 
66
- ### Complete Authentication Flow
316
+ // Random generation
317
+ const randomBytes = generateRandomBytes(32); // Buffer
318
+ const randomString = generateRandomString(16); // Base64 string
319
+ const randomHex = generateRandomHex(32); // Hex string
320
+ ```
321
+
322
+ ### CryptoManager Class
67
323
  ```typescript
68
- import { hashPassword, verifyPassword, generateToken, verifyToken } from '@naman_deep_singh/security';
324
+ const cryptoManager = new CryptoManager("your-secret-key");
325
+
326
+ // Encryption
327
+ const encrypted = cryptoManager.encrypt("data");
328
+ const decrypted = cryptoManager.decrypt(encrypted);
329
+
330
+ // HMAC
331
+ const hmac = cryptoManager.createHMAC("data");
332
+ const isValid = cryptoManager.verifyHMAC("data", hmac);
333
+
334
+ // Random
335
+ const randomBytes = cryptoManager.generateRandomBytes(32);
336
+ const randomString = cryptoManager.generateRandomString(16);
337
+ ```
338
+
339
+ ## 🚨 Error Handling
340
+
341
+ This package uses standardized errors from `@naman_deep_singh/errors-utils`:
342
+
343
+ ```typescript
344
+ import {
345
+ hashPassword,
346
+ verifyPassword,
347
+ BadRequestError,
348
+ UnauthorizedError,
349
+ ValidationError,
350
+ InternalServerError
351
+ } from '@naman_deep_singh/security';
352
+
353
+ try {
354
+ const hash = await hashPassword('mypassword');
355
+ } catch (error) {
356
+ if (error instanceof BadRequestError) {
357
+ // Invalid password input (400)
358
+ console.log('Invalid password provided');
359
+ } else if (error instanceof InternalServerError) {
360
+ // Hashing failed (500)
361
+ console.log('Server error during hashing');
362
+ }
363
+ }
364
+
365
+ try {
366
+ const isValid = await verifyPassword('password', hash);
367
+ } catch (error) {
368
+ if (error instanceof UnauthorizedError) {
369
+ // Password verification failed (401)
370
+ console.log('Invalid credentials');
371
+ }
372
+ }
373
+ ```
374
+
375
+ **Error Types:**
376
+ - `BadRequestError` (400) - Invalid input data
377
+ - `UnauthorizedError` (401) - Authentication failures
378
+ - `ValidationError` (422) - Password strength validation
379
+ - `InternalServerError` (500) - Server-side processing errors
380
+
381
+ ## 🧩 Complete Authentication Example
382
+
383
+ ### Registration with Validation
384
+ ```typescript
385
+ import { PasswordManager, JWTManager } from '@naman_deep_singh/security';
386
+
387
+ const passwordManager = new PasswordManager({
388
+ minLength: 12,
389
+ requireUppercase: true,
390
+ requireNumbers: true,
391
+ requireSpecialChars: true
392
+ });
393
+
394
+ const jwtManager = new JWTManager({
395
+ accessSecret: process.env.ACCESS_SECRET!,
396
+ refreshSecret: process.env.REFRESH_SECRET!,
397
+ accessExpiry: "15m",
398
+ refreshExpiry: "7d"
399
+ });
69
400
 
70
- // Registration
71
401
  async function registerUser(email: string, password: string) {
72
- const hashedPassword = await hashPassword(password);
73
- // Save user with hashedPassword to database
74
- return { email, password: hashedPassword };
402
+ // Validate password strength
403
+ const validation = passwordManager.validate(password);
404
+ if (!validation.isValid) {
405
+ throw new ValidationError(`Password validation failed: ${validation.errors.join(', ')}`);
406
+ }
407
+
408
+ // Hash password
409
+ const { hash, salt } = await passwordManager.hash(password);
410
+
411
+ // Store user with hash and salt
412
+ return {
413
+ email,
414
+ passwordHash: hash,
415
+ passwordSalt: salt
416
+ };
75
417
  }
418
+ ```
76
419
 
77
- // Login
78
- async function loginUser(email: string, password: string, storedHash: string) {
79
- const isValid = await verifyPassword(password, storedHash);
80
-
420
+ ### Login with Token Generation
421
+ ```typescript
422
+ async function loginUser(email: string, password: string, storedHash: string, storedSalt: string) {
423
+ // Verify password
424
+ const isValid = await passwordManager.verify(password, storedHash, storedSalt);
81
425
  if (!isValid) {
82
- throw new Error('Invalid credentials');
426
+ throw new UnauthorizedError("Invalid credentials");
83
427
  }
84
-
85
- const token = generateToken(
86
- { email, loginTime: Date.now() },
87
- process.env.JWT_SECRET!,
88
- '7d'
89
- );
90
-
91
- return { token };
428
+
429
+ // Generate tokens
430
+ return jwtManager.generateTokens({ email });
92
431
  }
432
+ ```
433
+
434
+ ### Token Refresh
435
+ ```typescript
436
+ async function refreshTokens(oldRefreshToken: string) {
437
+ // Verify old refresh token
438
+ const decoded = await jwtManager.verifyRefreshToken(oldRefreshToken);
93
439
 
94
- // Verify JWT
95
- function authenticateRequest(token: string) {
440
+ // Generate new token pair
441
+ const newTokens = await jwtManager.generateTokens(decoded);
442
+
443
+ // Rotate refresh token
444
+ const rotatedRefreshToken = await jwtManager.rotateRefreshToken(oldRefreshToken);
445
+
446
+ return {
447
+ accessToken: newTokens.accessToken,
448
+ refreshToken: rotatedRefreshToken
449
+ };
450
+ }
451
+ ```
452
+
453
+ ### Express Middleware
454
+ ```typescript
455
+ import { extractToken, safeVerifyToken } from '@naman_deep_singh/security';
456
+
457
+ export function authMiddleware(req, res, next) {
458
+ const token = extractToken({
459
+ header: req.headers.authorization,
460
+ cookies: req.cookies,
461
+ query: req.query,
462
+ body: req.body
463
+ });
464
+
465
+ if (!token) {
466
+ return res.status(401).json({ error: "Token missing" });
467
+ }
468
+
469
+ const result = safeVerifyToken(token, process.env.ACCESS_SECRET!);
470
+
471
+ if (!result.valid) {
472
+ return res.status(401).json({ error: "Invalid token" });
473
+ }
474
+
475
+ req.user = result.payload;
476
+ next();
477
+ }
478
+ ```
479
+
480
+ 🔐 Security Best Practices
481
+
482
+ ✔ Use 32+ character secrets for JWT and encryption
483
+ ✔ Store secrets in environment variables
484
+ ✔ Always use HTTPS in production
485
+ ✔ Keep refresh tokens secure (HttpOnly cookie recommended)
486
+ ✔ Do not store passwords in plain text—ever
487
+ ✔ Use password peppering for additional security
488
+ ✔ Implement proper password strength requirements
489
+ ✔ Enable JWT caching for performance (but monitor memory usage)
490
+ ✔ Handle errors appropriately with proper HTTP status codes
491
+ ✔ Regularly rotate secrets and tokens
492
+ ✔ Use secure random generation for all cryptographic operations
493
+
494
+ 🔗 Integration with Other Packages
495
+
496
+ ### With @naman_deep_singh/server-utils
497
+
498
+ ```typescript
499
+ import { createServer } from '@naman_deep_singh/server-utils';
500
+ import { PasswordManager } from '@naman_deep_singh/security';
501
+
502
+ const server = createServer('Auth API', '1.0.0');
503
+ const passwordManager = new PasswordManager();
504
+
505
+ server.app.post('/register', async (req, res) => {
96
506
  try {
97
- const decoded = verifyToken(token, process.env.JWT_SECRET!);
98
- return decoded;
507
+ const { password } = req.body;
508
+ const hash = await passwordManager.hash(password);
509
+ // Save user with hash...
510
+ res.json({ success: true });
99
511
  } catch (error) {
100
- throw new Error('Invalid token');
512
+ // Errors automatically handled by server-utils middleware
513
+ throw error;
101
514
  }
102
- }
515
+ });
103
516
  ```
104
517
 
105
- ## Dependencies
518
+ ### With @naman_deep_singh/errors-utils + @naman_deep_singh/response-utils
106
519
 
107
- - **bcryptjs** - For secure password hashing
108
- - **jsonwebtoken** - For JWT token management
520
+ ```typescript
521
+ import { expressErrorHandler } from '@naman_deep_singh/errors-utils';
522
+ import { responderMiddleware } from '@naman_deep_singh/response-utils';
523
+
524
+ server.app.use(responderMiddleware());
525
+ server.app.use(expressErrorHandler); // Handles security errors consistently
526
+ ```
109
527
 
110
- ## Security Best Practices
528
+ 📜 License
111
529
 
112
- 1. **Use strong secrets** for JWT signing (minimum 32 characters)
113
- 2. **Set appropriate expiration times** for tokens
114
- 3. **Store JWT secrets in environment variables**
115
- 4. **Never log or expose hashed passwords**
116
- 5. **Use HTTPS** in production for token transmission
530
+ MIT free to use & modify.