@common-stack/server-stack 7.1.1-alpha.9 → 7.2.1-alpha.2
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.
- package/lib/MainStackServer.cjs +101 -142
- package/lib/MainStackServer.cjs.map +1 -1
- package/lib/MainStackServer.d.ts +10 -5
- package/lib/MainStackServer.mjs +101 -142
- package/lib/MainStackServer.mjs.map +1 -1
- package/lib/StackServer.cjs +23 -66
- package/lib/StackServer.cjs.map +1 -1
- package/lib/StackServer.d.ts +4 -5
- package/lib/StackServer.mjs +23 -66
- package/lib/StackServer.mjs.map +1 -1
- package/lib/api/schema-builder.cjs +13 -12
- package/lib/api/schema-builder.cjs.map +1 -1
- package/lib/api/schema-builder.mjs +13 -12
- package/lib/api/schema-builder.mjs.map +1 -1
- package/lib/api/sub-graph-schema-builder.cjs +13 -15
- package/lib/api/sub-graph-schema-builder.cjs.map +1 -1
- package/lib/api/sub-graph-schema-builder.mjs +14 -16
- package/lib/api/sub-graph-schema-builder.mjs.map +1 -1
- package/lib/config/env-config.cjs +6 -0
- package/lib/config/env-config.cjs.map +1 -1
- package/lib/config/env-config.d.ts +6 -0
- package/lib/config/env-config.mjs +6 -0
- package/lib/config/env-config.mjs.map +1 -1
- package/lib/examples/tenant-feature-example.d.ts +13 -0
- package/lib/examples/tenant-feature-integration.d.ts +14 -0
- package/lib/features/multi-module-example.d.ts +17 -0
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.mjs +1 -1
- package/lib/infrastructure/container-module.cjs +27 -0
- package/lib/infrastructure/container-module.cjs.map +1 -0
- package/lib/infrastructure/container-module.d.ts +3 -0
- package/lib/infrastructure/container-module.mjs +27 -0
- package/lib/infrastructure/container-module.mjs.map +1 -0
- package/lib/infrastructure/example-workflows.d.ts +16 -0
- package/lib/infrastructure/index.d.ts +5 -0
- package/lib/infrastructure/infrastructure-factory.cjs +127 -0
- package/lib/infrastructure/infrastructure-factory.cjs.map +1 -0
- package/lib/infrastructure/infrastructure-factory.d.ts +33 -0
- package/lib/infrastructure/infrastructure-factory.mjs +127 -0
- package/lib/infrastructure/infrastructure-factory.mjs.map +1 -0
- package/lib/infrastructure/inngest-factory.cjs +26 -0
- package/lib/infrastructure/inngest-factory.cjs.map +1 -0
- package/lib/infrastructure/inngest-factory.d.ts +8 -0
- package/lib/infrastructure/inngest-factory.mjs +26 -0
- package/lib/infrastructure/inngest-factory.mjs.map +1 -0
- package/lib/infrastructure/types.d.ts +28 -0
- package/lib/infrastructure/usage-examples.d.ts +9 -0
- package/lib/infrastructure/workflow-orchestrator.cjs +59 -0
- package/lib/infrastructure/workflow-orchestrator.cjs.map +1 -0
- package/lib/infrastructure/workflow-orchestrator.d.ts +10 -0
- package/lib/infrastructure/workflow-orchestrator.mjs +59 -0
- package/lib/infrastructure/workflow-orchestrator.mjs.map +1 -0
- package/lib/inngest/client-id-generator.d.ts +29 -0
- package/lib/inngest/handler-factory.d.ts +18 -0
- package/lib/inngest/multi-module-functions.d.ts +133 -0
- package/lib/inngest/setup.cjs +38 -0
- package/lib/inngest/setup.cjs.map +1 -0
- package/lib/inngest/setup.d.ts +10 -0
- package/lib/inngest/setup.mjs +38 -0
- package/lib/inngest/setup.mjs.map +1 -0
- package/lib/interfaces/graphql-request-context.d.ts +5 -0
- package/lib/middleware/index.d.ts +5 -0
- package/lib/middleware/redis-client.cjs +18 -0
- package/lib/middleware/redis-client.cjs.map +1 -0
- package/lib/middleware/redis-client.d.ts +16 -0
- package/lib/middleware/redis-client.mjs +18 -0
- package/lib/middleware/redis-client.mjs.map +1 -0
- package/lib/plugins/responseCachePlugin.cjs +1 -2
- package/lib/plugins/responseCachePlugin.cjs.map +1 -1
- package/lib/plugins/responseCachePlugin.mjs +1 -2
- package/lib/plugins/responseCachePlugin.mjs.map +1 -1
- package/lib/servers/ExpressApp.cjs +7 -2
- package/lib/servers/ExpressApp.cjs.map +1 -1
- package/lib/servers/ExpressApp.d.ts +1 -1
- package/lib/servers/ExpressApp.mjs +7 -2
- package/lib/servers/ExpressApp.mjs.map +1 -1
- package/lib/servers/GraphqlServer.cjs +7 -2
- package/lib/servers/GraphqlServer.cjs.map +1 -1
- package/lib/servers/GraphqlServer.d.ts +8 -6
- package/lib/servers/GraphqlServer.mjs +7 -2
- package/lib/servers/GraphqlServer.mjs.map +1 -1
- package/lib/servers/mongodb-migration-update.d.ts +1 -1
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/safe-model-factory.d.ts +18 -0
- package/package.json +10 -9
- package/lib/api/resolver.cjs +0 -12
- package/lib/api/resolver.cjs.map +0 -1
- package/lib/api/resolver.mjs +0 -12
- package/lib/api/resolver.mjs.map +0 -1
- package/lib/api/root-schema.graphqls.cjs +0 -2
- package/lib/api/root-schema.graphqls.cjs.map +0 -1
- package/lib/api/root-schema.graphqls.mjs +0 -2
- package/lib/api/root-schema.graphqls.mjs.map +0 -1
- package/lib/api/scalar.cjs +0 -16
- package/lib/api/scalar.cjs.map +0 -1
- package/lib/api/scalar.mjs +0 -16
- package/lib/api/scalar.mjs.map +0 -1
- package/lib/graphql/directives/index.cjs +0 -10
- package/lib/graphql/directives/index.cjs.map +0 -1
- package/lib/graphql/directives/index.d.ts +0 -7
- package/lib/graphql/directives/index.mjs +0 -10
- package/lib/graphql/directives/index.mjs.map +0 -1
- package/lib/graphql/index.d.ts +0 -2
- package/lib/graphql/schema/directives.graphql.cjs +0 -1
- package/lib/graphql/schema/directives.graphql.cjs.map +0 -1
- package/lib/graphql/schema/directives.graphql.mjs +0 -1
- package/lib/graphql/schema/directives.graphql.mjs.map +0 -1
- package/lib/graphql/schema/index.cjs +0 -1
- package/lib/graphql/schema/index.cjs.map +0 -1
- package/lib/graphql/schema/index.d.ts +0 -1
- package/lib/graphql/schema/index.mjs +0 -1
- package/lib/graphql/schema/index.mjs.map +0 -1
package/lib/MainStackServer.mjs
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import*as http from'http';import {logger}from'@cdm-logger/server';import {Feature}from'@common-stack/server-core';import {
|
|
1
|
+
import'reflect-metadata';import*as http from'http';import {logger}from'@cdm-logger/server';import {Feature}from'@common-stack/server-core';import {isEmpty}from'lodash-es';import graphqlModule from'@common-stack/graphql-api/lib/module.js';import {expressApp}from'./servers/ExpressApp.mjs';import {GraphqlServer}from'./servers/GraphqlServer.mjs';import {config}from'./config/env-config.mjs';import {GatewaySchemaBuilder}from'./api/schema-builder.mjs';import {WebsocketMultiPathServer}from'./servers/WebsocketMultipathUpdate.mjs';import {migrate}from'./utils/migrations.mjs';import'graphql';import {SubGraphSchemaBuilder}from'./api/sub-graph-schema-builder.mjs';import {setupInngestFunctions}from'./inngest/setup.mjs';import'inversify';import'@common-stack/core';import {InfrastructureFactory}from'./infrastructure/infrastructure-factory.mjs';import'inngest';/* eslint-disable import/namespace */
|
|
2
2
|
/* eslint-disable import/no-unresolved */
|
|
3
3
|
/* eslint-disable import/no-extraneous-dependencies */
|
|
4
4
|
// version 08/25/2021
|
|
5
|
+
const graphqlApiFeature = graphqlModule.default ?? graphqlModule;
|
|
5
6
|
function startListening(port) {
|
|
6
7
|
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
7
8
|
const server = this;
|
|
@@ -9,18 +10,6 @@ function startListening(port) {
|
|
|
9
10
|
server.listen(port, resolve);
|
|
10
11
|
});
|
|
11
12
|
}
|
|
12
|
-
const infraModule = ({ broker, pubsub, mongoClient, logger, redisClient }) => new ContainerModule((bind) => {
|
|
13
|
-
bind('Logger').toConstantValue(logger);
|
|
14
|
-
bind(CommonType.LOGGER).toConstantValue(logger);
|
|
15
|
-
bind('Environment').toConstantValue(config.NODE_ENV || 'development');
|
|
16
|
-
bind(CommonType.ENVIRONMENT).toConstantValue(config.NODE_ENV || 'development');
|
|
17
|
-
bind('PubSub').toConstantValue(pubsub);
|
|
18
|
-
bind(CommonType.PUBSUB).toConstantValue(pubsub);
|
|
19
|
-
bind(CommonType.MOLECULER_BROKER).toConstantValue(broker);
|
|
20
|
-
bind(CommonType.REDIS_CLIENT).toConstantValue(redisClient);
|
|
21
|
-
bind('MoleculerBroker').toConstantValue(broker);
|
|
22
|
-
bind('MongoDBConnection').toConstantValue(mongoClient);
|
|
23
|
-
});
|
|
24
13
|
/**
|
|
25
14
|
* Controls the lifecycle of the Application Server
|
|
26
15
|
*
|
|
@@ -31,116 +20,84 @@ class MainStackServer {
|
|
|
31
20
|
httpServer;
|
|
32
21
|
app;
|
|
33
22
|
logger;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
23
|
+
infrastructureFactory;
|
|
24
|
+
mainServiceContext;
|
|
25
|
+
microserviceContext;
|
|
37
26
|
multiPathWebsocket;
|
|
38
|
-
serviceContainer;
|
|
39
|
-
microserviceContainer;
|
|
40
27
|
serverFeature;
|
|
41
28
|
settings;
|
|
42
29
|
options;
|
|
30
|
+
serviceBroker;
|
|
31
|
+
allModules;
|
|
43
32
|
constructor(feature, settings, options) {
|
|
44
33
|
this.serverFeature = feature;
|
|
45
34
|
this.settings = settings;
|
|
46
35
|
this.options = options;
|
|
47
36
|
this.logger = logger.child({ className: 'StackServer' });
|
|
37
|
+
this.infrastructureFactory = new InfrastructureFactory(this.logger);
|
|
48
38
|
}
|
|
49
39
|
async initialize() {
|
|
50
40
|
this.logger.info('StackServer initializing');
|
|
51
|
-
//
|
|
52
|
-
this.
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
//
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
InterNamespaceMiddleware([
|
|
60
|
-
{
|
|
61
|
-
namespace: 'api-admin',
|
|
62
|
-
transporter: brokerConfig.transporter,
|
|
63
|
-
metrics: { enabled: false },
|
|
64
|
-
},
|
|
65
|
-
]),
|
|
66
|
-
],
|
|
67
|
-
started: async () => {
|
|
68
|
-
await this.serverFeature.preStart(this.serviceContainer);
|
|
69
|
-
if (config.NODE_ENV === 'development') ;
|
|
70
|
-
try {
|
|
71
|
-
this.logger.info('Starting Migration');
|
|
72
|
-
await migrate(mongoClient, this.serviceContainer, this.logger);
|
|
73
|
-
this.logger.info('End Migration');
|
|
74
|
-
}
|
|
75
|
-
catch (e) {
|
|
76
|
-
this.logger.error('Error while running migrations', e);
|
|
77
|
-
this.logger.error(e.stack);
|
|
78
|
-
}
|
|
79
|
-
try {
|
|
80
|
-
await this.serverFeature.postStart(this.serviceContainer);
|
|
81
|
-
}
|
|
82
|
-
catch (e) {
|
|
83
|
-
this.logger.error('Error while running Post Start due to [%s]', e.message);
|
|
84
|
-
this.logger.error(e.stack);
|
|
85
|
-
}
|
|
86
|
-
// start DB migration
|
|
87
|
-
if (config.NODE_ENV === 'development') ;
|
|
88
|
-
},
|
|
89
|
-
// created,
|
|
90
|
-
async created() {
|
|
91
|
-
return Promise.resolve();
|
|
92
|
-
},
|
|
93
|
-
});
|
|
41
|
+
// Initialize infrastructure factory
|
|
42
|
+
await this.infrastructureFactory.initialize();
|
|
43
|
+
// Create main service broker and container
|
|
44
|
+
this.mainServiceContext = await this.infrastructureFactory.createBrokerAndContainer(InfrastructureFactory.createMainServiceConfig(), this.serverFeature, this.settings);
|
|
45
|
+
// Setup main service broker lifecycle
|
|
46
|
+
this.setupMainServiceBrokerLifecycle();
|
|
47
|
+
// Create microservice broker and container for development environment
|
|
48
|
+
// Reuse same allModules but allow separate container with proper bindings
|
|
94
49
|
if (config.NODE_ENV === 'development') {
|
|
95
|
-
this.
|
|
96
|
-
|
|
97
|
-
metrics: { enabled: false },
|
|
98
|
-
nodeID: 'node-broker-2',
|
|
99
|
-
started: async () => {
|
|
100
|
-
await this.serverFeature.microservicePreStart(this.microserviceContainer);
|
|
101
|
-
await this.serverFeature.microservicePostStart(this.microserviceContainer);
|
|
102
|
-
},
|
|
103
|
-
// created,
|
|
104
|
-
created: async () => Promise.resolve(),
|
|
105
|
-
});
|
|
50
|
+
this.microserviceContext = await this.infrastructureFactory.createBrokerAndContainer(InfrastructureFactory.createDevelopmentMicroserviceConfig(), this.serverFeature, this.settings, this.mainServiceContext.allModules);
|
|
51
|
+
this.setupMicroserviceBrokerLifecycle();
|
|
106
52
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
53
|
+
// Build GraphQL schema and create service context
|
|
54
|
+
await this.setupGraphQLSchema();
|
|
55
|
+
// Initialize HTTP server and Express app
|
|
56
|
+
await this.setupHttpServer();
|
|
57
|
+
}
|
|
58
|
+
setupMainServiceBrokerLifecycle() {
|
|
59
|
+
const originalStart = this.mainServiceContext.broker.start.bind(this.mainServiceContext.broker);
|
|
60
|
+
this.mainServiceContext.broker.start = async () => {
|
|
61
|
+
await originalStart();
|
|
62
|
+
// Execute pre-start hooks
|
|
63
|
+
await this.serverFeature.preStart(this.mainServiceContext.container);
|
|
64
|
+
try {
|
|
65
|
+
this.logger.info('Starting Migration');
|
|
66
|
+
await migrate(this.mainServiceContext.context.mongoClient, this.mainServiceContext.container, this.logger);
|
|
67
|
+
this.logger.info('End Migration');
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
this.logger.error('Error while running migrations', e);
|
|
71
|
+
this.logger.error(e.stack);
|
|
72
|
+
}
|
|
73
|
+
try {
|
|
74
|
+
await this.serverFeature.postStart(this.mainServiceContext.container);
|
|
75
|
+
}
|
|
76
|
+
catch (e) {
|
|
77
|
+
this.logger.error('Error while running Post Start due to [%s]', e.message);
|
|
78
|
+
this.logger.error(e.stack);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
setupMicroserviceBrokerLifecycle() {
|
|
83
|
+
if (!this.microserviceContext)
|
|
84
|
+
return;
|
|
85
|
+
const originalStart = this.microserviceContext.broker.start.bind(this.microserviceContext.broker);
|
|
86
|
+
this.microserviceContext.broker.start = async () => {
|
|
87
|
+
await originalStart();
|
|
88
|
+
await this.serverFeature.microservicePreStart(this.microserviceContext.container);
|
|
89
|
+
await this.serverFeature.microservicePostStart(this.microserviceContext.container);
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
async setupGraphQLSchema() {
|
|
93
|
+
const { context, container, allModules: baseModules } = this.mainServiceContext;
|
|
94
|
+
// Compose features using the proper Feature pattern
|
|
95
|
+
const allModules = new Feature(this.mainServiceContext.allModules, graphqlApiFeature);
|
|
139
96
|
const Constructor = this?.options?.isSubGraph ? SubGraphSchemaBuilder : GatewaySchemaBuilder;
|
|
140
97
|
const executableSchema = await new Constructor({
|
|
141
98
|
schema: allModules.schemas,
|
|
142
99
|
resolvers: allModules.createResolvers({
|
|
143
|
-
pubsub,
|
|
100
|
+
pubsub: context.pubsub,
|
|
144
101
|
logger: logger,
|
|
145
102
|
subscriptionID: `${this.settings.subTopic}`,
|
|
146
103
|
}),
|
|
@@ -150,53 +107,55 @@ class MainStackServer {
|
|
|
150
107
|
rules: allModules.rules,
|
|
151
108
|
logger: logger,
|
|
152
109
|
}).build();
|
|
153
|
-
//
|
|
154
|
-
|
|
155
|
-
|
|
110
|
+
// Use the existing singleton container
|
|
111
|
+
const serviceContainer = container;
|
|
112
|
+
// Initialize services once to avoid recreating containers on every request
|
|
113
|
+
await allModules.createService({
|
|
156
114
|
...this.settings,
|
|
157
|
-
mongoConnection: mongoClient,
|
|
115
|
+
mongoConnection: context.mongoClient,
|
|
158
116
|
});
|
|
117
|
+
// Pre-create the service context function to avoid recreating containers on every request
|
|
118
|
+
const serviceContextFunc = allModules.createServiceContext({
|
|
119
|
+
...this.settings,
|
|
120
|
+
mongoConnection: context.mongoClient,
|
|
121
|
+
});
|
|
122
|
+
// Create service broker interface
|
|
159
123
|
const serviceBroker = {
|
|
160
|
-
serviceContainer:
|
|
161
|
-
serviceContext:
|
|
124
|
+
serviceContainer: serviceContainer,
|
|
125
|
+
serviceContext: serviceContextFunc,
|
|
162
126
|
dataSource: allModules.createDataSource(),
|
|
163
127
|
defaultPreferences: allModules.createDefaultPreferences(),
|
|
164
128
|
createContext: async (req, res) => allModules.createContext(req, res),
|
|
165
129
|
logger: logger,
|
|
166
130
|
schema: executableSchema,
|
|
167
131
|
};
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
this.microserviceContainer = await allModules.createHemeraContainers({
|
|
175
|
-
...this.settings,
|
|
176
|
-
mongoConnection: mongoClient,
|
|
177
|
-
});
|
|
178
|
-
allModules.loadClientMoleculerService({
|
|
179
|
-
broker: this.microserviceBroker,
|
|
180
|
-
container: this.microserviceContainer,
|
|
181
|
-
settings: this.settings,
|
|
182
|
-
});
|
|
183
|
-
}
|
|
184
|
-
// initialize Servers
|
|
132
|
+
this.serviceBroker = serviceBroker;
|
|
133
|
+
this.allModules = allModules;
|
|
134
|
+
}
|
|
135
|
+
async setupHttpServer() {
|
|
136
|
+
const { context } = this.mainServiceContext;
|
|
137
|
+
// Initialize HTTP server and Express app
|
|
185
138
|
this.httpServer = http.createServer();
|
|
186
|
-
|
|
187
|
-
|
|
139
|
+
// Pass Redis client to expressApp so it can be attached at the very top of middleware stack
|
|
140
|
+
this.app = await expressApp(this.allModules, this.serviceBroker, null, this.httpServer, context.redisClient);
|
|
141
|
+
// Register existing express middleware (Redis client middleware is already attached in expressApp)
|
|
142
|
+
this.allModules.registerExpressMiddleware(this.app, this.mainServiceContext.container);
|
|
143
|
+
// Setup Inngest functions
|
|
144
|
+
setupInngestFunctions(this.allModules, this.app, this.mainServiceContext.container, this.logger);
|
|
188
145
|
this.httpServer.startListening = startListening.bind(this.httpServer);
|
|
189
146
|
this.httpServer.on('request', this.app);
|
|
190
147
|
this.httpServer.on('close', () => {
|
|
191
148
|
this.httpServer = undefined;
|
|
192
149
|
});
|
|
193
|
-
|
|
150
|
+
// Setup WebSocket if configured
|
|
151
|
+
const customWebsocket = this.allModules.getWebsocketConfig();
|
|
194
152
|
const customWebsocketEnable = !isEmpty(customWebsocket);
|
|
195
153
|
if (customWebsocketEnable) {
|
|
196
|
-
this.multiPathWebsocket = new WebsocketMultiPathServer(serviceBroker, redisClient, customWebsocket);
|
|
154
|
+
this.multiPathWebsocket = new WebsocketMultiPathServer(this.serviceBroker, context.redisClient, customWebsocket);
|
|
197
155
|
this.httpServer = this.multiPathWebsocket.httpServerUpgrade(this.httpServer);
|
|
198
156
|
}
|
|
199
|
-
|
|
157
|
+
// Setup GraphQL server
|
|
158
|
+
const graphqlServer = new GraphqlServer(this.app, this.httpServer, context.redisClient, this.serviceBroker, !customWebsocketEnable, this.allModules.apolloCacheKeyGenerator.bind(this.allModules), this.allModules.apolloInvalidateCacheKeyGenerator.bind(this.allModules), this.allModules.graphqlPlugins);
|
|
200
159
|
await graphqlServer.initialize();
|
|
201
160
|
this.app.use('/graphql', (req, res, next) => {
|
|
202
161
|
res.append('Access-Control-Allow-Credentials', JSON.stringify(true));
|
|
@@ -207,11 +166,11 @@ class MainStackServer {
|
|
|
207
166
|
});
|
|
208
167
|
}
|
|
209
168
|
async start() {
|
|
210
|
-
if (config.NODE_ENV === 'development') {
|
|
211
|
-
await Promise.all([this.
|
|
169
|
+
if (config.NODE_ENV === 'development' && this.microserviceContext) {
|
|
170
|
+
await Promise.all([this.mainServiceContext.broker.start(), this.microserviceContext.broker.start()]);
|
|
212
171
|
}
|
|
213
172
|
else {
|
|
214
|
-
await this.
|
|
173
|
+
await this.mainServiceContext.broker.start();
|
|
215
174
|
}
|
|
216
175
|
}
|
|
217
176
|
async cleanup() {
|
|
@@ -221,14 +180,14 @@ class MainStackServer {
|
|
|
221
180
|
if (this.httpServer) {
|
|
222
181
|
await this.httpServer.close();
|
|
223
182
|
}
|
|
224
|
-
if (this.
|
|
225
|
-
await this.
|
|
183
|
+
if (this.infrastructureFactory) {
|
|
184
|
+
await this.infrastructureFactory.cleanup();
|
|
226
185
|
}
|
|
227
|
-
if (this.
|
|
228
|
-
await this.
|
|
186
|
+
if (this.mainServiceContext?.broker) {
|
|
187
|
+
await this.mainServiceContext.broker.stop();
|
|
229
188
|
}
|
|
230
|
-
if (this.
|
|
231
|
-
await this.
|
|
189
|
+
if (this.microserviceContext?.broker) {
|
|
190
|
+
await this.microserviceContext.broker.stop();
|
|
232
191
|
}
|
|
233
192
|
}
|
|
234
193
|
}export{MainStackServer};//# sourceMappingURL=MainStackServer.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MainStackServer.mjs","sources":["../src/MainStackServer.ts"],"sourcesContent":[null],"names":["serverLogger"],"mappings":"
|
|
1
|
+
{"version":3,"file":"MainStackServer.mjs","sources":["../src/MainStackServer.ts"],"sourcesContent":[null],"names":["serverLogger"],"mappings":"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"}
|
package/lib/StackServer.cjs
CHANGED
|
@@ -1,92 +1,49 @@
|
|
|
1
|
-
'use strict';var server=require('@cdm-logger/server')
|
|
1
|
+
'use strict';var server=require('@cdm-logger/server');require('inversify'),require('@common-stack/core');var infrastructureFactory=require('./infrastructure/infrastructure-factory.cjs');require('inngest'),require('./config/env-config.cjs');/* eslint-disable import/no-extraneous-dependencies */
|
|
2
2
|
/* eslint-disable import/namespace */
|
|
3
|
-
const infraModule = ({ broker, pubsub, mongoClient, logger }) => new inversify.ContainerModule((bind) => {
|
|
4
|
-
bind('Logger').toConstantValue(logger);
|
|
5
|
-
bind(core.CommonType.LOGGER).toConstantValue(logger);
|
|
6
|
-
bind('Environment').toConstantValue(envConfig.config.NODE_ENV || 'development');
|
|
7
|
-
bind(core.CommonType.ENVIRONMENT).toConstantValue(envConfig.config.NODE_ENV || 'development');
|
|
8
|
-
bind('PubSub').toConstantValue(pubsub);
|
|
9
|
-
bind(core.CommonType.PUBSUB).toConstantValue(pubsub);
|
|
10
|
-
bind(core.CommonType.MOLECULER_BROKER).toConstantValue(broker);
|
|
11
|
-
bind('MoleculerBroker').toConstantValue(broker);
|
|
12
|
-
bind('MongoDBConnection').toConstantValue(mongoClient);
|
|
13
|
-
});
|
|
14
3
|
/**
|
|
15
|
-
* Controls the lifecycle of the
|
|
4
|
+
* Controls the lifecycle of the Microservice Server
|
|
16
5
|
*
|
|
17
6
|
* @export
|
|
18
7
|
* @class StackServer
|
|
19
8
|
*/
|
|
20
9
|
class StackServer {
|
|
21
10
|
logger;
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
serviceContainer;
|
|
25
|
-
microserviceContainer;
|
|
11
|
+
infrastructureFactory;
|
|
12
|
+
microserviceContext;
|
|
26
13
|
serverFeature;
|
|
27
14
|
settings;
|
|
28
15
|
constructor(feature, settings) {
|
|
29
16
|
this.serverFeature = feature;
|
|
30
17
|
this.settings = settings;
|
|
31
18
|
this.logger = server.logger.child({ className: 'StackServer' });
|
|
19
|
+
this.infrastructureFactory = new infrastructureFactory.InfrastructureFactory(this.logger);
|
|
32
20
|
}
|
|
33
21
|
async initialize() {
|
|
34
22
|
this.logger.info('StackServer initializing');
|
|
35
|
-
|
|
36
|
-
await this.
|
|
37
|
-
|
|
38
|
-
this.
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
started: async () => {
|
|
49
|
-
await this.serverFeature.microservicePreStart(this.microserviceContainer);
|
|
50
|
-
await this.serverFeature.microservicePostStart(this.microserviceContainer);
|
|
51
|
-
},
|
|
52
|
-
});
|
|
53
|
-
const pubsub = await this.connectionBroker.graphqlPubsub;
|
|
54
|
-
const InfraStructureFeature = new serverCore.Feature({
|
|
55
|
-
createHemeraContainerFunc: [
|
|
56
|
-
() => infraModule({
|
|
57
|
-
broker: this.microserviceBroker,
|
|
58
|
-
pubsub,
|
|
59
|
-
mongoClient,
|
|
60
|
-
logger: server.logger,
|
|
61
|
-
}),
|
|
62
|
-
],
|
|
63
|
-
});
|
|
64
|
-
const allModules = new serverCore.Feature(InfraStructureFeature, this.serverFeature);
|
|
65
|
-
this.microserviceContainer = await allModules.createHemeraContainers({
|
|
66
|
-
...this.settings,
|
|
67
|
-
mongoConnection: mongoClient,
|
|
68
|
-
});
|
|
69
|
-
const serviceBroker = {
|
|
70
|
-
microserviceContainer: this.microserviceContainer,
|
|
71
|
-
logger: this.logger,
|
|
23
|
+
// Initialize infrastructure factory
|
|
24
|
+
await this.infrastructureFactory.initialize();
|
|
25
|
+
// Create microservice broker and container with all required bindings
|
|
26
|
+
this.microserviceContext = await this.infrastructureFactory.createBrokerAndContainer(infrastructureFactory.InfrastructureFactory.createMicroserviceConfig(), this.serverFeature, this.settings);
|
|
27
|
+
// Setup microservice broker lifecycle
|
|
28
|
+
this.setupMicroserviceBrokerLifecycle();
|
|
29
|
+
}
|
|
30
|
+
setupMicroserviceBrokerLifecycle() {
|
|
31
|
+
const originalStart = this.microserviceContext.broker.start.bind(this.microserviceContext.broker);
|
|
32
|
+
this.microserviceContext.broker.start = async () => {
|
|
33
|
+
await originalStart();
|
|
34
|
+
await this.serverFeature.microservicePreStart(this.microserviceContext.container);
|
|
35
|
+
await this.serverFeature.microservicePostStart(this.microserviceContext.container);
|
|
72
36
|
};
|
|
73
|
-
// set the service container
|
|
74
|
-
this.microserviceContainer = serviceBroker.microserviceContainer;
|
|
75
|
-
allModules.loadClientMoleculerService({
|
|
76
|
-
broker: this.microserviceBroker,
|
|
77
|
-
container: this.microserviceContainer,
|
|
78
|
-
settings: this.settings,
|
|
79
|
-
});
|
|
80
37
|
}
|
|
81
38
|
async start() {
|
|
82
|
-
await this.
|
|
39
|
+
await this.microserviceContext.broker.start();
|
|
83
40
|
}
|
|
84
41
|
async cleanup() {
|
|
85
|
-
if (this.
|
|
86
|
-
await this.
|
|
42
|
+
if (this.infrastructureFactory) {
|
|
43
|
+
await this.infrastructureFactory.cleanup();
|
|
87
44
|
}
|
|
88
|
-
if (this.
|
|
89
|
-
await this.
|
|
45
|
+
if (this.microserviceContext?.broker) {
|
|
46
|
+
await this.microserviceContext.broker.stop();
|
|
90
47
|
}
|
|
91
48
|
}
|
|
92
49
|
}exports.StackServer=StackServer;//# sourceMappingURL=StackServer.cjs.map
|
package/lib/StackServer.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StackServer.cjs","sources":["../src/StackServer.ts"],"sourcesContent":[null],"names":["
|
|
1
|
+
{"version":3,"file":"StackServer.cjs","sources":["../src/StackServer.ts"],"sourcesContent":[null],"names":["serverLogger","InfrastructureFactory"],"mappings":"gPAAA;AACA;AAaA;;;;;AAKG;MACU,WAAW,CAAA;AACZ,IAAA,MAAM,CAAU;AAEhB,IAAA,qBAAqB,CAAwB;AAE7C,IAAA,mBAAmB,CAIzB;AAEM,IAAA,aAAa,CAAgB;AAE7B,IAAA,QAAQ,CAAC;IAEjB,WAAY,CAAA,OAAsB,EAAE,QAAQ,EAAA;AACxC,QAAA,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;AAC7B,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;AACzB,QAAA,IAAI,CAAC,MAAM,GAAGA,aAAY,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,qBAAqB,GAAG,IAAIC,2CAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;KACvE;AAEM,IAAA,MAAM,UAAU,GAAA;AACnB,QAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;;AAG7C,QAAA,MAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC;;QAG9C,IAAI,CAAC,mBAAmB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,wBAAwB,CAChFA,2CAAqB,CAAC,wBAAwB,EAAE,EAChD,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,QAAQ,CAChB,CAAC;;QAGF,IAAI,CAAC,gCAAgC,EAAE,CAAC;KAC3C;IAEO,gCAAgC,GAAA;AACpC,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAClG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,KAAK,GAAG,YAAW;YAC/C,MAAM,aAAa,EAAE,CAAC;AACtB,YAAA,MAAM,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;AAClF,YAAA,MAAM,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;AACvF,SAAC,CAAC;KACL;AAEM,IAAA,MAAM,KAAK,GAAA;QACd,MAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;KACjD;AAEM,IAAA,MAAM,OAAO,GAAA;AAChB,QAAA,IAAI,IAAI,CAAC,qBAAqB,EAAE;AAC5B,YAAA,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;SAC9C;AACD,QAAA,IAAI,IAAI,CAAC,mBAAmB,EAAE,MAAM,EAAE;YAClC,MAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;SAChD;KACJ;AACJ"}
|
package/lib/StackServer.d.ts
CHANGED
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
import { Feature as ServerFeature } from '@common-stack/server-core';
|
|
2
2
|
/**
|
|
3
|
-
* Controls the lifecycle of the
|
|
3
|
+
* Controls the lifecycle of the Microservice Server
|
|
4
4
|
*
|
|
5
5
|
* @export
|
|
6
6
|
* @class StackServer
|
|
7
7
|
*/
|
|
8
8
|
export declare class StackServer {
|
|
9
9
|
private logger;
|
|
10
|
-
private
|
|
11
|
-
private
|
|
12
|
-
private serviceContainer;
|
|
13
|
-
private microserviceContainer;
|
|
10
|
+
private infrastructureFactory;
|
|
11
|
+
private microserviceContext;
|
|
14
12
|
private serverFeature;
|
|
15
13
|
private settings;
|
|
16
14
|
constructor(feature: ServerFeature, settings: any);
|
|
17
15
|
initialize(): Promise<void>;
|
|
16
|
+
private setupMicroserviceBrokerLifecycle;
|
|
18
17
|
start(): Promise<void>;
|
|
19
18
|
cleanup(): Promise<void>;
|
|
20
19
|
}
|