@nu-art/file-upload-backend 0.500.0 → 0.500.6
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/core/module-pack.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const ModulePackBE_FileUploader: (import("../modules/ModuleBE_AssetsTemp.js").ModuleBE_AssetsTemp_Class | import("../modules/ModuleBE_BucketListener.js").ModuleBE_BucketListener_Class | import("../modules/ModuleBE_AssetsStorage.js").ModuleBE_AssetsStorage_Class | import("../modules/ModuleBE_AssetsDB.js").ModuleBE_AssetsDB_Class | import("@nu-art/push-pub-sub-backend").ModuleBE_PushPubSub_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushSessionDB").ModuleBE_PushSessionDB_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushSubscriptionDB").ModuleBE_PushSubscriptionDB_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushMessagesHistoryDB").ModuleBE_PushMessagesHistoryDB_Class | import("@nu-art/db-api-backend").ModuleBE_BaseApi_Class<import("@nu-art/push-pub-sub-shared/push-subscription/types").DatabaseDef_PushSubscription & import("@nu-art/db-api-shared").DB_Prototype<any, Omit<any, any>, import("@nu-art/ts-common").SubsetObjectByKeys<any, any
|
|
1
|
+
export declare const ModulePackBE_FileUploader: (import("../modules/ModuleBE_AssetsTemp.js").ModuleBE_AssetsTemp_Class | import("../modules/ModuleBE_BucketListener.js").ModuleBE_BucketListener_Class | import("../modules/ModuleBE_AssetsStorage.js").ModuleBE_AssetsStorage_Class | import("../modules/ModuleBE_AssetsDB.js").ModuleBE_AssetsDB_Class | import("@nu-art/push-pub-sub-backend").ModuleBE_PushPubSub_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushSessionDB").ModuleBE_PushSessionDB_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushSubscriptionDB").ModuleBE_PushSubscriptionDB_Class | import("@nu-art/push-pub-sub-backend/modules/ModuleBE_PushMessagesHistoryDB").ModuleBE_PushMessagesHistoryDB_Class | import("@nu-art/db-api-backend").ModuleBE_BaseApi_Class<import("@nu-art/push-pub-sub-shared/push-subscription/types").DatabaseDef_PushSubscription & import("@nu-art/db-api-shared").DB_Prototype<any, Omit<any, any>, import("@nu-art/ts-common").SubsetObjectByKeys<any, any>>, any> | import("../modules/ModuleBE_AssetsDeleted.js").ModuleBE_AssetsDeleted_Class | import("../modules/ModuleBE_AssetUploader.js").ModuleBE_AssetUploader_Class | import("../modules/ModuleBE_AssetsAPI.js").ModuleBE_AssetsAPI_Class | import("@nu-art/db-api-backend").ModuleBE_BaseApi_Class<import("@nu-art/file-upload-shared").DatabaseDef_AssetsTemp, any> | import("@nu-art/db-api-backend").ModuleBE_BaseApi_Class<import("@nu-art/file-upload-shared").DatabaseDef_Assets, any>)[];
|
package/core/permissions.d.ts
CHANGED
|
@@ -1,6 +1 @@
|
|
|
1
|
-
|
|
2
|
-
import { DefaultDef_Domain, DefaultDef_Package } from '@nu-art/permissions-backend';
|
|
3
|
-
export declare const PermissionsDomain_AssetsManager: Readonly<DefaultDef_Domain>;
|
|
4
|
-
export declare const PermissionsGroup_AssetsManager: Readonly<DefaultDef_Group>;
|
|
5
|
-
export declare const PermissionsGroup_AssetsViewer: Readonly<DefaultDef_Group>;
|
|
6
|
-
export declare const PermissionsPackage_AssetsManager: DefaultDef_Package;
|
|
1
|
+
export {};
|
package/core/permissions.js
CHANGED
|
@@ -1,53 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { ApiDef_Assets, ApiDef_AssetUploader, DBDef_Assets } from '@nu-art/file-upload-shared';
|
|
4
|
-
import { Domain_Developer } from '@nu-art/permissions-backend';
|
|
5
|
-
const AssetsCrudApiDef = CrudApiDef(DBDef_Assets.dbKey);
|
|
6
|
-
const Domain_AssetsManager_ID = '993c496c6aaad9c67723034137d26c42';
|
|
7
|
-
const _PermissionsDomain_AssetsManager = {
|
|
8
|
-
_id: toPermissionDomainId(Domain_AssetsManager_ID),
|
|
9
|
-
namespace: 'Assets',
|
|
10
|
-
dbNames: [],
|
|
11
|
-
customApis: [
|
|
12
|
-
{ path: AssetsCrudApiDef.deleteAll.path, accessLevel: DefaultAccessLevel_Admin.name },
|
|
13
|
-
{ path: AssetsCrudApiDef.deleteQuery.path, accessLevel: DefaultAccessLevel_Admin.name },
|
|
14
|
-
{ path: AssetsCrudApiDef.upsertAll.path, accessLevel: DefaultAccessLevel_Admin.name },
|
|
15
|
-
{ path: AssetsCrudApiDef.upsert.path, accessLevel: DefaultAccessLevel_Admin.name },
|
|
16
|
-
{ path: AssetsCrudApiDef.deleteUnique.path, accessLevel: DefaultAccessLevel_Delete.name },
|
|
17
|
-
{ path: AssetsCrudApiDef.queryUnique.path, accessLevel: DefaultAccessLevel_Read.name },
|
|
18
|
-
{ path: AssetsCrudApiDef.query.path, accessLevel: DefaultAccessLevel_Read.name },
|
|
19
|
-
{ path: ApiDef_Assets.getReadSignedUrl.path, accessLevel: DefaultAccessLevel_Read.name },
|
|
20
|
-
{ path: ApiDef_AssetUploader.getUploadUrl.path, accessLevel: DefaultAccessLevel_Write.name },
|
|
21
|
-
{
|
|
22
|
-
path: ApiDef_AssetUploader.processAssetManually.path,
|
|
23
|
-
domainId: Domain_Developer._id,
|
|
24
|
-
accessLevel: DefaultAccessLevel_Write.name
|
|
25
|
-
},
|
|
26
|
-
]
|
|
27
|
-
};
|
|
28
|
-
export const PermissionsDomain_AssetsManager = Object.freeze(_PermissionsDomain_AssetsManager);
|
|
29
|
-
const PermissionsGroupId_AssetsViewer = '0773dcf3b9fbe5e595ef6e2a596b8939';
|
|
30
|
-
const PermissionsGroupId_AssetsManager = '3f5037358fba0ae1199047f2fa8add94';
|
|
31
|
-
const _PermissionsGroup_AssetsViewer = {
|
|
32
|
-
_id: toPermissionGroupId(PermissionsGroupId_AssetsViewer),
|
|
33
|
-
name: 'Assets Viewer',
|
|
34
|
-
uiLabel: 'Assets Viewer',
|
|
35
|
-
accessLevels: {
|
|
36
|
-
[PermissionsDomain_AssetsManager.namespace]: DefaultAccessLevel_Read.name,
|
|
37
|
-
}
|
|
38
|
-
};
|
|
39
|
-
const _PermissionsGroup_AssetsManager = {
|
|
40
|
-
_id: toPermissionGroupId(PermissionsGroupId_AssetsManager),
|
|
41
|
-
name: 'Assets Manager',
|
|
42
|
-
uiLabel: 'Assets Manager',
|
|
43
|
-
accessLevels: {
|
|
44
|
-
[PermissionsDomain_AssetsManager.namespace]: DefaultAccessLevel_Delete.name,
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
export const PermissionsGroup_AssetsManager = Object.freeze(_PermissionsGroup_AssetsManager);
|
|
48
|
-
export const PermissionsGroup_AssetsViewer = Object.freeze(_PermissionsGroup_AssetsViewer);
|
|
49
|
-
export const PermissionsPackage_AssetsManager = {
|
|
50
|
-
name: PermissionsDomain_AssetsManager.namespace,
|
|
51
|
-
domains: [PermissionsDomain_AssetsManager],
|
|
52
|
-
groups: [PermissionsGroup_AssetsViewer, PermissionsGroup_AssetsManager]
|
|
53
|
-
};
|
|
1
|
+
export {};
|
|
2
|
+
// Legacy domain-level permissions removed; use scope-based permissions.
|
|
@@ -3,10 +3,9 @@ import { ModuleBE_BaseDB, PostWriteProcessingDataShape } from '@nu-art/db-api-ba
|
|
|
3
3
|
import { Clause_Where } from '@nu-art/firebase-shared';
|
|
4
4
|
import { OnAssetUploaded } from './ModuleBE_BucketListener.js';
|
|
5
5
|
import { API_AssetUploader, DB_Asset, DatabaseDef_Assets, TempSignedUrl, UI_Asset } from '@nu-art/file-upload-shared';
|
|
6
|
-
import { CollectionActionType } from '@nu-art/firebase-backend/firestore
|
|
6
|
+
import { CollectionActionType } from '@nu-art/firebase-backend/firestore/FirestoreCollection';
|
|
7
7
|
import { FileMetadata } from '@google-cloud/storage';
|
|
8
8
|
import { FileWrapper } from '@nu-art/firebase-backend';
|
|
9
|
-
import { Transaction } from 'firebase-admin/firestore';
|
|
10
9
|
/** Local type for cleanup scheduler (replaces thunderstorm-backend). */
|
|
11
10
|
export type CleanupDetails = {
|
|
12
11
|
moduleKey: string;
|
|
@@ -43,13 +42,13 @@ export declare class ModuleBE_AssetsDB_Class extends ModuleBE_BaseDB<DatabaseDef
|
|
|
43
42
|
constructor();
|
|
44
43
|
mimeTypeValidator: TypedMap<FileValidator>;
|
|
45
44
|
fileValidator: TypedMap<FileTypeValidation>;
|
|
46
|
-
protected postWriteProcessing(data: PostWriteProcessingDataShape<DB_Asset>, actionType: CollectionActionType
|
|
45
|
+
protected postWriteProcessing(data: PostWriteProcessingDataShape<DB_Asset>, actionType: CollectionActionType): Promise<void>;
|
|
47
46
|
getUploadUrl(body: API_AssetUploader['getUploadUrl']['Body']): Promise<API_AssetUploader['getUploadUrl']['Response']>;
|
|
48
47
|
processAssetManually(params: API_AssetUploader['processAssetManually']['Params']): Promise<API_AssetUploader['processAssetManually']['Response']>;
|
|
49
48
|
init(): void;
|
|
50
49
|
getAssetsContent(assetIds: string[]): Promise<AssetContent[]>;
|
|
51
50
|
registerTypeValidator(mimeType: string, validator: (file: FileWrapper, doc: DB_Asset) => Promise<void>): void;
|
|
52
|
-
queryUnique(where: Clause_Where<DB_Asset
|
|
51
|
+
queryUnique(where: Clause_Where<DB_Asset>): Promise<DB_Asset>;
|
|
53
52
|
register: (key: string, validationConfig: FileTypeValidation) => void;
|
|
54
53
|
__onCleanupSchedulerAct(): CleanupDetails;
|
|
55
54
|
private cleanup;
|
|
@@ -99,10 +99,10 @@ let ModuleBE_AssetsDB_Class = (() => {
|
|
|
99
99
|
}
|
|
100
100
|
mimeTypeValidator = (__runInitializers(this, _instanceExtraInitializers), {});
|
|
101
101
|
fileValidator = {};
|
|
102
|
-
async postWriteProcessing(data, actionType
|
|
102
|
+
async postWriteProcessing(data, actionType) {
|
|
103
103
|
const deleted = data.deleted ? (Array.isArray(data.deleted) ? data.deleted : [data.deleted]) : [];
|
|
104
104
|
if (deleted.length)
|
|
105
|
-
await ModuleBE_AssetsDeleted.set.all(deleted
|
|
105
|
+
await ModuleBE_AssetsDeleted.set.all(deleted);
|
|
106
106
|
}
|
|
107
107
|
async getUploadUrl(body) {
|
|
108
108
|
return this.getUrl(body);
|
|
@@ -122,8 +122,8 @@ let ModuleBE_AssetsDB_Class = (() => {
|
|
|
122
122
|
const originalQuery = this.query;
|
|
123
123
|
this.query = {
|
|
124
124
|
...originalQuery,
|
|
125
|
-
unique: async (_id
|
|
126
|
-
const dbAsset = await originalQuery.uniqueAssert(_id
|
|
125
|
+
unique: async (_id) => {
|
|
126
|
+
const dbAsset = await originalQuery.uniqueAssert(_id);
|
|
127
127
|
const signedUrl = (dbAsset.signedUrl?.validUntil || 0) > currentTimeMillis() ? dbAsset.signedUrl : undefined;
|
|
128
128
|
if (!signedUrl) {
|
|
129
129
|
const url = await ModuleBE_AssetsStorage.getReadSignedUrl(dbAsset);
|
|
@@ -144,7 +144,7 @@ let ModuleBE_AssetsDB_Class = (() => {
|
|
|
144
144
|
}
|
|
145
145
|
registerTypeValidator(mimeType, validator) {
|
|
146
146
|
}
|
|
147
|
-
async queryUnique(where
|
|
147
|
+
async queryUnique(where) {
|
|
148
148
|
const dbAsset = await this.query.uniqueCustom({ where });
|
|
149
149
|
const signedUrl = (dbAsset.signedUrl?.validUntil || 0) > currentTimeMillis() ? dbAsset.signedUrl : undefined;
|
|
150
150
|
if (!signedUrl) {
|
|
@@ -273,16 +273,16 @@ let ModuleBE_AssetsDB_Class = (() => {
|
|
|
273
273
|
return this.notifyFrontend(FileStatus.ErrorMakingPublic, assetForApi);
|
|
274
274
|
}
|
|
275
275
|
}
|
|
276
|
-
const finalDbAsset = await this.runTransaction(async (
|
|
277
|
-
const duplicatedAssets = await this.query.custom({ where: { md5Hash: dbTempAsset.md5Hash } }
|
|
276
|
+
const finalDbAsset = await this.runTransaction(async () => {
|
|
277
|
+
const duplicatedAssets = await this.query.custom({ where: { md5Hash: dbTempAsset.md5Hash } });
|
|
278
278
|
if (duplicatedAssets.length && duplicatedAssets[0]) {
|
|
279
279
|
this.logWarning(`${dbTempAsset.feId} is a duplicated entry for ${duplicatedAssets[0]._id}`);
|
|
280
280
|
return { ...duplicatedAssets[0], feId: dbTempAsset.feId };
|
|
281
281
|
}
|
|
282
|
-
const doc = this.
|
|
283
|
-
await ModuleBE_AssetsTemp.delete.unique(dbTempAsset._id
|
|
282
|
+
const doc = this.doc.item(assetForApi);
|
|
283
|
+
await ModuleBE_AssetsTemp.delete.unique(dbTempAsset._id);
|
|
284
284
|
const assetForMain = { ...dbTempAsset, _id: dbTempAsset._id };
|
|
285
|
-
return await doc.set(assetForMain
|
|
285
|
+
return await doc.set(assetForMain);
|
|
286
286
|
});
|
|
287
287
|
return this.notifyFrontend(FileStatus.Completed, finalDbAsset);
|
|
288
288
|
};
|
|
@@ -18,7 +18,6 @@
|
|
|
18
18
|
import { BadImplementationException, Dispatcher } from '@nu-art/ts-common';
|
|
19
19
|
import { MemStorage } from '@nu-art/ts-common/mem-storage/MemStorage';
|
|
20
20
|
import { ModuleBE_StorageListener } from '@nu-art/firebase-backend';
|
|
21
|
-
import { PermissionsGroup_PushMessanger } from '@nu-art/push-pub-sub-backend/core/permissions';
|
|
22
21
|
import { MemKey_AccountId } from '@nu-art/user-account-backend';
|
|
23
22
|
const dispatcher_onAssetUploaded = new Dispatcher('__processAsset');
|
|
24
23
|
export class ModuleBE_BucketListener_Class extends ModuleBE_StorageListener {
|
|
@@ -46,7 +45,7 @@ export class ModuleBE_BucketListener_Class extends ModuleBE_StorageListener {
|
|
|
46
45
|
const serviceAccount = {
|
|
47
46
|
moduleName: this.getName(),
|
|
48
47
|
email: 'bucket-manager@nu-art-software.com',
|
|
49
|
-
groupIds: [
|
|
48
|
+
groupIds: []
|
|
50
49
|
};
|
|
51
50
|
return serviceAccount;
|
|
52
51
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nu-art/file-upload-backend",
|
|
3
|
-
"version": "0.500.
|
|
3
|
+
"version": "0.500.6",
|
|
4
4
|
"description": "File Uploader - Express & Typescript based backend framework Backend",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"TacB0sS",
|
|
@@ -30,23 +30,23 @@
|
|
|
30
30
|
"build": "tsc"
|
|
31
31
|
},
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@nu-art/file-upload-shared": "0.500.
|
|
33
|
+
"@nu-art/file-upload-shared": "0.500.6",
|
|
34
34
|
"@google-cloud/common": "^5.0.2",
|
|
35
35
|
"@google-cloud/firestore": "^7.11.0",
|
|
36
36
|
"@google-cloud/storage": "^7.15.0",
|
|
37
|
-
"@nu-art/firebase-backend": "0.500.
|
|
38
|
-
"@nu-art/firebase-shared": "0.500.
|
|
39
|
-
"@nu-art/permissions-backend": "0.500.
|
|
40
|
-
"@nu-art/permissions-shared": "0.500.
|
|
41
|
-
"@nu-art/push-pub-sub-backend": "0.500.
|
|
42
|
-
"@nu-art/push-pub-sub-shared": "0.500.
|
|
43
|
-
"@nu-art/api-types": "
|
|
44
|
-
"@nu-art/db-api-backend": "0.500.
|
|
45
|
-
"@nu-art/db-api-shared": "0.500.
|
|
46
|
-
"@nu-art/http-server": "
|
|
47
|
-
"@nu-art/ts-common": "0.500.
|
|
48
|
-
"@nu-art/user-account-backend": "0.500.
|
|
49
|
-
"@nu-art/user-account-shared": "0.500.
|
|
37
|
+
"@nu-art/firebase-backend": "0.500.6",
|
|
38
|
+
"@nu-art/firebase-shared": "0.500.6",
|
|
39
|
+
"@nu-art/permissions-backend": "0.500.6",
|
|
40
|
+
"@nu-art/permissions-shared": "0.500.6",
|
|
41
|
+
"@nu-art/push-pub-sub-backend": "0.500.6",
|
|
42
|
+
"@nu-art/push-pub-sub-shared": "0.500.6",
|
|
43
|
+
"@nu-art/api-types": "0.500.6",
|
|
44
|
+
"@nu-art/db-api-backend": "0.500.6",
|
|
45
|
+
"@nu-art/db-api-shared": "0.500.6",
|
|
46
|
+
"@nu-art/http-server": "0.500.6",
|
|
47
|
+
"@nu-art/ts-common": "0.500.6",
|
|
48
|
+
"@nu-art/user-account-backend": "0.500.6",
|
|
49
|
+
"@nu-art/user-account-shared": "0.500.6",
|
|
50
50
|
"express": "^4.18.2",
|
|
51
51
|
"file-type": "^21.0.0",
|
|
52
52
|
"firebase": "^11.9.0",
|