@qrvey/assets-sharing 0.1.6 → 0.2.0
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/dist/cjs/context.js +6 -0
- package/dist/cjs/context.js.map +1 -1
- package/dist/cjs/quser/implementations/group.model.js +19 -0
- package/dist/cjs/quser/implementations/group.model.js.map +1 -0
- package/dist/cjs/quser/implementations/group.repository.js +19 -0
- package/dist/cjs/quser/implementations/group.repository.js.map +1 -0
- package/dist/cjs/quser/interfaces/rolesRepository.interface.js +3 -0
- package/dist/cjs/quser/interfaces/rolesRepository.interface.js.map +1 -0
- package/dist/cjs/sharing/implementations/details.repository.js +11 -0
- package/dist/cjs/sharing/implementations/details.repository.js.map +1 -1
- package/dist/cjs/sharing/implementations/dm.model.js +22 -0
- package/dist/cjs/sharing/implementations/dm.model.js.map +1 -0
- package/dist/cjs/sharing/implementations/dm.repository.js +20 -0
- package/dist/cjs/sharing/implementations/dm.repository.js.map +1 -0
- package/dist/cjs/sharing/implementations/dx.model.js +30 -0
- package/dist/cjs/sharing/implementations/dx.model.js.map +1 -0
- package/dist/cjs/sharing/implementations/dx.repository.js +21 -0
- package/dist/cjs/sharing/implementations/dx.repository.js.map +1 -0
- package/dist/cjs/sharing/interfaces/dashboardRepository.interface.js +3 -0
- package/dist/cjs/sharing/interfaces/dashboardRepository.interface.js.map +1 -0
- package/dist/cjs/sharing/interfaces/downloadManagerRepository.interface.js +3 -0
- package/dist/cjs/sharing/interfaces/downloadManagerRepository.interface.js.map +1 -0
- package/dist/cjs/sharing/services/upsert.js +76 -19
- package/dist/cjs/sharing/services/upsert.js.map +1 -1
- package/dist/esm/index.mjs +230 -49
- package/dist/esm/index.mjs.map +1 -1
- package/dist/types/index.d.ts +10 -9
- package/package.json +1 -1
- package/src/context.ts +15 -0
- package/src/quser/implementations/group.model.ts +18 -0
- package/src/quser/implementations/group.repository.ts +20 -0
- package/src/quser/interfaces/rolesRepository.interface.ts +3 -0
- package/src/sharing/implementations/details.repository.ts +15 -0
- package/src/sharing/implementations/dm.model.ts +21 -0
- package/src/sharing/implementations/dm.repository.ts +23 -0
- package/src/sharing/implementations/dx.model.ts +30 -0
- package/src/sharing/implementations/dx.repository.ts +22 -0
- package/src/sharing/interfaces/dashboardRepository.interface.ts +3 -0
- package/src/sharing/interfaces/detailsRepository.interface.ts +11 -0
- package/src/sharing/interfaces/downloadManagerRepository.interface.ts +3 -0
- package/src/sharing/services/upsert.ts +115 -31
package/dist/cjs/context.js
CHANGED
|
@@ -2,11 +2,17 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Context = void 0;
|
|
4
4
|
const tsyringe_1 = require("tsyringe");
|
|
5
|
+
const group_repository_1 = require("./quser/implementations/group.repository");
|
|
5
6
|
const user_repository_1 = require("./quser/implementations/user.repository");
|
|
6
7
|
const details_repository_1 = require("./sharing/implementations/details.repository");
|
|
8
|
+
const dm_repository_1 = require("./sharing/implementations/dm.repository");
|
|
9
|
+
const dx_repository_1 = require("./sharing/implementations/dx.repository");
|
|
7
10
|
const sharing_repository_1 = require("./sharing/implementations/sharing.repository");
|
|
8
11
|
tsyringe_1.container.register('SharingRepository', sharing_repository_1.SharingRepository);
|
|
9
12
|
tsyringe_1.container.register('SharingDetailsRepository', details_repository_1.SharingDetailsRepository);
|
|
10
13
|
tsyringe_1.container.register('UserRepository', user_repository_1.UserRepository);
|
|
14
|
+
tsyringe_1.container.register('RoleRepository', group_repository_1.GroupRepository);
|
|
15
|
+
tsyringe_1.container.register('dxRepository', dx_repository_1.DashboardRepository);
|
|
16
|
+
tsyringe_1.container.register('dmRepository', dm_repository_1.DownloadManagerRepository);
|
|
11
17
|
exports.Context = tsyringe_1.container;
|
|
12
18
|
//# sourceMappingURL=context.js.map
|
package/dist/cjs/context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/context.ts"],"names":[],"mappings":";;;AAAA,uCAAqC;AAErC,6EAAyE;
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/context.ts"],"names":[],"mappings":";;;AAAA,uCAAqC;AAErC,+EAA2E;AAC3E,6EAAyE;AAGzE,qFAAwF;AACxF,2EAAoF;AACpF,2EAA8E;AAC9E,qFAAiF;AAMjF,oBAAS,CAAC,QAAQ,CACd,mBAAmB,EACnB,sCAAiB,CACpB,CAAC;AACF,oBAAS,CAAC,QAAQ,CACd,0BAA0B,EAC1B,6CAAwB,CAC3B,CAAC;AACF,oBAAS,CAAC,QAAQ,CAA0B,gBAAgB,EAAE,gCAAc,CAAC,CAAC;AAC9E,oBAAS,CAAC,QAAQ,CAA0B,gBAAgB,EAAE,kCAAe,CAAC,CAAC;AAC/E,oBAAS,CAAC,QAAQ,CACd,cAAc,EACd,mCAAmB,CACtB,CAAC;AACF,oBAAS,CAAC,QAAQ,CACd,cAAc,EACd,yCAAyB,CAC5B,CAAC;AAEW,QAAA,OAAO,GAAG,oBAAS,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GroupModel = void 0;
|
|
4
|
+
const data_persistence_1 = require("@qrvey/data-persistence");
|
|
5
|
+
const constants_1 = require("../../common/constants");
|
|
6
|
+
class GroupModel extends data_persistence_1.CrudSchema {
|
|
7
|
+
}
|
|
8
|
+
exports.GroupModel = GroupModel;
|
|
9
|
+
GroupModel.table = {
|
|
10
|
+
name: `${constants_1.DATABASE_INFO.SERVER_PREFIX}Groups`,
|
|
11
|
+
alias: 'qv_groups',
|
|
12
|
+
};
|
|
13
|
+
GroupModel.columns = {
|
|
14
|
+
groupid: {
|
|
15
|
+
type: 'string',
|
|
16
|
+
},
|
|
17
|
+
};
|
|
18
|
+
GroupModel.schema = constants_1.DATABASE_INFO.DATA_PERSISTENCE_SCHEMA;
|
|
19
|
+
//# sourceMappingURL=group.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"group.model.js","sourceRoot":"","sources":["../../../../src/quser/implementations/group.model.ts"],"names":[],"mappings":";;;AAAA,8DAAqD;AAErD,sDAAuD;AAEvD,MAAa,UAAW,SAAQ,6BAAU;;AAA1C,gCAaC;AAZU,gBAAK,GAAG;IACX,IAAI,EAAE,GAAG,yBAAa,CAAC,aAAa,QAAQ;IAC5C,KAAK,EAAE,WAAW;CACrB,CAAC;AAEK,kBAAO,GAAG;IACb,OAAO,EAAE;QACL,IAAI,EAAE,QAAQ;KACjB;CACJ,CAAC;AAEK,iBAAM,GAAG,yBAAa,CAAC,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GroupRepository = void 0;
|
|
4
|
+
const group_model_1 = require("./group.model");
|
|
5
|
+
const base_1 = require("../../common/persistence/base");
|
|
6
|
+
class GroupRepository extends base_1.BaseRepository {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(group_model_1.GroupModel);
|
|
9
|
+
}
|
|
10
|
+
async getOne(identifier) {
|
|
11
|
+
const params = {
|
|
12
|
+
filters: [this.filter('groupid', identifier)],
|
|
13
|
+
};
|
|
14
|
+
const response = await super.findItem(params);
|
|
15
|
+
return response;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.GroupRepository = GroupRepository;
|
|
19
|
+
//# sourceMappingURL=group.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"group.repository.js","sourceRoot":"","sources":["../../../../src/quser/implementations/group.repository.ts"],"names":[],"mappings":";;;AAAA,+CAA2C;AAC3C,wDAA+D;AAG/D,MAAa,eACT,SAAQ,qBAAc;IAGtB;QACI,KAAK,CAAC,wBAAU,CAAC,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,UAAkB;QAC3B,MAAM,MAAM,GAAG;YACX,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;SAChD,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC9C,OAAO,QAA+B,CAAC;IAC3C,CAAC;CACJ;AAfD,0CAeC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rolesRepository.interface.js","sourceRoot":"","sources":["../../../../src/quser/interfaces/rolesRepository.interface.ts"],"names":[],"mappings":""}
|
|
@@ -15,6 +15,17 @@ class SharingDetailsRepository extends base_1.BaseRepository {
|
|
|
15
15
|
const response = await super.findItem(params);
|
|
16
16
|
return response;
|
|
17
17
|
}
|
|
18
|
+
async getBySharedWith(assetId, sharedWith) {
|
|
19
|
+
const filterList = [
|
|
20
|
+
this.filter('asset_id', assetId),
|
|
21
|
+
this.filter('shared_with', sharedWith),
|
|
22
|
+
];
|
|
23
|
+
const params = {
|
|
24
|
+
filters: filterList,
|
|
25
|
+
};
|
|
26
|
+
const response = await super.findItem(params);
|
|
27
|
+
return response;
|
|
28
|
+
}
|
|
18
29
|
async getList(options) {
|
|
19
30
|
const assetIndex = details_model_1.SharingDetailsModel.indexes.sharingDetailsAssetId;
|
|
20
31
|
const pagination = this.getPagination(options.pagination);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"details.repository.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/details.repository.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"details.repository.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/details.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DownloadManagerSchema = void 0;
|
|
4
|
+
const data_persistence_1 = require("@qrvey/data-persistence");
|
|
5
|
+
const constants_1 = require("../../common/constants");
|
|
6
|
+
class DownloadManagerSchema extends data_persistence_1.CrudSchema {
|
|
7
|
+
}
|
|
8
|
+
exports.DownloadManagerSchema = DownloadManagerSchema;
|
|
9
|
+
DownloadManagerSchema.table = {
|
|
10
|
+
name: `${constants_1.DATABASE_INFO.SERVER_PREFIX}DownloadManager`,
|
|
11
|
+
alias: `${constants_1.DATABASE_INFO.TABLE_PREFIX}_download_manager`,
|
|
12
|
+
};
|
|
13
|
+
DownloadManagerSchema.columns = {
|
|
14
|
+
downloadManagerId: {
|
|
15
|
+
primary: true,
|
|
16
|
+
type: 'String',
|
|
17
|
+
columnId: true,
|
|
18
|
+
},
|
|
19
|
+
};
|
|
20
|
+
DownloadManagerSchema.schema = 'exports';
|
|
21
|
+
DownloadManagerSchema.usePool = true;
|
|
22
|
+
//# sourceMappingURL=dm.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dm.model.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/dm.model.ts"],"names":[],"mappings":";;;AAAA,8DAAqD;AAErD,sDAAuD;AAEvD,MAAa,qBAAsB,SAAQ,6BAAU;;AAArD,sDAgBC;AAfU,2BAAK,GAAG;IACX,IAAI,EAAE,GAAG,yBAAa,CAAC,aAAa,iBAAiB;IACrD,KAAK,EAAE,GAAG,yBAAa,CAAC,YAAY,mBAAmB;CAC1D,CAAC;AAEK,6BAAO,GAAG;IACb,iBAAiB,EAAE;QACf,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,IAAI;KACjB;CACJ,CAAC;AAEK,4BAAM,GAAG,SAAS,CAAC;AACnB,6BAAO,GAAG,IAAI,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DownloadManagerRepository = void 0;
|
|
4
|
+
const dm_model_1 = require("./dm.model");
|
|
5
|
+
const base_1 = require("../../common/persistence/base");
|
|
6
|
+
class DownloadManagerRepository extends base_1.BaseRepository {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(dm_model_1.DownloadManagerSchema);
|
|
9
|
+
}
|
|
10
|
+
async get(identifier) {
|
|
11
|
+
const filterList = [this.filter('downloadManagerId', identifier)];
|
|
12
|
+
const params = {
|
|
13
|
+
filters: filterList,
|
|
14
|
+
};
|
|
15
|
+
const response = await super.findItem(params);
|
|
16
|
+
return response;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.DownloadManagerRepository = DownloadManagerRepository;
|
|
20
|
+
//# sourceMappingURL=dm.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dm.repository.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/dm.repository.ts"],"names":[],"mappings":";;;AAAA,yCAAmD;AACnD,wDAA+D;AAG/D,MAAa,yBACT,SAAQ,qBAAc;IAGtB;QACI,KAAK,CAAC,gCAAqB,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,GAAG,CACL,UAAkB;QAElB,MAAM,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,UAAU,CAAC,CAAC,CAAC;QAClE,MAAM,MAAM,GAAG;YACX,OAAO,EAAE,UAAU;SACtB,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC9C,OAAO,QAAyC,CAAC;IACrD,CAAC;CACJ;AAlBD,8DAkBC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DashboardSchema = void 0;
|
|
4
|
+
const data_persistence_1 = require("@qrvey/data-persistence");
|
|
5
|
+
const constants_1 = require("../../common/constants");
|
|
6
|
+
class DashboardSchema extends data_persistence_1.CrudSchema {
|
|
7
|
+
}
|
|
8
|
+
exports.DashboardSchema = DashboardSchema;
|
|
9
|
+
DashboardSchema.table = {
|
|
10
|
+
name: `${constants_1.DATABASE_INFO.SERVER_PREFIX}_dx_dashboard`,
|
|
11
|
+
alias: `${constants_1.DATABASE_INFO.TABLE_PREFIX}_dashboard`,
|
|
12
|
+
};
|
|
13
|
+
DashboardSchema.columns = {
|
|
14
|
+
ResourceUID: { type: 'string', primary: true },
|
|
15
|
+
dashboardId: { type: 'string' },
|
|
16
|
+
contentId: { type: 'string' },
|
|
17
|
+
userId: { type: 'string' },
|
|
18
|
+
ownerId: { type: 'string' },
|
|
19
|
+
appId: { type: 'string' },
|
|
20
|
+
qvAttributes: { type: 'object' },
|
|
21
|
+
};
|
|
22
|
+
DashboardSchema.indexes = {
|
|
23
|
+
ResourceUID: {
|
|
24
|
+
name: 'MetadataByResource',
|
|
25
|
+
columns: ['Metadata', 'ResourceUID'],
|
|
26
|
+
},
|
|
27
|
+
};
|
|
28
|
+
DashboardSchema.schema = 'dashboard_x';
|
|
29
|
+
DashboardSchema.usePool = true;
|
|
30
|
+
//# sourceMappingURL=dx.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dx.model.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/dx.model.ts"],"names":[],"mappings":";;;AAAA,8DAAqD;AAErD,sDAAuD;AAEvD,MAAa,eAAgB,SAAQ,6BAAU;;AAA/C,0CAyBC;AAxBU,qBAAK,GAAG;IACX,IAAI,EAAE,GAAG,yBAAa,CAAC,aAAa,eAAe;IACnD,KAAK,EAAE,GAAG,yBAAa,CAAC,YAAY,YAAY;CACnD,CAAC;AAEK,uBAAO,GAAG;IACb,WAAW,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE;IAC9C,WAAW,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;IAC/B,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;IAC7B,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;IAC1B,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;IAC3B,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;IACzB,YAAY,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;CACnC,CAAC;AAEK,uBAAO,GAAG;IACb,WAAW,EAAE;QACT,IAAI,EAAE,oBAAoB;QAC1B,OAAO,EAAE,CAAC,UAAU,EAAE,aAAa,CAAC;KACvC;CACJ,CAAC;AAEK,sBAAM,GAAG,aAAa,CAAC;AACvB,uBAAO,GAAG,IAAI,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DashboardRepository = void 0;
|
|
4
|
+
const dx_model_1 = require("./dx.model");
|
|
5
|
+
const base_1 = require("../../common/persistence/base");
|
|
6
|
+
class DashboardRepository extends base_1.BaseRepository {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(dx_model_1.DashboardSchema);
|
|
9
|
+
}
|
|
10
|
+
async get(identifier) {
|
|
11
|
+
const uid = `DASHBOARD=${identifier}&BRANCH=MAIN`;
|
|
12
|
+
const filterList = [this.filter('ResourceUID', uid)];
|
|
13
|
+
const params = {
|
|
14
|
+
filters: filterList,
|
|
15
|
+
};
|
|
16
|
+
const response = await super.findItem(params);
|
|
17
|
+
return response;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.DashboardRepository = DashboardRepository;
|
|
21
|
+
//# sourceMappingURL=dx.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dx.repository.js","sourceRoot":"","sources":["../../../../src/sharing/implementations/dx.repository.ts"],"names":[],"mappings":";;;AAAA,yCAA6C;AAC7C,wDAA+D;AAG/D,MAAa,mBACT,SAAQ,qBAAc;IAGtB;QACI,KAAK,CAAC,0BAAe,CAAC,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,UAAkB;QACxB,MAAM,GAAG,GAAG,aAAa,UAAU,cAAc,CAAC;QAClD,MAAM,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC;QACrD,MAAM,MAAM,GAAG;YACX,OAAO,EAAE,UAAU;SACtB,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC9C,OAAO,QAAmC,CAAC;IAC/C,CAAC;CACJ;AAjBD,kDAiBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboardRepository.interface.js","sourceRoot":"","sources":["../../../../src/sharing/interfaces/dashboardRepository.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"downloadManagerRepository.interface.js","sourceRoot":"","sources":["../../../../src/sharing/interfaces/downloadManagerRepository.interface.ts"],"names":[],"mappings":""}
|
|
@@ -15,12 +15,19 @@ const constants_1 = require("../../common/constants");
|
|
|
15
15
|
const details_1 = require("../entities/details");
|
|
16
16
|
const sharing_1 = require("../entities/sharing");
|
|
17
17
|
let UpsertSharing = class UpsertSharing {
|
|
18
|
-
constructor(sharingRepository, detailsRepository) {
|
|
18
|
+
constructor(sharingRepository, detailsRepository, dxRepository, dmRepository, userRepository, roleRepository) {
|
|
19
19
|
this.sharingRepository = sharingRepository;
|
|
20
20
|
this.detailsRepository = detailsRepository;
|
|
21
|
+
this.dxRepository = dxRepository;
|
|
22
|
+
this.dmRepository = dmRepository;
|
|
23
|
+
this.userRepository = userRepository;
|
|
24
|
+
this.roleRepository = roleRepository;
|
|
21
25
|
}
|
|
22
26
|
async execute({ body, }) {
|
|
23
27
|
const assetId = body.assetId;
|
|
28
|
+
const isValidAsset = await this.validateIfAssetExists(assetId, body.assetType);
|
|
29
|
+
if (!isValidAsset)
|
|
30
|
+
throw new Error(`Asset with ID ${assetId} not found`);
|
|
24
31
|
const sharing = await this.sharingRepository.getOne(assetId);
|
|
25
32
|
let currentSharing;
|
|
26
33
|
if (sharing) {
|
|
@@ -28,7 +35,7 @@ let UpsertSharing = class UpsertSharing {
|
|
|
28
35
|
}
|
|
29
36
|
else {
|
|
30
37
|
const createSharing = {
|
|
31
|
-
assetId
|
|
38
|
+
assetId,
|
|
32
39
|
assetType: body.assetType,
|
|
33
40
|
};
|
|
34
41
|
currentSharing = sharing_1.Sharing.create(createSharing);
|
|
@@ -43,28 +50,74 @@ let UpsertSharing = class UpsertSharing {
|
|
|
43
50
|
await this.sharingRepository.patch(currentSharing.getAssetId, currentSharing.toTable());
|
|
44
51
|
return updatedList.map((detail) => detail.toJSON());
|
|
45
52
|
}
|
|
53
|
+
async validateIfAssetExists(assetId, assetType) {
|
|
54
|
+
switch (assetType) {
|
|
55
|
+
case constants_1.ASSET_TYPE.DX: {
|
|
56
|
+
const result = await this.dxRepository.get(assetId);
|
|
57
|
+
if (result)
|
|
58
|
+
return true;
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
61
|
+
case constants_1.ASSET_TYPE.DM: {
|
|
62
|
+
const result = await this.dmRepository.get(assetId);
|
|
63
|
+
if (result)
|
|
64
|
+
return true;
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
default:
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
46
71
|
async addDetails(assetId, list) {
|
|
47
|
-
var _a;
|
|
48
72
|
const sharingList = [];
|
|
49
73
|
for (const detail of list) {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
: await this.detailsRepository.getOne(detail.sharedId);
|
|
54
|
-
if (sharingDetail) {
|
|
55
|
-
currentDetail = details_1.SharingDetail.parse(sharingDetail);
|
|
56
|
-
currentDetail.update(detail);
|
|
57
|
-
await this.detailsRepository.patch(currentDetail.getSharingDetailsId, currentDetail.toTable());
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
const createDetails = Object.assign({ assetId: assetId, orgId: (_a = detail.orgId) !== null && _a !== void 0 ? _a : constants_1.ORGANIZATION_QRVEY }, detail);
|
|
61
|
-
currentDetail = details_1.SharingDetail.create(createDetails);
|
|
62
|
-
await this.detailsRepository.create(currentDetail.toTable());
|
|
63
|
-
}
|
|
64
|
-
sharingList.push(currentDetail);
|
|
74
|
+
const currentDetail = await this.addSpecificDetail(assetId, detail);
|
|
75
|
+
if (currentDetail)
|
|
76
|
+
sharingList.push(currentDetail);
|
|
65
77
|
}
|
|
66
78
|
return sharingList;
|
|
67
79
|
}
|
|
80
|
+
async addSpecificDetail(assetId, detail) {
|
|
81
|
+
var _a;
|
|
82
|
+
let currentDetail;
|
|
83
|
+
const isValid = await this.validateIfSharedWithExist(detail);
|
|
84
|
+
if (!isValid)
|
|
85
|
+
return null;
|
|
86
|
+
let sharingDetail = await this.detailsRepository.getBySharedWith(assetId, detail.sharedWith);
|
|
87
|
+
if (!sharingDetail && detail.sharedId) {
|
|
88
|
+
sharingDetail = await this.detailsRepository.getOne(detail.sharedId);
|
|
89
|
+
}
|
|
90
|
+
if (sharingDetail) {
|
|
91
|
+
currentDetail = details_1.SharingDetail.parse(sharingDetail);
|
|
92
|
+
currentDetail.update(detail);
|
|
93
|
+
await this.detailsRepository.patch(currentDetail.getSharingDetailsId, currentDetail.toTable());
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
const createDetails = Object.assign({ assetId: assetId, orgId: (_a = detail.orgId) !== null && _a !== void 0 ? _a : constants_1.ORGANIZATION_QRVEY }, detail);
|
|
97
|
+
currentDetail = details_1.SharingDetail.create(createDetails);
|
|
98
|
+
await this.detailsRepository.create(currentDetail.toTable());
|
|
99
|
+
}
|
|
100
|
+
return currentDetail;
|
|
101
|
+
}
|
|
102
|
+
async validateIfSharedWithExist(detail) {
|
|
103
|
+
if (detail.sharedOrigin === constants_1.SHARED_ORIGIN.EXTERNAL)
|
|
104
|
+
return true;
|
|
105
|
+
const isQrveyOrg = detail.sharedType === constants_1.SHARE_TYPE.ORGANIZATION &&
|
|
106
|
+
detail.sharedWith === constants_1.ORGANIZATION_QRVEY;
|
|
107
|
+
if (isQrveyOrg)
|
|
108
|
+
return true; // NOTE: If more Internal Organization arrive, need to change this validation
|
|
109
|
+
if (detail.sharedType === constants_1.SHARE_TYPE.USER) {
|
|
110
|
+
const user = await this.userRepository.getOne(detail.sharedWith);
|
|
111
|
+
if (user)
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
if (detail.sharedType === constants_1.SHARE_TYPE.ROLE) {
|
|
115
|
+
const role = await this.roleRepository.getOne(detail.sharedWith);
|
|
116
|
+
if (role)
|
|
117
|
+
return true;
|
|
118
|
+
}
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
68
121
|
async removeDetails(list) {
|
|
69
122
|
for (const detail of list) {
|
|
70
123
|
await this.detailsRepository.delete(detail.sharedId);
|
|
@@ -75,6 +128,10 @@ exports.UpsertSharing = UpsertSharing;
|
|
|
75
128
|
exports.UpsertSharing = UpsertSharing = __decorate([
|
|
76
129
|
(0, tsyringe_1.injectable)(),
|
|
77
130
|
__param(0, (0, tsyringe_1.inject)('SharingRepository')),
|
|
78
|
-
__param(1, (0, tsyringe_1.inject)('SharingDetailsRepository'))
|
|
131
|
+
__param(1, (0, tsyringe_1.inject)('SharingDetailsRepository')),
|
|
132
|
+
__param(2, (0, tsyringe_1.inject)('dxRepository')),
|
|
133
|
+
__param(3, (0, tsyringe_1.inject)('dmRepository')),
|
|
134
|
+
__param(4, (0, tsyringe_1.inject)('UserRepository')),
|
|
135
|
+
__param(5, (0, tsyringe_1.inject)('RoleRepository'))
|
|
79
136
|
], UpsertSharing);
|
|
80
137
|
//# sourceMappingURL=upsert.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"upsert.js","sourceRoot":"","sources":["../../../../src/sharing/services/upsert.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAA8C;AAE9C,sDAMgC;
|
|
1
|
+
{"version":3,"file":"upsert.js","sourceRoot":"","sources":["../../../../src/sharing/services/upsert.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAA8C;AAE9C,sDAMgC;AAGhC,iDAAoD;AACpD,iDAA8C;AA2BvC,IAAM,aAAa,GAAnB,MAAM,aAAa;IACtB,YAEqB,iBAA6C,EAE7C,iBAAoD,EAEpD,YAA0C,EAE1C,YAAgD,EAEhD,cAAuC,EAEvC,cAAuC;QAVvC,sBAAiB,GAAjB,iBAAiB,CAA4B;QAE7C,sBAAiB,GAAjB,iBAAiB,CAAmC;QAEpD,iBAAY,GAAZ,YAAY,CAA8B;QAE1C,iBAAY,GAAZ,YAAY,CAAoC;QAEhD,mBAAc,GAAd,cAAc,CAAyB;QAEvC,mBAAc,GAAd,cAAc,CAAyB;IACzD,CAAC;IAEG,KAAK,CAAC,OAAO,CAAC,EACjB,IAAI,GAGP;QACG,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAE7B,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,qBAAqB,CACjD,OAAO,EACP,IAAI,CAAC,SAAS,CACjB,CAAC;QACF,IAAI,CAAC,YAAY;YACb,MAAM,IAAI,KAAK,CAAC,iBAAiB,OAAO,YAAY,CAAC,CAAC;QAE1D,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC7D,IAAI,cAAuB,CAAC;QAC5B,IAAI,OAAO,EAAE,CAAC;YACV,cAAc,GAAG,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACJ,MAAM,aAAa,GAAG;gBAClB,OAAO;gBACP,SAAS,EAAE,IAAI,CAAC,SAAS;aAC5B,CAAC;YACF,cAAc,GAAG,iBAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAC/C,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,CAAC;QAClE,CAAC;QAED,IAAI,WAAW,GAAoB,EAAE,CAAC;QACtC,IAAI,IAAI,CAAC,GAAG;YAAE,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QACrE,IAAI,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEvD,cAAc,CAAC,MAAM,EAAE,CAAC;QACxB,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAC9B,cAAc,CAAC,UAAU,EACzB,cAAc,CAAC,OAAO,EAAE,CAC3B,CAAC;QACF,OAAO,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;IACxD,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAC/B,OAAe,EACf,SAAqB;QAErB,QAAQ,SAAS,EAAE,CAAC;YAChB,KAAK,sBAAU,CAAC,EAAE,CAAC,CAAC,CAAC;gBACjB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;gBACpD,IAAI,MAAM;oBAAE,OAAO,IAAI,CAAC;gBACxB,OAAO,KAAK,CAAC;YACjB,CAAC;YACD,KAAK,sBAAU,CAAC,EAAE,CAAC,CAAC,CAAC;gBACjB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;gBACpD,IAAI,MAAM;oBAAE,OAAO,IAAI,CAAC;gBACxB,OAAO,KAAK,CAAC;YACjB,CAAC;YAED;gBACI,OAAO,KAAK,CAAC;QACrB,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,UAAU,CACpB,OAAe,EACf,IAAsC;QAEtC,MAAM,WAAW,GAAoB,EAAE,CAAC;QACxC,KAAK,MAAM,MAAM,IAAI,IAAI,EAAE,CAAC;YACxB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YACpE,IAAI,aAAa;gBAAE,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACvD,CAAC;QACD,OAAO,WAAW,CAAC;IACvB,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAC3B,OAAe,EACf,MAAmB;;QAEnB,IAAI,aAA4B,CAAC;QACjC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC;QAC7D,IAAI,CAAC,OAAO;YAAE,OAAO,IAAI,CAAC;QAE1B,IAAI,aAAa,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC5D,OAAO,EACP,MAAM,CAAC,UAAU,CACpB,CAAC;QACF,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACpC,aAAa,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAC/C,MAAM,CAAC,QAAQ,CAClB,CAAC;QACN,CAAC;QAED,IAAI,aAAa,EAAE,CAAC;YAChB,aAAa,GAAG,uBAAa,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACnD,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC7B,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAC9B,aAAa,CAAC,mBAAmB,EACjC,aAAa,CAAC,OAAO,EAAE,CAC1B,CAAC;QACN,CAAC;aAAM,CAAC;YACJ,MAAM,aAAa,mBACf,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,MAAA,MAAM,CAAC,KAAK,mCAAI,8BAAkB,IACtC,MAAM,CACZ,CAAC;YACF,aAAa,GAAG,uBAAa,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YACpD,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;QACjE,CAAC;QACD,OAAO,aAAa,CAAC;IACzB,CAAC;IAEO,KAAK,CAAC,yBAAyB,CACnC,MAAmB;QAEnB,IAAI,MAAM,CAAC,YAAY,KAAK,yBAAa,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAC;QAEhE,MAAM,UAAU,GACZ,MAAM,CAAC,UAAU,KAAK,sBAAU,CAAC,YAAY;YAC7C,MAAM,CAAC,UAAU,KAAK,8BAAkB,CAAC;QAC7C,IAAI,UAAU;YAAE,OAAO,IAAI,CAAC,CAAC,6EAA6E;QAE1G,IAAI,MAAM,CAAC,UAAU,KAAK,sBAAU,CAAC,IAAI,EAAE,CAAC;YACxC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACjE,IAAI,IAAI;gBAAE,OAAO,IAAI,CAAC;QAC1B,CAAC;QAED,IAAI,MAAM,CAAC,UAAU,KAAK,sBAAU,CAAC,IAAI,EAAE,CAAC;YACxC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACjE,IAAI,IAAI;gBAAE,OAAO,IAAI,CAAC;QAC1B,CAAC;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,KAAK,CAAC,aAAa,CACvB,IAAyC;QAEzC,KAAK,MAAM,MAAM,IAAI,IAAI,EAAE,CAAC;YACxB,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACzD,CAAC;IACL,CAAC;CACJ,CAAA;AA3JY,sCAAa;wBAAb,aAAa;IADzB,IAAA,qBAAU,GAAE;IAGJ,WAAA,IAAA,iBAAM,EAAC,mBAAmB,CAAC,CAAA;IAE3B,WAAA,IAAA,iBAAM,EAAC,0BAA0B,CAAC,CAAA;IAElC,WAAA,IAAA,iBAAM,EAAC,cAAc,CAAC,CAAA;IAEtB,WAAA,IAAA,iBAAM,EAAC,cAAc,CAAC,CAAA;IAEtB,WAAA,IAAA,iBAAM,EAAC,gBAAgB,CAAC,CAAA;IAExB,WAAA,IAAA,iBAAM,EAAC,gBAAgB,CAAC,CAAA;GAZpB,aAAa,CA2JzB"}
|