@subsquid/openreader 5.2.0 → 5.3.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/lib/dialect/common.js +3 -3
- package/lib/dialect/common.js.map +1 -1
- package/lib/dialect/index.js +1 -2
- package/lib/dialect/index.js.map +1 -1
- package/lib/dialect/opencrud/orderBy.js +2 -3
- package/lib/dialect/opencrud/orderBy.js.map +1 -1
- package/lib/dialect/opencrud/schema.js +1 -1
- package/lib/dialect/opencrud/schema.js.map +1 -1
- package/lib/dialect/opencrud/tree.js +4 -5
- package/lib/dialect/opencrud/tree.js.map +1 -1
- package/lib/dialect/opencrud/where.js +2 -3
- package/lib/dialect/opencrud/where.js.map +1 -1
- package/lib/dialect/thegraph/locale.js +1 -2
- package/lib/dialect/thegraph/locale.js.map +1 -1
- package/lib/dialect/thegraph/orderBy.js +3 -3
- package/lib/dialect/thegraph/orderBy.js.map +1 -1
- package/lib/dialect/thegraph/tree.js +4 -5
- package/lib/dialect/thegraph/tree.js.map +1 -1
- package/lib/dialect/thegraph/where.js +2 -3
- package/lib/dialect/thegraph/where.js.map +1 -1
- package/lib/ir/connection.js +2 -3
- package/lib/ir/connection.js.map +1 -1
- package/lib/ir/fields.js +2 -3
- package/lib/ir/fields.js.map +1 -1
- package/lib/limit.size.js +3 -4
- package/lib/limit.size.js.map +1 -1
- package/lib/main.js +3 -1
- package/lib/main.js.map +1 -1
- package/lib/model.schema.js +3 -3
- package/lib/model.schema.js.map +1 -1
- package/lib/model.tools.js +16 -17
- package/lib/model.tools.js.map +1 -1
- package/lib/server.d.ts +3 -1
- package/lib/server.d.ts.map +1 -1
- package/lib/server.js +13 -9
- package/lib/server.js.map +1 -1
- package/lib/sql/mapping.js +4 -5
- package/lib/sql/mapping.js.map +1 -1
- package/lib/sql/util.js +3 -3
- package/lib/sql/util.js.map +1 -1
- package/lib/test/setup.js +7 -7
- package/lib/test/setup.js.map +1 -1
- package/lib/tools.js +2 -3
- package/lib/tools.js.map +1 -1
- package/lib/util/error-handling.js +2 -2
- package/lib/util/error-handling.js.map +1 -1
- package/lib/util/execute.js +3 -4
- package/lib/util/execute.js.map +1 -1
- package/lib/util/limit.js +1 -1
- package/lib/util/limit.js.map +1 -1
- package/lib/util/resolve-tree.js +5 -6
- package/lib/util/resolve-tree.js.map +1 -1
- package/lib/util/util.js +7 -8
- package/lib/util/util.js.map +1 -1
- package/package.json +7 -7
- package/src/dialect/opencrud/schema.ts +1 -1
- package/src/main.ts +4 -1
- package/src/server.ts +13 -5
- package/src/util/execute.ts +1 -1
- package/src/util/limit.ts +1 -1
- package/src/util/resolve-tree.ts +1 -1
package/lib/test/setup.js
CHANGED
|
@@ -1,6 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.db_config = void 0;
|
|
4
|
+
exports.isCockroach = isCockroach;
|
|
5
|
+
exports.withDatabase = withDatabase;
|
|
6
|
+
exports.databaseExecute = databaseExecute;
|
|
7
|
+
exports.databaseDelete = databaseDelete;
|
|
8
|
+
exports.useDatabase = useDatabase;
|
|
9
|
+
exports.useServer = useServer;
|
|
4
10
|
const util_internal_1 = require("@subsquid/util-internal");
|
|
5
11
|
const gql_test_client_1 = require("gql-test-client");
|
|
6
12
|
const graphql_1 = require("graphql");
|
|
@@ -10,7 +16,6 @@ const server_1 = require("../server");
|
|
|
10
16
|
function isCockroach() {
|
|
11
17
|
return process.env.DB_TYPE == 'cockroach';
|
|
12
18
|
}
|
|
13
|
-
exports.isCockroach = isCockroach;
|
|
14
19
|
exports.db_config = {
|
|
15
20
|
host: 'localhost',
|
|
16
21
|
port: parseInt((0, util_internal_1.assertNotNull)(isCockroach() ? process.env.DB_PORT_COCKROACH : process.env.DB_PORT_PG)),
|
|
@@ -28,7 +33,6 @@ async function withDatabase(block) {
|
|
|
28
33
|
await client.end();
|
|
29
34
|
}
|
|
30
35
|
}
|
|
31
|
-
exports.withDatabase = withDatabase;
|
|
32
36
|
function databaseExecute(sql) {
|
|
33
37
|
return withDatabase(async (client) => {
|
|
34
38
|
for (let i = 0; i < sql.length; i++) {
|
|
@@ -36,21 +40,18 @@ function databaseExecute(sql) {
|
|
|
36
40
|
}
|
|
37
41
|
});
|
|
38
42
|
}
|
|
39
|
-
exports.databaseExecute = databaseExecute;
|
|
40
43
|
function databaseDelete() {
|
|
41
44
|
return withDatabase(async (client) => {
|
|
42
45
|
await client.query(`DROP SCHEMA IF EXISTS root CASCADE`);
|
|
43
46
|
await client.query(`CREATE SCHEMA root`);
|
|
44
47
|
});
|
|
45
48
|
}
|
|
46
|
-
exports.databaseDelete = databaseDelete;
|
|
47
49
|
function useDatabase(sql) {
|
|
48
50
|
before(async () => {
|
|
49
51
|
await databaseDelete();
|
|
50
52
|
await databaseExecute(sql);
|
|
51
53
|
});
|
|
52
54
|
}
|
|
53
|
-
exports.useDatabase = useDatabase;
|
|
54
55
|
function useServer(schema, options) {
|
|
55
56
|
let client = new gql_test_client_1.Client('not defined');
|
|
56
57
|
let db = new pg_1.Pool(exports.db_config);
|
|
@@ -73,5 +74,4 @@ function useServer(schema, options) {
|
|
|
73
74
|
after(() => db.end());
|
|
74
75
|
return client;
|
|
75
76
|
}
|
|
76
|
-
exports.useServer = useServer;
|
|
77
77
|
//# sourceMappingURL=setup.js.map
|
package/lib/test/setup.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../src/test/setup.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../src/test/setup.ts"],"names":[],"mappings":"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"}
|
package/lib/tools.js
CHANGED
|
@@ -26,7 +26,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
26
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
27
|
};
|
|
28
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.
|
|
29
|
+
exports.loadModel = loadModel;
|
|
30
|
+
exports.resolveGraphqlSchema = resolveGraphqlSchema;
|
|
30
31
|
const merge_1 = require("@graphql-tools/merge");
|
|
31
32
|
const fs = __importStar(require("fs"));
|
|
32
33
|
const path = __importStar(require("path"));
|
|
@@ -55,7 +56,6 @@ function loadModel(schemaFile) {
|
|
|
55
56
|
let schema = (0, model_schema_1.buildSchema)(doc);
|
|
56
57
|
return (0, model_schema_1.buildModel)(schema);
|
|
57
58
|
}
|
|
58
|
-
exports.loadModel = loadModel;
|
|
59
59
|
function resolveGraphqlSchema(projectDir) {
|
|
60
60
|
let dir = projectDir || process_1.default.cwd();
|
|
61
61
|
let loc = path.resolve(dir, 'schema.graphql');
|
|
@@ -70,5 +70,4 @@ function resolveGraphqlSchema(projectDir) {
|
|
|
70
70
|
}
|
|
71
71
|
throw new Error(`Failed to locate schema.graphql at ${dir}`);
|
|
72
72
|
}
|
|
73
|
-
exports.resolveGraphqlSchema = resolveGraphqlSchema;
|
|
74
73
|
//# sourceMappingURL=tools.js.map
|
package/lib/tools.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../src/tools.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../src/tools.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,8BAwBC;AAGD,oDAWC;AA/CD,gDAAkD;AAClD,uCAAwB;AACxB,2CAA4B;AAC5B,qCAAqC;AACrC,sDAA6B;AAC7B,iDAAsD;AAItD,SAAgB,SAAS,CAAC,UAAkB;IACxC,IAAI,KAAK,GAAa,EAAE,CAAA;IACxB,IAAI,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;QACxC,EAAE,CAAC,WAAW,CAAC,UAAU,EAAE,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC7D,IAAI,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;gBAClF,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YAChD,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;SAAM,CAAC;QACJ,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAC1B,CAAC;IAED,IAAI,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;QACrB,IAAI,GAAG,GAAG,IAAI,gBAAM,CAChB,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,EAC3B,CAAC,CACJ,CAAA;QACD,OAAO,IAAA,eAAK,EAAC,GAAG,CAAC,CAAA;IACrB,CAAC,CAAC,CAAA;IAEF,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC;QAAE,OAAO,EAAE,CAAA;IAC/B,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAA,qBAAa,EAAC,IAAI,CAAC,CAAA;IAC1D,IAAI,MAAM,GAAG,IAAA,0BAAW,EAAC,GAAG,CAAC,CAAA;IAC7B,OAAO,IAAA,yBAAU,EAAC,MAAM,CAAC,CAAA;AAC7B,CAAC;AAGD,SAAgB,oBAAoB,CAAC,UAAmB;IACpD,IAAI,GAAG,GAAG,UAAU,IAAI,iBAAO,CAAC,GAAG,EAAE,CAAA;IACrC,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAA;IAC7C,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC;QAAE,OAAO,GAAG,CAAA;IAClC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;IACjC,IAAI,IAAI,GAAG,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAC,cAAc,EAAE,KAAK,EAAC,CAAC,CAAA;IACpD,IAAI,IAAI,EAAE,WAAW,EAAE,EAAE,CAAC;QACtB,IAAI,UAAU,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAA;QACrG,IAAI,UAAU;YAAE,OAAO,GAAG,CAAA;IAC9B,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,sCAAsC,GAAG,EAAE,CAAC,CAAA;AAChE,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.getDocumentCtx = void 0;
|
|
4
|
+
exports.logGraphQLErrors = logGraphQLErrors;
|
|
4
5
|
const logger_1 = require("@subsquid/logger");
|
|
5
6
|
const util_internal_1 = require("@subsquid/util-internal");
|
|
6
7
|
const graphql_1 = require("graphql");
|
|
@@ -31,7 +32,6 @@ function logGraphQLErrors(log, args, errors) {
|
|
|
31
32
|
...(0, exports.getDocumentCtx)(args)
|
|
32
33
|
}, 'graphql query ended with errors');
|
|
33
34
|
}
|
|
34
|
-
exports.logGraphQLErrors = logGraphQLErrors;
|
|
35
35
|
function getErrorLevel(err) {
|
|
36
36
|
if (err.__openreaderLogLevel)
|
|
37
37
|
return err.__openreaderLogLevel;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error-handling.js","sourceRoot":"","sources":["../../src/util/error-handling.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"error-handling.js","sourceRoot":"","sources":["../../src/util/error-handling.ts"],"names":[],"mappings":";;;AAqBA,4CAqBC;AA1CD,6CAAiD;AACjD,2DAAgD;AAChD,qCAA0D;AAU7C,QAAA,cAAc,GAAG,IAAA,wBAAQ,EAAC,CAAC,IAAmB,EAAe,EAAE;IACxE,OAAO;QACH,oBAAoB,EAAE,IAAI,CAAC,aAAa,IAAI,SAAS;QACrD,eAAe,EAAE,IAAA,eAAK,EAAC,IAAI,CAAC,QAAQ,CAAC;QACrC,gBAAgB,EAAE,IAAI,CAAC,cAAc;KACxC,CAAA;AACL,CAAC,CAAC,CAAA;AAGF,SAAgB,gBAAgB,CAC5B,GAAW,EACX,IAAmB,EACnB,MAA2C;IAE3C,IAAI,CAAC,MAAM,EAAE,MAAM;QAAE,OAAM;IAC3B,IAAI,KAAK,GAAG,CAAC,CAAA;IACb,IAAI,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;QACjC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,CAAA;QAC3C,OAAO;YACH,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC;YACzB,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,aAAa,EAAE,GAAG,CAAC,aAAa;SACnC,CAAA;IACL,CAAC,CAAC,CAAA;IACF,IAAI,GAAG,CAAC,KAAK,GAAG,KAAK;QAAE,OAAM;IAC7B,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE;QACb,aAAa;QACb,GAAG,IAAA,sBAAc,EAAC,IAAI,CAAC;KAC1B,EAAE,iCAAiC,CAAC,CAAA;AACzC,CAAC;AAGD,SAAS,aAAa,CAAC,GAAiB;IACpC,IAAK,GAAW,CAAC,oBAAoB;QAAE,OAAQ,GAAW,CAAC,oBAAoB,CAAA;IAC/E,IAAI,GAAG,CAAC,UAAU,EAAE,IAAI,KAAK,gBAAgB;QAAE,OAAO,iBAAQ,CAAC,IAAI,CAAA;IACnE,OAAO,iBAAQ,CAAC,KAAK,CAAA;AACzB,CAAC"}
|
package/lib/util/execute.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.openreaderExecute = openreaderExecute;
|
|
4
|
+
exports.openreaderSubscribe = openreaderSubscribe;
|
|
4
5
|
const logger_1 = require("@subsquid/logger");
|
|
5
6
|
const util_internal_1 = require("@subsquid/util-internal");
|
|
6
|
-
const apollo_server_core_1 = require("apollo-server-core");
|
|
7
|
+
const apollo_server_core_1 = require("@subsquid/apollo-server-core");
|
|
7
8
|
const graphql_1 = require("graphql");
|
|
8
9
|
const execute_1 = require("graphql/execution/execute");
|
|
9
10
|
const error_handling_1 = require("./error-handling");
|
|
@@ -23,7 +24,6 @@ async function openreaderExecute(args, options) {
|
|
|
23
24
|
logResult('graphql result', log, args, result);
|
|
24
25
|
return result;
|
|
25
26
|
}
|
|
26
|
-
exports.openreaderExecute = openreaderExecute;
|
|
27
27
|
async function openreaderSubscribe(args) {
|
|
28
28
|
let log = args.contextValue.openreader.log?.child('gql');
|
|
29
29
|
if (log?.isDebug()) {
|
|
@@ -47,7 +47,6 @@ async function openreaderSubscribe(args) {
|
|
|
47
47
|
}
|
|
48
48
|
return result;
|
|
49
49
|
}
|
|
50
|
-
exports.openreaderSubscribe = openreaderSubscribe;
|
|
51
50
|
async function* logSubscriptionResults(log, args, results) {
|
|
52
51
|
for await (let result of results) {
|
|
53
52
|
logResult('graphql subscription result', log, args, result);
|
package/lib/util/execute.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"execute.js","sourceRoot":"","sources":["../../src/util/execute.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"execute.js","sourceRoot":"","sources":["../../src/util/execute.ts"],"names":[],"mappings":"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"}
|
package/lib/util/limit.js
CHANGED
|
@@ -4,7 +4,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.ResponseSizeLimit = exports.Limit = void 0;
|
|
7
|
-
const apollo_server_core_1 = require("apollo-server-core");
|
|
7
|
+
const apollo_server_core_1 = require("@subsquid/apollo-server-core");
|
|
8
8
|
const assert_1 = __importDefault(require("assert"));
|
|
9
9
|
class Limit {
|
|
10
10
|
constructor(error, value) {
|
package/lib/util/limit.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"limit.js","sourceRoot":"","sources":["../../src/util/limit.ts"],"names":[],"mappings":";;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"limit.js","sourceRoot":"","sources":["../../src/util/limit.ts"],"names":[],"mappings":";;;;;;AAAA,qEAA2D;AAC3D,oDAA2B;AAG3B,MAAa,KAAK;IACd,YAAoB,KAAY,EAAU,KAAa;QAAnC,UAAK,GAAL,KAAK,CAAO;QAAU,UAAK,GAAL,KAAK,CAAQ;QACnD,IAAA,gBAAM,EAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAA;IAC1B,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;IAClC,CAAC;IAED,KAAK,CAAC,EAA4B;QAC9B,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC;YAAE,MAAM,IAAI,CAAC,KAAK,CAAA;QACpC,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACtC,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;YACX,MAAM,IAAI,CAAC,KAAK,CAAA;QACpB,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACrB,CAAC;IACL,CAAC;CACJ;AAlBD,sBAkBC;AAGD,MAAM,UAAU,GAAG,IAAI,mCAAc,CAAC,sCAAsC,CAAC,CAAA;AAC7E,UAAU,CAAC,KAAK,GAAG,SAAS,CAAA;AAG5B,MAAa,iBAAkB,SAAQ,KAAK;IACxC,YAAY,QAAgB;QACxB,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IAC/B,CAAC;CACJ;AAJD,8CAIC"}
|
package/lib/util/resolve-tree.js
CHANGED
|
@@ -3,8 +3,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
7
|
-
|
|
6
|
+
exports.simplifyResolveTree = simplifyResolveTree;
|
|
7
|
+
exports.getResolveTree = getResolveTree;
|
|
8
|
+
exports.getTreeRequest = getTreeRequest;
|
|
9
|
+
exports.hasTreeRequest = hasTreeRequest;
|
|
10
|
+
const apollo_server_core_1 = require("@subsquid/apollo-server-core");
|
|
8
11
|
const assert_1 = __importDefault(require("assert"));
|
|
9
12
|
const graphql_parse_resolve_info_1 = require("graphql-parse-resolve-info");
|
|
10
13
|
function simplifyResolveTree(schema, tree, typeName) {
|
|
@@ -12,7 +15,6 @@ function simplifyResolveTree(schema, tree, typeName) {
|
|
|
12
15
|
(0, assert_1.default)(type != null);
|
|
13
16
|
return (0, graphql_parse_resolve_info_1.simplifyParsedResolveInfoFragmentWithType)(tree, type);
|
|
14
17
|
}
|
|
15
|
-
exports.simplifyResolveTree = simplifyResolveTree;
|
|
16
18
|
function getResolveTree(info, typeName) {
|
|
17
19
|
let tree = (0, graphql_parse_resolve_info_1.parseResolveInfo)(info);
|
|
18
20
|
(0, assert_1.default)(isResolveTree(tree));
|
|
@@ -23,7 +25,6 @@ function getResolveTree(info, typeName) {
|
|
|
23
25
|
return tree;
|
|
24
26
|
}
|
|
25
27
|
}
|
|
26
|
-
exports.getResolveTree = getResolveTree;
|
|
27
28
|
function isResolveTree(resolveInfo) {
|
|
28
29
|
return resolveInfo != null && resolveInfo.fieldsByTypeName != null;
|
|
29
30
|
}
|
|
@@ -39,7 +40,6 @@ function getTreeRequest(treeFields, fieldName) {
|
|
|
39
40
|
}
|
|
40
41
|
return req;
|
|
41
42
|
}
|
|
42
|
-
exports.getTreeRequest = getTreeRequest;
|
|
43
43
|
function hasTreeRequest(treeFields, fieldName) {
|
|
44
44
|
for (let alias in treeFields) {
|
|
45
45
|
let e = treeFields[alias];
|
|
@@ -48,5 +48,4 @@ function hasTreeRequest(treeFields, fieldName) {
|
|
|
48
48
|
}
|
|
49
49
|
return false;
|
|
50
50
|
}
|
|
51
|
-
exports.hasTreeRequest = hasTreeRequest;
|
|
52
51
|
//# sourceMappingURL=resolve-tree.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resolve-tree.js","sourceRoot":"","sources":["../../src/util/resolve-tree.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"resolve-tree.js","sourceRoot":"","sources":["../../src/util/resolve-tree.ts"],"names":[],"mappings":";;;;;AAqBA,kDAIC;AAKD,wCAQC;AAQD,wCASC;AAGD,wCAMC;AAhED,qEAA2D;AAC3D,oDAA2B;AAE3B,2EAKmC;AAanC,SAAgB,mBAAmB,CAAC,MAAqB,EAAE,IAAiB,EAAE,QAAgB;IAC1F,IAAI,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IACnC,IAAA,gBAAM,EAAC,IAAI,IAAI,IAAI,CAAC,CAAA;IACpB,OAAO,IAAA,sEAAyC,EAAC,IAAI,EAAE,IAAI,CAAC,CAAA;AAChE,CAAC;AAKD,SAAgB,cAAc,CAAC,IAAwB,EAAE,QAAiB;IACtE,IAAI,IAAI,GAAG,IAAA,6CAAgB,EAAC,IAAI,CAAC,CAAA;IACjC,IAAA,gBAAM,EAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAA;IAC3B,IAAI,QAAQ,EAAE,CAAC;QACX,OAAO,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAA;IAC3D,CAAC;SAAM,CAAC;QACJ,OAAO,IAAI,CAAA;IACf,CAAC;AACL,CAAC;AAGD,SAAS,aAAa,CAAC,WAA8D;IACjF,OAAO,WAAW,IAAI,IAAI,IAAI,WAAW,CAAC,gBAAgB,IAAI,IAAI,CAAA;AACtE,CAAC;AAGD,SAAgB,cAAc,CAAC,UAA6B,EAAE,SAAiB;IAC3E,IAAI,GAA4B,CAAA;IAChC,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE,CAAC;QAC3B,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;QACzB,IAAI,CAAC,CAAC,IAAI,IAAI,SAAS;YAAE,SAAQ;QACjC,IAAI,GAAG,IAAI,IAAI;YAAE,MAAM,IAAI,mCAAc,CAAC,+BAA+B,SAAS,qBAAqB,CAAC,CAAA;QACxG,GAAG,GAAG,CAAC,CAAA;IACX,CAAC;IACD,OAAO,GAAG,CAAA;AACd,CAAC;AAGD,SAAgB,cAAc,CAAC,UAA6B,EAAE,SAAiB;IAC3E,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE,CAAC;QAC3B,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,CAAA;QACzB,IAAI,CAAC,CAAC,IAAI,IAAI,SAAS;YAAE,OAAO,IAAI,CAAA;IACxC,CAAC;IACD,OAAO,KAAK,CAAA;AAChB,CAAC"}
|
package/lib/util/util.js
CHANGED
|
@@ -3,37 +3,36 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
6
|
+
exports.toColumn = toColumn;
|
|
7
|
+
exports.toFkColumn = toFkColumn;
|
|
8
|
+
exports.toTable = toTable;
|
|
9
|
+
exports.ensureArray = ensureArray;
|
|
10
|
+
exports.toSafeInteger = toSafeInteger;
|
|
11
|
+
exports.invalidFormat = invalidFormat;
|
|
12
|
+
exports.identity = identity;
|
|
7
13
|
const util_naming_1 = require("@subsquid/util-naming");
|
|
8
14
|
const assert_1 = __importDefault(require("assert"));
|
|
9
15
|
function toColumn(gqlFieldName) {
|
|
10
16
|
return (0, util_naming_1.toSnakeCase)(gqlFieldName);
|
|
11
17
|
}
|
|
12
|
-
exports.toColumn = toColumn;
|
|
13
18
|
function toFkColumn(gqlFieldName) {
|
|
14
19
|
return (0, util_naming_1.toSnakeCase)(gqlFieldName) + '_id';
|
|
15
20
|
}
|
|
16
|
-
exports.toFkColumn = toFkColumn;
|
|
17
21
|
function toTable(entityName) {
|
|
18
22
|
return (0, util_naming_1.toSnakeCase)(entityName);
|
|
19
23
|
}
|
|
20
|
-
exports.toTable = toTable;
|
|
21
24
|
function ensureArray(item) {
|
|
22
25
|
return Array.isArray(item) ? item : [item];
|
|
23
26
|
}
|
|
24
|
-
exports.ensureArray = ensureArray;
|
|
25
27
|
function toSafeInteger(s) {
|
|
26
28
|
let i = parseInt(s, 10);
|
|
27
29
|
(0, assert_1.default)(Number.isSafeInteger(i));
|
|
28
30
|
return i;
|
|
29
31
|
}
|
|
30
|
-
exports.toSafeInteger = toSafeInteger;
|
|
31
32
|
function invalidFormat(type, value) {
|
|
32
33
|
return new TypeError(`Not a ${type}: ${value}`);
|
|
33
34
|
}
|
|
34
|
-
exports.invalidFormat = invalidFormat;
|
|
35
35
|
function identity(x) {
|
|
36
36
|
return x;
|
|
37
37
|
}
|
|
38
|
-
exports.identity = identity;
|
|
39
38
|
//# sourceMappingURL=util.js.map
|
package/lib/util/util.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util/util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util/util.ts"],"names":[],"mappings":";;;;;AAIA,4BAEC;AAGD,gCAEC;AAGD,0BAEC;AAGD,kCAEC;AAGD,sCAIC;AAGD,sCAEC;AAGD,4BAEC;AAtCD,uDAAiD;AACjD,oDAA2B;AAG3B,SAAgB,QAAQ,CAAC,YAAoB;IACzC,OAAO,IAAA,yBAAW,EAAC,YAAY,CAAC,CAAA;AACpC,CAAC;AAGD,SAAgB,UAAU,CAAC,YAAoB;IAC3C,OAAO,IAAA,yBAAW,EAAC,YAAY,CAAC,GAAG,KAAK,CAAA;AAC5C,CAAC;AAGD,SAAgB,OAAO,CAAC,UAAkB;IACtC,OAAO,IAAA,yBAAW,EAAC,UAAU,CAAC,CAAA;AAClC,CAAC;AAGD,SAAgB,WAAW,CAAI,IAAa;IACxC,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;AAC9C,CAAC;AAGD,SAAgB,aAAa,CAAC,CAAkB;IAC5C,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAW,EAAE,EAAE,CAAC,CAAA;IACjC,IAAA,gBAAM,EAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAA;IAC/B,OAAO,CAAC,CAAA;AACZ,CAAC;AAGD,SAAgB,aAAa,CAAC,IAAY,EAAE,KAAa;IACrD,OAAO,IAAI,SAAS,CAAC,SAAS,IAAI,KAAK,KAAK,EAAE,CAAC,CAAA;AACnD,CAAC;AAGD,SAAgB,QAAQ,CAAI,CAAI;IAC5B,OAAO,CAAC,CAAA;AACZ,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@subsquid/openreader",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.3.0",
|
|
4
4
|
"description": "GraphQL server for postgres-compatible databases",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"graphql",
|
|
@@ -23,14 +23,14 @@
|
|
|
23
23
|
"dependencies": {
|
|
24
24
|
"@graphql-tools/merge": "^9.0.1",
|
|
25
25
|
"@subsquid/graphiql-console": "^0.3.0",
|
|
26
|
-
"@subsquid/logger": "^1.
|
|
26
|
+
"@subsquid/logger": "^1.4.0",
|
|
27
27
|
"@subsquid/util-internal": "^3.2.0",
|
|
28
28
|
"@subsquid/util-internal-commander": "^1.4.0",
|
|
29
29
|
"@subsquid/util-internal-hex": "^1.2.2",
|
|
30
30
|
"@subsquid/util-internal-http-server": "^2.0.0",
|
|
31
31
|
"@subsquid/util-naming": "^1.3.0",
|
|
32
|
-
"apollo-server-core": "^3.
|
|
33
|
-
"apollo-server-express": "^3.
|
|
32
|
+
"@subsquid/apollo-server-core": "^3.14.0",
|
|
33
|
+
"@subsquid/apollo-server-express": "^3.14.1",
|
|
34
34
|
"commander": "^11.1.0",
|
|
35
35
|
"deep-equal": "^2.2.3",
|
|
36
36
|
"express": "^4.18.2",
|
|
@@ -52,15 +52,15 @@
|
|
|
52
52
|
"devDependencies": {
|
|
53
53
|
"@types/deep-equal": "^1.0.4",
|
|
54
54
|
"@types/express": "^4.17.21",
|
|
55
|
-
"@types/mocha": "^10.0.
|
|
55
|
+
"@types/mocha": "^10.0.7",
|
|
56
56
|
"@types/node": "^18.18.14",
|
|
57
57
|
"@types/pg": "^8.10.9",
|
|
58
58
|
"@types/ws": "^8.5.10",
|
|
59
59
|
"dotenv": "^16.3.1",
|
|
60
60
|
"expect": "^29.7.0",
|
|
61
61
|
"gql-test-client": "^0.0.0",
|
|
62
|
-
"mocha": "^10.
|
|
63
|
-
"typescript": "~5.
|
|
62
|
+
"mocha": "^10.7.0",
|
|
63
|
+
"typescript": "~5.5.4",
|
|
64
64
|
"@types/inflected": "^2.1.3"
|
|
65
65
|
},
|
|
66
66
|
"scripts": {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {def, unexpectedCase} from '@subsquid/util-internal'
|
|
2
2
|
import {toCamelCase, toPlural} from '@subsquid/util-naming'
|
|
3
|
-
import {UserInputError} from 'apollo-server-core'
|
|
3
|
+
import {UserInputError} from '@subsquid/apollo-server-core'
|
|
4
4
|
import assert from 'assert'
|
|
5
5
|
import {
|
|
6
6
|
GraphQLBoolean,
|
package/src/main.ts
CHANGED
|
@@ -29,6 +29,7 @@ GraphQL server for postgres-compatible databases
|
|
|
29
29
|
program.option('--max-root-fields <count>', 'max number of root fields in a query', nat)
|
|
30
30
|
program.option('--max-response-size <nodes>', 'max response size measured in nodes', nat)
|
|
31
31
|
program.option('--sql-statement-timeout <ms>', 'sql statement timeout in ms', nat)
|
|
32
|
+
program.option('--validation-max-errors <count>', 'max validation errors', nat)
|
|
32
33
|
program.option('--subscriptions', 'enable gql subscriptions')
|
|
33
34
|
program.option('--subscription-poll-interval <ms>', 'subscription poll interval in ms', nat, 1000)
|
|
34
35
|
program.option('--subscription-max-response-size <nodes>', 'max response size measured in nodes', nat)
|
|
@@ -42,6 +43,7 @@ GraphQL server for postgres-compatible databases
|
|
|
42
43
|
maxRootFields?: number
|
|
43
44
|
maxResponseSize?: number
|
|
44
45
|
sqlStatementTimeout?: number
|
|
46
|
+
validationMaxErrors?: number
|
|
45
47
|
subscriptions?: boolean
|
|
46
48
|
subscriptionPollInterval: number
|
|
47
49
|
subscriptionMaxResponseSize?: number
|
|
@@ -65,7 +67,8 @@ GraphQL server for postgres-compatible databases
|
|
|
65
67
|
maxResponseNodes: opts.maxResponseSize,
|
|
66
68
|
subscriptions: opts.subscriptions,
|
|
67
69
|
subscriptionPollInterval: opts.subscriptionPollInterval,
|
|
68
|
-
subscriptionMaxResponseNodes: opts.subscriptionMaxResponseSize
|
|
70
|
+
subscriptionMaxResponseNodes: opts.subscriptionMaxResponseSize,
|
|
71
|
+
validationMaxErrors: opts.validationMaxErrors
|
|
69
72
|
})
|
|
70
73
|
|
|
71
74
|
LOG.info(`listening on port ${server.port}`)
|
package/src/server.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {Logger} from '@subsquid/logger'
|
|
2
2
|
import {listen, ListeningServer} from '@subsquid/util-internal-http-server'
|
|
3
|
-
import {KeyValueCache, PluginDefinition} from 'apollo-server-core'
|
|
4
|
-
import {ApolloServer} from 'apollo-server-express'
|
|
3
|
+
import {KeyValueCache, PluginDefinition} from '@subsquid/apollo-server-core'
|
|
4
|
+
import {ApolloServer} from '@subsquid/apollo-server-express'
|
|
5
5
|
import express from 'express'
|
|
6
6
|
import fs from 'fs'
|
|
7
7
|
import {ExecutionArgs, GraphQLSchema} from 'graphql'
|
|
@@ -34,6 +34,7 @@ export interface ServerOptions {
|
|
|
34
34
|
subscriptionPollInterval?: number
|
|
35
35
|
subscriptionConnection?: Pool
|
|
36
36
|
subscriptionMaxResponseNodes?: number
|
|
37
|
+
validationMaxErrors?: number
|
|
37
38
|
cache?: KeyValueCache
|
|
38
39
|
}
|
|
39
40
|
|
|
@@ -44,6 +45,7 @@ export async function serve(options: ServerOptions): Promise<ListeningServer> {
|
|
|
44
45
|
subscriptionPollInterval,
|
|
45
46
|
maxResponseNodes,
|
|
46
47
|
subscriptionMaxResponseNodes,
|
|
48
|
+
validationMaxErrors,
|
|
47
49
|
log,
|
|
48
50
|
} = options
|
|
49
51
|
|
|
@@ -85,6 +87,7 @@ export async function serve(options: ServerOptions): Promise<ListeningServer> {
|
|
|
85
87
|
subscriptions: options.subscriptions,
|
|
86
88
|
log: options.log,
|
|
87
89
|
graphiqlConsole: options.graphiqlConsole,
|
|
90
|
+
validationMaxErrors,
|
|
88
91
|
maxRequestSizeBytes: options.maxRequestSizeBytes,
|
|
89
92
|
maxRootFields: options.maxRootFields,
|
|
90
93
|
cache: options.cache,
|
|
@@ -105,13 +108,14 @@ export interface ApolloOptions {
|
|
|
105
108
|
graphiqlConsole?: boolean
|
|
106
109
|
log?: Logger
|
|
107
110
|
maxRequestSizeBytes?: number
|
|
111
|
+
validationMaxErrors?: number
|
|
108
112
|
maxRootFields?: number
|
|
109
113
|
cache?: KeyValueCache
|
|
110
114
|
}
|
|
111
115
|
|
|
112
116
|
|
|
113
117
|
export async function runApollo(options: ApolloOptions): Promise<ListeningServer> {
|
|
114
|
-
const {disposals, context, schema, log, maxRootFields} = options
|
|
118
|
+
const {disposals, context, schema, log, maxRootFields, validationMaxErrors} = options
|
|
115
119
|
|
|
116
120
|
let maxRequestSizeBytes = options.maxRequestSizeBytes ?? 256 * 1024
|
|
117
121
|
let app: express.Application = express()
|
|
@@ -119,7 +123,7 @@ export async function runApollo(options: ApolloOptions): Promise<ListeningServer
|
|
|
119
123
|
|
|
120
124
|
let execute = (args: ExecutionArgs) => openreaderExecute(args, {
|
|
121
125
|
maxRootFields: maxRootFields
|
|
122
|
-
|
|
126
|
+
})
|
|
123
127
|
|
|
124
128
|
if (options.subscriptions) {
|
|
125
129
|
let wsServer = new WebSocketServer({
|
|
@@ -150,6 +154,10 @@ export async function runApollo(options: ApolloOptions): Promise<ListeningServer
|
|
|
150
154
|
cache: options.cache,
|
|
151
155
|
stopOnTerminationSignals: false,
|
|
152
156
|
allowBatchedHttpRequests: false,
|
|
157
|
+
dangerouslyDisableValidation: false,
|
|
158
|
+
validateOptions: {
|
|
159
|
+
maxErrors: validationMaxErrors
|
|
160
|
+
},
|
|
153
161
|
executor: async req => {
|
|
154
162
|
return execute({
|
|
155
163
|
schema,
|
|
@@ -157,7 +165,7 @@ export async function runApollo(options: ApolloOptions): Promise<ListeningServer
|
|
|
157
165
|
rootValue: {},
|
|
158
166
|
contextValue: req.context,
|
|
159
167
|
variableValues: req.request.variables,
|
|
160
|
-
operationName: req.operationName
|
|
168
|
+
operationName: req.operationName,
|
|
161
169
|
})
|
|
162
170
|
},
|
|
163
171
|
plugins: [
|
package/src/util/execute.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {Logger, LogLevel} from '@subsquid/logger'
|
|
2
2
|
import {addErrorContext} from '@subsquid/util-internal'
|
|
3
|
-
import {UserInputError} from 'apollo-server-core'
|
|
3
|
+
import {UserInputError} from '@subsquid/apollo-server-core'
|
|
4
4
|
import {getOperationRootType, GraphQLError, subscribe as graphqlSubscribe} from 'graphql'
|
|
5
5
|
import {ExecutionResult} from 'graphql-ws'
|
|
6
6
|
import {
|
package/src/util/limit.ts
CHANGED
package/src/util/resolve-tree.ts
CHANGED