@common-stack/server-stack 8.0.2-alpha.0 → 8.2.1-alpha.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.
- package/LICENSE +34 -21
- package/lib/MainStackServer.cjs +126 -146
- package/lib/MainStackServer.cjs.map +1 -1
- package/lib/MainStackServer.d.ts +12 -6
- package/lib/MainStackServer.mjs +126 -146
- 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 +147 -0
- package/lib/api/sub-graph-schema-builder.cjs.map +1 -0
- package/lib/api/sub-graph-schema-builder.d.ts +24 -0
- package/lib/api/sub-graph-schema-builder.mjs +147 -0
- package/lib/api/sub-graph-schema-builder.mjs.map +1 -0
- 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 +172 -0
- package/lib/infrastructure/infrastructure-factory.cjs.map +1 -0
- package/lib/infrastructure/infrastructure-factory.d.ts +36 -0
- package/lib/infrastructure/infrastructure-factory.mjs +172 -0
- package/lib/infrastructure/infrastructure-factory.mjs.map +1 -0
- package/lib/infrastructure/inngest-factory.cjs +47 -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 +47 -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 +24 -0
- package/lib/inngest/middleware/auto-resolve-invoke.middleware.cjs +275 -0
- package/lib/inngest/middleware/auto-resolve-invoke.middleware.cjs.map +1 -0
- package/lib/inngest/middleware/auto-resolve-invoke.middleware.d.ts +111 -0
- package/lib/inngest/middleware/auto-resolve-invoke.middleware.mjs +275 -0
- package/lib/inngest/middleware/auto-resolve-invoke.middleware.mjs.map +1 -0
- package/lib/inngest/middleware/function-reference-helper.cjs +363 -0
- package/lib/inngest/middleware/function-reference-helper.cjs.map +1 -0
- package/lib/inngest/middleware/function-reference-helper.d.ts +211 -0
- package/lib/inngest/middleware/function-reference-helper.mjs +363 -0
- package/lib/inngest/middleware/function-reference-helper.mjs.map +1 -0
- package/lib/inngest/middleware/index.d.ts +31 -0
- package/lib/inngest/middleware/types.d.ts +162 -0
- package/lib/inngest/multi-module-functions.d.ts +133 -0
- package/lib/inngest/setup.cjs +55 -0
- package/lib/inngest/setup.cjs.map +1 -0
- package/lib/inngest/setup.d.ts +10 -0
- package/lib/inngest/setup.mjs +55 -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 +2 -2
- package/lib/plugins/responseCachePlugin.cjs.map +1 -1
- package/lib/plugins/responseCachePlugin.mjs +2 -2
- package/lib/plugins/responseCachePlugin.mjs.map +1 -1
- package/lib/servers/ExpressApp.cjs +8 -3
- package/lib/servers/ExpressApp.cjs.map +1 -1
- package/lib/servers/ExpressApp.d.ts +1 -1
- package/lib/servers/ExpressApp.mjs +8 -3
- 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/GraphqlWs.cjs +3 -44
- package/lib/servers/GraphqlWs.cjs.map +1 -1
- package/lib/servers/GraphqlWs.mjs +3 -44
- package/lib/servers/GraphqlWs.mjs.map +1 -1
- package/lib/servers/WebsocketMultipathUpdate.cjs +4 -2
- package/lib/servers/WebsocketMultipathUpdate.cjs.map +1 -1
- package/lib/servers/WebsocketMultipathUpdate.mjs +4 -2
- package/lib/servers/WebsocketMultipathUpdate.mjs.map +1 -1
- package/lib/servers/mongodb-migration-update.d.ts +1 -1
- package/lib/servers/websocket-context.cjs +70 -0
- package/lib/servers/websocket-context.cjs.map +1 -0
- package/lib/servers/websocket-context.d.ts +30 -0
- package/lib/servers/websocket-context.mjs +70 -0
- package/lib/servers/websocket-context.mjs.map +1 -0
- package/lib/utils/add-shareable-directive-to-schema.cjs +44 -0
- package/lib/utils/add-shareable-directive-to-schema.cjs.map +1 -0
- package/lib/utils/add-shareable-directive-to-schema.d.ts +1 -0
- package/lib/utils/add-shareable-directive-to-schema.mjs +44 -0
- package/lib/utils/add-shareable-directive-to-schema.mjs.map +1 -0
- package/lib/utils/index.d.ts +2 -0
- package/lib/utils/safe-model-factory.d.ts +18 -0
- package/package.json +15 -11
- 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/plugins/invalidateCachePlugin.test.d.ts +0 -1
- package/lib/plugins/response-cache-plugin.test.d.ts +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,merge}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,113 +20,86 @@ 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;
|
|
32
|
+
constructor(feature, settings, options) {
|
|
43
33
|
this.serverFeature = feature;
|
|
44
34
|
this.settings = settings;
|
|
35
|
+
this.options = options;
|
|
45
36
|
this.logger = logger.child({ className: 'StackServer' });
|
|
37
|
+
this.infrastructureFactory = new InfrastructureFactory(this.logger);
|
|
46
38
|
}
|
|
47
39
|
async initialize() {
|
|
48
40
|
this.logger.info('StackServer initializing');
|
|
49
|
-
//
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
//
|
|
54
|
-
this.
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
InterNamespaceMiddleware([
|
|
58
|
-
{
|
|
59
|
-
namespace: 'api-admin',
|
|
60
|
-
transporter: brokerConfig.transporter,
|
|
61
|
-
metrics: { enabled: false },
|
|
62
|
-
},
|
|
63
|
-
]),
|
|
64
|
-
],
|
|
65
|
-
started: async () => {
|
|
66
|
-
await this.serverFeature.preStart(this.serviceContainer);
|
|
67
|
-
if (config.NODE_ENV === 'development') ;
|
|
68
|
-
try {
|
|
69
|
-
this.logger.info('Starting Migration');
|
|
70
|
-
await migrate(mongoClient, this.serviceContainer, this.logger);
|
|
71
|
-
this.logger.info('End Migration');
|
|
72
|
-
}
|
|
73
|
-
catch (e) {
|
|
74
|
-
this.logger.error('Error while running migrations', e);
|
|
75
|
-
this.logger.error(e.stack);
|
|
76
|
-
}
|
|
77
|
-
try {
|
|
78
|
-
await this.serverFeature.postStart(this.serviceContainer);
|
|
79
|
-
}
|
|
80
|
-
catch (e) {
|
|
81
|
-
this.logger.error('Error while running Post Start due to [%s]', e.message);
|
|
82
|
-
this.logger.error(e.stack);
|
|
83
|
-
}
|
|
84
|
-
// start DB migration
|
|
85
|
-
if (config.NODE_ENV === 'development') ;
|
|
86
|
-
},
|
|
87
|
-
// created,
|
|
88
|
-
async created() {
|
|
89
|
-
return Promise.resolve();
|
|
90
|
-
},
|
|
91
|
-
});
|
|
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
|
|
92
49
|
if (config.NODE_ENV === 'development') {
|
|
93
|
-
this.
|
|
94
|
-
|
|
95
|
-
metrics: { enabled: false },
|
|
96
|
-
nodeID: 'node-broker-2',
|
|
97
|
-
started: async () => {
|
|
98
|
-
await this.serverFeature.microservicePreStart(this.microserviceContainer);
|
|
99
|
-
await this.serverFeature.microservicePostStart(this.microserviceContainer);
|
|
100
|
-
},
|
|
101
|
-
// created,
|
|
102
|
-
created: async () => Promise.resolve(),
|
|
103
|
-
});
|
|
50
|
+
this.microserviceContext = await this.infrastructureFactory.createBrokerAndContainer(InfrastructureFactory.createDevelopmentMicroserviceConfig(), this.serverFeature, this.settings, this.mainServiceContext.allModules);
|
|
51
|
+
this.setupMicroserviceBrokerLifecycle();
|
|
104
52
|
}
|
|
105
|
-
|
|
106
|
-
|
|
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
|
-
const
|
|
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
|
+
// Use main container if microservice container is null (due to module reuse)
|
|
89
|
+
const containerToUse = this.microserviceContext.container || this.mainServiceContext.container;
|
|
90
|
+
await this.serverFeature.microservicePreStart(containerToUse);
|
|
91
|
+
await this.serverFeature.microservicePostStart(containerToUse);
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
async setupGraphQLSchema() {
|
|
95
|
+
const { context, container, allModules: baseModules } = this.mainServiceContext;
|
|
96
|
+
// Compose features using the proper Feature pattern
|
|
97
|
+
const allModules = new Feature(this.mainServiceContext.allModules, graphqlApiFeature);
|
|
98
|
+
const Constructor = this?.options?.isSubGraph ? SubGraphSchemaBuilder : GatewaySchemaBuilder;
|
|
99
|
+
const executableSchema = await new Constructor({
|
|
138
100
|
schema: allModules.schemas,
|
|
139
101
|
resolvers: allModules.createResolvers({
|
|
140
|
-
pubsub,
|
|
102
|
+
pubsub: context.pubsub,
|
|
141
103
|
logger: logger,
|
|
142
104
|
subscriptionID: `${this.settings.subTopic}`,
|
|
143
105
|
}),
|
|
@@ -147,53 +109,71 @@ class MainStackServer {
|
|
|
147
109
|
rules: allModules.rules,
|
|
148
110
|
logger: logger,
|
|
149
111
|
}).build();
|
|
150
|
-
//
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
112
|
+
// Use the existing singleton container
|
|
113
|
+
const serviceContainer = container;
|
|
114
|
+
// Only create services if the base modules don't already have services created
|
|
115
|
+
// This prevents duplicate service creation when infrastructure factory already created them
|
|
116
|
+
let services;
|
|
117
|
+
const baseModulesServices = baseModules.services;
|
|
118
|
+
if (baseModulesServices) {
|
|
119
|
+
this.logger.info('Reusing existing services from infrastructure factory to avoid duplication');
|
|
120
|
+
services = baseModulesServices;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
try {
|
|
124
|
+
this.logger.info('Creating services for GraphQL schema (base modules had no services)');
|
|
125
|
+
services = await allModules.createService({
|
|
126
|
+
...this.settings,
|
|
127
|
+
mongoConnection: context.mongoClient,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
this.logger.error('Failed to create services in MainStackServer:', error);
|
|
132
|
+
services = {};
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
// Create service context function that uses the created services
|
|
136
|
+
const serviceContextFunc = async (req, connectionParams, webSocket) => {
|
|
137
|
+
const results = await Promise.all(allModules.createContextFunc.map((createContext) => createContext(req, connectionParams, webSocket)));
|
|
138
|
+
return merge({}, ...results, services);
|
|
139
|
+
};
|
|
140
|
+
// Create service broker interface
|
|
156
141
|
const serviceBroker = {
|
|
157
|
-
serviceContainer:
|
|
158
|
-
serviceContext:
|
|
142
|
+
serviceContainer: serviceContainer,
|
|
143
|
+
serviceContext: serviceContextFunc,
|
|
159
144
|
dataSource: allModules.createDataSource(),
|
|
160
145
|
defaultPreferences: allModules.createDefaultPreferences(),
|
|
161
146
|
createContext: async (req, res) => allModules.createContext(req, res),
|
|
162
147
|
logger: logger,
|
|
163
148
|
schema: executableSchema,
|
|
164
149
|
};
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
this.microserviceContainer = await allModules.createHemeraContainers({
|
|
172
|
-
...this.settings,
|
|
173
|
-
mongoConnection: mongoClient,
|
|
174
|
-
});
|
|
175
|
-
allModules.loadClientMoleculerService({
|
|
176
|
-
broker: this.microserviceBroker,
|
|
177
|
-
container: this.microserviceContainer,
|
|
178
|
-
settings: this.settings,
|
|
179
|
-
});
|
|
180
|
-
}
|
|
181
|
-
// initialize Servers
|
|
150
|
+
this.serviceBroker = serviceBroker;
|
|
151
|
+
this.allModules = allModules;
|
|
152
|
+
}
|
|
153
|
+
async setupHttpServer() {
|
|
154
|
+
const { context } = this.mainServiceContext;
|
|
155
|
+
// Initialize HTTP server and Express app
|
|
182
156
|
this.httpServer = http.createServer();
|
|
183
|
-
|
|
184
|
-
|
|
157
|
+
// Pass Redis client to expressApp so it can be attached at the very top of middleware stack
|
|
158
|
+
this.app = await expressApp(this.allModules, this.serviceBroker, null, this.httpServer, context.redisClient);
|
|
159
|
+
// Register existing express middleware (Redis client middleware is already attached in expressApp)
|
|
160
|
+
this.allModules.registerExpressMiddleware(this.app, this.mainServiceContext.container);
|
|
161
|
+
// Setup Inngest functions
|
|
162
|
+
setupInngestFunctions(this.allModules, this.app, this.mainServiceContext.container, this.logger);
|
|
185
163
|
this.httpServer.startListening = startListening.bind(this.httpServer);
|
|
186
164
|
this.httpServer.on('request', this.app);
|
|
187
165
|
this.httpServer.on('close', () => {
|
|
188
166
|
this.httpServer = undefined;
|
|
189
167
|
});
|
|
190
|
-
|
|
168
|
+
// Setup WebSocket if configured
|
|
169
|
+
const customWebsocket = this.allModules.getWebsocketConfig();
|
|
191
170
|
const customWebsocketEnable = !isEmpty(customWebsocket);
|
|
192
171
|
if (customWebsocketEnable) {
|
|
193
|
-
this.multiPathWebsocket = new WebsocketMultiPathServer(serviceBroker, redisClient, customWebsocket);
|
|
172
|
+
this.multiPathWebsocket = new WebsocketMultiPathServer(this.serviceBroker, context.redisClient, customWebsocket);
|
|
194
173
|
this.httpServer = this.multiPathWebsocket.httpServerUpgrade(this.httpServer);
|
|
195
174
|
}
|
|
196
|
-
|
|
175
|
+
// Setup GraphQL server
|
|
176
|
+
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);
|
|
197
177
|
await graphqlServer.initialize();
|
|
198
178
|
this.app.use('/graphql', (req, res, next) => {
|
|
199
179
|
res.append('Access-Control-Allow-Credentials', JSON.stringify(true));
|
|
@@ -204,11 +184,11 @@ class MainStackServer {
|
|
|
204
184
|
});
|
|
205
185
|
}
|
|
206
186
|
async start() {
|
|
207
|
-
if (config.NODE_ENV === 'development') {
|
|
208
|
-
await Promise.all([this.
|
|
187
|
+
if (config.NODE_ENV === 'development' && this.microserviceContext) {
|
|
188
|
+
await Promise.all([this.mainServiceContext.broker.start(), this.microserviceContext.broker.start()]);
|
|
209
189
|
}
|
|
210
190
|
else {
|
|
211
|
-
await this.
|
|
191
|
+
await this.mainServiceContext.broker.start();
|
|
212
192
|
}
|
|
213
193
|
}
|
|
214
194
|
async cleanup() {
|
|
@@ -218,14 +198,14 @@ class MainStackServer {
|
|
|
218
198
|
if (this.httpServer) {
|
|
219
199
|
await this.httpServer.close();
|
|
220
200
|
}
|
|
221
|
-
if (this.
|
|
222
|
-
await this.
|
|
201
|
+
if (this.infrastructureFactory) {
|
|
202
|
+
await this.infrastructureFactory.cleanup();
|
|
223
203
|
}
|
|
224
|
-
if (this.
|
|
225
|
-
await this.
|
|
204
|
+
if (this.mainServiceContext?.broker) {
|
|
205
|
+
await this.mainServiceContext.broker.stop();
|
|
226
206
|
}
|
|
227
|
-
if (this.
|
|
228
|
-
await this.
|
|
207
|
+
if (this.microserviceContext?.broker) {
|
|
208
|
+
await this.microserviceContext.broker.stop();
|
|
229
209
|
}
|
|
230
210
|
}
|
|
231
211
|
}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":"81BAAA;AACA;AACA;AACA;AAwBA,MAAM,iBAAiB,GAAI,aAAqB,CAAC,OAAO,IAAI,aAAa,CAAC;AAE1E,SAAS,cAAc,CAAC,IAAI,EAAA;;IAExB,MAAM,MAAM,GAAG,IAAI,CAAC;AACpB,IAAA,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,KAAI;AAC3B,QAAA,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACjC,KAAC,CAAC,CAAC;AACP,CAAC;AAED;;;;;AAKG;MACU,eAAe,CAAA;AACjB,IAAA,UAAU,CAAoD;AAE9D,IAAA,GAAG,CAAkB;AAEpB,IAAA,MAAM,CAAU;AAEhB,IAAA,qBAAqB,CAAwB;AAE7C,IAAA,kBAAkB,CAKxB;AAEM,IAAA,mBAAmB,CAKzB;AAEM,IAAA,kBAAkB,CAA2B;AAE7C,IAAA,aAAa,CAAgB;AAE7B,IAAA,QAAQ,CAAC;AAET,IAAA,OAAO,CAA0B;AAEjC,IAAA,aAAa,CAAiB;AAE9B,IAAA,UAAU,CAAU;AAE5B,IAAA,WAAA,CAAY,OAAsB,EAAE,QAAQ,EAAE,OAAiC,EAAA;AAC3E,QAAA,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;AAC7B,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;AACzB,QAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;AACvB,QAAA,IAAI,CAAC,MAAM,GAAGA,MAAY,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,qBAAqB,GAAG,IAAI,qBAAqB,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,kBAAkB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,wBAAwB,CAC/E,qBAAqB,CAAC,uBAAuB,EAAE,EAC/C,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,QAAQ,CAChB,CAAC;;QAGF,IAAI,CAAC,+BAA+B,EAAE,CAAC;;;AAIvC,QAAA,IAAI,MAAM,CAAC,QAAQ,KAAK,aAAa,EAAE;AACnC,YAAA,IAAI,CAAC,mBAAmB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,wBAAwB,CAChF,qBAAqB,CAAC,mCAAmC,EAAE,EAC3D,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACrC,CAAC;YACF,IAAI,CAAC,gCAAgC,EAAE,CAAC;SAC3C;;AAGD,QAAA,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;;AAGhC,QAAA,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;KAChC;IAEO,+BAA+B,GAAA;AACnC,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAChG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,GAAG,YAAW;YAC9C,MAAM,aAAa,EAAE,CAAC;;AAGtB,YAAA,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;AAErE,YAAA,IAAI;AACA,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;gBACvC,MAAM,OAAO,CACT,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,WAAW,EAC3C,IAAI,CAAC,kBAAkB,CAAC,SAAS,EACjC,IAAI,CAAC,MAAM,CACd,CAAC;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aACrC;YAAC,OAAO,CAAC,EAAE;gBACR,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE,CAAC,CAAC,CAAC;gBACvD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aAC9B;AAED,YAAA,IAAI;AACA,gBAAA,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;aACzE;YAAC,OAAO,CAAC,EAAE;gBACR,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;gBAC3E,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aAC9B;AACL,SAAC,CAAC;KACL;IAEO,gCAAgC,GAAA;QACpC,IAAI,CAAC,IAAI,CAAC,mBAAmB;YAAE,OAAO;AAEtC,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;;AAEtB,YAAA,MAAM,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC;YAC/F,MAAM,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;YAC9D,MAAM,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;AACnE,SAAC,CAAC;KACL;AAEO,IAAA,MAAM,kBAAkB,GAAA;AAC5B,QAAA,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC;;AAGhF,QAAA,MAAM,UAAU,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,iBAAiB,CAAC,CAAC;AAEtF,QAAA,MAAM,WAAW,GAAG,IAAI,EAAE,OAAO,EAAE,UAAU,GAAG,qBAAqB,GAAG,oBAAoB,CAAC;AAC7F,QAAA,MAAM,gBAAgB,GAAG,MAAM,IAAI,WAAW,CAAC;YAC3C,MAAM,EAAE,UAAU,CAAC,OAAO;AAC1B,YAAA,SAAS,EAAE,UAAU,CAAC,eAAe,CAAC;gBAClC,MAAM,EAAE,OAAO,CAAC,MAAM;AACtB,gBAAA,MAAM,EAAEA,MAAY;AACpB,gBAAA,cAAc,EAAE,CAAG,EAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAE,CAAA;aAC9C,CAAC;AACF,YAAA,UAAU,EAAE,EAAE;AACd,YAAA,kBAAkB,EAAE,UAAU,CAAC,gBAAgB,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;YACxE,WAAW,EAAE,UAAU,CAAC,kBAAkB;YAC1C,KAAK,EAAE,UAAU,CAAC,KAAK;AACvB,YAAA,MAAM,EAAEA,MAAY;SACvB,CAAC,CAAC,KAAK,EAAE,CAAC;;QAGX,MAAM,gBAAgB,GAAG,SAAS,CAAC;;;AAInC,QAAA,IAAI,QAAQ,CAAC;AACb,QAAA,MAAM,mBAAmB,GAAI,WAAmB,CAAC,QAAQ,CAAC;QAC1D,IAAI,mBAAmB,EAAE;AACrB,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4EAA4E,CAAC,CAAC;YAC/F,QAAQ,GAAG,mBAAmB,CAAC;SAClC;aAAM;AACH,YAAA,IAAI;AACA,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;AACxF,gBAAA,QAAQ,GAAG,MAAM,UAAU,CAAC,aAAa,CAAC;oBACtC,GAAG,IAAI,CAAC,QAAQ;oBAChB,eAAe,EAAE,OAAO,CAAC,WAAW;AACvC,iBAAA,CAAC,CAAC;aACN;YAAC,OAAO,KAAK,EAAE;gBACZ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,+CAA+C,EAAE,KAAK,CAAC,CAAC;gBAC1E,QAAQ,GAAG,EAAE,CAAC;aACjB;SACJ;;QAGD,MAAM,kBAAkB,GAAG,OAAO,GAAQ,EAAE,gBAAqB,EAAE,SAAe,KAAI;AAClF,YAAA,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,CAC7B,UAAU,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,aAAa,KAAK,aAAa,CAAC,GAAG,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAC,CACvG,CAAC;YACF,OAAO,KAAK,CAAC,EAAE,EAAE,GAAG,OAAO,EAAE,QAAQ,CAAC,CAAC;AAC3C,SAAC,CAAC;;AAGF,QAAA,MAAM,aAAa,GAAmB;AAClC,YAAA,gBAAgB,EAAE,gBAAgB;AAClC,YAAA,cAAc,EAAE,kBAAkB;AAClC,YAAA,UAAU,EAAE,UAAU,CAAC,gBAAgB,EAAE;AACzC,YAAA,kBAAkB,EAAE,UAAU,CAAC,wBAAwB,EAAE;AACzD,YAAA,aAAa,EAAE,OAAO,GAAG,EAAE,GAAG,KAAK,UAAU,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,CAAC;AACrE,YAAA,MAAM,EAAEA,MAAY;AACpB,YAAA,MAAM,EAAE,gBAAgB;SAC3B,CAAC;AAEF,QAAA,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;AACnC,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;KAChC;AAEO,IAAA,MAAM,eAAe,GAAA;AACzB,QAAA,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC;;AAG5C,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;;QAGtC,IAAI,CAAC,GAAG,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;;AAG7G,QAAA,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;;AAGvF,QAAA,qBAAqB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AAEjG,QAAA,IAAI,CAAC,UAAU,CAAC,cAAc,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACtE,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAK;AAC7B,YAAA,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;AAChC,SAAC,CAAC,CAAC;;QAGH,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;AAC7D,QAAA,MAAM,qBAAqB,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAExD,IAAI,qBAAqB,EAAE;AACvB,YAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,wBAAwB,CAClD,IAAI,CAAC,aAAa,EAClB,OAAO,CAAC,WAAW,EACnB,eAAe,CAClB,CAAC;AACF,YAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAChF;;QAGD,MAAM,aAAa,GAAG,IAAI,aAAa,CACnC,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,UAAU,EACf,OAAO,CAAC,WAAW,EACnB,IAAI,CAAC,aAAa,EAClB,CAAC,qBAAqB,EACtB,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAC7D,IAAI,CAAC,UAAU,CAAC,iCAAiC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EACvE,IAAI,CAAC,UAAU,CAAC,cAAc,CACjC,CAAC;AAEF,QAAA,MAAM,aAAa,CAAC,UAAU,EAAE,CAAC;AAEjC,QAAA,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,KAAI;AACxC,YAAA,GAAG,CAAC,MAAM,CAAC,kCAAkC,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;AACrE,YAAA,GAAG,CAAC,MAAM,CAAC,8BAA8B,EAAE,qBAAqB,CAAC,CAAC;AAClE,YAAA,GAAG,CAAC,MAAM,CAAC,6BAA6B,EAAE,GAAG,CAAC,CAAC;AAC/C,YAAA,GAAG,CAAC,MAAM,CACN,8BAA8B,EAC9B,6EAA6E,CAChF,CAAC;AACF,YAAA,IAAI,EAAE,CAAC;AACX,SAAC,CAAC,CAAC;KACN;AAEM,IAAA,MAAM,KAAK,GAAA;QACd,IAAI,MAAM,CAAC,QAAQ,KAAK,aAAa,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC/D,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;SACxG;aAAM;YACH,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;SAChD;KACJ;AAEM,IAAA,MAAM,OAAO,GAAA;AAChB,QAAA,IAAI,IAAI,CAAC,kBAAkB,EAAE;AACzB,YAAA,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;SACnC;AACD,QAAA,IAAI,IAAI,CAAC,UAAU,EAAE;AACjB,YAAA,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;SACjC;AACD,QAAA,IAAI,IAAI,CAAC,qBAAqB,EAAE;AAC5B,YAAA,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;SAC9C;AACD,QAAA,IAAI,IAAI,CAAC,kBAAkB,EAAE,MAAM,EAAE;YACjC,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;SAC/C;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.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
|
}
|