@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.
Files changed (345) hide show
  1. package/dist-client/activities/activity-data-collect-edit.d.ts +19 -0
  2. package/dist-client/activities/activity-data-collect-edit.js +105 -0
  3. package/dist-client/activities/activity-data-collect-edit.js.map +1 -0
  4. package/dist-client/activities/activity-data-collect-view.d.ts +16 -0
  5. package/dist-client/activities/activity-data-collect-view.js +94 -0
  6. package/dist-client/activities/activity-data-collect-view.js.map +1 -0
  7. package/dist-client/activities/activity-data-review-edit.d.ts +18 -0
  8. package/dist-client/activities/activity-data-review-edit.js +279 -0
  9. package/dist-client/activities/activity-data-review-edit.js.map +1 -0
  10. package/dist-client/activities/activity-data-review-view.d.ts +14 -0
  11. package/dist-client/activities/activity-data-review-view.js +224 -0
  12. package/dist-client/activities/activity-data-review-view.js.map +1 -0
  13. package/dist-client/activities/activity-ooc-resolve-edit.d.ts +2 -0
  14. package/dist-client/activities/activity-ooc-resolve-edit.js +196 -0
  15. package/dist-client/activities/activity-ooc-resolve-edit.js.map +1 -0
  16. package/dist-client/activities/activity-ooc-resolve-view.d.ts +14 -0
  17. package/dist-client/activities/activity-ooc-resolve-view.js +146 -0
  18. package/dist-client/activities/activity-ooc-resolve-view.js.map +1 -0
  19. package/dist-client/activities/activity-ooc-review-edit.d.ts +2 -0
  20. package/dist-client/activities/activity-ooc-review-edit.js +176 -0
  21. package/dist-client/activities/activity-ooc-review-edit.js.map +1 -0
  22. package/dist-client/activities/activity-ooc-review-view.d.ts +1 -0
  23. package/dist-client/activities/activity-ooc-review-view.js +133 -0
  24. package/dist-client/activities/activity-ooc-review-view.js.map +1 -0
  25. package/dist-client/bootstrap.d.ts +10 -0
  26. package/dist-client/bootstrap.js +26 -0
  27. package/dist-client/bootstrap.js.map +1 -0
  28. package/dist-client/components/data-entry-form.d.ts +20 -0
  29. package/dist-client/components/data-entry-form.js +108 -0
  30. package/dist-client/components/data-entry-form.js.map +1 -0
  31. package/dist-client/index.d.ts +1 -0
  32. package/dist-client/index.js +2 -0
  33. package/dist-client/index.js.map +1 -0
  34. package/dist-client/pages/data-archive/data-archive-list-page.d.ts +67 -0
  35. package/dist-client/pages/data-archive/data-archive-list-page.js +272 -0
  36. package/dist-client/pages/data-archive/data-archive-list-page.js.map +1 -0
  37. package/dist-client/pages/data-archive/data-archive-request-popup.d.ts +1 -0
  38. package/dist-client/pages/data-archive/data-archive-request-popup.js +160 -0
  39. package/dist-client/pages/data-archive/data-archive-request-popup.js.map +1 -0
  40. package/dist-client/pages/data-entry/checklist-entry-page.d.ts +21 -0
  41. package/dist-client/pages/data-entry/checklist-entry-page.js +209 -0
  42. package/dist-client/pages/data-entry/checklist-entry-page.js.map +1 -0
  43. package/dist-client/pages/data-entry/data-entry-list-page.d.ts +38 -0
  44. package/dist-client/pages/data-entry/data-entry-list-page.js +448 -0
  45. package/dist-client/pages/data-entry/data-entry-list-page.js.map +1 -0
  46. package/dist-client/pages/data-key-set/data-key-item-list.d.ts +19 -0
  47. package/dist-client/pages/data-key-set/data-key-item-list.js +182 -0
  48. package/dist-client/pages/data-key-set/data-key-item-list.js.map +1 -0
  49. package/dist-client/pages/data-key-set/data-key-set-importer.d.ts +10 -0
  50. package/dist-client/pages/data-key-set/data-key-set-importer.js +94 -0
  51. package/dist-client/pages/data-key-set/data-key-set-importer.js.map +1 -0
  52. package/dist-client/pages/data-key-set/data-key-set-list-page.d.ts +64 -0
  53. package/dist-client/pages/data-key-set/data-key-set-list-page.js +405 -0
  54. package/dist-client/pages/data-key-set/data-key-set-list-page.js.map +1 -0
  55. package/dist-client/pages/data-ooc/data-ooc-list-page.d.ts +72 -0
  56. package/dist-client/pages/data-ooc/data-ooc-list-page.js +545 -0
  57. package/dist-client/pages/data-ooc/data-ooc-list-page.js.map +1 -0
  58. package/dist-client/pages/data-ooc/data-ooc-page.d.ts +18 -0
  59. package/dist-client/pages/data-ooc/data-ooc-page.js +163 -0
  60. package/dist-client/pages/data-ooc/data-ooc-page.js.map +1 -0
  61. package/dist-client/pages/data-ooc/data-ooc-view.d.ts +19 -0
  62. package/dist-client/pages/data-ooc/data-ooc-view.js +232 -0
  63. package/dist-client/pages/data-ooc/data-ooc-view.js.map +1 -0
  64. package/dist-client/pages/data-ooc/data-oocs-page.d.ts +18 -0
  65. package/dist-client/pages/data-ooc/data-oocs-page.js +200 -0
  66. package/dist-client/pages/data-ooc/data-oocs-page.js.map +1 -0
  67. package/dist-client/pages/data-report/data-report-embed-page.d.ts +36 -0
  68. package/dist-client/pages/data-report/data-report-embed-page.js +101 -0
  69. package/dist-client/pages/data-report/data-report-embed-page.js.map +1 -0
  70. package/dist-client/pages/data-report/data-report-list-page.d.ts +38 -0
  71. package/dist-client/pages/data-report/data-report-list-page.js +441 -0
  72. package/dist-client/pages/data-report/data-report-list-page.js.map +1 -0
  73. package/dist-client/pages/data-report/data-report-samples-page.d.ts +32 -0
  74. package/dist-client/pages/data-report/data-report-samples-page.js +166 -0
  75. package/dist-client/pages/data-report/data-report-samples-page.js.map +1 -0
  76. package/dist-client/pages/data-report/jasper-report-oocs-page.d.ts +2 -0
  77. package/dist-client/pages/data-report/jasper-report-oocs-page.js +101 -0
  78. package/dist-client/pages/data-report/jasper-report-oocs-page.js.map +1 -0
  79. package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.d.ts +2 -0
  80. package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.js +101 -0
  81. package/dist-client/pages/data-report/jasper-report-samples-crosstab-page.js.map +1 -0
  82. package/dist-client/pages/data-report/jasper-report-samples-page.d.ts +2 -0
  83. package/dist-client/pages/data-report/jasper-report-samples-page.js +101 -0
  84. package/dist-client/pages/data-report/jasper-report-samples-page.js.map +1 -0
  85. package/dist-client/pages/data-sample/data-sample-list-page.d.ts +70 -0
  86. package/dist-client/pages/data-sample/data-sample-list-page.js +437 -0
  87. package/dist-client/pages/data-sample/data-sample-list-page.js.map +1 -0
  88. package/dist-client/pages/data-sample/data-sample-page.d.ts +17 -0
  89. package/dist-client/pages/data-sample/data-sample-page.js +57 -0
  90. package/dist-client/pages/data-sample/data-sample-page.js.map +1 -0
  91. package/dist-client/pages/data-sample/data-sample-search-page.d.ts +59 -0
  92. package/dist-client/pages/data-sample/data-sample-search-page.js +421 -0
  93. package/dist-client/pages/data-sample/data-sample-search-page.js.map +1 -0
  94. package/dist-client/pages/data-sample/data-sample-view.d.ts +21 -0
  95. package/dist-client/pages/data-sample/data-sample-view.js +285 -0
  96. package/dist-client/pages/data-sample/data-sample-view.js.map +1 -0
  97. package/dist-client/pages/data-sample/data-samples-page.d.ts +21 -0
  98. package/dist-client/pages/data-sample/data-samples-page.js +249 -0
  99. package/dist-client/pages/data-sample/data-samples-page.js.map +1 -0
  100. package/dist-client/pages/data-sensor/data-sensor-list-page.d.ts +58 -0
  101. package/dist-client/pages/data-sensor/data-sensor-list-page.js +455 -0
  102. package/dist-client/pages/data-sensor/data-sensor-list-page.js.map +1 -0
  103. package/dist-client/pages/data-set/data-item-list.d.ts +1 -0
  104. package/dist-client/pages/data-set/data-item-list.js +306 -0
  105. package/dist-client/pages/data-set/data-item-list.js.map +1 -0
  106. package/dist-client/pages/data-set/data-set-importer.d.ts +11 -0
  107. package/dist-client/pages/data-set/data-set-importer.js +97 -0
  108. package/dist-client/pages/data-set/data-set-importer.js.map +1 -0
  109. package/dist-client/pages/data-set/data-set-list-page.d.ts +83 -0
  110. package/dist-client/pages/data-set/data-set-list-page.js +1048 -0
  111. package/dist-client/pages/data-set/data-set-list-page.js.map +1 -0
  112. package/dist-client/pages/data-summary/data-summary-list-page.d.ts +59 -0
  113. package/dist-client/pages/data-summary/data-summary-list-page.js +361 -0
  114. package/dist-client/pages/data-summary/data-summary-list-page.js.map +1 -0
  115. package/dist-client/pages/data-summary/data-summary-period-page.d.ts +81 -0
  116. package/dist-client/pages/data-summary/data-summary-period-page.js +459 -0
  117. package/dist-client/pages/data-summary/data-summary-period-page.js.map +1 -0
  118. package/dist-client/pages/data-summary/data-summary-search-page.d.ts +78 -0
  119. package/dist-client/pages/data-summary/data-summary-search-page.js +413 -0
  120. package/dist-client/pages/data-summary/data-summary-search-page.js.map +1 -0
  121. package/dist-client/pages/data-summary/data-summary-view.d.ts +1 -0
  122. package/dist-client/pages/data-summary/data-summary-view.js +114 -0
  123. package/dist-client/pages/data-summary/data-summary-view.js.map +1 -0
  124. package/dist-client/route.d.ts +1 -0
  125. package/dist-client/route.js +74 -0
  126. package/dist-client/route.js.map +1 -0
  127. package/dist-client/tsconfig.tsbuildinfo +1 -0
  128. package/dist-server/activities/activity-data-collect.d.ts +42 -0
  129. package/dist-server/activities/activity-data-collect.js +87 -0
  130. package/dist-server/activities/activity-data-collect.js.map +1 -0
  131. package/dist-server/activities/activity-data-review.d.ts +42 -0
  132. package/dist-server/activities/activity-data-review.js +87 -0
  133. package/dist-server/activities/activity-data-review.js.map +1 -0
  134. package/dist-server/activities/activity-ooc-resolve.d.ts +42 -0
  135. package/dist-server/activities/activity-ooc-resolve.js +104 -0
  136. package/dist-server/activities/activity-ooc-resolve.js.map +1 -0
  137. package/dist-server/activities/activity-ooc-review.d.ts +42 -0
  138. package/dist-server/activities/activity-ooc-review.js +82 -0
  139. package/dist-server/activities/activity-ooc-review.js.map +1 -0
  140. package/dist-server/activities/index.d.ts +1 -0
  141. package/dist-server/activities/index.js +11 -0
  142. package/dist-server/activities/index.js.map +1 -0
  143. package/dist-server/controllers/create-data-ooc.d.ts +4 -0
  144. package/dist-server/controllers/create-data-ooc.js +65 -0
  145. package/dist-server/controllers/create-data-ooc.js.map +1 -0
  146. package/dist-server/controllers/create-data-sample.d.ts +3 -0
  147. package/dist-server/controllers/create-data-sample.js +268 -0
  148. package/dist-server/controllers/create-data-sample.js.map +1 -0
  149. package/dist-server/controllers/data-use-case.d.ts +36 -0
  150. package/dist-server/controllers/data-use-case.js +63 -0
  151. package/dist-server/controllers/data-use-case.js.map +1 -0
  152. package/dist-server/controllers/finalize-data-collection.d.ts +4 -0
  153. package/dist-server/controllers/finalize-data-collection.js +328 -0
  154. package/dist-server/controllers/finalize-data-collection.js.map +1 -0
  155. package/dist-server/controllers/index.d.ts +6 -0
  156. package/dist-server/controllers/index.js +10 -0
  157. package/dist-server/controllers/index.js.map +1 -0
  158. package/dist-server/controllers/issue-data-collection-task.d.ts +2 -0
  159. package/dist-server/controllers/issue-data-collection-task.js +57 -0
  160. package/dist-server/controllers/issue-data-collection-task.js.map +1 -0
  161. package/dist-server/controllers/issue-ooc-resolve.d.ts +3 -0
  162. package/dist-server/controllers/issue-ooc-resolve.js +49 -0
  163. package/dist-server/controllers/issue-ooc-resolve.js.map +1 -0
  164. package/dist-server/controllers/issue-ooc-review.d.ts +3 -0
  165. package/dist-server/controllers/issue-ooc-review.js +47 -0
  166. package/dist-server/controllers/issue-ooc-review.js.map +1 -0
  167. package/dist-server/controllers/jasper-report.d.ts +1 -0
  168. package/dist-server/controllers/jasper-report.js +163 -0
  169. package/dist-server/controllers/jasper-report.js.map +1 -0
  170. package/dist-server/controllers/query-data-summary-by-period.d.ts +3 -0
  171. package/dist-server/controllers/query-data-summary-by-period.js +157 -0
  172. package/dist-server/controllers/query-data-summary-by-period.js.map +1 -0
  173. package/dist-server/controllers/shiny-report.d.ts +1 -0
  174. package/dist-server/controllers/shiny-report.js +35 -0
  175. package/dist-server/controllers/shiny-report.js.map +1 -0
  176. package/dist-server/engine/index.d.ts +1 -0
  177. package/dist-server/engine/index.js +4 -0
  178. package/dist-server/engine/index.js.map +1 -0
  179. package/dist-server/engine/task/create-data-sample.d.ts +1 -0
  180. package/dist-server/engine/task/create-data-sample.js +81 -0
  181. package/dist-server/engine/task/create-data-sample.js.map +1 -0
  182. package/dist-server/engine/task/index.d.ts +2 -0
  183. package/dist-server/engine/task/index.js +5 -0
  184. package/dist-server/engine/task/index.js.map +1 -0
  185. package/dist-server/engine/task/issue-collect-data.d.ts +1 -0
  186. package/dist-server/engine/task/issue-collect-data.js +40 -0
  187. package/dist-server/engine/task/issue-collect-data.js.map +1 -0
  188. package/dist-server/index.d.ts +6 -0
  189. package/dist-server/index.js +10 -0
  190. package/dist-server/index.js.map +1 -0
  191. package/dist-server/routes.d.ts +1 -0
  192. package/dist-server/routes.js +140 -0
  193. package/dist-server/routes.js.map +1 -0
  194. package/dist-server/service/data-archive/data-archive-mutation.d.ts +16 -0
  195. package/dist-server/service/data-archive/data-archive-mutation.js +227 -0
  196. package/dist-server/service/data-archive/data-archive-mutation.js.map +1 -0
  197. package/dist-server/service/data-archive/data-archive-query.d.ts +11 -0
  198. package/dist-server/service/data-archive/data-archive-query.js +83 -0
  199. package/dist-server/service/data-archive/data-archive-query.js.map +1 -0
  200. package/dist-server/service/data-archive/data-archive-type.d.ts +23 -0
  201. package/dist-server/service/data-archive/data-archive-type.js +74 -0
  202. package/dist-server/service/data-archive/data-archive-type.js.map +1 -0
  203. package/dist-server/service/data-archive/data-archive.d.ts +19 -0
  204. package/dist-server/service/data-archive/data-archive.js +79 -0
  205. package/dist-server/service/data-archive/data-archive.js.map +1 -0
  206. package/dist-server/service/data-archive/index.d.ts +5 -0
  207. package/dist-server/service/data-archive/index.js +9 -0
  208. package/dist-server/service/data-archive/index.js.map +1 -0
  209. package/dist-server/service/data-key-set/data-key-item-type.d.ts +12 -0
  210. package/dist-server/service/data-key-set/data-key-item-type.js +50 -0
  211. package/dist-server/service/data-key-set/data-key-item-type.js.map +1 -0
  212. package/dist-server/service/data-key-set/data-key-set-mutation.d.ts +10 -0
  213. package/dist-server/service/data-key-set/data-key-set-mutation.js +168 -0
  214. package/dist-server/service/data-key-set/data-key-set-mutation.js.map +1 -0
  215. package/dist-server/service/data-key-set/data-key-set-query.d.ts +12 -0
  216. package/dist-server/service/data-key-set/data-key-set-query.js +98 -0
  217. package/dist-server/service/data-key-set/data-key-set-query.js.map +1 -0
  218. package/dist-server/service/data-key-set/data-key-set-type.d.ts +28 -0
  219. package/dist-server/service/data-key-set/data-key-set-type.js +100 -0
  220. package/dist-server/service/data-key-set/data-key-set-type.js.map +1 -0
  221. package/dist-server/service/data-key-set/data-key-set.d.ts +22 -0
  222. package/dist-server/service/data-key-set/data-key-set.js +99 -0
  223. package/dist-server/service/data-key-set/data-key-set.js.map +1 -0
  224. package/dist-server/service/data-key-set/index.d.ts +5 -0
  225. package/dist-server/service/data-key-set/index.js +9 -0
  226. package/dist-server/service/data-key-set/index.js.map +1 -0
  227. package/dist-server/service/data-ooc/data-ooc-mutation.d.ts +6 -0
  228. package/dist-server/service/data-ooc/data-ooc-mutation.js +81 -0
  229. package/dist-server/service/data-ooc/data-ooc-mutation.js.map +1 -0
  230. package/dist-server/service/data-ooc/data-ooc-query.d.ts +22 -0
  231. package/dist-server/service/data-ooc/data-ooc-query.js +165 -0
  232. package/dist-server/service/data-ooc/data-ooc-query.js.map +1 -0
  233. package/dist-server/service/data-ooc/data-ooc-subscription.d.ts +7 -0
  234. package/dist-server/service/data-ooc/data-ooc-subscription.js +51 -0
  235. package/dist-server/service/data-ooc/data-ooc-subscription.js.map +1 -0
  236. package/dist-server/service/data-ooc/data-ooc-type.d.ts +27 -0
  237. package/dist-server/service/data-ooc/data-ooc-type.js +102 -0
  238. package/dist-server/service/data-ooc/data-ooc-type.js.map +1 -0
  239. package/dist-server/service/data-ooc/data-ooc.d.ts +63 -0
  240. package/dist-server/service/data-ooc/data-ooc.js +304 -0
  241. package/dist-server/service/data-ooc/data-ooc.js.map +1 -0
  242. package/dist-server/service/data-ooc/index.d.ts +6 -0
  243. package/dist-server/service/data-ooc/index.js +10 -0
  244. package/dist-server/service/data-ooc/index.js.map +1 -0
  245. package/dist-server/service/data-sample/data-sample-mutation.d.ts +5 -0
  246. package/dist-server/service/data-sample/data-sample-mutation.js +28 -0
  247. package/dist-server/service/data-sample/data-sample-mutation.js.map +1 -0
  248. package/dist-server/service/data-sample/data-sample-query.d.ts +22 -0
  249. package/dist-server/service/data-sample/data-sample-query.js +249 -0
  250. package/dist-server/service/data-sample/data-sample-query.js.map +1 -0
  251. package/dist-server/service/data-sample/data-sample-type.d.ts +18 -0
  252. package/dist-server/service/data-sample/data-sample-type.js +68 -0
  253. package/dist-server/service/data-sample/data-sample-type.js.map +1 -0
  254. package/dist-server/service/data-sample/data-sample.d.ts +45 -0
  255. package/dist-server/service/data-sample/data-sample.js +221 -0
  256. package/dist-server/service/data-sample/data-sample.js.map +1 -0
  257. package/dist-server/service/data-sample/index.d.ts +5 -0
  258. package/dist-server/service/data-sample/index.js +9 -0
  259. package/dist-server/service/data-sample/index.js.map +1 -0
  260. package/dist-server/service/data-sensor/data-sensor-mutation.d.ts +9 -0
  261. package/dist-server/service/data-sensor/data-sensor-mutation.js +109 -0
  262. package/dist-server/service/data-sensor/data-sensor-mutation.js.map +1 -0
  263. package/dist-server/service/data-sensor/data-sensor-query.d.ts +16 -0
  264. package/dist-server/service/data-sensor/data-sensor-query.js +115 -0
  265. package/dist-server/service/data-sensor/data-sensor-query.js.map +1 -0
  266. package/dist-server/service/data-sensor/data-sensor-type.d.ts +38 -0
  267. package/dist-server/service/data-sensor/data-sensor-type.js +146 -0
  268. package/dist-server/service/data-sensor/data-sensor-type.js.map +1 -0
  269. package/dist-server/service/data-sensor/data-sensor.d.ts +31 -0
  270. package/dist-server/service/data-sensor/data-sensor.js +148 -0
  271. package/dist-server/service/data-sensor/data-sensor.js.map +1 -0
  272. package/dist-server/service/data-sensor/index.d.ts +5 -0
  273. package/dist-server/service/data-sensor/index.js +9 -0
  274. package/dist-server/service/data-sensor/index.js.map +1 -0
  275. package/dist-server/service/data-set/data-item-type.d.ts +62 -0
  276. package/dist-server/service/data-set/data-item-type.js +199 -0
  277. package/dist-server/service/data-set/data-item-type.js.map +1 -0
  278. package/dist-server/service/data-set/data-set-mutation.d.ts +20 -0
  279. package/dist-server/service/data-set/data-set-mutation.js +474 -0
  280. package/dist-server/service/data-set/data-set-mutation.js.map +1 -0
  281. package/dist-server/service/data-set/data-set-query.d.ts +39 -0
  282. package/dist-server/service/data-set/data-set-query.js +545 -0
  283. package/dist-server/service/data-set/data-set-query.js.map +1 -0
  284. package/dist-server/service/data-set/data-set-type.d.ts +75 -0
  285. package/dist-server/service/data-set/data-set-type.js +274 -0
  286. package/dist-server/service/data-set/data-set-type.js.map +1 -0
  287. package/dist-server/service/data-set/data-set.d.ts +95 -0
  288. package/dist-server/service/data-set/data-set.js +375 -0
  289. package/dist-server/service/data-set/data-set.js.map +1 -0
  290. package/dist-server/service/data-set/index.d.ts +5 -0
  291. package/dist-server/service/data-set/index.js +9 -0
  292. package/dist-server/service/data-set/index.js.map +1 -0
  293. package/dist-server/service/data-set-history/data-set-history-query.d.ts +21 -0
  294. package/dist-server/service/data-set-history/data-set-history-query.js +177 -0
  295. package/dist-server/service/data-set-history/data-set-history-query.js.map +1 -0
  296. package/dist-server/service/data-set-history/data-set-history-type.d.ts +5 -0
  297. package/dist-server/service/data-set-history/data-set-history-type.js +21 -0
  298. package/dist-server/service/data-set-history/data-set-history-type.js.map +1 -0
  299. package/dist-server/service/data-set-history/data-set-history.d.ts +53 -0
  300. package/dist-server/service/data-set-history/data-set-history.js +246 -0
  301. package/dist-server/service/data-set-history/data-set-history.js.map +1 -0
  302. package/dist-server/service/data-set-history/event-subscriber.d.ts +7 -0
  303. package/dist-server/service/data-set-history/event-subscriber.js +21 -0
  304. package/dist-server/service/data-set-history/event-subscriber.js.map +1 -0
  305. package/dist-server/service/data-set-history/index.d.ts +6 -0
  306. package/dist-server/service/data-set-history/index.js +10 -0
  307. package/dist-server/service/data-set-history/index.js.map +1 -0
  308. package/dist-server/service/data-spec/data-spec-manager.d.ts +10 -0
  309. package/dist-server/service/data-spec/data-spec-manager.js +20 -0
  310. package/dist-server/service/data-spec/data-spec-manager.js.map +1 -0
  311. package/dist-server/service/data-spec/data-spec-query.d.ts +5 -0
  312. package/dist-server/service/data-spec/data-spec-query.js +37 -0
  313. package/dist-server/service/data-spec/data-spec-query.js.map +1 -0
  314. package/dist-server/service/data-spec/data-spec.d.ts +19 -0
  315. package/dist-server/service/data-spec/data-spec.js +69 -0
  316. package/dist-server/service/data-spec/data-spec.js.map +1 -0
  317. package/dist-server/service/data-spec/index.d.ts +4 -0
  318. package/dist-server/service/data-spec/index.js +8 -0
  319. package/dist-server/service/data-spec/index.js.map +1 -0
  320. package/dist-server/service/data-summary/data-summary-mutation.d.ts +6 -0
  321. package/dist-server/service/data-summary/data-summary-mutation.js +72 -0
  322. package/dist-server/service/data-summary/data-summary-mutation.js.map +1 -0
  323. package/dist-server/service/data-summary/data-summary-query.d.ts +19 -0
  324. package/dist-server/service/data-summary/data-summary-query.js +214 -0
  325. package/dist-server/service/data-summary/data-summary-query.js.map +1 -0
  326. package/dist-server/service/data-summary/data-summary-type.d.ts +33 -0
  327. package/dist-server/service/data-summary/data-summary-type.js +137 -0
  328. package/dist-server/service/data-summary/data-summary-type.js.map +1 -0
  329. package/dist-server/service/data-summary/data-summary.d.ts +38 -0
  330. package/dist-server/service/data-summary/data-summary.js +200 -0
  331. package/dist-server/service/data-summary/data-summary.js.map +1 -0
  332. package/dist-server/service/data-summary/index.d.ts +6 -0
  333. package/dist-server/service/data-summary/index.js +10 -0
  334. package/dist-server/service/data-summary/index.js.map +1 -0
  335. package/dist-server/service/index.d.ts +14 -0
  336. package/dist-server/service/index.js +54 -0
  337. package/dist-server/service/index.js.map +1 -0
  338. package/dist-server/tsconfig.tsbuildinfo +1 -0
  339. package/dist-server/utils/config-resolver.d.ts +1 -0
  340. package/dist-server/utils/config-resolver.js +32 -0
  341. package/dist-server/utils/config-resolver.js.map +1 -0
  342. package/dist-server/utils/index.d.ts +1 -0
  343. package/dist-server/utils/index.js +5 -0
  344. package/dist-server/utils/index.js.map +1 -0
  345. 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,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./task/index.js");
4
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ import './create-data-sample.js';
2
+ import './issue-collect-data.js';
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./create-data-sample.js");
4
+ require("./issue-collect-data.js");
5
+ //# sourceMappingURL=index.js.map
@@ -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,6 @@
1
+ import './routes.js';
2
+ import './activities/index.js';
3
+ import './engine/index.js';
4
+ export * from './controllers/index.js';
5
+ export * from './service/index.js';
6
+ export * from './service/data-spec/data-spec-manager.js';
@@ -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 {};