@webiny/handler-graphql 0.0.0-unstable.78f581c1d2 → 0.0.0-unstable.7be00a75a9
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/README.md +9 -5
- package/ResolverDecoration.d.ts +6 -0
- package/ResolverDecoration.js +23 -0
- package/ResolverDecoration.js.map +1 -0
- package/builtInTypes/AnyScalar.d.ts +1 -1
- package/builtInTypes/AnyScalar.js +9 -18
- package/builtInTypes/AnyScalar.js.map +1 -1
- package/builtInTypes/DateScalar.d.ts +1 -1
- package/builtInTypes/DateScalar.js +16 -32
- package/builtInTypes/DateScalar.js.map +1 -1
- package/builtInTypes/DateTimeScalar.d.ts +1 -1
- package/builtInTypes/DateTimeScalar.js +16 -32
- package/builtInTypes/DateTimeScalar.js.map +1 -1
- package/builtInTypes/DateTimeZScalar.d.ts +1 -1
- package/builtInTypes/DateTimeZScalar.js +27 -58
- package/builtInTypes/DateTimeZScalar.js.map +1 -1
- package/builtInTypes/IconScalar.d.ts +10 -0
- package/builtInTypes/IconScalar.js +65 -0
- package/builtInTypes/IconScalar.js.map +1 -0
- package/builtInTypes/JsonScalar.d.ts +1 -1
- package/builtInTypes/JsonScalar.js +4 -10
- package/builtInTypes/JsonScalar.js.map +1 -1
- package/builtInTypes/LongScalar.d.ts +2 -1
- package/builtInTypes/LongScalar.js +38 -9
- package/builtInTypes/LongScalar.js.map +1 -1
- package/builtInTypes/NumberScalar.d.ts +1 -1
- package/builtInTypes/NumberScalar.js +35 -58
- package/builtInTypes/NumberScalar.js.map +1 -1
- package/builtInTypes/RefInputScalar.d.ts +1 -1
- package/builtInTypes/RefInputScalar.js +48 -60
- package/builtInTypes/RefInputScalar.js.map +1 -1
- package/builtInTypes/TimeScalar.d.ts +1 -1
- package/builtInTypes/TimeScalar.js +31 -62
- package/builtInTypes/TimeScalar.js.map +1 -1
- package/builtInTypes/index.d.ts +10 -9
- package/builtInTypes/index.js +10 -122
- package/createGraphQLHandler.d.ts +3 -3
- package/createGraphQLHandler.js +77 -55
- package/createGraphQLHandler.js.map +1 -1
- package/createGraphQLSchema.d.ts +4 -2
- package/createGraphQLSchema.js +67 -54
- package/createGraphQLSchema.js.map +1 -1
- package/createRequestBody.d.ts +2 -0
- package/createRequestBody.js +28 -0
- package/createRequestBody.js.map +1 -0
- package/createResolverDecorator.d.ts +2 -0
- package/createResolverDecorator.js +4 -0
- package/createResolverDecorator.js.map +1 -0
- package/debugPlugins.d.ts +2 -2
- package/debugPlugins.js +28 -45
- package/debugPlugins.js.map +1 -1
- package/errors.js +7 -17
- package/errors.js.map +1 -1
- package/exports/api/graphql.d.ts +2 -0
- package/exports/api/graphql.js +2 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaBuilder.d.ts +16 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaBuilder.js +57 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaBuilder.js.map +1 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaComposer.d.ts +13 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaComposer.js +35 -0
- package/features/GraphQLSchemaBuilder/GraphQLSchemaComposer.js.map +1 -0
- package/features/GraphQLSchemaBuilder/abstractions.d.ts +34 -0
- package/features/GraphQLSchemaBuilder/abstractions.js +6 -0
- package/features/GraphQLSchemaBuilder/abstractions.js.map +1 -0
- package/features/GraphQLSchemaBuilder/feature.d.ts +4 -0
- package/features/GraphQLSchemaBuilder/feature.js +11 -0
- package/features/GraphQLSchemaBuilder/feature.js.map +1 -0
- package/graphql/abstractions.core.d.ts +11 -0
- package/graphql/abstractions.core.js +5 -0
- package/graphql/abstractions.core.js.map +1 -0
- package/graphql/abstractions.d.ts +2 -0
- package/graphql/abstractions.js +2 -0
- package/graphql/abstractions.public.d.ts +18 -0
- package/graphql/abstractions.public.js +5 -0
- package/graphql/abstractions.public.js.map +1 -0
- package/index.d.ts +10 -5
- package/index.js +12 -57
- package/index.js.map +1 -1
- package/interceptConsole.js +31 -39
- package/interceptConsole.js.map +1 -1
- package/package.json +32 -29
- package/plugins/GraphQLSchemaPlugin.d.ts +13 -5
- package/plugins/GraphQLSchemaPlugin.js +23 -29
- package/plugins/GraphQLSchemaPlugin.js.map +1 -1
- package/plugins/index.d.ts +1 -1
- package/plugins/index.js +1 -18
- package/processRequestBody.d.ts +4 -5
- package/processRequestBody.js +35 -42
- package/processRequestBody.js.map +1 -1
- package/responses.d.ts +11 -1
- package/responses.js +44 -92
- package/responses.js.map +1 -1
- package/types.d.ts +20 -13
- package/types.js +0 -5
- package/utils/index.d.ts +1 -0
- package/utils/index.js +1 -0
- package/utils/resolve.d.ts +21 -0
- package/utils/resolve.js +20 -0
- package/utils/resolve.js.map +1 -0
- package/builtInTypes/index.js.map +0 -1
- package/plugins/index.js.map +0 -1
- package/types.js.map +0 -1
package/processRequestBody.js
CHANGED
|
@@ -1,47 +1,40 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
context.plugins.byType("graphql-before-query").forEach(pl => pl.apply({
|
|
17
|
-
body,
|
|
18
|
-
schema,
|
|
19
|
-
context
|
|
20
|
-
}));
|
|
21
|
-
const result = await (0, _graphql.graphql)(schema, query, {}, context, variables, operationName);
|
|
22
|
-
context.plugins.byType("graphql-after-query").forEach(pl => {
|
|
23
|
-
pl.apply({
|
|
24
|
-
result,
|
|
25
|
-
body,
|
|
26
|
-
schema,
|
|
27
|
-
context
|
|
1
|
+
import { graphql } from "graphql";
|
|
2
|
+
const executeGraphQl = async (body, schema, context)=>{
|
|
3
|
+
const { query, variables, operationName } = body;
|
|
4
|
+
context.plugins.byType("graphql-before-query").forEach((pl)=>pl.apply({
|
|
5
|
+
body,
|
|
6
|
+
schema,
|
|
7
|
+
context
|
|
8
|
+
}));
|
|
9
|
+
const result = await graphql({
|
|
10
|
+
schema,
|
|
11
|
+
source: query,
|
|
12
|
+
rootValue: {},
|
|
13
|
+
contextValue: context,
|
|
14
|
+
variableValues: variables,
|
|
15
|
+
operationName
|
|
28
16
|
});
|
|
29
|
-
|
|
30
|
-
|
|
17
|
+
context.plugins.byType("graphql-after-query").forEach((pl)=>{
|
|
18
|
+
pl.apply({
|
|
19
|
+
result,
|
|
20
|
+
body,
|
|
21
|
+
schema,
|
|
22
|
+
context
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
return result;
|
|
31
26
|
};
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
27
|
+
const processRequestBody = async (requestBody, schema, context)=>{
|
|
28
|
+
if (Array.isArray(requestBody)) {
|
|
29
|
+
const results = [];
|
|
30
|
+
for (const body of requestBody){
|
|
31
|
+
const result = await executeGraphQl(body, schema, context);
|
|
32
|
+
results.push(result);
|
|
33
|
+
}
|
|
34
|
+
return results;
|
|
39
35
|
}
|
|
40
|
-
|
|
41
|
-
return result;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return await processRequestBody(requestBody, schema, context);
|
|
36
|
+
return await executeGraphQl(requestBody, schema, context);
|
|
45
37
|
};
|
|
38
|
+
export { processRequestBody };
|
|
46
39
|
|
|
47
|
-
|
|
40
|
+
//# sourceMappingURL=processRequestBody.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"processRequestBody.js","sources":["../src/processRequestBody.ts"],"sourcesContent":["import type { ExecutionResult, GraphQLSchema } from \"graphql\";\nimport { graphql } from \"graphql\";\nimport type {\n GraphQLAfterQueryPlugin,\n GraphQLBeforeQueryPlugin,\n GraphQLRequestBody\n} from \"~/types.js\";\nimport type { Context } from \"@webiny/api/types.js\";\n\nconst executeGraphQl = async <TData = Record<string, any>, TExtensions = Record<string, any>>(\n body: GraphQLRequestBody,\n schema: GraphQLSchema,\n context: Context\n): Promise<ExecutionResult<TData, TExtensions>> => {\n const { query, variables, operationName } = body;\n\n context.plugins\n .byType<GraphQLBeforeQueryPlugin>(\"graphql-before-query\")\n .forEach(pl => pl.apply({ body, schema, context }));\n\n const result = await graphql({\n schema,\n source: query,\n rootValue: {},\n contextValue: context,\n variableValues: variables,\n operationName\n });\n\n context.plugins.byType<GraphQLAfterQueryPlugin>(\"graphql-after-query\").forEach(pl => {\n pl.apply({ result, body, schema, context });\n });\n\n return result as ExecutionResult<TData, TExtensions>;\n};\n\nexport const processRequestBody = async <\n TData = Record<string, any>,\n TExtensions = Record<string, any>\n>(\n requestBody: GraphQLRequestBody | GraphQLRequestBody[],\n schema: GraphQLSchema,\n context: Context\n): Promise<ExecutionResult<TData, TExtensions>[] | ExecutionResult<TData, TExtensions>> => {\n if (Array.isArray(requestBody)) {\n const results: ExecutionResult<TData, TExtensions>[] = [];\n for (const body of requestBody) {\n const result = await executeGraphQl<TData, TExtensions>(body, schema, context);\n results.push(result);\n }\n return results;\n }\n return await executeGraphQl<TData, TExtensions>(requestBody, schema, context);\n};\n"],"names":["executeGraphQl","body","schema","context","query","variables","operationName","pl","result","graphql","processRequestBody","requestBody","Array","results"],"mappings":";AASA,MAAMA,iBAAiB,OACnBC,MACAC,QACAC;IAEA,MAAM,EAAEC,KAAK,EAAEC,SAAS,EAAEC,aAAa,EAAE,GAAGL;IAE5CE,QAAQ,OAAO,CACV,MAAM,CAA2B,wBACjC,OAAO,CAACI,CAAAA,KAAMA,GAAG,KAAK,CAAC;YAAEN;YAAMC;YAAQC;QAAQ;IAEpD,MAAMK,SAAS,MAAMC,QAAQ;QACzBP;QACA,QAAQE;QACR,WAAW,CAAC;QACZ,cAAcD;QACd,gBAAgBE;QAChBC;IACJ;IAEAH,QAAQ,OAAO,CAAC,MAAM,CAA0B,uBAAuB,OAAO,CAACI,CAAAA;QAC3EA,GAAG,KAAK,CAAC;YAAEC;YAAQP;YAAMC;YAAQC;QAAQ;IAC7C;IAEA,OAAOK;AACX;AAEO,MAAME,qBAAqB,OAI9BC,aACAT,QACAC;IAEA,IAAIS,MAAM,OAAO,CAACD,cAAc;QAC5B,MAAME,UAAiD,EAAE;QACzD,KAAK,MAAMZ,QAAQU,YAAa;YAC5B,MAAMH,SAAS,MAAMR,eAAmCC,MAAMC,QAAQC;YACtEU,QAAQ,IAAI,CAACL;QACjB;QACA,OAAOK;IACX;IACA,OAAO,MAAMb,eAAmCW,aAAaT,QAAQC;AACzE"}
|
package/responses.d.ts
CHANGED
|
@@ -1,9 +1,15 @@
|
|
|
1
|
+
export interface IMeta {
|
|
2
|
+
hasMoreItems: boolean;
|
|
3
|
+
totalCount: number;
|
|
4
|
+
cursor?: string | null;
|
|
5
|
+
}
|
|
1
6
|
export interface ErrorResponseParams {
|
|
2
7
|
message: string;
|
|
3
8
|
code?: string;
|
|
4
9
|
data?: any;
|
|
5
10
|
stack?: string | null;
|
|
6
11
|
}
|
|
12
|
+
/** GraphQL error response helper. */
|
|
7
13
|
export declare class ErrorResponse {
|
|
8
14
|
readonly data: null;
|
|
9
15
|
readonly error: {
|
|
@@ -14,9 +20,11 @@ export declare class ErrorResponse {
|
|
|
14
20
|
};
|
|
15
21
|
constructor(params: ErrorResponseParams);
|
|
16
22
|
}
|
|
23
|
+
/** GraphQL not-found response helper. */
|
|
17
24
|
export declare class NotFoundResponse extends ErrorResponse {
|
|
18
25
|
constructor(message: string);
|
|
19
26
|
}
|
|
27
|
+
/** GraphQL list error response helper. */
|
|
20
28
|
export declare class ListErrorResponse {
|
|
21
29
|
readonly data: null;
|
|
22
30
|
readonly meta: null;
|
|
@@ -28,12 +36,14 @@ export declare class ListErrorResponse {
|
|
|
28
36
|
};
|
|
29
37
|
constructor(params: ErrorResponseParams);
|
|
30
38
|
}
|
|
39
|
+
/** GraphQL response helper. */
|
|
31
40
|
export declare class Response<T = any> {
|
|
32
41
|
readonly data: T;
|
|
33
42
|
readonly error: null;
|
|
34
43
|
constructor(data: T);
|
|
35
44
|
}
|
|
36
|
-
|
|
45
|
+
/** GraphQL list response helper. */
|
|
46
|
+
export declare class ListResponse<T, M = IMeta> {
|
|
37
47
|
readonly data: Array<T>;
|
|
38
48
|
readonly meta: M;
|
|
39
49
|
readonly error: null;
|
package/responses.js
CHANGED
|
@@ -1,107 +1,59 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
exports.Response = exports.NotFoundResponse = exports.ListResponse = exports.ListErrorResponse = exports.ErrorResponse = void 0;
|
|
9
|
-
|
|
10
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
|
-
|
|
12
1
|
const defaultParams = {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
2
|
+
code: "",
|
|
3
|
+
message: "",
|
|
4
|
+
data: null,
|
|
5
|
+
stack: null
|
|
17
6
|
};
|
|
18
|
-
|
|
19
7
|
class ErrorResponse {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
8
|
+
constructor(params){
|
|
9
|
+
this.data = null;
|
|
10
|
+
const debug = "true" === process.env.DEBUG;
|
|
11
|
+
let stack = defaultParams.stack;
|
|
12
|
+
if (debug && params.stack) stack = params.stack;
|
|
13
|
+
this.error = {
|
|
14
|
+
code: params.code || defaultParams.code,
|
|
15
|
+
message: params.message || defaultParams.message,
|
|
16
|
+
data: params.data || defaultParams.data,
|
|
17
|
+
stack: stack
|
|
18
|
+
};
|
|
30
19
|
}
|
|
31
|
-
|
|
32
|
-
this.error = {
|
|
33
|
-
code: params.code || defaultParams.code,
|
|
34
|
-
message: params.message || defaultParams.message,
|
|
35
|
-
data: params.data || defaultParams.data,
|
|
36
|
-
stack: stack
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
|
|
40
20
|
}
|
|
41
|
-
|
|
42
|
-
exports.ErrorResponse = ErrorResponse;
|
|
43
|
-
|
|
44
21
|
class NotFoundResponse extends ErrorResponse {
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
22
|
+
constructor(message){
|
|
23
|
+
super({
|
|
24
|
+
code: "NOT_FOUND",
|
|
25
|
+
message
|
|
26
|
+
});
|
|
27
|
+
}
|
|
52
28
|
}
|
|
53
|
-
|
|
54
|
-
exports.NotFoundResponse = NotFoundResponse;
|
|
55
|
-
|
|
56
29
|
class ListErrorResponse {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
30
|
+
constructor(params){
|
|
31
|
+
this.meta = null;
|
|
32
|
+
this.data = null;
|
|
33
|
+
const debug = "true" === process.env.DEBUG;
|
|
34
|
+
let stack = defaultParams.stack;
|
|
35
|
+
if (debug && params.stack) stack = params.stack;
|
|
36
|
+
this.error = {
|
|
37
|
+
code: params.code || defaultParams.code,
|
|
38
|
+
message: params.message || defaultParams.message,
|
|
39
|
+
data: params.data || defaultParams.data,
|
|
40
|
+
stack: stack
|
|
41
|
+
};
|
|
69
42
|
}
|
|
70
|
-
|
|
71
|
-
this.error = {
|
|
72
|
-
code: params.code || defaultParams.code,
|
|
73
|
-
message: params.message || defaultParams.message,
|
|
74
|
-
data: params.data || defaultParams.data,
|
|
75
|
-
stack: stack
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
43
|
}
|
|
80
|
-
|
|
81
|
-
exports.ListErrorResponse = ListErrorResponse;
|
|
82
|
-
|
|
83
44
|
class Response {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
this.error = null;
|
|
89
|
-
}
|
|
90
|
-
|
|
45
|
+
constructor(data){
|
|
46
|
+
this.data = data;
|
|
47
|
+
this.error = null;
|
|
48
|
+
}
|
|
91
49
|
}
|
|
92
|
-
|
|
93
|
-
exports.Response = Response;
|
|
94
|
-
|
|
95
50
|
class ListResponse {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
this.meta = meta || {};
|
|
102
|
-
this.error = null;
|
|
103
|
-
}
|
|
104
|
-
|
|
51
|
+
constructor(data, meta){
|
|
52
|
+
this.data = Array.isArray(data) ? data : [];
|
|
53
|
+
this.meta = meta || {};
|
|
54
|
+
this.error = null;
|
|
55
|
+
}
|
|
105
56
|
}
|
|
57
|
+
export { ErrorResponse, ListErrorResponse, ListResponse, NotFoundResponse, Response };
|
|
106
58
|
|
|
107
|
-
|
|
59
|
+
//# sourceMappingURL=responses.js.map
|
package/responses.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"responses.js","sources":["../src/responses.ts"],"sourcesContent":["export interface IMeta {\n hasMoreItems: boolean;\n totalCount: number;\n cursor?: string | null;\n}\n\nexport interface ErrorResponseParams {\n message: string;\n code?: string;\n data?: any;\n stack?: string | null;\n}\n\nconst defaultParams: Required<ErrorResponseParams> = {\n code: \"\",\n message: \"\",\n data: null,\n stack: null\n};\n\n/** GraphQL error response helper. */\nexport class ErrorResponse {\n public readonly data: null;\n public readonly error: {\n code: string;\n message: string;\n data: any;\n stack: string | null;\n };\n\n constructor(params: ErrorResponseParams) {\n this.data = null;\n\n const debug = process.env.DEBUG === \"true\";\n\n // Ensure `stack` is either `string` or `null`.\n let stack = defaultParams.stack;\n if (debug && params.stack) {\n stack = params.stack;\n }\n\n this.error = {\n code: params.code || defaultParams.code,\n message: params.message || defaultParams.message,\n data: params.data || defaultParams.data,\n stack: stack\n };\n }\n}\n\n/** GraphQL not-found response helper. */\nexport class NotFoundResponse extends ErrorResponse {\n constructor(message: string) {\n super({\n code: \"NOT_FOUND\",\n message\n });\n }\n}\n\n/** GraphQL list error response helper. */\nexport class ListErrorResponse {\n public readonly data: null;\n public readonly meta: null;\n public readonly error: {\n code: string;\n message: string;\n data: any;\n stack: string | null;\n };\n\n constructor(params: ErrorResponseParams) {\n this.meta = null;\n this.data = null;\n\n const debug = process.env.DEBUG === \"true\";\n\n // Ensure `stack` is either `string` or `null`.\n let stack = defaultParams.stack;\n if (debug && params.stack) {\n stack = params.stack;\n }\n\n this.error = {\n code: params.code || defaultParams.code,\n message: params.message || defaultParams.message,\n data: params.data || defaultParams.data,\n stack: stack\n };\n }\n}\n\n/** GraphQL response helper. */\nexport class Response<T = any> {\n public readonly data: T;\n public readonly error: null;\n\n constructor(data: T) {\n this.data = data;\n this.error = null;\n }\n}\n\n/** GraphQL list response helper. */\nexport class ListResponse<T, M = IMeta> {\n public readonly data: Array<T>;\n public readonly meta: M;\n public readonly error: null;\n\n constructor(data: Array<T>, meta?: M) {\n this.data = Array.isArray(data) ? data : [];\n this.meta = meta || ({} as M);\n this.error = null;\n }\n}\n"],"names":["defaultParams","ErrorResponse","params","debug","process","stack","NotFoundResponse","message","ListErrorResponse","Response","data","ListResponse","meta","Array"],"mappings":"AAaA,MAAMA,gBAA+C;IACjD,MAAM;IACN,SAAS;IACT,MAAM;IACN,OAAO;AACX;AAGO,MAAMC;IAST,YAAYC,MAA2B,CAAE;QACrC,IAAI,CAAC,IAAI,GAAG;QAEZ,MAAMC,QAAQC,AAAsB,WAAtBA,QAAQ,GAAG,CAAC,KAAK;QAG/B,IAAIC,QAAQL,cAAc,KAAK;QAC/B,IAAIG,SAASD,OAAO,KAAK,EACrBG,QAAQH,OAAO,KAAK;QAGxB,IAAI,CAAC,KAAK,GAAG;YACT,MAAMA,OAAO,IAAI,IAAIF,cAAc,IAAI;YACvC,SAASE,OAAO,OAAO,IAAIF,cAAc,OAAO;YAChD,MAAME,OAAO,IAAI,IAAIF,cAAc,IAAI;YACvC,OAAOK;QACX;IACJ;AACJ;AAGO,MAAMC,yBAAyBL;IAClC,YAAYM,OAAe,CAAE;QACzB,KAAK,CAAC;YACF,MAAM;YACNA;QACJ;IACJ;AACJ;AAGO,MAAMC;IAUT,YAAYN,MAA2B,CAAE;QACrC,IAAI,CAAC,IAAI,GAAG;QACZ,IAAI,CAAC,IAAI,GAAG;QAEZ,MAAMC,QAAQC,AAAsB,WAAtBA,QAAQ,GAAG,CAAC,KAAK;QAG/B,IAAIC,QAAQL,cAAc,KAAK;QAC/B,IAAIG,SAASD,OAAO,KAAK,EACrBG,QAAQH,OAAO,KAAK;QAGxB,IAAI,CAAC,KAAK,GAAG;YACT,MAAMA,OAAO,IAAI,IAAIF,cAAc,IAAI;YACvC,SAASE,OAAO,OAAO,IAAIF,cAAc,OAAO;YAChD,MAAME,OAAO,IAAI,IAAIF,cAAc,IAAI;YACvC,OAAOK;QACX;IACJ;AACJ;AAGO,MAAMI;IAIT,YAAYC,IAAO,CAAE;QACjB,IAAI,CAAC,IAAI,GAAGA;QACZ,IAAI,CAAC,KAAK,GAAG;IACjB;AACJ;AAGO,MAAMC;IAKT,YAAYD,IAAc,EAAEE,IAAQ,CAAE;QAClC,IAAI,CAAC,IAAI,GAAGC,MAAM,OAAO,CAACH,QAAQA,OAAO,EAAE;QAC3C,IAAI,CAAC,IAAI,GAAGE,QAAS,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG;IACjB;AACJ"}
|
package/types.d.ts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { GraphQLScalarType, GraphQLFieldResolver as BaseGraphQLFieldResolver, GraphQLSchema } from "graphql";
|
|
2
|
-
import { Plugin } from "@webiny/plugins/types";
|
|
3
|
-
import { Context } from "@webiny/api/types";
|
|
4
|
-
import { RouteMethodPath } from "@webiny/handler/types";
|
|
1
|
+
import type { GraphQLScalarType, GraphQLFieldResolver as BaseGraphQLFieldResolver, GraphQLSchema } from "graphql";
|
|
2
|
+
import type { Plugin } from "@webiny/plugins/types.js";
|
|
3
|
+
import type { Context, GenericRecord } from "@webiny/api/types.js";
|
|
4
|
+
import type { RouteMethodPath } from "@webiny/handler/types.js";
|
|
5
|
+
import type { ResolversComposition } from "@graphql-tools/resolvers-composition";
|
|
6
|
+
import type { IResolvers, TypeSource } from "@graphql-tools/utils";
|
|
5
7
|
export interface GraphQLScalarPlugin extends Plugin {
|
|
6
8
|
type: "graphql-scalar";
|
|
7
9
|
scalar: GraphQLScalarType;
|
|
@@ -10,19 +12,24 @@ export interface HandlerGraphQLOptions {
|
|
|
10
12
|
path?: RouteMethodPath;
|
|
11
13
|
debug?: boolean | string;
|
|
12
14
|
}
|
|
13
|
-
export
|
|
14
|
-
|
|
15
|
+
export type GraphQLFieldResolver<TSource = any, TArgs = any, TContext = Context> = BaseGraphQLFieldResolver<TSource, TContext, TArgs>;
|
|
16
|
+
/**
|
|
17
|
+
* @deprecated Use `TypeDefs` instead.
|
|
18
|
+
*/
|
|
19
|
+
export type Types = TypeDefs;
|
|
20
|
+
export type TypeDefs = TypeSource;
|
|
15
21
|
export interface GraphQLSchemaPluginTypeArgs {
|
|
16
22
|
context?: any;
|
|
17
23
|
args?: any;
|
|
18
24
|
source?: any;
|
|
19
25
|
}
|
|
20
|
-
export
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
export interface GraphQLSchemaDefinition<TContext> {
|
|
24
|
-
typeDefs:
|
|
26
|
+
export type Resolvers<TContext> = IResolvers<any, TContext>;
|
|
27
|
+
export type ResolverDecorator<TSource = any, TContext = any, TArgs = any> = ResolversComposition<GraphQLFieldResolver<TSource, TContext, TArgs>>;
|
|
28
|
+
export type ResolverDecorators = GenericRecord<string, ResolverDecorator[]>;
|
|
29
|
+
export interface GraphQLSchemaDefinition<TContext = any> {
|
|
30
|
+
typeDefs: TypeDefs;
|
|
25
31
|
resolvers?: Resolvers<TContext>;
|
|
32
|
+
resolverDecorators?: ResolverDecorators;
|
|
26
33
|
}
|
|
27
34
|
export interface GraphQLSchemaPlugin<TContext extends Context = Context> extends Plugin {
|
|
28
35
|
type: "graphql-schema";
|
|
@@ -30,8 +37,8 @@ export interface GraphQLSchemaPlugin<TContext extends Context = Context> extends
|
|
|
30
37
|
}
|
|
31
38
|
export interface GraphQLRequestBody {
|
|
32
39
|
query: string;
|
|
33
|
-
variables
|
|
34
|
-
operationName
|
|
40
|
+
variables?: Record<string, any> | null;
|
|
41
|
+
operationName?: string;
|
|
35
42
|
}
|
|
36
43
|
export interface GraphQLBeforeQueryPlugin<TContext extends Context = Context> extends Plugin {
|
|
37
44
|
type: "graphql-before-query";
|
package/types.js
CHANGED
package/utils/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./resolve.js";
|
package/utils/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./resolve.js";
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ErrorResponse, ListErrorResponse, ListResponse, Response } from "../responses.js";
|
|
2
|
+
import type { GenericRecord } from "@webiny/api/types.js";
|
|
3
|
+
export interface Meta {
|
|
4
|
+
totalCount: number;
|
|
5
|
+
hasMoreItems: boolean;
|
|
6
|
+
cursor: string | null;
|
|
7
|
+
}
|
|
8
|
+
export declare const emptyResolver: () => {};
|
|
9
|
+
interface ResolveCallable<T = GenericRecord> {
|
|
10
|
+
(): Promise<T>;
|
|
11
|
+
}
|
|
12
|
+
export declare const resolve: <T = GenericRecord>(fn: ResolveCallable<T>) => Promise<ErrorResponse | Response<Awaited<T>>>;
|
|
13
|
+
interface ResolveListCallable<T> {
|
|
14
|
+
(): Promise<IListResult<T>>;
|
|
15
|
+
}
|
|
16
|
+
interface IListResult<T = GenericRecord> {
|
|
17
|
+
items: T[];
|
|
18
|
+
meta: Meta;
|
|
19
|
+
}
|
|
20
|
+
export declare const resolveList: <T = GenericRecord>(fn: ResolveListCallable<T>) => Promise<ListErrorResponse | ListResponse<T, Meta>>;
|
|
21
|
+
export {};
|
package/utils/resolve.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ErrorResponse, ListErrorResponse, ListResponse, Response } from "../responses.js";
|
|
2
|
+
const emptyResolver = ()=>({});
|
|
3
|
+
const resolve = async (fn)=>{
|
|
4
|
+
try {
|
|
5
|
+
return new Response(await fn());
|
|
6
|
+
} catch (ex) {
|
|
7
|
+
return new ErrorResponse(ex);
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
const resolveList = async (fn)=>{
|
|
11
|
+
try {
|
|
12
|
+
const result = await fn();
|
|
13
|
+
return new ListResponse(result.items, result.meta);
|
|
14
|
+
} catch (ex) {
|
|
15
|
+
return new ListErrorResponse(ex);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export { emptyResolver, resolve, resolveList };
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=resolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils/resolve.js","sources":["../../src/utils/resolve.ts"],"sourcesContent":["import { ErrorResponse, ListErrorResponse, ListResponse, Response } from \"~/responses.js\";\nimport type { GenericRecord } from \"@webiny/api/types.js\";\n\nexport interface Meta {\n totalCount: number;\n hasMoreItems: boolean;\n cursor: string | null;\n}\n\nexport const emptyResolver = () => ({});\n\ninterface ResolveCallable<T = GenericRecord> {\n (): Promise<T>;\n}\n\nexport const resolve = async <T = GenericRecord>(fn: ResolveCallable<T>) => {\n try {\n return new Response(await fn());\n } catch (ex) {\n return new ErrorResponse(ex);\n }\n};\n\ninterface ResolveListCallable<T> {\n (): Promise<IListResult<T>>;\n}\n\ninterface IListResult<T = GenericRecord> {\n items: T[];\n meta: Meta;\n}\n\nexport const resolveList = async <T = GenericRecord>(fn: ResolveListCallable<T>) => {\n try {\n const result = (await fn()) as IListResult<T>;\n return new ListResponse(result.items, result.meta);\n } catch (ex) {\n return new ListErrorResponse(ex);\n }\n};\n"],"names":["emptyResolver","resolve","fn","Response","ex","ErrorResponse","resolveList","result","ListResponse","ListErrorResponse"],"mappings":";AASO,MAAMA,gBAAgB,IAAO,EAAC;AAM9B,MAAMC,UAAU,OAA0BC;IAC7C,IAAI;QACA,OAAO,IAAIC,SAAS,MAAMD;IAC9B,EAAE,OAAOE,IAAI;QACT,OAAO,IAAIC,cAAcD;IAC7B;AACJ;AAWO,MAAME,cAAc,OAA0BJ;IACjD,IAAI;QACA,MAAMK,SAAU,MAAML;QACtB,OAAO,IAAIM,aAAaD,OAAO,KAAK,EAAEA,OAAO,IAAI;IACrD,EAAE,OAAOH,IAAI;QACT,OAAO,IAAIK,kBAAkBL;IACjC;AACJ"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./AnyScalar\";\nexport * from \"./DateScalar\";\nexport * from \"./DateTimeScalar\";\nexport * from \"./DateTimeZScalar\";\nexport * from \"./JsonScalar\";\nexport * from \"./LongScalar\";\nexport * from \"./NumberScalar\";\nexport * from \"./RefInputScalar\";\nexport * from \"./TimeScalar\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
|
package/plugins/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./GraphQLSchemaPlugin\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
|
package/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import {\n GraphQLScalarType,\n GraphQLFieldResolver as BaseGraphQLFieldResolver,\n GraphQLSchema\n} from \"graphql\";\nimport { Plugin } from \"@webiny/plugins/types\";\nimport { Context } from \"@webiny/api/types\";\nimport { RouteMethodPath } from \"@webiny/handler/types\";\n\nexport interface GraphQLScalarPlugin extends Plugin {\n type: \"graphql-scalar\";\n scalar: GraphQLScalarType;\n}\n\nexport interface HandlerGraphQLOptions {\n path?: RouteMethodPath;\n debug?: boolean | string;\n}\n\nexport type GraphQLFieldResolver<\n TSource = any,\n TArgs = any,\n TContext = Context\n> = BaseGraphQLFieldResolver<TSource, TContext, TArgs>;\n\n// `GraphQLSchemaPlugin` types.\nexport type Types = string | (() => string | Promise<string>);\n\nexport interface GraphQLSchemaPluginTypeArgs {\n context?: any;\n args?: any;\n source?: any;\n}\n\nexport type Resolvers<TContext> =\n | GraphQLScalarType\n | GraphQLFieldResolver<any, Record<string, any>, TContext>\n | { [property: string]: Resolvers<TContext> };\n\nexport interface GraphQLSchemaDefinition<TContext> {\n typeDefs: Types;\n resolvers?: Resolvers<TContext>;\n}\n\nexport interface GraphQLSchemaPlugin<TContext extends Context = Context> extends Plugin {\n type: \"graphql-schema\";\n schema: GraphQLSchemaDefinition<TContext>;\n}\n\nexport interface GraphQLRequestBody {\n query: string;\n variables: Record<string, any>;\n operationName: string;\n}\n\nexport interface GraphQLBeforeQueryPlugin<TContext extends Context = Context> extends Plugin {\n type: \"graphql-before-query\";\n apply(params: { body: GraphQLRequestBody; schema: GraphQLSchema; context: TContext }): void;\n}\n\nexport interface GraphQLAfterQueryPlugin<TContext extends Context = Context> extends Plugin {\n type: \"graphql-after-query\";\n apply(params: {\n result: any;\n body: GraphQLRequestBody;\n schema: GraphQLSchema;\n context: TContext;\n }): void;\n}\n"],"mappings":""}
|