semola 0.5.3 → 0.5.4

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 (363) hide show
  1. package/dist/index-BhGNDjPq.d.mts +13 -0
  2. package/dist/index-DxSbeGP-.d.cts +13 -0
  3. package/dist/lib/api/index.cjs +522 -4
  4. package/dist/lib/api/index.d.cts +270 -4
  5. package/dist/lib/api/index.d.mts +270 -4
  6. package/dist/lib/api/index.mjs +520 -2
  7. package/dist/lib/cache/index.d.cts +16 -4
  8. package/dist/lib/cache/index.d.mts +16 -4
  9. package/dist/lib/cache/index.mjs +0 -2
  10. package/dist/lib/cron/index.cjs +734 -12
  11. package/dist/lib/cron/index.d.cts +145 -3
  12. package/dist/lib/cron/index.d.mts +145 -3
  13. package/dist/lib/cron/index.mjs +725 -3
  14. package/dist/lib/errors/index.d.cts +2 -13
  15. package/dist/lib/errors/index.d.mts +2 -13
  16. package/dist/lib/errors/index.mjs +0 -2
  17. package/dist/lib/i18n/index.d.cts +12 -4
  18. package/dist/lib/i18n/index.d.mts +12 -4
  19. package/dist/lib/i18n/index.mjs +0 -2
  20. package/dist/lib/logging/index.cjs +386 -17
  21. package/dist/lib/logging/index.d.cts +107 -6
  22. package/dist/lib/logging/index.d.mts +107 -6
  23. package/dist/lib/logging/index.mjs +373 -4
  24. package/dist/lib/policy/index.cjs +206 -20
  25. package/dist/lib/policy/index.d.cts +61 -5
  26. package/dist/lib/policy/index.d.mts +61 -5
  27. package/dist/lib/policy/index.mjs +187 -3
  28. package/dist/lib/prompts/index.cjs +374 -14
  29. package/dist/lib/prompts/index.d.cts +69 -4
  30. package/dist/lib/prompts/index.d.mts +69 -4
  31. package/dist/lib/prompts/index.mjs +362 -4
  32. package/dist/lib/pubsub/index.d.cts +9 -4
  33. package/dist/lib/pubsub/index.d.mts +9 -4
  34. package/dist/lib/pubsub/index.mjs +0 -2
  35. package/dist/lib/queue/index.d.cts +48 -6
  36. package/dist/lib/queue/index.d.mts +48 -6
  37. package/dist/lib/queue/index.mjs +0 -2
  38. package/dist/lib/workflow/index.d.cts +82 -4
  39. package/dist/lib/workflow/index.d.mts +82 -4
  40. package/dist/lib/workflow/index.mjs +0 -2
  41. package/package.json +1 -1
  42. package/dist/api/core/index.cjs +0 -206
  43. package/dist/api/core/index.d.cts +0 -21
  44. package/dist/api/core/index.d.cts.map +0 -1
  45. package/dist/api/core/index.d.mts +0 -21
  46. package/dist/api/core/index.d.mts.map +0 -1
  47. package/dist/api/core/index.mjs +0 -208
  48. package/dist/api/core/index.mjs.map +0 -1
  49. package/dist/api/core/types.d.cts +0 -107
  50. package/dist/api/core/types.d.cts.map +0 -1
  51. package/dist/api/core/types.d.mts +0 -107
  52. package/dist/api/core/types.d.mts.map +0 -1
  53. package/dist/api/middleware/index.cjs +0 -8
  54. package/dist/api/middleware/index.d.cts +0 -11
  55. package/dist/api/middleware/index.d.cts.map +0 -1
  56. package/dist/api/middleware/index.d.mts +0 -11
  57. package/dist/api/middleware/index.d.mts.map +0 -1
  58. package/dist/api/middleware/index.mjs +0 -10
  59. package/dist/api/middleware/index.mjs.map +0 -1
  60. package/dist/api/middleware/types.d.cts +0 -16
  61. package/dist/api/middleware/types.d.cts.map +0 -1
  62. package/dist/api/middleware/types.d.mts +0 -16
  63. package/dist/api/middleware/types.d.mts.map +0 -1
  64. package/dist/api/openapi/index.cjs +0 -254
  65. package/dist/api/openapi/index.mjs +0 -256
  66. package/dist/api/openapi/index.mjs.map +0 -1
  67. package/dist/api/openapi/types.d.cts +0 -60
  68. package/dist/api/openapi/types.d.cts.map +0 -1
  69. package/dist/api/openapi/types.d.mts +0 -60
  70. package/dist/api/openapi/types.d.mts.map +0 -1
  71. package/dist/api/validation/index.cjs +0 -64
  72. package/dist/api/validation/index.mjs +0 -61
  73. package/dist/api/validation/index.mjs.map +0 -1
  74. package/dist/cache/types.d.cts +0 -17
  75. package/dist/cache/types.d.cts.map +0 -1
  76. package/dist/cache/types.d.mts +0 -17
  77. package/dist/cache/types.d.mts.map +0 -1
  78. package/dist/cron/builder/index.cjs +0 -166
  79. package/dist/cron/builder/index.d.cts +0 -28
  80. package/dist/cron/builder/index.d.cts.map +0 -1
  81. package/dist/cron/builder/index.d.mts +0 -28
  82. package/dist/cron/builder/index.d.mts.map +0 -1
  83. package/dist/cron/builder/index.mjs +0 -163
  84. package/dist/cron/builder/index.mjs.map +0 -1
  85. package/dist/cron/builder/types.cjs +0 -27
  86. package/dist/cron/builder/types.d.cts +0 -79
  87. package/dist/cron/builder/types.d.cts.map +0 -1
  88. package/dist/cron/builder/types.d.mts +0 -79
  89. package/dist/cron/builder/types.d.mts.map +0 -1
  90. package/dist/cron/builder/types.mjs +0 -28
  91. package/dist/cron/builder/types.mjs.map +0 -1
  92. package/dist/cron/core/index.cjs +0 -308
  93. package/dist/cron/core/index.d.cts +0 -39
  94. package/dist/cron/core/index.d.cts.map +0 -1
  95. package/dist/cron/core/index.d.mts +0 -39
  96. package/dist/cron/core/index.d.mts.map +0 -1
  97. package/dist/cron/core/index.mjs +0 -310
  98. package/dist/cron/core/index.mjs.map +0 -1
  99. package/dist/cron/core/scanner.cjs +0 -237
  100. package/dist/cron/core/scanner.mjs +0 -238
  101. package/dist/cron/core/scanner.mjs.map +0 -1
  102. package/dist/cron/core/types.d.cts +0 -11
  103. package/dist/cron/core/types.d.cts.map +0 -1
  104. package/dist/cron/core/types.d.mts +0 -11
  105. package/dist/cron/core/types.d.mts.map +0 -1
  106. package/dist/errors/types.d.cts +0 -5
  107. package/dist/errors/types.d.cts.map +0 -1
  108. package/dist/errors/types.d.mts +0 -5
  109. package/dist/errors/types.d.mts.map +0 -1
  110. package/dist/i18n/types.d.cts +0 -13
  111. package/dist/i18n/types.d.cts.map +0 -1
  112. package/dist/i18n/types.d.mts +0 -13
  113. package/dist/i18n/types.d.mts.map +0 -1
  114. package/dist/lib/cache/index.d.cts.map +0 -1
  115. package/dist/lib/cache/index.d.mts.map +0 -1
  116. package/dist/lib/cache/index.mjs.map +0 -1
  117. package/dist/lib/errors/index.d.cts.map +0 -1
  118. package/dist/lib/errors/index.d.mts.map +0 -1
  119. package/dist/lib/errors/index.mjs.map +0 -1
  120. package/dist/lib/i18n/index.d.cts.map +0 -1
  121. package/dist/lib/i18n/index.d.mts.map +0 -1
  122. package/dist/lib/i18n/index.mjs.map +0 -1
  123. package/dist/lib/orm/index.cjs +0 -20
  124. package/dist/lib/orm/index.d.cts +0 -7
  125. package/dist/lib/orm/index.d.mts +0 -7
  126. package/dist/lib/orm/index.mjs +0 -6
  127. package/dist/lib/policy/index.d.cts.map +0 -1
  128. package/dist/lib/policy/index.d.mts.map +0 -1
  129. package/dist/lib/policy/index.mjs.map +0 -1
  130. package/dist/lib/prompts/index.d.cts.map +0 -1
  131. package/dist/lib/prompts/index.d.mts.map +0 -1
  132. package/dist/lib/prompts/index.mjs.map +0 -1
  133. package/dist/lib/pubsub/index.d.cts.map +0 -1
  134. package/dist/lib/pubsub/index.d.mts.map +0 -1
  135. package/dist/lib/pubsub/index.mjs.map +0 -1
  136. package/dist/lib/queue/index.d.cts.map +0 -1
  137. package/dist/lib/queue/index.d.mts.map +0 -1
  138. package/dist/lib/queue/index.mjs.map +0 -1
  139. package/dist/lib/workflow/index.d.cts.map +0 -1
  140. package/dist/lib/workflow/index.d.mts.map +0 -1
  141. package/dist/lib/workflow/index.mjs.map +0 -1
  142. package/dist/logging/core/index.cjs +0 -99
  143. package/dist/logging/core/index.d.cts +0 -26
  144. package/dist/logging/core/index.d.cts.map +0 -1
  145. package/dist/logging/core/index.d.mts +0 -26
  146. package/dist/logging/core/index.d.mts.map +0 -1
  147. package/dist/logging/core/index.mjs +0 -99
  148. package/dist/logging/core/index.mjs.map +0 -1
  149. package/dist/logging/core/types.cjs +0 -10
  150. package/dist/logging/core/types.d.cts +0 -22
  151. package/dist/logging/core/types.d.cts.map +0 -1
  152. package/dist/logging/core/types.d.mts +0 -22
  153. package/dist/logging/core/types.d.mts.map +0 -1
  154. package/dist/logging/core/types.mjs +0 -12
  155. package/dist/logging/core/types.mjs.map +0 -1
  156. package/dist/logging/formatter/index.cjs +0 -119
  157. package/dist/logging/formatter/index.d.cts +0 -27
  158. package/dist/logging/formatter/index.d.cts.map +0 -1
  159. package/dist/logging/formatter/index.d.mts +0 -27
  160. package/dist/logging/formatter/index.d.mts.map +0 -1
  161. package/dist/logging/formatter/index.mjs +0 -115
  162. package/dist/logging/formatter/index.mjs.map +0 -1
  163. package/dist/logging/formatter/types.d.cts +0 -5
  164. package/dist/logging/formatter/types.d.cts.map +0 -1
  165. package/dist/logging/formatter/types.d.mts +0 -5
  166. package/dist/logging/formatter/types.d.mts.map +0 -1
  167. package/dist/logging/provider/index.cjs +0 -165
  168. package/dist/logging/provider/index.d.cts +0 -28
  169. package/dist/logging/provider/index.d.cts.map +0 -1
  170. package/dist/logging/provider/index.d.mts +0 -28
  171. package/dist/logging/provider/index.d.mts.map +0 -1
  172. package/dist/logging/provider/index.mjs +0 -165
  173. package/dist/logging/provider/index.mjs.map +0 -1
  174. package/dist/logging/provider/types.d.cts +0 -23
  175. package/dist/logging/provider/types.d.cts.map +0 -1
  176. package/dist/logging/provider/types.d.mts +0 -23
  177. package/dist/logging/provider/types.d.mts.map +0 -1
  178. package/dist/node_modules/@standard-schema/spec/dist/index.d.cts +0 -80
  179. package/dist/node_modules/@standard-schema/spec/dist/index.d.cts.map +0 -1
  180. package/dist/node_modules/@standard-schema/spec/dist/index.d.mts +0 -80
  181. package/dist/node_modules/@standard-schema/spec/dist/index.d.mts.map +0 -1
  182. package/dist/orm/column.cjs +0 -137
  183. package/dist/orm/column.d.cts +0 -121
  184. package/dist/orm/column.d.cts.map +0 -1
  185. package/dist/orm/column.d.mts +0 -121
  186. package/dist/orm/column.d.mts.map +0 -1
  187. package/dist/orm/column.mjs +0 -132
  188. package/dist/orm/column.mjs.map +0 -1
  189. package/dist/orm/dialect/index.cjs +0 -14
  190. package/dist/orm/dialect/index.mjs +0 -16
  191. package/dist/orm/dialect/index.mjs.map +0 -1
  192. package/dist/orm/dialect/mysql.cjs +0 -31
  193. package/dist/orm/dialect/mysql.mjs +0 -33
  194. package/dist/orm/dialect/mysql.mjs.map +0 -1
  195. package/dist/orm/dialect/postgres.cjs +0 -23
  196. package/dist/orm/dialect/postgres.mjs +0 -25
  197. package/dist/orm/dialect/postgres.mjs.map +0 -1
  198. package/dist/orm/dialect/sqlite.cjs +0 -31
  199. package/dist/orm/dialect/sqlite.mjs +0 -33
  200. package/dist/orm/dialect/sqlite.mjs.map +0 -1
  201. package/dist/orm/dialect/utils.cjs +0 -8
  202. package/dist/orm/dialect/utils.mjs +0 -10
  203. package/dist/orm/dialect/utils.mjs.map +0 -1
  204. package/dist/orm/internal/table-columns.cjs +0 -31
  205. package/dist/orm/internal/table-columns.mjs +0 -32
  206. package/dist/orm/internal/table-columns.mjs.map +0 -1
  207. package/dist/orm/internal/table-lookup.cjs +0 -35
  208. package/dist/orm/internal/table-lookup.mjs +0 -35
  209. package/dist/orm/internal/table-lookup.mjs.map +0 -1
  210. package/dist/orm/internal/table-relations.cjs +0 -28
  211. package/dist/orm/internal/table-relations.mjs +0 -29
  212. package/dist/orm/internal/table-relations.mjs.map +0 -1
  213. package/dist/orm/migration/config.cjs +0 -7
  214. package/dist/orm/migration/config.d.cts +0 -7
  215. package/dist/orm/migration/config.d.cts.map +0 -1
  216. package/dist/orm/migration/config.d.mts +0 -7
  217. package/dist/orm/migration/config.d.mts.map +0 -1
  218. package/dist/orm/migration/config.mjs +0 -8
  219. package/dist/orm/migration/config.mjs.map +0 -1
  220. package/dist/orm/migration/types.d.cts +0 -20
  221. package/dist/orm/migration/types.d.cts.map +0 -1
  222. package/dist/orm/migration/types.d.mts +0 -20
  223. package/dist/orm/migration/types.d.mts.map +0 -1
  224. package/dist/orm/orm.cjs +0 -41
  225. package/dist/orm/orm.d.cts +0 -18
  226. package/dist/orm/orm.d.cts.map +0 -1
  227. package/dist/orm/orm.d.mts +0 -18
  228. package/dist/orm/orm.d.mts.map +0 -1
  229. package/dist/orm/orm.mjs +0 -43
  230. package/dist/orm/orm.mjs.map +0 -1
  231. package/dist/orm/relation.cjs +0 -18
  232. package/dist/orm/relation.d.cts +0 -8
  233. package/dist/orm/relation.d.cts.map +0 -1
  234. package/dist/orm/relation.d.mts +0 -8
  235. package/dist/orm/relation.d.mts.map +0 -1
  236. package/dist/orm/relation.mjs +0 -19
  237. package/dist/orm/relation.mjs.map +0 -1
  238. package/dist/orm/runtime/builders/mutations.cjs +0 -29
  239. package/dist/orm/runtime/builders/mutations.mjs +0 -28
  240. package/dist/orm/runtime/builders/mutations.mjs.map +0 -1
  241. package/dist/orm/runtime/builders/select.cjs +0 -18
  242. package/dist/orm/runtime/builders/select.mjs +0 -19
  243. package/dist/orm/runtime/builders/select.mjs.map +0 -1
  244. package/dist/orm/runtime/client.cjs +0 -90
  245. package/dist/orm/runtime/client.mjs +0 -92
  246. package/dist/orm/runtime/client.mjs.map +0 -1
  247. package/dist/orm/runtime/context.cjs +0 -49
  248. package/dist/orm/runtime/context.mjs +0 -51
  249. package/dist/orm/runtime/context.mjs.map +0 -1
  250. package/dist/orm/runtime/dialect/index.cjs +0 -11
  251. package/dist/orm/runtime/dialect/index.mjs +0 -13
  252. package/dist/orm/runtime/dialect/index.mjs.map +0 -1
  253. package/dist/orm/runtime/dialect/mysql.cjs +0 -95
  254. package/dist/orm/runtime/dialect/mysql.mjs +0 -97
  255. package/dist/orm/runtime/dialect/mysql.mjs.map +0 -1
  256. package/dist/orm/runtime/dialect/postgres.cjs +0 -51
  257. package/dist/orm/runtime/dialect/postgres.mjs +0 -53
  258. package/dist/orm/runtime/dialect/postgres.mjs.map +0 -1
  259. package/dist/orm/runtime/dialect/sqlite.cjs +0 -4
  260. package/dist/orm/runtime/dialect/sqlite.mjs +0 -7
  261. package/dist/orm/runtime/dialect/sqlite.mjs.map +0 -1
  262. package/dist/orm/runtime/errors.cjs +0 -19
  263. package/dist/orm/runtime/errors.mjs +0 -21
  264. package/dist/orm/runtime/errors.mjs.map +0 -1
  265. package/dist/orm/runtime/hydrate/many.cjs +0 -46
  266. package/dist/orm/runtime/hydrate/many.mjs +0 -48
  267. package/dist/orm/runtime/hydrate/many.mjs.map +0 -1
  268. package/dist/orm/runtime/hydrate/one.cjs +0 -38
  269. package/dist/orm/runtime/hydrate/one.mjs +0 -40
  270. package/dist/orm/runtime/hydrate/one.mjs.map +0 -1
  271. package/dist/orm/runtime/hydrate.cjs +0 -49
  272. package/dist/orm/runtime/hydrate.mjs +0 -51
  273. package/dist/orm/runtime/hydrate.mjs.map +0 -1
  274. package/dist/orm/runtime/rows.cjs +0 -30
  275. package/dist/orm/runtime/rows.mjs +0 -31
  276. package/dist/orm/runtime/rows.mjs.map +0 -1
  277. package/dist/orm/runtime/utils.cjs +0 -27
  278. package/dist/orm/runtime/utils.mjs +0 -27
  279. package/dist/orm/runtime/utils.mjs.map +0 -1
  280. package/dist/orm/sql/parse-array.cjs +0 -64
  281. package/dist/orm/sql/parse-array.mjs +0 -66
  282. package/dist/orm/sql/parse-array.mjs.map +0 -1
  283. package/dist/orm/sql/plan/select.cjs +0 -36
  284. package/dist/orm/sql/plan/select.mjs +0 -38
  285. package/dist/orm/sql/plan/select.mjs.map +0 -1
  286. package/dist/orm/sql/plan/where/operators.cjs +0 -95
  287. package/dist/orm/sql/plan/where/operators.mjs +0 -97
  288. package/dist/orm/sql/plan/where/operators.mjs.map +0 -1
  289. package/dist/orm/sql/plan/where.cjs +0 -59
  290. package/dist/orm/sql/plan/where.mjs +0 -61
  291. package/dist/orm/sql/plan/where.mjs.map +0 -1
  292. package/dist/orm/sql/serialize/clauses.cjs +0 -36
  293. package/dist/orm/sql/serialize/clauses.mjs +0 -37
  294. package/dist/orm/sql/serialize/clauses.mjs.map +0 -1
  295. package/dist/orm/sql/serialize/joins.cjs +0 -31
  296. package/dist/orm/sql/serialize/joins.mjs +0 -33
  297. package/dist/orm/sql/serialize/joins.mjs.map +0 -1
  298. package/dist/orm/sql/serialize/values.cjs +0 -30
  299. package/dist/orm/sql/serialize/values.mjs +0 -32
  300. package/dist/orm/sql/serialize/values.mjs.map +0 -1
  301. package/dist/orm/sql/serialize/where/predicate.cjs +0 -73
  302. package/dist/orm/sql/serialize/where/predicate.mjs +0 -75
  303. package/dist/orm/sql/serialize/where/predicate.mjs.map +0 -1
  304. package/dist/orm/sql/serialize/where/tree.cjs +0 -26
  305. package/dist/orm/sql/serialize/where/tree.mjs +0 -28
  306. package/dist/orm/sql/serialize/where/tree.mjs.map +0 -1
  307. package/dist/orm/sql/serialize/where.cjs +0 -10
  308. package/dist/orm/sql/serialize/where.mjs +0 -12
  309. package/dist/orm/sql/serialize/where.mjs.map +0 -1
  310. package/dist/orm/sql/serialize.cjs +0 -24
  311. package/dist/orm/sql/serialize.mjs +0 -25
  312. package/dist/orm/sql/serialize.mjs.map +0 -1
  313. package/dist/orm/table.cjs +0 -12
  314. package/dist/orm/table.d.cts +0 -12
  315. package/dist/orm/table.d.cts.map +0 -1
  316. package/dist/orm/table.d.mts +0 -12
  317. package/dist/orm/table.d.mts.map +0 -1
  318. package/dist/orm/table.mjs +0 -14
  319. package/dist/orm/table.mjs.map +0 -1
  320. package/dist/orm/types.d.cts +0 -183
  321. package/dist/orm/types.d.cts.map +0 -1
  322. package/dist/orm/types.d.mts +0 -183
  323. package/dist/orm/types.d.mts.map +0 -1
  324. package/dist/policy/helpers.cjs +0 -206
  325. package/dist/policy/helpers.d.cts +0 -50
  326. package/dist/policy/helpers.d.cts.map +0 -1
  327. package/dist/policy/helpers.d.mts +0 -50
  328. package/dist/policy/helpers.d.mts.map +0 -1
  329. package/dist/policy/helpers.mjs +0 -190
  330. package/dist/policy/helpers.mjs.map +0 -1
  331. package/dist/policy/types.d.cts +0 -16
  332. package/dist/policy/types.d.cts.map +0 -1
  333. package/dist/policy/types.d.mts +0 -16
  334. package/dist/policy/types.d.mts.map +0 -1
  335. package/dist/prompts/core/keys.cjs +0 -165
  336. package/dist/prompts/core/keys.mjs +0 -167
  337. package/dist/prompts/core/keys.mjs.map +0 -1
  338. package/dist/prompts/core/runtime.cjs +0 -104
  339. package/dist/prompts/core/runtime.mjs +0 -106
  340. package/dist/prompts/core/runtime.mjs.map +0 -1
  341. package/dist/prompts/core/session.cjs +0 -98
  342. package/dist/prompts/core/session.mjs +0 -100
  343. package/dist/prompts/core/session.mjs.map +0 -1
  344. package/dist/prompts/core/types.d.cts +0 -21
  345. package/dist/prompts/core/types.d.cts.map +0 -1
  346. package/dist/prompts/core/types.d.mts +0 -21
  347. package/dist/prompts/core/types.d.mts.map +0 -1
  348. package/dist/prompts/types.d.cts +0 -52
  349. package/dist/prompts/types.d.cts.map +0 -1
  350. package/dist/prompts/types.d.mts +0 -52
  351. package/dist/prompts/types.d.mts.map +0 -1
  352. package/dist/pubsub/types.d.cts +0 -10
  353. package/dist/pubsub/types.d.cts.map +0 -1
  354. package/dist/pubsub/types.d.mts +0 -10
  355. package/dist/pubsub/types.d.mts.map +0 -1
  356. package/dist/queue/types.d.cts +0 -47
  357. package/dist/queue/types.d.cts.map +0 -1
  358. package/dist/queue/types.d.mts +0 -47
  359. package/dist/queue/types.d.mts.map +0 -1
  360. package/dist/workflow/types.d.cts +0 -83
  361. package/dist/workflow/types.d.cts.map +0 -1
  362. package/dist/workflow/types.d.mts +0 -83
  363. package/dist/workflow/types.d.mts.map +0 -1
@@ -1,7 +1,108 @@
1
- import { LogDataType, LogLevel, LogLevelType, LogMessageType } from "../../logging/core/types.mjs";
2
- import { DateFmtFnType } from "../../logging/formatter/types.mjs";
3
- import { BaseFormatter, Formatter, JSONFormatter, dmyFormat, isoDateFormat, isoDateTimeFormat, mdyFormat } from "../../logging/formatter/index.mjs";
4
- import { FileProviderOptions, ProviderOptions, SizeBasedPolicyType, TimeBasedPolicyType } from "../../logging/provider/types.mjs";
5
- import { ConsoleProvider, FileProvider, LoggerProvider } from "../../logging/provider/index.mjs";
6
- import { AbstractLogger, Logger } from "../../logging/core/index.mjs";
1
+ //#region src/lib/logging/core/types.d.ts
2
+ declare const LogLevel: {
3
+ readonly debug: 10;
4
+ readonly info: 20;
5
+ readonly warning: 30;
6
+ readonly error: 40;
7
+ readonly critical: 50;
8
+ };
9
+ type LogLevelType = keyof typeof LogLevel;
10
+ type LogMessageType = string | object | number | boolean;
11
+ type LogDataType = {
12
+ prefix: string;
13
+ level: LogLevelType;
14
+ msg: LogMessageType;
15
+ row?: string;
16
+ column?: string;
17
+ fileName?: string;
18
+ method?: string;
19
+ };
20
+ //#endregion
21
+ //#region src/lib/logging/formatter/types.d.ts
22
+ type DateFmtFnType = () => string;
23
+ //#endregion
24
+ //#region src/lib/logging/formatter/index.d.ts
25
+ declare abstract class Formatter {
26
+ protected dateFmt: DateFmtFnType;
27
+ constructor(dateFmt: DateFmtFnType);
28
+ abstract format(logData: LogDataType): string;
29
+ abstract formatError(logData: LogDataType, error: Error): string;
30
+ }
31
+ declare class BaseFormatter extends Formatter {
32
+ constructor(dateFmt?: DateFmtFnType);
33
+ format(logData: LogDataType): string;
34
+ formatError(logData: LogDataType, error: Error): string;
35
+ }
36
+ declare class JSONFormatter extends Formatter {
37
+ constructor(dateFmt?: DateFmtFnType);
38
+ format(logData: LogDataType): string;
39
+ formatError(logData: LogDataType, error: Error): string;
40
+ }
41
+ declare function isoDateTimeFormat(): string;
42
+ declare function isoDateFormat(): string;
43
+ declare function dmyFormat(): string;
44
+ declare function mdyFormat(): string;
45
+ //#endregion
46
+ //#region src/lib/logging/provider/types.d.ts
47
+ type ProviderOptions = {
48
+ level?: LogLevelType;
49
+ formatter?: Formatter;
50
+ };
51
+ interface SizeBasedPolicyType {
52
+ type: "size";
53
+ maxSize?: number;
54
+ }
55
+ interface TimeBasedPolicyType {
56
+ type: "time";
57
+ instant: "hour" | "day" | "week" | "month";
58
+ duration: number;
59
+ }
60
+ type FileProviderOptions = ProviderOptions & {
61
+ policy?: SizeBasedPolicyType | TimeBasedPolicyType;
62
+ };
63
+ //#endregion
64
+ //#region src/lib/logging/provider/index.d.ts
65
+ declare abstract class LoggerProvider {
66
+ protected options: ProviderOptions;
67
+ constructor(options?: ProviderOptions);
68
+ abstract execute(data: LogDataType): void;
69
+ getLogLevel(): number;
70
+ }
71
+ declare class FileProvider extends LoggerProvider {
72
+ private readonly filePath;
73
+ private counter;
74
+ private file;
75
+ private policy?;
76
+ constructor(file: string, options?: FileProviderOptions);
77
+ execute(data: LogDataType): void;
78
+ private canRollFile;
79
+ private getFileSize;
80
+ private isJSONFile;
81
+ private createNewFileName;
82
+ }
83
+ declare class ConsoleProvider extends LoggerProvider {
84
+ execute(data: LogDataType): void;
85
+ }
86
+ //#endregion
87
+ //#region src/lib/logging/core/index.d.ts
88
+ declare abstract class AbstractLogger {
89
+ protected providers: LoggerProvider[];
90
+ protected prefix: string;
91
+ constructor(prefix: string, providers: [LoggerProvider, ...LoggerProvider[]]);
92
+ abstract debug(msg: LogMessageType): void;
93
+ abstract info(msg: LogMessageType): void;
94
+ abstract warning(msg: LogMessageType): void;
95
+ abstract error(msg: LogMessageType): void;
96
+ abstract critical(msg: LogMessageType): void;
97
+ protected createLogData(level: LogLevelType, msg: LogMessageType, prefix: string): LogDataType;
98
+ }
99
+ declare class Logger extends AbstractLogger {
100
+ debug(msg: LogMessageType): void;
101
+ info(msg: LogMessageType): void;
102
+ warning(msg: LogMessageType): void;
103
+ error(msg: LogMessageType): void;
104
+ critical(msg: LogMessageType): void;
105
+ private run;
106
+ }
107
+ //#endregion
7
108
  export { AbstractLogger, BaseFormatter, ConsoleProvider, type DateFmtFnType, FileProvider, type FileProviderOptions, Formatter, JSONFormatter, type LogDataType, LogLevel, type LogLevelType, type LogMessageType, Logger, LoggerProvider, type ProviderOptions, type SizeBasedPolicyType, type TimeBasedPolicyType, dmyFormat, isoDateFormat, isoDateTimeFormat, mdyFormat };
@@ -1,5 +1,374 @@
1
- import { BaseFormatter, Formatter, JSONFormatter, dmyFormat, isoDateFormat, isoDateTimeFormat, mdyFormat } from "../../logging/formatter/index.mjs";
2
- import { AbstractLogger, Logger } from "../../logging/core/index.mjs";
3
- import { LogLevel } from "../../logging/core/types.mjs";
4
- import { ConsoleProvider, FileProvider, LoggerProvider } from "../../logging/provider/index.mjs";
1
+ import { mightThrowSync } from "../errors/index.mjs";
2
+ import { basename, dirname, extname, join } from "node:path";
3
+ import { appendFileSync, existsSync, mkdirSync, statSync } from "node:fs";
4
+ //#region src/lib/logging/formatter/index.ts
5
+ var Formatter = class {
6
+ dateFmt;
7
+ constructor(dateFmt) {
8
+ this.dateFmt = dateFmt;
9
+ }
10
+ };
11
+ var BaseFormatter = class extends Formatter {
12
+ constructor(dateFmt = isoDateTimeFormat) {
13
+ super(dateFmt);
14
+ }
15
+ format(logData) {
16
+ let { prefix, level, msg, fileName, row, column, method } = logData;
17
+ const timestamp = this.dateFmt();
18
+ const levelType = level.toUpperCase();
19
+ if (typeof msg === "object") msg = JSON.stringify(msg);
20
+ const fileData = `${prefix}/${fileName}:${row}:${column}`;
21
+ let header = `[${levelType}]`;
22
+ if (method) header = `${header}\t[${method}]\t[${fileData}]`;
23
+ else header = `${header}\t[${fileData}]`;
24
+ return `${timestamp} ${header} : ${msg}`;
25
+ }
26
+ formatError(logData, error) {
27
+ const { prefix, fileName, row, column, method } = logData;
28
+ const timestamp = this.dateFmt();
29
+ const fileData = `${prefix}/${fileName}:${row}:${column}`;
30
+ let errorMsg = `Error name="${error.name}" Error message="${error.message}"`;
31
+ let header = "[ERROR]";
32
+ if (method) header = `${header}\t[${method}]\t[${fileData}]`;
33
+ else header = `${header}\t[${fileData}]`;
34
+ if (error.cause) errorMsg = `${errorMsg}\n\tError cause="${error.cause}"`;
35
+ if (error.stack) errorMsg = `${errorMsg}\n\tStack trace="${error.stack}"`;
36
+ return `${timestamp} ${header} : ${errorMsg}`;
37
+ }
38
+ };
39
+ var JSONFormatter = class extends Formatter {
40
+ constructor(dateFmt = isoDateTimeFormat) {
41
+ super(dateFmt);
42
+ }
43
+ format(logData) {
44
+ const { prefix, level, msg, fileName, row, column, method } = logData;
45
+ const timestamp = this.dateFmt();
46
+ const levelType = level.toUpperCase();
47
+ let position = {};
48
+ if (method) position = { method };
49
+ position = {
50
+ ...position,
51
+ fileName,
52
+ row,
53
+ column
54
+ };
55
+ return JSON.stringify({
56
+ timestamp,
57
+ level: levelType,
58
+ prefix,
59
+ position,
60
+ msg
61
+ });
62
+ }
63
+ formatError(logData, error) {
64
+ const { prefix, fileName, row, column, method } = logData;
65
+ const timestamp = this.dateFmt();
66
+ let errorMsg = {
67
+ errorName: error.name,
68
+ errorMessage: error.message
69
+ };
70
+ let position = {};
71
+ if (method) position = { method };
72
+ position = {
73
+ ...position,
74
+ fileName,
75
+ row,
76
+ column
77
+ };
78
+ if (error.cause) errorMsg = {
79
+ ...errorMsg,
80
+ errorCause: error.cause
81
+ };
82
+ if (error.stack) errorMsg = {
83
+ ...errorMsg,
84
+ stackTrace: error.stack
85
+ };
86
+ return JSON.stringify({
87
+ timestamp,
88
+ level: "ERROR",
89
+ prefix,
90
+ position,
91
+ msg: errorMsg
92
+ });
93
+ }
94
+ };
95
+ function isoDateTimeFormat() {
96
+ return (/* @__PURE__ */ new Date()).toISOString();
97
+ }
98
+ function isoDateFormat() {
99
+ const date = isoDateTimeFormat().split("T")[0];
100
+ if (!date) return "";
101
+ return date;
102
+ }
103
+ function dmyFormat() {
104
+ const isoDate = isoDateFormat();
105
+ if (!isoDate) return "";
106
+ const info = isoDate.split("-");
107
+ return `${info[2]}-${info[1]}-${info[0]}`;
108
+ }
109
+ function mdyFormat() {
110
+ const isoDate = isoDateFormat();
111
+ if (!isoDate) return "";
112
+ const info = isoDate.split("-");
113
+ return `${info[1]}-${info[2]}-${info[0]}`;
114
+ }
115
+ //#endregion
116
+ //#region src/lib/logging/core/index.ts
117
+ const PROVIDER_OPTION_DEFAULT = {
118
+ formatter: new BaseFormatter(),
119
+ level: "debug"
120
+ };
121
+ const STACK_FRAME_IDX = 1;
122
+ var StackData = class {
123
+ stack = [];
124
+ constructor(fn) {
125
+ const oldStackTrace = Error.prepareStackTrace;
126
+ const [stackTraceError] = mightThrowSync(() => {
127
+ Error.prepareStackTrace = (_, stack) => {
128
+ return stack.map((callSite) => {
129
+ return {
130
+ fileName: callSite.getFileName(),
131
+ column: callSite.getColumnNumber(),
132
+ row: callSite.getLineNumber(),
133
+ functionCall: callSite.getFunctionName()
134
+ };
135
+ });
136
+ };
137
+ Error.captureStackTrace(this, fn);
138
+ this.stack;
139
+ });
140
+ Error.prepareStackTrace = oldStackTrace;
141
+ if (stackTraceError) this.stack = [];
142
+ }
143
+ retrieveFrame() {
144
+ if (this.stack.length === 0) return void 0;
145
+ return this.stack[STACK_FRAME_IDX];
146
+ }
147
+ };
148
+ var AbstractLogger = class {
149
+ providers;
150
+ prefix;
151
+ constructor(prefix, providers) {
152
+ this.prefix = prefix;
153
+ this.providers = providers;
154
+ }
155
+ createLogData(level, msg, prefix) {
156
+ const logCall = new StackData(this.createLogData).retrieveFrame();
157
+ let logData = {
158
+ level,
159
+ msg,
160
+ prefix
161
+ };
162
+ if (!logCall) return logData;
163
+ const { column, fileName, functionCall, row } = logCall;
164
+ if (fileName) logData = {
165
+ ...logData,
166
+ fileName: basename(fileName)
167
+ };
168
+ if (column) logData = {
169
+ ...logData,
170
+ column: String(column)
171
+ };
172
+ if (row) logData = {
173
+ ...logData,
174
+ row: String(row)
175
+ };
176
+ if (functionCall) logData = {
177
+ ...logData,
178
+ method: functionCall
179
+ };
180
+ return logData;
181
+ }
182
+ };
183
+ var Logger = class extends AbstractLogger {
184
+ debug(msg) {
185
+ const data = this.createLogData("debug", msg, this.prefix);
186
+ this.run(data);
187
+ }
188
+ info(msg) {
189
+ const data = this.createLogData("info", msg, this.prefix);
190
+ this.run(data);
191
+ }
192
+ warning(msg) {
193
+ const data = this.createLogData("warning", msg, this.prefix);
194
+ this.run(data);
195
+ }
196
+ error(msg) {
197
+ const data = this.createLogData("error", msg, this.prefix);
198
+ this.run(data);
199
+ }
200
+ critical(msg) {
201
+ const data = this.createLogData("critical", msg, this.prefix);
202
+ this.run(data);
203
+ }
204
+ run(data) {
205
+ for (let i = 0; i < this.providers.length; i++) this.providers[i]?.execute(data);
206
+ }
207
+ };
208
+ //#endregion
209
+ //#region src/lib/logging/core/types.ts
210
+ const LogLevel = {
211
+ debug: 10,
212
+ info: 20,
213
+ warning: 30,
214
+ error: 40,
215
+ critical: 50
216
+ };
217
+ //#endregion
218
+ //#region src/lib/logging/provider/index.ts
219
+ const DEFAULT_MAX_SIZE = 4 * 1024;
220
+ const DurationUnit = {
221
+ hour: 1e3 * 60 * 60,
222
+ day: 1e3 * 60 * 60 * 24,
223
+ week: 1e3 * 60 * 60 * 24 * 7,
224
+ month: 1e3 * 60 * 60 * 24 * 7 * 4.345
225
+ };
226
+ var LoggerProvider = class {
227
+ options;
228
+ constructor(options = PROVIDER_OPTION_DEFAULT) {
229
+ this.options = {
230
+ ...PROVIDER_OPTION_DEFAULT,
231
+ ...options
232
+ };
233
+ }
234
+ getLogLevel() {
235
+ if (!this.options.level) return LogLevel.debug;
236
+ return LogLevel[this.options.level];
237
+ }
238
+ };
239
+ const FILE_PROVIDER_OPTION_DEFAULT = {
240
+ ...PROVIDER_OPTION_DEFAULT,
241
+ policy: { type: "size" }
242
+ };
243
+ var FileProvider = class extends LoggerProvider {
244
+ filePath;
245
+ counter;
246
+ file;
247
+ policy;
248
+ constructor(file, options = FILE_PROVIDER_OPTION_DEFAULT) {
249
+ super({
250
+ formatter: options.formatter ?? PROVIDER_OPTION_DEFAULT.formatter,
251
+ level: options.level ?? PROVIDER_OPTION_DEFAULT.level
252
+ });
253
+ this.policy = options.policy ?? FILE_PROVIDER_OPTION_DEFAULT.policy;
254
+ this.filePath = file;
255
+ this.counter = 0;
256
+ this.file = this.createNewFileName();
257
+ }
258
+ execute(data) {
259
+ if (this.getLogLevel() > LogLevel[data.level]) return;
260
+ const [error, formattedMessage] = mightThrowSync(() => {
261
+ if (this.isJSONFile()) return JSON.stringify({
262
+ timestamp: isoDateTimeFormat(),
263
+ level: data.level,
264
+ message: data.msg
265
+ });
266
+ const { formatter } = this.options;
267
+ return formatter?.format(data) ?? "";
268
+ });
269
+ const [fsError] = mightThrowSync(() => {
270
+ if (error && error instanceof Error) {
271
+ const { formatter } = this.options;
272
+ const errorMsg = formatter?.formatError(data, error);
273
+ appendFileSync(this.file, `${errorMsg}\n`);
274
+ }
275
+ if (this.canRollFile()) {
276
+ this.counter += 1;
277
+ this.file = this.createNewFileName();
278
+ }
279
+ if (error || !formattedMessage) return;
280
+ appendFileSync(this.file, `${formattedMessage}\n`);
281
+ });
282
+ if (fsError && fsError instanceof Error) throw fsError;
283
+ }
284
+ canRollFile() {
285
+ if (!this.policy) return false;
286
+ switch (this.policy.type) {
287
+ case "size":
288
+ if (this.policy.maxSize) return this.getFileSize() >= this.policy.maxSize;
289
+ return this.getFileSize() >= DEFAULT_MAX_SIZE;
290
+ case "time": {
291
+ if (!existsSync(this.file)) return false;
292
+ const { duration, instant } = this.policy;
293
+ const { birthtime } = statSync(this.file);
294
+ const creationTimeMs = birthtime.getTime();
295
+ const currenTimeMs = Date.now();
296
+ const diffMs = currenTimeMs - creationTimeMs;
297
+ switch (instant) {
298
+ case "hour": return Math.floor(diffMs / DurationUnit.hour) >= duration;
299
+ case "day": return Math.floor(diffMs / DurationUnit.day) >= duration;
300
+ case "week": return Math.floor(diffMs / DurationUnit.week) >= duration;
301
+ case "month": {
302
+ const currentDate = new Date(currenTimeMs);
303
+ const monthsDiff = (currentDate.getFullYear() - birthtime.getFullYear()) * 12 + (currentDate.getMonth() - birthtime.getMonth());
304
+ return (currentDate.getDate() >= birthtime.getDate() ? monthsDiff : monthsDiff - 1) >= duration;
305
+ }
306
+ }
307
+ }
308
+ }
309
+ }
310
+ getFileSize() {
311
+ if (!existsSync(this.file)) return 0;
312
+ const [statError, size] = mightThrowSync(() => {
313
+ const { size } = statSync(this.file);
314
+ return size;
315
+ });
316
+ if (statError && statError instanceof Error) return 0;
317
+ if (!size) return 0;
318
+ return size;
319
+ }
320
+ isJSONFile() {
321
+ return extname(this.filePath) === ".json";
322
+ }
323
+ createNewFileName() {
324
+ const fileName = basename(this.filePath);
325
+ const directory = dirname(this.filePath);
326
+ if (!existsSync(directory)) mkdirSync(directory, { recursive: true });
327
+ const fileInfo = fileName.split(".");
328
+ const extension = fileInfo.pop();
329
+ return join(directory, [
330
+ ...fileInfo,
331
+ this.counter,
332
+ extension
333
+ ].join("."));
334
+ }
335
+ };
336
+ var ConsoleProvider = class extends LoggerProvider {
337
+ execute(data) {
338
+ const level = this.getLogLevel();
339
+ const userLevel = LogLevel[data.level];
340
+ if (level > userLevel) return;
341
+ const [error, formattedMessage] = mightThrowSync(() => {
342
+ const { formatter } = this.options;
343
+ return formatter?.format(data) ?? "";
344
+ });
345
+ if (error && error instanceof Error) {
346
+ const { formatter } = this.options;
347
+ console.error(formatter?.formatError(data, error));
348
+ return;
349
+ }
350
+ if (!formattedMessage) return;
351
+ switch (userLevel) {
352
+ case LogLevel.debug:
353
+ console.debug(formattedMessage);
354
+ break;
355
+ case LogLevel.info:
356
+ console.info(formattedMessage);
357
+ break;
358
+ case LogLevel.warning:
359
+ console.warn(formattedMessage);
360
+ break;
361
+ case LogLevel.error:
362
+ console.error(formattedMessage);
363
+ break;
364
+ case LogLevel.critical:
365
+ console.error(formattedMessage);
366
+ break;
367
+ default:
368
+ console.debug(formattedMessage);
369
+ break;
370
+ }
371
+ }
372
+ };
373
+ //#endregion
5
374
  export { AbstractLogger, BaseFormatter, ConsoleProvider, FileProvider, Formatter, JSONFormatter, LogLevel, Logger, LoggerProvider, dmyFormat, isoDateFormat, isoDateTimeFormat, mdyFormat };