assemblerjs 1.1.9 → 1.1.10

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 (69) hide show
  1. package/dist/index11.js +2 -2
  2. package/dist/index11.mjs +2 -2
  3. package/dist/index13.js +2 -2
  4. package/dist/index13.mjs +2 -2
  5. package/dist/index16.js +1 -1
  6. package/dist/index16.mjs +1 -1
  7. package/dist/index17.js +1 -1
  8. package/dist/index17.mjs +1 -1
  9. package/dist/index18.js +1 -1
  10. package/dist/index18.mjs +1 -1
  11. package/dist/index19.js +1 -1
  12. package/dist/index19.mjs +1 -1
  13. package/dist/index2.js +2 -2
  14. package/dist/index2.mjs +2 -2
  15. package/dist/index20.js +1 -1
  16. package/dist/index20.mjs +1 -1
  17. package/dist/index21.js +1 -1
  18. package/dist/index21.mjs +1 -1
  19. package/dist/index22.js +2 -2
  20. package/dist/index22.mjs +2 -2
  21. package/dist/index23.js +2 -2
  22. package/dist/index23.mjs +2 -2
  23. package/dist/index24.js +2 -2
  24. package/dist/index24.mjs +2 -2
  25. package/dist/index25.js +1 -1
  26. package/dist/index25.mjs +1 -1
  27. package/dist/index26.js +1 -1
  28. package/dist/index26.mjs +1 -1
  29. package/dist/index29.js +15 -38
  30. package/dist/index29.mjs +12 -37
  31. package/dist/index3.js +1 -1
  32. package/dist/index3.mjs +1 -1
  33. package/dist/index30.js +100 -130
  34. package/dist/index30.mjs +98 -130
  35. package/dist/index31.js +123 -36
  36. package/dist/index31.mjs +123 -36
  37. package/dist/index32.js +41 -70
  38. package/dist/index32.mjs +41 -70
  39. package/dist/index33.js +75 -37
  40. package/dist/index33.mjs +75 -37
  41. package/dist/index34.js +39 -29
  42. package/dist/index34.mjs +39 -29
  43. package/dist/index35.js +26 -151
  44. package/dist/index35.mjs +26 -151
  45. package/dist/index36.js +155 -16
  46. package/dist/index36.mjs +155 -13
  47. package/dist/index37.js +18 -103
  48. package/dist/index37.mjs +18 -101
  49. package/dist/index38.js +35 -100
  50. package/dist/index38.mjs +34 -100
  51. package/dist/index39.js +101 -24
  52. package/dist/index39.mjs +101 -24
  53. package/dist/index4.js +6 -6
  54. package/dist/index4.mjs +6 -6
  55. package/dist/index40.js +24 -18
  56. package/dist/index40.mjs +24 -18
  57. package/dist/index41.js +49 -29
  58. package/dist/index41.mjs +49 -28
  59. package/dist/index43.js +29 -49
  60. package/dist/index43.mjs +28 -49
  61. package/dist/index44.js +4 -4
  62. package/dist/index44.mjs +4 -4
  63. package/dist/index48.js +1 -1
  64. package/dist/index48.mjs +1 -1
  65. package/dist/index49.js +2 -2
  66. package/dist/index49.mjs +2 -2
  67. package/dist/index50.js +1 -1
  68. package/dist/index50.mjs +1 -1
  69. package/package.json +1 -1
package/dist/index30.js CHANGED
@@ -2,142 +2,112 @@
2
2
 
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
4
 
5
- const hookManager = require('./index32.js');
6
- const resolutionStrategies = require('./index41.js');
7
- const debugLogger = require('./index35.js');
8
- const core = require('@assemblerjs/core');
9
- const use = require('./index42.js');
10
- const inject = require('./index43.js');
11
- const injectable = require('./index44.js');
5
+ const constants = require('./index28.js');
6
+ const reflection = require('./index29.js');
7
+ const helpers = require('./index3.js');
12
8
 
13
- function a(e) {
14
- if (e === undefined) return 'undefined';
15
- if (e === null) return 'null';
16
- if (typeof e === 'function') {
17
- if (e.name) return e.name;
18
- if (e.constructor?.name && e.constructor.name !== 'Function') {
19
- return e.constructor.name;
9
+ const n = {
10
+ singleton: {
11
+ test: (r)=>typeof r === 'boolean' || typeof r === 'undefined',
12
+ throw: ()=>{
13
+ throw new Error(`'singleton' property must be of type 'boolean' or 'undefined'.`);
14
+ },
15
+ transform: (r)=>{
16
+ return typeof r === 'undefined' ? true : r ? true : false;
20
17
  }
21
- return 'AnonymousFunction';
18
+ },
19
+ events: {
20
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>typeof r === 'string'),
21
+ throw: ()=>{
22
+ throw new Error(`'events' property must be an array of strings or 'undefined'.`);
23
+ },
24
+ transform: (r)=>r
25
+ },
26
+ inject: {
27
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>Array.isArray(r) && r.length >= 1 && r.length <= 3),
28
+ throw: ()=>{
29
+ throw new Error(`'inject' property must be an array of tuples of length 1, 2 or 3.`);
30
+ },
31
+ transform: (r)=>r
32
+ },
33
+ use: {
34
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>{
35
+ if (!Array.isArray(r) || r.length !== 2) {
36
+ return false;
37
+ }
38
+ const e = r[1];
39
+ return typeof e !== 'undefined';
40
+ }),
41
+ throw: ()=>{
42
+ throw new Error(`'use' property must be an array of tuples of length 2 with [identifier, instance | factory].`);
43
+ },
44
+ transform: (r)=>r
45
+ },
46
+ engage: {
47
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>Array.isArray(r) && r.length >= 1 && r.length <= 3),
48
+ throw: ()=>{
49
+ throw new Error(`'engage' property must be an array of tuples of length 1, 2 or 3.`);
50
+ },
51
+ transform: (r)=>r
52
+ },
53
+ tags: {
54
+ test: (r)=>typeof r === 'undefined' || typeof r === 'string' || Array.isArray(r) && r.every((r)=>typeof r === 'string'),
55
+ throw: ()=>{
56
+ throw new Error(`'tags' property must be a string or an array of strings.`);
57
+ },
58
+ transform: (r)=>typeof r === 'string' ? [
59
+ r
60
+ ] : r
61
+ },
62
+ metadata: {
63
+ test: (r)=>(typeof r === 'object' || typeof r === 'undefined') && !Array.isArray(r),
64
+ throw: ()=>{
65
+ throw new Error(`'metadata' property must be of type 'object' or 'undefined'.`);
66
+ },
67
+ transform: (r)=>r
68
+ },
69
+ global: {
70
+ test: (r)=>(typeof r === 'object' || typeof r === 'undefined') && !Array.isArray(r),
71
+ throw: ()=>{
72
+ throw new Error(`'global' property must be of type 'object' or 'undefined'.`);
73
+ },
74
+ transform: (r)=>r
22
75
  }
23
- if (typeof e === 'string') return e;
24
- if (typeof e === 'symbol') return e.toString();
25
- if (typeof e === 'number') return String(e);
26
- if (typeof e === 'boolean') return String(e);
27
- if (typeof e === 'object') {
28
- if (e.name && typeof e.name === 'string') {
29
- return e.name;
76
+ };
77
+ const validateDefinition = (r)=>{
78
+ const e = {
79
+ ...r
80
+ };
81
+ for(const r in e){
82
+ if (!Object.keys(n).includes(r)) {
83
+ throw new Error(`Property '${r}' is not a valid assemblage definition property.`);
30
84
  }
31
- try {
32
- const t = JSON.stringify(e);
33
- if (t.length > 100) {
34
- return t.substring(0, 100) + '...';
35
- }
36
- return t;
37
- } catch {
38
- const t = e.constructor?.name;
39
- if (t && t !== 'Object') {
40
- return `[${t}]`;
41
- }
42
- return '[UnknownObject]';
43
- }
44
- }
45
- return String(e);
46
- }
47
- function f(e) {
48
- if (core.isClass(e)) {
49
- const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
50
- return t ? 'class' : 'class';
51
- }
52
- if (typeof e === 'function') return 'function';
53
- if (typeof e === 'string') return 'string';
54
- if (typeof e === 'symbol') return 'symbol';
55
- if (typeof e === 'object' && e !== null) return 'object';
56
- return 'unknown';
57
- }
58
- class InjectableManager {
59
- setContexts(e, t) {
60
- this.privateContext = e;
61
- this.publicContext = t;
62
- }
63
- register(i, o = false) {
64
- const c = debugLogger.DebugLogger.getInstance();
65
- const a = o === true ? use.resolveInstanceInjectionTuple(i) : inject.resolveInjectionTuple(i);
66
- if (this.has(a.identifier)) {
67
- const e = `An assemblage is already registered with identifier '${a.identifier.name}'.`;
68
- c.log('error', 'Duplicate registration', {
69
- identifier: a.identifier.name,
70
- error: e
71
- });
72
- throw new Error(e);
73
- }
74
- const f = injectable.Injectable.of(a, this.privateContext, this.publicContext);
75
- c.logRegistration(f);
76
- this.injectables.set(f.identifier, f);
77
- if (f.concrete) {
78
- hookManager.HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
79
- }
80
- return f;
81
- }
82
- has(e) {
83
- return this.injectables.has(e);
84
85
  }
85
- require(e, t, n) {
86
- if (!this.injectables.has(e)) {
87
- const t = this.resolvingStack.has(e);
88
- const r = t ? 'Circular dependency detected' : 'Dependency not registered';
89
- const i = a(e);
90
- const o = f(e);
91
- const c = t ? `Circular dependency detected: '${i}' is already being resolved.` : `Dependency '${i}' has not been registered (Class/Service not found in current assemblies).`;
92
- debugLogger.DebugLogger.getInstance().log('error', r, {
93
- identifier: i,
94
- caller: n ? a(n) : 'unknown',
95
- type: o,
96
- error: c
97
- });
98
- throw new Error(c);
86
+ for(const r in n){
87
+ const t = n[r].test;
88
+ const o = n[r].throw;
89
+ const s = n[r].transform;
90
+ if (!t(e[r])) {
91
+ o();
99
92
  }
100
- const r = this.injectables.get(e);
101
- this.resolvingStack.add(r.identifier);
102
- try {
103
- if (r.isSingleton) {
104
- return this.singletonStrategy.resolve(r, t);
105
- } else {
106
- return this.transientStrategy.resolve(r, t);
107
- }
108
- } finally{
109
- this.resolvingStack.delete(r.identifier);
110
- }
111
- }
112
- concrete(e) {
113
- const t = this.injectables.get(e);
114
- if (t) return t.concrete;
115
- return;
116
- }
117
- tagged(...e) {
118
- const t = [];
119
- for (const n of e){
120
- for (const [e, r] of this.injectables){
121
- if (r.tags.includes(n)) t.push(r.build());
122
- }
123
- }
124
- return t;
125
- }
126
- dispose() {
127
- for (const [e, t] of this.injectables){
128
- t.dispose();
129
- }
130
- this.resolvingStack.clear();
131
- }
132
- get size() {
133
- return this.injectables.size;
93
+ e[r] = s(e[r]);
134
94
  }
135
- constructor(){
136
- this.injectables = new Map();
137
- this.resolvingStack = new Set();
138
- this.singletonStrategy = new resolutionStrategies.SingletonStrategy();
139
- this.transientStrategy = new resolutionStrategies.TransientStrategy();
95
+ return e;
96
+ };
97
+ const getDefinition = (e)=>{
98
+ if (!helpers.isAssemblage(e)) {
99
+ throw new Error(`Class '${e.name}' is not an assemblage or transversal.`);
140
100
  }
141
- }
101
+ return reflection.getOwnCustomMetadata(constants.ReflectValue.AssemblageDefinition, e);
102
+ };
103
+ const setDefinitionValue = (t, o, n)=>{
104
+ const s = getDefinition(n);
105
+ s[t] = o;
106
+ const a = validateDefinition(s);
107
+ reflection.defineCustomMetadata(constants.ReflectValue.AssemblageDefinition, a, n);
108
+ return a;
109
+ };
142
110
 
143
- exports.InjectableManager = InjectableManager;
111
+ exports.getDefinition = getDefinition;
112
+ exports.setDefinitionValue = setDefinitionValue;
113
+ exports.validateDefinition = validateDefinition;
package/dist/index30.mjs CHANGED
@@ -1,139 +1,107 @@
1
- import { HookManager } from './index32.mjs';
2
- import { SingletonStrategy, TransientStrategy } from './index41.mjs';
3
- import { DebugLogger } from './index35.mjs';
4
- import { isClass } from '@assemblerjs/core';
5
- import { resolveInstanceInjectionTuple } from './index42.mjs';
6
- import { resolveInjectionTuple } from './index43.mjs';
7
- import { Injectable } from './index44.mjs';
1
+ import { ReflectValue } from './index28.mjs';
2
+ import { getOwnCustomMetadata, defineCustomMetadata } from './index29.mjs';
3
+ import { isAssemblage } from './index3.mjs';
8
4
 
9
- function a(e) {
10
- if (e === undefined) return 'undefined';
11
- if (e === null) return 'null';
12
- if (typeof e === 'function') {
13
- if (e.name) return e.name;
14
- if (e.constructor?.name && e.constructor.name !== 'Function') {
15
- return e.constructor.name;
5
+ const n = {
6
+ singleton: {
7
+ test: (r)=>typeof r === 'boolean' || typeof r === 'undefined',
8
+ throw: ()=>{
9
+ throw new Error(`'singleton' property must be of type 'boolean' or 'undefined'.`);
10
+ },
11
+ transform: (r)=>{
12
+ return typeof r === 'undefined' ? true : r ? true : false;
16
13
  }
17
- return 'AnonymousFunction';
14
+ },
15
+ events: {
16
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>typeof r === 'string'),
17
+ throw: ()=>{
18
+ throw new Error(`'events' property must be an array of strings or 'undefined'.`);
19
+ },
20
+ transform: (r)=>r
21
+ },
22
+ inject: {
23
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>Array.isArray(r) && r.length >= 1 && r.length <= 3),
24
+ throw: ()=>{
25
+ throw new Error(`'inject' property must be an array of tuples of length 1, 2 or 3.`);
26
+ },
27
+ transform: (r)=>r
28
+ },
29
+ use: {
30
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>{
31
+ if (!Array.isArray(r) || r.length !== 2) {
32
+ return false;
33
+ }
34
+ const e = r[1];
35
+ return typeof e !== 'undefined';
36
+ }),
37
+ throw: ()=>{
38
+ throw new Error(`'use' property must be an array of tuples of length 2 with [identifier, instance | factory].`);
39
+ },
40
+ transform: (r)=>r
41
+ },
42
+ engage: {
43
+ test: (r)=>typeof r === 'undefined' || Array.isArray(r) && r.every((r)=>Array.isArray(r) && r.length >= 1 && r.length <= 3),
44
+ throw: ()=>{
45
+ throw new Error(`'engage' property must be an array of tuples of length 1, 2 or 3.`);
46
+ },
47
+ transform: (r)=>r
48
+ },
49
+ tags: {
50
+ test: (r)=>typeof r === 'undefined' || typeof r === 'string' || Array.isArray(r) && r.every((r)=>typeof r === 'string'),
51
+ throw: ()=>{
52
+ throw new Error(`'tags' property must be a string or an array of strings.`);
53
+ },
54
+ transform: (r)=>typeof r === 'string' ? [
55
+ r
56
+ ] : r
57
+ },
58
+ metadata: {
59
+ test: (r)=>(typeof r === 'object' || typeof r === 'undefined') && !Array.isArray(r),
60
+ throw: ()=>{
61
+ throw new Error(`'metadata' property must be of type 'object' or 'undefined'.`);
62
+ },
63
+ transform: (r)=>r
64
+ },
65
+ global: {
66
+ test: (r)=>(typeof r === 'object' || typeof r === 'undefined') && !Array.isArray(r),
67
+ throw: ()=>{
68
+ throw new Error(`'global' property must be of type 'object' or 'undefined'.`);
69
+ },
70
+ transform: (r)=>r
18
71
  }
19
- if (typeof e === 'string') return e;
20
- if (typeof e === 'symbol') return e.toString();
21
- if (typeof e === 'number') return String(e);
22
- if (typeof e === 'boolean') return String(e);
23
- if (typeof e === 'object') {
24
- if (e.name && typeof e.name === 'string') {
25
- return e.name;
72
+ };
73
+ const validateDefinition = (r)=>{
74
+ const e = {
75
+ ...r
76
+ };
77
+ for(const r in e){
78
+ if (!Object.keys(n).includes(r)) {
79
+ throw new Error(`Property '${r}' is not a valid assemblage definition property.`);
26
80
  }
27
- try {
28
- const t = JSON.stringify(e);
29
- if (t.length > 100) {
30
- return t.substring(0, 100) + '...';
31
- }
32
- return t;
33
- } catch {
34
- const t = e.constructor?.name;
35
- if (t && t !== 'Object') {
36
- return `[${t}]`;
37
- }
38
- return '[UnknownObject]';
39
- }
40
- }
41
- return String(e);
42
- }
43
- function f(e) {
44
- if (isClass(e)) {
45
- const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
46
- return t ? 'class' : 'class';
47
- }
48
- if (typeof e === 'function') return 'function';
49
- if (typeof e === 'string') return 'string';
50
- if (typeof e === 'symbol') return 'symbol';
51
- if (typeof e === 'object' && e !== null) return 'object';
52
- return 'unknown';
53
- }
54
- class InjectableManager {
55
- setContexts(e, t) {
56
- this.privateContext = e;
57
- this.publicContext = t;
58
- }
59
- register(i, o = false) {
60
- const c = DebugLogger.getInstance();
61
- const a = o === true ? resolveInstanceInjectionTuple(i) : resolveInjectionTuple(i);
62
- if (this.has(a.identifier)) {
63
- const e = `An assemblage is already registered with identifier '${a.identifier.name}'.`;
64
- c.log('error', 'Duplicate registration', {
65
- identifier: a.identifier.name,
66
- error: e
67
- });
68
- throw new Error(e);
69
- }
70
- const f = Injectable.of(a, this.privateContext, this.publicContext);
71
- c.logRegistration(f);
72
- this.injectables.set(f.identifier, f);
73
- if (f.concrete) {
74
- HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
75
- }
76
- return f;
77
- }
78
- has(e) {
79
- return this.injectables.has(e);
80
81
  }
81
- require(e, t, n) {
82
- if (!this.injectables.has(e)) {
83
- const t = this.resolvingStack.has(e);
84
- const r = t ? 'Circular dependency detected' : 'Dependency not registered';
85
- const i = a(e);
86
- const o = f(e);
87
- const c = t ? `Circular dependency detected: '${i}' is already being resolved.` : `Dependency '${i}' has not been registered (Class/Service not found in current assemblies).`;
88
- DebugLogger.getInstance().log('error', r, {
89
- identifier: i,
90
- caller: n ? a(n) : 'unknown',
91
- type: o,
92
- error: c
93
- });
94
- throw new Error(c);
82
+ for(const r in n){
83
+ const t = n[r].test;
84
+ const o = n[r].throw;
85
+ const s = n[r].transform;
86
+ if (!t(e[r])) {
87
+ o();
95
88
  }
96
- const r = this.injectables.get(e);
97
- this.resolvingStack.add(r.identifier);
98
- try {
99
- if (r.isSingleton) {
100
- return this.singletonStrategy.resolve(r, t);
101
- } else {
102
- return this.transientStrategy.resolve(r, t);
103
- }
104
- } finally{
105
- this.resolvingStack.delete(r.identifier);
106
- }
107
- }
108
- concrete(e) {
109
- const t = this.injectables.get(e);
110
- if (t) return t.concrete;
111
- return;
112
- }
113
- tagged(...e) {
114
- const t = [];
115
- for (const n of e){
116
- for (const [e, r] of this.injectables){
117
- if (r.tags.includes(n)) t.push(r.build());
118
- }
119
- }
120
- return t;
121
- }
122
- dispose() {
123
- for (const [e, t] of this.injectables){
124
- t.dispose();
125
- }
126
- this.resolvingStack.clear();
127
- }
128
- get size() {
129
- return this.injectables.size;
89
+ e[r] = s(e[r]);
130
90
  }
131
- constructor(){
132
- this.injectables = new Map();
133
- this.resolvingStack = new Set();
134
- this.singletonStrategy = new SingletonStrategy();
135
- this.transientStrategy = new TransientStrategy();
91
+ return e;
92
+ };
93
+ const getDefinition = (e)=>{
94
+ if (!isAssemblage(e)) {
95
+ throw new Error(`Class '${e.name}' is not an assemblage or transversal.`);
136
96
  }
137
- }
97
+ return getOwnCustomMetadata(ReflectValue.AssemblageDefinition, e);
98
+ };
99
+ const setDefinitionValue = (t, o, n)=>{
100
+ const s = getDefinition(n);
101
+ s[t] = o;
102
+ const a = validateDefinition(s);
103
+ defineCustomMetadata(ReflectValue.AssemblageDefinition, a, n);
104
+ return a;
105
+ };
138
106
 
139
- export { InjectableManager };
107
+ export { getDefinition, setDefinitionValue, validateDefinition };
package/dist/index31.js CHANGED
@@ -2,55 +2,142 @@
2
2
 
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
4
 
5
- const debugLogger = require('./index35.js');
5
+ const hookManager = require('./index33.js');
6
+ const resolutionStrategies = require('./index43.js');
7
+ const debugLogger = require('./index36.js');
8
+ const core = require('@assemblerjs/core');
9
+ const use = require('./index42.js');
10
+ const inject = require('./index41.js');
11
+ const injectable = require('./index44.js');
6
12
 
7
- function t(e) {
8
- return typeof e === 'symbol' ? 'symbol' : 'string';
13
+ function a(e) {
14
+ if (e === undefined) return 'undefined';
15
+ if (e === null) return 'null';
16
+ if (typeof e === 'function') {
17
+ if (e.name) return e.name;
18
+ if (e.constructor?.name && e.constructor.name !== 'Function') {
19
+ return e.constructor.name;
20
+ }
21
+ return 'AnonymousFunction';
22
+ }
23
+ if (typeof e === 'string') return e;
24
+ if (typeof e === 'symbol') return e.toString();
25
+ if (typeof e === 'number') return String(e);
26
+ if (typeof e === 'boolean') return String(e);
27
+ if (typeof e === 'object') {
28
+ if (e.name && typeof e.name === 'string') {
29
+ return e.name;
30
+ }
31
+ const t = e.constructor?.name;
32
+ if (t && t !== 'Object') {
33
+ return t;
34
+ }
35
+ try {
36
+ const t = JSON.stringify(e);
37
+ if (t.length > 100) {
38
+ return t.substring(0, 100) + '...';
39
+ }
40
+ return t;
41
+ } catch {
42
+ return '[UnknownObject]';
43
+ }
44
+ }
45
+ return String(e);
46
+ }
47
+ function f(e) {
48
+ if (core.isClass(e)) {
49
+ const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
50
+ return t ? 'class' : 'class';
51
+ }
52
+ if (typeof e === 'function') return 'function';
53
+ if (typeof e === 'string') return 'string';
54
+ if (typeof e === 'symbol') return 'symbol';
55
+ if (typeof e === 'object' && e !== null) return 'object';
56
+ return 'unknown';
9
57
  }
10
- class ObjectManager {
11
- use(r, o) {
12
- if (this.has(r)) {
13
- const o = typeof r === 'symbol' ? r.toString() : String(r);
14
- const s = `Object/value '${o}' is already registered (cannot register twice).`;
15
- debugLogger.DebugLogger.getInstance().log('error', 'Duplicate object/value registration', {
16
- identifier: o,
17
- type: t(r),
18
- error: s
58
+ class InjectableManager {
59
+ setContexts(e, t) {
60
+ this.privateContext = e;
61
+ this.publicContext = t;
62
+ }
63
+ register(i, o = false) {
64
+ const c = debugLogger.DebugLogger.getInstance();
65
+ const a = o === true ? use.resolveInstanceInjectionTuple(i) : inject.resolveInjectionTuple(i);
66
+ if (this.has(a.identifier)) {
67
+ const e = `An assemblage is already registered with identifier '${a.identifier.name}'.`;
68
+ c.log('error', 'Duplicate registration', {
69
+ identifier: a.identifier.name,
70
+ error: e
19
71
  });
20
- throw new Error(s);
72
+ throw new Error(e);
73
+ }
74
+ const f = injectable.Injectable.of(a, this.privateContext, this.publicContext);
75
+ c.logRegistration(f);
76
+ this.injectables.set(f.identifier, f);
77
+ if (f.concrete) {
78
+ hookManager.HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
21
79
  }
22
- this.objects.set(r, o);
23
- return o;
80
+ return f;
24
81
  }
25
82
  has(e) {
26
- return this.objects.has(e);
27
- }
28
- require(r) {
29
- if (!this.objects.has(r)) {
30
- const o = typeof r === 'symbol' ? r.toString() : String(r);
31
- const s = `Object/value '${o}' has not been registered in the object store.`;
32
- debugLogger.DebugLogger.getInstance().log('error', 'Object/value not found', {
33
- identifier: o,
34
- type: t(r),
35
- error: s
83
+ return this.injectables.has(e);
84
+ }
85
+ require(e, t, n) {
86
+ if (!this.injectables.has(e)) {
87
+ const t = this.resolvingStack.has(e);
88
+ const r = t ? 'Circular dependency detected' : 'Dependency not registered';
89
+ const i = a(e);
90
+ const o = f(e);
91
+ const c = t ? `Circular dependency detected: '${i}' is already being resolved.` : `Dependency '${i}' has not been registered (Class/Service not found in current assemblies).`;
92
+ debugLogger.DebugLogger.getInstance().log('error', r, {
93
+ identifier: i,
94
+ caller: n ? a(n) : 'unknown',
95
+ type: o,
96
+ error: c
36
97
  });
37
- throw new Error(s);
98
+ throw new Error(c);
99
+ }
100
+ const r = this.injectables.get(e);
101
+ this.resolvingStack.add(r.identifier);
102
+ try {
103
+ if (r.isSingleton) {
104
+ return this.singletonStrategy.resolve(r, t);
105
+ } else {
106
+ return this.transientStrategy.resolve(r, t);
107
+ }
108
+ } finally{
109
+ this.resolvingStack.delete(r.identifier);
110
+ }
111
+ }
112
+ concrete(e) {
113
+ const t = this.injectables.get(e);
114
+ if (t) return t.concrete;
115
+ return;
116
+ }
117
+ tagged(...e) {
118
+ const t = [];
119
+ for (const n of e){
120
+ for (const [e, r] of this.injectables){
121
+ if (r.tags.includes(n)) t.push(r.build());
122
+ }
38
123
  }
39
- return this.objects.get(r);
124
+ return t;
40
125
  }
41
- addGlobal(e, t) {
42
- if (this.globals.has(e)) {
43
- throw new Error(`Global value with key '${e}' has already been registered.`);
126
+ dispose() {
127
+ for (const [e, t] of this.injectables){
128
+ t.dispose();
44
129
  }
45
- this.globals.set(e, t);
130
+ this.resolvingStack.clear();
46
131
  }
47
- global(e) {
48
- return this.globals.get(e);
132
+ get size() {
133
+ return this.injectables.size;
49
134
  }
50
135
  constructor(){
51
- this.objects = new Map();
52
- this.globals = new Map();
136
+ this.injectables = new Map();
137
+ this.resolvingStack = new Set();
138
+ this.singletonStrategy = new resolutionStrategies.SingletonStrategy();
139
+ this.transientStrategy = new resolutionStrategies.TransientStrategy();
53
140
  }
54
141
  }
55
142
 
56
- exports.ObjectManager = ObjectManager;
143
+ exports.InjectableManager = InjectableManager;