@balena/open-balena-api 31.2.8 → 31.2.9-build-resolve-dsev-permission-with-device-b5a7e911544591aa75faa4af012969a755abe9ee-1
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/features/service-install/hooks/backfill-service-install-on-device-service-env-var.js +41 -0
- package/dist/features/service-install/hooks/backfill-service-install-on-device-service-env-var.js.map +1 -0
- package/dist/features/service-install/hooks/index.d.ts +1 -1
- package/dist/features/service-install/hooks/index.js +1 -1
- package/dist/features/service-install/hooks/index.js.map +1 -1
- package/dist/lib/auth.js +2 -2
- package/dist/lib/auth.js.map +1 -1
- package/dist/translations/v7/hooks.js +31 -1
- package/dist/translations/v7/hooks.js.map +1 -1
- package/package.json +2 -2
- package/dist/features/service-install/hooks/backfill-device-service-environment-variable.js +0 -26
- package/dist/features/service-install/hooks/backfill-device-service-environment-variable.js.map +0 -1
- /package/dist/features/service-install/hooks/{backfill-device-service-environment-variable.d.ts → backfill-service-install-on-device-service-env-var.d.ts} +0 -0
package/dist/features/service-install/hooks/backfill-service-install-on-device-service-env-var.js
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
import { hooks, errors } from '@balena/pinejs';
|
2
|
+
async function backfillServiceInstall({ request, api, }) {
|
3
|
+
const { device: deviceId, service: serviceId } = request.values;
|
4
|
+
if (deviceId == null && serviceId == null) {
|
5
|
+
return;
|
6
|
+
}
|
7
|
+
if ((deviceId == null && serviceId != null) ||
|
8
|
+
(deviceId != null && serviceId == null)) {
|
9
|
+
throw new errors.BadRequestError('Both or none of device and service must be specified');
|
10
|
+
}
|
11
|
+
let si = await api.get({
|
12
|
+
resource: 'service_install',
|
13
|
+
id: {
|
14
|
+
device: deviceId,
|
15
|
+
installs__service: serviceId,
|
16
|
+
},
|
17
|
+
options: {
|
18
|
+
$select: ['id'],
|
19
|
+
},
|
20
|
+
});
|
21
|
+
if (si == null) {
|
22
|
+
si = await api.post({
|
23
|
+
resource: 'service_install',
|
24
|
+
body: {
|
25
|
+
device: deviceId,
|
26
|
+
installs__service: serviceId,
|
27
|
+
},
|
28
|
+
});
|
29
|
+
}
|
30
|
+
if (si == null) {
|
31
|
+
throw new errors.BadRequestError(`No service install exists for device: ${deviceId} and service ${serviceId} and one could not be created`);
|
32
|
+
}
|
33
|
+
request.values.service_install = si.id;
|
34
|
+
}
|
35
|
+
hooks.addPureHook('POST', 'resin', 'device_service_environment_variable', {
|
36
|
+
POSTPARSE: backfillServiceInstall,
|
37
|
+
});
|
38
|
+
hooks.addPureHook('PATCH', 'resin', 'device_service_environment_variable', {
|
39
|
+
POSTPARSE: backfillServiceInstall,
|
40
|
+
});
|
41
|
+
//# sourceMappingURL=backfill-service-install-on-device-service-env-var.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"backfill-service-install-on-device-service-env-var.js","sourceRoot":"","sources":["../../../../src/features/service-install/hooks/backfill-service-install-on-device-service-env-var.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAkB,MAAM,gBAAgB,CAAC;AAE/D,KAAK,UAAU,sBAAsB,CAAC,EACrC,OAAO,EACP,GAAG,GAC0B;IAC7B,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAEhE,IAAI,QAAQ,IAAI,IAAI,IAAI,SAAS,IAAI,IAAI,EAAE,CAAC;QAC3C,OAAO;IACR,CAAC;IAED,IACC,CAAC,QAAQ,IAAI,IAAI,IAAI,SAAS,IAAI,IAAI,CAAC;QACvC,CAAC,QAAQ,IAAI,IAAI,IAAI,SAAS,IAAI,IAAI,CAAC,EACtC,CAAC;QACF,MAAM,IAAI,MAAM,CAAC,eAAe,CAC/B,sDAAsD,CACtD,CAAC;IACH,CAAC;IAED,IAAI,EAAE,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC;QACtB,QAAQ,EAAE,iBAAiB;QAC3B,EAAE,EAAE;YACH,MAAM,EAAE,QAAQ;YAChB,iBAAiB,EAAE,SAAS;SAC5B;QACD,OAAO,EAAE;YACR,OAAO,EAAE,CAAC,IAAI,CAAC;SACf;KACD,CAAC,CAAC;IAEH,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QAChB,EAAE,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC;YACnB,QAAQ,EAAE,iBAAiB;YAC3B,IAAI,EAAE;gBACL,MAAM,EAAE,QAAQ;gBAChB,iBAAiB,EAAE,SAAS;aAC5B;SACD,CAAC,CAAC;IACJ,CAAC;IAED,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QAChB,MAAM,IAAI,MAAM,CAAC,eAAe,CAC/B,yCAAyC,QAAQ,gBAAgB,SAAS,+BAA+B,CACzG,CAAC;IACH,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,eAAe,GAAG,EAAE,CAAC,EAAE,CAAC;AACxC,CAAC;AAED,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,OAAO,EAAE,qCAAqC,EAAE;IACzE,SAAS,EAAE,sBAAsB;CACjC,CAAC,CAAC;AAEH,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,qCAAqC,EAAE;IAC1E,SAAS,EAAE,sBAAsB;CACjC,CAAC,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
import './backfill-device-service-
|
1
|
+
import './backfill-service-install-on-device-service-env-var.js';
|
@@ -1,2 +1,2 @@
|
|
1
|
-
import './backfill-device-service-
|
1
|
+
import './backfill-service-install-on-device-service-env-var.js';
|
2
2
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/features/service-install/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/features/service-install/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,yDAAyD,CAAC"}
|
package/dist/lib/auth.js
CHANGED
@@ -81,8 +81,8 @@ export const DEVICE_API_KEY_PERMISSIONS = [
|
|
81
81
|
// A device should be able to manage its own service installs, even from apps its not or no longer part of (past/supervisor/os)
|
82
82
|
...writePerms('resin.service_install', `device/any(d:${matchesNonFrozenDeviceActor('d')})`, ['update', 'delete']),
|
83
83
|
'resin.service_environment_variable.read?service/canAccess()',
|
84
|
-
'resin.device_service_environment_variable.read?
|
85
|
-
...writePerms('resin.device_service_environment_variable', `
|
84
|
+
'resin.device_service_environment_variable.read?device/canAccess()',
|
85
|
+
...writePerms('resin.device_service_environment_variable', `device/any(d:${matchesNonFrozenDeviceActor('d')})`),
|
86
86
|
'resin.image__is_part_of__release.read?is_part_of__release/canAccess()',
|
87
87
|
'resin.image.read?image_install/canAccess() or image__is_part_of__release/canAccess()',
|
88
88
|
'resin.image_install.read?device/canAccess()',
|
package/dist/lib/auth.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/lib/auth.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,8DAA8D;AAC9D,EAAE;AAIF,OAAO,EACN,uBAAuB,EACvB,gCAAgC,EAChC,iBAAiB,EACjB,mBAAmB,GACnB,MAAM,aAAa,CAAC;AAErB,MAAM,iBAAiB,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAU,CAAC;AAElE,MAAM,UAAU,GAAG,CAClB,QAAgB,EAChB,MAAc,EACd,SAA4D,iBAAiB,EAClE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,GAAG,QAAQ,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC,CAAC;AAErE,MAAM,YAAY,GAAG,sBAAsB,CAAC;AAC5C,MAAM,WAAW,GAAG,gBAAgB,YAAY,GAAG,CAAC;AACpD,MAAM,2BAA2B,GAAG,CAAC,KAAK,GAAG,EAAE,EAAE,EAAE;IAClD,IAAI,KAAK,EAAE,CAAC;QACX,KAAK,IAAI,GAAG,CAAC;IACd,CAAC;IACD,MAAM,cAAc,GAAG,CAAC,gCAAgC;QACvD,CAAC,CAAC,QAAQ,KAAK,oBAAoB;QACnC,CAAC,CAAC,EAAE,CAAC;IACN,OAAO,GAAG,KAAK,GAAG,YAAY,GAAG,cAAc,EAAE,CAAC;AACnD,CAAC,CAAC;AACF,MAAM,UAAU,GAAG,wBAAwB,YAAY,GAAG,CAAC;AAE3D,MAAM,CAAC,MAAM,KAAK,GAEd;IACH,sBAAsB,EAAE;QACvB,uDAAuD,YAAY,GAAG;KACtE;IACD,gCAAgC;IAChC,oBAAoB,EAAE;QACrB,sCAAsC;QACtC,gDAAgD;QAChD,uBAAuB;QACvB,wBAAwB;QACxB,8BAA8B;QAC9B,6BAA6B;QAC7B,uCAAuC;QACvC,4CAA4C;QAC5C,2BAA2B;QAC3B,4BAA4B;QAC5B,kBAAkB;QAClB,2BAA2B;QAC3B,kCAAkC;QAClC,uCAAuC;QACvC,sBAAsB;QACtB,+CAA+C;QAC/C,iBAAiB;QACjB,sCAAsC;QACtC,sCAAsC;QACtC,yBAAyB;QACzB,uBAAuB;QACvB,yBAAyB;QACzB,oCAAoC;QACpC,mBAAmB;QACnB,uBAAuB;QACvB,mBAAmB;QACnB,wCAAwC;QACxC,2BAA2B;QAC3B,mDAAmD;QACnD,yBAAyB;QACzB,iBAAiB;QACjB,mCAAmC,WAAW,EAAE;QAChD,yBAAyB;KACzB;CACD,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG;IACzC,sDAAsD;IACtD,qBAAqB,2BAA2B,EAAE,EAAE;IACpD,uBAAuB,2BAA2B,EAAE,EAAE;IACtD,yIAAyI;IACzI,oDAAoD;IACpD,sDAAsD;IACtD,oDAAoD,2BAA2B,CAC9E,GAAG,CACH,GAAG;IACJ,oDAAoD,2BAA2B,CAC9E,GAAG,CACH,GAAG;IACJ,0CAA0C;IAC1C,GAAG,UAAU,CACZ,kBAAkB,EAClB,gBAAgB,2BAA2B,CAAC,GAAG,CAAC,GAAG,CACnD;IACD,gEAAgE;IAChE,4FAA4F;IAC5F,4CAA4C;IAC5C,2DAA2D;IAC3D,GAAG,UAAU,CACZ,mCAAmC,EACnC,gBAAgB,2BAA2B,CAAC,GAAG,CAAC,GAAG,CACnD;IACD,qEAAqE;IAErE,8EAA8E;IAE9E,+CAA+C;IAC/C,qMAAqM;IACrM,6CAA6C,2BAA2B,CACvE,GAAG,CACH,4EAA4E,YAAY,uFAAuF,YAAY,yCAAyC,YAAY,OAAO;IACxP,+HAA+H;IAC/H,GAAG,UAAU,CACZ,uBAAuB,EACvB,gBAAgB,2BAA2B,CAAC,GAAG,CAAC,GAAG,EACnD,CAAC,QAAQ,EAAE,QAAQ,CAAC,CACpB;IAED,6DAA6D;IAE7D,
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/lib/auth.ts"],"names":[],"mappings":"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"}
|
@@ -1,2 +1,32 @@
|
|
1
|
-
|
1
|
+
import { hooks, sbvrUtils, errors } from '@balena/pinejs';
|
2
|
+
const addReadOnlyHook = (methods, resource, hook) => {
|
3
|
+
methods.map((method) => {
|
4
|
+
hooks.addHook(method, 'v7', resource, {
|
5
|
+
...hook,
|
6
|
+
sideEffects: false,
|
7
|
+
readOnlyTx: true,
|
8
|
+
});
|
9
|
+
});
|
10
|
+
};
|
11
|
+
addReadOnlyHook(['POST', 'PATCH', 'PUT'], 'device_service_environment_variable', {
|
12
|
+
POSTPARSE: async ({ request, api }) => {
|
13
|
+
const { service_install: siId } = request.values;
|
14
|
+
if (siId == null) {
|
15
|
+
return;
|
16
|
+
}
|
17
|
+
const si = await sbvrUtils.api.resin.get({
|
18
|
+
resource: 'service_install',
|
19
|
+
passthrough: api.passthrough,
|
20
|
+
id: siId,
|
21
|
+
options: {
|
22
|
+
$select: ['device', 'service'],
|
23
|
+
},
|
24
|
+
});
|
25
|
+
if (si == null) {
|
26
|
+
throw new errors.UnauthorizedError();
|
27
|
+
}
|
28
|
+
request.values.device = si.device.__id;
|
29
|
+
request.values.service = si.service.__id;
|
30
|
+
},
|
31
|
+
});
|
2
32
|
//# sourceMappingURL=hooks.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/translations/v7/hooks.ts"],"names":[],"mappings":""}
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/translations/v7/hooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAE1D,MAAM,eAAe,GAAG,CACvB,OAAmD,EACnD,QAAgB,EAChB,IAA2B,EAC1B,EAAE;IACH,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QACtB,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE;YACrC,GAAG,IAAI;YACP,WAAW,EAAE,KAAK;YAClB,UAAU,EAAE,IAAI;SAChB,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,CACd,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,EACxB,qCAAqC,EACrC;IACC,SAAS,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE;QACrC,MAAM,EAAE,eAAe,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;QAEjD,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YAClB,OAAO;QACR,CAAC;QAED,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC;YACxC,QAAQ,EAAE,iBAAiB;YAC3B,WAAW,EAAE,GAAG,CAAC,WAAW;YAC5B,EAAE,EAAE,IAAI;YACR,OAAO,EAAE;gBACR,OAAO,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC;aAC9B;SACD,CAAC,CAAC;QAEH,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;YAChB,MAAM,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;QACtC,CAAC;QAED,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;QACvC,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;IAC1C,CAAC;CACD,CACD,CAAC"}
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@balena/open-balena-api",
|
3
3
|
"description": "Internet of things, Made Simple",
|
4
|
-
"version": "31.2.
|
4
|
+
"version": "31.2.9-build-resolve-dsev-permission-with-device-b5a7e911544591aa75faa4af012969a755abe9ee-1",
|
5
5
|
"license": "AGPL-3.0",
|
6
6
|
"repository": {
|
7
7
|
"type": "git",
|
@@ -166,6 +166,6 @@
|
|
166
166
|
"loader": "ts-node/esm/transpile-only"
|
167
167
|
},
|
168
168
|
"versionist": {
|
169
|
-
"publishedAt": "2024-11-
|
169
|
+
"publishedAt": "2024-11-19T23:44:08.500Z"
|
170
170
|
}
|
171
171
|
}
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import { hooks, errors } from '@balena/pinejs';
|
2
|
-
async function backfillDeviceAndService({ request, api, }) {
|
3
|
-
const { service_install: siId } = request.values;
|
4
|
-
if (siId == null) {
|
5
|
-
return;
|
6
|
-
}
|
7
|
-
const si = await api.get({
|
8
|
-
resource: 'service_install',
|
9
|
-
id: siId,
|
10
|
-
options: {
|
11
|
-
$select: ['device', 'service'],
|
12
|
-
},
|
13
|
-
});
|
14
|
-
if (si == null) {
|
15
|
-
throw new errors.UnauthorizedError();
|
16
|
-
}
|
17
|
-
request.values.device = si.device.__id;
|
18
|
-
request.values.service = si.service.__id;
|
19
|
-
}
|
20
|
-
hooks.addPureHook('POST', 'resin', 'device_service_environment_variable', {
|
21
|
-
POSTPARSE: backfillDeviceAndService,
|
22
|
-
});
|
23
|
-
hooks.addPureHook('PATCH', 'resin', 'device_service_environment_variable', {
|
24
|
-
POSTPARSE: backfillDeviceAndService,
|
25
|
-
});
|
26
|
-
//# sourceMappingURL=backfill-device-service-environment-variable.js.map
|
package/dist/features/service-install/hooks/backfill-device-service-environment-variable.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"backfill-device-service-environment-variable.js","sourceRoot":"","sources":["../../../../src/features/service-install/hooks/backfill-device-service-environment-variable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAkB,MAAM,gBAAgB,CAAC;AAE/D,KAAK,UAAU,wBAAwB,CAAC,EACvC,OAAO,EACP,GAAG,GAC0B;IAC7B,MAAM,EAAE,eAAe,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAEjD,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;QAClB,OAAO;IACR,CAAC;IAED,MAAM,EAAE,GAAG,MAAM,GAAG,CAAC,GAAG,CAAC;QACxB,QAAQ,EAAE,iBAAiB;QAC3B,EAAE,EAAE,IAAI;QACR,OAAO,EAAE;YACR,OAAO,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC;SAC9B;KACD,CAAC,CAAC;IAEH,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QAChB,MAAM,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;IACtC,CAAC;IAED,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;IACvC,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;AAC1C,CAAC;AAED,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,OAAO,EAAE,qCAAqC,EAAE;IACzE,SAAS,EAAE,wBAAwB;CACnC,CAAC,CAAC;AAEH,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,qCAAqC,EAAE;IAC1E,SAAS,EAAE,wBAAwB;CACnC,CAAC,CAAC"}
|