@vertikalx/vtx-backend-client 1.0.0-dev.2 → 1.0.0-dev.21
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/package.json +3 -2
- package/src/api/api-call-headers.d.ts +16 -0
- package/src/api/api-call-headers.js +20 -0
- package/src/api/api-call-headers.js.map +1 -0
- package/src/api/backend-response.d.ts +4 -0
- package/src/api/backend-response.js +3 -0
- package/src/api/backend-response.js.map +1 -0
- package/src/api/response-builder.d.ts +4 -0
- package/src/api/response-builder.js +63 -0
- package/src/api/response-builder.js.map +1 -0
- package/src/api/vtx-apikey-api.d.ts +6 -0
- package/src/api/vtx-apikey-api.js +19 -0
- package/src/api/vtx-apikey-api.js.map +1 -0
- package/src/api/vtx-base-api.d.ts +23 -0
- package/src/api/vtx-base-api.js +752 -0
- package/src/api/vtx-base-api.js.map +1 -0
- package/src/api/vtx-mobile-api.d.ts +6 -0
- package/src/api/vtx-mobile-api.js +27 -0
- package/src/api/vtx-mobile-api.js.map +1 -0
- package/src/api/vtx-web-browser-api.d.ts +7 -0
- package/src/api/vtx-web-browser-api.js +36 -0
- package/src/api/vtx-web-browser-api.js.map +1 -0
- package/src/api/vtx-web-server-api.d.ts +7 -0
- package/src/api/vtx-web-server-api.js +33 -0
- package/src/api/vtx-web-server-api.js.map +1 -0
- package/src/client/index.js.map +1 -0
- package/src/client/runtime/batcher.js.map +1 -0
- package/{runtime → src/client/runtime}/createClient.d.ts +4 -10
- package/src/client/runtime/createClient.js.map +1 -0
- package/src/client/runtime/error.js.map +1 -0
- package/src/client/runtime/fetcher.js.map +1 -0
- package/{runtime → src/client/runtime}/generateGraphqlOperation.d.ts +1 -1
- package/src/client/runtime/generateGraphqlOperation.js.map +1 -0
- package/src/client/runtime/index.js.map +1 -0
- package/src/client/runtime/linkTypeMap.js.map +1 -0
- package/src/client/runtime/typeSelection.js.map +1 -0
- package/src/client/runtime/types.js.map +1 -0
- package/src/client/schema.d.ts +985 -0
- package/src/client/schema.graphql +433 -0
- package/src/client/schema.js +235 -0
- package/src/client/schema.js.map +1 -0
- package/src/client/types.d.ts +499 -0
- package/src/client/types.js +1292 -0
- package/src/client/types.js.map +1 -0
- package/src/index.d.ts +9 -0
- package/src/index.js +26 -0
- package/src/index.js.map +1 -0
- package/tsconfig.lib.tsbuildinfo +1 -1
- package/index.js.map +0 -1
- package/index.ts +0 -65
- package/runtime/batcher.js.map +0 -1
- package/runtime/batcher.ts +0 -275
- package/runtime/createClient.js.map +0 -1
- package/runtime/createClient.ts +0 -68
- package/runtime/error.js.map +0 -1
- package/runtime/error.ts +0 -29
- package/runtime/fetcher.js.map +0 -1
- package/runtime/fetcher.ts +0 -97
- package/runtime/generateGraphqlOperation.js.map +0 -1
- package/runtime/generateGraphqlOperation.ts +0 -225
- package/runtime/index.js.map +0 -1
- package/runtime/index.ts +0 -13
- package/runtime/linkTypeMap.js.map +0 -1
- package/runtime/linkTypeMap.ts +0 -156
- package/runtime/typeSelection.js.map +0 -1
- package/runtime/typeSelection.ts +0 -95
- package/runtime/types.js.map +0 -1
- package/runtime/types.ts +0 -69
- package/schema.d.ts +0 -406
- package/schema.graphql +0 -162
- package/schema.js +0 -109
- package/schema.js.map +0 -1
- package/schema.ts +0 -420
- package/types.d.ts +0 -207
- package/types.js +0 -518
- package/types.js.map +0 -1
- package/types.ts +0 -515
- /package/{index.d.ts → src/client/index.d.ts} +0 -0
- /package/{index.js → src/client/index.js} +0 -0
- /package/{runtime → src/client/runtime}/batcher.d.ts +0 -0
- /package/{runtime → src/client/runtime}/batcher.js +0 -0
- /package/{runtime → src/client/runtime}/createClient.js +0 -0
- /package/{runtime → src/client/runtime}/error.d.ts +0 -0
- /package/{runtime → src/client/runtime}/error.js +0 -0
- /package/{runtime → src/client/runtime}/fetcher.d.ts +0 -0
- /package/{runtime → src/client/runtime}/fetcher.js +0 -0
- /package/{runtime → src/client/runtime}/generateGraphqlOperation.js +0 -0
- /package/{runtime → src/client/runtime}/index.d.ts +0 -0
- /package/{runtime → src/client/runtime}/index.js +0 -0
- /package/{runtime → src/client/runtime}/linkTypeMap.d.ts +0 -0
- /package/{runtime → src/client/runtime}/linkTypeMap.js +0 -0
- /package/{runtime → src/client/runtime}/typeSelection.d.ts +0 -0
- /package/{runtime → src/client/runtime}/typeSelection.js +0 -0
- /package/{runtime → src/client/runtime}/types.d.ts +0 -0
- /package/{runtime → src/client/runtime}/types.js +0 -0
package/runtime/batcher.ts
DELETED
|
@@ -1,275 +0,0 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
|
-
import type { GraphqlOperation } from './generateGraphqlOperation'
|
|
3
|
-
import { GenqlError } from './error'
|
|
4
|
-
|
|
5
|
-
type Variables = Record<string, any>
|
|
6
|
-
|
|
7
|
-
type QueryError = Error & {
|
|
8
|
-
message: string
|
|
9
|
-
|
|
10
|
-
locations?: Array<{
|
|
11
|
-
line: number
|
|
12
|
-
column: number
|
|
13
|
-
}>
|
|
14
|
-
path?: any
|
|
15
|
-
rid: string
|
|
16
|
-
details?: Record<string, any>
|
|
17
|
-
}
|
|
18
|
-
type Result = {
|
|
19
|
-
data: Record<string, any>
|
|
20
|
-
errors: Array<QueryError>
|
|
21
|
-
}
|
|
22
|
-
type Fetcher = (
|
|
23
|
-
batchedQuery: GraphqlOperation | Array<GraphqlOperation>,
|
|
24
|
-
) => Promise<Array<Result>>
|
|
25
|
-
type Options = {
|
|
26
|
-
batchInterval?: number
|
|
27
|
-
shouldBatch?: boolean
|
|
28
|
-
maxBatchSize?: number
|
|
29
|
-
}
|
|
30
|
-
type Queue = Array<{
|
|
31
|
-
request: GraphqlOperation
|
|
32
|
-
resolve: (...args: Array<any>) => any
|
|
33
|
-
reject: (...args: Array<any>) => any
|
|
34
|
-
}>
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* takes a list of requests (queue) and batches them into a single server request.
|
|
38
|
-
* It will then resolve each individual requests promise with the appropriate data.
|
|
39
|
-
* @private
|
|
40
|
-
* @param {QueryBatcher} client - the client to use
|
|
41
|
-
* @param {Queue} queue - the list of requests to batch
|
|
42
|
-
*/
|
|
43
|
-
function dispatchQueueBatch(client: QueryBatcher, queue: Queue): void {
|
|
44
|
-
let batchedQuery: any = queue.map((item) => item.request)
|
|
45
|
-
|
|
46
|
-
if (batchedQuery.length === 1) {
|
|
47
|
-
batchedQuery = batchedQuery[0]
|
|
48
|
-
}
|
|
49
|
-
(() => {
|
|
50
|
-
try {
|
|
51
|
-
return client.fetcher(batchedQuery);
|
|
52
|
-
} catch(e) {
|
|
53
|
-
return Promise.reject(e);
|
|
54
|
-
}
|
|
55
|
-
})().then((responses: any) => {
|
|
56
|
-
if (queue.length === 1 && !Array.isArray(responses)) {
|
|
57
|
-
if (responses.errors && responses.errors.length) {
|
|
58
|
-
queue[0].reject(
|
|
59
|
-
new GenqlError(responses.errors, responses.data),
|
|
60
|
-
)
|
|
61
|
-
return
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
queue[0].resolve(responses)
|
|
65
|
-
return
|
|
66
|
-
} else if (responses.length !== queue.length) {
|
|
67
|
-
throw new Error('response length did not match query length')
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
for (let i = 0; i < queue.length; i++) {
|
|
71
|
-
if (responses[i].errors && responses[i].errors.length) {
|
|
72
|
-
queue[i].reject(
|
|
73
|
-
new GenqlError(responses[i].errors, responses[i].data),
|
|
74
|
-
)
|
|
75
|
-
} else {
|
|
76
|
-
queue[i].resolve(responses[i])
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
})
|
|
80
|
-
.catch((e) => {
|
|
81
|
-
for (let i = 0; i < queue.length; i++) {
|
|
82
|
-
queue[i].reject(e)
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* creates a list of requests to batch according to max batch size.
|
|
89
|
-
* @private
|
|
90
|
-
* @param {QueryBatcher} client - the client to create list of requests from from
|
|
91
|
-
* @param {Options} options - the options for the batch
|
|
92
|
-
*/
|
|
93
|
-
function dispatchQueue(client: QueryBatcher, options: Options): void {
|
|
94
|
-
const queue = client._queue
|
|
95
|
-
const maxBatchSize = options.maxBatchSize || 0
|
|
96
|
-
client._queue = []
|
|
97
|
-
|
|
98
|
-
if (maxBatchSize > 0 && maxBatchSize < queue.length) {
|
|
99
|
-
for (let i = 0; i < queue.length / maxBatchSize; i++) {
|
|
100
|
-
dispatchQueueBatch(
|
|
101
|
-
client,
|
|
102
|
-
queue.slice(i * maxBatchSize, (i + 1) * maxBatchSize),
|
|
103
|
-
)
|
|
104
|
-
}
|
|
105
|
-
} else {
|
|
106
|
-
dispatchQueueBatch(client, queue)
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Create a batcher client.
|
|
111
|
-
* @param {Fetcher} fetcher - A function that can handle the network requests to graphql endpoint
|
|
112
|
-
* @param {Options} options - the options to be used by client
|
|
113
|
-
* @param {boolean} options.shouldBatch - should the client batch requests. (default true)
|
|
114
|
-
* @param {integer} options.batchInterval - duration (in MS) of each batch window. (default 6)
|
|
115
|
-
* @param {integer} options.maxBatchSize - max number of requests in a batch. (default 0)
|
|
116
|
-
* @param {boolean} options.defaultHeaders - default headers to include with every request
|
|
117
|
-
*
|
|
118
|
-
* @example
|
|
119
|
-
* const fetcher = batchedQuery => fetch('path/to/graphql', {
|
|
120
|
-
* method: 'post',
|
|
121
|
-
* headers: {
|
|
122
|
-
* Accept: 'application/json',
|
|
123
|
-
* 'Content-Type': 'application/json',
|
|
124
|
-
* },
|
|
125
|
-
* body: JSON.stringify(batchedQuery),
|
|
126
|
-
* credentials: 'include',
|
|
127
|
-
* })
|
|
128
|
-
* .then(response => response.json())
|
|
129
|
-
*
|
|
130
|
-
* const client = new QueryBatcher(fetcher, { maxBatchSize: 10 })
|
|
131
|
-
*/
|
|
132
|
-
|
|
133
|
-
export class QueryBatcher {
|
|
134
|
-
fetcher: Fetcher
|
|
135
|
-
_options: Options
|
|
136
|
-
_queue: Queue
|
|
137
|
-
|
|
138
|
-
constructor(
|
|
139
|
-
fetcher: Fetcher,
|
|
140
|
-
{
|
|
141
|
-
batchInterval = 6,
|
|
142
|
-
shouldBatch = true,
|
|
143
|
-
maxBatchSize = 0,
|
|
144
|
-
}: Options = {},
|
|
145
|
-
) {
|
|
146
|
-
this.fetcher = fetcher
|
|
147
|
-
this._options = {
|
|
148
|
-
batchInterval,
|
|
149
|
-
shouldBatch,
|
|
150
|
-
maxBatchSize,
|
|
151
|
-
}
|
|
152
|
-
this._queue = []
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
/**
|
|
156
|
-
* Fetch will send a graphql request and return the parsed json.
|
|
157
|
-
* @param {string} query - the graphql query.
|
|
158
|
-
* @param {Variables} variables - any variables you wish to inject as key/value pairs.
|
|
159
|
-
* @param {[string]} operationName - the graphql operationName.
|
|
160
|
-
* @param {Options} overrides - the client options overrides.
|
|
161
|
-
*
|
|
162
|
-
* @return {promise} resolves to parsed json of server response
|
|
163
|
-
*
|
|
164
|
-
* @example
|
|
165
|
-
* client.fetch(`
|
|
166
|
-
* query getHuman($id: ID!) {
|
|
167
|
-
* human(id: $id) {
|
|
168
|
-
* name
|
|
169
|
-
* height
|
|
170
|
-
* }
|
|
171
|
-
* }
|
|
172
|
-
* `, { id: "1001" }, 'getHuman')
|
|
173
|
-
* .then(human => {
|
|
174
|
-
* // do something with human
|
|
175
|
-
* console.log(human);
|
|
176
|
-
* });
|
|
177
|
-
*/
|
|
178
|
-
fetch(
|
|
179
|
-
query: string,
|
|
180
|
-
variables?: Variables,
|
|
181
|
-
operationName?: string,
|
|
182
|
-
overrides: Options = {},
|
|
183
|
-
): Promise<Result> {
|
|
184
|
-
const request: GraphqlOperation = {
|
|
185
|
-
query,
|
|
186
|
-
}
|
|
187
|
-
const options = Object.assign({}, this._options, overrides)
|
|
188
|
-
|
|
189
|
-
if (variables) {
|
|
190
|
-
request.variables = variables
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
if (operationName) {
|
|
194
|
-
request.operationName = operationName
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
const promise = new Promise<Result>((resolve, reject) => {
|
|
198
|
-
this._queue.push({
|
|
199
|
-
request,
|
|
200
|
-
resolve,
|
|
201
|
-
reject,
|
|
202
|
-
})
|
|
203
|
-
|
|
204
|
-
if (this._queue.length === 1) {
|
|
205
|
-
if (options.shouldBatch) {
|
|
206
|
-
setTimeout(
|
|
207
|
-
() => dispatchQueue(this, options),
|
|
208
|
-
options.batchInterval,
|
|
209
|
-
)
|
|
210
|
-
} else {
|
|
211
|
-
dispatchQueue(this, options)
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
})
|
|
215
|
-
return promise
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
/**
|
|
219
|
-
* Fetch will send a graphql request and return the parsed json.
|
|
220
|
-
* @param {string} query - the graphql query.
|
|
221
|
-
* @param {Variables} variables - any variables you wish to inject as key/value pairs.
|
|
222
|
-
* @param {[string]} operationName - the graphql operationName.
|
|
223
|
-
* @param {Options} overrides - the client options overrides.
|
|
224
|
-
*
|
|
225
|
-
* @return {Promise<Array<Result>>} resolves to parsed json of server response
|
|
226
|
-
*
|
|
227
|
-
* @example
|
|
228
|
-
* client.forceFetch(`
|
|
229
|
-
* query getHuman($id: ID!) {
|
|
230
|
-
* human(id: $id) {
|
|
231
|
-
* name
|
|
232
|
-
* height
|
|
233
|
-
* }
|
|
234
|
-
* }
|
|
235
|
-
* `, { id: "1001" }, 'getHuman')
|
|
236
|
-
* .then(human => {
|
|
237
|
-
* // do something with human
|
|
238
|
-
* console.log(human);
|
|
239
|
-
* });
|
|
240
|
-
*/
|
|
241
|
-
forceFetch(
|
|
242
|
-
query: string,
|
|
243
|
-
variables?: Variables,
|
|
244
|
-
operationName?: string,
|
|
245
|
-
overrides: Options = {},
|
|
246
|
-
): Promise<Result> {
|
|
247
|
-
const request: GraphqlOperation = {
|
|
248
|
-
query,
|
|
249
|
-
}
|
|
250
|
-
const options = Object.assign({}, this._options, overrides, {
|
|
251
|
-
shouldBatch: false,
|
|
252
|
-
})
|
|
253
|
-
|
|
254
|
-
if (variables) {
|
|
255
|
-
request.variables = variables
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
if (operationName) {
|
|
259
|
-
request.operationName = operationName
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
const promise = new Promise<Result>((resolve, reject) => {
|
|
263
|
-
const client = new QueryBatcher(this.fetcher, this._options)
|
|
264
|
-
client._queue = [
|
|
265
|
-
{
|
|
266
|
-
request,
|
|
267
|
-
resolve,
|
|
268
|
-
reject,
|
|
269
|
-
},
|
|
270
|
-
]
|
|
271
|
-
dispatchQueue(client, options)
|
|
272
|
-
})
|
|
273
|
-
return promise
|
|
274
|
-
}
|
|
275
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createClient.js","sourceRoot":"","sources":["../../../../libs/vtx-backend-client/runtime/createClient.ts"],"names":[],"mappings":";;;AAEA,uCAA6D;AAE7D,yEAGmC;AAmB5B,MAAM,YAAY,GAAG,CAAC,EACzB,SAAS,EACT,YAAY,EACZ,gBAAgB,EAChB,GAAG,OAAO,EAKb,EAAE,EAAE;IACD,MAAM,OAAO,GAAG,IAAA,uBAAa,EAAC,OAAO,CAAC,CAAA;IACtC,MAAM,MAAM,GAGR,EAAE,CAAA;IAEN,IAAI,SAAS,EAAE,CAAC;QACZ,MAAM,CAAC,KAAK,GAAG,CAAC,OAAY,EAAE,EAAE;YAC5B,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;YAEhE,MAAM,aAAa,GAAG,OAAO,CACzB,IAAA,mDAAwB,EAAC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,CACxD,CAAA;YAED,OAAO,aAAa,CAAA;QACxB,CAAC,CAAA;IACL,CAAC;IACD,IAAI,YAAY,EAAE,CAAC;QACf,MAAM,CAAC,QAAQ,GAAG,CAAC,OAAY,EAAE,EAAE;YAC/B,IAAI,CAAC,YAAY;gBACb,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAA;YAEvD,MAAM,aAAa,GAAG,OAAO,CACzB,IAAA,mDAAwB,EAAC,UAAU,EAAE,YAAY,EAAE,OAAO,CAAC,CAC9D,CAAA;YAED,OAAO,aAAa,CAAA;QACxB,CAAC,CAAA;IACL,CAAC;IAED,OAAO,MAAa,CAAA;AACxB,CAAC,CAAA;AAzCY,QAAA,YAAY,gBAyCxB"}
|
package/runtime/createClient.ts
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
|
-
|
|
3
|
-
import { type BatchOptions, createFetcher } from './fetcher'
|
|
4
|
-
import type { ExecutionResult, LinkedType } from './types'
|
|
5
|
-
import {
|
|
6
|
-
generateGraphqlOperation,
|
|
7
|
-
type GraphqlOperation,
|
|
8
|
-
} from './generateGraphqlOperation'
|
|
9
|
-
|
|
10
|
-
export type Headers =
|
|
11
|
-
| HeadersInit
|
|
12
|
-
| (() => HeadersInit)
|
|
13
|
-
| (() => Promise<HeadersInit>)
|
|
14
|
-
|
|
15
|
-
export type BaseFetcher = (
|
|
16
|
-
operation: GraphqlOperation | GraphqlOperation[],
|
|
17
|
-
) => Promise<ExecutionResult | ExecutionResult[]>
|
|
18
|
-
|
|
19
|
-
export type ClientOptions = Omit<RequestInit, 'body' | 'headers'> & {
|
|
20
|
-
url?: string
|
|
21
|
-
batch?: BatchOptions | boolean
|
|
22
|
-
fetcher?: BaseFetcher
|
|
23
|
-
fetch?: Function
|
|
24
|
-
headers?: Headers
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
export const createClient = ({
|
|
28
|
-
queryRoot,
|
|
29
|
-
mutationRoot,
|
|
30
|
-
subscriptionRoot,
|
|
31
|
-
...options
|
|
32
|
-
}: ClientOptions & {
|
|
33
|
-
queryRoot?: LinkedType
|
|
34
|
-
mutationRoot?: LinkedType
|
|
35
|
-
subscriptionRoot?: LinkedType
|
|
36
|
-
}) => {
|
|
37
|
-
const fetcher = createFetcher(options)
|
|
38
|
-
const client: {
|
|
39
|
-
query?: Function
|
|
40
|
-
mutation?: Function
|
|
41
|
-
} = {}
|
|
42
|
-
|
|
43
|
-
if (queryRoot) {
|
|
44
|
-
client.query = (request: any) => {
|
|
45
|
-
if (!queryRoot) throw new Error('queryRoot argument is missing')
|
|
46
|
-
|
|
47
|
-
const resultPromise = fetcher(
|
|
48
|
-
generateGraphqlOperation('query', queryRoot, request),
|
|
49
|
-
)
|
|
50
|
-
|
|
51
|
-
return resultPromise
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
if (mutationRoot) {
|
|
55
|
-
client.mutation = (request: any) => {
|
|
56
|
-
if (!mutationRoot)
|
|
57
|
-
throw new Error('mutationRoot argument is missing')
|
|
58
|
-
|
|
59
|
-
const resultPromise = fetcher(
|
|
60
|
-
generateGraphqlOperation('mutation', mutationRoot, request),
|
|
61
|
-
)
|
|
62
|
-
|
|
63
|
-
return resultPromise
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
return client as any
|
|
68
|
-
}
|
package/runtime/error.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../../../libs/vtx-backend-client/runtime/error.ts"],"names":[],"mappings":";;;AACA,MAAa,UAAW,SAAQ,KAAK;IAMjC,YAAY,MAAa,EAAE,IAAS;QAChC,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YAC/B,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;YAChD,CAAC,CAAC,EAAE,CAAA;QACR,IAAI,CAAC,OAAO,EAAE,CAAC;YACX,OAAO,GAAG,eAAe,CAAA;QAC7B,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,CAAA;QAZlB,WAAM,GAAwB,EAAE,CAAA;QAa5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;IACpB,CAAC;CACJ;AAjBD,gCAiBC"}
|
package/runtime/error.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
|
-
export class GenqlError extends Error {
|
|
3
|
-
errors: Array<GraphqlError> = []
|
|
4
|
-
/**
|
|
5
|
-
* Partial data returned by the server
|
|
6
|
-
*/
|
|
7
|
-
data?: any
|
|
8
|
-
constructor(errors: any[], data: any) {
|
|
9
|
-
let message = Array.isArray(errors)
|
|
10
|
-
? errors.map((x) => x?.message || '').join('\n')
|
|
11
|
-
: ''
|
|
12
|
-
if (!message) {
|
|
13
|
-
message = 'GraphQL error'
|
|
14
|
-
}
|
|
15
|
-
super(message)
|
|
16
|
-
this.errors = errors
|
|
17
|
-
this.data = data
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
interface GraphqlError {
|
|
22
|
-
message: string
|
|
23
|
-
locations?: Array<{
|
|
24
|
-
line: number
|
|
25
|
-
column: number
|
|
26
|
-
}>
|
|
27
|
-
path?: string[]
|
|
28
|
-
extensions?: Record<string, any>
|
|
29
|
-
}
|
package/runtime/fetcher.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fetcher.js","sourceRoot":"","sources":["../../../../libs/vtx-backend-client/runtime/fetcher.ts"],"names":[],"mappings":"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"}
|
package/runtime/fetcher.ts
DELETED
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
|
-
import { QueryBatcher } from './batcher'
|
|
3
|
-
|
|
4
|
-
import type { ClientOptions } from './createClient'
|
|
5
|
-
import type { GraphqlOperation } from './generateGraphqlOperation'
|
|
6
|
-
import { GenqlError } from './error'
|
|
7
|
-
|
|
8
|
-
export interface Fetcher {
|
|
9
|
-
(gql: GraphqlOperation): Promise<any>
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export type BatchOptions = {
|
|
13
|
-
batchInterval?: number // ms
|
|
14
|
-
maxBatchSize?: number
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const DEFAULT_BATCH_OPTIONS = {
|
|
18
|
-
maxBatchSize: 10,
|
|
19
|
-
batchInterval: 40,
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export const createFetcher = ({
|
|
23
|
-
url,
|
|
24
|
-
headers = {},
|
|
25
|
-
fetcher,
|
|
26
|
-
fetch: _fetch,
|
|
27
|
-
batch = false,
|
|
28
|
-
...rest
|
|
29
|
-
}: ClientOptions): Fetcher => {
|
|
30
|
-
if (!url && !fetcher) {
|
|
31
|
-
throw new Error('url or fetcher is required')
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
fetcher = fetcher || (async (body) => {
|
|
35
|
-
let headersObject =
|
|
36
|
-
typeof headers == 'function' ? await headers() : headers
|
|
37
|
-
headersObject = headersObject || {}
|
|
38
|
-
if (typeof fetch === 'undefined' && !_fetch) {
|
|
39
|
-
throw new Error(
|
|
40
|
-
'Global `fetch` function is not available, pass a fetch polyfill to Genql `createClient`',
|
|
41
|
-
)
|
|
42
|
-
}
|
|
43
|
-
let fetchImpl = _fetch || fetch
|
|
44
|
-
const res = await fetchImpl(url!, {
|
|
45
|
-
headers: {
|
|
46
|
-
'Content-Type': 'application/json',
|
|
47
|
-
...headersObject,
|
|
48
|
-
},
|
|
49
|
-
method: 'POST',
|
|
50
|
-
body: JSON.stringify(body),
|
|
51
|
-
...rest,
|
|
52
|
-
})
|
|
53
|
-
if (!res.ok) {
|
|
54
|
-
throw new Error(`${res.statusText}: ${await res.text()}`)
|
|
55
|
-
}
|
|
56
|
-
const json = await res.json()
|
|
57
|
-
return json
|
|
58
|
-
})
|
|
59
|
-
|
|
60
|
-
if (!batch) {
|
|
61
|
-
return async (body) => {
|
|
62
|
-
const json = await fetcher!(body)
|
|
63
|
-
if (Array.isArray(json)) {
|
|
64
|
-
return json.map((json) => {
|
|
65
|
-
if (json?.errors?.length) {
|
|
66
|
-
throw new GenqlError(json.errors || [], json.data)
|
|
67
|
-
}
|
|
68
|
-
return json.data
|
|
69
|
-
})
|
|
70
|
-
} else {
|
|
71
|
-
if (json?.errors?.length) {
|
|
72
|
-
throw new GenqlError(json.errors || [], json.data)
|
|
73
|
-
}
|
|
74
|
-
return json.data
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
const batcher = new QueryBatcher(
|
|
80
|
-
async (batchedQuery) => {
|
|
81
|
-
// console.log(batchedQuery) // [{ query: 'query{user{age}}', variables: {} }, ...]
|
|
82
|
-
const json = await fetcher!(batchedQuery)
|
|
83
|
-
return json as any
|
|
84
|
-
},
|
|
85
|
-
batch === true ? DEFAULT_BATCH_OPTIONS : batch,
|
|
86
|
-
)
|
|
87
|
-
|
|
88
|
-
return async ({ query, variables }) => {
|
|
89
|
-
const json = await batcher.fetch(query, variables)
|
|
90
|
-
if (json?.data) {
|
|
91
|
-
return json.data
|
|
92
|
-
}
|
|
93
|
-
throw new Error(
|
|
94
|
-
'Genql batch fetcher returned unexpected result ' + JSON.stringify(json),
|
|
95
|
-
)
|
|
96
|
-
}
|
|
97
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generateGraphqlOperation.js","sourceRoot":"","sources":["../../../../libs/vtx-backend-client/runtime/generateGraphqlOperation.ts"],"names":[],"mappings":";;;AAkCA,MAAM,YAAY,GAAG,CACjB,OAA4B,EAC5B,GAAY,EACZ,IAAc,EACR,EAAE;IACR,IAAI,OAAO,OAAO,KAAK,QAAQ,IAAI,QAAQ,IAAI,OAAO,EAAE,CAAC;QACrD,MAAM,IAAI,GAAQ,OAAO,CAAC,MAAM,CAAA;QAChC,IAAI,MAAM,GAAwB,EAAE,GAAG,OAAO,EAAE,CAAA;QAChD,OAAO,MAAM,CAAC,MAAM,CAAA;QACpB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAElC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,OAAO,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,CAAA;QAC1C,CAAC;QAED,MAAM,KAAK,GAAG,IAAA,wBAAgB,EAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;QAE9C,MAAM,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACxC,GAAG,CAAC,UAAU,EAAE,CAAA;YAChB,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,UAAU,EAAE,CAAA;YAEpC,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YAEhD,IAAI,CAAC,MAAM,EAAE,CAAC;gBACV,MAAM,IAAI,KAAK,CACX,oCAAoC,OAAO,gBAAgB,IAAI,CAAC,IAAI,CAChE,GAAG,CACN,IAAI,CACR,CAAA;YACL,CAAC;YAED,GAAG,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG;gBACrB,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC;gBACpB,MAAM;aACT,CAAA;YAED,OAAO,GAAG,OAAO,KAAK,OAAO,EAAE,CAAA;QACnC,CAAC,CAAC,CAAA;QACF,OAAO,IAAI,UAAU,IAAI,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,CAAA;IAC9D,CAAC;SAAM,IAAI,OAAO,OAAO,KAAK,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxE,MAAM,MAAM,GAAG,OAAO,CAAA;QACtB,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAExE,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CACX,wCAAwC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAC3D,CAAA;QACL,CAAC;QAED,MAAM,IAAI,GACN,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAA,wBAAgB,EAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAA;QACtE,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAA;QAEhC,IAAI,oBAAwC,CAAA;QAE5C,IAAI,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAClC,MAAM,eAAe,GAAG,IAAI,GAAG,CAC3B,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CACzD,CAAA;YACD,IAAI,YAAY,EAAE,MAAM,EAAE,CAAC;gBACvB,GAAG,CAAC,eAAe,EAAE,CAAA;gBACrB,oBAAoB,GAAG,IAAI,GAAG,CAAC,eAAe,EAAE,CAAA;gBAEhD,GAAG,CAAC,SAAS,CAAC,IAAI,CACd,YAAY,oBAAoB,OAC5B,IAAI,CAAC,IACT,IAAI,YAAY;qBACX,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;qBACtC,IAAI,CAAC,GAAG,CAAC,GAAG,CACpB,CAAA;YACL,CAAC;QACL,CAAC;QAED,MAAM,eAAe,GAAG,UAAU;aAC7B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;aAClD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACP,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YAEzD,IAAI,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,GAAG,CAAC,eAAe,EAAE,CAAA;gBACrB,MAAM,sBAAsB,GAAG,IAAI,GAAG,CAAC,eAAe,EAAE,CAAA;gBAExD,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;gBAErC,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;oBAC3B,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAA;gBAEnC,GAAG,CAAC,SAAS,CAAC,IAAI,CACd,YAAY,sBAAsB,OAAO,SAAS,CAAC,CAAC,CAAC,GAAG,MAAM,EAAE,CACnE,CAAA;gBAED,OAAO,MAAM,sBAAsB,EAAE,CAAA;YACzC,CAAC;iBAAM,CAAC;gBACJ,OAAO,GAAG,CAAC,GAAG,MAAM,EAAE,CAAA;YAC1B,CAAC;QACL,CAAC,CAAC;aACD,MAAM,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,MAAM,oBAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;aAClE,IAAI,CAAC,GAAG,CAAC,CAAA;QAEd,OAAO,IAAI,eAAe,GAAG,CAAA;IACjC,CAAC;SAAM,CAAC;QACJ,OAAO,EAAE,CAAA;IACb,CAAC;AACL,CAAC,CAAA;AAEM,MAAM,wBAAwB,GAAG,CACpC,SAAgD,EAChD,IAAgB,EAChB,MAAe,EACC,EAAE;IAClB,MAAM,GAAG,GAAY;QACjB,IAAI,EAAE,IAAI;QACV,UAAU,EAAE,CAAC;QACb,SAAS,EAAE,EAAE;QACb,eAAe,EAAE,CAAC;QAClB,SAAS,EAAE,EAAE;KAChB,CAAA;IACD,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAA;IAE5C,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IAE3C,MAAM,UAAU,GACZ,QAAQ,CAAC,MAAM,GAAG,CAAC;QACf,CAAC,CAAC,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACnB,MAAM,YAAY,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;YAC/C,OAAO,IAAI,CAAC,IAAI,YAAY,EAAE,CAAA;QAClC,CAAC,CAAC,GAAG;QACP,CAAC,CAAC,EAAE,CAAA;IAEZ,MAAM,aAAa,GAAG,MAAM,EAAE,MAAM,IAAI,EAAE,CAAA;IAE1C,OAAO;QACH,KAAK,EAAE;YACH,GAAG,SAAS,IAAI,aAAa,GAAG,UAAU,GAAG,MAAM,EAAE;YACrD,GAAG,GAAG,CAAC,SAAS;SACnB,CAAC,IAAI,CAAC,GAAG,CAAC;QACX,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,MAAM,CACxC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACL,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;YAC7B,OAAO,CAAC,CAAA;QACZ,CAAC,EACD,EAAE,CACL;QACD,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,aAAa,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACxE,CAAA;AACL,CAAC,CAAA;AAxCY,QAAA,wBAAwB,4BAwCpC;AAEM,MAAM,gBAAgB,GAAG,CAC5B,IAA4B,EAC5B,IAAc,EAChB,EAAE;IACA,IAAI,OAAgC,CAAA;IAEpC,IAAI,CAAC,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;IAEvD,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;IAEvD,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;QACf,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAE1C,IAAI,CAAC,IAAI,CAAC,MAAM;YACZ,MAAM,IAAI,KAAK,CAAC,UAAU,IAAI,CAAC,IAAI,yBAAyB,CAAC,CAAA;QAEjE,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;aACzC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;aAClC,MAAM,CACH,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;YACjB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YACnD,IAAI,KAAK;gBAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YACjC,OAAO,KAAK,CAAA;QAChB,CAAC,EACD,CAAC,IAAI,CAAC,CACT,CAAA;QAEL,IAAI,KAAK,GAAuB,IAAI,CAAA;QAEpC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;YAC3C,IAAI,KAAK;gBAAE,KAAK,GAAG,KAAK,CAAA;QAC5B,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,KAAK;YACN,MAAM,IAAI,KAAK,CACX,UAAU,IAAI,CAAC,IAAI,8BAA8B,CAAC,IAAI,CACzD,CAAA;QAEL,OAAO,GAAG,KAAK,CAAA;IACnB,CAAC,CAAC,CAAA;IAEF,OAAO,OAAsB,CAAA;AACjC,CAAC,CAAA;AA3CY,QAAA,gBAAgB,oBA2C5B"}
|