@hestia-earth/api 0.25.50 → 0.25.52

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;
@@ -199,3 +199,4 @@ export declare const canSubmit: (file: Partial<File>, user: User) => boolean;
199
199
  export declare const isDraft: ({ filepath, filename }: Partial<File>) => boolean;
200
200
  export declare const canEditComment: (comment: IFileComment, user: User) => boolean;
201
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;
@@ -278,3 +278,16 @@ const canEditComment = (comment, user) => asString(comment?.user) === asString(u
278
278
  exports.canEditComment = canEditComment;
279
279
  const canCommitHestiaData = (file, user) => !file.archived && (0, exports.isValidated)(file) && ((0, model_1.isReviewer)(user) || user?.canCommitHestiaData);
280
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.50",
3
+ "version": "0.25.52",
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",