@nmxjs/app 1.1.1 → 1.1.3
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/dist/ensureDatabase.d.ts +7 -0
- package/dist/ensureDatabase.js +25 -0
- package/dist/ensureDatabase.js.map +1 -0
- package/dist/getGraphQlModule.js +6 -17
- package/dist/getGraphQlModule.js.map +1 -1
- package/dist/getTypeOrmModule.js +8 -1
- package/dist/getTypeOrmModule.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/interfaces/IGetGraphQlModuleOptions.d.ts +2 -1
- package/dist/interfaces/IGetGraphQlModuleUseFactoryResult.d.ts +1 -0
- package/package.json +3 -1
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ensureDatabase = void 0;
|
|
4
|
+
const pg_1 = require("pg");
|
|
5
|
+
const ensureDatabase = async (db) => {
|
|
6
|
+
const client = new pg_1.Client({
|
|
7
|
+
host: db.host,
|
|
8
|
+
port: db.port,
|
|
9
|
+
user: db.username,
|
|
10
|
+
password: db.password,
|
|
11
|
+
database: 'postgres',
|
|
12
|
+
});
|
|
13
|
+
try {
|
|
14
|
+
await client.connect();
|
|
15
|
+
const res = await client.query('SELECT 1 FROM pg_database WHERE datname = $1', [db.database]);
|
|
16
|
+
if (res.rowCount === 0) {
|
|
17
|
+
await client.query(`CREATE DATABASE "${db.database}"`);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
finally {
|
|
21
|
+
await client.end();
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
exports.ensureDatabase = ensureDatabase;
|
|
25
|
+
//# sourceMappingURL=ensureDatabase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensureDatabase.js","sourceRoot":"","sources":["../src/ensureDatabase.ts"],"names":[],"mappings":";;;AAAA,2BAA4B;AAErB,MAAM,cAAc,GAAG,KAAK,EAAE,EAA2F,EAAE,EAAE;IAClI,MAAM,MAAM,GAAG,IAAI,WAAM,CAAC;QACxB,IAAI,EAAE,EAAE,CAAC,IAAI;QACb,IAAI,EAAE,EAAE,CAAC,IAAI;QACb,IAAI,EAAE,EAAE,CAAC,QAAQ;QACjB,QAAQ,EAAE,EAAE,CAAC,QAAQ;QACrB,QAAQ,EAAE,UAAU;KACrB,CAAC,CAAC;IAEH,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;QACvB,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,8CAA8C,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC9F,IAAI,GAAG,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;YACvB,MAAM,MAAM,CAAC,KAAK,CAAC,oBAAoB,EAAE,CAAC,QAAQ,GAAG,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;YAAS,CAAC;QACT,MAAM,MAAM,CAAC,GAAG,EAAE,CAAC;IACrB,CAAC;AACH,CAAC,CAAC;AAlBW,QAAA,cAAc,kBAkBzB"}
|
package/dist/getGraphQlModule.js
CHANGED
|
@@ -13,18 +13,10 @@ exports.checkIsGraphQlModuleExits = checkIsGraphQlModuleExits;
|
|
|
13
13
|
const getGraphQlModule = (options) => {
|
|
14
14
|
var _a, _b;
|
|
15
15
|
return GraphQLModule.forRootAsync(Object.assign(Object.assign(Object.assign({}, (((_a = options === null || options === void 0 ? void 0 : options.inject) === null || _a === void 0 ? void 0 : _a.length) ? { inject: options.inject } : {})), (((_b = options === null || options === void 0 ? void 0 : options.imports) === null || _b === void 0 ? void 0 : _b.length) ? { imports: options.imports } : {})), { driver: ApolloDriver, useFactory: async (...params) => {
|
|
16
|
-
|
|
16
|
+
var _a;
|
|
17
|
+
const { resolvers = {}, onSubscriptionConnect, onSubscriptionDisconnect, config = {}, } = (options === null || options === void 0 ? void 0 : options.useFactory) ? await options.useFactory(...params) : {};
|
|
17
18
|
isGraphQlModuleExits = true;
|
|
18
|
-
return {
|
|
19
|
-
uploads: false,
|
|
20
|
-
autoSchemaFile: true,
|
|
21
|
-
transformSchema: utils_2.pruneSchema,
|
|
22
|
-
installSubscriptionHandlers: true,
|
|
23
|
-
graphiql: (0, utils_1.getEnvironment)() !== types_1.EnvironmentEnum.PRODUCTION,
|
|
24
|
-
fieldResolverEnhancers: ['filters', 'guards', 'interceptors'],
|
|
25
|
-
resolvers,
|
|
26
|
-
status400ForVariableCoercionErrors: true,
|
|
27
|
-
formatError: (error) => {
|
|
19
|
+
return Object.assign(Object.assign({ uploads: false, autoTransformHttpErrors: false, autoSchemaFile: true, transformSchema: utils_2.pruneSchema, installSubscriptionHandlers: true, graphiql: (0, utils_1.getEnvironment)() !== types_1.EnvironmentEnum.PRODUCTION, fieldResolverEnhancers: ['filters', 'guards', 'interceptors'], resolvers, status400ForVariableCoercionErrors: true, formatError: (error) => {
|
|
28
20
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
29
21
|
return (Object.assign(Object.assign(Object.assign(Object.assign({}, (((_b = (_a = error.extensions.exception) === null || _a === void 0 ? void 0 : _a.error) === null || _b === void 0 ? void 0 : _b.code)
|
|
30
22
|
? { code: error.extensions.exception.error.code }
|
|
@@ -37,16 +29,13 @@ const getGraphQlModule = (options) => {
|
|
|
37
29
|
error.toString() }), (error.message.includes(unexpectedErrorMessage)
|
|
38
30
|
? { message: eval(`eval(${error.message.substring(unexpectedErrorMessage.length)})`).message }
|
|
39
31
|
: {})));
|
|
40
|
-
},
|
|
41
|
-
subscriptions: {
|
|
32
|
+
}, subscriptions: {
|
|
42
33
|
'subscriptions-transport-ws': Object.assign({ onConnect: (connectionParams, client) => (Object.assign({ client,
|
|
43
34
|
connectionParams }, (onSubscriptionConnect ? onSubscriptionConnect(connectionParams, client) : {}))) }, (onSubscriptionDisconnect ? { onDisconnect: onSubscriptionDisconnect } : {})),
|
|
44
|
-
},
|
|
45
|
-
context: ctx => ({
|
|
35
|
+
}, context: ctx => ({
|
|
46
36
|
req: ctx.req,
|
|
47
37
|
res: ctx.res,
|
|
48
|
-
}),
|
|
49
|
-
};
|
|
38
|
+
}) }, ((_a = options === null || options === void 0 ? void 0 : options.config) !== null && _a !== void 0 ? _a : {})), (config !== null && config !== void 0 ? config : {}));
|
|
50
39
|
} }));
|
|
51
40
|
};
|
|
52
41
|
exports.getGraphQlModule = getGraphQlModule;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getGraphQlModule.js","sourceRoot":"","sources":["../src/getGraphQlModule.ts"],"names":[],"mappings":";;;AACA,wCAA8C;AAC9C,wCAA+C;AAC/C,gDAAmD;AAGnD,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;AACnD,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;AAErD,MAAM,sBAAsB,GAAG,0BAA0B,CAAC;AAE1D,IAAI,oBAAoB,GAAG,KAAK,CAAC;AAE1B,MAAM,yBAAyB,GAAG,GAAG,EAAE,CAAC,oBAAoB,CAAC;AAAvD,QAAA,yBAAyB,6BAA8B;AAE7D,MAAM,gBAAgB,GAAG,CAAC,OAAkC,EAAiB,EAAE;;IACpF,OAAA,aAAa,CAAC,YAAY,+CACrB,CAAC,CAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,0CAAE,MAAM,EAAC,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAC3D,CAAC,CAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,0CAAE,MAAM,EAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,KACjE,MAAM,EAAE,YAAY,EACpB,UAAU,EAAE,KAAK,EAAE,GAAG,MAAM,EAAE,EAAE
|
|
1
|
+
{"version":3,"file":"getGraphQlModule.js","sourceRoot":"","sources":["../src/getGraphQlModule.ts"],"names":[],"mappings":"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"}
|
package/dist/getTypeOrmModule.js
CHANGED
|
@@ -3,8 +3,15 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.getTypeOrmModule = void 0;
|
|
4
4
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
5
5
|
const config_1 = require("@nmxjs/config");
|
|
6
|
+
const ensureDatabase_1 = require("./ensureDatabase");
|
|
6
7
|
const getTypeOrmModule = (options) => typeorm_1.TypeOrmModule.forRootAsync({
|
|
7
|
-
useFactory: (config) =>
|
|
8
|
+
useFactory: async (config) => {
|
|
9
|
+
var _a;
|
|
10
|
+
if (((_a = config.db) === null || _a === void 0 ? void 0 : _a.type) === 'postgres') {
|
|
11
|
+
await (0, ensureDatabase_1.ensureDatabase)(config.db);
|
|
12
|
+
}
|
|
13
|
+
return Object.assign(Object.assign({ type: config.db.type, host: config.db.host, port: config.db.port, username: config.db.username, password: config.db.password, database: config.db.database, synchronize: true, autoLoadEntities: true }, (config.db.options ? config.db.options : {})), (options ? options : {}));
|
|
14
|
+
},
|
|
8
15
|
inject: [config_1.configKey],
|
|
9
16
|
});
|
|
10
17
|
exports.getTypeOrmModule = getTypeOrmModule;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTypeOrmModule.js","sourceRoot":"","sources":["../src/getTypeOrmModule.ts"],"names":[],"mappings":";;;AAAA,6CAAsE;AACtE,0CAAmD;
|
|
1
|
+
{"version":3,"file":"getTypeOrmModule.js","sourceRoot":"","sources":["../src/getTypeOrmModule.ts"],"names":[],"mappings":";;;AAAA,6CAAsE;AACtE,0CAAmD;AACnD,qDAAkD;AAE3C,MAAM,gBAAgB,GAAG,CAAC,OAAuC,EAAE,EAAE,CAC1E,uBAAa,CAAC,YAAY,CAAC;IACzB,UAAU,EAAE,KAAK,EAAE,MAAe,EAAE,EAAE;;QACpC,IAAI,CAAA,MAAA,MAAM,CAAC,EAAE,0CAAE,IAAI,MAAK,UAAU,EAAE,CAAC;YACnC,MAAM,IAAA,+BAAc,EAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAClC,CAAC;QAED,qCACE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,IAAI,EACpB,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,IAAI,EACpB,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,IAAI,EACpB,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,EAC5B,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,EAC5B,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,EAC5B,WAAW,EAAE,IAAI,EACjB,gBAAgB,EAAE,IAAI,IACnB,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,GAC5C,CAAC,OAAO,CAAC,CAAC,CAAM,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAChC;IACJ,CAAC;IACD,MAAM,EAAE,CAAC,kBAAS,CAAC;CACpB,CAAC,CAAC;AArBQ,QAAA,gBAAgB,oBAqBxB"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -24,4 +24,5 @@ __exportStar(require("./CrudService"), exports);
|
|
|
24
24
|
__exportStar(require("./ExtraRepository"), exports);
|
|
25
25
|
__exportStar(require("./GqlExceptionFilter"), exports);
|
|
26
26
|
__exportStar(require("./createTestNestHttpApp"), exports);
|
|
27
|
+
__exportStar(require("./ensureDatabase"), exports);
|
|
27
28
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,kDAAgC;AAChC,kDAAgC;AAChC,qDAAmC;AACnC,qDAAmC;AACnC,sDAAoC;AACpC,gDAA8B;AAC9B,oDAAkC;AAClC,uDAAqC;AACrC,0DAAwC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,kDAAgC;AAChC,kDAAgC;AAChC,qDAAmC;AACnC,qDAAmC;AACnC,sDAAoC;AACpC,gDAA8B;AAC9B,oDAAkC;AAClC,uDAAqC;AACrC,0DAAwC;AACxC,mDAAiC"}
|
|
@@ -2,5 +2,6 @@ import { ModuleMetadata } from '@nestjs/common';
|
|
|
2
2
|
import { IGetGraphQlModuleUseFactoryResult } from './IGetGraphQlModuleUseFactoryResult';
|
|
3
3
|
export interface IGetGraphQlModuleOptions extends Pick<ModuleMetadata, 'imports'> {
|
|
4
4
|
inject?: Array<string | symbol>;
|
|
5
|
-
|
|
5
|
+
config?: Record<string, any>;
|
|
6
|
+
useFactory?: (...params: any[]) => IGetGraphQlModuleUseFactoryResult | Promise<IGetGraphQlModuleUseFactoryResult>;
|
|
6
7
|
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ICallback } from '@nmxjs/types';
|
|
2
2
|
export interface IGetGraphQlModuleUseFactoryResult {
|
|
3
3
|
resolvers?: Record<string, any>;
|
|
4
|
+
config?: Record<string, any>;
|
|
4
5
|
onSubscriptionConnect?: ICallback<Record<string, any>>;
|
|
5
6
|
onSubscriptionDisconnect?: ICallback<Record<string, any>>;
|
|
6
7
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nmxjs/app",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.3",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -24,6 +24,7 @@
|
|
|
24
24
|
"devDependencies": {
|
|
25
25
|
"@types/body-parser": "^1.19.6",
|
|
26
26
|
"@types/node": "^22.19.15",
|
|
27
|
+
"@types/pg": "^8.15.2",
|
|
27
28
|
"typescript": "^5.9.3"
|
|
28
29
|
},
|
|
29
30
|
"dependencies": {
|
|
@@ -36,6 +37,7 @@
|
|
|
36
37
|
"graphql-upload-ts": "^2.1.3",
|
|
37
38
|
"graphql-ws": "^6.0.7",
|
|
38
39
|
"helmet": "^8.1.0",
|
|
40
|
+
"pg": "^8.16.3",
|
|
39
41
|
"typeorm": "^0.3.28"
|
|
40
42
|
},
|
|
41
43
|
"peerDependencies": {
|