@balena/pinejs 20.1.0-build-large-file-uploads-2-982761fe0158fb7be40429355c602a7d0fa49a91-1 → 21.0.0-build-21-x-658ee19ce50a7abb157362062f95f9c0ec721330-1
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/.pinejs-cache.json +1 -1
- package/.versionbot/CHANGELOG.yml +323 -17
- package/CHANGELOG.md +77 -5
- package/VERSION +1 -1
- package/build/browser.cts +0 -1
- package/build/module.cts +0 -1
- package/build/server.cts +0 -1
- package/out/config-loader/env.d.ts +0 -5
- package/out/config-loader/env.js +0 -7
- package/out/config-loader/env.js.map +1 -1
- package/out/migrator/async.js +6 -7
- package/out/migrator/async.js.map +1 -1
- package/out/sbvr-api/abstract-sql.js +19 -11
- package/out/sbvr-api/abstract-sql.js.map +1 -1
- package/out/sbvr-api/sbvr-utils.d.ts +0 -10
- package/out/sbvr-api/sbvr-utils.js +7 -48
- package/out/sbvr-api/sbvr-utils.js.map +1 -1
- package/out/sbvr-api/translations.js +4 -17
- package/out/sbvr-api/translations.js.map +1 -1
- package/out/sbvr-api/uri-parser.d.ts +7 -1
- package/out/sbvr-api/uri-parser.js +0 -2
- package/out/sbvr-api/uri-parser.js.map +1 -1
- package/out/server-glue/module.js +1 -13
- package/out/server-glue/module.js.map +1 -1
- package/out/tasks/worker.js +1 -0
- package/out/tasks/worker.js.map +1 -1
- package/out/webresource-handler/index.d.ts +0 -42
- package/out/webresource-handler/index.js +1 -24
- package/out/webresource-handler/index.js.map +1 -1
- package/package.json +30 -30
- package/src/config-loader/env.ts +0 -14
- package/src/migrator/async.ts +20 -21
- package/src/sbvr-api/abstract-sql.ts +30 -25
- package/src/sbvr-api/sbvr-utils.ts +9 -58
- package/src/sbvr-api/translations.ts +5 -18
- package/src/sbvr-api/uri-parser.ts +11 -4
- package/src/server-glue/module.ts +1 -15
- package/src/tasks/worker.ts +3 -0
- package/src/webresource-handler/index.ts +0 -85
- package/out/data-server/sbvr-server.d.ts +0 -17
- package/out/data-server/sbvr-server.js +0 -350
- package/out/data-server/sbvr-server.js.map +0 -1
- package/out/http-transactions/transaction.sbvr +0 -59
- package/out/http-transactions/transactions.d.ts +0 -3
- package/out/http-transactions/transactions.js +0 -305
- package/out/http-transactions/transactions.js.map +0 -1
- package/out/webresource-handler/multipartUpload.d.ts +0 -12
- package/out/webresource-handler/multipartUpload.js +0 -257
- package/out/webresource-handler/multipartUpload.js.map +0 -1
- package/out/webresource-handler/webresource.d.ts +0 -42
- package/out/webresource-handler/webresource.js +0 -2
- package/out/webresource-handler/webresource.js.map +0 -1
- package/out/webresource-handler/webresource.sbvr +0 -60
- package/src/data-server/sbvr-server.ts +0 -412
- package/src/http-transactions/transaction.sbvr +0 -59
- package/src/http-transactions/transactions.js +0 -305
- package/src/webresource-handler/multipartUpload.ts +0 -377
- package/src/webresource-handler/webresource.sbvr +0 -60
- package/src/webresource-handler/webresource.ts +0 -48
@@ -1,305 +0,0 @@
|
|
1
|
-
import { odataNameToSqlName } from '@balena/odata-to-abstract-sql';
|
2
|
-
import { importSBVR } from '../server-glue/sbvr-loader.js';
|
3
|
-
const transactionModel = await importSBVR('./transaction.sbvr', import.meta);
|
4
|
-
|
5
|
-
/** @type {import('../config-loader/config-loader.js').Config} */
|
6
|
-
export const config = {
|
7
|
-
models: [
|
8
|
-
{
|
9
|
-
apiRoot: 'transaction',
|
10
|
-
modelText: transactionModel,
|
11
|
-
customServerCode: { setup },
|
12
|
-
migrations: {
|
13
|
-
'11.0.0-modified-at': `\
|
14
|
-
ALTER TABLE "conditional field"
|
15
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;
|
16
|
-
ALTER TABLE "conditional resource"
|
17
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;
|
18
|
-
ALTER TABLE "lock"
|
19
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;
|
20
|
-
ALTER TABLE "resource"
|
21
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;
|
22
|
-
ALTER TABLE "resource-is under-lock"
|
23
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;
|
24
|
-
ALTER TABLE "transaction"
|
25
|
-
ADD COLUMN IF NOT EXISTS "modified at" TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL;\
|
26
|
-
`,
|
27
|
-
'15.0.0-data-types': async (tx, sbvrUtils) => {
|
28
|
-
switch (sbvrUtils.db.engine) {
|
29
|
-
case 'mysql':
|
30
|
-
await tx.executeSql(`\
|
31
|
-
ALTER TABLE "lock"
|
32
|
-
MODIFY "is exclusive" BOOLEAN NOT NULL,
|
33
|
-
MODIFY "is under lock" BOOLEAN NOT NULL;`);
|
34
|
-
break;
|
35
|
-
case 'postgres':
|
36
|
-
await tx.executeSql(`\
|
37
|
-
ALTER TABLE "lock"
|
38
|
-
ALTER COLUMN "is exclusive" DROP DEFAULT,
|
39
|
-
ALTER COLUMN "is exclusive" SET DATA TYPE BOOLEAN USING "is exclusive"::BOOLEAN,
|
40
|
-
ALTER COLUMN "is exclusive" SET DEFAULT FALSE,
|
41
|
-
ALTER COLUMN "is under lock" DROP DEFAULT,
|
42
|
-
ALTER COLUMN "is under lock" SET DATA TYPE BOOLEAN USING "is under lock"::BOOLEAN,
|
43
|
-
ALTER COLUMN "is under lock" SET DEFAULT FALSE;`);
|
44
|
-
break;
|
45
|
-
// No need to migrate for websql
|
46
|
-
}
|
47
|
-
},
|
48
|
-
},
|
49
|
-
},
|
50
|
-
],
|
51
|
-
};
|
52
|
-
|
53
|
-
/** @type {(modelName: string) => void} */
|
54
|
-
export let addModelHooks;
|
55
|
-
|
56
|
-
/** @type { import('../config-loader/config-loader.js').SetupFunction } */
|
57
|
-
export function setup(app, sbvrUtils) {
|
58
|
-
addModelHooks = (modelName) => {
|
59
|
-
// TODO: Add checks on POST/PATCH requests as well.
|
60
|
-
sbvrUtils.addPureHook('PUT', modelName, 'all', {
|
61
|
-
async PRERUN({ tx, request }) {
|
62
|
-
const vocab = request.vocabulary;
|
63
|
-
const log = sbvrUtils.logger[vocab];
|
64
|
-
const id = sbvrUtils.getID(vocab, request);
|
65
|
-
let result;
|
66
|
-
try {
|
67
|
-
result = await tx.executeSql(
|
68
|
-
`\
|
69
|
-
SELECT NOT EXISTS(
|
70
|
-
SELECT 1
|
71
|
-
FROM "resource" r
|
72
|
-
JOIN "resource-is under-lock" AS rl ON rl."resource" = r."id"
|
73
|
-
WHERE r."resource type" = ?
|
74
|
-
AND r."resource id" = ?
|
75
|
-
) AS result;`,
|
76
|
-
[request.resourceName, id],
|
77
|
-
);
|
78
|
-
} catch (/** @type any */ err) {
|
79
|
-
log.error('Unable to check resource locks', err);
|
80
|
-
throw new Error('Unable to check resource locks');
|
81
|
-
}
|
82
|
-
if ([false, 0, '0'].includes(result.rows[0].result)) {
|
83
|
-
throw new Error('The resource is locked and cannot be edited');
|
84
|
-
}
|
85
|
-
},
|
86
|
-
});
|
87
|
-
|
88
|
-
const endTransaction = (/** @type {number} */ transactionID) =>
|
89
|
-
sbvrUtils.db.transaction(async (tx) => {
|
90
|
-
/** @type {{[key: string]: { promise: Promise<any>, resolve: Function, reject: Function }}} */
|
91
|
-
const placeholders = {};
|
92
|
-
const getLockedRow = (
|
93
|
-
/** @type {number} */ lockID, // 'GET', '/transaction/resource?$select=resource_id&$filter=resource__is_under__lock/lock eq ?'
|
94
|
-
) =>
|
95
|
-
tx.executeSql(
|
96
|
-
`SELECT "resource"."resource id" AS "resource_id"
|
97
|
-
FROM "resource",
|
98
|
-
"resource-is under-lock"
|
99
|
-
WHERE "resource"."id" = "resource-is under-lock"."resource"
|
100
|
-
AND "resource-is under-lock"."lock" = ?;`,
|
101
|
-
[lockID],
|
102
|
-
);
|
103
|
-
const getFieldsObject = async (
|
104
|
-
/** @type {number} */ conditionalResourceID,
|
105
|
-
/** @type {import('@balena/abstract-sql-compiler').AbstractSqlTable} */ clientModel, // 'GET', '/transaction/conditional_field?$select=field_name,field_value&$filter=conditional_resource eq ?'
|
106
|
-
) => {
|
107
|
-
const fields = await tx.executeSql(
|
108
|
-
`SELECT "conditional field"."field name" AS "field_name", "conditional field"."field value" AS "field_value"
|
109
|
-
FROM "conditional field"
|
110
|
-
WHERE "conditional field"."conditional resource" = ?;`,
|
111
|
-
[conditionalResourceID],
|
112
|
-
);
|
113
|
-
/** @type {{[key: string]: any}} */
|
114
|
-
const fieldsObject = {};
|
115
|
-
await Promise.all(
|
116
|
-
fields.rows.map(async (field) => {
|
117
|
-
const fieldName = field.field_name.replace(
|
118
|
-
clientModel.resourceName + '.',
|
119
|
-
'',
|
120
|
-
);
|
121
|
-
const fieldValue = field.field_value;
|
122
|
-
const modelField = clientModel.fields.find(
|
123
|
-
(f) => f.fieldName === fieldName,
|
124
|
-
);
|
125
|
-
if (modelField == null) {
|
126
|
-
throw new Error(`Invalid field: ${fieldName}`);
|
127
|
-
}
|
128
|
-
if (
|
129
|
-
modelField.dataType === 'ForeignKey' &&
|
130
|
-
Number.isNaN(Number(fieldValue))
|
131
|
-
) {
|
132
|
-
if (!Object.hasOwn(placeholders, fieldValue)) {
|
133
|
-
throw new Error('Cannot resolve placeholder' + fieldValue);
|
134
|
-
} else {
|
135
|
-
try {
|
136
|
-
const resolvedID = await placeholders[fieldValue].promise;
|
137
|
-
fieldsObject[fieldName] = resolvedID;
|
138
|
-
} catch {
|
139
|
-
throw new Error('Placeholder failed' + fieldValue);
|
140
|
-
}
|
141
|
-
}
|
142
|
-
} else {
|
143
|
-
fieldsObject[fieldName] = fieldValue;
|
144
|
-
}
|
145
|
-
}),
|
146
|
-
);
|
147
|
-
return fieldsObject;
|
148
|
-
};
|
149
|
-
|
150
|
-
// 'GET', '/transaction/conditional_resource?$select=id,lock,resource_type,conditional_type,placeholder&$filter=transaction eq ?'
|
151
|
-
const conditionalResources = await tx.executeSql(
|
152
|
-
`\
|
153
|
-
SELECT "conditional resource"."id", "conditional resource"."lock", "conditional resource"."resource type" AS "resource_type",
|
154
|
-
"conditional resource"."conditional type" AS "conditional_type", "conditional resource"."placeholder"
|
155
|
-
FROM "conditional resource"
|
156
|
-
WHERE "conditional resource"."transaction" = ?;\
|
157
|
-
`,
|
158
|
-
[transactionID],
|
159
|
-
);
|
160
|
-
|
161
|
-
for (const conditionalResource of conditionalResources.rows) {
|
162
|
-
const { placeholder } = conditionalResource;
|
163
|
-
if (placeholder != null && placeholder.length > 0) {
|
164
|
-
/** @type {Function} */
|
165
|
-
let resolve;
|
166
|
-
/** @type {Function} */
|
167
|
-
let reject;
|
168
|
-
const promise = new Promise(($resolve, $reject) => {
|
169
|
-
resolve = $resolve;
|
170
|
-
reject = $reject;
|
171
|
-
});
|
172
|
-
// @ts-expect-error we use resolve & reject before they are assigned b/c we treat them as a deferred.
|
173
|
-
placeholders[placeholder] = { promise, resolve, reject };
|
174
|
-
}
|
175
|
-
}
|
176
|
-
|
177
|
-
// get conditional resources (if exist)
|
178
|
-
await Promise.all(
|
179
|
-
conditionalResources.rows.map(async (conditionalResource) => {
|
180
|
-
const { placeholder } = conditionalResource;
|
181
|
-
const lockID = conditionalResource.lock;
|
182
|
-
const doCleanup = () =>
|
183
|
-
Promise.all([
|
184
|
-
tx.executeSql(
|
185
|
-
'DELETE FROM "conditional field" WHERE "conditional resource" = ?;',
|
186
|
-
[conditionalResource.id],
|
187
|
-
),
|
188
|
-
tx.executeSql(
|
189
|
-
'DELETE FROM "conditional resource" WHERE "lock" = ?;',
|
190
|
-
[lockID],
|
191
|
-
),
|
192
|
-
tx.executeSql(
|
193
|
-
'DELETE FROM "resource-is under-lock" WHERE "lock" = ?;',
|
194
|
-
[lockID],
|
195
|
-
),
|
196
|
-
tx.executeSql('DELETE FROM "lock" WHERE "id" = ?;', [lockID]),
|
197
|
-
]);
|
198
|
-
|
199
|
-
const passthrough = { tx };
|
200
|
-
|
201
|
-
const clientModel = sbvrUtils.getAbstractSqlModel({
|
202
|
-
vocabulary: modelName,
|
203
|
-
}).tables[odataNameToSqlName(conditionalResource.resource_type)];
|
204
|
-
let url = modelName + '/' + conditionalResource.resource_type;
|
205
|
-
switch (conditionalResource.conditional_type) {
|
206
|
-
case 'DELETE': {
|
207
|
-
const lockedResult = await getLockedRow(lockID);
|
208
|
-
const lockedRow = lockedResult.rows[0];
|
209
|
-
url =
|
210
|
-
url +
|
211
|
-
'?$filter=' +
|
212
|
-
clientModel.idField +
|
213
|
-
' eq ' +
|
214
|
-
lockedRow.resource_id;
|
215
|
-
await sbvrUtils.PinejsClient.prototype.request({
|
216
|
-
method: 'DELETE',
|
217
|
-
url,
|
218
|
-
passthrough,
|
219
|
-
});
|
220
|
-
await doCleanup();
|
221
|
-
return;
|
222
|
-
}
|
223
|
-
case 'EDIT': {
|
224
|
-
const lockedResult = await getLockedRow(lockID);
|
225
|
-
const lockedRow = lockedResult.rows[0];
|
226
|
-
const body = await getFieldsObject(
|
227
|
-
conditionalResource.id,
|
228
|
-
clientModel,
|
229
|
-
);
|
230
|
-
body[clientModel.idField] = lockedRow.resource_id;
|
231
|
-
await sbvrUtils.PinejsClient.prototype.request({
|
232
|
-
method: 'PUT',
|
233
|
-
url,
|
234
|
-
body,
|
235
|
-
passthrough,
|
236
|
-
});
|
237
|
-
await doCleanup();
|
238
|
-
return;
|
239
|
-
}
|
240
|
-
case 'ADD': {
|
241
|
-
try {
|
242
|
-
const body = await getFieldsObject(
|
243
|
-
conditionalResource.id,
|
244
|
-
clientModel,
|
245
|
-
);
|
246
|
-
/** @type { {[key: string]: any} } */
|
247
|
-
const result = await sbvrUtils.PinejsClient.prototype.request(
|
248
|
-
{
|
249
|
-
method: 'POST',
|
250
|
-
url,
|
251
|
-
body,
|
252
|
-
passthrough,
|
253
|
-
},
|
254
|
-
);
|
255
|
-
placeholders[placeholder].resolve(
|
256
|
-
result[clientModel.idField],
|
257
|
-
);
|
258
|
-
await doCleanup();
|
259
|
-
} catch (err) {
|
260
|
-
placeholders[placeholder].reject(err);
|
261
|
-
throw err;
|
262
|
-
}
|
263
|
-
return;
|
264
|
-
}
|
265
|
-
}
|
266
|
-
}),
|
267
|
-
);
|
268
|
-
await tx.executeSql('DELETE FROM "transaction" WHERE "id" = ?;', [
|
269
|
-
transactionID,
|
270
|
-
]);
|
271
|
-
await sbvrUtils.validateModel(tx, modelName);
|
272
|
-
});
|
273
|
-
|
274
|
-
// TODO: these really should be specific to the model - currently they will only work for the first model added
|
275
|
-
app.post('/transaction/execute', async (req, res) => {
|
276
|
-
const id = Number(req.body.id);
|
277
|
-
if (Number.isNaN(id)) {
|
278
|
-
res.status(404).end();
|
279
|
-
} else {
|
280
|
-
try {
|
281
|
-
await endTransaction(id);
|
282
|
-
|
283
|
-
res.status(200).end();
|
284
|
-
} catch (/** @type any */ err) {
|
285
|
-
console.error('Error ending transaction', err);
|
286
|
-
res.status(404).json(err);
|
287
|
-
}
|
288
|
-
}
|
289
|
-
});
|
290
|
-
app.get('/transaction', (_req, res) => {
|
291
|
-
res.json({
|
292
|
-
transactionURI: '/transaction/transaction',
|
293
|
-
conditionalResourceURI: '/transaction/conditional_resource',
|
294
|
-
conditionalFieldURI: '/transaction/conditional_field',
|
295
|
-
lockURI: '/transaction/lock',
|
296
|
-
transactionLockURI: '/transaction/lock__belongs_to__transaction',
|
297
|
-
resourceURI: '/transaction/resource',
|
298
|
-
lockResourceURI: '/transaction/resource__is_under__lock',
|
299
|
-
exclusiveLockURI: '/transaction/lock__is_exclusive',
|
300
|
-
commitTransactionURI: '/transaction/execute',
|
301
|
-
});
|
302
|
-
});
|
303
|
-
app.all('/transaction/*', sbvrUtils.handleODataRequest);
|
304
|
-
};
|
305
|
-
}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"transactions.js","sourceRoot":"","sources":["../../src/http-transactions/transactions.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,MAAM,gBAAgB,GAAG,MAAM,UAAU,CAAC,oBAAoB,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;AAG7E,MAAM,CAAC,MAAM,MAAM,GAAG;IACrB,MAAM,EAAE;QACP;YACC,OAAO,EAAE,aAAa;YACtB,SAAS,EAAE,gBAAgB;YAC3B,gBAAgB,EAAE,EAAE,KAAK,EAAE;YAC3B,UAAU,EAAE;gBACX,oBAAoB,EAAE;;;;;;;;;;;;;CAazB;gBACG,mBAAmB,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE;oBAC5C,QAAQ,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC;wBAC7B,KAAK,OAAO;4BACX,MAAM,EAAE,CAAC,UAAU,CAAC;;;iDAGsB,CAAC,CAAC;4BAC5C,MAAM;wBACP,KAAK,UAAU;4BACd,MAAM,EAAE,CAAC,UAAU,CAAC;;;;;;;wDAO6B,CAAC,CAAC;4BACnD,MAAM;oBAER,CAAC;gBACF,CAAC;aACD;SACD;KACD;CACD,CAAC;AAGF,MAAM,CAAC,IAAI,aAAa,CAAC;AAGzB,MAAM,UAAU,KAAK,CAAC,GAAG,EAAE,SAAS;IACnC,aAAa,GAAG,CAAC,SAAS,EAAE,EAAE;QAE7B,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE;YAC9C,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,OAAO,EAAE;gBAC3B,MAAM,KAAK,GAAG,OAAO,CAAC,UAAU,CAAC;gBACjC,MAAM,GAAG,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACpC,MAAM,EAAE,GAAG,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;gBAC3C,IAAI,MAAM,CAAC;gBACX,IAAI,CAAC;oBACJ,MAAM,GAAG,MAAM,EAAE,CAAC,UAAU,CAC3B;;;;;;;aAOO,EACP,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,CAC1B,CAAC;gBACH,CAAC;gBAAC,OAAwB,GAAG,EAAE,CAAC;oBAC/B,GAAG,CAAC,KAAK,CAAC,gCAAgC,EAAE,GAAG,CAAC,CAAC;oBACjD,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;gBACnD,CAAC;gBACD,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;oBACrD,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;gBAChE,CAAC;YACF,CAAC;SACD,CAAC,CAAC;QAEH,MAAM,cAAc,GAAG,CAAuB,aAAa,EAAE,EAAE,CAC9D,SAAS,CAAC,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;YAErC,MAAM,YAAY,GAAG,EAAE,CAAC;YACxB,MAAM,YAAY,GAAG,CACE,MAAM,EAC3B,EAAE,CACH,EAAE,CAAC,UAAU,CACZ;;;;yCAImC,EACnC,CAAC,MAAM,CAAC,CACR,CAAC;YACH,MAAM,eAAe,GAAG,KAAK,EACN,qBAAqB,EAC6B,WAAW,EAClF,EAAE;gBACH,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,UAAU,CACjC;;sDAEgD,EAChD,CAAC,qBAAqB,CAAC,CACvB,CAAC;gBAEF,MAAM,YAAY,GAAG,EAAE,CAAC;gBACxB,MAAM,OAAO,CAAC,GAAG,CAChB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;oBAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC,OAAO,CACzC,WAAW,CAAC,YAAY,GAAG,GAAG,EAC9B,EAAE,CACF,CAAC;oBACF,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC;oBACrC,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,CAAC,IAAI,CACzC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,CAChC,CAAC;oBACF,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;wBACxB,MAAM,IAAI,KAAK,CAAC,kBAAkB,SAAS,EAAE,CAAC,CAAC;oBAChD,CAAC;oBACD,IACC,UAAU,CAAC,QAAQ,KAAK,YAAY;wBACpC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,EAC/B,CAAC;wBACF,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,UAAU,CAAC,EAAE,CAAC;4BAC9C,MAAM,IAAI,KAAK,CAAC,4BAA4B,GAAG,UAAU,CAAC,CAAC;wBAC5D,CAAC;6BAAM,CAAC;4BACP,IAAI,CAAC;gCACJ,MAAM,UAAU,GAAG,MAAM,YAAY,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC;gCAC1D,YAAY,CAAC,SAAS,CAAC,GAAG,UAAU,CAAC;4BACtC,CAAC;4BAAC,MAAM,CAAC;gCACR,MAAM,IAAI,KAAK,CAAC,oBAAoB,GAAG,UAAU,CAAC,CAAC;4BACpD,CAAC;wBACF,CAAC;oBACF,CAAC;yBAAM,CAAC;wBACP,YAAY,CAAC,SAAS,CAAC,GAAG,UAAU,CAAC;oBACtC,CAAC;gBACF,CAAC,CAAC,CACF,CAAC;gBACF,OAAO,YAAY,CAAC;YACrB,CAAC,CAAC;YAGF,MAAM,oBAAoB,GAAG,MAAM,EAAE,CAAC,UAAU,CAC/C;;;;;CAKJ,EACI,CAAC,aAAa,CAAC,CACf,CAAC;YAEF,KAAK,MAAM,mBAAmB,IAAI,oBAAoB,CAAC,IAAI,EAAE,CAAC;gBAC7D,MAAM,EAAE,WAAW,EAAE,GAAG,mBAAmB,CAAC;gBAC5C,IAAI,WAAW,IAAI,IAAI,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAEnD,IAAI,OAAO,CAAC;oBAEZ,IAAI,MAAM,CAAC;oBACX,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE;wBACjD,OAAO,GAAG,QAAQ,CAAC;wBACnB,MAAM,GAAG,OAAO,CAAC;oBAClB,CAAC,CAAC,CAAC;oBAEH,YAAY,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;gBAC1D,CAAC;YACF,CAAC;YAGD,MAAM,OAAO,CAAC,GAAG,CAChB,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,mBAAmB,EAAE,EAAE;gBAC3D,MAAM,EAAE,WAAW,EAAE,GAAG,mBAAmB,CAAC;gBAC5C,MAAM,MAAM,GAAG,mBAAmB,CAAC,IAAI,CAAC;gBACxC,MAAM,SAAS,GAAG,GAAG,EAAE,CACtB,OAAO,CAAC,GAAG,CAAC;oBACX,EAAE,CAAC,UAAU,CACZ,mEAAmE,EACnE,CAAC,mBAAmB,CAAC,EAAE,CAAC,CACxB;oBACD,EAAE,CAAC,UAAU,CACZ,sDAAsD,EACtD,CAAC,MAAM,CAAC,CACR;oBACD,EAAE,CAAC,UAAU,CACZ,wDAAwD,EACxD,CAAC,MAAM,CAAC,CACR;oBACD,EAAE,CAAC,UAAU,CAAC,oCAAoC,EAAE,CAAC,MAAM,CAAC,CAAC;iBAC7D,CAAC,CAAC;gBAEJ,MAAM,WAAW,GAAG,EAAE,EAAE,EAAE,CAAC;gBAE3B,MAAM,WAAW,GAAG,SAAS,CAAC,mBAAmB,CAAC;oBACjD,UAAU,EAAE,SAAS;iBACrB,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC,CAAC;gBACjE,IAAI,GAAG,GAAG,SAAS,GAAG,GAAG,GAAG,mBAAmB,CAAC,aAAa,CAAC;gBAC9D,QAAQ,mBAAmB,CAAC,gBAAgB,EAAE,CAAC;oBAC9C,KAAK,QAAQ,CAAC,CAAC,CAAC;wBACf,MAAM,YAAY,GAAG,MAAM,YAAY,CAAC,MAAM,CAAC,CAAC;wBAChD,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;wBACvC,GAAG;4BACF,GAAG;gCACH,WAAW;gCACX,WAAW,CAAC,OAAO;gCACnB,MAAM;gCACN,SAAS,CAAC,WAAW,CAAC;wBACvB,MAAM,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC;4BAC9C,MAAM,EAAE,QAAQ;4BAChB,GAAG;4BACH,WAAW;yBACX,CAAC,CAAC;wBACH,MAAM,SAAS,EAAE,CAAC;wBAClB,OAAO;oBACR,CAAC;oBACD,KAAK,MAAM,CAAC,CAAC,CAAC;wBACb,MAAM,YAAY,GAAG,MAAM,YAAY,CAAC,MAAM,CAAC,CAAC;wBAChD,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;wBACvC,MAAM,IAAI,GAAG,MAAM,eAAe,CACjC,mBAAmB,CAAC,EAAE,EACtB,WAAW,CACX,CAAC;wBACF,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,SAAS,CAAC,WAAW,CAAC;wBAClD,MAAM,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC;4BAC9C,MAAM,EAAE,KAAK;4BACb,GAAG;4BACH,IAAI;4BACJ,WAAW;yBACX,CAAC,CAAC;wBACH,MAAM,SAAS,EAAE,CAAC;wBAClB,OAAO;oBACR,CAAC;oBACD,KAAK,KAAK,CAAC,CAAC,CAAC;wBACZ,IAAI,CAAC;4BACJ,MAAM,IAAI,GAAG,MAAM,eAAe,CACjC,mBAAmB,CAAC,EAAE,EACtB,WAAW,CACX,CAAC;4BAEF,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,CAC5D;gCACC,MAAM,EAAE,MAAM;gCACd,GAAG;gCACH,IAAI;gCACJ,WAAW;6BACX,CACD,CAAC;4BACF,YAAY,CAAC,WAAW,CAAC,CAAC,OAAO,CAChC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAC3B,CAAC;4BACF,MAAM,SAAS,EAAE,CAAC;wBACnB,CAAC;wBAAC,OAAO,GAAG,EAAE,CAAC;4BACd,YAAY,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;4BACtC,MAAM,GAAG,CAAC;wBACX,CAAC;wBACD,OAAO;oBACR,CAAC;gBACF,CAAC;YACF,CAAC,CAAC,CACF,CAAC;YACF,MAAM,EAAE,CAAC,UAAU,CAAC,2CAA2C,EAAE;gBAChE,aAAa;aACb,CAAC,CAAC;YACH,MAAM,SAAS,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAGJ,GAAG,CAAC,IAAI,CAAC,sBAAsB,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YACnD,MAAM,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC/B,IAAI,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;gBACtB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC;oBACJ,MAAM,cAAc,CAAC,EAAE,CAAC,CAAC;oBAEzB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;gBACvB,CAAC;gBAAC,OAAwB,GAAG,EAAE,CAAC;oBAC/B,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,GAAG,CAAC,CAAC;oBAC/C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC3B,CAAC;YACF,CAAC;QACF,CAAC,CAAC,CAAC;QACH,GAAG,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;YACrC,GAAG,CAAC,IAAI,CAAC;gBACR,cAAc,EAAE,0BAA0B;gBAC1C,sBAAsB,EAAE,mCAAmC;gBAC3D,mBAAmB,EAAE,gCAAgC;gBACrD,OAAO,EAAE,mBAAmB;gBAC5B,kBAAkB,EAAE,4CAA4C;gBAChE,WAAW,EAAE,uBAAuB;gBACpC,eAAe,EAAE,uCAAuC;gBACxD,gBAAgB,EAAE,iCAAiC;gBACnD,oBAAoB,EAAE,sBAAsB;aAC5C,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,GAAG,CAAC,GAAG,CAAC,gBAAgB,EAAE,SAAS,CAAC,kBAAkB,CAAC,CAAC;IACzD,CAAC,CAAC;AACH,CAAC"}
|
@@ -1,12 +0,0 @@
|
|
1
|
-
import type { UploadPart, WebResourceHandler } from './index.js';
|
2
|
-
import { sbvrUtils } from '../server-glue/module.js';
|
3
|
-
export interface BeginUploadResponse {
|
4
|
-
[fieldName: string]: {
|
5
|
-
uuid: string;
|
6
|
-
uploadParts: UploadPart[];
|
7
|
-
};
|
8
|
-
}
|
9
|
-
type MultipartUploadHandler = WebResourceHandler & Required<Pick<WebResourceHandler, 'multipartUpload'>>;
|
10
|
-
export declare const isMultipartUploadAvailable: (webResourceHandler: WebResourceHandler) => webResourceHandler is MultipartUploadHandler;
|
11
|
-
export declare const multipartUploadHooks: (webResourceHandler: MultipartUploadHandler) => sbvrUtils.Hooks;
|
12
|
-
export {};
|
@@ -1,257 +0,0 @@
|
|
1
|
-
import { randomUUID } from 'node:crypto';
|
2
|
-
import { getWebResourceFields } from './index.js';
|
3
|
-
import { api } from '../sbvr-api/sbvr-utils.js';
|
4
|
-
import { errors, sbvrUtils } from '../server-glue/module.js';
|
5
|
-
import { webResource as webResourceEnv } from '../config-loader/env.js';
|
6
|
-
import * as permissions from '../sbvr-api/permissions.js';
|
7
|
-
import { sqlNameToODataName } from '@balena/odata-to-abstract-sql';
|
8
|
-
export const isMultipartUploadAvailable = (webResourceHandler) => {
|
9
|
-
return (webResourceEnv.multipartUploadEnabled &&
|
10
|
-
webResourceHandler.multipartUpload != null);
|
11
|
-
};
|
12
|
-
export const multipartUploadHooks = (webResourceHandler) => {
|
13
|
-
return {
|
14
|
-
POSTPARSE: async ({ req, request, tx, api: applicationApi }) => {
|
15
|
-
if (request.odataQuery.property?.resource === 'beginUpload') {
|
16
|
-
const uploadParams = await validateBeginUpload(request, applicationApi, webResourceHandler);
|
17
|
-
tx = await sbvrUtils.db.transaction();
|
18
|
-
req.tx = tx;
|
19
|
-
request.tx = tx;
|
20
|
-
request.method = 'PATCH';
|
21
|
-
request.values = uploadParams;
|
22
|
-
request.odataQuery.resource = request.resourceName;
|
23
|
-
delete request.odataQuery.property;
|
24
|
-
request.custom.isAction = 'beginUpload';
|
25
|
-
}
|
26
|
-
else if (request.odataQuery.property?.resource === 'commitUpload') {
|
27
|
-
const commitPayload = await validateCommitUpload(request, applicationApi);
|
28
|
-
const webresource = await webResourceHandler.multipartUpload.commit({
|
29
|
-
fileKey: commitPayload.metadata.fileKey,
|
30
|
-
uploadId: commitPayload.metadata.uploadId,
|
31
|
-
filename: commitPayload.metadata.filename,
|
32
|
-
providerCommitData: commitPayload.providerCommitData,
|
33
|
-
});
|
34
|
-
await api.webresource.patch({
|
35
|
-
resource: 'multipart_upload',
|
36
|
-
body: {
|
37
|
-
status: 'completed',
|
38
|
-
},
|
39
|
-
options: {
|
40
|
-
$filter: {
|
41
|
-
uuid: commitPayload.uuid,
|
42
|
-
},
|
43
|
-
},
|
44
|
-
passthrough: {
|
45
|
-
tx: tx,
|
46
|
-
req: permissions.root,
|
47
|
-
},
|
48
|
-
});
|
49
|
-
request.method = 'PATCH';
|
50
|
-
request.values = {
|
51
|
-
[commitPayload.metadata.fieldName]: webresource,
|
52
|
-
};
|
53
|
-
request.odataQuery.resource = request.resourceName;
|
54
|
-
delete request.odataQuery.property;
|
55
|
-
request.custom.isAction = 'commitUpload';
|
56
|
-
request.custom.commitUploadPayload = webresource;
|
57
|
-
}
|
58
|
-
else if (request.odataQuery.property?.resource === 'cancelUpload') {
|
59
|
-
const { uuid, fileKey, uploadId } = await validateCancelPayload(request, applicationApi);
|
60
|
-
await webResourceHandler.multipartUpload.cancel({ fileKey, uploadId });
|
61
|
-
await api.webresource.patch({
|
62
|
-
resource: 'multipart_upload',
|
63
|
-
body: {
|
64
|
-
status: 'cancelled',
|
65
|
-
},
|
66
|
-
options: {
|
67
|
-
$filter: { uuid },
|
68
|
-
},
|
69
|
-
passthrough: {
|
70
|
-
tx: tx,
|
71
|
-
req: permissions.root,
|
72
|
-
},
|
73
|
-
});
|
74
|
-
request.method = 'GET';
|
75
|
-
request.odataQuery.resource = request.resourceName;
|
76
|
-
delete request.odataQuery.property;
|
77
|
-
request.custom.isAction = 'cancelUpload';
|
78
|
-
}
|
79
|
-
},
|
80
|
-
PRERESPOND: async ({ req, request, response, tx }) => {
|
81
|
-
if (request.custom.isAction === 'beginUpload') {
|
82
|
-
await tx.rollback();
|
83
|
-
response.statusCode = 200;
|
84
|
-
response.body = await beginUpload({
|
85
|
-
webResourceHandler,
|
86
|
-
odataRequest: request,
|
87
|
-
actorId: req.user?.actor,
|
88
|
-
});
|
89
|
-
}
|
90
|
-
else if (request.custom.isAction === 'commitUpload') {
|
91
|
-
response.body = await webResourceHandler.onPreRespond(request.custom.commitUploadPayload);
|
92
|
-
}
|
93
|
-
else if (request.custom.isAction === 'cancelUpload') {
|
94
|
-
response.statusCode = 204;
|
95
|
-
delete response.body;
|
96
|
-
}
|
97
|
-
},
|
98
|
-
};
|
99
|
-
};
|
100
|
-
const beginUpload = async ({ webResourceHandler, odataRequest, actorId, }) => {
|
101
|
-
const payload = odataRequest.values;
|
102
|
-
const fieldName = Object.keys(payload)[0];
|
103
|
-
const metadata = payload[fieldName];
|
104
|
-
const { fileKey, uploadId, uploadParts } = await webResourceHandler.multipartUpload.begin(fieldName, metadata);
|
105
|
-
const uuid = randomUUID();
|
106
|
-
return await sbvrUtils.db.transaction(async (tx) => {
|
107
|
-
try {
|
108
|
-
await api.webresource.post({
|
109
|
-
resource: 'multipart_upload',
|
110
|
-
body: {
|
111
|
-
uuid,
|
112
|
-
resource_name: odataRequest.resourceName,
|
113
|
-
field_name: fieldName,
|
114
|
-
resource_id: odataRequest.affectedIds?.[0],
|
115
|
-
upload_id: uploadId,
|
116
|
-
file_key: fileKey,
|
117
|
-
status: 'pending',
|
118
|
-
filename: metadata.filename,
|
119
|
-
content_type: metadata.content_type,
|
120
|
-
size: metadata.size,
|
121
|
-
chunk_size: metadata.chunk_size,
|
122
|
-
expiry_date: Date.now() + 7 * 24 * 60 * 60 * 1000,
|
123
|
-
is_created_by__actor: actorId,
|
124
|
-
},
|
125
|
-
passthrough: {
|
126
|
-
req: permissions.root,
|
127
|
-
tx,
|
128
|
-
},
|
129
|
-
});
|
130
|
-
return { [fieldName]: { uuid, uploadParts } };
|
131
|
-
}
|
132
|
-
catch (err) {
|
133
|
-
console.error('failed to start multipart upload', err);
|
134
|
-
throw new errors.BadRequestError('Failed to start multipart upload');
|
135
|
-
}
|
136
|
-
});
|
137
|
-
};
|
138
|
-
const validateBeginUpload = async (request, applicationApi, webResourceHandler) => {
|
139
|
-
await canAccess(request, applicationApi);
|
140
|
-
const fieldNames = Object.keys(request.values);
|
141
|
-
if (fieldNames.length !== 1) {
|
142
|
-
throw new errors.BadRequestError('You can only get upload url for one field at a time');
|
143
|
-
}
|
144
|
-
const [fieldName] = fieldNames;
|
145
|
-
const webResourceFields = getWebResourceFields(request);
|
146
|
-
if (!webResourceFields.includes(fieldName)) {
|
147
|
-
throw new errors.BadRequestError(`The provided field '${fieldName}' is not a valid webresource`);
|
148
|
-
}
|
149
|
-
const beginUploadPayload = parseBeginUploadPayload(request.values[fieldName], webResourceHandler);
|
150
|
-
if (beginUploadPayload == null) {
|
151
|
-
throw new errors.BadRequestError('Invalid file metadata');
|
152
|
-
}
|
153
|
-
const uploadMetadataCheck = {
|
154
|
-
...beginUploadPayload,
|
155
|
-
href: 'metadata_check_probe',
|
156
|
-
};
|
157
|
-
return { [fieldName]: uploadMetadataCheck };
|
158
|
-
};
|
159
|
-
const parseBeginUploadPayload = (payload, webResourceHandler) => {
|
160
|
-
if (payload == null || typeof payload !== 'object') {
|
161
|
-
return null;
|
162
|
-
}
|
163
|
-
let { filename, content_type, size, chunk_size } = payload;
|
164
|
-
if (typeof filename !== 'string' ||
|
165
|
-
typeof content_type !== 'string' ||
|
166
|
-
typeof size !== 'number' ||
|
167
|
-
(chunk_size != null && typeof chunk_size !== 'number') ||
|
168
|
-
(chunk_size != null &&
|
169
|
-
chunk_size < webResourceHandler.multipartUpload.getMinimumPartSize())) {
|
170
|
-
return null;
|
171
|
-
}
|
172
|
-
if (chunk_size == null) {
|
173
|
-
chunk_size = webResourceHandler.multipartUpload.getDefaultPartSize();
|
174
|
-
}
|
175
|
-
return { filename, content_type, size, chunk_size };
|
176
|
-
};
|
177
|
-
const validateCommitUpload = async (request, applicationApi) => {
|
178
|
-
await canAccess(request, applicationApi);
|
179
|
-
const { uuid, providerCommitData } = request.values;
|
180
|
-
if (typeof uuid !== 'string') {
|
181
|
-
throw new errors.BadRequestError('Invalid uuid type');
|
182
|
-
}
|
183
|
-
const [multipartUpload] = await api.webresource.get({
|
184
|
-
resource: 'multipart_upload',
|
185
|
-
options: {
|
186
|
-
$select: ['id', 'file_key', 'upload_id', 'field_name', 'filename'],
|
187
|
-
$filter: {
|
188
|
-
uuid,
|
189
|
-
status: 'pending',
|
190
|
-
expiry_date: { $gt: { $now: {} } },
|
191
|
-
},
|
192
|
-
},
|
193
|
-
passthrough: {
|
194
|
-
tx: request.tx,
|
195
|
-
req: permissions.rootRead,
|
196
|
-
},
|
197
|
-
});
|
198
|
-
if (multipartUpload == null) {
|
199
|
-
throw new errors.BadRequestError(`Invalid upload for uuid ${uuid}`);
|
200
|
-
}
|
201
|
-
const metadata = {
|
202
|
-
fileKey: multipartUpload.file_key,
|
203
|
-
uploadId: multipartUpload.upload_id,
|
204
|
-
filename: multipartUpload.filename,
|
205
|
-
fieldName: multipartUpload.field_name,
|
206
|
-
};
|
207
|
-
return { uuid, providerCommitData, metadata };
|
208
|
-
};
|
209
|
-
const validateCancelPayload = async (request, applicationApi) => {
|
210
|
-
await canAccess(request, applicationApi);
|
211
|
-
const { uuid } = request.values;
|
212
|
-
if (typeof uuid !== 'string') {
|
213
|
-
throw new errors.BadRequestError('Invalid uuid type');
|
214
|
-
}
|
215
|
-
const [multipartUpload] = await api.webresource.get({
|
216
|
-
resource: 'multipart_upload',
|
217
|
-
options: {
|
218
|
-
$select: ['id', 'file_key', 'upload_id'],
|
219
|
-
$filter: {
|
220
|
-
uuid,
|
221
|
-
status: 'pending',
|
222
|
-
expiry_date: { $gt: { $now: {} } },
|
223
|
-
},
|
224
|
-
},
|
225
|
-
passthrough: {
|
226
|
-
tx: request.tx,
|
227
|
-
req: permissions.rootRead,
|
228
|
-
},
|
229
|
-
});
|
230
|
-
if (multipartUpload == null) {
|
231
|
-
throw new errors.BadRequestError(`Invalid upload for uuid ${uuid}`);
|
232
|
-
}
|
233
|
-
return {
|
234
|
-
uuid,
|
235
|
-
fileKey: multipartUpload.file_key,
|
236
|
-
uploadId: multipartUpload.upload_id,
|
237
|
-
};
|
238
|
-
};
|
239
|
-
const matchQueryKey = /^\/[a-zA-Z0-9_\-\s]+\((.*?)\)\/(beginUpload|commitUpload|cancelUpload)$/;
|
240
|
-
const canAccess = async (request, applicationApi) => {
|
241
|
-
if (request.odataQuery.key == null) {
|
242
|
-
throw new errors.BadRequestError();
|
243
|
-
}
|
244
|
-
const match = request.url.match(matchQueryKey);
|
245
|
-
if (match == null) {
|
246
|
-
throw new errors.BadRequestError();
|
247
|
-
}
|
248
|
-
const resourceKey = match[1];
|
249
|
-
const resourceName = sqlNameToODataName(sbvrUtils.resolveSynonym(request));
|
250
|
-
const canAccessUrl = `${resourceName}(${resourceKey})/canAccess`;
|
251
|
-
await applicationApi.request({
|
252
|
-
method: 'POST',
|
253
|
-
url: canAccessUrl,
|
254
|
-
body: { method: 'PATCH' },
|
255
|
-
});
|
256
|
-
};
|
257
|
-
//# sourceMappingURL=multipartUpload.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"multipartUpload.js","sourceRoot":"","sources":["../../src/webresource-handler/multipartUpload.ts"],"names":[],"mappings":"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"}
|
@@ -1,42 +0,0 @@
|
|
1
|
-
import type { Types } from '@balena/abstract-sql-to-typescript';
|
2
|
-
export interface MultipartUpload {
|
3
|
-
Read: {
|
4
|
-
created_at: Types['Date Time']['Read'];
|
5
|
-
modified_at: Types['Date Time']['Read'];
|
6
|
-
id: Types['Serial']['Read'];
|
7
|
-
uuid: Types['Short Text']['Read'];
|
8
|
-
resource_name: Types['Short Text']['Read'];
|
9
|
-
field_name: Types['Short Text']['Read'];
|
10
|
-
resource_id: Types['Integer']['Read'];
|
11
|
-
upload_id: Types['Short Text']['Read'];
|
12
|
-
file_key: Types['Short Text']['Read'];
|
13
|
-
status: 'pending' | 'completed' | 'cancelled';
|
14
|
-
filename: Types['Short Text']['Read'];
|
15
|
-
content_type: Types['Short Text']['Read'];
|
16
|
-
size: Types['Integer']['Read'];
|
17
|
-
chunk_size: Types['Integer']['Read'];
|
18
|
-
expiry_date: Types['Date Time']['Read'];
|
19
|
-
is_created_by__actor: Types['Integer']['Read'] | null;
|
20
|
-
};
|
21
|
-
Write: {
|
22
|
-
created_at: Types['Date Time']['Write'];
|
23
|
-
modified_at: Types['Date Time']['Write'];
|
24
|
-
id: Types['Serial']['Write'];
|
25
|
-
uuid: Types['Short Text']['Write'];
|
26
|
-
resource_name: Types['Short Text']['Write'];
|
27
|
-
field_name: Types['Short Text']['Write'];
|
28
|
-
resource_id: Types['Integer']['Write'];
|
29
|
-
upload_id: Types['Short Text']['Write'];
|
30
|
-
file_key: Types['Short Text']['Write'];
|
31
|
-
status: 'pending' | 'completed' | 'cancelled';
|
32
|
-
filename: Types['Short Text']['Write'];
|
33
|
-
content_type: Types['Short Text']['Write'];
|
34
|
-
size: Types['Integer']['Write'];
|
35
|
-
chunk_size: Types['Integer']['Write'];
|
36
|
-
expiry_date: Types['Date Time']['Write'];
|
37
|
-
is_created_by__actor: Types['Integer']['Write'] | null;
|
38
|
-
};
|
39
|
-
}
|
40
|
-
export default interface $Model {
|
41
|
-
multipart_upload: MultipartUpload;
|
42
|
-
}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"webresource.js","sourceRoot":"","sources":["../../src/webresource-handler/webresource.ts"],"names":[],"mappings":""}
|