@common-stack/server-stack 8.0.1-alpha.2 → 8.2.1-alpha.0
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 -143
- package/lib/MainStackServer.cjs.map +1 -1
- package/lib/MainStackServer.d.ts +12 -6
- package/lib/MainStackServer.mjs +126 -143
- 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 +20 -0
- package/lib/interfaces/index.d.ts +1 -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/index.d.ts +1 -0
- package/lib/plugins/invalidateCachePlugin.cjs +33 -10
- package/lib/plugins/invalidateCachePlugin.cjs.map +1 -1
- package/lib/plugins/invalidateCachePlugin.mjs +33 -10
- package/lib/plugins/invalidateCachePlugin.mjs.map +1 -1
- package/lib/plugins/responseCachePlugin.cjs +63 -0
- package/lib/plugins/responseCachePlugin.cjs.map +1 -0
- package/lib/plugins/responseCachePlugin.d.ts +12 -0
- package/lib/plugins/responseCachePlugin.mjs +63 -0
- package/lib/plugins/responseCachePlugin.mjs.map +1 -0
- 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 +10 -36
- package/lib/servers/GraphqlServer.cjs.map +1 -1
- package/lib/servers/GraphqlServer.d.ts +8 -6
- package/lib/servers/GraphqlServer.mjs +10 -36
- 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 +3 -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/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,17 +10,6 @@ function startListening(port) {
|
|
|
9
10
|
server.listen(port, resolve);
|
|
10
11
|
});
|
|
11
12
|
}
|
|
12
|
-
const infraModule = ({ broker, pubsub, mongoClient, logger }) => 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('MoleculerBroker').toConstantValue(broker);
|
|
21
|
-
bind('MongoDBConnection').toConstantValue(mongoClient);
|
|
22
|
-
});
|
|
23
13
|
/**
|
|
24
14
|
* Controls the lifecycle of the Application Server
|
|
25
15
|
*
|
|
@@ -30,111 +20,86 @@ class MainStackServer {
|
|
|
30
20
|
httpServer;
|
|
31
21
|
app;
|
|
32
22
|
logger;
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
23
|
+
infrastructureFactory;
|
|
24
|
+
mainServiceContext;
|
|
25
|
+
microserviceContext;
|
|
36
26
|
multiPathWebsocket;
|
|
37
|
-
serviceContainer;
|
|
38
|
-
microserviceContainer;
|
|
39
27
|
serverFeature;
|
|
40
28
|
settings;
|
|
41
|
-
|
|
29
|
+
options;
|
|
30
|
+
serviceBroker;
|
|
31
|
+
allModules;
|
|
32
|
+
constructor(feature, settings, options) {
|
|
42
33
|
this.serverFeature = feature;
|
|
43
34
|
this.settings = settings;
|
|
35
|
+
this.options = options;
|
|
44
36
|
this.logger = logger.child({ className: 'StackServer' });
|
|
37
|
+
this.infrastructureFactory = new InfrastructureFactory(this.logger);
|
|
45
38
|
}
|
|
46
39
|
async initialize() {
|
|
47
40
|
this.logger.info('StackServer initializing');
|
|
48
|
-
//
|
|
49
|
-
this.
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
//
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
InterNamespaceMiddleware([
|
|
57
|
-
{
|
|
58
|
-
namespace: 'api-admin',
|
|
59
|
-
transporter: brokerConfig.transporter,
|
|
60
|
-
metrics: { enabled: false },
|
|
61
|
-
},
|
|
62
|
-
]),
|
|
63
|
-
],
|
|
64
|
-
started: async () => {
|
|
65
|
-
await this.serverFeature.preStart(this.serviceContainer);
|
|
66
|
-
if (config.NODE_ENV === 'development') ;
|
|
67
|
-
try {
|
|
68
|
-
this.logger.info('Starting Migration');
|
|
69
|
-
await migrate(mongoClient, this.serviceContainer, this.logger);
|
|
70
|
-
this.logger.info('End Migration');
|
|
71
|
-
}
|
|
72
|
-
catch (e) {
|
|
73
|
-
this.logger.error('Error while running migrations', e);
|
|
74
|
-
this.logger.error(e.stack);
|
|
75
|
-
}
|
|
76
|
-
try {
|
|
77
|
-
await this.serverFeature.postStart(this.serviceContainer);
|
|
78
|
-
}
|
|
79
|
-
catch (e) {
|
|
80
|
-
this.logger.error('Error while running Post Start due to [%s]', e.message);
|
|
81
|
-
this.logger.error(e.stack);
|
|
82
|
-
}
|
|
83
|
-
// start DB migration
|
|
84
|
-
if (config.NODE_ENV === 'development') ;
|
|
85
|
-
},
|
|
86
|
-
// created,
|
|
87
|
-
async created() {
|
|
88
|
-
return Promise.resolve();
|
|
89
|
-
},
|
|
90
|
-
});
|
|
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
|
|
91
49
|
if (config.NODE_ENV === 'development') {
|
|
92
|
-
this.
|
|
93
|
-
|
|
94
|
-
metrics: { enabled: false },
|
|
95
|
-
nodeID: 'node-broker-2',
|
|
96
|
-
started: async () => {
|
|
97
|
-
await this.serverFeature.microservicePreStart(this.microserviceContainer);
|
|
98
|
-
await this.serverFeature.microservicePostStart(this.microserviceContainer);
|
|
99
|
-
},
|
|
100
|
-
// created,
|
|
101
|
-
created: async () => Promise.resolve(),
|
|
102
|
-
});
|
|
50
|
+
this.microserviceContext = await this.infrastructureFactory.createBrokerAndContainer(InfrastructureFactory.createDevelopmentMicroserviceConfig(), this.serverFeature, this.settings, this.mainServiceContext.allModules);
|
|
51
|
+
this.setupMicroserviceBrokerLifecycle();
|
|
103
52
|
}
|
|
104
|
-
|
|
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
|
-
|
|
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({
|
|
135
100
|
schema: allModules.schemas,
|
|
136
101
|
resolvers: allModules.createResolvers({
|
|
137
|
-
pubsub,
|
|
102
|
+
pubsub: context.pubsub,
|
|
138
103
|
logger: logger,
|
|
139
104
|
subscriptionID: `${this.settings.subTopic}`,
|
|
140
105
|
}),
|
|
@@ -144,53 +109,71 @@ class MainStackServer {
|
|
|
144
109
|
rules: allModules.rules,
|
|
145
110
|
logger: logger,
|
|
146
111
|
}).build();
|
|
147
|
-
//
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
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
|
|
153
141
|
const serviceBroker = {
|
|
154
|
-
serviceContainer:
|
|
155
|
-
serviceContext:
|
|
142
|
+
serviceContainer: serviceContainer,
|
|
143
|
+
serviceContext: serviceContextFunc,
|
|
156
144
|
dataSource: allModules.createDataSource(),
|
|
157
145
|
defaultPreferences: allModules.createDefaultPreferences(),
|
|
158
146
|
createContext: async (req, res) => allModules.createContext(req, res),
|
|
159
147
|
logger: logger,
|
|
160
148
|
schema: executableSchema,
|
|
161
149
|
};
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
this.microserviceContainer = await allModules.createHemeraContainers({
|
|
169
|
-
...this.settings,
|
|
170
|
-
mongoConnection: mongoClient,
|
|
171
|
-
});
|
|
172
|
-
allModules.loadClientMoleculerService({
|
|
173
|
-
broker: this.microserviceBroker,
|
|
174
|
-
container: this.microserviceContainer,
|
|
175
|
-
settings: this.settings,
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
// 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
|
|
179
156
|
this.httpServer = http.createServer();
|
|
180
|
-
|
|
181
|
-
|
|
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);
|
|
182
163
|
this.httpServer.startListening = startListening.bind(this.httpServer);
|
|
183
164
|
this.httpServer.on('request', this.app);
|
|
184
165
|
this.httpServer.on('close', () => {
|
|
185
166
|
this.httpServer = undefined;
|
|
186
167
|
});
|
|
187
|
-
|
|
168
|
+
// Setup WebSocket if configured
|
|
169
|
+
const customWebsocket = this.allModules.getWebsocketConfig();
|
|
188
170
|
const customWebsocketEnable = !isEmpty(customWebsocket);
|
|
189
171
|
if (customWebsocketEnable) {
|
|
190
|
-
this.multiPathWebsocket = new WebsocketMultiPathServer(serviceBroker, redisClient, customWebsocket);
|
|
172
|
+
this.multiPathWebsocket = new WebsocketMultiPathServer(this.serviceBroker, context.redisClient, customWebsocket);
|
|
191
173
|
this.httpServer = this.multiPathWebsocket.httpServerUpgrade(this.httpServer);
|
|
192
174
|
}
|
|
193
|
-
|
|
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);
|
|
194
177
|
await graphqlServer.initialize();
|
|
195
178
|
this.app.use('/graphql', (req, res, next) => {
|
|
196
179
|
res.append('Access-Control-Allow-Credentials', JSON.stringify(true));
|
|
@@ -201,11 +184,11 @@ class MainStackServer {
|
|
|
201
184
|
});
|
|
202
185
|
}
|
|
203
186
|
async start() {
|
|
204
|
-
if (config.NODE_ENV === 'development') {
|
|
205
|
-
await Promise.all([this.
|
|
187
|
+
if (config.NODE_ENV === 'development' && this.microserviceContext) {
|
|
188
|
+
await Promise.all([this.mainServiceContext.broker.start(), this.microserviceContext.broker.start()]);
|
|
206
189
|
}
|
|
207
190
|
else {
|
|
208
|
-
await this.
|
|
191
|
+
await this.mainServiceContext.broker.start();
|
|
209
192
|
}
|
|
210
193
|
}
|
|
211
194
|
async cleanup() {
|
|
@@ -215,14 +198,14 @@ class MainStackServer {
|
|
|
215
198
|
if (this.httpServer) {
|
|
216
199
|
await this.httpServer.close();
|
|
217
200
|
}
|
|
218
|
-
if (this.
|
|
219
|
-
await this.
|
|
201
|
+
if (this.infrastructureFactory) {
|
|
202
|
+
await this.infrastructureFactory.cleanup();
|
|
220
203
|
}
|
|
221
|
-
if (this.
|
|
222
|
-
await this.
|
|
204
|
+
if (this.mainServiceContext?.broker) {
|
|
205
|
+
await this.mainServiceContext.broker.stop();
|
|
223
206
|
}
|
|
224
|
-
if (this.
|
|
225
|
-
await this.
|
|
207
|
+
if (this.microserviceContext?.broker) {
|
|
208
|
+
await this.microserviceContext.broker.stop();
|
|
226
209
|
}
|
|
227
210
|
}
|
|
228
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":"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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
|
}
|