@decaf-ts/core 0.5.0 → 0.5.1

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 (294) hide show
  1. package/dist/core.cjs +574 -999
  2. package/dist/core.esm.cjs +572 -984
  3. package/lib/esm/identity/decorators.d.ts +1 -8
  4. package/lib/esm/identity/decorators.js +12 -19
  5. package/lib/esm/identity/utils.d.ts +1 -1
  6. package/lib/esm/identity/utils.js +3 -2
  7. package/lib/esm/index.d.ts +4 -15
  8. package/lib/esm/index.js +8 -17
  9. package/lib/esm/interfaces/Executor.d.ts +2 -18
  10. package/lib/esm/interfaces/Executor.js +1 -1
  11. package/lib/esm/interfaces/Observable.d.ts +2 -27
  12. package/lib/esm/interfaces/Observable.js +1 -1
  13. package/lib/esm/interfaces/Observer.d.ts +0 -13
  14. package/lib/esm/interfaces/Observer.js +1 -1
  15. package/lib/esm/interfaces/Paginatable.d.ts +3 -2
  16. package/lib/esm/interfaces/Paginatable.js +1 -1
  17. package/lib/esm/interfaces/Queriable.d.ts +19 -3
  18. package/lib/esm/interfaces/Queriable.js +1 -1
  19. package/lib/esm/interfaces/RawExecutor.d.ts +1 -18
  20. package/lib/esm/interfaces/RawExecutor.js +1 -1
  21. package/lib/esm/interfaces/SequenceOptions.d.ts +0 -7
  22. package/lib/esm/interfaces/SequenceOptions.js +1 -1
  23. package/lib/esm/interfaces/index.d.ts +0 -1
  24. package/lib/esm/interfaces/index.js +1 -2
  25. package/lib/esm/model/construction.d.ts +9 -9
  26. package/lib/esm/model/construction.js +1 -1
  27. package/lib/esm/model/decorators.d.ts +6 -12
  28. package/lib/esm/model/decorators.js +6 -12
  29. package/lib/esm/model/index.js +1 -2
  30. package/lib/esm/persistence/Adapter.d.ts +29 -26
  31. package/lib/esm/persistence/Adapter.js +133 -45
  32. package/lib/esm/persistence/Dispatch.d.ts +18 -0
  33. package/lib/esm/persistence/Dispatch.js +89 -0
  34. package/lib/esm/persistence/ObserverHandler.d.ts +14 -0
  35. package/lib/esm/persistence/ObserverHandler.js +42 -0
  36. package/lib/esm/persistence/Sequence.d.ts +4 -12
  37. package/lib/esm/persistence/Sequence.js +22 -1
  38. package/lib/esm/persistence/constants.d.ts +0 -5
  39. package/lib/esm/persistence/constants.js +1 -7
  40. package/lib/esm/persistence/errors.d.ts +0 -3
  41. package/lib/esm/persistence/errors.js +2 -7
  42. package/lib/esm/persistence/index.d.ts +3 -0
  43. package/lib/esm/persistence/index.js +4 -1
  44. package/lib/esm/persistence/types.d.ts +3 -0
  45. package/lib/esm/persistence/types.js +2 -0
  46. package/lib/esm/query/Condition.d.ts +10 -13
  47. package/lib/esm/query/Condition.js +13 -10
  48. package/lib/esm/query/Paginator.d.ts +11 -10
  49. package/lib/esm/query/Paginator.js +8 -10
  50. package/lib/esm/query/Statement.d.ts +37 -53
  51. package/lib/esm/query/Statement.js +130 -128
  52. package/lib/esm/query/constants.d.ts +0 -64
  53. package/lib/esm/query/constants.js +1 -68
  54. package/lib/esm/query/index.d.ts +0 -5
  55. package/lib/esm/query/index.js +1 -6
  56. package/lib/esm/query/options.d.ts +48 -175
  57. package/lib/esm/query/options.js +1 -1
  58. package/lib/esm/query/selectors.d.ts +3 -33
  59. package/lib/esm/query/selectors.js +1 -1
  60. package/lib/esm/ram/RamAdapter.d.ts +11 -20
  61. package/lib/esm/ram/RamAdapter.js +49 -140
  62. package/lib/esm/ram/RamPaginator.d.ts +8 -6
  63. package/lib/esm/ram/RamPaginator.js +5 -5
  64. package/lib/esm/ram/RamSequence.d.ts +0 -36
  65. package/lib/esm/ram/RamSequence.js +2 -51
  66. package/lib/esm/ram/RamStatement.d.ts +10 -6
  67. package/lib/esm/ram/RamStatement.js +101 -6
  68. package/lib/esm/ram/constants.d.ts +1 -0
  69. package/lib/esm/ram/constants.js +2 -0
  70. package/lib/esm/ram/handlers.d.ts +6 -0
  71. package/lib/esm/ram/handlers.js +8 -0
  72. package/lib/esm/ram/index.d.ts +4 -4
  73. package/lib/esm/ram/index.js +9 -5
  74. package/lib/esm/ram/model/RamSequence.d.ts +0 -13
  75. package/lib/esm/ram/model/RamSequence.js +1 -1
  76. package/lib/esm/ram/types.d.ts +5 -5
  77. package/lib/esm/ram/types.js +1 -1
  78. package/lib/esm/repository/Repository.d.ts +21 -17
  79. package/lib/esm/repository/Repository.js +89 -31
  80. package/lib/esm/repository/constants.d.ts +0 -15
  81. package/lib/esm/repository/constants.js +1 -16
  82. package/lib/esm/repository/errors.d.ts +0 -6
  83. package/lib/esm/repository/errors.js +1 -11
  84. package/lib/esm/repository/injectables.js +1 -1
  85. package/lib/esm/repository/types.d.ts +0 -3
  86. package/lib/esm/repository/types.js +1 -1
  87. package/lib/esm/utils/decorators.d.ts +1 -0
  88. package/lib/esm/utils/decorators.js +11 -0
  89. package/lib/esm/utils/errors.d.ts +10 -0
  90. package/lib/esm/utils/errors.js +17 -0
  91. package/lib/esm/utils/index.d.ts +2 -0
  92. package/lib/esm/utils/index.js +3 -0
  93. package/lib/identity/decorators.cjs +12 -19
  94. package/lib/identity/decorators.d.ts +1 -8
  95. package/lib/identity/utils.cjs +3 -2
  96. package/lib/identity/utils.d.ts +1 -1
  97. package/lib/index.cjs +8 -17
  98. package/lib/index.d.ts +4 -15
  99. package/lib/interfaces/Executor.cjs +1 -1
  100. package/lib/interfaces/Executor.d.ts +2 -18
  101. package/lib/interfaces/Observable.cjs +1 -1
  102. package/lib/interfaces/Observable.d.ts +2 -27
  103. package/lib/interfaces/Observer.cjs +1 -1
  104. package/lib/interfaces/Observer.d.ts +0 -13
  105. package/lib/interfaces/Paginatable.cjs +1 -1
  106. package/lib/interfaces/Paginatable.d.ts +3 -2
  107. package/lib/interfaces/Queriable.cjs +1 -1
  108. package/lib/interfaces/Queriable.d.ts +19 -3
  109. package/lib/interfaces/RawExecutor.cjs +1 -1
  110. package/lib/interfaces/RawExecutor.d.ts +1 -18
  111. package/lib/interfaces/SequenceOptions.cjs +1 -1
  112. package/lib/interfaces/SequenceOptions.d.ts +0 -7
  113. package/lib/interfaces/index.cjs +1 -2
  114. package/lib/interfaces/index.d.ts +0 -1
  115. package/lib/model/construction.cjs +1 -1
  116. package/lib/model/construction.d.ts +9 -9
  117. package/lib/model/decorators.cjs +6 -12
  118. package/lib/model/decorators.d.ts +6 -12
  119. package/lib/model/index.cjs +1 -2
  120. package/lib/persistence/Adapter.cjs +132 -44
  121. package/lib/persistence/Adapter.d.ts +29 -26
  122. package/lib/persistence/Dispatch.cjs +93 -0
  123. package/lib/persistence/Dispatch.d.ts +18 -0
  124. package/lib/persistence/ObserverHandler.cjs +46 -0
  125. package/lib/persistence/ObserverHandler.d.ts +14 -0
  126. package/lib/persistence/Sequence.cjs +22 -1
  127. package/lib/persistence/Sequence.d.ts +4 -12
  128. package/lib/persistence/constants.cjs +2 -8
  129. package/lib/persistence/constants.d.ts +0 -5
  130. package/lib/persistence/errors.cjs +3 -9
  131. package/lib/persistence/errors.d.ts +0 -3
  132. package/lib/persistence/index.cjs +4 -1
  133. package/lib/persistence/index.d.ts +3 -0
  134. package/lib/persistence/types.cjs +3 -0
  135. package/lib/persistence/types.d.ts +3 -0
  136. package/lib/query/Condition.cjs +12 -9
  137. package/lib/query/Condition.d.ts +10 -13
  138. package/lib/query/Paginator.cjs +8 -10
  139. package/lib/query/Paginator.d.ts +11 -10
  140. package/lib/query/Statement.cjs +129 -127
  141. package/lib/query/Statement.d.ts +37 -53
  142. package/lib/query/constants.cjs +2 -69
  143. package/lib/query/constants.d.ts +0 -64
  144. package/lib/query/index.cjs +1 -6
  145. package/lib/query/index.d.ts +0 -5
  146. package/lib/query/options.cjs +1 -1
  147. package/lib/query/options.d.ts +48 -175
  148. package/lib/query/selectors.cjs +1 -1
  149. package/lib/query/selectors.d.ts +3 -33
  150. package/lib/ram/RamAdapter.cjs +47 -172
  151. package/lib/ram/RamAdapter.d.ts +11 -20
  152. package/lib/ram/RamPaginator.cjs +5 -5
  153. package/lib/ram/RamPaginator.d.ts +8 -6
  154. package/lib/ram/RamSequence.cjs +2 -52
  155. package/lib/ram/RamSequence.d.ts +0 -36
  156. package/lib/ram/RamStatement.cjs +101 -6
  157. package/lib/ram/RamStatement.d.ts +10 -6
  158. package/lib/ram/constants.cjs +5 -0
  159. package/lib/ram/constants.d.ts +1 -0
  160. package/lib/ram/handlers.cjs +11 -0
  161. package/lib/ram/handlers.d.ts +6 -0
  162. package/lib/ram/index.cjs +9 -5
  163. package/lib/ram/index.d.ts +4 -4
  164. package/lib/ram/model/RamSequence.cjs +1 -1
  165. package/lib/ram/model/RamSequence.d.ts +0 -13
  166. package/lib/ram/types.cjs +1 -1
  167. package/lib/ram/types.d.ts +5 -5
  168. package/lib/repository/Repository.cjs +89 -31
  169. package/lib/repository/Repository.d.ts +21 -17
  170. package/lib/repository/constants.cjs +1 -16
  171. package/lib/repository/constants.d.ts +0 -15
  172. package/lib/repository/errors.cjs +2 -14
  173. package/lib/repository/errors.d.ts +0 -6
  174. package/lib/repository/injectables.cjs +1 -1
  175. package/lib/repository/types.cjs +1 -1
  176. package/lib/repository/types.d.ts +0 -3
  177. package/lib/utils/decorators.cjs +14 -0
  178. package/lib/utils/decorators.d.ts +1 -0
  179. package/lib/utils/errors.cjs +23 -0
  180. package/lib/utils/errors.d.ts +10 -0
  181. package/lib/{validators → utils}/index.cjs +2 -2
  182. package/lib/utils/index.d.ts +2 -0
  183. package/package.json +1 -1
  184. package/lib/esm/interfaces/Builder.d.ts +0 -16
  185. package/lib/esm/interfaces/Builder.js +0 -2
  186. package/lib/esm/model/IdentifiedBaseModel.d.ts +0 -7
  187. package/lib/esm/model/IdentifiedBaseModel.js +0 -25
  188. package/lib/esm/query/Clause.d.ts +0 -50
  189. package/lib/esm/query/Clause.js +0 -82
  190. package/lib/esm/query/ClauseFactory.d.ts +0 -71
  191. package/lib/esm/query/ClauseFactory.js +0 -6
  192. package/lib/esm/query/Query.d.ts +0 -43
  193. package/lib/esm/query/Query.js +0 -54
  194. package/lib/esm/query/clauses/FromClause.d.ts +0 -45
  195. package/lib/esm/query/clauses/FromClause.js +0 -59
  196. package/lib/esm/query/clauses/GroupByClause.d.ts +0 -21
  197. package/lib/esm/query/clauses/GroupByClause.js +0 -19
  198. package/lib/esm/query/clauses/InsertClause.d.ts +0 -37
  199. package/lib/esm/query/clauses/InsertClause.js +0 -55
  200. package/lib/esm/query/clauses/LimitClause.d.ts +0 -29
  201. package/lib/esm/query/clauses/LimitClause.js +0 -27
  202. package/lib/esm/query/clauses/OffsetClause.d.ts +0 -21
  203. package/lib/esm/query/clauses/OffsetClause.js +0 -19
  204. package/lib/esm/query/clauses/OrderByClause.d.ts +0 -37
  205. package/lib/esm/query/clauses/OrderByClause.js +0 -39
  206. package/lib/esm/query/clauses/SelectClause.d.ts +0 -47
  207. package/lib/esm/query/clauses/SelectClause.js +0 -62
  208. package/lib/esm/query/clauses/SelectorBasedClause.d.ts +0 -25
  209. package/lib/esm/query/clauses/SelectorBasedClause.js +0 -44
  210. package/lib/esm/query/clauses/ValuesClause.d.ts +0 -21
  211. package/lib/esm/query/clauses/ValuesClause.js +0 -36
  212. package/lib/esm/query/clauses/WhereClause.d.ts +0 -46
  213. package/lib/esm/query/clauses/WhereClause.js +0 -71
  214. package/lib/esm/query/clauses/index.d.ts +0 -10
  215. package/lib/esm/query/clauses/index.js +0 -11
  216. package/lib/esm/query/types.d.ts +0 -2
  217. package/lib/esm/query/types.js +0 -2
  218. package/lib/esm/ram/RamClauseFactory.d.ts +0 -17
  219. package/lib/esm/ram/RamClauseFactory.js +0 -92
  220. package/lib/esm/ram/clauses/FromClause.d.ts +0 -7
  221. package/lib/esm/ram/clauses/FromClause.js +0 -11
  222. package/lib/esm/ram/clauses/InsertClause.d.ts +0 -7
  223. package/lib/esm/ram/clauses/InsertClause.js +0 -13
  224. package/lib/esm/ram/clauses/OrderByClause.d.ts +0 -7
  225. package/lib/esm/ram/clauses/OrderByClause.js +0 -39
  226. package/lib/esm/ram/clauses/SelectClause.d.ts +0 -7
  227. package/lib/esm/ram/clauses/SelectClause.js +0 -16
  228. package/lib/esm/ram/clauses/ValuesClause.d.ts +0 -7
  229. package/lib/esm/ram/clauses/ValuesClause.js +0 -12
  230. package/lib/esm/ram/clauses/WhereClause.d.ts +0 -7
  231. package/lib/esm/ram/clauses/WhereClause.js +0 -11
  232. package/lib/esm/ram/clauses/index.d.ts +0 -6
  233. package/lib/esm/ram/clauses/index.js +0 -7
  234. package/lib/esm/validators/ClauseSequenceValidator.d.ts +0 -28
  235. package/lib/esm/validators/ClauseSequenceValidator.js +0 -95
  236. package/lib/esm/validators/decorators.d.ts +0 -10
  237. package/lib/esm/validators/decorators.js +0 -24
  238. package/lib/esm/validators/index.d.ts +0 -2
  239. package/lib/esm/validators/index.js +0 -3
  240. package/lib/interfaces/Builder.cjs +0 -3
  241. package/lib/interfaces/Builder.d.ts +0 -16
  242. package/lib/model/IdentifiedBaseModel.cjs +0 -29
  243. package/lib/model/IdentifiedBaseModel.d.ts +0 -7
  244. package/lib/query/Clause.cjs +0 -86
  245. package/lib/query/Clause.d.ts +0 -50
  246. package/lib/query/ClauseFactory.cjs +0 -10
  247. package/lib/query/ClauseFactory.d.ts +0 -71
  248. package/lib/query/Query.cjs +0 -58
  249. package/lib/query/Query.d.ts +0 -43
  250. package/lib/query/clauses/FromClause.cjs +0 -63
  251. package/lib/query/clauses/FromClause.d.ts +0 -45
  252. package/lib/query/clauses/GroupByClause.cjs +0 -23
  253. package/lib/query/clauses/GroupByClause.d.ts +0 -21
  254. package/lib/query/clauses/InsertClause.cjs +0 -59
  255. package/lib/query/clauses/InsertClause.d.ts +0 -37
  256. package/lib/query/clauses/LimitClause.cjs +0 -31
  257. package/lib/query/clauses/LimitClause.d.ts +0 -29
  258. package/lib/query/clauses/OffsetClause.cjs +0 -23
  259. package/lib/query/clauses/OffsetClause.d.ts +0 -21
  260. package/lib/query/clauses/OrderByClause.cjs +0 -43
  261. package/lib/query/clauses/OrderByClause.d.ts +0 -37
  262. package/lib/query/clauses/SelectClause.cjs +0 -66
  263. package/lib/query/clauses/SelectClause.d.ts +0 -47
  264. package/lib/query/clauses/SelectorBasedClause.cjs +0 -48
  265. package/lib/query/clauses/SelectorBasedClause.d.ts +0 -25
  266. package/lib/query/clauses/ValuesClause.cjs +0 -40
  267. package/lib/query/clauses/ValuesClause.d.ts +0 -21
  268. package/lib/query/clauses/WhereClause.cjs +0 -75
  269. package/lib/query/clauses/WhereClause.d.ts +0 -46
  270. package/lib/query/clauses/index.cjs +0 -27
  271. package/lib/query/clauses/index.d.ts +0 -10
  272. package/lib/query/types.cjs +0 -3
  273. package/lib/query/types.d.ts +0 -2
  274. package/lib/ram/RamClauseFactory.cjs +0 -96
  275. package/lib/ram/RamClauseFactory.d.ts +0 -17
  276. package/lib/ram/clauses/FromClause.cjs +0 -15
  277. package/lib/ram/clauses/FromClause.d.ts +0 -7
  278. package/lib/ram/clauses/InsertClause.cjs +0 -17
  279. package/lib/ram/clauses/InsertClause.d.ts +0 -7
  280. package/lib/ram/clauses/OrderByClause.cjs +0 -43
  281. package/lib/ram/clauses/OrderByClause.d.ts +0 -7
  282. package/lib/ram/clauses/SelectClause.cjs +0 -20
  283. package/lib/ram/clauses/SelectClause.d.ts +0 -7
  284. package/lib/ram/clauses/ValuesClause.cjs +0 -16
  285. package/lib/ram/clauses/ValuesClause.d.ts +0 -7
  286. package/lib/ram/clauses/WhereClause.cjs +0 -15
  287. package/lib/ram/clauses/WhereClause.d.ts +0 -7
  288. package/lib/ram/clauses/index.cjs +0 -23
  289. package/lib/ram/clauses/index.d.ts +0 -6
  290. package/lib/validators/ClauseSequenceValidator.cjs +0 -98
  291. package/lib/validators/ClauseSequenceValidator.d.ts +0 -28
  292. package/lib/validators/decorators.cjs +0 -27
  293. package/lib/validators/decorators.d.ts +0 -10
  294. package/lib/validators/index.d.ts +0 -2
@@ -1,8 +1,20 @@
1
- import { DBKeys, InternalError, NotFoundError, Context, OperationKeys, DefaultRepositoryFlags, } from "@decaf-ts/db-decorators";
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { DBKeys, InternalError, NotFoundError, Context, OperationKeys, DefaultRepositoryFlags, modelToTransient, } from "@decaf-ts/db-decorators";
2
11
  import { Decoration, DefaultFlavour, Model, } from "@decaf-ts/decorator-validation";
3
12
  import { PersistenceKeys } from "./constants";
4
- import { Query } from "../query/Query";
5
13
  import { Repository } from "../repository/Repository";
14
+ import { Logging } from "@decaf-ts/logging";
15
+ import { final } from "../utils";
16
+ import { Dispatch } from "./Dispatch";
17
+ import { ObserverHandler } from "./ObserverHandler";
6
18
  Decoration.setFlavourResolver((obj) => {
7
19
  try {
8
20
  return (Adapter.flavourOf(Model.isModel(obj) ? obj.constructor : obj) ||
@@ -30,66 +42,93 @@ Decoration.setFlavourResolver((obj) => {
30
42
  */
31
43
  export class Adapter {
32
44
  static { this._cache = {}; }
45
+ get log() {
46
+ if (!this.logger)
47
+ this.logger = Logging.for(this);
48
+ return this.logger;
49
+ }
33
50
  get native() {
34
51
  return this._native;
35
52
  }
53
+ get alias() {
54
+ return this._alias || this.flavour;
55
+ }
36
56
  repository() {
37
57
  return Repository;
38
58
  }
39
- constructor(native, flavour) {
59
+ constructor(_native, flavour, _alias) {
60
+ this._native = _native;
40
61
  this.flavour = flavour;
41
- this._observers = [];
62
+ this._alias = _alias;
63
+ this.Context = (Context);
42
64
  if (this.flavour in Adapter._cache)
43
- throw new InternalError(`Persistence adapter flavour ${this.flavour} already registered`);
44
- this._native = native;
45
- Adapter._cache[this.flavour] = this;
46
- if (!Adapter._current)
65
+ throw new InternalError(`${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : ""} already registered`);
66
+ Adapter._cache[this.alias] = this;
67
+ this.log.info(`Created ${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : ""} persistence adapter`);
68
+ if (!Adapter._current) {
69
+ this.log.verbose(`Defined ${this.alias} persistence adapter as current`);
47
70
  Adapter._current = this;
71
+ }
72
+ }
73
+ Dispatch() {
74
+ return new Dispatch();
48
75
  }
49
- Query() {
50
- return new Query(this);
76
+ ObserverHandler() {
77
+ return new ObserverHandler();
51
78
  }
52
79
  isReserved(attr) {
53
80
  return !attr;
54
81
  }
55
- async context(operation, overrides, model) {
56
- const AdapterContext = class extends Context {
57
- constructor(obj) {
58
- super(obj);
59
- }
60
- };
61
- return new AdapterContext(Object.assign({}, DefaultRepositoryFlags, overrides, {
82
+ flags(operation, model, flags,
83
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
84
+ ...args) {
85
+ return Object.assign({}, DefaultRepositoryFlags, flags, {
62
86
  affectedTables: Repository.table(model),
63
87
  writeOperation: operation !== OperationKeys.READ,
64
88
  timestamp: new Date(),
65
89
  operation: operation,
66
- }));
90
+ });
91
+ }
92
+ async context(operation, overrides, model, ...args) {
93
+ this.log
94
+ .for(this.context)
95
+ .debug(`Creating new context for ${operation} operation on ${model.name} model with flags: ${JSON.stringify(overrides)}`);
96
+ return new this.Context(this.flags(operation, model, overrides, ...args));
67
97
  }
68
98
  prepare(model, pk) {
69
- const result = Object.entries(model).reduce((accum, [key, val]) => {
70
- // if (key === pk) return accum;
99
+ const log = this.log.for(this.prepare);
100
+ log.silly(`Preparing model ${model.constructor.name} before persisting`);
101
+ const split = modelToTransient(model);
102
+ const result = Object.entries(split.model).reduce((accum, [key, val]) => {
103
+ if (typeof val === "undefined")
104
+ return accum;
71
105
  const mappedProp = Repository.column(model, key);
72
106
  if (this.isReserved(mappedProp))
73
107
  throw new InternalError(`Property name ${mappedProp} is reserved`);
74
108
  accum[mappedProp] = val;
75
109
  return accum;
76
110
  }, {});
77
- if (model[PersistenceKeys.METADATA])
111
+ if (model[PersistenceKeys.METADATA]) {
112
+ log.silly(`Passing along persistence metadata for ${model[PersistenceKeys.METADATA]}`);
78
113
  Object.defineProperty(result, PersistenceKeys.METADATA, {
79
114
  enumerable: false,
80
115
  writable: false,
81
116
  configurable: true,
82
117
  value: model[PersistenceKeys.METADATA],
83
118
  });
119
+ }
84
120
  return {
85
121
  record: result,
86
122
  id: model[pk],
123
+ transient: split.transient,
87
124
  };
88
125
  }
89
- revert(obj, clazz, pk, id) {
126
+ revert(obj, clazz, pk, id, transient) {
127
+ const log = this.log.for(this.revert);
90
128
  const ob = {};
91
129
  ob[pk] = id;
92
130
  const m = (typeof clazz === "string" ? Model.build(ob, clazz) : new clazz(ob));
131
+ log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);
93
132
  const metadata = obj[PersistenceKeys.METADATA];
94
133
  const result = Object.keys(m).reduce((accum, key) => {
95
134
  if (key === pk)
@@ -97,42 +136,72 @@ export class Adapter {
97
136
  accum[key] = obj[Repository.column(accum, key)];
98
137
  return accum;
99
138
  }, m);
100
- if (metadata)
139
+ if (transient) {
140
+ log.verbose(`re-adding transient properties: ${Object.keys(transient).join(", ")}`);
141
+ Object.entries(transient).forEach(([key, val]) => {
142
+ if (key in result)
143
+ throw new InternalError(`Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`);
144
+ result[key] = val;
145
+ });
146
+ }
147
+ if (metadata) {
148
+ log.silly(`Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`);
101
149
  Object.defineProperty(result, PersistenceKeys.METADATA, {
102
150
  enumerable: false,
103
151
  configurable: false,
104
152
  writable: false,
105
153
  value: metadata,
106
154
  });
155
+ }
107
156
  return result;
108
157
  }
109
158
  async createAll(tableName, id, model, ...args) {
110
159
  if (id.length !== model.length)
111
160
  throw new InternalError("Ids and models must have the same length");
161
+ const log = this.log.for(this.createAll);
162
+ log.verbose(`Creating ${id.length} entries ${tableName} table`);
163
+ log.debug(`pks: ${id}`);
112
164
  return Promise.all(id.map((i, count) => this.create(tableName, i, model[count], ...args)));
113
165
  }
114
166
  async readAll(tableName, id, ...args) {
167
+ const log = this.log.for(this.readAll);
168
+ log.verbose(`Reading ${id.length} entries ${tableName} table`);
169
+ log.debug(`pks: ${id}`);
115
170
  return Promise.all(id.map((i) => this.read(tableName, i, ...args)));
116
171
  }
117
172
  async updateAll(tableName, id, model, ...args) {
118
173
  if (id.length !== model.length)
119
174
  throw new InternalError("Ids and models must have the same length");
175
+ const log = this.log.for(this.updateAll);
176
+ log.verbose(`Updating ${id.length} entries ${tableName} table`);
177
+ log.debug(`pks: ${id}`);
120
178
  return Promise.all(id.map((i, count) => this.update(tableName, i, model[count], ...args)));
121
179
  }
122
180
  async deleteAll(tableName, id, ...args) {
181
+ const log = this.log.for(this.createAll);
182
+ log.verbose(`Deleting ${id.length} entries ${tableName} table`);
183
+ log.debug(`pks: ${id}`);
123
184
  return Promise.all(id.map((i) => this.delete(tableName, i, ...args)));
124
185
  }
125
186
  /**
126
- * @summary Registers an {@link Observer}
127
- * @param {Observer} observer
128
187
  *
129
188
  * @see {Observable#observe}
130
189
  */
131
- observe(observer) {
132
- const index = this._observers.indexOf(observer);
133
- if (index !== -1)
134
- throw new InternalError("Observer already registered");
135
- this._observers.push(observer);
190
+ observe(observer, filter) {
191
+ if (!this.observerHandler)
192
+ Object.defineProperty(this, "observerHandler", {
193
+ value: this.ObserverHandler(),
194
+ writable: false,
195
+ });
196
+ this.observerHandler.observe(observer, filter);
197
+ this.log
198
+ .for(this.observe)
199
+ .verbose(`Registering new observer ${observer.toString()}`);
200
+ if (!this.dispatch) {
201
+ this.log.for(this.observe).info(`Creating dispatch for ${this.alias}`);
202
+ this.dispatch = this.Dispatch();
203
+ this.dispatch.observe(this);
204
+ }
136
205
  }
137
206
  /**
138
207
  * @summary Unregisters an {@link Observer}
@@ -141,21 +210,22 @@ export class Adapter {
141
210
  * @see {Observable#unObserve}
142
211
  */
143
212
  unObserve(observer) {
144
- const index = this._observers.indexOf(observer);
145
- if (index === -1)
146
- throw new InternalError("Failed to find Observer");
147
- this._observers.splice(index, 1);
213
+ if (!this.observerHandler)
214
+ throw new InternalError("ObserverHandler not initialized. Did you register any observables?");
215
+ this.observerHandler.unObserve(observer);
216
+ this.log
217
+ .for(this.unObserve)
218
+ .verbose(`Observer ${observer.toString()} removed`);
148
219
  }
149
- /**
150
- * @summary calls all registered {@link Observer}s to update themselves
151
- * @param {any[]} [args] optional arguments to be passed to the {@link Observer#refresh} method
152
- */
153
- async updateObservers(...args) {
154
- const results = await Promise.allSettled(this._observers.map((o) => o.refresh(...args)));
155
- results.forEach((result, i) => {
156
- if (result.status === "rejected")
157
- console.warn(`Failed to update observable ${this._observers[i]}: ${result.reason}`);
158
- });
220
+ async updateObservers(table, event, id, ...args) {
221
+ if (!this.observerHandler)
222
+ throw new InternalError("ObserverHandler not initialized. Did you register any observables?");
223
+ const log = this.log.for(this.updateObservers);
224
+ log.verbose(`Updating ${this.observerHandler.count()} observers for adapter ${this.alias}`);
225
+ await this.observerHandler.updateObservers(this.log, table, event, id, ...args);
226
+ }
227
+ async refresh(table, event, id, ...args) {
228
+ return this.updateObservers(table, event, id, ...args);
159
229
  }
160
230
  toString() {
161
231
  return `${this.flavour} persistence Adapter`;
@@ -209,4 +279,22 @@ export class Adapter {
209
279
  }
210
280
  }
211
281
  }
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Adapter.js","sourceRoot":"","sources":["../../../src/persistence/Adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseError,\n  DBKeys,\n  InternalError,\n  NotFoundError,\n  Context,\n  OperationKeys,\n  RepositoryFlags,\n  Contextual,\n  DefaultRepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { Observer } from \"../interfaces/Observer\";\nimport {\n  Constructor,\n  Decoration,\n  DefaultFlavour,\n  Model,\n  ModelConstructor,\n  ModelRegistry,\n} from \"@decaf-ts/decorator-validation\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { RawExecutor } from \"../interfaces/RawExecutor\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { PersistenceKeys } from \"./constants\";\nimport { Query } from \"../query/Query\";\nimport { Statement } from \"../query/Statement\";\nimport { ClauseFactory } from \"../query/ClauseFactory\";\nimport { Condition } from \"../query/Condition\";\nimport { Repository } from \"../repository/Repository\";\nimport { Sequence } from \"./Sequence\";\nimport { ErrorParser } from \"../interfaces\";\n\nDecoration.setFlavourResolver((obj: object) => {\n  try {\n    return (\n      Adapter.flavourOf(Model.isModel(obj) ? obj.constructor : (obj as any)) ||\n      DefaultFlavour\n    );\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    return DefaultFlavour;\n  }\n});\n\n/**\n * @summary Abstract Decaf-ts Persistence Adapter Class\n * @description Offers the base implementation for all Adapter Classes\n * and manages them various registered {@link Adapter}s\n *\n * @typedef Y the underlying persistence object type or the required config to set it up\n * @typedef Q The query object the adapter uses\n *\n * @param {Y} native the underlying persistence object\n * @param {string} flavour the under witch the persistence adapter should be stored\n *\n * @class Adapter\n * @implements RawExecutor\n * @implements Observable\n */\nexport abstract class Adapter<\n    Y,\n    Q,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >\n  implements RawExecutor<Q>, Observable, Contextual<F>, ErrorParser\n{\n  private static _current: Adapter<any, any, any, any>;\n  private static _cache: Record<string, Adapter<any, any, any, any>> = {};\n\n  protected readonly _observers: Observer[] = [];\n  private readonly _native: Y;\n\n  get native() {\n    return this._native;\n  }\n\n  repository<M extends Model>(): Constructor<\n    Repository<M, Q, Adapter<Y, Q, F, C>, F, C>\n  > {\n    return Repository;\n  }\n\n  protected constructor(\n    native: Y,\n    readonly flavour: string\n  ) {\n    if (this.flavour in Adapter._cache)\n      throw new InternalError(\n        `Persistence adapter flavour ${this.flavour} already registered`\n      );\n    this._native = native;\n    Adapter._cache[this.flavour] = this;\n    if (!Adapter._current) Adapter._current = this;\n  }\n\n  Query<M extends Model>(): Query<Q, M> {\n    return new Query(this);\n  }\n\n  abstract parseCondition(condition: Condition): Q;\n\n  abstract get Statement(): Statement<Q>;\n\n  abstract get Clauses(): ClauseFactory<Y, Q, typeof this>;\n\n  protected isReserved(attr: string) {\n    return !attr;\n  }\n\n  abstract parseError(err: Error): BaseError;\n\n  abstract initialize(...args: any[]): Promise<void>;\n\n  abstract Sequence(options: SequenceOptions): Promise<Sequence>;\n\n  async context<\n    M extends Model,\n    C extends Context<F>,\n    F extends RepositoryFlags,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>\n  ): Promise<C> {\n    const AdapterContext = class extends Context<F> {\n      constructor(obj: F) {\n        super(obj);\n      }\n    };\n    return new AdapterContext(\n      Object.assign({}, DefaultRepositoryFlags, overrides, {\n        affectedTables: Repository.table(model),\n        writeOperation: operation !== OperationKeys.READ,\n        timestamp: new Date(),\n        operation: operation,\n      }) as F\n    ) as C;\n  }\n\n  prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): {\n    record: Record<string, any>;\n    id: string;\n  } {\n    const result = Object.entries(model).reduce(\n      (accum: Record<string, any>, [key, val]) => {\n        // if (key === pk) return accum;\n        const mappedProp = Repository.column(model, key);\n        if (this.isReserved(mappedProp))\n          throw new InternalError(`Property name ${mappedProp} is reserved`);\n        accum[mappedProp] = val;\n        return accum;\n      },\n      {}\n    );\n    if ((model as any)[PersistenceKeys.METADATA])\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    return {\n      record: result,\n      id: model[pk] as string,\n    };\n  }\n\n  revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint\n  ): M {\n    const ob: Record<string, any> = {};\n    ob[pk as string] = id;\n    const m = (\n      typeof clazz === \"string\" ? Model.build(ob, clazz) : new clazz(ob)\n    ) as M;\n    const metadata = obj[PersistenceKeys.METADATA];\n    const result = Object.keys(m).reduce((accum: M, key) => {\n      if (key === pk) return accum;\n      (accum as Record<string, any>)[key] = obj[Repository.column(accum, key)];\n      return accum;\n    }, m);\n    if (metadata)\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        configurable: false,\n        writable: false,\n        value: metadata,\n      });\n    return result;\n  }\n\n  abstract create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    return Promise.all(\n      id.map((i, count) => this.create(tableName, i, model[count], ...args))\n    );\n  }\n\n  abstract read(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async readAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    return Promise.all(id.map((i) => this.read(tableName, i, ...args)));\n  }\n\n  abstract update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async updateAll(\n    tableName: string,\n    id: string[] | number[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    return Promise.all(\n      id.map((i, count) => this.update(tableName, i, model[count], ...args))\n    );\n  }\n\n  abstract delete(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async deleteAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    return Promise.all(id.map((i) => this.delete(tableName, i, ...args)));\n  }\n\n  abstract raw<R>(rawInput: Q, process: boolean, ...args: any[]): Promise<R>;\n\n  /**\n   * @summary Registers an {@link Observer}\n   * @param {Observer} observer\n   *\n   * @see {Observable#observe}\n   */\n  observe(observer: Observer): void {\n    const index = this._observers.indexOf(observer);\n    if (index !== -1) throw new InternalError(\"Observer already registered\");\n    this._observers.push(observer);\n  }\n\n  /**\n   * @summary Unregisters an {@link Observer}\n   * @param {Observer} observer\n   *\n   * @see {Observable#unObserve}\n   */\n  unObserve(observer: Observer): void {\n    const index = this._observers.indexOf(observer);\n    if (index === -1) throw new InternalError(\"Failed to find Observer\");\n    this._observers.splice(index, 1);\n  }\n\n  /**\n   * @summary calls all registered {@link Observer}s to update themselves\n   * @param {any[]} [args] optional arguments to be passed to the {@link Observer#refresh} method\n   */\n  async updateObservers(...args: any[]): Promise<void> {\n    const results = await Promise.allSettled(\n      this._observers.map((o) => o.refresh(...args))\n    );\n    results.forEach((result, i) => {\n      if (result.status === \"rejected\")\n        console.warn(\n          `Failed to update observable ${this._observers[i]}: ${result.reason}`\n        );\n    });\n  }\n\n  toString() {\n    return `${this.flavour} persistence Adapter`;\n  }\n\n  static flavourOf<M extends Model>(model: Constructor<M>): string {\n    return (\n      Reflect.getMetadata(this.key(PersistenceKeys.ADAPTER), model) ||\n      this.current.flavour\n    );\n  }\n\n  static get current() {\n    if (!Adapter._current)\n      throw new InternalError(\n        `No persistence flavour set. Please initialize your adapter`\n      );\n    return Adapter._current;\n  }\n\n  static get<Y, Q, C extends Context<F>, F extends RepositoryFlags>(\n    flavour: any\n  ): Adapter<Y, Q, F, C> | undefined {\n    if (flavour in this._cache) return this._cache[flavour];\n    throw new InternalError(`No Adapter registered under ${flavour}.`);\n  }\n\n  static setCurrent(flavour: string) {\n    const adapter = Adapter.get(flavour);\n    if (!adapter)\n      throw new NotFoundError(`No persistence flavour ${flavour} registered`);\n    this._current = adapter;\n  }\n\n  static key(key: string) {\n    return Repository.key(key);\n  }\n\n  static models<M extends Model>(flavour: string) {\n    try {\n      const registry = (Model as any).getRegistry() as ModelRegistry<any>;\n      const cache = (\n        registry as unknown as { cache: Record<string, ModelConstructor<any>> }\n      ).cache;\n      const managedModels: ModelConstructor<any>[] = Object.values(cache)\n        .map((m: ModelConstructor<M>) => {\n          let f = Reflect.getMetadata(\n            Adapter.key(PersistenceKeys.ADAPTER),\n            m as ModelConstructor<any>\n          );\n          if (f && f === flavour) return m;\n          if (!f) {\n            const repo = Reflect.getMetadata(\n              Repository.key(DBKeys.REPOSITORY),\n              m as ModelConstructor<any>\n            );\n            if (!repo) return;\n            const repository = Repository.forModel(m);\n\n            f = Reflect.getMetadata(\n              Adapter.key(PersistenceKeys.ADAPTER),\n              repository\n            );\n            return f;\n          }\n        })\n        .filter((m) => !!m);\n      return managedModels;\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n}\n"]}
282
+ __decorate([
283
+ final(),
284
+ __metadata("design:type", Function),
285
+ __metadata("design:paramtypes", [String, Object, Object, Object]),
286
+ __metadata("design:returntype", Promise)
287
+ ], Adapter.prototype, "context", null);
288
+ __decorate([
289
+ final(),
290
+ __metadata("design:type", Function),
291
+ __metadata("design:paramtypes", [Object, Function]),
292
+ __metadata("design:returntype", void 0)
293
+ ], Adapter.prototype, "observe", null);
294
+ __decorate([
295
+ final(),
296
+ __metadata("design:type", Function),
297
+ __metadata("design:paramtypes", [Object]),
298
+ __metadata("design:returntype", void 0)
299
+ ], Adapter.prototype, "unObserve", null);
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Adapter.js","sourceRoot":"","sources":["../../../src/persistence/Adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseError,\n  DBKeys,\n  InternalError,\n  NotFoundError,\n  Context,\n  OperationKeys,\n  RepositoryFlags,\n  DefaultRepositoryFlags,\n  Contextual,\n  BulkCrudOperationKeys,\n  modelToTransient,\n} from \"@decaf-ts/db-decorators\";\nimport { type Observer } from \"../interfaces/Observer\";\nimport {\n  type Constructor,\n  Decoration,\n  DefaultFlavour,\n  Model,\n  ModelConstructor,\n  ModelRegistry,\n} from \"@decaf-ts/decorator-validation\";\nimport { SequenceOptions } from \"../interfaces/SequenceOptions\";\nimport { RawExecutor } from \"../interfaces/RawExecutor\";\nimport { Observable } from \"../interfaces/Observable\";\nimport { PersistenceKeys } from \"./constants\";\nimport { Repository } from \"../repository/Repository\";\nimport { Sequence } from \"./Sequence\";\nimport { ErrorParser } from \"../interfaces\";\nimport { Statement } from \"../query/Statement\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { final } from \"../utils\";\nimport { Dispatch } from \"./Dispatch\";\nimport { type EventIds, type ObserverFilter } from \"./types\";\nimport { ObserverHandler } from \"./ObserverHandler\";\n\nDecoration.setFlavourResolver((obj: object) => {\n  try {\n    return (\n      Adapter.flavourOf(Model.isModel(obj) ? obj.constructor : (obj as any)) ||\n      DefaultFlavour\n    );\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    return DefaultFlavour;\n  }\n});\n\n/**\n * @summary Abstract Decaf-ts Persistence Adapter Class\n * @description Offers the base implementation for all Adapter Classes\n * and manages them various registered {@link Adapter}s\n *\n * @typedef Y the underlying persistence object type or the required config to set it up\n * @typedef Q The query object the adapter uses\n *\n * @param {Y} native the underlying persistence object\n * @param {string} flavour the under witch the persistence adapter should be stored\n *\n * @class Adapter\n * @implements RawExecutor\n * @implements Observable\n */\nexport abstract class Adapter<\n    Y,\n    Q,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >\n  implements RawExecutor<Q>, Contextual<F, C>, Observable, Observer, ErrorParser\n{\n  private static _current: Adapter<any, any, any, any>;\n  private static _cache: Record<string, Adapter<any, any, any, any>> = {};\n\n  private logger!: Logger;\n\n  protected dispatch?: Dispatch<Y>;\n\n  protected readonly observerHandler?: ObserverHandler;\n\n  protected get log() {\n    if (!this.logger) this.logger = Logging.for(this as any);\n    return this.logger;\n  }\n\n  get native() {\n    return this._native;\n  }\n\n  get alias() {\n    return this._alias || this.flavour;\n  }\n\n  repository<M extends Model>(): Constructor<\n    Repository<M, Q, Adapter<Y, Q, F, C>, F, C>\n  > {\n    return Repository;\n  }\n\n  protected constructor(\n    private readonly _native: Y,\n    readonly flavour: string,\n    private readonly _alias?: string\n  ) {\n    if (this.flavour in Adapter._cache)\n      throw new InternalError(\n        `${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} already registered`\n      );\n    Adapter._cache[this.alias] = this;\n    this.log.info(\n      `Created ${this.alias} persistence adapter ${this._alias ? `(${this.flavour}) ` : \"\"} persistence adapter`\n    );\n    if (!Adapter._current) {\n      this.log.verbose(`Defined ${this.alias} persistence adapter as current`);\n      Adapter._current = this;\n    }\n  }\n\n  abstract Statement<M extends Model>(): Statement<Q, M, any>;\n\n  protected Dispatch(): Dispatch<Y> {\n    return new Dispatch();\n  }\n\n  protected ObserverHandler() {\n    return new ObserverHandler();\n  }\n\n  protected isReserved(attr: string) {\n    return !attr;\n  }\n\n  abstract parseError(err: Error): BaseError;\n\n  abstract initialize(...args: any[]): Promise<void>;\n\n  abstract Sequence(options: SequenceOptions): Promise<Sequence>;\n\n  protected flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<F>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): F {\n    return Object.assign({}, DefaultRepositoryFlags, flags, {\n      affectedTables: Repository.table(model),\n      writeOperation: operation !== OperationKeys.READ,\n      timestamp: new Date(),\n      operation: operation,\n    }) as F;\n  }\n\n  protected Context: Constructor<C> = Context<F> as any;\n\n  @final()\n  async context<M extends Model>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>,\n    ...args: any[]\n  ): Promise<C> {\n    this.log\n      .for(this.context)\n      .debug(\n        `Creating new context for ${operation} operation on ${model.name} model with flags: ${JSON.stringify(overrides)}`\n      );\n    return new this.Context(\n      this.flags(operation, model, overrides, ...args)\n    ) as unknown as C;\n  }\n\n  prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const log = this.log.for(this.prepare);\n    log.silly(`Preparing model ${model.constructor.name} before persisting`);\n    const split = modelToTransient(model);\n    const result = Object.entries(split.model).reduce(\n      (accum: Record<string, any>, [key, val]) => {\n        if (typeof val === \"undefined\") return accum;\n        const mappedProp = Repository.column(model, key);\n        if (this.isReserved(mappedProp))\n          throw new InternalError(`Property name ${mappedProp} is reserved`);\n        accum[mappedProp] = val;\n        return accum;\n      },\n      {}\n    );\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    return {\n      record: result,\n      id: model[pk] as string,\n      transient: split.transient,\n    };\n  }\n\n  revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint,\n    transient?: Record<string, any>\n  ): M {\n    const log = this.log.for(this.revert);\n    const ob: Record<string, any> = {};\n    ob[pk as string] = id;\n    const m = (\n      typeof clazz === \"string\" ? Model.build(ob, clazz) : new clazz(ob)\n    ) as M;\n    log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);\n    const metadata = obj[PersistenceKeys.METADATA];\n    const result = Object.keys(m).reduce((accum: M, key) => {\n      if (key === pk) return accum;\n      (accum as Record<string, any>)[key] = obj[Repository.column(accum, key)];\n      return accum;\n    }, m);\n\n    if (transient) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient).forEach(([key, val]) => {\n        if (key in result)\n          throw new InternalError(\n            `Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`\n          );\n        result[key as keyof M] = val;\n      });\n    }\n\n    if (metadata) {\n      log.silly(\n        `Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        configurable: false,\n        writable: false,\n        value: metadata,\n      });\n    }\n\n    return result;\n  }\n\n  abstract create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.createAll);\n    log.verbose(`Creating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.create(tableName, i, model[count], ...args))\n    );\n  }\n\n  abstract read(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async readAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.readAll);\n    log.verbose(`Reading ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.read(tableName, i, ...args)));\n  }\n\n  abstract update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async updateAll(\n    tableName: string,\n    id: string[] | number[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n    const log = this.log.for(this.updateAll);\n    log.verbose(`Updating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(\n      id.map((i, count) => this.update(tableName, i, model[count], ...args))\n    );\n  }\n\n  abstract delete(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  async deleteAll(\n    tableName: string,\n    id: (string | number | bigint)[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.createAll);\n    log.verbose(`Deleting ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n    return Promise.all(id.map((i) => this.delete(tableName, i, ...args)));\n  }\n\n  abstract raw<R>(rawInput: Q, ...args: any[]): Promise<R>;\n\n  /**\n   *\n   * @see {Observable#observe}\n   */\n  @final()\n  observe(observer: Observer, filter?: ObserverFilter): void {\n    if (!this.observerHandler)\n      Object.defineProperty(this, \"observerHandler\", {\n        value: this.ObserverHandler(),\n        writable: false,\n      });\n    this.observerHandler!.observe(observer, filter);\n    this.log\n      .for(this.observe)\n      .verbose(`Registering new observer ${observer.toString()}`);\n    if (!this.dispatch) {\n      this.log.for(this.observe).info(`Creating dispatch for ${this.alias}`);\n      this.dispatch = this.Dispatch();\n      this.dispatch.observe(this);\n    }\n  }\n\n  /**\n   * @summary Unregisters an {@link Observer}\n   * @param {Observer} observer\n   *\n   * @see {Observable#unObserve}\n   */\n  @final()\n  unObserve(observer: Observer): void {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    this.observerHandler.unObserve(observer);\n    this.log\n      .for(this.unObserve)\n      .verbose(`Observer ${observer.toString()} removed`);\n  }\n\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ): Promise<void> {\n    if (!this.observerHandler)\n      throw new InternalError(\n        \"ObserverHandler not initialized. Did you register any observables?\"\n      );\n    const log = this.log.for(this.updateObservers);\n    log.verbose(\n      `Updating ${this.observerHandler.count()} observers for adapter ${this.alias}`\n    );\n    await this.observerHandler.updateObservers(\n      this.log,\n      table,\n      event,\n      id,\n      ...args\n    );\n  }\n\n  async refresh(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds,\n    ...args: any[]\n  ) {\n    return this.updateObservers(table, event, id, ...args);\n  }\n\n  toString() {\n    return `${this.flavour} persistence Adapter`;\n  }\n\n  static flavourOf<M extends Model>(model: Constructor<M>): string {\n    return (\n      Reflect.getMetadata(this.key(PersistenceKeys.ADAPTER), model) ||\n      this.current.flavour\n    );\n  }\n\n  static get current() {\n    if (!Adapter._current)\n      throw new InternalError(\n        `No persistence flavour set. Please initialize your adapter`\n      );\n    return Adapter._current;\n  }\n\n  static get<Y, Q, C extends Context<F>, F extends RepositoryFlags>(\n    flavour: any\n  ): Adapter<Y, Q, F, C> | undefined {\n    if (flavour in this._cache) return this._cache[flavour];\n    throw new InternalError(`No Adapter registered under ${flavour}.`);\n  }\n\n  static setCurrent(flavour: string) {\n    const adapter = Adapter.get(flavour);\n    if (!adapter)\n      throw new NotFoundError(`No persistence flavour ${flavour} registered`);\n    this._current = adapter;\n  }\n\n  static key(key: string) {\n    return Repository.key(key);\n  }\n\n  static models<M extends Model>(flavour: string) {\n    try {\n      const registry = (Model as any).getRegistry() as ModelRegistry<any>;\n      const cache = (\n        registry as unknown as { cache: Record<string, ModelConstructor<any>> }\n      ).cache;\n      const managedModels: ModelConstructor<any>[] = Object.values(cache)\n        .map((m: ModelConstructor<M>) => {\n          let f = Reflect.getMetadata(\n            Adapter.key(PersistenceKeys.ADAPTER),\n            m as ModelConstructor<any>\n          );\n          if (f && f === flavour) return m;\n          if (!f) {\n            const repo = Reflect.getMetadata(\n              Repository.key(DBKeys.REPOSITORY),\n              m as ModelConstructor<any>\n            );\n            if (!repo) return;\n            const repository = Repository.forModel(m);\n\n            f = Reflect.getMetadata(\n              Adapter.key(PersistenceKeys.ADAPTER),\n              repository\n            );\n            return f;\n          }\n        })\n        .filter((m) => !!m);\n      return managedModels;\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n}\n"]}
@@ -0,0 +1,18 @@
1
+ import { OperationKeys, BulkCrudOperationKeys } from "@decaf-ts/db-decorators";
2
+ import { ModelConstructor } from "@decaf-ts/decorator-validation";
3
+ import { Observable, Observer } from "../interfaces";
4
+ import { Adapter } from "./Adapter";
5
+ import { Logger } from "@decaf-ts/logging";
6
+ import { EventIds } from "./types";
7
+ export declare class Dispatch<Y> implements Observable {
8
+ protected adapter?: Adapter<Y, any, any, any>;
9
+ protected native?: Y;
10
+ protected models: ModelConstructor<any>[];
11
+ private logger;
12
+ protected get log(): Logger;
13
+ constructor();
14
+ protected initialize(): void;
15
+ observe(observer: Adapter<Y, any, any, any>): void;
16
+ unObserve(observer: Observer): void;
17
+ updateObservers(table: string, event: OperationKeys | BulkCrudOperationKeys | string, id: EventIds): Promise<void>;
18
+ }
@@ -0,0 +1,89 @@
1
+ import { InternalError, OperationKeys, BulkCrudOperationKeys, } from "@decaf-ts/db-decorators";
2
+ import { Adapter } from "./Adapter";
3
+ import { UnsupportedError } from "./errors";
4
+ import { Logging } from "@decaf-ts/logging";
5
+ export class Dispatch {
6
+ get log() {
7
+ if (!this.logger)
8
+ this.logger = Logging.for(this).for(this.adapter);
9
+ return this.logger;
10
+ }
11
+ constructor() { }
12
+ initialize() {
13
+ if (!this.adapter)
14
+ throw new InternalError(`No adapter observed for dispatch`);
15
+ const adapter = this.adapter;
16
+ [
17
+ OperationKeys.CREATE,
18
+ OperationKeys.UPDATE,
19
+ OperationKeys.DELETE,
20
+ BulkCrudOperationKeys.CREATE_ALL,
21
+ BulkCrudOperationKeys.UPDATE_ALL,
22
+ BulkCrudOperationKeys.DELETE_ALL,
23
+ ].forEach((method) => {
24
+ if (!adapter[method])
25
+ throw new InternalError(`Method ${method} not found in ${adapter.alias} adapter to bind Observables Dispatch`);
26
+ let descriptor = Object.getOwnPropertyDescriptor(adapter, method);
27
+ let proto = adapter;
28
+ while (!descriptor && proto !== Object.prototype) {
29
+ proto = Object.getPrototypeOf(proto);
30
+ descriptor = Object.getOwnPropertyDescriptor(proto, method);
31
+ }
32
+ if (!descriptor || !descriptor.writable) {
33
+ this.log.error(`Could not find method ${method} to bind Observables Dispatch`);
34
+ return;
35
+ }
36
+ function bulkToSingle(method) {
37
+ switch (method) {
38
+ case BulkCrudOperationKeys.CREATE_ALL:
39
+ return OperationKeys.CREATE;
40
+ case BulkCrudOperationKeys.UPDATE_ALL:
41
+ return OperationKeys.UPDATE;
42
+ case BulkCrudOperationKeys.DELETE_ALL:
43
+ return OperationKeys.DELETE;
44
+ default:
45
+ return method;
46
+ }
47
+ }
48
+ // @ts-expect-error because there are read only properties
49
+ adapter[method] = new Proxy(adapter[method], {
50
+ apply: async (target, thisArg, argArray) => {
51
+ const [tableName, ids] = argArray;
52
+ const result = await target.apply(thisArg, argArray);
53
+ this.updateObservers(tableName, bulkToSingle(method), ids)
54
+ .then(() => {
55
+ this.log.verbose(`Observer refresh dispatched by ${method} for ${tableName}`);
56
+ this.log.debug(`pks: ${ids}`);
57
+ })
58
+ .catch((e) => this.log.error(`Failed to dispatch observer refresh for ${method} on ${tableName}: ${e}`));
59
+ return result;
60
+ },
61
+ });
62
+ });
63
+ }
64
+ observe(observer) {
65
+ if (!(observer instanceof Adapter))
66
+ throw new UnsupportedError("Only Adapters can be observed by dispatch");
67
+ this.adapter = observer;
68
+ this.native = observer.native;
69
+ this.models = Adapter.models(this.adapter.alias);
70
+ this.initialize();
71
+ this.log.verbose(`Dispatch initialized for ${this.adapter.alias} adapter`);
72
+ }
73
+ unObserve(observer) {
74
+ if (this.adapter !== observer)
75
+ throw new UnsupportedError("Only the adapter that was used to observe can be unobserved");
76
+ this.adapter = undefined;
77
+ }
78
+ async updateObservers(table, event, id) {
79
+ if (!this.adapter)
80
+ throw new InternalError(`No adapter observed for dispatch`);
81
+ try {
82
+ await this.adapter.refresh(table, event, id);
83
+ }
84
+ catch (e) {
85
+ throw new InternalError(`Failed to refresh dispatch: ${e}`);
86
+ }
87
+ }
88
+ }
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Dispatch.js","sourceRoot":"","sources":["../../../src/persistence/Dispatch.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  InternalError,\n  OperationKeys,\n  BulkCrudOperationKeys,\n} from \"@decaf-ts/db-decorators\";\nimport { ModelConstructor } from \"@decaf-ts/decorator-validation\";\nimport { Observable, Observer } from \"../interfaces\";\nimport { Adapter } from \"./Adapter\";\nimport { UnsupportedError } from \"./errors\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { EventIds } from \"./types\";\n\nexport class Dispatch<Y> implements Observable {\n  protected adapter?: Adapter<Y, any, any, any>;\n  protected native?: Y;\n  protected models!: ModelConstructor<any>[];\n\n  private logger!: Logger;\n\n  protected get log() {\n    if (!this.logger)\n      this.logger = Logging.for(this as any).for(this.adapter as any);\n    return this.logger;\n  }\n\n  constructor() {}\n\n  protected initialize(): void {\n    if (!this.adapter)\n      throw new InternalError(`No adapter observed for dispatch`);\n    const adapter = this.adapter as Adapter<Y, any, any, any>;\n    (\n      [\n        OperationKeys.CREATE,\n        OperationKeys.UPDATE,\n        OperationKeys.DELETE,\n        BulkCrudOperationKeys.CREATE_ALL,\n        BulkCrudOperationKeys.UPDATE_ALL,\n        BulkCrudOperationKeys.DELETE_ALL,\n      ] as (keyof Adapter<Y, any, any, any>)[]\n    ).forEach((method) => {\n      if (!adapter[method])\n        throw new InternalError(\n          `Method ${method} not found in ${adapter.alias} adapter to bind Observables Dispatch`\n        );\n\n      let descriptor = Object.getOwnPropertyDescriptor(adapter, method);\n      let proto: any = adapter;\n      while (!descriptor && proto !== Object.prototype) {\n        proto = Object.getPrototypeOf(proto);\n        descriptor = Object.getOwnPropertyDescriptor(proto, method);\n      }\n\n      if (!descriptor || !descriptor.writable) {\n        this.log.error(\n          `Could not find method ${method} to bind Observables Dispatch`\n        );\n        return;\n      }\n      function bulkToSingle(method: string) {\n        switch (method) {\n          case BulkCrudOperationKeys.CREATE_ALL:\n            return OperationKeys.CREATE;\n          case BulkCrudOperationKeys.UPDATE_ALL:\n            return OperationKeys.UPDATE;\n          case BulkCrudOperationKeys.DELETE_ALL:\n            return OperationKeys.DELETE;\n          default:\n            return method;\n        }\n      }\n      // @ts-expect-error because there are read only properties\n      adapter[method] = new Proxy(adapter[method], {\n        apply: async (target: any, thisArg, argArray: any[]) => {\n          const [tableName, ids] = argArray;\n          const result = await target.apply(thisArg, argArray);\n          this.updateObservers(tableName, bulkToSingle(method), ids as EventIds)\n            .then(() => {\n              this.log.verbose(\n                `Observer refresh dispatched by ${method} for ${tableName}`\n              );\n              this.log.debug(`pks: ${ids}`);\n            })\n            .catch((e: unknown) =>\n              this.log.error(\n                `Failed to dispatch observer refresh for ${method} on ${tableName}: ${e}`\n              )\n            );\n          return result;\n        },\n      });\n    });\n  }\n\n  observe(observer: Adapter<Y, any, any, any>): void {\n    if (!(observer instanceof Adapter))\n      throw new UnsupportedError(\"Only Adapters can be observed by dispatch\");\n    this.adapter = observer;\n    this.native = observer.native;\n    this.models = Adapter.models(this.adapter.alias);\n    this.initialize();\n    this.log.verbose(`Dispatch initialized for ${this.adapter.alias} adapter`);\n  }\n\n  unObserve(observer: Observer): void {\n    if (this.adapter !== observer)\n      throw new UnsupportedError(\n        \"Only the adapter that was used to observe can be unobserved\"\n      );\n    this.adapter = undefined;\n  }\n\n  async updateObservers(\n    table: string,\n    event: OperationKeys | BulkCrudOperationKeys | string,\n    id: EventIds\n  ): Promise<void> {\n    if (!this.adapter)\n      throw new InternalError(`No adapter observed for dispatch`);\n    try {\n      await this.adapter.refresh(table, event, id);\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ import { Observable, Observer } from "../interfaces";
2
+ import { EventIds, ObserverFilter } from "./types";
3
+ import { BulkCrudOperationKeys, OperationKeys } from "@decaf-ts/db-decorators";
4
+ import { Logger } from "@decaf-ts/logging";
5
+ export declare class ObserverHandler implements Observable {
6
+ protected readonly observers: {
7
+ observer: Observer;
8
+ filter?: ObserverFilter;
9
+ }[];
10
+ count(): number;
11
+ observe(observer: Observer, filter?: ObserverFilter): void;
12
+ unObserve(observer: Observer): void;
13
+ updateObservers(log: Logger, table: string, event: OperationKeys | BulkCrudOperationKeys | string, id: EventIds, ...args: any[]): Promise<void>;
14
+ }
@@ -0,0 +1,42 @@
1
+ import { InternalError, } from "@decaf-ts/db-decorators";
2
+ export class ObserverHandler {
3
+ constructor() {
4
+ this.observers = [];
5
+ }
6
+ count() {
7
+ return this.observers.length;
8
+ }
9
+ observe(observer, filter) {
10
+ const index = this.observers.map((o) => o.observer).indexOf(observer);
11
+ if (index !== -1)
12
+ throw new InternalError("Observer already registered");
13
+ this.observers.push({ observer: observer, filter: filter });
14
+ }
15
+ unObserve(observer) {
16
+ const index = this.observers.map((o) => o.observer).indexOf(observer);
17
+ if (index === -1)
18
+ throw new InternalError("Failed to find Observer");
19
+ this.observers.splice(index, 1);
20
+ }
21
+ async updateObservers(log, table, event, id, ...args) {
22
+ const results = await Promise.allSettled(this.observers
23
+ .filter((o) => {
24
+ const { filter } = o;
25
+ if (!filter)
26
+ return true;
27
+ try {
28
+ return filter(table, event, id);
29
+ }
30
+ catch (e) {
31
+ log.error(`Failed to filter observer ${o.observer.toString()}: ${e}`);
32
+ return false;
33
+ }
34
+ })
35
+ .map((o) => o.observer.refresh(table, event, id, ...args)));
36
+ results.forEach((result, i) => {
37
+ if (result.status === "rejected")
38
+ log.error(`Failed to update observable ${this.observers[i].toString()}: ${result.reason}`);
39
+ });
40
+ }
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT2JzZXJ2ZXJIYW5kbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BlcnNpc3RlbmNlL09ic2VydmVySGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBRUwsYUFBYSxHQUVkLE1BQU0seUJBQXlCLENBQUM7QUFHakMsTUFBTSxPQUFPLGVBQWU7SUFBNUI7UUFDcUIsY0FBUyxHQUd0QixFQUFFLENBQUM7SUFnRFgsQ0FBQztJQTlDQyxLQUFLO1FBQ0gsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0lBRUQsT0FBTyxDQUFDLFFBQWtCLEVBQUUsTUFBdUI7UUFDakQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEUsSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDO1lBQUUsTUFBTSxJQUFJLGFBQWEsQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBQ3pFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsU0FBUyxDQUFDLFFBQWtCO1FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3RFLElBQUksS0FBSyxLQUFLLENBQUMsQ0FBQztZQUFFLE1BQU0sSUFBSSxhQUFhLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUNyRSxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELEtBQUssQ0FBQyxlQUFlLENBQ25CLEdBQVcsRUFDWCxLQUFhLEVBQ2IsS0FBcUQsRUFDckQsRUFBWSxFQUNaLEdBQUcsSUFBVztRQUVkLE1BQU0sT0FBTyxHQUFHLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FDdEMsSUFBSSxDQUFDLFNBQVM7YUFDWCxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNaLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUM7WUFDckIsSUFBSSxDQUFDLE1BQU07Z0JBQUUsT0FBTyxJQUFJLENBQUM7WUFDekIsSUFBSSxDQUFDO2dCQUNILE9BQU8sTUFBTSxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUFDLE9BQU8sQ0FBVSxFQUFFLENBQUM7Z0JBQ3BCLEdBQUcsQ0FBQyxLQUFLLENBQ1AsNkJBQTZCLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQzNELENBQUM7Z0JBQ0YsT0FBTyxLQUFLLENBQUM7WUFDZixDQUFDO1FBQ0gsQ0FBQyxDQUFDO2FBQ0QsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQzdELENBQUM7UUFDRixPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzVCLElBQUksTUFBTSxDQUFDLE1BQU0sS0FBSyxVQUFVO2dCQUM5QixHQUFHLENBQUMsS0FBSyxDQUNQLCtCQUErQixJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxLQUFLLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FDaEYsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgT2JzZXJ2ZXIgfSBmcm9tIFwiLi4vaW50ZXJmYWNlc1wiO1xuaW1wb3J0IHsgRXZlbnRJZHMsIE9ic2VydmVyRmlsdGVyIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7XG4gIEJ1bGtDcnVkT3BlcmF0aW9uS2V5cyxcbiAgSW50ZXJuYWxFcnJvcixcbiAgT3BlcmF0aW9uS2V5cyxcbn0gZnJvbSBcIkBkZWNhZi10cy9kYi1kZWNvcmF0b3JzXCI7XG5pbXBvcnQgeyBMb2dnZXIgfSBmcm9tIFwiQGRlY2FmLXRzL2xvZ2dpbmdcIjtcblxuZXhwb3J0IGNsYXNzIE9ic2VydmVySGFuZGxlciBpbXBsZW1lbnRzIE9ic2VydmFibGUge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgb2JzZXJ2ZXJzOiB7XG4gICAgb2JzZXJ2ZXI6IE9ic2VydmVyO1xuICAgIGZpbHRlcj86IE9ic2VydmVyRmlsdGVyO1xuICB9W10gPSBbXTtcblxuICBjb3VudCgpIHtcbiAgICByZXR1cm4gdGhpcy5vYnNlcnZlcnMubGVuZ3RoO1xuICB9XG5cbiAgb2JzZXJ2ZShvYnNlcnZlcjogT2JzZXJ2ZXIsIGZpbHRlcj86IE9ic2VydmVyRmlsdGVyKTogdm9pZCB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLm9ic2VydmVycy5tYXAoKG8pID0+IG8ub2JzZXJ2ZXIpLmluZGV4T2Yob2JzZXJ2ZXIpO1xuICAgIGlmIChpbmRleCAhPT0gLTEpIHRocm93IG5ldyBJbnRlcm5hbEVycm9yKFwiT2JzZXJ2ZXIgYWxyZWFkeSByZWdpc3RlcmVkXCIpO1xuICAgIHRoaXMub2JzZXJ2ZXJzLnB1c2goeyBvYnNlcnZlcjogb2JzZXJ2ZXIsIGZpbHRlcjogZmlsdGVyIH0pO1xuICB9XG5cbiAgdW5PYnNlcnZlKG9ic2VydmVyOiBPYnNlcnZlcik6IHZvaWQge1xuICAgIGNvbnN0IGluZGV4ID0gdGhpcy5vYnNlcnZlcnMubWFwKChvKSA9PiBvLm9ic2VydmVyKS5pbmRleE9mKG9ic2VydmVyKTtcbiAgICBpZiAoaW5kZXggPT09IC0xKSB0aHJvdyBuZXcgSW50ZXJuYWxFcnJvcihcIkZhaWxlZCB0byBmaW5kIE9ic2VydmVyXCIpO1xuICAgIHRoaXMub2JzZXJ2ZXJzLnNwbGljZShpbmRleCwgMSk7XG4gIH1cblxuICBhc3luYyB1cGRhdGVPYnNlcnZlcnMoXG4gICAgbG9nOiBMb2dnZXIsXG4gICAgdGFibGU6IHN0cmluZyxcbiAgICBldmVudDogT3BlcmF0aW9uS2V5cyB8IEJ1bGtDcnVkT3BlcmF0aW9uS2V5cyB8IHN0cmluZyxcbiAgICBpZDogRXZlbnRJZHMsXG4gICAgLi4uYXJnczogYW55W11cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgcmVzdWx0cyA9IGF3YWl0IFByb21pc2UuYWxsU2V0dGxlZChcbiAgICAgIHRoaXMub2JzZXJ2ZXJzXG4gICAgICAgIC5maWx0ZXIoKG8pID0+IHtcbiAgICAgICAgICBjb25zdCB7IGZpbHRlciB9ID0gbztcbiAgICAgICAgICBpZiAoIWZpbHRlcikgcmV0dXJuIHRydWU7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIHJldHVybiBmaWx0ZXIodGFibGUsIGV2ZW50LCBpZCk7XG4gICAgICAgICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgICAgICAgbG9nLmVycm9yKFxuICAgICAgICAgICAgICBgRmFpbGVkIHRvIGZpbHRlciBvYnNlcnZlciAke28ub2JzZXJ2ZXIudG9TdHJpbmcoKX06ICR7ZX1gXG4gICAgICAgICAgICApO1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgICAgLm1hcCgobykgPT4gby5vYnNlcnZlci5yZWZyZXNoKHRhYmxlLCBldmVudCwgaWQsIC4uLmFyZ3MpKVxuICAgICk7XG4gICAgcmVzdWx0cy5mb3JFYWNoKChyZXN1bHQsIGkpID0+IHtcbiAgICAgIGlmIChyZXN1bHQuc3RhdHVzID09PSBcInJlamVjdGVkXCIpXG4gICAgICAgIGxvZy5lcnJvcihcbiAgICAgICAgICBgRmFpbGVkIHRvIHVwZGF0ZSBvYnNlcnZhYmxlICR7dGhpcy5vYnNlcnZlcnNbaV0udG9TdHJpbmcoKX06ICR7cmVzdWx0LnJlYXNvbn1gXG4gICAgICAgICk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -1,22 +1,14 @@
1
- /**
2
- * @summary Sequence
3
- *
4
- * @interface Sequence
5
- *
6
- * @category Sequences
7
- */
8
1
  import { Constructor, Model } from "@decaf-ts/decorator-validation";
9
2
  import { SequenceOptions } from "../interfaces/SequenceOptions";
3
+ import { Logger } from "@decaf-ts/logging";
10
4
  export declare abstract class Sequence {
11
5
  protected readonly options: SequenceOptions;
6
+ private logger;
7
+ protected get log(): Logger;
12
8
  protected constructor(options: SequenceOptions);
13
- /**
14
- * @summary generates the next value in the sequence
15
- *
16
- * @method
17
- */
18
9
  abstract next(): Promise<string | number | bigint>;
19
10
  abstract current(): Promise<string | number | bigint>;
20
11
  abstract range(count: number): Promise<(number | string | bigint)[]>;
21
12
  static pk<M extends Model>(model: M | Constructor<M>): string;
13
+ static parseValue(type: "Number" | "BigInt" | undefined, value: string | number | bigint): string | number | bigint;
22
14
  }