@hestia-earth/api 0.25.49 → 0.25.51
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.
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ISourceJSONLD } from '@hestia-earth/schema';
|
|
2
2
|
import { BaseModel } from '../../db/model.base';
|
|
3
|
-
import { User } from '../../users/model/model';
|
|
3
|
+
import { User, UserRole } from '../../users/model/model';
|
|
4
4
|
export declare const mb = 1048576;
|
|
5
5
|
export declare const sizeInMb: (size: number) => number;
|
|
6
6
|
export declare const maxFileSizeMb = 100;
|
|
@@ -19,9 +19,11 @@ export declare enum HestiaExtensions {
|
|
|
19
19
|
nodes = "hestia",
|
|
20
20
|
progress = "progress",
|
|
21
21
|
log = "log",
|
|
22
|
+
jsonLog = "jlog",
|
|
22
23
|
error = "err",
|
|
23
24
|
json = "json",
|
|
24
|
-
jsonld = "jsonld"
|
|
25
|
+
jsonld = "jsonld",
|
|
26
|
+
contributions = "contributions"
|
|
25
27
|
}
|
|
26
28
|
export declare enum FileFindFields {
|
|
27
29
|
sources = "sources",
|
|
@@ -197,3 +199,4 @@ export declare const canSubmit: (file: Partial<File>, user: User) => boolean;
|
|
|
197
199
|
export declare const isDraft: ({ filepath, filename }: Partial<File>) => boolean;
|
|
198
200
|
export declare const canEditComment: (comment: IFileComment, user: User) => boolean;
|
|
199
201
|
export declare const canCommitHestiaData: (file: File, user: User) => boolean;
|
|
202
|
+
export declare const hasAccess: (file: File, user: User, allowedRoles: UserRole[]) => boolean;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.isAssigned = exports.isAuthorized = exports.isOwner = exports.userFolder = exports.isFolderUpload = exports.isAdminFolder = exports.isAggregation = exports.aggregationFolder = exports.isTerm = exports.isGlossary = exports.hasReconciliationAccess = exports.isReconciliation = exports.isAnalysis = exports.reconciliationFolder = exports.termFolder = exports.glossaryFolder = exports.analysesFolder = exports.filenameFromPath = exports.rootFolderFromPath = exports.folderFromPath = exports.normalizeFolder = exports.isFilepathValid = exports.isFilenameValid = exports.canUploadFolderFile = exports.canUseFolder = exports.replaceInvalidChars = exports.validPathChars = exports.filenameWithoutExt = exports.fileToExt = exports.isSupportedExt = exports.fileExt = exports.filepathSearch = exports.filenameSearch = exports.File = exports.FileValidationStatus = exports.FilePipelineError = exports.FilePipelineProgress = exports.FilePipelineStatus = exports.FileError = exports.FileStatus = exports.FileProgress = exports.FileFindFields = exports.HestiaExtensions = exports.finalFormatExtensions = exports.maxFileSizeByFile = exports.SupportedExtensions = exports.maxFileSize = exports.maxFileSizeMb = exports.sizeInMb = exports.mb = void 0;
|
|
4
|
-
exports.canCommitHestiaData = exports.canEditComment = exports.isDraft = exports.canSubmit = exports.isValidated = exports.canValidate = exports.validatedStatuses = exports.canRemove = void 0;
|
|
4
|
+
exports.hasAccess = exports.canCommitHestiaData = exports.canEditComment = exports.isDraft = exports.canSubmit = exports.isValidated = exports.canValidate = exports.validatedStatuses = exports.canRemove = void 0;
|
|
5
5
|
const model_base_1 = require("../../db/model.base");
|
|
6
6
|
const model_1 = require("../../users/model/model");
|
|
7
7
|
exports.mb = 1048576;
|
|
@@ -34,9 +34,11 @@ var HestiaExtensions;
|
|
|
34
34
|
HestiaExtensions["nodes"] = "hestia";
|
|
35
35
|
HestiaExtensions["progress"] = "progress";
|
|
36
36
|
HestiaExtensions["log"] = "log";
|
|
37
|
+
HestiaExtensions["jsonLog"] = "jlog";
|
|
37
38
|
HestiaExtensions["error"] = "err";
|
|
38
39
|
HestiaExtensions["json"] = "json";
|
|
39
40
|
HestiaExtensions["jsonld"] = "jsonld";
|
|
41
|
+
HestiaExtensions["contributions"] = "contributions";
|
|
40
42
|
})(HestiaExtensions || (exports.HestiaExtensions = HestiaExtensions = {}));
|
|
41
43
|
var FileFindFields;
|
|
42
44
|
(function (FileFindFields) {
|
|
@@ -276,3 +278,16 @@ const canEditComment = (comment, user) => asString(comment?.user) === asString(u
|
|
|
276
278
|
exports.canEditComment = canEditComment;
|
|
277
279
|
const canCommitHestiaData = (file, user) => !file.archived && (0, exports.isValidated)(file) && ((0, model_1.isReviewer)(user) || user?.canCommitHestiaData);
|
|
278
280
|
exports.canCommitHestiaData = canCommitHestiaData;
|
|
281
|
+
const grantAccessByRole = {
|
|
282
|
+
[model_1.UserRole.Admin]: () => true,
|
|
283
|
+
[model_1.UserRole.Reviewer]: (file, user) => !file.isPrivate || (0, exports.isAssigned)(file, user),
|
|
284
|
+
[model_1.UserRole.Developer]: () => false,
|
|
285
|
+
[model_1.UserRole.Researcher]: () => false
|
|
286
|
+
};
|
|
287
|
+
const hasAccess = (file, user, allowedRoles) => [
|
|
288
|
+
(0, model_1.isAdmin)(user),
|
|
289
|
+
(0, exports.hasReconciliationAccess)(file, user),
|
|
290
|
+
(!allowedRoles.length || allowedRoles.includes(user.role)) &&
|
|
291
|
+
((0, exports.isAuthorized)(file, user) || grantAccessByRole[user.role]?.(file, user))
|
|
292
|
+
].some(Boolean);
|
|
293
|
+
exports.hasAccess = hasAccess;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hestia-earth/api",
|
|
3
|
-
"version": "0.25.
|
|
3
|
+
"version": "0.25.51",
|
|
4
4
|
"description": "Hestia API definitions",
|
|
5
5
|
"main": "dist/models.js",
|
|
6
6
|
"typings": "dist/models.d.ts",
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"watch": "tsc --watch",
|
|
15
15
|
"lint": "eslint \"src/**/*.ts\"",
|
|
16
16
|
"lint:fix": "npm run lint -- --fix",
|
|
17
|
-
"test": "jest --runInBand --coverage",
|
|
17
|
+
"test": "jest --runInBand --coverage --forceExit",
|
|
18
18
|
"test:watch": "jest --watch",
|
|
19
19
|
"pre-release": "standard-version --prerelease && git push origin develop --follow-tags",
|
|
20
20
|
"release": "standard-version",
|
|
@@ -36,8 +36,7 @@
|
|
|
36
36
|
"dependencies": {
|
|
37
37
|
"@hestia-earth/json-schema": ">=33.0.0",
|
|
38
38
|
"@hestia-earth/schema": ">=33.0.0",
|
|
39
|
-
"@hestia-earth/utils": ">=0.15.0"
|
|
40
|
-
"passport-gitlab2": "^5.0.0"
|
|
39
|
+
"@hestia-earth/utils": ">=0.15.0"
|
|
41
40
|
},
|
|
42
41
|
"devDependencies": {
|
|
43
42
|
"@aws-sdk/client-cloudwatch": "^3.0.0",
|
|
@@ -60,6 +59,7 @@
|
|
|
60
59
|
"@sentry/serverless": "^7.114.0",
|
|
61
60
|
"@sentry/tracing": "^7.114.0",
|
|
62
61
|
"@slack/web-api": "^6.7.0",
|
|
62
|
+
"@socket.io/redis-adapter": "^8.3.0",
|
|
63
63
|
"@sokratis/passport-linkedin-oauth2": "^2.1.0",
|
|
64
64
|
"@types/compression": "^1.7.2",
|
|
65
65
|
"@types/cors": "^2.8.12",
|
|
@@ -110,6 +110,7 @@
|
|
|
110
110
|
"multer-s3": "^3.0.1",
|
|
111
111
|
"orientjs": "^3.0.11",
|
|
112
112
|
"passport": "^0.4.1",
|
|
113
|
+
"passport-gitlab2": "^5.0.0",
|
|
113
114
|
"passport-google-oauth20": "^2.0.0",
|
|
114
115
|
"passport-orcid": "0.0.4",
|
|
115
116
|
"prettier": "^3.0.3",
|
|
@@ -117,6 +118,7 @@
|
|
|
117
118
|
"redis": "^3.1.2",
|
|
118
119
|
"request": "^2.88.2",
|
|
119
120
|
"request-promise-native": "^1.0.9",
|
|
121
|
+
"socket.io": "^4.8.3",
|
|
120
122
|
"source-map-support": "^0.5.21",
|
|
121
123
|
"standard-version": "^9.3.2",
|
|
122
124
|
"supertest": "^3.4.2",
|