@kiyasov/platform-hono 1.0.8 → 1.0.9
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/.yarn/install-state.gz +0 -0
- package/Readme.md +0 -7
- package/dist/cjs/src/drivers/graphQLUpload/GraphQLUpload.d.ts +3 -0
- package/dist/cjs/src/drivers/graphQLUpload/GraphQLUpload.js +21 -0
- package/dist/cjs/src/drivers/graphQLUpload/GraphQLUpload.js.map +1 -0
- package/dist/cjs/src/drivers/graphQLUpload/Upload.d.ts +16 -0
- package/dist/cjs/src/drivers/graphQLUpload/Upload.js +17 -0
- package/dist/cjs/src/drivers/graphQLUpload/Upload.js.map +1 -0
- package/dist/cjs/src/drivers/graphQLUpload/fs-capacitor.d.ts +44 -0
- package/dist/cjs/src/drivers/graphQLUpload/fs-capacitor.js +190 -0
- package/dist/cjs/src/drivers/graphQLUpload/fs-capacitor.js.map +1 -0
- package/dist/cjs/src/drivers/graphQLUpload/index.d.ts +4 -0
- package/dist/cjs/src/drivers/graphQLUpload/index.js +21 -0
- package/dist/cjs/src/drivers/graphQLUpload/index.js.map +1 -0
- package/dist/cjs/src/drivers/graphQLUpload/processRequest.d.ts +2 -0
- package/dist/cjs/src/drivers/graphQLUpload/processRequest.js +45 -0
- package/dist/cjs/src/drivers/graphQLUpload/processRequest.js.map +1 -0
- package/dist/cjs/src/drivers/graphql.driver.d.ts +7 -4
- package/dist/cjs/src/drivers/graphql.driver.js +23 -11
- package/dist/cjs/src/drivers/graphql.driver.js.map +1 -1
- package/dist/cjs/src/drivers/index.d.ts +1 -0
- package/dist/cjs/src/drivers/index.js +1 -0
- package/dist/cjs/src/drivers/index.js.map +1 -1
- package/dist/cjs/src/drivers/services/processRequest.d.ts +2 -0
- package/dist/cjs/src/drivers/services/processRequest.js +45 -0
- package/dist/cjs/src/drivers/services/processRequest.js.map +1 -0
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/drivers/graphQLUpload/GraphQLUpload.d.ts +3 -0
- package/dist/esm/src/drivers/graphQLUpload/GraphQLUpload.js +18 -0
- package/dist/esm/src/drivers/graphQLUpload/GraphQLUpload.js.map +1 -0
- package/dist/esm/src/drivers/graphQLUpload/Upload.d.ts +16 -0
- package/dist/esm/src/drivers/graphQLUpload/Upload.js +13 -0
- package/dist/esm/src/drivers/graphQLUpload/Upload.js.map +1 -0
- package/dist/esm/src/drivers/graphQLUpload/fs-capacitor.d.ts +44 -0
- package/dist/esm/src/drivers/graphQLUpload/fs-capacitor.js +183 -0
- package/dist/esm/src/drivers/graphQLUpload/fs-capacitor.js.map +1 -0
- package/dist/esm/src/drivers/graphQLUpload/index.d.ts +4 -0
- package/dist/esm/src/drivers/graphQLUpload/index.js +5 -0
- package/dist/esm/src/drivers/graphQLUpload/index.js.map +1 -0
- package/dist/esm/src/drivers/graphQLUpload/processRequest.d.ts +2 -0
- package/dist/esm/src/drivers/graphQLUpload/processRequest.js +41 -0
- package/dist/esm/src/drivers/graphQLUpload/processRequest.js.map +1 -0
- package/dist/esm/src/drivers/graphql.driver.d.ts +7 -4
- package/dist/esm/src/drivers/graphql.driver.js +28 -16
- package/dist/esm/src/drivers/graphql.driver.js.map +1 -1
- package/dist/esm/src/drivers/index.d.ts +1 -0
- package/dist/esm/src/drivers/index.js +1 -0
- package/dist/esm/src/drivers/index.js.map +1 -1
- package/dist/esm/src/drivers/services/processRequest.d.ts +2 -0
- package/dist/esm/src/drivers/services/processRequest.js +41 -0
- package/dist/esm/src/drivers/services/processRequest.js.map +1 -0
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/drivers/graphQLUpload/GraphQLUpload.ts +86 -0
- package/src/drivers/graphQLUpload/Upload.ts +35 -0
- package/src/drivers/graphQLUpload/fs-capacitor.ts +285 -0
- package/src/drivers/graphQLUpload/index.ts +4 -0
- package/src/drivers/graphQLUpload/processRequest.ts +50 -0
- package/src/drivers/graphql.driver.ts +38 -23
- package/src/drivers/index.ts +1 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Upload } from "./Upload";
|
|
2
|
+
import { GraphQLError, GraphQLScalarType } from "graphql";
|
|
3
|
+
export const GraphQLUpload = new GraphQLScalarType({
|
|
4
|
+
name: "Upload",
|
|
5
|
+
description: "The `Upload` scalar type represents a file upload.",
|
|
6
|
+
parseValue(value) {
|
|
7
|
+
if (value instanceof Upload)
|
|
8
|
+
return value.promise;
|
|
9
|
+
throw new GraphQLError("Upload value invalid.");
|
|
10
|
+
},
|
|
11
|
+
parseLiteral(node) {
|
|
12
|
+
throw new GraphQLError("Upload literal unsupported.", { nodes: node });
|
|
13
|
+
},
|
|
14
|
+
serialize() {
|
|
15
|
+
throw new GraphQLError("Upload serialization unsupported.");
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
//# sourceMappingURL=GraphQLUpload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GraphQLUpload.js","sourceRoot":"","sources":["../../../../../src/drivers/graphQLUpload/GraphQLUpload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAW,YAAY,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAuEnE,MAAM,CAAC,MAAM,aAAa,GAAG,IAAI,iBAAiB,CAAC;IACjD,IAAI,EAAE,QAAQ;IACd,WAAW,EAAE,oDAAoD;IACjE,UAAU,CAAC,KAAmC;QAC5C,IAAI,KAAK,YAAY,MAAM;YAAE,OAAO,KAAK,CAAC,OAAO,CAAC;QAClD,MAAM,IAAI,YAAY,CAAC,uBAAuB,CAAC,CAAC;IAClD,CAAC;IACD,YAAY,CAAC,IAAyB;QACpC,MAAM,IAAI,YAAY,CAAC,6BAA6B,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACzE,CAAC;IACD,SAAS;QACP,MAAM,IAAI,YAAY,CAAC,mCAAmC,CAAC,CAAC;IAC9D,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ReadStream, ReadStreamOptions, WriteStream } from "./fs-capacitor";
|
|
2
|
+
export interface FileUpload {
|
|
3
|
+
filename: string;
|
|
4
|
+
fieldName: string;
|
|
5
|
+
mimetype: string;
|
|
6
|
+
encoding: string;
|
|
7
|
+
createReadStream(options?: ReadStreamOptions): ReadStream;
|
|
8
|
+
capacitor: WriteStream;
|
|
9
|
+
}
|
|
10
|
+
export declare class Upload {
|
|
11
|
+
promise: Promise<FileUpload>;
|
|
12
|
+
resolve: (file?: FileUpload) => void;
|
|
13
|
+
reject: (error?: Error | string) => void;
|
|
14
|
+
file?: FileUpload;
|
|
15
|
+
constructor();
|
|
16
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export class Upload {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.promise = new Promise((resolve, reject) => {
|
|
4
|
+
this.resolve = (file) => {
|
|
5
|
+
this.file = file;
|
|
6
|
+
resolve(file);
|
|
7
|
+
};
|
|
8
|
+
this.reject = reject;
|
|
9
|
+
});
|
|
10
|
+
this.promise.catch(() => { });
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=Upload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Upload.js","sourceRoot":"","sources":["../../../../../src/drivers/graphQLUpload/Upload.ts"],"names":[],"mappings":"AAaA,MAAM,OAAO,MAAM;IAMjB;QACE,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC7C,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,EAAE,EAAE;gBACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBAEjB,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC;YAEF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACvB,CAAC,CAAC,CAAC;QAIH,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IAC/B,CAAC;CACF"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { Readable, ReadableOptions, Writable, WritableOptions } from "stream";
|
|
4
|
+
export declare class ReadAfterDestroyedError extends Error {
|
|
5
|
+
}
|
|
6
|
+
export declare class ReadAfterReleasedError extends Error {
|
|
7
|
+
}
|
|
8
|
+
export interface ReadStreamOptions {
|
|
9
|
+
highWaterMark?: ReadableOptions["highWaterMark"];
|
|
10
|
+
encoding?: ReadableOptions["encoding"];
|
|
11
|
+
}
|
|
12
|
+
export declare class ReadStream extends Readable {
|
|
13
|
+
private _pos;
|
|
14
|
+
private _writeStream;
|
|
15
|
+
constructor(writeStream: WriteStream, options?: ReadStreamOptions);
|
|
16
|
+
_read(n: number): void;
|
|
17
|
+
}
|
|
18
|
+
export interface WriteStreamOptions {
|
|
19
|
+
highWaterMark?: WritableOptions["highWaterMark"];
|
|
20
|
+
defaultEncoding?: WritableOptions["defaultEncoding"];
|
|
21
|
+
tmpdir?: () => string;
|
|
22
|
+
}
|
|
23
|
+
export declare class WriteStream extends Writable {
|
|
24
|
+
private _fd;
|
|
25
|
+
private _path;
|
|
26
|
+
private _pos;
|
|
27
|
+
private _readStreams;
|
|
28
|
+
private _released;
|
|
29
|
+
constructor(options?: WriteStreamOptions);
|
|
30
|
+
_cleanup: (callback: (error: null | Error) => void) => void;
|
|
31
|
+
_cleanupSync: () => void;
|
|
32
|
+
_final(callback: (error?: null | Error) => any): void;
|
|
33
|
+
_write(chunk: Buffer, encoding: string, callback: (error?: null | Error) => any): void;
|
|
34
|
+
release(): void;
|
|
35
|
+
_destroy(error: undefined | null | Error, callback: (error?: null | Error) => any): void;
|
|
36
|
+
createReadStream(options?: ReadStreamOptions): ReadStream;
|
|
37
|
+
}
|
|
38
|
+
declare const _default: {
|
|
39
|
+
WriteStream: typeof WriteStream;
|
|
40
|
+
ReadStream: typeof ReadStream;
|
|
41
|
+
ReadAfterDestroyedError: typeof ReadAfterDestroyedError;
|
|
42
|
+
ReadAfterReleasedError: typeof ReadAfterReleasedError;
|
|
43
|
+
};
|
|
44
|
+
export default _default;
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { randomBytes } from "crypto";
|
|
2
|
+
import { read, open, closeSync, unlinkSync, write, close, unlink } from "fs";
|
|
3
|
+
import { tmpdir } from "os";
|
|
4
|
+
import { join } from "path";
|
|
5
|
+
import { Readable, Writable } from "stream";
|
|
6
|
+
import { EventEmitter } from "events";
|
|
7
|
+
export class ReadAfterDestroyedError extends Error {
|
|
8
|
+
}
|
|
9
|
+
export class ReadAfterReleasedError extends Error {
|
|
10
|
+
}
|
|
11
|
+
const processExitProxy = new EventEmitter();
|
|
12
|
+
processExitProxy.setMaxListeners(Infinity);
|
|
13
|
+
process.once("exit", () => processExitProxy.emit("exit"));
|
|
14
|
+
export class ReadStream extends Readable {
|
|
15
|
+
constructor(writeStream, options) {
|
|
16
|
+
super({
|
|
17
|
+
highWaterMark: options?.highWaterMark,
|
|
18
|
+
encoding: options?.encoding,
|
|
19
|
+
autoDestroy: true,
|
|
20
|
+
});
|
|
21
|
+
this._pos = 0;
|
|
22
|
+
this._writeStream = writeStream;
|
|
23
|
+
}
|
|
24
|
+
_read(n) {
|
|
25
|
+
if (this.destroyed)
|
|
26
|
+
return;
|
|
27
|
+
if (typeof this._writeStream["_fd"] !== "number") {
|
|
28
|
+
this._writeStream.once("ready", () => this._read(n));
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const buf = Buffer.allocUnsafe(n);
|
|
32
|
+
read(this._writeStream["_fd"], buf, 0, n, this._pos, (error, bytesRead) => {
|
|
33
|
+
if (error)
|
|
34
|
+
this.destroy(error);
|
|
35
|
+
if (bytesRead) {
|
|
36
|
+
this._pos += bytesRead;
|
|
37
|
+
this.push(buf.slice(0, bytesRead));
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (this._writeStream._writableState.finished) {
|
|
41
|
+
if (this._pos < this._writeStream._pos)
|
|
42
|
+
this._read(n);
|
|
43
|
+
else
|
|
44
|
+
this.push(null);
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const retry = () => {
|
|
48
|
+
this._writeStream.off("finish", retry);
|
|
49
|
+
this._writeStream.off("write", retry);
|
|
50
|
+
this._read(n);
|
|
51
|
+
};
|
|
52
|
+
this._writeStream.on("finish", retry);
|
|
53
|
+
this._writeStream.on("write", retry);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
export class WriteStream extends Writable {
|
|
58
|
+
constructor(options) {
|
|
59
|
+
super({
|
|
60
|
+
highWaterMark: options?.highWaterMark,
|
|
61
|
+
defaultEncoding: options?.defaultEncoding,
|
|
62
|
+
autoDestroy: false,
|
|
63
|
+
});
|
|
64
|
+
this._fd = null;
|
|
65
|
+
this._path = null;
|
|
66
|
+
this._pos = 0;
|
|
67
|
+
this._readStreams = new Set();
|
|
68
|
+
this._released = false;
|
|
69
|
+
this._cleanup = (callback) => {
|
|
70
|
+
const fd = this._fd;
|
|
71
|
+
const path = this._path;
|
|
72
|
+
if (typeof fd !== "number" || typeof path !== "string") {
|
|
73
|
+
callback(null);
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
close(fd, (closeError) => {
|
|
77
|
+
unlink(path, (unlinkError) => {
|
|
78
|
+
this._fd = null;
|
|
79
|
+
processExitProxy.off("exit", this._cleanupSync);
|
|
80
|
+
callback(unlinkError ?? closeError);
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
this._cleanupSync = () => {
|
|
85
|
+
processExitProxy.off("exit", this._cleanupSync);
|
|
86
|
+
if (typeof this._fd === "number")
|
|
87
|
+
try {
|
|
88
|
+
closeSync(this._fd);
|
|
89
|
+
}
|
|
90
|
+
catch (error) {
|
|
91
|
+
}
|
|
92
|
+
try {
|
|
93
|
+
if (this._path !== null) {
|
|
94
|
+
unlinkSync(this._path);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
randomBytes(16, (error, buffer) => {
|
|
101
|
+
if (error) {
|
|
102
|
+
this.destroy(error);
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
this._path = join((options?.tmpdir ?? tmpdir)(), `capacitor-${buffer.toString("hex")}.tmp`);
|
|
106
|
+
open(this._path, "wx+", 0o600, (error, fd) => {
|
|
107
|
+
if (error) {
|
|
108
|
+
this.destroy(error);
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
processExitProxy.once("exit", this._cleanupSync);
|
|
112
|
+
this._fd = fd;
|
|
113
|
+
this.emit("ready");
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
_final(callback) {
|
|
118
|
+
if (typeof this._fd !== "number") {
|
|
119
|
+
this.once("ready", () => this._final(callback));
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
callback();
|
|
123
|
+
}
|
|
124
|
+
_write(chunk, encoding, callback) {
|
|
125
|
+
if (typeof this._fd !== "number") {
|
|
126
|
+
this.once("ready", () => this._write(chunk, encoding, callback));
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
write(this._fd, chunk, 0, chunk.length, this._pos, (error) => {
|
|
130
|
+
if (error) {
|
|
131
|
+
callback(error);
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
this._pos += chunk.length;
|
|
135
|
+
this.emit("write");
|
|
136
|
+
callback();
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
release() {
|
|
140
|
+
this._released = true;
|
|
141
|
+
if (this._readStreams.size === 0)
|
|
142
|
+
this.destroy();
|
|
143
|
+
}
|
|
144
|
+
_destroy(error, callback) {
|
|
145
|
+
for (const readStream of this._readStreams) {
|
|
146
|
+
readStream.destroy(error || undefined);
|
|
147
|
+
}
|
|
148
|
+
if (typeof this._fd === "number" && typeof this._path === "string") {
|
|
149
|
+
this._cleanup((cleanupError) => callback(cleanupError ?? error));
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
this.once("ready", () => {
|
|
153
|
+
this._cleanup((cleanupError) => {
|
|
154
|
+
if (cleanupError) {
|
|
155
|
+
this.emit("error", cleanupError);
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
callback(error);
|
|
160
|
+
}
|
|
161
|
+
createReadStream(options) {
|
|
162
|
+
if (this.destroyed)
|
|
163
|
+
throw new ReadAfterDestroyedError("A ReadStream cannot be created from a destroyed WriteStream.");
|
|
164
|
+
if (this._released)
|
|
165
|
+
throw new ReadAfterReleasedError("A ReadStream cannot be created from a released WriteStream.");
|
|
166
|
+
const readStream = new ReadStream(this, options);
|
|
167
|
+
this._readStreams.add(readStream);
|
|
168
|
+
readStream.once("close", () => {
|
|
169
|
+
this._readStreams.delete(readStream);
|
|
170
|
+
if (this._released && this._readStreams.size === 0) {
|
|
171
|
+
this.destroy();
|
|
172
|
+
}
|
|
173
|
+
});
|
|
174
|
+
return readStream;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
export default {
|
|
178
|
+
WriteStream,
|
|
179
|
+
ReadStream,
|
|
180
|
+
ReadAfterDestroyedError,
|
|
181
|
+
ReadAfterReleasedError,
|
|
182
|
+
};
|
|
183
|
+
//# sourceMappingURL=fs-capacitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fs-capacitor.js","sourceRoot":"","sources":["../../../../../src/drivers/graphQLUpload/fs-capacitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/drivers/graphQLUpload/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { WriteStream, Upload } from ".";
|
|
2
|
+
import { Readable } from "stream";
|
|
3
|
+
export async function processRequest(ctx) {
|
|
4
|
+
const body = await ctx.req.parseBody();
|
|
5
|
+
const operations = JSON.parse(body.operations);
|
|
6
|
+
const map = new Map(Object.entries(JSON.parse(body.map)));
|
|
7
|
+
for (const [fieldName, file] of Object.entries(body)) {
|
|
8
|
+
if (fieldName === "operations" ||
|
|
9
|
+
fieldName === "map" ||
|
|
10
|
+
!(file instanceof File))
|
|
11
|
+
continue;
|
|
12
|
+
const fileKeys = map.get(fieldName);
|
|
13
|
+
if (!Array.isArray(fileKeys) || !fileKeys.length)
|
|
14
|
+
continue;
|
|
15
|
+
const buffer = Buffer.from(await file.arrayBuffer());
|
|
16
|
+
const capacitor = new WriteStream();
|
|
17
|
+
Readable.from(buffer).pipe(capacitor);
|
|
18
|
+
const upload = new Upload();
|
|
19
|
+
upload.file = {
|
|
20
|
+
filename: file.name,
|
|
21
|
+
mimetype: file.type,
|
|
22
|
+
fieldName,
|
|
23
|
+
encoding: "7bit",
|
|
24
|
+
createReadStream: (options) => capacitor.createReadStream(options),
|
|
25
|
+
capacitor,
|
|
26
|
+
};
|
|
27
|
+
upload.resolve(upload.file);
|
|
28
|
+
for (const fileKey of fileKeys) {
|
|
29
|
+
const pathSegments = fileKey.split(".");
|
|
30
|
+
let current = operations;
|
|
31
|
+
for (let i = 0; i < pathSegments.length - 1; i++) {
|
|
32
|
+
if (!current[pathSegments[i]])
|
|
33
|
+
current[pathSegments[i]] = {};
|
|
34
|
+
current = current[pathSegments[i]];
|
|
35
|
+
}
|
|
36
|
+
current[pathSegments[pathSegments.length - 1]] = upload;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return operations;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=processRequest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processRequest.js","sourceRoot":"","sources":["../../../../../src/drivers/graphQLUpload/processRequest.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAY;IAEZ,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;IACvC,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAoB,CAAC,CAAC;IACzD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAa,CAAC,CAAC,CAAC,CAAC;IAEpE,KAAK,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACrD,IACE,SAAS,KAAK,YAAY;YAC1B,SAAS,KAAK,KAAK;YACnB,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC;YAEvB,SAAS;QAEX,MAAM,QAAQ,GAAG,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,SAAS;QAE3D,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACrD,MAAM,SAAS,GAAG,IAAI,WAAW,EAAE,CAAC;QACpC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEtC,MAAM,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;QAC5B,MAAM,CAAC,IAAI,GAAG;YACZ,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,SAAS;YACT,QAAQ,EAAE,MAAM;YAChB,gBAAgB,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,CAAC;YAClE,SAAS;SACV,CAAC;QACF,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAE5B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACxC,IAAI,OAAO,GAAG,UAAU,CAAC;YACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjD,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;oBAAE,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBAC7D,OAAO,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;YACrC,CAAC;YACD,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { ApolloServer, BaseContext } from "@apollo/server";
|
|
3
|
+
import { ModulesContainer } from "@nestjs/core";
|
|
4
|
+
import { AbstractGraphQLDriver } from "@nestjs/graphql";
|
|
5
|
+
import { ApolloDriverConfig } from "@nestjs/apollo";
|
|
6
|
+
import http from "http";
|
|
5
7
|
export declare class HonoGraphQLDriver<T extends Record<string, any> = ApolloDriverConfig> extends AbstractGraphQLDriver {
|
|
6
8
|
protected apolloServer: ApolloServer<BaseContext>;
|
|
7
9
|
private _subscriptionService?;
|
|
@@ -15,6 +17,7 @@ export declare class HonoGraphQLDriver<T extends Record<string, any> = ApolloDri
|
|
|
15
17
|
stop(): Promise<void>;
|
|
16
18
|
private httpHeadersToMap;
|
|
17
19
|
private parseBody;
|
|
20
|
+
headersToRecord(headers: Headers): http.IncomingHttpHeaders;
|
|
18
21
|
private logError;
|
|
19
22
|
private parseFormURL;
|
|
20
23
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { ApolloServer, HeaderMap } from
|
|
2
|
-
import { AbstractGraphQLDriver, GqlSubscriptionService, } from
|
|
3
|
-
import { ApolloServerPluginDrainHttpServer } from
|
|
4
|
-
import { Logger } from
|
|
5
|
-
import { PluginsExplorerService } from
|
|
1
|
+
import { ApolloServer, HeaderMap } from "@apollo/server";
|
|
2
|
+
import { AbstractGraphQLDriver, GqlSubscriptionService, } from "@nestjs/graphql";
|
|
3
|
+
import { ApolloServerPluginDrainHttpServer } from "@apollo/server/plugin/drainHttpServer";
|
|
4
|
+
import { Logger } from "@nestjs/common";
|
|
5
|
+
import { PluginsExplorerService } from "./services/plugins-explorer.service";
|
|
6
|
+
import { processRequest } from "./graphQLUpload";
|
|
6
7
|
export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
7
8
|
constructor(modulesContainer) {
|
|
8
9
|
super();
|
|
@@ -14,12 +15,12 @@ export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
|
14
15
|
async start(options) {
|
|
15
16
|
const { httpAdapter } = this.httpAdapterHost;
|
|
16
17
|
const platformName = httpAdapter.getType();
|
|
17
|
-
if (platformName !==
|
|
18
|
-
throw new Error(
|
|
18
|
+
if (platformName !== "hono") {
|
|
19
|
+
throw new Error("This driver is only compatible with the Hono platform");
|
|
19
20
|
}
|
|
20
21
|
await this.registerHono(options);
|
|
21
22
|
if (options.installSubscriptionHandlers || options.subscriptions) {
|
|
22
|
-
const subscriptionsOptions = options.subscriptions || {
|
|
23
|
+
const subscriptionsOptions = options.subscriptions || { "subscriptions-transport-ws": {} };
|
|
23
24
|
this._subscriptionService = new GqlSubscriptionService({
|
|
24
25
|
schema: options.schema,
|
|
25
26
|
path: options.path,
|
|
@@ -45,7 +46,7 @@ export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
|
45
46
|
});
|
|
46
47
|
await server.start();
|
|
47
48
|
app.use(path, async (ctx) => {
|
|
48
|
-
const bodyData = await this.parseBody(ctx
|
|
49
|
+
const bodyData = await this.parseBody(ctx);
|
|
49
50
|
const defaultContext = () => Promise.resolve({});
|
|
50
51
|
const contextFunction = options?.context ?? defaultContext;
|
|
51
52
|
const httpGraphQLResponse = await server.executeHTTPGraphQLRequest({
|
|
@@ -67,7 +68,7 @@ export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
|
67
68
|
ctx.header(headerKey, headerValue);
|
|
68
69
|
}
|
|
69
70
|
ctx.status(status === undefined ? 200 : status);
|
|
70
|
-
if (body.kind ===
|
|
71
|
+
if (body.kind === "complete") {
|
|
71
72
|
return ctx.body(body.string);
|
|
72
73
|
}
|
|
73
74
|
const readableStream = new ReadableStream({
|
|
@@ -79,7 +80,7 @@ export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
|
79
80
|
},
|
|
80
81
|
});
|
|
81
82
|
return new Response(readableStream, {
|
|
82
|
-
headers: {
|
|
83
|
+
headers: { "Content-Type": "application/octet-stream" },
|
|
83
84
|
});
|
|
84
85
|
});
|
|
85
86
|
this.apolloServer = server;
|
|
@@ -93,16 +94,27 @@ export class HonoGraphQLDriver extends AbstractGraphQLDriver {
|
|
|
93
94
|
headers.forEach((value, key) => map.set(key, value));
|
|
94
95
|
return map;
|
|
95
96
|
}
|
|
96
|
-
async parseBody(
|
|
97
|
-
const
|
|
98
|
-
|
|
97
|
+
async parseBody(ctx) {
|
|
98
|
+
const req = ctx.req;
|
|
99
|
+
const contentType = req.header("content-type");
|
|
100
|
+
if (contentType === "application/graphql")
|
|
99
101
|
return { query: await req.text() };
|
|
100
|
-
if (contentType ===
|
|
102
|
+
if (contentType === "application/json")
|
|
101
103
|
return req.json().catch(this.logError);
|
|
102
|
-
if (contentType ===
|
|
104
|
+
if (contentType === "application/x-www-form-urlencoded")
|
|
103
105
|
return this.parseFormURL(req);
|
|
106
|
+
if (contentType?.startsWith("multipart/form-data")) {
|
|
107
|
+
return processRequest(ctx);
|
|
108
|
+
}
|
|
104
109
|
return {};
|
|
105
110
|
}
|
|
111
|
+
headersToRecord(headers) {
|
|
112
|
+
const obj = {};
|
|
113
|
+
headers.forEach((value, key) => {
|
|
114
|
+
obj[key] = value;
|
|
115
|
+
});
|
|
116
|
+
return obj;
|
|
117
|
+
}
|
|
106
118
|
logError(e) {
|
|
107
119
|
if (e instanceof Error) {
|
|
108
120
|
Logger.error(e.stack || e.message);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"graphql.driver.js","sourceRoot":"","sources":["../../../../src/drivers/graphql.driver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAe,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"graphql.driver.js","sourceRoot":"","sources":["../../../../src/drivers/graphql.driver.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/drivers/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/drivers/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { WriteStream, Upload } from 'graphql-upload-ts';
|
|
2
|
+
import { Readable } from 'stream';
|
|
3
|
+
export async function processRequest(ctx) {
|
|
4
|
+
const body = await ctx.req.parseBody();
|
|
5
|
+
const operations = JSON.parse(body.operations);
|
|
6
|
+
const map = new Map(Object.entries(JSON.parse(body.map)));
|
|
7
|
+
for (const [fieldName, file] of Object.entries(body)) {
|
|
8
|
+
if (fieldName === 'operations' ||
|
|
9
|
+
fieldName === 'map' ||
|
|
10
|
+
!(file instanceof File))
|
|
11
|
+
continue;
|
|
12
|
+
const fileKeys = map.get(fieldName);
|
|
13
|
+
if (!Array.isArray(fileKeys) || !fileKeys.length)
|
|
14
|
+
continue;
|
|
15
|
+
const buffer = Buffer.from(await file.arrayBuffer());
|
|
16
|
+
const capacitor = new WriteStream();
|
|
17
|
+
Readable.from(buffer).pipe(capacitor);
|
|
18
|
+
const upload = new Upload();
|
|
19
|
+
upload.file = {
|
|
20
|
+
filename: file.name,
|
|
21
|
+
mimetype: file.type,
|
|
22
|
+
fieldName,
|
|
23
|
+
encoding: '7bit',
|
|
24
|
+
createReadStream: (options) => capacitor.createReadStream(options),
|
|
25
|
+
capacitor,
|
|
26
|
+
};
|
|
27
|
+
upload.resolve(upload.file);
|
|
28
|
+
for (const fileKey of fileKeys) {
|
|
29
|
+
const pathSegments = fileKey.split('.');
|
|
30
|
+
let current = operations;
|
|
31
|
+
for (let i = 0; i < pathSegments.length - 1; i++) {
|
|
32
|
+
if (!current[pathSegments[i]])
|
|
33
|
+
current[pathSegments[i]] = {};
|
|
34
|
+
current = current[pathSegments[i]];
|
|
35
|
+
}
|
|
36
|
+
current[pathSegments[pathSegments.length - 1]] = upload;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return operations;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=processRequest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processRequest.js","sourceRoot":"","sources":["../../../../../src/drivers/services/processRequest.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAElC,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAY;IAEZ,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;IACvC,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAoB,CAAC,CAAC;IACzD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAa,CAAC,CAAC,CAAC,CAAC;IAEpE,KAAK,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACrD,IACE,SAAS,KAAK,YAAY;YAC1B,SAAS,KAAK,KAAK;YACnB,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC;YAEvB,SAAS;QAEX,MAAM,QAAQ,GAAG,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,SAAS;QAE3D,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACrD,MAAM,SAAS,GAAG,IAAI,WAAW,EAAE,CAAC;QACpC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEtC,MAAM,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;QAC5B,MAAM,CAAC,IAAI,GAAG;YACZ,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,SAAS;YACT,QAAQ,EAAE,MAAM;YAChB,gBAAgB,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,CAAC;YAClE,SAAS;SACV,CAAC;QACF,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAE5B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACxC,IAAI,OAAO,GAAG,UAAU,CAAC;YACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjD,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;oBAAE,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBAC7D,OAAO,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;YACrC,CAAC;YACD,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC"}
|