@things-factory/dataset 8.0.0-alpha.0 → 8.0.0-alpha.11
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/client/activities/activity-data-collect-edit.ts +3 -1
- package/client/activities/activity-ooc-resolve-edit.ts +4 -2
- package/client/activities/activity-ooc-review-edit.ts +4 -2
- package/client/bootstrap.ts +11 -1
- package/client/components/data-entry-form.ts +3 -3
- package/client/pages/data-entry/data-entry-list-page.ts +65 -12
- package/client/pages/data-report/data-report-list-page.ts +9 -2
- package/client/pages/data-set/data-item-list.ts +1 -1
- package/client/pages/data-set/data-set-list-page.ts +14 -1
- package/dist-client/activities/activity-data-collect-edit.d.ts +1 -1
- package/dist-client/activities/activity-data-collect-edit.js +2 -1
- package/dist-client/activities/activity-data-collect-edit.js.map +1 -1
- package/dist-client/activities/activity-ooc-resolve-edit.js +4 -2
- package/dist-client/activities/activity-ooc-resolve-edit.js.map +1 -1
- package/dist-client/activities/activity-ooc-review-edit.js +4 -2
- package/dist-client/activities/activity-ooc-review-edit.js.map +1 -1
- package/dist-client/bootstrap.js +4 -0
- package/dist-client/bootstrap.js.map +1 -1
- package/dist-client/components/data-entry-form.js +3 -3
- package/dist-client/components/data-entry-form.js.map +1 -1
- package/dist-client/pages/data-entry/data-entry-list-page.js +61 -10
- package/dist-client/pages/data-entry/data-entry-list-page.js.map +1 -1
- package/dist-client/pages/data-report/data-report-list-page.js +8 -2
- package/dist-client/pages/data-report/data-report-list-page.js.map +1 -1
- package/dist-client/pages/data-set/data-item-list.js +1 -1
- package/dist-client/pages/data-set/data-item-list.js.map +1 -1
- package/dist-client/pages/data-set/data-set-list-page.js +14 -1
- package/dist-client/pages/data-set/data-set-list-page.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-server/controllers/issue-data-collection-task.d.ts +2 -0
- package/dist-server/controllers/{issue-collect-data.js → issue-data-collection-task.js} +10 -7
- package/dist-server/controllers/issue-data-collection-task.js.map +1 -0
- package/dist-server/engine/task/issue-collect-data.js +2 -2
- package/dist-server/engine/task/issue-collect-data.js.map +1 -1
- package/dist-server/routes.js +5 -3
- package/dist-server/routes.js.map +1 -1
- package/dist-server/service/data-set/data-item-type.d.ts +2 -1
- package/dist-server/service/data-set/data-item-type.js +1 -0
- package/dist-server/service/data-set/data-item-type.js.map +1 -1
- package/dist-server/service/data-set/data-set-mutation.d.ts +1 -0
- package/dist-server/service/data-set/data-set-mutation.js +44 -11
- package/dist-server/service/data-set/data-set-mutation.js.map +1 -1
- package/dist-server/service/data-set/data-set-query.d.ts +2 -0
- package/dist-server/service/data-set/data-set-query.js +89 -29
- package/dist-server/service/data-set/data-set-query.js.map +1 -1
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/helps/dataset/data-set.ja.md +55 -59
- package/helps/dataset/data-set.ko.md +9 -11
- package/helps/dataset/data-set.md +20 -24
- package/helps/dataset/data-set.zh.md +3 -11
- package/helps/dataset/task/issue-collect-data.ja.md +1 -1
- package/helps/dataset/task/issue-collect-data.ko.md +1 -1
- package/helps/dataset/task/issue-collect-data.md +1 -1
- package/helps/dataset/task/issue-collect-data.ms.md +1 -1
- package/helps/dataset/task/issue-collect-data.zh.md +1 -1
- package/package.json +13 -13
- package/server/controllers/{issue-collect-data.ts → issue-data-collection-task.ts} +9 -5
- package/server/engine/task/issue-collect-data.ts +2 -2
- package/server/routes.ts +5 -3
- package/server/service/data-set/data-item-type.ts +10 -5
- package/server/service/data-set/data-set-mutation.ts +45 -12
- package/server/service/data-set/data-set-query.ts +86 -30
- package/translations/en.json +1 -0
- package/translations/ja.json +1 -0
- package/translations/ko.json +1 -0
- package/translations/ms.json +1 -0
- package/translations/zh.json +1 -0
- package/dist-server/controllers/issue-collect-data.d.ts +0 -2
- package/dist-server/controllers/issue-collect-data.js.map +0 -1
|
@@ -18,18 +18,21 @@ const data_set_1 = require("./data-set");
|
|
|
18
18
|
const data_set_type_1 = require("./data-set-type");
|
|
19
19
|
var parser = require('cron-parser');
|
|
20
20
|
let DataSetQuery = class DataSetQuery {
|
|
21
|
+
// 데이터셋을 ID로 조회
|
|
21
22
|
async dataSet(id, context) {
|
|
22
23
|
const { domain } = context.state;
|
|
23
24
|
return await (0, shell_1.getRepository)(data_set_1.DataSet).findOne({
|
|
24
25
|
where: { domain: { id: (0, typeorm_1.In)([domain.id, domain.parentId].filter(Boolean)) }, id }
|
|
25
26
|
});
|
|
26
27
|
}
|
|
28
|
+
// 데이터셋을 이름으로 조회
|
|
27
29
|
async dataSetByName(name, context) {
|
|
28
30
|
const { domain } = context.state;
|
|
29
31
|
return await (0, shell_1.getRepository)(data_set_1.DataSet).findOne({
|
|
30
32
|
where: { domain: { id: (0, typeorm_1.In)([domain.id, domain.parentId].filter(Boolean)) }, name }
|
|
31
33
|
});
|
|
32
34
|
}
|
|
35
|
+
// 여러 데이터셋을 조회
|
|
33
36
|
async dataSets(params, context) {
|
|
34
37
|
const { domain } = context.state;
|
|
35
38
|
const queryBuilder = (0, shell_1.getQueryBuilderFromListParams)({
|
|
@@ -42,14 +45,17 @@ let DataSetQuery = class DataSetQuery {
|
|
|
42
45
|
const [items, total] = await queryBuilder.getManyAndCount();
|
|
43
46
|
return { items, total };
|
|
44
47
|
}
|
|
48
|
+
// 데이터 입력을 위한 데이터셋 조회
|
|
45
49
|
async dataSetsForEntry(params, context) {
|
|
46
50
|
var { domain, user } = context.state;
|
|
47
|
-
|
|
51
|
+
// 조회한 사용자가 entry-role을 가진 data-set 리스트만 반환
|
|
48
52
|
user = await (0, shell_1.getRepository)(auth_base_1.User).findOne({
|
|
49
53
|
where: { id: user.id },
|
|
50
54
|
relations: ['roles']
|
|
51
55
|
});
|
|
52
|
-
const roles = user.roles
|
|
56
|
+
const roles = user.roles
|
|
57
|
+
.filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))
|
|
58
|
+
.map(role => role.id);
|
|
53
59
|
if (!roles.length) {
|
|
54
60
|
return { items: [], total: 0 };
|
|
55
61
|
}
|
|
@@ -60,14 +66,21 @@ let DataSetQuery = class DataSetQuery {
|
|
|
60
66
|
alias: 'dataset',
|
|
61
67
|
searchables: ['name', 'description']
|
|
62
68
|
})
|
|
63
|
-
.andWhere(
|
|
64
|
-
.andWhere(
|
|
69
|
+
.andWhere('dataset.active = :active', { active: true })
|
|
70
|
+
.andWhere(new typeorm_1.Brackets(qb => {
|
|
71
|
+
qb.where('dataset.supervisoryRole IN (:...roles)').orWhere('dataset.entryRole IN (:...roles)');
|
|
72
|
+
}))
|
|
73
|
+
.setParameter('roles', roles)
|
|
65
74
|
.getManyAndCount();
|
|
66
|
-
return {
|
|
75
|
+
return {
|
|
76
|
+
items,
|
|
77
|
+
total
|
|
78
|
+
};
|
|
67
79
|
}
|
|
80
|
+
// 데이터 보고를 위한 데이터셋 조회
|
|
68
81
|
async dataSetsForReport(params, context) {
|
|
69
82
|
var { domain, user } = context.state;
|
|
70
|
-
|
|
83
|
+
// 조회한 사용자가 supervisory 역할을 가진 data-set 리스트만 반환
|
|
71
84
|
user = await (0, shell_1.getRepository)(auth_base_1.User).findOne({
|
|
72
85
|
where: { id: user.id },
|
|
73
86
|
relations: ['roles']
|
|
@@ -88,8 +101,9 @@ let DataSetQuery = class DataSetQuery {
|
|
|
88
101
|
.getManyAndCount();
|
|
89
102
|
return { items, total };
|
|
90
103
|
}
|
|
104
|
+
// 데이터셋의 상태를 조회
|
|
91
105
|
async status(dataSet) {
|
|
92
|
-
//
|
|
106
|
+
// 스케줄러 서비스에서 정보 가져오기
|
|
93
107
|
return {
|
|
94
108
|
id: '',
|
|
95
109
|
scheduleId: '',
|
|
@@ -98,12 +112,14 @@ let DataSetQuery = class DataSetQuery {
|
|
|
98
112
|
nextSchedule: new Date()
|
|
99
113
|
};
|
|
100
114
|
}
|
|
115
|
+
// 데이터셋의 데이터 항목을 조회
|
|
101
116
|
async dataItems(dataSet) {
|
|
102
117
|
if (dataSet.dataItems instanceof Array) {
|
|
103
118
|
return dataSet.dataItems.filter(item => item.name);
|
|
104
119
|
}
|
|
105
120
|
return [];
|
|
106
121
|
}
|
|
122
|
+
// 데이터셋의 entry 역할을 조회
|
|
107
123
|
async entryRole(dataSet) {
|
|
108
124
|
return (dataSet.entryRole ||
|
|
109
125
|
(dataSet.entryRoleId &&
|
|
@@ -111,6 +127,7 @@ let DataSetQuery = class DataSetQuery {
|
|
|
111
127
|
id: dataSet.entryRoleId
|
|
112
128
|
}))));
|
|
113
129
|
}
|
|
130
|
+
// 데이터셋의 supervisory 역할을 조회
|
|
114
131
|
async supervisoryRole(dataSet) {
|
|
115
132
|
return (dataSet.supervisoryRole ||
|
|
116
133
|
(dataSet.supervisoryRoleId &&
|
|
@@ -216,12 +233,15 @@ let DataSetQuery = class DataSetQuery {
|
|
|
216
233
|
id: dataSet.outlierScenarioId
|
|
217
234
|
}))));
|
|
218
235
|
}
|
|
236
|
+
// 데이터셋의 도메인을 조회
|
|
219
237
|
async domain(dataSet) {
|
|
220
238
|
return dataSet.domainId && (await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: dataSet.domainId }));
|
|
221
239
|
}
|
|
240
|
+
// 데이터셋의 업데이트한 사용자를 조회
|
|
222
241
|
async updater(dataSet) {
|
|
223
242
|
return dataSet.updaterId && (await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: dataSet.updaterId }));
|
|
224
243
|
}
|
|
244
|
+
// 데이터셋의 생성자를 조회
|
|
225
245
|
async creator(dataSet) {
|
|
226
246
|
return dataSet.creatorId && (await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: dataSet.creatorId }));
|
|
227
247
|
}
|
|
@@ -262,15 +282,14 @@ let DataSetQuery = class DataSetQuery {
|
|
|
262
282
|
tz: timezone || (await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: domainId })).timezone || 'UTC'
|
|
263
283
|
});
|
|
264
284
|
return interval.next().toDate();
|
|
265
|
-
//
|
|
266
|
-
//
|
|
267
|
-
//
|
|
268
|
-
//
|
|
269
|
-
//
|
|
270
|
-
//
|
|
271
|
-
//
|
|
272
|
-
//
|
|
273
|
-
// */
|
|
285
|
+
// FIXME: getSchedules 의 파라미터를 수정해야한다. scheduler 가 없거나 커넥션이 끊겨있어서 오래걸리는 문제는 어떻게 ?? 비동기로 처리한다. 어떻게???
|
|
286
|
+
// client: {
|
|
287
|
+
// application: Application,
|
|
288
|
+
// group: `${domain.id}`,
|
|
289
|
+
// type: 'data-set',
|
|
290
|
+
// key: dataSet.id,
|
|
291
|
+
// operation: 'summary'
|
|
292
|
+
// }
|
|
274
293
|
// const schedule = getSchedules('name', 'group', false)
|
|
275
294
|
// return schedule.nextSchedule
|
|
276
295
|
}
|
|
@@ -284,6 +303,28 @@ let DataSetQuery = class DataSetQuery {
|
|
|
284
303
|
});
|
|
285
304
|
return attachment === null || attachment === void 0 ? void 0 : attachment.path;
|
|
286
305
|
}
|
|
306
|
+
async isSupervisor(dataset, context) {
|
|
307
|
+
const { user, domain } = context.state;
|
|
308
|
+
const foundUser = await (0, shell_1.getRepository)(auth_base_1.User).findOne({
|
|
309
|
+
where: { id: user.id },
|
|
310
|
+
relations: ['roles']
|
|
311
|
+
});
|
|
312
|
+
const roles = foundUser.roles
|
|
313
|
+
.filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))
|
|
314
|
+
.map(role => role.id);
|
|
315
|
+
return roles.includes(dataset.supervisoryRoleId);
|
|
316
|
+
}
|
|
317
|
+
async isEntryAllowed(dataset, context) {
|
|
318
|
+
const { user, domain } = context.state;
|
|
319
|
+
const foundUser = await (0, shell_1.getRepository)(auth_base_1.User).findOne({
|
|
320
|
+
where: { id: user.id },
|
|
321
|
+
relations: ['roles']
|
|
322
|
+
});
|
|
323
|
+
const roles = foundUser.roles
|
|
324
|
+
.filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))
|
|
325
|
+
.map(role => role.id);
|
|
326
|
+
return roles.includes(dataset.entryRoleId);
|
|
327
|
+
}
|
|
287
328
|
};
|
|
288
329
|
exports.DataSetQuery = DataSetQuery;
|
|
289
330
|
tslib_1.__decorate([
|
|
@@ -351,14 +392,14 @@ tslib_1.__decorate([
|
|
|
351
392
|
tslib_1.__metadata("design:returntype", Promise)
|
|
352
393
|
], DataSetQuery.prototype, "entryRole", null);
|
|
353
394
|
tslib_1.__decorate([
|
|
354
|
-
(0, type_graphql_1.FieldResolver)(type => auth_base_1.Role),
|
|
395
|
+
(0, type_graphql_1.FieldResolver)(type => auth_base_1.Role, { description: 'Retrieves the supervisory role for the dataset' }),
|
|
355
396
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
356
397
|
tslib_1.__metadata("design:type", Function),
|
|
357
398
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
358
399
|
tslib_1.__metadata("design:returntype", Promise)
|
|
359
400
|
], DataSetQuery.prototype, "supervisoryRole", null);
|
|
360
401
|
tslib_1.__decorate([
|
|
361
|
-
(0, type_graphql_1.FieldResolver)(type => [worklist_1.AssigneeItem]),
|
|
402
|
+
(0, type_graphql_1.FieldResolver)(type => [worklist_1.AssigneeItem], { description: 'Retrieves the assignee items for the dataset' }),
|
|
362
403
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
363
404
|
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
364
405
|
tslib_1.__metadata("design:type", Function),
|
|
@@ -366,7 +407,7 @@ tslib_1.__decorate([
|
|
|
366
407
|
tslib_1.__metadata("design:returntype", Promise)
|
|
367
408
|
], DataSetQuery.prototype, "assignees", null);
|
|
368
409
|
tslib_1.__decorate([
|
|
369
|
-
(0, type_graphql_1.FieldResolver)(type => [organization_1.ApprovalLineItem]),
|
|
410
|
+
(0, type_graphql_1.FieldResolver)(type => [organization_1.ApprovalLineItem], { description: 'Retrieves the approval line items for the dataset' }),
|
|
370
411
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
371
412
|
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
372
413
|
tslib_1.__metadata("design:type", Function),
|
|
@@ -374,35 +415,35 @@ tslib_1.__decorate([
|
|
|
374
415
|
tslib_1.__metadata("design:returntype", Promise)
|
|
375
416
|
], DataSetQuery.prototype, "approvalLine", null);
|
|
376
417
|
tslib_1.__decorate([
|
|
377
|
-
(0, type_graphql_1.FieldResolver)(type => board_service_1.Board, { nullable: true }),
|
|
418
|
+
(0, type_graphql_1.FieldResolver)(type => board_service_1.Board, { nullable: true, description: 'Retrieves the entry board for the dataset' }),
|
|
378
419
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
379
420
|
tslib_1.__metadata("design:type", Function),
|
|
380
421
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
381
422
|
tslib_1.__metadata("design:returntype", Promise)
|
|
382
423
|
], DataSetQuery.prototype, "entryBoard", null);
|
|
383
424
|
tslib_1.__decorate([
|
|
384
|
-
(0, type_graphql_1.FieldResolver)(type => board_service_1.Board, { nullable: true }),
|
|
425
|
+
(0, type_graphql_1.FieldResolver)(type => board_service_1.Board, { nullable: true, description: 'Retrieves the monitor board for the dataset' }),
|
|
385
426
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
386
427
|
tslib_1.__metadata("design:type", Function),
|
|
387
428
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
388
429
|
tslib_1.__metadata("design:returntype", Promise)
|
|
389
430
|
], DataSetQuery.prototype, "monitorBoard", null);
|
|
390
431
|
tslib_1.__decorate([
|
|
391
|
-
(0, type_graphql_1.FieldResolver)(type => data_key_set_1.DataKeySet, { nullable: true }),
|
|
432
|
+
(0, type_graphql_1.FieldResolver)(type => data_key_set_1.DataKeySet, { nullable: true, description: 'Retrieves the data key set for the dataset' }),
|
|
392
433
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
393
434
|
tslib_1.__metadata("design:type", Function),
|
|
394
435
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
395
436
|
tslib_1.__metadata("design:returntype", Promise)
|
|
396
437
|
], DataSetQuery.prototype, "dataKeySet", null);
|
|
397
438
|
tslib_1.__decorate([
|
|
398
|
-
(0, type_graphql_1.FieldResolver)(type => integration_base_1.Scenario),
|
|
439
|
+
(0, type_graphql_1.FieldResolver)(type => integration_base_1.Scenario, { description: 'Retrieves the normal scenario for the dataset.' }),
|
|
399
440
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
400
441
|
tslib_1.__metadata("design:type", Function),
|
|
401
442
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
402
443
|
tslib_1.__metadata("design:returntype", Promise)
|
|
403
444
|
], DataSetQuery.prototype, "normalScenario", null);
|
|
404
445
|
tslib_1.__decorate([
|
|
405
|
-
(0, type_graphql_1.FieldResolver)(type => integration_base_1.Scenario),
|
|
446
|
+
(0, type_graphql_1.FieldResolver)(type => integration_base_1.Scenario, { description: 'Retrieves the outlier scenario for the dataset.' }),
|
|
406
447
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
407
448
|
tslib_1.__metadata("design:type", Function),
|
|
408
449
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
@@ -430,40 +471,59 @@ tslib_1.__decorate([
|
|
|
430
471
|
tslib_1.__metadata("design:returntype", Promise)
|
|
431
472
|
], DataSetQuery.prototype, "creator", null);
|
|
432
473
|
tslib_1.__decorate([
|
|
433
|
-
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true }),
|
|
474
|
+
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true, description: 'Retrieves the latest collection time for the dataset.' }),
|
|
434
475
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
435
476
|
tslib_1.__metadata("design:type", Function),
|
|
436
477
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
437
478
|
tslib_1.__metadata("design:returntype", Promise)
|
|
438
479
|
], DataSetQuery.prototype, "latestCollectedAt", null);
|
|
439
480
|
tslib_1.__decorate([
|
|
440
|
-
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true }),
|
|
481
|
+
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true, description: 'Retrieves the next schedule time for the dataset.' }),
|
|
441
482
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
442
483
|
tslib_1.__metadata("design:type", Function),
|
|
443
484
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
444
485
|
tslib_1.__metadata("design:returntype", Promise)
|
|
445
486
|
], DataSetQuery.prototype, "nextSchedule", null);
|
|
446
487
|
tslib_1.__decorate([
|
|
447
|
-
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true }),
|
|
488
|
+
(0, type_graphql_1.FieldResolver)(type => Date, { nullable: true, description: 'Retrieves the previous schedule time for the dataset.' }),
|
|
448
489
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
449
490
|
tslib_1.__metadata("design:type", Function),
|
|
450
491
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
451
492
|
tslib_1.__metadata("design:returntype", Promise)
|
|
452
493
|
], DataSetQuery.prototype, "prevSchedule", null);
|
|
453
494
|
tslib_1.__decorate([
|
|
454
|
-
(0, type_graphql_1.FieldResolver)(type => Date, {
|
|
495
|
+
(0, type_graphql_1.FieldResolver)(type => Date, {
|
|
496
|
+
nullable: true,
|
|
497
|
+
description: 'Retrieves the next summary schedule time for the dataset.'
|
|
498
|
+
}),
|
|
455
499
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
456
500
|
tslib_1.__metadata("design:type", Function),
|
|
457
501
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
458
502
|
tslib_1.__metadata("design:returntype", Promise)
|
|
459
503
|
], DataSetQuery.prototype, "nextSummarySchedule", null);
|
|
460
504
|
tslib_1.__decorate([
|
|
461
|
-
(0, type_graphql_1.FieldResolver)(type => String),
|
|
505
|
+
(0, type_graphql_1.FieldResolver)(type => String, { description: 'Retrieves the report template for the dataset.' }),
|
|
462
506
|
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
463
507
|
tslib_1.__metadata("design:type", Function),
|
|
464
508
|
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet]),
|
|
465
509
|
tslib_1.__metadata("design:returntype", Promise)
|
|
466
510
|
], DataSetQuery.prototype, "reportTemplate", null);
|
|
511
|
+
tslib_1.__decorate([
|
|
512
|
+
(0, type_graphql_1.FieldResolver)(returns => Boolean, { description: 'Whether the user is a supervisor for this dataset' }),
|
|
513
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
514
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
515
|
+
tslib_1.__metadata("design:type", Function),
|
|
516
|
+
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet, Object]),
|
|
517
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
518
|
+
], DataSetQuery.prototype, "isSupervisor", null);
|
|
519
|
+
tslib_1.__decorate([
|
|
520
|
+
(0, type_graphql_1.FieldResolver)(returns => Boolean, { description: 'Whether the user is allowed to enter data for this dataset' }),
|
|
521
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
522
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
523
|
+
tslib_1.__metadata("design:type", Function),
|
|
524
|
+
tslib_1.__metadata("design:paramtypes", [data_set_1.DataSet, Object]),
|
|
525
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
526
|
+
], DataSetQuery.prototype, "isEntryAllowed", null);
|
|
467
527
|
exports.DataSetQuery = DataSetQuery = tslib_1.__decorate([
|
|
468
528
|
(0, type_graphql_1.Resolver)(data_set_1.DataSet)
|
|
469
529
|
], DataSetQuery);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data-set-query.js","sourceRoot":"","sources":["../../../server/service/data-set/data-set-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\nimport { In } from 'typeorm'\n\nimport { Attachment } from '@things-factory/attachment-base'\nimport { Role, User } from '@things-factory/auth-base'\nimport { Board } from '@things-factory/board-service'\nimport { ApprovalLineItem } from '@things-factory/organization'\nimport { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'\nimport { AssigneeItem } from '@things-factory/worklist'\nimport { Scenario } from '@things-factory/integration-base'\n\nimport { DataKeySet } from '../data-key-set/data-key-set'\nimport { DataSample } from '../data-sample/data-sample'\nimport { DataItem } from './data-item-type'\nimport { DataSet, DataSetState } from './data-set'\nimport { DataSetList } from './data-set-type'\n\nvar parser = require('cron-parser')\n\n@Resolver(DataSet)\nexport class DataSetQuery {\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSet, { description: 'To fetch a DataSet' })\n async dataSet(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<DataSet> {\n const { domain } = context.state\n\n return await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, id }\n })\n }\n\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSet, { description: 'To fetch a DataSet by name' })\n async dataSetByName(@Arg('name') name: string, @Ctx() context: ResolverContext): Promise<DataSet> {\n const { domain } = context.state\n\n return await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, name }\n })\n }\n\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets' })\n async dataSets(@Args(type => ListParam) params: ListParam, @Ctx() context: ResolverContext): Promise<DataSetList> {\n const { domain } = context.state\n\n const queryBuilder = getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description', 'tag', 'supervisoryRole']\n })\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets for data entry manually' })\n async dataSetsForEntry(\n @Args(type => ListParam) params: ListParam,\n @Ctx() context: ResolverContext\n ): Promise<DataSetList> {\n var { domain, user } = context.state\n\n /* 조회한 사용자가 entry-role을 가진 data-set 리스트만 반환 */\n user = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n\n const roles = user.roles.filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId)).map(role => role.id)\n\n if (!roles.length) {\n return { items: [], total: 0 }\n }\n\n const [items, total] = await getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description']\n })\n .andWhere(`dataset.active = :active`, { active: true })\n .andWhere('dataset.entryRole IN (:...roles)', { roles })\n .getManyAndCount()\n\n return { items, total }\n }\n\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets to see data report' })\n async dataSetsForReport(\n @Args(type => ListParam) params: ListParam,\n @Ctx() context: ResolverContext\n ): Promise<DataSetList> {\n var { domain, user } = context.state\n\n /* 조회한 사용자가 supervisory 역할을 가진 data-set 리스트만 반환 */\n user = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n const roles = user.roles.filter(role => role.domainId === domain.id).map(role => role.id)\n\n if (!roles.length) {\n return { items: [], total: 0 }\n }\n\n const [items, total] = await getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description']\n })\n .andWhere(`dataset.active = :active`, { active: true })\n .andWhere('dataset.supervisoryRole IN (:...roles)', { roles })\n .getManyAndCount()\n\n return { items, total }\n }\n\n @FieldResolver(type => DataSetState)\n async status(@Root() dataSet: DataSet): Promise<DataSetState> {\n // get information from scheduler service\n return {\n id: '',\n scheduleId: '',\n state: '',\n startedAt: new Date(),\n nextSchedule: new Date()\n }\n }\n\n @FieldResolver(type => [DataItem])\n async dataItems(@Root() dataSet: DataSet): Promise<DataItem[]> {\n if (dataSet.dataItems instanceof Array) {\n return dataSet.dataItems.filter(item => item.name)\n }\n\n return []\n }\n\n @FieldResolver(type => Role)\n async entryRole(@Root() dataSet: DataSet): Promise<Role> {\n return (\n dataSet.entryRole ||\n (dataSet.entryRoleId &&\n (await getRepository(Role).findOneBy({\n id: dataSet.entryRoleId\n })))\n )\n }\n\n @FieldResolver(type => Role)\n async supervisoryRole(@Root() dataSet: DataSet): Promise<Role> {\n return (\n dataSet.supervisoryRole ||\n (dataSet.supervisoryRoleId &&\n (await getRepository(Role).findOneBy({\n id: dataSet.supervisoryRoleId\n })))\n )\n }\n\n @FieldResolver(type => [AssigneeItem])\n async assignees(@Root() dataSet: DataSet, @Ctx() context: ResolverContext): Promise<AssigneeItem[]> {\n const { domain, user } = context.state\n const { assignees } = dataSet\n\n if (!assignees || !(assignees instanceof Array)) {\n return null\n }\n\n var assigneeItemList = []\n\n for (let item of assignees) {\n // \"value\" deprecated. to be removed\n var { type, assignee, value } = item\n var id = assignee?.id || id\n\n switch (type) {\n case 'Employee':\n assignee = id && (await getRepository('Employee').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Department':\n assignee = id && (await getRepository('Department').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Role':\n assignee = id && (await getRepository('Role').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Myself':\n assignee = user\n break\n case 'MyDepartment':\n case 'MySupervisor':\n break\n default:\n }\n\n id ? assigneeItemList.push({ type, assignee }) : assigneeItemList.push({ type })\n }\n\n return assigneeItemList\n }\n\n @FieldResolver(type => [ApprovalLineItem])\n async approvalLine(@Root() dataSet: DataSet, @Ctx() context: ResolverContext): Promise<ApprovalLineItem[]> {\n const { domain, user } = context.state\n const { reviewApprovalLine } = dataSet\n\n if (!reviewApprovalLine || !(reviewApprovalLine instanceof Array)) {\n return null\n }\n\n var approvalLineItems = []\n\n for (let item of reviewApprovalLine) {\n // \"value\" deprecated. to be removed\n var { type, approver, value } = item\n var id = approver?.id || value\n approver = null\n\n switch (type) {\n case 'Employee':\n approver = id && (await getRepository('Employee').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Department':\n approver = id && (await getRepository('Department').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Role':\n approver = id && (await getRepository('Role').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Myself':\n approver = user\n break\n case 'MyDepartment':\n case 'MySupervisor':\n break\n default:\n }\n\n id ? approvalLineItems.push({ type, approver }) : approvalLineItems.push({ type })\n }\n\n return approvalLineItems\n }\n\n @FieldResolver(type => Board, { nullable: true })\n async entryBoard(@Root() dataSet: DataSet): Promise<Board> {\n if (dataSet.entryType == 'board' && dataSet.entryView) {\n return await getRepository(Board).findOneBy({ id: dataSet.entryView })\n }\n }\n\n @FieldResolver(type => Board, { nullable: true })\n async monitorBoard(@Root() dataSet: DataSet): Promise<Board> {\n if (dataSet.monitorType == 'board' && dataSet.monitorView) {\n return await getRepository(Board).findOneBy({ id: dataSet.monitorView })\n }\n }\n\n @FieldResolver(type => DataKeySet, { nullable: true })\n async dataKeySet(@Root() dataSet: DataSet): Promise<DataKeySet> {\n return (\n dataSet.dataKeySet ||\n (dataSet.dataKeySetId &&\n (await getRepository(DataKeySet).findOneBy({\n id: dataSet.dataKeySetId\n })))\n )\n }\n\n @FieldResolver(type => Scenario)\n async normalScenario(@Root() dataSet: DataSet): Promise<Scenario> {\n return (\n dataSet.normalScenario ||\n (dataSet.normalScenarioId &&\n (await getRepository(Scenario).findOneBy({\n id: dataSet.normalScenarioId\n })))\n )\n }\n\n @FieldResolver(type => Scenario)\n async outlierScenario(@Root() dataSet: DataSet): Promise<Scenario> {\n return (\n dataSet.outlierScenario ||\n (dataSet.outlierScenarioId &&\n (await getRepository(Scenario).findOneBy({\n id: dataSet.outlierScenarioId\n })))\n )\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() dataSet: DataSet): Promise<Domain> {\n return dataSet.domainId && (await getRepository(Domain).findOneBy({ id: dataSet.domainId }))\n }\n\n @FieldResolver(type => User)\n async updater(@Root() dataSet: DataSet): Promise<User> {\n return dataSet.updaterId && (await getRepository(User).findOneBy({ id: dataSet.updaterId }))\n }\n\n @FieldResolver(type => User)\n async creator(@Root() dataSet: DataSet): Promise<User> {\n return dataSet.creatorId && (await getRepository(User).findOneBy({ id: dataSet.creatorId }))\n }\n\n @FieldResolver(type => Date, { nullable: true })\n async latestCollectedAt(@Root() dataSet: DataSet): Promise<Date> {\n const sample = await getRepository(DataSample).findOne({\n select: ['id', 'collectedAt'],\n where: { dataSet: { id: dataSet.id } },\n order: { collectedAt: 'DESC' }\n })\n\n return sample?.collectedAt\n }\n\n @FieldResolver(type => Date, { nullable: true })\n async nextSchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, schedule, timezone } = dataSet\n\n if (!schedule) {\n return\n }\n\n var interval = parser.parseExpression(schedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.next().toDate()\n }\n\n @FieldResolver(type => Date, { nullable: true })\n async prevSchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, schedule, timezone } = dataSet\n\n if (!schedule) {\n return\n }\n\n var interval = parser.parseExpression(schedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.prev().toDate()\n }\n\n @FieldResolver(type => Date, { nullable: true })\n async nextSummarySchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, summarySchedule, timezone } = dataSet\n\n if (!summarySchedule) {\n return\n }\n\n var interval = parser.parseExpression(summarySchedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.next().toDate()\n\n // /* FIXME: getSchedules 의 파라미터를 수정해야한다. scheduler 가 없거나 커넥션이 끊겨있어서 오래걸리는 문제는 어떻게 ?? 비동기로 처리한다. 어떻게???\n // client: {\n // application: Application,\n // group: `${domain.id}`,\n // type: 'data-set',\n // key: dataSet.id,\n // operation: 'summary'\n // },\n // */\n // const schedule = getSchedules('name', 'group', false)\n // return schedule.nextSchedule\n }\n\n @FieldResolver(type => String)\n async reportTemplate(@Root() dataset: DataSet): Promise<string | undefined> {\n const attachment: Attachment = await getRepository(Attachment).findOne({\n where: {\n domain: { id: dataset.domainId },\n refType: `${DataSet.name}-report-template`,\n refBy: dataset.id\n }\n })\n\n return attachment?.path\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"data-set-query.js","sourceRoot":"","sources":["../../../server/service/data-set/data-set-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\nimport { Brackets, In } from 'typeorm'\n\nimport { Attachment } from '@things-factory/attachment-base'\nimport { Role, User } from '@things-factory/auth-base'\nimport { Board } from '@things-factory/board-service'\nimport { ApprovalLineItem } from '@things-factory/organization'\nimport { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'\nimport { AssigneeItem } from '@things-factory/worklist'\nimport { Scenario } from '@things-factory/integration-base'\n\nimport { DataKeySet } from '../data-key-set/data-key-set'\nimport { DataSample } from '../data-sample/data-sample'\nimport { DataItem } from './data-item-type'\nimport { DataSet, DataSetState } from './data-set'\nimport { DataSetList } from './data-set-type'\n\nvar parser = require('cron-parser')\n\n@Resolver(DataSet)\nexport class DataSetQuery {\n // 데이터셋을 ID로 조회\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSet, { description: 'To fetch a DataSet' })\n async dataSet(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<DataSet> {\n const { domain } = context.state\n\n return await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, id }\n })\n }\n\n // 데이터셋을 이름으로 조회\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSet, { description: 'To fetch a DataSet by name' })\n async dataSetByName(@Arg('name') name: string, @Ctx() context: ResolverContext): Promise<DataSet> {\n const { domain } = context.state\n\n return await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, name }\n })\n }\n\n // 여러 데이터셋을 조회\n @Directive('@privilege(category: \"data-set\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets' })\n async dataSets(@Args(type => ListParam) params: ListParam, @Ctx() context: ResolverContext): Promise<DataSetList> {\n const { domain } = context.state\n\n const queryBuilder = getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description', 'tag', 'supervisoryRole']\n })\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n // 데이터 입력을 위한 데이터셋 조회\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets for data entry manually' })\n async dataSetsForEntry(\n @Args(type => ListParam) params: ListParam,\n @Ctx() context: ResolverContext\n ): Promise<DataSetList> {\n var { domain, user } = context.state\n\n // 조회한 사용자가 entry-role을 가진 data-set 리스트만 반환\n user = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n\n const roles = user.roles\n .filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))\n .map(role => role.id)\n\n if (!roles.length) {\n return { items: [], total: 0 }\n }\n\n const [items, total] = await getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description']\n })\n .andWhere('dataset.active = :active', { active: true })\n .andWhere(\n new Brackets(qb => {\n qb.where('dataset.supervisoryRole IN (:...roles)').orWhere('dataset.entryRole IN (:...roles)')\n })\n )\n .setParameter('roles', roles)\n .getManyAndCount()\n\n return {\n items,\n total\n }\n }\n\n // 데이터 보고를 위한 데이터셋 조회\n @Query(returns => DataSetList, { description: 'To fetch multiple DataSets to see data report' })\n async dataSetsForReport(\n @Args(type => ListParam) params: ListParam,\n @Ctx() context: ResolverContext\n ): Promise<DataSetList> {\n var { domain, user } = context.state\n\n // 조회한 사용자가 supervisory 역할을 가진 data-set 리스트만 반환\n user = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n const roles = user.roles.filter(role => role.domainId === domain.id).map(role => role.id)\n\n if (!roles.length) {\n return { items: [], total: 0 }\n }\n\n const [items, total] = await getQueryBuilderFromListParams({\n repository: getRepository(DataSet),\n params,\n domain,\n alias: 'dataset',\n searchables: ['name', 'description']\n })\n .andWhere(`dataset.active = :active`, { active: true })\n .andWhere('dataset.supervisoryRole IN (:...roles)', { roles })\n .getManyAndCount()\n\n return { items, total }\n }\n\n // 데이터셋의 상태를 조회\n @FieldResolver(type => DataSetState)\n async status(@Root() dataSet: DataSet): Promise<DataSetState> {\n // 스케줄러 서비스에서 정보 가져오기\n return {\n id: '',\n scheduleId: '',\n state: '',\n startedAt: new Date(),\n nextSchedule: new Date()\n }\n }\n\n // 데이터셋의 데이터 항목을 조회\n @FieldResolver(type => [DataItem])\n async dataItems(@Root() dataSet: DataSet): Promise<DataItem[]> {\n if (dataSet.dataItems instanceof Array) {\n return dataSet.dataItems.filter(item => item.name)\n }\n\n return []\n }\n\n // 데이터셋의 entry 역할을 조회\n @FieldResolver(type => Role)\n async entryRole(@Root() dataSet: DataSet): Promise<Role> {\n return (\n dataSet.entryRole ||\n (dataSet.entryRoleId &&\n (await getRepository(Role).findOneBy({\n id: dataSet.entryRoleId\n })))\n )\n }\n\n // 데이터셋의 supervisory 역할을 조회\n @FieldResolver(type => Role, { description: 'Retrieves the supervisory role for the dataset' })\n async supervisoryRole(@Root() dataSet: DataSet): Promise<Role> {\n return (\n dataSet.supervisoryRole ||\n (dataSet.supervisoryRoleId &&\n (await getRepository(Role).findOneBy({\n id: dataSet.supervisoryRoleId\n })))\n )\n }\n\n @FieldResolver(type => [AssigneeItem], { description: 'Retrieves the assignee items for the dataset' })\n async assignees(@Root() dataSet: DataSet, @Ctx() context: ResolverContext): Promise<AssigneeItem[]> {\n const { domain, user } = context.state\n const { assignees } = dataSet\n\n if (!assignees || !(assignees instanceof Array)) {\n return null\n }\n\n var assigneeItemList = []\n\n for (let item of assignees) {\n // \"value\" deprecated. to be removed\n var { type, assignee, value } = item\n var id = assignee?.id || id\n\n switch (type) {\n case 'Employee':\n assignee = id && (await getRepository('Employee').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Department':\n assignee = id && (await getRepository('Department').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Role':\n assignee = id && (await getRepository('Role').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Myself':\n assignee = user\n break\n case 'MyDepartment':\n case 'MySupervisor':\n break\n default:\n }\n\n id ? assigneeItemList.push({ type, assignee }) : assigneeItemList.push({ type })\n }\n\n return assigneeItemList\n }\n\n @FieldResolver(type => [ApprovalLineItem], { description: 'Retrieves the approval line items for the dataset' })\n async approvalLine(@Root() dataSet: DataSet, @Ctx() context: ResolverContext): Promise<ApprovalLineItem[]> {\n const { domain, user } = context.state\n const { reviewApprovalLine } = dataSet\n\n if (!reviewApprovalLine || !(reviewApprovalLine instanceof Array)) {\n return null\n }\n\n var approvalLineItems = []\n\n for (let item of reviewApprovalLine) {\n // \"value\" deprecated. to be removed\n var { type, approver, value } = item\n var id = approver?.id || value\n approver = null\n\n switch (type) {\n case 'Employee':\n approver = id && (await getRepository('Employee').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Department':\n approver = id && (await getRepository('Department').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Role':\n approver = id && (await getRepository('Role').findOneBy({ domain: { id: domain.id }, id }))\n break\n case 'Myself':\n approver = user\n break\n case 'MyDepartment':\n case 'MySupervisor':\n break\n default:\n }\n\n id ? approvalLineItems.push({ type, approver }) : approvalLineItems.push({ type })\n }\n\n return approvalLineItems\n }\n\n @FieldResolver(type => Board, { nullable: true, description: 'Retrieves the entry board for the dataset' })\n async entryBoard(@Root() dataSet: DataSet): Promise<Board> {\n if (dataSet.entryType == 'board' && dataSet.entryView) {\n return await getRepository(Board).findOneBy({ id: dataSet.entryView })\n }\n }\n\n @FieldResolver(type => Board, { nullable: true, description: 'Retrieves the monitor board for the dataset' })\n async monitorBoard(@Root() dataSet: DataSet): Promise<Board> {\n if (dataSet.monitorType == 'board' && dataSet.monitorView) {\n return await getRepository(Board).findOneBy({ id: dataSet.monitorView })\n }\n }\n\n @FieldResolver(type => DataKeySet, { nullable: true, description: 'Retrieves the data key set for the dataset' })\n async dataKeySet(@Root() dataSet: DataSet): Promise<DataKeySet> {\n return (\n dataSet.dataKeySet ||\n (dataSet.dataKeySetId &&\n (await getRepository(DataKeySet).findOneBy({\n id: dataSet.dataKeySetId\n })))\n )\n }\n\n @FieldResolver(type => Scenario, { description: 'Retrieves the normal scenario for the dataset.' })\n async normalScenario(@Root() dataSet: DataSet): Promise<Scenario> {\n return (\n dataSet.normalScenario ||\n (dataSet.normalScenarioId &&\n (await getRepository(Scenario).findOneBy({\n id: dataSet.normalScenarioId\n })))\n )\n }\n\n @FieldResolver(type => Scenario, { description: 'Retrieves the outlier scenario for the dataset.' })\n async outlierScenario(@Root() dataSet: DataSet): Promise<Scenario> {\n return (\n dataSet.outlierScenario ||\n (dataSet.outlierScenarioId &&\n (await getRepository(Scenario).findOneBy({\n id: dataSet.outlierScenarioId\n })))\n )\n }\n\n // 데이터셋의 도메인을 조회\n @FieldResolver(type => Domain)\n async domain(@Root() dataSet: DataSet): Promise<Domain> {\n return dataSet.domainId && (await getRepository(Domain).findOneBy({ id: dataSet.domainId }))\n }\n\n // 데이터셋의 업데이트한 사용자를 조회\n @FieldResolver(type => User)\n async updater(@Root() dataSet: DataSet): Promise<User> {\n return dataSet.updaterId && (await getRepository(User).findOneBy({ id: dataSet.updaterId }))\n }\n\n // 데이터셋의 생성자를 조회\n @FieldResolver(type => User)\n async creator(@Root() dataSet: DataSet): Promise<User> {\n return dataSet.creatorId && (await getRepository(User).findOneBy({ id: dataSet.creatorId }))\n }\n\n @FieldResolver(type => Date, { nullable: true, description: 'Retrieves the latest collection time for the dataset.' })\n async latestCollectedAt(@Root() dataSet: DataSet): Promise<Date> {\n const sample = await getRepository(DataSample).findOne({\n select: ['id', 'collectedAt'],\n where: { dataSet: { id: dataSet.id } },\n order: { collectedAt: 'DESC' }\n })\n\n return sample?.collectedAt\n }\n\n @FieldResolver(type => Date, { nullable: true, description: 'Retrieves the next schedule time for the dataset.' })\n async nextSchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, schedule, timezone } = dataSet\n\n if (!schedule) {\n return\n }\n\n var interval = parser.parseExpression(schedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.next().toDate()\n }\n\n @FieldResolver(type => Date, { nullable: true, description: 'Retrieves the previous schedule time for the dataset.' })\n async prevSchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, schedule, timezone } = dataSet\n\n if (!schedule) {\n return\n }\n\n var interval = parser.parseExpression(schedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.prev().toDate()\n }\n\n @FieldResolver(type => Date, {\n nullable: true,\n description: 'Retrieves the next summary schedule time for the dataset.'\n })\n async nextSummarySchedule(@Root() dataSet: DataSet): Promise<Date> {\n const { domainId, summarySchedule, timezone } = dataSet\n\n if (!summarySchedule) {\n return\n }\n\n var interval = parser.parseExpression(summarySchedule, {\n tz: timezone || ((await getRepository(Domain).findOneBy({ id: domainId })) as Domain).timezone || 'UTC'\n })\n\n return interval.next().toDate()\n\n // FIXME: getSchedules 의 파라미터를 수정해야한다. scheduler 가 없거나 커넥션이 끊겨있어서 오래걸리는 문제는 어떻게 ?? 비동기로 처리한다. 어떻게???\n // client: {\n // application: Application,\n // group: `${domain.id}`,\n // type: 'data-set',\n // key: dataSet.id,\n // operation: 'summary'\n // }\n // const schedule = getSchedules('name', 'group', false)\n // return schedule.nextSchedule\n }\n\n @FieldResolver(type => String, { description: 'Retrieves the report template for the dataset.' })\n async reportTemplate(@Root() dataset: DataSet): Promise<string | undefined> {\n const attachment: Attachment = await getRepository(Attachment).findOne({\n where: {\n domain: { id: dataset.domainId },\n refType: `${DataSet.name}-report-template`,\n refBy: dataset.id\n }\n })\n\n return attachment?.path\n }\n\n @FieldResolver(returns => Boolean, { description: 'Whether the user is a supervisor for this dataset' })\n async isSupervisor(@Root() dataset: DataSet, @Ctx() context: ResolverContext): Promise<boolean> {\n const { user, domain } = context.state\n\n const foundUser = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n\n const roles = foundUser.roles\n .filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))\n .map(role => role.id)\n\n return roles.includes(dataset.supervisoryRoleId)\n }\n\n @FieldResolver(returns => Boolean, { description: 'Whether the user is allowed to enter data for this dataset' })\n async isEntryAllowed(@Root() dataset: DataSet, @Ctx() context: ResolverContext): Promise<boolean> {\n const { user, domain } = context.state\n\n const foundUser = await getRepository(User).findOne({\n where: { id: user.id },\n relations: ['roles']\n })\n\n const roles = foundUser.roles\n .filter(role => role.domainId === domain.id || (domain.parentId && role.domainId === domain.parentId))\n .map(role => role.id)\n\n return roles.includes(dataset.entryRoleId)\n }\n}\n"]}
|