@things-factory/dataset 9.0.0-beta.27 → 9.0.0-beta.29
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-client/activities/activity-data-collect-edit.d.ts +19 -0
- package/dist-client/activities/activity-data-collect-edit.js +105 -0
- package/dist-client/activities/activity-data-collect-edit.js.map +1 -0
- package/dist-client/activities/activity-data-collect-view.d.ts +16 -0
- package/dist-client/activities/activity-data-collect-view.js +94 -0
- package/dist-client/activities/activity-data-collect-view.js.map +1 -0
- package/dist-client/activities/activity-data-review-edit.d.ts +18 -0
- package/dist-client/activities/activity-data-review-edit.js +279 -0
- package/dist-client/activities/activity-data-review-edit.js.map +1 -0
- package/dist-client/activities/activity-data-review-view.d.ts +14 -0
- package/dist-client/activities/activity-data-review-view.js +224 -0
- package/dist-client/activities/activity-data-review-view.js.map +1 -0
- package/dist-client/activities/activity-ooc-resolve-edit.d.ts +2 -0
- package/dist-client/activities/activity-ooc-resolve-edit.js +196 -0
- package/dist-client/activities/activity-ooc-resolve-edit.js.map +1 -0
- package/dist-client/activities/activity-ooc-resolve-view.d.ts +14 -0
- package/dist-client/activities/activity-ooc-resolve-view.js +146 -0
- package/dist-client/activities/activity-ooc-resolve-view.js.map +1 -0
- package/dist-client/activities/activity-ooc-review-edit.d.ts +2 -0
- package/dist-client/activities/activity-ooc-review-edit.js +176 -0
- package/dist-client/activities/activity-ooc-review-edit.js.map +1 -0
- package/dist-client/activities/activity-ooc-review-view.d.ts +1 -0
- package/dist-client/activities/activity-ooc-review-view.js +133 -0
- package/dist-client/activities/activity-ooc-review-view.js.map +1 -0
- package/dist-client/bootstrap.d.ts +10 -0
- package/dist-client/bootstrap.js +26 -0
- package/dist-client/bootstrap.js.map +1 -0
- package/dist-client/components/data-entry-form.d.ts +20 -0
- package/dist-client/components/data-entry-form.js +108 -0
- package/dist-client/components/data-entry-form.js.map +1 -0
- package/dist-client/index.d.ts +1 -0
- package/dist-client/index.js +2 -0
- package/dist-client/index.js.map +1 -0
- package/dist-client/pages/data-archive/data-archive-list-page.d.ts +67 -0
- package/dist-client/pages/data-archive/data-archive-list-page.js +272 -0
- package/dist-client/pages/data-archive/data-archive-list-page.js.map +1 -0
- package/dist-client/pages/data-archive/data-archive-request-popup.d.ts +1 -0
- package/dist-client/pages/data-archive/data-archive-request-popup.js +160 -0
- package/dist-client/pages/data-archive/data-archive-request-popup.js.map +1 -0
- package/dist-client/pages/data-entry/checklist-entry-page.d.ts +21 -0
- package/dist-client/pages/data-entry/checklist-entry-page.js +209 -0
- package/dist-client/pages/data-entry/checklist-entry-page.js.map +1 -0
- package/dist-client/pages/data-entry/data-entry-list-page.d.ts +38 -0
- package/dist-client/pages/data-entry/data-entry-list-page.js +448 -0
- package/dist-client/pages/data-entry/data-entry-list-page.js.map +1 -0
- package/dist-client/pages/data-key-set/data-key-item-list.d.ts +19 -0
- package/dist-client/pages/data-key-set/data-key-item-list.js +182 -0
- package/dist-client/pages/data-key-set/data-key-item-list.js.map +1 -0
- package/dist-client/pages/data-key-set/data-key-set-importer.d.ts +10 -0
- package/dist-client/pages/data-key-set/data-key-set-importer.js +94 -0
- package/dist-client/pages/data-key-set/data-key-set-importer.js.map +1 -0
- package/dist-client/pages/data-key-set/data-key-set-list-page.d.ts +64 -0
- package/dist-client/pages/data-key-set/data-key-set-list-page.js +405 -0
- package/dist-client/pages/data-key-set/data-key-set-list-page.js.map +1 -0
- package/dist-client/pages/data-ooc/data-ooc-list-page.d.ts +72 -0
- package/dist-client/pages/data-ooc/data-ooc-list-page.js +545 -0
- package/dist-client/pages/data-ooc/data-ooc-list-page.js.map +1 -0
- package/dist-client/pages/data-ooc/data-ooc-page.d.ts +18 -0
- package/dist-client/pages/data-ooc/data-ooc-page.js +163 -0
- package/dist-client/pages/data-ooc/data-ooc-page.js.map +1 -0
- package/dist-client/pages/data-ooc/data-ooc-view.d.ts +19 -0
- package/dist-client/pages/data-ooc/data-ooc-view.js +232 -0
- package/dist-client/pages/data-ooc/data-ooc-view.js.map +1 -0
- package/dist-client/pages/data-ooc/data-oocs-page.d.ts +18 -0
- package/dist-client/pages/data-ooc/data-oocs-page.js +200 -0
- package/dist-client/pages/data-ooc/data-oocs-page.js.map +1 -0
- package/dist-client/pages/data-report/data-report-embed-page.d.ts +36 -0
- package/dist-client/pages/data-report/data-report-embed-page.js +101 -0
- package/dist-client/pages/data-report/data-report-embed-page.js.map +1 -0
- package/dist-client/pages/data-report/data-report-list-page.d.ts +38 -0
- package/dist-client/pages/data-report/data-report-list-page.js +441 -0
- package/dist-client/pages/data-report/data-report-list-page.js.map +1 -0
- package/dist-client/pages/data-report/data-report-samples-page.d.ts +32 -0
- package/dist-client/pages/data-report/data-report-samples-page.js +166 -0
- package/dist-client/pages/data-report/data-report-samples-page.js.map +1 -0
- package/dist-client/pages/data-report/jasper-report-oocs-page.d.ts +2 -0
- package/dist-client/pages/data-report/jasper-report-oocs-page.js +101 -0
- package/dist-client/pages/data-report/jasper-report-oocs-page.js.map +1 -0
- package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.d.ts +2 -0
- package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.js +101 -0
- package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.js.map +1 -0
- package/dist-client/pages/data-report/jasper-report-samples-page.d.ts +2 -0
- package/dist-client/pages/data-report/jasper-report-samples-page.js +101 -0
- package/dist-client/pages/data-report/jasper-report-samples-page.js.map +1 -0
- package/dist-client/pages/data-sample/data-sample-list-page.d.ts +70 -0
- package/dist-client/pages/data-sample/data-sample-list-page.js +437 -0
- package/dist-client/pages/data-sample/data-sample-list-page.js.map +1 -0
- package/dist-client/pages/data-sample/data-sample-page.d.ts +17 -0
- package/dist-client/pages/data-sample/data-sample-page.js +57 -0
- package/dist-client/pages/data-sample/data-sample-page.js.map +1 -0
- package/dist-client/pages/data-sample/data-sample-search-page.d.ts +59 -0
- package/dist-client/pages/data-sample/data-sample-search-page.js +421 -0
- package/dist-client/pages/data-sample/data-sample-search-page.js.map +1 -0
- package/dist-client/pages/data-sample/data-sample-view.d.ts +21 -0
- package/dist-client/pages/data-sample/data-sample-view.js +285 -0
- package/dist-client/pages/data-sample/data-sample-view.js.map +1 -0
- package/dist-client/pages/data-sample/data-samples-page.d.ts +21 -0
- package/dist-client/pages/data-sample/data-samples-page.js +249 -0
- package/dist-client/pages/data-sample/data-samples-page.js.map +1 -0
- package/dist-client/pages/data-sensor/data-sensor-list-page.d.ts +58 -0
- package/dist-client/pages/data-sensor/data-sensor-list-page.js +455 -0
- package/dist-client/pages/data-sensor/data-sensor-list-page.js.map +1 -0
- package/dist-client/pages/data-set/data-item-list.d.ts +1 -0
- package/dist-client/pages/data-set/data-item-list.js +306 -0
- package/dist-client/pages/data-set/data-item-list.js.map +1 -0
- package/dist-client/pages/data-set/data-set-importer.d.ts +11 -0
- package/dist-client/pages/data-set/data-set-importer.js +97 -0
- package/dist-client/pages/data-set/data-set-importer.js.map +1 -0
- package/dist-client/pages/data-set/data-set-list-page.d.ts +83 -0
- package/dist-client/pages/data-set/data-set-list-page.js +1048 -0
- package/dist-client/pages/data-set/data-set-list-page.js.map +1 -0
- package/dist-client/pages/data-summary/data-summary-list-page.d.ts +59 -0
- package/dist-client/pages/data-summary/data-summary-list-page.js +361 -0
- package/dist-client/pages/data-summary/data-summary-list-page.js.map +1 -0
- package/dist-client/pages/data-summary/data-summary-period-page.d.ts +81 -0
- package/dist-client/pages/data-summary/data-summary-period-page.js +459 -0
- package/dist-client/pages/data-summary/data-summary-period-page.js.map +1 -0
- package/dist-client/pages/data-summary/data-summary-search-page.d.ts +78 -0
- package/dist-client/pages/data-summary/data-summary-search-page.js +413 -0
- package/dist-client/pages/data-summary/data-summary-search-page.js.map +1 -0
- package/dist-client/pages/data-summary/data-summary-view.d.ts +1 -0
- package/dist-client/pages/data-summary/data-summary-view.js +114 -0
- package/dist-client/pages/data-summary/data-summary-view.js.map +1 -0
- package/dist-client/route.d.ts +1 -0
- package/dist-client/route.js +74 -0
- package/dist-client/route.js.map +1 -0
- package/dist-client/tsconfig.tsbuildinfo +1 -0
- package/dist-server/activities/activity-data-collect.d.ts +42 -0
- package/dist-server/activities/activity-data-collect.js +87 -0
- package/dist-server/activities/activity-data-collect.js.map +1 -0
- package/dist-server/activities/activity-data-review.d.ts +42 -0
- package/dist-server/activities/activity-data-review.js +87 -0
- package/dist-server/activities/activity-data-review.js.map +1 -0
- package/dist-server/activities/activity-ooc-resolve.d.ts +42 -0
- package/dist-server/activities/activity-ooc-resolve.js +104 -0
- package/dist-server/activities/activity-ooc-resolve.js.map +1 -0
- package/dist-server/activities/activity-ooc-review.d.ts +42 -0
- package/dist-server/activities/activity-ooc-review.js +82 -0
- package/dist-server/activities/activity-ooc-review.js.map +1 -0
- package/dist-server/activities/index.d.ts +1 -0
- package/dist-server/activities/index.js +11 -0
- package/dist-server/activities/index.js.map +1 -0
- package/dist-server/controllers/create-data-ooc.d.ts +4 -0
- package/dist-server/controllers/create-data-ooc.js +65 -0
- package/dist-server/controllers/create-data-ooc.js.map +1 -0
- package/dist-server/controllers/create-data-sample.d.ts +3 -0
- package/dist-server/controllers/create-data-sample.js +268 -0
- package/dist-server/controllers/create-data-sample.js.map +1 -0
- package/dist-server/controllers/data-use-case.d.ts +36 -0
- package/dist-server/controllers/data-use-case.js +63 -0
- package/dist-server/controllers/data-use-case.js.map +1 -0
- package/dist-server/controllers/finalize-data-collection.d.ts +4 -0
- package/dist-server/controllers/finalize-data-collection.js +328 -0
- package/dist-server/controllers/finalize-data-collection.js.map +1 -0
- package/dist-server/controllers/index.d.ts +6 -0
- package/dist-server/controllers/index.js +10 -0
- package/dist-server/controllers/index.js.map +1 -0
- package/dist-server/controllers/issue-data-collection-task.d.ts +2 -0
- package/dist-server/controllers/issue-data-collection-task.js +57 -0
- package/dist-server/controllers/issue-data-collection-task.js.map +1 -0
- package/dist-server/controllers/issue-ooc-resolve.d.ts +3 -0
- package/dist-server/controllers/issue-ooc-resolve.js +49 -0
- package/dist-server/controllers/issue-ooc-resolve.js.map +1 -0
- package/dist-server/controllers/issue-ooc-review.d.ts +3 -0
- package/dist-server/controllers/issue-ooc-review.js +47 -0
- package/dist-server/controllers/issue-ooc-review.js.map +1 -0
- package/dist-server/controllers/jasper-report.d.ts +1 -0
- package/dist-server/controllers/jasper-report.js +163 -0
- package/dist-server/controllers/jasper-report.js.map +1 -0
- package/dist-server/controllers/query-data-summary-by-period.d.ts +3 -0
- package/dist-server/controllers/query-data-summary-by-period.js +157 -0
- package/dist-server/controllers/query-data-summary-by-period.js.map +1 -0
- package/dist-server/controllers/shiny-report.d.ts +1 -0
- package/dist-server/controllers/shiny-report.js +35 -0
- package/dist-server/controllers/shiny-report.js.map +1 -0
- package/dist-server/engine/index.d.ts +1 -0
- package/dist-server/engine/index.js +4 -0
- package/dist-server/engine/index.js.map +1 -0
- package/dist-server/engine/task/create-data-sample.d.ts +1 -0
- package/dist-server/engine/task/create-data-sample.js +81 -0
- package/dist-server/engine/task/create-data-sample.js.map +1 -0
- package/dist-server/engine/task/index.d.ts +2 -0
- package/dist-server/engine/task/index.js +5 -0
- package/dist-server/engine/task/index.js.map +1 -0
- package/dist-server/engine/task/issue-collect-data.d.ts +1 -0
- package/dist-server/engine/task/issue-collect-data.js +40 -0
- package/dist-server/engine/task/issue-collect-data.js.map +1 -0
- package/dist-server/index.d.ts +6 -0
- package/dist-server/index.js +10 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/routes.d.ts +1 -0
- package/dist-server/routes.js +140 -0
- package/dist-server/routes.js.map +1 -0
- package/dist-server/service/data-archive/data-archive-mutation.d.ts +16 -0
- package/dist-server/service/data-archive/data-archive-mutation.js +227 -0
- package/dist-server/service/data-archive/data-archive-mutation.js.map +1 -0
- package/dist-server/service/data-archive/data-archive-query.d.ts +11 -0
- package/dist-server/service/data-archive/data-archive-query.js +83 -0
- package/dist-server/service/data-archive/data-archive-query.js.map +1 -0
- package/dist-server/service/data-archive/data-archive-type.d.ts +23 -0
- package/dist-server/service/data-archive/data-archive-type.js +74 -0
- package/dist-server/service/data-archive/data-archive-type.js.map +1 -0
- package/dist-server/service/data-archive/data-archive.d.ts +19 -0
- package/dist-server/service/data-archive/data-archive.js +79 -0
- package/dist-server/service/data-archive/data-archive.js.map +1 -0
- package/dist-server/service/data-archive/index.d.ts +5 -0
- package/dist-server/service/data-archive/index.js +9 -0
- package/dist-server/service/data-archive/index.js.map +1 -0
- package/dist-server/service/data-key-set/data-key-item-type.d.ts +12 -0
- package/dist-server/service/data-key-set/data-key-item-type.js +50 -0
- package/dist-server/service/data-key-set/data-key-item-type.js.map +1 -0
- package/dist-server/service/data-key-set/data-key-set-mutation.d.ts +10 -0
- package/dist-server/service/data-key-set/data-key-set-mutation.js +168 -0
- package/dist-server/service/data-key-set/data-key-set-mutation.js.map +1 -0
- package/dist-server/service/data-key-set/data-key-set-query.d.ts +12 -0
- package/dist-server/service/data-key-set/data-key-set-query.js +98 -0
- package/dist-server/service/data-key-set/data-key-set-query.js.map +1 -0
- package/dist-server/service/data-key-set/data-key-set-type.d.ts +28 -0
- package/dist-server/service/data-key-set/data-key-set-type.js +100 -0
- package/dist-server/service/data-key-set/data-key-set-type.js.map +1 -0
- package/dist-server/service/data-key-set/data-key-set.d.ts +22 -0
- package/dist-server/service/data-key-set/data-key-set.js +99 -0
- package/dist-server/service/data-key-set/data-key-set.js.map +1 -0
- package/dist-server/service/data-key-set/index.d.ts +5 -0
- package/dist-server/service/data-key-set/index.js +9 -0
- package/dist-server/service/data-key-set/index.js.map +1 -0
- package/dist-server/service/data-ooc/data-ooc-mutation.d.ts +6 -0
- package/dist-server/service/data-ooc/data-ooc-mutation.js +81 -0
- package/dist-server/service/data-ooc/data-ooc-mutation.js.map +1 -0
- package/dist-server/service/data-ooc/data-ooc-query.d.ts +22 -0
- package/dist-server/service/data-ooc/data-ooc-query.js +165 -0
- package/dist-server/service/data-ooc/data-ooc-query.js.map +1 -0
- package/dist-server/service/data-ooc/data-ooc-subscription.d.ts +7 -0
- package/dist-server/service/data-ooc/data-ooc-subscription.js +51 -0
- package/dist-server/service/data-ooc/data-ooc-subscription.js.map +1 -0
- package/dist-server/service/data-ooc/data-ooc-type.d.ts +27 -0
- package/dist-server/service/data-ooc/data-ooc-type.js +102 -0
- package/dist-server/service/data-ooc/data-ooc-type.js.map +1 -0
- package/dist-server/service/data-ooc/data-ooc.d.ts +63 -0
- package/dist-server/service/data-ooc/data-ooc.js +304 -0
- package/dist-server/service/data-ooc/data-ooc.js.map +1 -0
- package/dist-server/service/data-ooc/index.d.ts +6 -0
- package/dist-server/service/data-ooc/index.js +10 -0
- package/dist-server/service/data-ooc/index.js.map +1 -0
- package/dist-server/service/data-sample/data-sample-mutation.d.ts +5 -0
- package/dist-server/service/data-sample/data-sample-mutation.js +28 -0
- package/dist-server/service/data-sample/data-sample-mutation.js.map +1 -0
- package/dist-server/service/data-sample/data-sample-query.d.ts +22 -0
- package/dist-server/service/data-sample/data-sample-query.js +249 -0
- package/dist-server/service/data-sample/data-sample-query.js.map +1 -0
- package/dist-server/service/data-sample/data-sample-type.d.ts +18 -0
- package/dist-server/service/data-sample/data-sample-type.js +68 -0
- package/dist-server/service/data-sample/data-sample-type.js.map +1 -0
- package/dist-server/service/data-sample/data-sample.d.ts +45 -0
- package/dist-server/service/data-sample/data-sample.js +221 -0
- package/dist-server/service/data-sample/data-sample.js.map +1 -0
- package/dist-server/service/data-sample/index.d.ts +5 -0
- package/dist-server/service/data-sample/index.js +9 -0
- package/dist-server/service/data-sample/index.js.map +1 -0
- package/dist-server/service/data-sensor/data-sensor-mutation.d.ts +9 -0
- package/dist-server/service/data-sensor/data-sensor-mutation.js +109 -0
- package/dist-server/service/data-sensor/data-sensor-mutation.js.map +1 -0
- package/dist-server/service/data-sensor/data-sensor-query.d.ts +16 -0
- package/dist-server/service/data-sensor/data-sensor-query.js +115 -0
- package/dist-server/service/data-sensor/data-sensor-query.js.map +1 -0
- package/dist-server/service/data-sensor/data-sensor-type.d.ts +38 -0
- package/dist-server/service/data-sensor/data-sensor-type.js +146 -0
- package/dist-server/service/data-sensor/data-sensor-type.js.map +1 -0
- package/dist-server/service/data-sensor/data-sensor.d.ts +31 -0
- package/dist-server/service/data-sensor/data-sensor.js +148 -0
- package/dist-server/service/data-sensor/data-sensor.js.map +1 -0
- package/dist-server/service/data-sensor/index.d.ts +5 -0
- package/dist-server/service/data-sensor/index.js +9 -0
- package/dist-server/service/data-sensor/index.js.map +1 -0
- package/dist-server/service/data-set/data-item-type.d.ts +62 -0
- package/dist-server/service/data-set/data-item-type.js +199 -0
- package/dist-server/service/data-set/data-item-type.js.map +1 -0
- package/dist-server/service/data-set/data-set-mutation.d.ts +20 -0
- package/dist-server/service/data-set/data-set-mutation.js +474 -0
- package/dist-server/service/data-set/data-set-mutation.js.map +1 -0
- package/dist-server/service/data-set/data-set-query.d.ts +39 -0
- package/dist-server/service/data-set/data-set-query.js +545 -0
- package/dist-server/service/data-set/data-set-query.js.map +1 -0
- package/dist-server/service/data-set/data-set-type.d.ts +75 -0
- package/dist-server/service/data-set/data-set-type.js +274 -0
- package/dist-server/service/data-set/data-set-type.js.map +1 -0
- package/dist-server/service/data-set/data-set.d.ts +95 -0
- package/dist-server/service/data-set/data-set.js +375 -0
- package/dist-server/service/data-set/data-set.js.map +1 -0
- package/dist-server/service/data-set/index.d.ts +5 -0
- package/dist-server/service/data-set/index.js +9 -0
- package/dist-server/service/data-set/index.js.map +1 -0
- package/dist-server/service/data-set-history/data-set-history-query.d.ts +21 -0
- package/dist-server/service/data-set-history/data-set-history-query.js +177 -0
- package/dist-server/service/data-set-history/data-set-history-query.js.map +1 -0
- package/dist-server/service/data-set-history/data-set-history-type.d.ts +5 -0
- package/dist-server/service/data-set-history/data-set-history-type.js +21 -0
- package/dist-server/service/data-set-history/data-set-history-type.js.map +1 -0
- package/dist-server/service/data-set-history/data-set-history.d.ts +53 -0
- package/dist-server/service/data-set-history/data-set-history.js +246 -0
- package/dist-server/service/data-set-history/data-set-history.js.map +1 -0
- package/dist-server/service/data-set-history/event-subscriber.d.ts +7 -0
- package/dist-server/service/data-set-history/event-subscriber.js +21 -0
- package/dist-server/service/data-set-history/event-subscriber.js.map +1 -0
- package/dist-server/service/data-set-history/index.d.ts +6 -0
- package/dist-server/service/data-set-history/index.js +10 -0
- package/dist-server/service/data-set-history/index.js.map +1 -0
- package/dist-server/service/data-spec/data-spec-manager.d.ts +10 -0
- package/dist-server/service/data-spec/data-spec-manager.js +20 -0
- package/dist-server/service/data-spec/data-spec-manager.js.map +1 -0
- package/dist-server/service/data-spec/data-spec-query.d.ts +5 -0
- package/dist-server/service/data-spec/data-spec-query.js +37 -0
- package/dist-server/service/data-spec/data-spec-query.js.map +1 -0
- package/dist-server/service/data-spec/data-spec.d.ts +19 -0
- package/dist-server/service/data-spec/data-spec.js +69 -0
- package/dist-server/service/data-spec/data-spec.js.map +1 -0
- package/dist-server/service/data-spec/index.d.ts +4 -0
- package/dist-server/service/data-spec/index.js +8 -0
- package/dist-server/service/data-spec/index.js.map +1 -0
- package/dist-server/service/data-summary/data-summary-mutation.d.ts +6 -0
- package/dist-server/service/data-summary/data-summary-mutation.js +72 -0
- package/dist-server/service/data-summary/data-summary-mutation.js.map +1 -0
- package/dist-server/service/data-summary/data-summary-query.d.ts +19 -0
- package/dist-server/service/data-summary/data-summary-query.js +214 -0
- package/dist-server/service/data-summary/data-summary-query.js.map +1 -0
- package/dist-server/service/data-summary/data-summary-type.d.ts +33 -0
- package/dist-server/service/data-summary/data-summary-type.js +137 -0
- package/dist-server/service/data-summary/data-summary-type.js.map +1 -0
- package/dist-server/service/data-summary/data-summary.d.ts +38 -0
- package/dist-server/service/data-summary/data-summary.js +200 -0
- package/dist-server/service/data-summary/data-summary.js.map +1 -0
- package/dist-server/service/data-summary/index.d.ts +6 -0
- package/dist-server/service/data-summary/index.js +10 -0
- package/dist-server/service/data-summary/index.js.map +1 -0
- package/dist-server/service/index.d.ts +14 -0
- package/dist-server/service/index.js +54 -0
- package/dist-server/service/index.js.map +1 -0
- package/dist-server/tsconfig.tsbuildinfo +1 -0
- package/dist-server/utils/config-resolver.d.ts +1 -0
- package/dist-server/utils/config-resolver.js +32 -0
- package/dist-server/utils/config-resolver.js.map +1 -0
- package/dist-server/utils/index.d.ts +1 -0
- package/dist-server/utils/index.js +5 -0
- package/dist-server/utils/index.js.map +1 -0
- package/package.json +13 -13
@@ -0,0 +1,163 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.renderJasperReport = renderJasperReport;
|
4
|
+
const tslib_1 = require("tslib");
|
5
|
+
const form_data_1 = tslib_1.__importDefault(require("form-data"));
|
6
|
+
const node_fetch_1 = tslib_1.__importDefault(require("node-fetch"));
|
7
|
+
const config_resolver_js_1 = require("../utils/config-resolver.js");
|
8
|
+
const attachment_base_1 = require("@things-factory/attachment-base");
|
9
|
+
const aws_base_1 = require("@things-factory/aws-base");
|
10
|
+
const env_1 = require("@things-factory/env");
|
11
|
+
const dataReportConfig = env_1.config.get('dataReport');
|
12
|
+
const { jasper: { endpoint: ENDPOINT, datasource: { database: DATABASE } } } = dataReportConfig || {
|
13
|
+
jasper: {
|
14
|
+
endpoint: {},
|
15
|
+
datasource: {}
|
16
|
+
}
|
17
|
+
};
|
18
|
+
function transformValuesToRows(queryResult) {
|
19
|
+
var parseData = [];
|
20
|
+
let index = 1;
|
21
|
+
for (let i = 0; i < queryResult.Items.length; i++) {
|
22
|
+
var j = 0;
|
23
|
+
const data = JSON.parse(queryResult.Items[i].data);
|
24
|
+
const spec = JSON.parse(queryResult.Items[i].spec);
|
25
|
+
for (let key in data) {
|
26
|
+
if (Array.isArray(data[key])) {
|
27
|
+
for (j = 0; j < data[key].length; j++) {
|
28
|
+
for (let specKey in spec) {
|
29
|
+
if (key === specKey) {
|
30
|
+
parseData.push({
|
31
|
+
item: spec[specKey].name,
|
32
|
+
index: index + j,
|
33
|
+
value: String(data[key][j])
|
34
|
+
});
|
35
|
+
}
|
36
|
+
}
|
37
|
+
}
|
38
|
+
}
|
39
|
+
else {
|
40
|
+
parseData.push({
|
41
|
+
item: key,
|
42
|
+
index,
|
43
|
+
value: String(data[key])
|
44
|
+
});
|
45
|
+
}
|
46
|
+
}
|
47
|
+
if (j !== 0) {
|
48
|
+
index = index + j;
|
49
|
+
}
|
50
|
+
else {
|
51
|
+
index = index + 1;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
}
|
55
|
+
/** @todo considering trasformation in lambda, as massive dataset */
|
56
|
+
function pivotData(rows) {
|
57
|
+
var _a, _b;
|
58
|
+
let parsedData = [];
|
59
|
+
let index = 1;
|
60
|
+
for (let i = 0; i < rows.length; i++) {
|
61
|
+
let j = 0;
|
62
|
+
const data = JSON.parse(rows[i].data);
|
63
|
+
const spec = JSON.parse(rows[i].spec);
|
64
|
+
for (let key in data) {
|
65
|
+
/** @todo rule to display or not, about unspecified spec */
|
66
|
+
const value = data[key];
|
67
|
+
!((_a = spec[key]) === null || _a === void 0 ? void 0 : _a.hidden) &&
|
68
|
+
parsedData.push({
|
69
|
+
item: ((_b = spec[key]) === null || _b === void 0 ? void 0 : _b.name) || key,
|
70
|
+
index,
|
71
|
+
value: Array.isArray(value) ? value.join(', ') : value
|
72
|
+
});
|
73
|
+
}
|
74
|
+
if (j !== 0) {
|
75
|
+
index = index + j;
|
76
|
+
}
|
77
|
+
else {
|
78
|
+
index = index + 1;
|
79
|
+
}
|
80
|
+
}
|
81
|
+
return parsedData;
|
82
|
+
}
|
83
|
+
function parseJsonDataField(rows) {
|
84
|
+
let parsedData = [];
|
85
|
+
for (let i = 0; i < rows.length; i++) {
|
86
|
+
const row = rows[i];
|
87
|
+
const data = JSON.parse(row.data);
|
88
|
+
for (let key in data) {
|
89
|
+
if (Array.isArray(data[key])) {
|
90
|
+
data[key] = data[key].toString();
|
91
|
+
}
|
92
|
+
}
|
93
|
+
delete row.data;
|
94
|
+
parsedData.push(Object.assign(Object.assign({}, row), data));
|
95
|
+
}
|
96
|
+
return parsedData;
|
97
|
+
}
|
98
|
+
const athenaClient = new aws_base_1.AthenaController();
|
99
|
+
async function queryAthena(params) {
|
100
|
+
const { table, domain, datasetId, startDate, endDate, workShift, timezone } = params;
|
101
|
+
const queryData = {
|
102
|
+
sql: `SELECT ds.name, ds.description, ds.data, dsh.data_items as spec, ds.workdate, ds.workshift,
|
103
|
+
DATE_FORMAT(
|
104
|
+
FROM_UNIXTIME(collected_at / 1000 / 1000) AT TIME ZONE '${timezone || 'UTC'}',
|
105
|
+
'%Y-%m-%d %H:%i:%s'
|
106
|
+
) AS dscollected_at
|
107
|
+
FROM ${table} ds
|
108
|
+
JOIN data_set_histories dsh
|
109
|
+
ON (ds.datasetid = dsh.original_id
|
110
|
+
and ds.data_set_version = dsh.version)
|
111
|
+
WHERE ds.domain='${domain}'
|
112
|
+
AND ds.datasetid = '${datasetId}'
|
113
|
+
AND ds.workdate >= '${startDate}'
|
114
|
+
AND ds.workdate <= '${endDate}'
|
115
|
+
${workShift ? "AND ds.workshift = '" + workShift + "'" : ''}
|
116
|
+
ORDER BY ds.collected_at`,
|
117
|
+
db: DATABASE
|
118
|
+
};
|
119
|
+
// and json_extract_scalar(data, '$.dauid') = 'A8032AD81730'
|
120
|
+
return await athenaClient.query(queryData);
|
121
|
+
}
|
122
|
+
async function renderJasperReport(context) {
|
123
|
+
const { state: { domain }, query } = context;
|
124
|
+
const template = await attachment_base_1.STORAGE.readFile(query['reportTemplate'] || 'dynamic_header_sample.jrxml', 'utf-8');
|
125
|
+
let templateType = query['templateType'] || 'crosstab';
|
126
|
+
let parsedData = [];
|
127
|
+
// @todo: get dataset timezone
|
128
|
+
/**
|
129
|
+
* const variables = await gql(dataSet(id:${dataSetId}) {
|
130
|
+
* name, description, partition_keys, timezone
|
131
|
+
* })
|
132
|
+
*/
|
133
|
+
query['domain'] = domain === null || domain === void 0 ? void 0 : domain.subdomain;
|
134
|
+
query['timezone'] = domain === null || domain === void 0 ? void 0 : domain.timezone;
|
135
|
+
const queryResult = await queryAthena(query);
|
136
|
+
const rows = queryResult.Items;
|
137
|
+
if (!rows.length) {
|
138
|
+
return '<h3>Not found result.</h3>';
|
139
|
+
}
|
140
|
+
else {
|
141
|
+
const firstRow = rows[0];
|
142
|
+
// uses the first row values as data-set has no history data.
|
143
|
+
const parameters = Object.assign({ name: firstRow.name, description: firstRow.description }, query);
|
144
|
+
if (templateType === 'crosstab') {
|
145
|
+
parsedData = pivotData(rows);
|
146
|
+
}
|
147
|
+
else {
|
148
|
+
parsedData = parseJsonDataField(rows);
|
149
|
+
}
|
150
|
+
const formData = new form_data_1.default();
|
151
|
+
formData.append('template', template);
|
152
|
+
formData.append('jsonString', JSON.stringify(parsedData));
|
153
|
+
formData.append('parameters', JSON.stringify(parameters));
|
154
|
+
const { reportView } = query;
|
155
|
+
const url = (0, config_resolver_js_1.getEndpointUrl)(ENDPOINT, reportView);
|
156
|
+
const response = await (0, node_fetch_1.default)(url, {
|
157
|
+
method: 'POST',
|
158
|
+
body: formData
|
159
|
+
});
|
160
|
+
return await response.text();
|
161
|
+
}
|
162
|
+
}
|
163
|
+
//# sourceMappingURL=jasper-report.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"jasper-report.js","sourceRoot":"","sources":["../../server/controllers/jasper-report.ts"],"names":[],"mappings":"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","sourcesContent":["import FormData from 'form-data'\nimport fetch from 'node-fetch'\n\nimport { getEndpointUrl } from '../utils/config-resolver.js'\n\nimport { STORAGE } from '@things-factory/attachment-base'\nimport { AthenaController } from '@things-factory/aws-base'\nimport { config } from '@things-factory/env'\n\nconst dataReportConfig = config.get('dataReport')\nconst {\n jasper: {\n endpoint: ENDPOINT,\n datasource: { database: DATABASE }\n }\n} = dataReportConfig || {\n jasper: {\n endpoint: {},\n datasource: {}\n }\n}\n\nfunction transformValuesToRows(queryResult) {\n var parseData = []\n let index = 1\n for (let i = 0; i < queryResult.Items.length; i++) {\n var j = 0\n const data = JSON.parse(queryResult.Items[i].data)\n const spec = JSON.parse(queryResult.Items[i].spec)\n\n for (let key in data) {\n if (Array.isArray(data[key])) {\n for (j = 0; j < data[key].length; j++) {\n for (let specKey in spec) {\n if (key === specKey) {\n parseData.push({\n item: spec[specKey].name,\n index: index + j,\n value: String(data[key][j])\n })\n }\n }\n }\n } else {\n parseData.push({\n item: key,\n index,\n value: String(data[key])\n })\n }\n }\n if (j !== 0) {\n index = index + j\n } else {\n index = index + 1\n }\n }\n}\n\n/** @todo considering trasformation in lambda, as massive dataset */\nfunction pivotData(rows) {\n let parsedData = []\n let index = 1\n for (let i = 0; i < rows.length; i++) {\n let j = 0\n const data = JSON.parse(rows[i].data)\n const spec = JSON.parse(rows[i].spec)\n\n for (let key in data) {\n /** @todo rule to display or not, about unspecified spec */\n const value = data[key]\n !spec[key]?.hidden &&\n parsedData.push({\n item: spec[key]?.name || key,\n index,\n value: Array.isArray(value) ? value.join(', ') : value\n })\n }\n if (j !== 0) {\n index = index + j\n } else {\n index = index + 1\n }\n }\n\n return parsedData\n}\n\nfunction parseJsonDataField(rows) {\n let parsedData = []\n for (let i = 0; i < rows.length; i++) {\n const row = rows[i]\n const data = JSON.parse(row.data)\n for (let key in data) {\n if (Array.isArray(data[key])) {\n data[key] = data[key].toString()\n }\n }\n delete row.data\n parsedData.push({ ...row, ...data })\n }\n\n return parsedData\n}\n\nconst athenaClient = new AthenaController()\n\nasync function queryAthena(params) {\n const { table, domain, datasetId, startDate, endDate, workShift, timezone } = params\n const queryData = {\n sql: `SELECT ds.name, ds.description, ds.data, dsh.data_items as spec, ds.workdate, ds.workshift,\n DATE_FORMAT(\n FROM_UNIXTIME(collected_at / 1000 / 1000) AT TIME ZONE '${timezone || 'UTC'}', \n '%Y-%m-%d %H:%i:%s'\n ) AS dscollected_at\n FROM ${table} ds\n JOIN data_set_histories dsh \n ON (ds.datasetid = dsh.original_id\n and ds.data_set_version = dsh.version)\n WHERE ds.domain='${domain}' \n AND ds.datasetid = '${datasetId}'\n AND ds.workdate >= '${startDate}'\n AND ds.workdate <= '${endDate}'\n ${workShift ? \"AND ds.workshift = '\" + workShift + \"'\" : ''}\n ORDER BY ds.collected_at`,\n db: DATABASE\n }\n // and json_extract_scalar(data, '$.dauid') = 'A8032AD81730'\n\n return await athenaClient.query(queryData)\n}\n\nexport async function renderJasperReport(context: any) {\n const {\n state: { domain },\n query\n } = context\n\n const template = await STORAGE.readFile(query['reportTemplate'] || 'dynamic_header_sample.jrxml', 'utf-8')\n let templateType = query['templateType'] || 'crosstab'\n let parsedData = []\n\n // @todo: get dataset timezone\n /**\n * const variables = await gql(dataSet(id:${dataSetId}) {\n * name, description, partition_keys, timezone\n * })\n */\n\n query['domain'] = domain?.subdomain\n query['timezone'] = domain?.timezone\n const queryResult = await queryAthena(query)\n const rows = queryResult.Items\n\n if (!rows.length) {\n return '<h3>Not found result.</h3>'\n } else {\n const firstRow = rows[0]\n // uses the first row values as data-set has no history data.\n const parameters = {\n name: firstRow.name,\n description: firstRow.description,\n ...query\n }\n\n if (templateType === 'crosstab') {\n parsedData = pivotData(rows)\n } else {\n parsedData = parseJsonDataField(rows)\n }\n\n const formData = new FormData()\n formData.append('template', template)\n formData.append('jsonString', JSON.stringify(parsedData))\n formData.append('parameters', JSON.stringify(parameters))\n\n const { reportView } = query\n const url = getEndpointUrl(ENDPOINT, reportView)\n const response = await fetch(url, {\n method: 'POST',\n body: formData\n })\n\n return await response.text()\n }\n}\n"]}
|
@@ -0,0 +1,3 @@
|
|
1
|
+
import { ListParam } from '@things-factory/shell';
|
2
|
+
import { DataSummary } from '../service/data-summary/data-summary.js';
|
3
|
+
export declare function queryDataSummaryByPeriod(period: 'today' | 'this month' | '30 days' | 'this year' | '12 months' | 'date range' | 'month', dataSetName: string, dataKeys: string[] | null, params: ListParam, context: ResolverContext): Promise<DataSummary[]>;
|
@@ -0,0 +1,157 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.queryDataSummaryByPeriod = queryDataSummaryByPeriod;
|
4
|
+
const typeorm_1 = require("typeorm");
|
5
|
+
const shell_1 = require("@things-factory/shell");
|
6
|
+
const data_set_js_1 = require("../service/data-set/data-set.js");
|
7
|
+
const data_summary_js_1 = require("../service/data-summary/data-summary.js");
|
8
|
+
const STAT_FUNCTION_MAP = {
|
9
|
+
sum: 'sum',
|
10
|
+
mean: 'mean',
|
11
|
+
stddev: 'standardDeviation',
|
12
|
+
variance: 'variance',
|
13
|
+
min: 'min',
|
14
|
+
max: 'max',
|
15
|
+
range: 'range',
|
16
|
+
median: 'median',
|
17
|
+
mode: 'mode'
|
18
|
+
};
|
19
|
+
async function queryDataSummaryByPeriod(period, dataSetName, dataKeys, params, context) {
|
20
|
+
var _a, _b;
|
21
|
+
const { domain, user, tx } = context.state;
|
22
|
+
const { t } = context;
|
23
|
+
const dataSet = await (0, shell_1.getRepository)(data_set_js_1.DataSet).findOne({
|
24
|
+
where: { domain: { id: (0, typeorm_1.In)([domain.id, domain.parentId].filter(Boolean)) }, name: dataSetName },
|
25
|
+
relations: ['dataKeySet']
|
26
|
+
});
|
27
|
+
if (!dataSet) {
|
28
|
+
throw new Error(t('error.dataset not found', { dataSetName }));
|
29
|
+
}
|
30
|
+
// limitations
|
31
|
+
const summaryPeriodType = dataSet.summaryPeriod;
|
32
|
+
if ((summaryPeriodType == data_set_js_1.DataSetSummaryPeriodType.Day || summaryPeriodType == data_set_js_1.DataSetSummaryPeriodType.WorkDate) &&
|
33
|
+
period == 'today') {
|
34
|
+
throw new Error(t('error.summary not supported', { dataSetName, period: t(`label.period-${period}`) }));
|
35
|
+
}
|
36
|
+
// dataKeys 가 설정되지 않았다면, dataSet의 dataKeySet을 그대로 적용한다는 의미임.
|
37
|
+
// dataKeys == [] 라면, dataKeySet을 적용하지 않는다는 의미임.
|
38
|
+
// dataKeys에는 dataKeySet의 dataKey 값을 따라야 한다.
|
39
|
+
const dataKeyItems = !((_a = dataSet.dataKeySet) === null || _a === void 0 ? void 0 : _a.dataKeyItems)
|
40
|
+
? []
|
41
|
+
: dataKeys
|
42
|
+
? dataKeys
|
43
|
+
.map(dataKey => {
|
44
|
+
return dataSet.dataKeySet.dataKeyItems.find(item => item.dataKey == dataKey);
|
45
|
+
})
|
46
|
+
.filter(Boolean)
|
47
|
+
: dataSet.dataKeySet.dataKeyItems;
|
48
|
+
const searchables = dataKeyItems.map((item, index) => `key0${index + 1}`);
|
49
|
+
const dataItems = dataSet.dataItems.filter(item => item.agg);
|
50
|
+
const { date, month } = params.filters.reduce((acc, filter) => {
|
51
|
+
if (filter.name === 'date')
|
52
|
+
acc.date = filter.value;
|
53
|
+
if (filter.name === 'month')
|
54
|
+
acc.month = filter.value;
|
55
|
+
return acc;
|
56
|
+
}, { date: null, month: null });
|
57
|
+
const { from, to } = await (0, shell_1.getTimesForPeriod)(period, { date, month }, context);
|
58
|
+
const selectPeriod = queryBuilder => {
|
59
|
+
if (period == 'today') {
|
60
|
+
queryBuilder.addSelect('summary.date', 'date').addSelect('summary.period', 'period');
|
61
|
+
}
|
62
|
+
else if (['this year', '12 months'].includes(period)) {
|
63
|
+
queryBuilder.addSelect('SUBSTRING(summary.date, 1, 7) AS month');
|
64
|
+
}
|
65
|
+
else {
|
66
|
+
queryBuilder.addSelect('summary.date', 'date');
|
67
|
+
}
|
68
|
+
return queryBuilder;
|
69
|
+
};
|
70
|
+
const selectKeys = dataKeyItems.map((item, index) => {
|
71
|
+
const aliasName = `key0${index + 1}`;
|
72
|
+
const columnName = `summary.${aliasName}`;
|
73
|
+
return `${columnName} as ${aliasName}`;
|
74
|
+
});
|
75
|
+
const selectData = dataItems.map((item, index) => {
|
76
|
+
const aliasName = `data0${index + 1}`;
|
77
|
+
const columnName = `summary.${aliasName}`;
|
78
|
+
switch (item.agg) {
|
79
|
+
case STAT_FUNCTION_MAP.sum:
|
80
|
+
return `SUM(${columnName}) as ${aliasName}`;
|
81
|
+
case STAT_FUNCTION_MAP.mean:
|
82
|
+
// 일차 mean 된 값들을 다시 계산하므로, 무의미할 수 있다.
|
83
|
+
return `AVG(${columnName}) as ${aliasName}`;
|
84
|
+
case STAT_FUNCTION_MAP.stddev:
|
85
|
+
// 일차 stddev 된 값들을 다시 계산하므로, 무의미할 수 있다.
|
86
|
+
return `STDDEV(${columnName}) as ${aliasName}`;
|
87
|
+
case STAT_FUNCTION_MAP.variance:
|
88
|
+
// 일차 variance 된 값들을 다시 계산하므로, 무의미할 수 있다.
|
89
|
+
return `VARIANCE(${columnName}) as ${aliasName}`;
|
90
|
+
case STAT_FUNCTION_MAP.min:
|
91
|
+
return `MIN(${columnName}) as ${aliasName}`;
|
92
|
+
case STAT_FUNCTION_MAP.max:
|
93
|
+
return `MAX(${columnName}) as ${aliasName}`;
|
94
|
+
case STAT_FUNCTION_MAP.range:
|
95
|
+
// 일차 range 값들을 다시 계산하므로, 무의미할 수 있다.
|
96
|
+
return `MAX(${columnName}) - MIN(${columnName}) as ${aliasName}`;
|
97
|
+
case STAT_FUNCTION_MAP.mode:
|
98
|
+
// not guaranteed
|
99
|
+
return `MODE() WITHIN GROUP (ORDER BY ${columnName})`;
|
100
|
+
default:
|
101
|
+
return `AVG(${columnName}) as ${aliasName}`;
|
102
|
+
}
|
103
|
+
});
|
104
|
+
const groupByPeriod = period == 'today'
|
105
|
+
? 'summary.date, summary.period'
|
106
|
+
: ['this year', '12 months'].includes(period)
|
107
|
+
? 'SUBSTRING(summary.date, 1, 7)'
|
108
|
+
: 'summary.date';
|
109
|
+
const groupByKeys = dataKeyItems
|
110
|
+
.map((item, index) => {
|
111
|
+
return `summary.key0${index + 1}`;
|
112
|
+
})
|
113
|
+
.join(', ');
|
114
|
+
const desc = false;
|
115
|
+
var orderByPeriod = period == 'today'
|
116
|
+
? [
|
117
|
+
{ name: 'date', desc },
|
118
|
+
{ name: 'period', desc }
|
119
|
+
]
|
120
|
+
: ['this year', '12 months'].includes(period)
|
121
|
+
? [{ name: 'month', desc }]
|
122
|
+
: [{ name: 'date', desc }];
|
123
|
+
if ((params === null || params === void 0 ? void 0 : params.sortings) && params.sortings.length > 0) {
|
124
|
+
orderByPeriod = params.sortings;
|
125
|
+
}
|
126
|
+
var queryBuilder = (0, shell_1.getQueryBuilderFromListParams)({
|
127
|
+
repository: (0, shell_1.getRepository)(data_summary_js_1.DataSummary),
|
128
|
+
params: Object.assign(Object.assign({}, params), { filters: ((_b = params === null || params === void 0 ? void 0 : params.filters) === null || _b === void 0 ? void 0 : _b.filter(({ name }) => name !== 'date' && name !== 'month')) || [], sortings: [] }),
|
129
|
+
domain,
|
130
|
+
alias: 'summary',
|
131
|
+
searchables: searchables
|
132
|
+
})
|
133
|
+
.select('summary.dataSet')
|
134
|
+
.addSelect(selectData)
|
135
|
+
.addSelect('SUM(summary.count)', 'count')
|
136
|
+
.addSelect('SUM(summary.countOoc)', 'countOoc')
|
137
|
+
.addSelect('SUM(summary.countOos)', 'countOos');
|
138
|
+
queryBuilder = selectPeriod(queryBuilder)
|
139
|
+
.innerJoin('summary.dataSet', 'ds', 'ds.id = :dataSetName', {
|
140
|
+
dataSetName: dataSet.id
|
141
|
+
})
|
142
|
+
.andWhere('summary.domain = :domain', { domain: domain.id })
|
143
|
+
.andWhere('summary.date >= :from', { from })
|
144
|
+
.andWhere('summary.date < :to', { to })
|
145
|
+
.addGroupBy('summary.dataSet')
|
146
|
+
.addGroupBy(groupByPeriod);
|
147
|
+
if (dataKeyItems.length > 0) {
|
148
|
+
queryBuilder.addSelect(selectKeys).addGroupBy(groupByKeys);
|
149
|
+
}
|
150
|
+
orderByPeriod.map(orderBy => {
|
151
|
+
const { name: sort, desc } = orderBy;
|
152
|
+
queryBuilder.addOrderBy(sort, desc ? 'DESC' : 'ASC');
|
153
|
+
});
|
154
|
+
const items = await queryBuilder.getRawMany();
|
155
|
+
return items;
|
156
|
+
}
|
157
|
+
//# sourceMappingURL=query-data-summary-by-period.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"query-data-summary-by-period.js","sourceRoot":"","sources":["../../server/controllers/query-data-summary-by-period.ts"],"names":[],"mappings":"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","sourcesContent":["import { In } from 'typeorm'\n\nimport {\n getQueryBuilderFromListParams,\n getRepository,\n getTimesForPeriod,\n ListParam,\n Sorting\n} from '@things-factory/shell'\n\nimport { DataSet, DataSetSummaryPeriodType } from '../service/data-set/data-set.js'\nimport { DataSummary } from '../service/data-summary/data-summary.js'\n\nconst STAT_FUNCTION_MAP = {\n sum: 'sum',\n mean: 'mean',\n stddev: 'standardDeviation',\n variance: 'variance',\n min: 'min',\n max: 'max',\n range: 'range',\n median: 'median',\n mode: 'mode'\n}\n\nexport async function queryDataSummaryByPeriod(\n period: 'today' | 'this month' | '30 days' | 'this year' | '12 months' | 'date range' | 'month',\n dataSetName: string,\n dataKeys: string[] | null,\n params: ListParam,\n context: ResolverContext\n): Promise<DataSummary[]> {\n const { domain, user, tx } = context.state\n const { t } = context\n\n const dataSet = await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, name: dataSetName },\n relations: ['dataKeySet']\n })\n\n if (!dataSet) {\n throw new Error(t('error.dataset not found', { dataSetName }))\n }\n\n // limitations\n const summaryPeriodType = dataSet.summaryPeriod\n if (\n (summaryPeriodType == DataSetSummaryPeriodType.Day || summaryPeriodType == DataSetSummaryPeriodType.WorkDate) &&\n period == 'today'\n ) {\n throw new Error(t('error.summary not supported', { dataSetName, period: t(`label.period-${period}`) }))\n }\n\n // dataKeys 가 설정되지 않았다면, dataSet의 dataKeySet을 그대로 적용한다는 의미임.\n // dataKeys == [] 라면, dataKeySet을 적용하지 않는다는 의미임.\n // dataKeys에는 dataKeySet의 dataKey 값을 따라야 한다.\n const dataKeyItems = !dataSet.dataKeySet?.dataKeyItems\n ? []\n : dataKeys\n ? dataKeys\n .map(dataKey => {\n return dataSet.dataKeySet.dataKeyItems.find(item => item.dataKey == dataKey)\n })\n .filter(Boolean)\n : dataSet.dataKeySet.dataKeyItems\n\n const searchables = dataKeyItems.map((item, index) => `key0${index + 1}`)\n const dataItems = dataSet.dataItems.filter(item => item.agg)\n\n const { date, month } = params.filters.reduce(\n (acc, filter) => {\n if (filter.name === 'date') acc.date = filter.value\n if (filter.name === 'month') acc.month = filter.value\n return acc\n },\n { date: null, month: null }\n )\n\n const { from, to } = await getTimesForPeriod(period, { date, month }, context)\n\n const selectPeriod = queryBuilder => {\n if (period == 'today') {\n queryBuilder.addSelect('summary.date', 'date').addSelect('summary.period', 'period')\n } else if (['this year', '12 months'].includes(period)) {\n queryBuilder.addSelect('SUBSTRING(summary.date, 1, 7) AS month')\n } else {\n queryBuilder.addSelect('summary.date', 'date')\n }\n\n return queryBuilder\n }\n const selectKeys = dataKeyItems.map((item, index) => {\n const aliasName = `key0${index + 1}`\n const columnName = `summary.${aliasName}`\n\n return `${columnName} as ${aliasName}`\n }) as string[]\n const selectData = dataItems.map((item, index) => {\n const aliasName = `data0${index + 1}`\n const columnName = `summary.${aliasName}`\n\n switch (item.agg) {\n case STAT_FUNCTION_MAP.sum:\n return `SUM(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.mean:\n // 일차 mean 된 값들을 다시 계산하므로, 무의미할 수 있다.\n return `AVG(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.stddev:\n // 일차 stddev 된 값들을 다시 계산하므로, 무의미할 수 있다.\n return `STDDEV(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.variance:\n // 일차 variance 된 값들을 다시 계산하므로, 무의미할 수 있다.\n return `VARIANCE(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.min:\n return `MIN(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.max:\n return `MAX(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.range:\n // 일차 range 값들을 다시 계산하므로, 무의미할 수 있다.\n return `MAX(${columnName}) - MIN(${columnName}) as ${aliasName}`\n case STAT_FUNCTION_MAP.mode:\n // not guaranteed\n return `MODE() WITHIN GROUP (ORDER BY ${columnName})`\n default:\n return `AVG(${columnName}) as ${aliasName}`\n }\n })\n\n const groupByPeriod =\n period == 'today'\n ? 'summary.date, summary.period'\n : ['this year', '12 months'].includes(period)\n ? 'SUBSTRING(summary.date, 1, 7)'\n : 'summary.date'\n const groupByKeys = dataKeyItems\n .map((item, index) => {\n return `summary.key0${index + 1}`\n })\n .join(', ')\n\n const desc = false\n var orderByPeriod: Sorting[] =\n period == 'today'\n ? [\n { name: 'date', desc },\n { name: 'period', desc }\n ]\n : ['this year', '12 months'].includes(period)\n ? [{ name: 'month', desc }]\n : [{ name: 'date', desc }]\n\n if (params?.sortings && params.sortings.length > 0) {\n orderByPeriod = params.sortings\n }\n\n var queryBuilder = getQueryBuilderFromListParams({\n repository: getRepository(DataSummary),\n params: {\n ...params,\n filters: params?.filters?.filter(({ name }) => name !== 'date' && name !== 'month') || [],\n sortings: []\n },\n domain,\n alias: 'summary',\n searchables: searchables\n })\n .select('summary.dataSet')\n .addSelect(selectData)\n .addSelect('SUM(summary.count)', 'count')\n .addSelect('SUM(summary.countOoc)', 'countOoc')\n .addSelect('SUM(summary.countOos)', 'countOos')\n\n queryBuilder = selectPeriod(queryBuilder)\n .innerJoin('summary.dataSet', 'ds', 'ds.id = :dataSetName', {\n dataSetName: dataSet.id\n })\n .andWhere('summary.domain = :domain', { domain: domain.id })\n .andWhere('summary.date >= :from', { from })\n .andWhere('summary.date < :to', { to })\n .addGroupBy('summary.dataSet')\n .addGroupBy(groupByPeriod)\n\n if (dataKeyItems.length > 0) {\n queryBuilder.addSelect(selectKeys).addGroupBy(groupByKeys)\n }\n\n orderByPeriod.map(orderBy => {\n const { name: sort, desc } = orderBy\n queryBuilder.addOrderBy(sort, desc ? 'DESC' : 'ASC')\n })\n\n const items = await queryBuilder.getRawMany()\n\n return items\n}\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
export declare function renderShinyReport(context: any): Promise<string>;
|
@@ -0,0 +1,35 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.renderShinyReport = renderShinyReport;
|
4
|
+
const tslib_1 = require("tslib");
|
5
|
+
const env_1 = require("@things-factory/env");
|
6
|
+
const config_resolver_js_1 = require("../utils/config-resolver.js");
|
7
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
8
|
+
const debug = (0, debug_1.default)('things-factory:dataset:shiny-report');
|
9
|
+
const dataReportConfig = env_1.config.get('dataReport');
|
10
|
+
const { shiny: { endpoint: ENDPOINT, datasource: { database: DATABASE } } } = Object.assign({
|
11
|
+
shiny: {
|
12
|
+
endpoint: {},
|
13
|
+
datasource: {}
|
14
|
+
}
|
15
|
+
}, dataReportConfig);
|
16
|
+
async function renderShinyReport(context) {
|
17
|
+
debug('render:context', context);
|
18
|
+
try {
|
19
|
+
const cookies = new URLSearchParams(context.header.cookie.replace(/; /g, '&'));
|
20
|
+
const token = cookies.get('access_token');
|
21
|
+
const { state: { domain }, query, response } = context;
|
22
|
+
const urlParams = new URLSearchParams(Object.assign(Object.assign({ token }, query), { database: DATABASE, domain: domain === null || domain === void 0 ? void 0 : domain.subdomain })).toString();
|
23
|
+
const subpath = (query === null || query === void 0 ? void 0 : query.reportView) || '';
|
24
|
+
if (!subpath) {
|
25
|
+
return (context.body = '');
|
26
|
+
}
|
27
|
+
const url = (0, config_resolver_js_1.getEndpointUrl)(ENDPOINT, subpath);
|
28
|
+
const reportUrl = `${url}/?${urlParams}`;
|
29
|
+
response.redirect(reportUrl);
|
30
|
+
}
|
31
|
+
catch (ex) {
|
32
|
+
context.body = `Error: ${ex.message} || ''`;
|
33
|
+
}
|
34
|
+
}
|
35
|
+
//# sourceMappingURL=shiny-report.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"shiny-report.js","sourceRoot":"","sources":["../../server/controllers/shiny-report.ts"],"names":[],"mappings":";;AAqBA,8CAgCC;;AArDD,6CAA4C;AAC5C,oEAA4D;AAE5D,0DAA4B;AAC5B,MAAM,KAAK,GAAG,IAAA,eAAQ,EAAC,qCAAqC,CAAC,CAAA;AAC7D,MAAM,gBAAgB,GAAG,YAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;AACjD,MAAM,EACJ,KAAK,EAAE,EACL,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,EACnC,EACF,GAAG,MAAM,CAAC,MAAM,CACf;IACE,KAAK,EAAE;QACL,QAAQ,EAAE,EAAE;QACZ,UAAU,EAAE,EAAE;KACf;CACF,EACD,gBAAgB,CACjB,CAAA;AAEM,KAAK,UAAU,iBAAiB,CAAC,OAAY;IAClD,KAAK,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAA;IAEhC,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,IAAI,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAA;QAC9E,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;QACzC,MAAM,EACJ,KAAK,EAAE,EAAE,MAAM,EAAE,EACjB,KAAK,EACL,QAAQ,EACT,GAAG,OAAO,CAAA;QAEX,MAAM,SAAS,GAAG,IAAI,eAAe,+BACnC,KAAK,IACF,KAAK,KACR,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,IACzB,CAAC,QAAQ,EAAE,CAAA;QAEb,MAAM,OAAO,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,KAAI,EAAE,CAAA;QAEvC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,CAAC,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC,CAAA;QAC5B,CAAC;QAED,MAAM,GAAG,GAAG,IAAA,mCAAc,EAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;QAC7C,MAAM,SAAS,GAAG,GAAG,GAAG,KAAK,SAAS,EAAE,CAAA;QAExC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;IAC9B,CAAC;IAAC,OAAO,EAAE,EAAE,CAAC;QACZ,OAAO,CAAC,IAAI,GAAG,UAAU,EAAE,CAAC,OAAO,QAAQ,CAAA;IAC7C,CAAC;AACH,CAAC","sourcesContent":["import { config } from '@things-factory/env'\nimport { getEndpointUrl } from '../utils/config-resolver.js'\n\nimport debugLib from 'debug'\nconst debug = debugLib('things-factory:dataset:shiny-report')\nconst dataReportConfig = config.get('dataReport')\nconst {\n shiny: {\n endpoint: ENDPOINT,\n datasource: { database: DATABASE }\n }\n} = Object.assign(\n {\n shiny: {\n endpoint: {},\n datasource: {}\n }\n },\n dataReportConfig\n)\n\nexport async function renderShinyReport(context: any) {\n debug('render:context', context)\n\n try {\n const cookies = new URLSearchParams(context.header.cookie.replace(/; /g, '&'))\n const token = cookies.get('access_token')\n const {\n state: { domain },\n query,\n response\n } = context\n\n const urlParams = new URLSearchParams({\n token,\n ...query,\n database: DATABASE,\n domain: domain?.subdomain\n }).toString()\n\n const subpath = query?.reportView || ''\n\n if (!subpath) {\n return (context.body = '')\n }\n\n const url = getEndpointUrl(ENDPOINT, subpath)\n const reportUrl = `${url}/?${urlParams}`\n\n response.redirect(reportUrl)\n } catch (ex) {\n context.body = `Error: ${ex.message} || ''`\n }\n}\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
import './task/index.js';
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/engine/index.ts"],"names":[],"mappings":";;AAAA,2BAAwB","sourcesContent":["import './task/index.js'\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
export {};
|
@@ -0,0 +1,81 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
const tslib_1 = require("tslib");
|
4
|
+
const integration_base_1 = require("@things-factory/integration-base");
|
5
|
+
const shell_1 = require("@things-factory/shell");
|
6
|
+
const utils_1 = require("@things-factory/utils");
|
7
|
+
const i18next_1 = tslib_1.__importDefault(require("i18next"));
|
8
|
+
const data_set_js_1 = require("../../service/data-set/data-set.js");
|
9
|
+
const create_data_sample_js_1 = require("../../controllers/create-data-sample.js");
|
10
|
+
async function CreateDataSample(step, context) {
|
11
|
+
const { data, domain, user, lng } = context;
|
12
|
+
var { params: { dataset: dataSetId, source: sourceAccessor, rawData: rawDataAccessor, data: dataAccessor, timestamp: timestampAccessor } } = step;
|
13
|
+
if (!dataSetId) {
|
14
|
+
throw new Error(`no dataset found`);
|
15
|
+
}
|
16
|
+
// make new data-sample
|
17
|
+
return await (0, shell_1.getDataSource)().transaction(async (tx) => {
|
18
|
+
const dataSet = await tx.getRepository(data_set_js_1.DataSet).findOne({
|
19
|
+
where: {
|
20
|
+
id: dataSetId
|
21
|
+
}
|
22
|
+
});
|
23
|
+
var source = await (0, utils_1.access)(sourceAccessor, data);
|
24
|
+
var extractedData = await (0, utils_1.access)(dataAccessor, data);
|
25
|
+
var extractedRawData = rawDataAccessor && (await (0, utils_1.access)(rawDataAccessor, data));
|
26
|
+
var timestamp = timestampAccessor && (await (0, utils_1.access)(timestampAccessor, data));
|
27
|
+
const dataSample = await (0, create_data_sample_js_1.createDataSample)({
|
28
|
+
dataSet,
|
29
|
+
data: extractedData,
|
30
|
+
rawData: extractedRawData,
|
31
|
+
source,
|
32
|
+
collectedAt: new Date(timestamp || new Date())
|
33
|
+
}, {
|
34
|
+
t: i18next_1.default.t,
|
35
|
+
state: {
|
36
|
+
domain,
|
37
|
+
user,
|
38
|
+
lng,
|
39
|
+
tx
|
40
|
+
}
|
41
|
+
});
|
42
|
+
return {
|
43
|
+
data: dataSample
|
44
|
+
};
|
45
|
+
});
|
46
|
+
}
|
47
|
+
CreateDataSample.parameterSpec = [
|
48
|
+
{
|
49
|
+
type: 'entity-selector',
|
50
|
+
name: 'dataset',
|
51
|
+
label: 'data-set',
|
52
|
+
property: {
|
53
|
+
queryName: 'dataSets',
|
54
|
+
valueKey: 'id'
|
55
|
+
}
|
56
|
+
},
|
57
|
+
{
|
58
|
+
type: 'string',
|
59
|
+
name: 'source',
|
60
|
+
label: 'source'
|
61
|
+
},
|
62
|
+
{
|
63
|
+
type: 'string',
|
64
|
+
name: 'rawData',
|
65
|
+
label: 'raw-data'
|
66
|
+
},
|
67
|
+
{
|
68
|
+
type: 'string',
|
69
|
+
name: 'data',
|
70
|
+
label: 'data'
|
71
|
+
},
|
72
|
+
{
|
73
|
+
type: 'string',
|
74
|
+
name: 'timestamp',
|
75
|
+
label: 'timestamp'
|
76
|
+
}
|
77
|
+
];
|
78
|
+
CreateDataSample.connectorFree = true;
|
79
|
+
CreateDataSample.help = 'dataset/task/create-data-sample';
|
80
|
+
integration_base_1.TaskRegistry.registerTaskHandler('create-data-sample', CreateDataSample);
|
81
|
+
//# sourceMappingURL=create-data-sample.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"create-data-sample.js","sourceRoot":"","sources":["../../../server/engine/task/create-data-sample.ts"],"names":[],"mappings":";;;AAAA,uEAAmF;AACnF,iDAAqD;AACrD,iDAA8C;AAC9C,8DAA6B;AAE7B,oEAA4D;AAC5D,mFAA0E;AAE1E,KAAK,UAAU,gBAAgB,CAAC,IAAe,EAAE,OAAgB;IAC/D,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,OAAO,CAAA;IAC3C,IAAI,EACF,MAAM,EAAE,EACN,OAAO,EAAE,SAAS,EAClB,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,eAAe,EACxB,IAAI,EAAE,YAAY,EAClB,SAAS,EAAE,iBAAiB,EAC7B,EACF,GAAG,IAAI,CAAA;IAER,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;IACrC,CAAC;IAED,uBAAuB;IACvB,OAAO,MAAM,IAAA,qBAAa,GAAE,CAAC,WAAW,CAAC,KAAK,EAAC,EAAE,EAAC,EAAE;QAClD,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,aAAa,CAAC,qBAAO,CAAC,CAAC,OAAO,CAAC;YACtD,KAAK,EAAE;gBACL,EAAE,EAAE,SAAS;aACd;SACF,CAAC,CAAA;QAEF,IAAI,MAAM,GAAG,MAAM,IAAA,cAAM,EAAC,cAAc,EAAE,IAAI,CAAC,CAAA;QAC/C,IAAI,aAAa,GAAG,MAAM,IAAA,cAAM,EAAC,YAAY,EAAE,IAAI,CAAC,CAAA;QACpD,IAAI,gBAAgB,GAAG,eAAe,IAAI,CAAC,MAAM,IAAA,cAAM,EAAC,eAAe,EAAE,IAAI,CAAC,CAAC,CAAA;QAC/E,IAAI,SAAS,GAAG,iBAAiB,IAAI,CAAC,MAAM,IAAA,cAAM,EAAC,iBAAiB,EAAE,IAAI,CAAC,CAAC,CAAA;QAE5E,MAAM,UAAU,GAAG,MAAM,IAAA,wCAAgB,EACvC;YACE,OAAO;YACP,IAAI,EAAE,aAAa;YACnB,OAAO,EAAE,gBAAgB;YACzB,MAAM;YACN,WAAW,EAAE,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC;SAC/C,EACD;YACE,CAAC,EAAE,iBAAO,CAAC,CAAC;YACZ,KAAK,EAAE;gBACL,MAAM;gBACN,IAAI;gBACJ,GAAG;gBACH,EAAE;aACH;SACF,CACF,CAAA;QAED,OAAO;YACL,IAAI,EAAE,UAAU;SACjB,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,gBAAgB,CAAC,aAAa,GAAG;IAC/B;QACE,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,UAAU;QACjB,QAAQ,EAAE;YACR,SAAS,EAAE,UAAU;YACrB,QAAQ,EAAE,IAAI;SACf;KACF;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,QAAQ;KAChB;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,UAAU;KAClB;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,MAAM;QACZ,KAAK,EAAE,MAAM;KACd;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,WAAW;QACjB,KAAK,EAAE,WAAW;KACnB;CACF,CAAA;AAED,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAA;AACrC,gBAAgB,CAAC,IAAI,GAAG,iCAAiC,CAAA;AAEzD,+BAAY,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,gBAAgB,CAAC,CAAA","sourcesContent":["import { TaskRegistry, InputStep, Context } from '@things-factory/integration-base'\nimport { getDataSource } from '@things-factory/shell'\nimport { access } from '@things-factory/utils'\nimport i18next from 'i18next'\n\nimport { DataSet } from '../../service/data-set/data-set.js'\nimport { createDataSample } from '../../controllers/create-data-sample.js'\n\nasync function CreateDataSample(step: InputStep, context: Context) {\n const { data, domain, user, lng } = context\n var {\n params: {\n dataset: dataSetId,\n source: sourceAccessor,\n rawData: rawDataAccessor,\n data: dataAccessor,\n timestamp: timestampAccessor\n }\n } = step\n\n if (!dataSetId) {\n throw new Error(`no dataset found`)\n }\n\n // make new data-sample\n return await getDataSource().transaction(async tx => {\n const dataSet = await tx.getRepository(DataSet).findOne({\n where: {\n id: dataSetId\n }\n })\n\n var source = await access(sourceAccessor, data)\n var extractedData = await access(dataAccessor, data)\n var extractedRawData = rawDataAccessor && (await access(rawDataAccessor, data))\n var timestamp = timestampAccessor && (await access(timestampAccessor, data))\n\n const dataSample = await createDataSample(\n {\n dataSet,\n data: extractedData,\n rawData: extractedRawData,\n source,\n collectedAt: new Date(timestamp || new Date())\n },\n {\n t: i18next.t,\n state: {\n domain,\n user,\n lng,\n tx\n }\n }\n )\n\n return {\n data: dataSample\n }\n })\n}\n\nCreateDataSample.parameterSpec = [\n {\n type: 'entity-selector',\n name: 'dataset',\n label: 'data-set',\n property: {\n queryName: 'dataSets',\n valueKey: 'id'\n }\n },\n {\n type: 'string',\n name: 'source',\n label: 'source'\n },\n {\n type: 'string',\n name: 'rawData',\n label: 'raw-data'\n },\n {\n type: 'string',\n name: 'data',\n label: 'data'\n },\n {\n type: 'string',\n name: 'timestamp',\n label: 'timestamp'\n }\n]\n\nCreateDataSample.connectorFree = true\nCreateDataSample.help = 'dataset/task/create-data-sample'\n\nTaskRegistry.registerTaskHandler('create-data-sample', CreateDataSample)\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/engine/task/index.ts"],"names":[],"mappings":";;AAAA,mCAAgC;AAChC,mCAAgC","sourcesContent":["import './create-data-sample.js'\nimport './issue-collect-data.js'\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
export {};
|
@@ -0,0 +1,40 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
const tslib_1 = require("tslib");
|
4
|
+
const integration_base_1 = require("@things-factory/integration-base");
|
5
|
+
const issue_data_collection_task_js_1 = require("../../controllers/issue-data-collection-task.js");
|
6
|
+
const i18next_1 = tslib_1.__importDefault(require("i18next"));
|
7
|
+
async function IssueCollectData(step, context) {
|
8
|
+
const { logger, data, domain, user, lng } = context;
|
9
|
+
var { params: { dataset: dataSetId } } = step;
|
10
|
+
if (!dataSetId) {
|
11
|
+
throw new Error(`no dataset found`);
|
12
|
+
}
|
13
|
+
const activityInstance = await (0, issue_data_collection_task_js_1.issueDataCollectionTask)(domain.id, dataSetId, {
|
14
|
+
t: i18next_1.default.t,
|
15
|
+
state: {
|
16
|
+
domain,
|
17
|
+
user,
|
18
|
+
lng,
|
19
|
+
tx: undefined
|
20
|
+
}
|
21
|
+
});
|
22
|
+
return {
|
23
|
+
data: activityInstance
|
24
|
+
};
|
25
|
+
}
|
26
|
+
IssueCollectData.parameterSpec = [
|
27
|
+
{
|
28
|
+
type: 'entity-selector',
|
29
|
+
name: 'dataset',
|
30
|
+
label: 'data-set',
|
31
|
+
property: {
|
32
|
+
queryName: 'dataSets',
|
33
|
+
valueKey: 'id'
|
34
|
+
}
|
35
|
+
}
|
36
|
+
];
|
37
|
+
IssueCollectData.connectorFree = true;
|
38
|
+
IssueCollectData.help = 'dataset/task/issue-collect-data';
|
39
|
+
integration_base_1.TaskRegistry.registerTaskHandler('issue-collect-data', IssueCollectData);
|
40
|
+
//# sourceMappingURL=issue-collect-data.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"issue-collect-data.js","sourceRoot":"","sources":["../../../server/engine/task/issue-collect-data.ts"],"names":[],"mappings":";;;AAAA,uEAAmF;AACnF,mGAAyF;AACzF,8DAA6B;AAE7B,KAAK,UAAU,gBAAgB,CAAC,IAAe,EAAE,OAAgB;IAC/D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,OAAO,CAAA;IACnD,IAAI,EACF,MAAM,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,EAC/B,GAAG,IAAI,CAAA;IAER,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;IACrC,CAAC;IAED,MAAM,gBAAgB,GAAG,MAAM,IAAA,uDAAuB,EAAC,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE;QAC3E,CAAC,EAAE,iBAAO,CAAC,CAAC;QACZ,KAAK,EAAE;YACL,MAAM;YACN,IAAI;YACJ,GAAG;YACH,EAAE,EAAE,SAAS;SACd;KACF,CAAC,CAAA;IAEF,OAAO;QACL,IAAI,EAAE,gBAAgB;KACvB,CAAA;AACH,CAAC;AAED,gBAAgB,CAAC,aAAa,GAAG;IAC/B;QACE,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,UAAU;QACjB,QAAQ,EAAE;YACR,SAAS,EAAE,UAAU;YACrB,QAAQ,EAAE,IAAI;SACf;KACF;CACF,CAAA;AAED,gBAAgB,CAAC,aAAa,GAAG,IAAI,CAAA;AACrC,gBAAgB,CAAC,IAAI,GAAG,iCAAiC,CAAA;AAEzD,+BAAY,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,gBAAgB,CAAC,CAAA","sourcesContent":["import { TaskRegistry, InputStep, Context } from '@things-factory/integration-base'\nimport { issueDataCollectionTask } from '../../controllers/issue-data-collection-task.js'\nimport i18next from 'i18next'\n\nasync function IssueCollectData(step: InputStep, context: Context) {\n const { logger, data, domain, user, lng } = context\n var {\n params: { dataset: dataSetId }\n } = step\n\n if (!dataSetId) {\n throw new Error(`no dataset found`)\n }\n\n const activityInstance = await issueDataCollectionTask(domain.id, dataSetId, {\n t: i18next.t,\n state: {\n domain,\n user,\n lng,\n tx: undefined\n }\n })\n\n return {\n data: activityInstance\n }\n}\n\nIssueCollectData.parameterSpec = [\n {\n type: 'entity-selector',\n name: 'dataset',\n label: 'data-set',\n property: {\n queryName: 'dataSets',\n valueKey: 'id'\n }\n }\n]\n\nIssueCollectData.connectorFree = true\nIssueCollectData.help = 'dataset/task/issue-collect-data'\n\nTaskRegistry.registerTaskHandler('issue-collect-data', IssueCollectData)\n"]}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
const tslib_1 = require("tslib");
|
4
|
+
require("./routes.js");
|
5
|
+
require("./activities/index.js");
|
6
|
+
require("./engine/index.js");
|
7
|
+
tslib_1.__exportStar(require("./controllers/index.js"), exports);
|
8
|
+
tslib_1.__exportStar(require("./service/index.js"), exports);
|
9
|
+
tslib_1.__exportStar(require("./service/data-spec/data-spec-manager.js"), exports);
|
10
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../server/index.ts"],"names":[],"mappings":";;;AAAA,uBAAoB;AACpB,iCAA8B;AAC9B,6BAA0B;AAE1B,iEAAsC;AACtC,6DAAkC;AAElC,mFAAwD","sourcesContent":["import './routes.js'\nimport './activities/index.js'\nimport './engine/index.js'\n\nexport * from './controllers/index.js'\nexport * from './service/index.js'\n\nexport * from './service/data-spec/data-spec-manager.js'\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
export {};
|