@jesec/flood 0.0.0-master.8daf3f8 → 0.0.0-master.8dbd865

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 (407) hide show
  1. package/CHANGELOG.md +606 -103
  2. package/README.md +125 -45
  3. package/SECURITY.md +27 -0
  4. package/dist/assets/icon_128x128.png +0 -0
  5. package/dist/assets/icon_192x192.png +0 -0
  6. package/dist/assets/icon_256x256.png +0 -0
  7. package/dist/assets/icon_384x384.png +0 -0
  8. package/dist/assets/icon_512x512.png +0 -0
  9. package/dist/assets/icon_96x96.png +0 -0
  10. package/dist/assets/icon_maskable.png +0 -0
  11. package/dist/assets/icon_maskable_180x180.png +0 -0
  12. package/dist/assets/index.html +1 -1
  13. package/dist/assets/manifest.json +35 -7
  14. package/dist/assets/static/css/662.37bdb6f87f387ec14604.css +1 -0
  15. package/dist/assets/static/css/main.1e285a62d2e5127de06b.css +1 -0
  16. package/dist/assets/static/js/179.372e151d.chunk.js +1 -0
  17. package/dist/assets/static/js/662.1b1f1092.chunk.js +1 -0
  18. package/dist/assets/static/js/963.94abcb99.chunk.js +1 -0
  19. package/dist/assets/static/js/996.f0e63eaa.chunk.js +1 -0
  20. package/dist/assets/static/js/flag0.56298b91.chunk.js +1 -0
  21. package/dist/assets/static/js/flag1.badfc781.chunk.js +1 -0
  22. package/dist/assets/static/js/flag2.c5a910ff.chunk.js +1 -0
  23. package/dist/assets/static/js/flag3.2a4050b4.chunk.js +1 -0
  24. package/dist/assets/static/js/i18n0.b0c0bc82.chunk.js +1 -0
  25. package/dist/assets/static/js/i18n1.cb04b1f5.chunk.js +1 -0
  26. package/dist/assets/static/js/i18n10.8ca66096.chunk.js +1 -0
  27. package/dist/assets/static/js/i18n11.b66895ae.chunk.js +1 -0
  28. package/dist/assets/static/js/i18n12.76af2306.chunk.js +1 -0
  29. package/dist/assets/static/js/i18n13.d6692432.chunk.js +1 -0
  30. package/dist/assets/static/js/i18n14.22da7cd2.chunk.js +1 -0
  31. package/dist/assets/static/js/i18n15.bbfb5738.chunk.js +1 -0
  32. package/dist/assets/static/js/i18n16.c77ad464.chunk.js +1 -0
  33. package/dist/assets/static/js/i18n17.e5397215.chunk.js +1 -0
  34. package/dist/assets/static/js/i18n18.2faa4785.chunk.js +1 -0
  35. package/dist/assets/static/js/i18n19.a5db1b01.chunk.js +1 -0
  36. package/dist/assets/static/js/i18n2.7d1aed47.chunk.js +1 -0
  37. package/dist/assets/static/js/i18n20.cba7bf0c.chunk.js +1 -0
  38. package/dist/assets/static/js/i18n21.a27eaf09.chunk.js +1 -0
  39. package/dist/assets/static/js/i18n22.fa878be7.chunk.js +1 -0
  40. package/dist/assets/static/js/i18n23.5c647e79.chunk.js +1 -0
  41. package/dist/assets/static/js/i18n24.6b14986d.chunk.js +1 -0
  42. package/dist/assets/static/js/i18n25.afe69894.chunk.js +1 -0
  43. package/dist/assets/static/js/i18n26.eac16996.chunk.js +1 -0
  44. package/dist/assets/static/js/i18n27.8d32b1f7.chunk.js +1 -0
  45. package/dist/assets/static/js/i18n28.d64c3baf.chunk.js +1 -0
  46. package/dist/assets/static/js/i18n3.14d4def3.chunk.js +1 -0
  47. package/dist/assets/static/js/i18n4.5c77cde4.chunk.js +1 -0
  48. package/dist/assets/static/js/i18n5.430ea15f.chunk.js +1 -0
  49. package/dist/assets/static/js/i18n6.3c79cffd.chunk.js +1 -0
  50. package/dist/assets/static/js/i18n8.6a62aa52.chunk.js +1 -0
  51. package/dist/assets/static/js/i18n9.d06ff92d.chunk.js +1 -0
  52. package/dist/assets/static/js/main.fd1408d5.js +1 -0
  53. package/dist/assets/static/media/ad.1b24595d.png +0 -0
  54. package/dist/assets/static/media/ae.4dd8f55e.png +0 -0
  55. package/dist/assets/static/media/af.4ce660eb.png +0 -0
  56. package/dist/assets/static/media/ag.fd9409e4.png +0 -0
  57. package/dist/assets/static/media/al.a297aacf.png +0 -0
  58. package/dist/assets/static/media/am.c84ee0cf.png +0 -0
  59. package/dist/assets/static/media/ao.a7c9214e.png +0 -0
  60. package/dist/assets/static/media/ar.7e57ef92.png +0 -0
  61. package/dist/assets/static/media/at.5aa9728a.png +0 -0
  62. package/dist/assets/static/media/au.155b51d8.png +0 -0
  63. package/dist/assets/static/media/az.63afef5b.png +0 -0
  64. package/dist/assets/static/media/ba.5ce8f273.png +0 -0
  65. package/dist/assets/static/media/bb.f369fc62.png +0 -0
  66. package/dist/assets/static/media/bd.516278fc.png +0 -0
  67. package/dist/assets/static/media/be.08ec4a8d.png +0 -0
  68. package/dist/assets/static/media/bf.50bfcb31.png +0 -0
  69. package/dist/assets/static/media/bg.d9346b96.png +0 -0
  70. package/dist/assets/static/media/bh.f06d5914.png +0 -0
  71. package/dist/assets/static/media/bi.4923e3a3.png +0 -0
  72. package/dist/assets/static/media/bj.019fa79b.png +0 -0
  73. package/dist/assets/static/media/bn.077671e2.png +0 -0
  74. package/dist/assets/static/media/bo.8fb15fc6.png +0 -0
  75. package/dist/assets/static/media/br.ec051f0c.png +0 -0
  76. package/dist/assets/static/media/bs.a74a126f.png +0 -0
  77. package/dist/assets/static/media/bt.4217b804.png +0 -0
  78. package/dist/assets/static/media/bw.21fe1567.png +0 -0
  79. package/dist/assets/static/media/by.d247fe16.png +0 -0
  80. package/dist/assets/static/media/bz.98ec59f6.png +0 -0
  81. package/dist/assets/static/media/ca.25743e11.png +0 -0
  82. package/dist/assets/static/media/cd.a5bfda53.png +0 -0
  83. package/dist/assets/static/media/cf.de7d5d92.png +0 -0
  84. package/dist/assets/static/media/cg.a47b626b.png +0 -0
  85. package/dist/assets/static/media/ch.445f47a1.png +0 -0
  86. package/dist/assets/static/media/ci.a6009c5b.png +0 -0
  87. package/dist/assets/static/media/cl.de1d715e.png +0 -0
  88. package/dist/assets/static/media/cm.3ce8a86a.png +0 -0
  89. package/dist/assets/static/media/cn.e6a26073.png +0 -0
  90. package/dist/assets/static/media/co.e9244faa.png +0 -0
  91. package/dist/assets/static/media/cr.c895e035.png +0 -0
  92. package/dist/assets/static/media/cu.e486c055.png +0 -0
  93. package/dist/assets/static/media/cv.a9585acf.png +0 -0
  94. package/dist/assets/static/media/cw.df13039d.png +0 -0
  95. package/dist/assets/static/media/cy.b31f43a9.png +0 -0
  96. package/dist/assets/static/media/cz.8ec5948b.png +0 -0
  97. package/dist/assets/static/media/de.d12f391a.png +0 -0
  98. package/dist/assets/static/media/dj.154c3580.png +0 -0
  99. package/dist/assets/static/media/dk.da382fe2.png +0 -0
  100. package/dist/assets/static/media/dm.f452e6cd.png +0 -0
  101. package/dist/assets/static/media/do.c6bd7637.png +0 -0
  102. package/dist/assets/static/media/dz.672a69c0.png +0 -0
  103. package/dist/assets/static/media/ec.349d9bd7.png +0 -0
  104. package/dist/assets/static/media/ee.2396205f.png +0 -0
  105. package/dist/assets/static/media/eg.ccbf3f45.png +0 -0
  106. package/dist/assets/static/media/eh.af65674a.png +0 -0
  107. package/dist/assets/static/media/er.21afb638.png +0 -0
  108. package/dist/assets/static/media/es.2a6eaee4.png +0 -0
  109. package/dist/assets/static/media/et.8beb65c8.png +0 -0
  110. package/dist/assets/static/media/fi.331f70fd.png +0 -0
  111. package/dist/assets/static/media/fj.7724d800.png +0 -0
  112. package/dist/assets/static/media/fm.eeaf71e9.png +0 -0
  113. package/dist/assets/static/media/fr.5d5ab008.png +0 -0
  114. package/dist/assets/static/media/ga.77ed474c.png +0 -0
  115. package/dist/assets/static/media/gb.e00065bf.png +0 -0
  116. package/dist/assets/static/media/gd.b4522267.png +0 -0
  117. package/dist/assets/static/media/ge.91a7654d.png +0 -0
  118. package/dist/assets/static/media/gh.4759f92f.png +0 -0
  119. package/dist/assets/static/media/gm.81cd9f75.png +0 -0
  120. package/dist/assets/static/media/gn.9f3d376e.png +0 -0
  121. package/dist/assets/static/media/gq.e8ad58be.png +0 -0
  122. package/dist/assets/static/media/gr.26f3ac0b.png +0 -0
  123. package/dist/assets/static/media/gt.9d81c52e.png +0 -0
  124. package/dist/assets/static/media/gw.dc906982.png +0 -0
  125. package/dist/assets/static/media/gy.a4f62b6c.png +0 -0
  126. package/dist/assets/static/media/hk.56555c3f.png +0 -0
  127. package/dist/assets/static/media/hn.64ee6aad.png +0 -0
  128. package/dist/assets/static/media/hr.93ebecd3.png +0 -0
  129. package/dist/assets/static/media/ht.42ca1596.png +0 -0
  130. package/dist/assets/static/media/hu.bb30f05d.png +0 -0
  131. package/dist/assets/static/media/id.2cb49f2d.png +0 -0
  132. package/dist/assets/static/media/ie.b4dd1f19.png +0 -0
  133. package/dist/assets/static/media/il.cd1d1faf.png +0 -0
  134. package/dist/assets/static/media/in.2df03847.png +0 -0
  135. package/dist/assets/static/media/iq.a9b670ab.png +0 -0
  136. package/dist/assets/static/media/ir.9a3de085.png +0 -0
  137. package/dist/assets/static/media/is.d88f4fc9.png +0 -0
  138. package/dist/assets/static/media/it.b73713e3.png +0 -0
  139. package/dist/assets/static/media/je.0353f56a.png +0 -0
  140. package/dist/assets/static/media/jm.20330ef4.png +0 -0
  141. package/dist/assets/static/media/jo.eb66f1d1.png +0 -0
  142. package/dist/assets/static/media/jp.63e382ae.png +0 -0
  143. package/dist/assets/static/media/ke.ab2e43b8.png +0 -0
  144. package/dist/assets/static/media/kg.2c47c2af.png +0 -0
  145. package/dist/assets/static/media/kh.4732c810.png +0 -0
  146. package/dist/assets/static/media/ki.5fba09fd.png +0 -0
  147. package/dist/assets/static/media/km.7bbed3e9.png +0 -0
  148. package/dist/assets/static/media/kn.a9595a16.png +0 -0
  149. package/dist/assets/static/media/kp.8a4dc30a.png +0 -0
  150. package/dist/assets/static/media/kr.5273be1d.png +0 -0
  151. package/dist/assets/static/media/ks.99f78645.png +0 -0
  152. package/dist/assets/static/media/kw.af3521bc.png +0 -0
  153. package/dist/assets/static/media/kz.ea47ef79.png +0 -0
  154. package/dist/assets/static/media/la.78a598d7.png +0 -0
  155. package/dist/assets/static/media/lb.7a7c15a9.png +0 -0
  156. package/dist/assets/static/media/lc.6083a4ff.png +0 -0
  157. package/dist/assets/static/media/li.61c564a4.png +0 -0
  158. package/dist/assets/static/media/lk.6fa85802.png +0 -0
  159. package/dist/assets/static/media/lr.8063f7db.png +0 -0
  160. package/dist/assets/static/media/ls.901ddb71.png +0 -0
  161. package/dist/assets/static/media/lt.9209ace3.png +0 -0
  162. package/dist/assets/static/media/lu.c9872bc1.png +0 -0
  163. package/dist/assets/static/media/lv.7bcacf0a.png +0 -0
  164. package/dist/assets/static/media/ly.2830aa63.png +0 -0
  165. package/dist/assets/static/media/ma.ce5f697b.png +0 -0
  166. package/dist/assets/static/media/mc.4bd5d57a.png +0 -0
  167. package/dist/assets/static/media/md.fb4b5bdf.png +0 -0
  168. package/dist/assets/static/media/me.1f1d1772.png +0 -0
  169. package/dist/assets/static/media/mg.89101bd2.png +0 -0
  170. package/dist/assets/static/media/mh.ff11dff7.png +0 -0
  171. package/dist/assets/static/media/mk.8420e604.png +0 -0
  172. package/dist/assets/static/media/ml.4db47c66.png +0 -0
  173. package/dist/assets/static/media/mm.8e4ac30a.png +0 -0
  174. package/dist/assets/static/media/mn.dc1daa04.png +0 -0
  175. package/dist/assets/static/media/mr.7cbca6d0.png +0 -0
  176. package/dist/assets/static/media/mt.28a4b863.png +0 -0
  177. package/dist/assets/static/media/mu.d93db6c7.png +0 -0
  178. package/dist/assets/static/media/mv.7d026bf1.png +0 -0
  179. package/dist/assets/static/media/mw.960cd4fb.png +0 -0
  180. package/dist/assets/static/media/mx.39b78eb2.png +0 -0
  181. package/dist/assets/static/media/my.916a8392.png +0 -0
  182. package/dist/assets/static/media/mz.facb4ea3.png +0 -0
  183. package/dist/assets/static/media/na.472666a9.png +0 -0
  184. package/dist/assets/static/media/ne.d774701f.png +0 -0
  185. package/dist/assets/static/media/ng.7b06a49f.png +0 -0
  186. package/dist/assets/static/media/ni.7140131c.png +0 -0
  187. package/dist/assets/static/media/nl.4c04aa96.png +0 -0
  188. package/dist/assets/static/media/no.c19eb00d.png +0 -0
  189. package/dist/assets/static/media/np.54fb4f2f.png +0 -0
  190. package/dist/assets/static/media/nr.7527cc38.png +0 -0
  191. package/dist/assets/static/media/nz.738be05b.png +0 -0
  192. package/dist/assets/static/media/om.b25e0a17.png +0 -0
  193. package/dist/assets/static/media/pa.b28a9059.png +0 -0
  194. package/dist/assets/static/media/pe.c1fc1d96.png +0 -0
  195. package/dist/assets/static/media/pg.380115db.png +0 -0
  196. package/dist/assets/static/media/ph.02199ddc.png +0 -0
  197. package/dist/assets/static/media/pk.094f9517.png +0 -0
  198. package/dist/assets/static/media/pl.41521283.png +0 -0
  199. package/dist/assets/static/media/pt.1f82dc04.png +0 -0
  200. package/dist/assets/static/media/pw.a26c2316.png +0 -0
  201. package/dist/assets/static/media/py.926c65ed.png +0 -0
  202. package/dist/assets/static/media/qa.c6a3c20e.png +0 -0
  203. package/dist/assets/static/media/ro.a36876c9.png +0 -0
  204. package/dist/assets/static/media/rs.c6629de8.png +0 -0
  205. package/dist/assets/static/media/ru.a9b948c1.png +0 -0
  206. package/dist/assets/static/media/rw.e8aecba0.png +0 -0
  207. package/dist/assets/static/media/sa.859049c8.png +0 -0
  208. package/dist/assets/static/media/sb.4ad27b27.png +0 -0
  209. package/dist/assets/static/media/sc.3293efde.png +0 -0
  210. package/dist/assets/static/media/sd.19c94faa.png +0 -0
  211. package/dist/assets/static/media/se.195b3f93.png +0 -0
  212. package/dist/assets/static/media/sg.19d81907.png +0 -0
  213. package/dist/assets/static/media/si.367c5443.png +0 -0
  214. package/dist/assets/static/media/sk.4e5b8a39.png +0 -0
  215. package/dist/assets/static/media/sl.4b174b1c.png +0 -0
  216. package/dist/assets/static/media/sm.2cba3dac.png +0 -0
  217. package/dist/assets/static/media/sn.a4c1041d.png +0 -0
  218. package/dist/assets/static/media/so.b455e3bf.png +0 -0
  219. package/dist/assets/static/media/sr.5adc1c00.png +0 -0
  220. package/dist/assets/static/media/st.5ae44155.png +0 -0
  221. package/dist/assets/static/media/sv.43aa6cdf.png +0 -0
  222. package/dist/assets/static/media/sy.0fbd24f7.png +0 -0
  223. package/dist/assets/static/media/sz.ff204912.png +0 -0
  224. package/dist/assets/static/media/td.c7aa2a4e.png +0 -0
  225. package/dist/assets/static/media/tg.857c3bec.png +0 -0
  226. package/dist/assets/static/media/th.683600c7.png +0 -0
  227. package/dist/assets/static/media/tj.d20c5570.png +0 -0
  228. package/dist/assets/static/media/tl.5edd8ea7.png +0 -0
  229. package/dist/assets/static/media/tm.15960215.png +0 -0
  230. package/dist/assets/static/media/tn.40df718e.png +0 -0
  231. package/dist/assets/static/media/to.c3b054df.png +0 -0
  232. package/dist/assets/static/media/tr.adeace6d.png +0 -0
  233. package/dist/assets/static/media/tt.839bd7f1.png +0 -0
  234. package/dist/assets/static/media/tv.628cae3e.png +0 -0
  235. package/dist/assets/static/media/tw.4e885914.png +0 -0
  236. package/dist/assets/static/media/tz.b2f0dc37.png +0 -0
  237. package/dist/assets/static/media/ua.6b103313.png +0 -0
  238. package/dist/assets/static/media/ug.c84042fc.png +0 -0
  239. package/dist/assets/static/media/us.8523c31d.png +0 -0
  240. package/dist/assets/static/media/uy.a943f85e.png +0 -0
  241. package/dist/assets/static/media/uz.25552673.png +0 -0
  242. package/dist/assets/static/media/va.a29e1b53.png +0 -0
  243. package/dist/assets/static/media/vc.7480bd37.png +0 -0
  244. package/dist/assets/static/media/ve.fd4273c2.png +0 -0
  245. package/dist/assets/static/media/vn.7d2eff1b.png +0 -0
  246. package/dist/assets/static/media/vu.48b64cf3.png +0 -0
  247. package/dist/assets/static/media/ws.f3d9202f.png +0 -0
  248. package/dist/assets/static/media/ye.311a0e50.png +0 -0
  249. package/dist/assets/static/media/za.090a856f.png +0 -0
  250. package/dist/assets/static/media/zm.8371e197.png +0 -0
  251. package/dist/assets/static/media/zw.a6809447.png +0 -0
  252. package/dist/index.js +145901 -0
  253. package/package.json +212 -152
  254. package/dist/assets/android-chrome-192x192.png +0 -0
  255. package/dist/assets/android-chrome-512x512.png +0 -0
  256. package/dist/assets/apple-touch-icon.png +0 -0
  257. package/dist/assets/asset-manifest.json +0 -57
  258. package/dist/assets/browserconfig.xml +0 -9
  259. package/dist/assets/favicon-16x16.png +0 -0
  260. package/dist/assets/favicon-32x32.png +0 -0
  261. package/dist/assets/mstile-144x144.png +0 -0
  262. package/dist/assets/mstile-150x150.png +0 -0
  263. package/dist/assets/mstile-310x150.png +0 -0
  264. package/dist/assets/mstile-310x310.png +0 -0
  265. package/dist/assets/mstile-70x70.png +0 -0
  266. package/dist/assets/static/css/main.b6ffc2bec74dc4b98b88.css +0 -1
  267. package/dist/assets/static/js/0.0a556a75.chunk.js +0 -1
  268. package/dist/assets/static/js/1.14dd2d0c.chunk.js +0 -1
  269. package/dist/assets/static/js/10.d4eef924.chunk.js +0 -1
  270. package/dist/assets/static/js/11.53cd515d.chunk.js +0 -1
  271. package/dist/assets/static/js/12.ce0f8a4e.chunk.js +0 -1
  272. package/dist/assets/static/js/13.9ca96920.chunk.js +0 -1
  273. package/dist/assets/static/js/14.588e3d0c.chunk.js +0 -1
  274. package/dist/assets/static/js/15.f28d64ab.chunk.js +0 -1
  275. package/dist/assets/static/js/16.53dd87df.chunk.js +0 -1
  276. package/dist/assets/static/js/17.b764e125.chunk.js +0 -1
  277. package/dist/assets/static/js/18.80c3ac22.chunk.js +0 -1
  278. package/dist/assets/static/js/2.8fafb9ff.chunk.js +0 -1
  279. package/dist/assets/static/js/20.64809e35.chunk.js +0 -1
  280. package/dist/assets/static/js/21.f3058669.chunk.js +0 -1
  281. package/dist/assets/static/js/22.9450fc59.chunk.js +0 -1
  282. package/dist/assets/static/js/23.840a4201.chunk.js +0 -1
  283. package/dist/assets/static/js/24.0a173a0d.chunk.js +0 -1
  284. package/dist/assets/static/js/25.e4c2217e.chunk.js +0 -1
  285. package/dist/assets/static/js/26.5f03f1a3.chunk.js +0 -1
  286. package/dist/assets/static/js/27.5127408d.chunk.js +0 -1
  287. package/dist/assets/static/js/28.ebac4379.chunk.js +0 -1
  288. package/dist/assets/static/js/29.de46849d.chunk.js +0 -1
  289. package/dist/assets/static/js/3.c219b8a8.chunk.js +0 -1
  290. package/dist/assets/static/js/30.ff543e93.chunk.js +0 -1
  291. package/dist/assets/static/js/31.1f1ad44f.chunk.js +0 -1
  292. package/dist/assets/static/js/32.b4c28098.chunk.js +0 -1
  293. package/dist/assets/static/js/33.3febffaf.chunk.js +0 -1
  294. package/dist/assets/static/js/34.2e764e96.chunk.js +0 -1
  295. package/dist/assets/static/js/35.92c40bb9.chunk.js +0 -1
  296. package/dist/assets/static/js/36.27afe215.chunk.js +0 -1
  297. package/dist/assets/static/js/37.6d94e34b.chunk.js +0 -1
  298. package/dist/assets/static/js/38.107b5aa9.chunk.js +0 -1
  299. package/dist/assets/static/js/39.112b724b.chunk.js +0 -1
  300. package/dist/assets/static/js/4.19d26f13.chunk.js +0 -1
  301. package/dist/assets/static/js/40.44aa79f5.chunk.js +0 -1
  302. package/dist/assets/static/js/41.fb69cc30.chunk.js +0 -1
  303. package/dist/assets/static/js/42.906cc1ff.chunk.js +0 -1
  304. package/dist/assets/static/js/43.135e1560.chunk.js +0 -1
  305. package/dist/assets/static/js/44.a3d23bab.chunk.js +0 -1
  306. package/dist/assets/static/js/45.f025dffe.chunk.js +0 -1
  307. package/dist/assets/static/js/46.3ea25c9e.chunk.js +0 -1
  308. package/dist/assets/static/js/47.5a213255.chunk.js +0 -1
  309. package/dist/assets/static/js/48.ce4bfe23.chunk.js +0 -1
  310. package/dist/assets/static/js/49.857650de.chunk.js +0 -1
  311. package/dist/assets/static/js/5.dc5232a2.chunk.js +0 -1
  312. package/dist/assets/static/js/50.2a5fd558.chunk.js +0 -1
  313. package/dist/assets/static/js/6.210f5d48.chunk.js +0 -1
  314. package/dist/assets/static/js/7.29af7904.chunk.js +0 -1
  315. package/dist/assets/static/js/8.efcd70d8.chunk.js +0 -1
  316. package/dist/assets/static/js/9.23e24017.chunk.js +0 -1
  317. package/dist/assets/static/js/main.f3cd799a.js +0 -1
  318. package/dist/assets/static/media/ABOUT.d02918c9.md +0 -13
  319. package/dist/assets/static/media/Roboto-500.64e69384.woff +0 -0
  320. package/dist/assets/static/media/Roboto-500.7f8f0146.eot +0 -0
  321. package/dist/assets/static/media/Roboto-500.916656a2.ttf +0 -0
  322. package/dist/assets/static/media/Roboto-500.abd255e8.svg +0 -305
  323. package/dist/assets/static/media/Roboto-700.8d11d1e1.ttf +0 -0
  324. package/dist/assets/static/media/Roboto-700.9c9c164e.svg +0 -310
  325. package/dist/assets/static/media/Roboto-700.c65552c8.eot +0 -0
  326. package/dist/assets/static/media/Roboto-700.ee82bda2.woff +0 -0
  327. package/dist/assets/static/media/Roboto-700italic.1dc5bfed.eot +0 -0
  328. package/dist/assets/static/media/Roboto-700italic.686da014.woff +0 -0
  329. package/dist/assets/static/media/Roboto-700italic.896656dc.ttf +0 -0
  330. package/dist/assets/static/media/Roboto-700italic.cacb9681.svg +0 -325
  331. package/dist/assets/static/media/Roboto-italic.09ed2f27.svg +0 -323
  332. package/dist/assets/static/media/Roboto-italic.c1421604.woff +0 -0
  333. package/dist/assets/static/media/Roboto-italic.c38ecad2.ttf +0 -0
  334. package/dist/assets/static/media/Roboto-italic.f7677a07.eot +0 -0
  335. package/dist/assets/static/media/Roboto-regular.5107f918.eot +0 -0
  336. package/dist/assets/static/media/Roboto-regular.6a307cf2.woff +0 -0
  337. package/dist/assets/static/media/Roboto-regular.81dc9b21.ttf +0 -0
  338. package/dist/assets/static/media/Roboto-regular.bcf2ba9e.svg +0 -308
  339. package/dist/config.js +0 -173
  340. package/dist/server/app.js +0 -79
  341. package/dist/server/bin/enforce-prerequisites.js +0 -55
  342. package/dist/server/bin/migrations/fix-is-admin-flag.js +0 -41
  343. package/dist/server/bin/migrations/per-user-rtorrent-instances.js +0 -67
  344. package/dist/server/bin/migrations/run.js +0 -10
  345. package/dist/server/bin/start.js +0 -18
  346. package/dist/server/bin/web-server.js +0 -94
  347. package/dist/server/config/passport.js +0 -32
  348. package/dist/server/constants/clientGatewayServiceEvents.js +0 -15
  349. package/dist/server/constants/diskUsageServiceEvents.js +0 -8
  350. package/dist/server/constants/fileListPropMap.js +0 -29
  351. package/dist/server/constants/historyServiceEvents.js +0 -18
  352. package/dist/server/constants/notificationServiceEvents.js +0 -8
  353. package/dist/server/constants/taxonomyServiceEvents.js +0 -8
  354. package/dist/server/constants/torrentListPropMap.js +0 -200
  355. package/dist/server/constants/torrentServiceEvents.js +0 -8
  356. package/dist/server/constants/transferSummaryPropMap.js +0 -28
  357. package/dist/server/middleware/appendUserServices.js +0 -10
  358. package/dist/server/middleware/booleanCoerce.js +0 -9
  359. package/dist/server/middleware/clientActivityStream.js +0 -124
  360. package/dist/server/middleware/eventStream.js +0 -25
  361. package/dist/server/middleware/requireAdmin.js +0 -8
  362. package/dist/server/models/ClientRequest.js +0 -310
  363. package/dist/server/models/Feed.js +0 -65
  364. package/dist/server/models/Filesystem.js +0 -44
  365. package/dist/server/models/HistoryEra.js +0 -168
  366. package/dist/server/models/ServerEvent.js +0 -27
  367. package/dist/server/models/TemporaryStorage.js +0 -20
  368. package/dist/server/models/Users.js +0 -171
  369. package/dist/server/models/client.js +0 -363
  370. package/dist/server/models/settings.js +0 -119
  371. package/dist/server/routes/api.js +0 -69
  372. package/dist/server/routes/auth.js +0 -184
  373. package/dist/server/routes/client.js +0 -101
  374. package/dist/server/services/BaseService.js +0 -24
  375. package/dist/server/services/clientGatewayService.js +0 -220
  376. package/dist/server/services/clientRequestManager.js +0 -76
  377. package/dist/server/services/diskUsageService.js +0 -133
  378. package/dist/server/services/feedService.js +0 -290
  379. package/dist/server/services/historyService.js +0 -181
  380. package/dist/server/services/index.js +0 -108
  381. package/dist/server/services/notificationService.js +0 -109
  382. package/dist/server/services/taxonomyService.js +0 -107
  383. package/dist/server/services/torrentService.js +0 -235
  384. package/dist/server/util/ajaxUtil.js +0 -19
  385. package/dist/server/util/clientResponseUtil.js +0 -99
  386. package/dist/server/util/fileUtil.js +0 -45
  387. package/dist/server/util/mediainfo.js +0 -34
  388. package/dist/server/util/methodCallUtil.js +0 -22
  389. package/dist/server/util/numberUtils.js +0 -7
  390. package/dist/server/util/rTorrentDeserializer.js +0 -104
  391. package/dist/server/util/rTorrentPropMap.js +0 -13
  392. package/dist/server/util/scgiUtil.js +0 -36
  393. package/dist/server/util/torrentFileUtil.js +0 -23
  394. package/dist/shared/config/paths.js +0 -41
  395. package/dist/shared/constants/clientSettingsMap.js +0 -53
  396. package/dist/shared/constants/diffActionTypes.js +0 -6
  397. package/dist/shared/constants/historySnapshotTypes.js +0 -11
  398. package/dist/shared/constants/serverEventTypes.js +0 -18
  399. package/dist/shared/constants/torrentFilePropsMap.js +0 -6
  400. package/dist/shared/constants/torrentPeerPropsMap.js +0 -32
  401. package/dist/shared/constants/torrentStatusMap.js +0 -17
  402. package/dist/shared/constants/torrentTrackerPropsMap.js +0 -6
  403. package/dist/shared/types/Auth.js +0 -2
  404. package/dist/shared/util/formatUtil.js +0 -33
  405. package/dist/shared/util/objectUtil.js +0 -56
  406. package/dist/shared/util/regEx.js +0 -7
  407. /package/dist/assets/{safari-pinned-tab.svg → icon.svg} +0 -0
@@ -1,363 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const fs_1 = __importDefault(require("fs"));
7
- const path_1 = __importDefault(require("path"));
8
- const sanitize_filename_1 = __importDefault(require("sanitize-filename"));
9
- const run_series_1 = __importDefault(require("run-series"));
10
- const tar_stream_1 = __importDefault(require("tar-stream"));
11
- const ClientRequest_1 = __importDefault(require("./ClientRequest"));
12
- const clientResponseUtil_1 = __importDefault(require("../util/clientResponseUtil"));
13
- const clientSettingsMap_1 = require("../../shared/constants/clientSettingsMap");
14
- const fileUtil_1 = __importDefault(require("../util/fileUtil"));
15
- const settings_1 = __importDefault(require("./settings"));
16
- const torrentFilePropsMap_1 = __importDefault(require("../../shared/constants/torrentFilePropsMap"));
17
- const torrentPeerPropsMap_1 = __importDefault(require("../../shared/constants/torrentPeerPropsMap"));
18
- const torrentFileUtil_1 = __importDefault(require("../util/torrentFileUtil"));
19
- const torrentStatusMap_1 = __importDefault(require("../../shared/constants/torrentStatusMap"));
20
- const torrentTrackerPropsMap_1 = __importDefault(require("../../shared/constants/torrentTrackerPropsMap"));
21
- const client = {
22
- addFiles(user, services, req, callback) {
23
- const { files } = req;
24
- const { destination: destinationPath, isBasePath, start } = req.body;
25
- let { tags } = req.body;
26
- const request = new ClientRequest_1.default(user, services);
27
- if (!Array.isArray(tags)) {
28
- tags = tags.split(',');
29
- }
30
- const resolvedPath = fileUtil_1.default.sanitizePath(destinationPath);
31
- if (!fileUtil_1.default.isAllowedPath(resolvedPath)) {
32
- callback(null, fileUtil_1.default.accessDeniedError());
33
- return;
34
- }
35
- fileUtil_1.default.createDirectory({ path: resolvedPath });
36
- request.send();
37
- // Each torrent is sent individually because rTorrent accepts a total
38
- // filesize of 524 kilobytes or less. This allows the user to send many
39
- // torrent files reliably.
40
- files.forEach((file, index) => {
41
- file.originalname = encodeURIComponent(file.originalname);
42
- const fileRequest = new ClientRequest_1.default(user, services);
43
- fileRequest.addFiles({
44
- files: file,
45
- path: resolvedPath,
46
- isBasePath,
47
- start,
48
- tags,
49
- });
50
- // Set the callback for only the last request.
51
- if (index === files.length - 1) {
52
- fileRequest.onComplete((response, error) => {
53
- services.torrentService.fetchTorrentList();
54
- callback(response, error);
55
- });
56
- }
57
- fileRequest.send();
58
- });
59
- settings_1.default.set(user, { id: 'startTorrentsOnLoad', data: start === 'true' || start === true });
60
- },
61
- addUrls(user, services, data, callback) {
62
- const { urls, destination, isBasePath, start, tags } = data;
63
- const request = new ClientRequest_1.default(user, services);
64
- const resolvedPath = fileUtil_1.default.sanitizePath(destination);
65
- if (!fileUtil_1.default.isAllowedPath(resolvedPath)) {
66
- callback(null, fileUtil_1.default.accessDeniedError());
67
- return;
68
- }
69
- fileUtil_1.default.createDirectory({ path: resolvedPath });
70
- request.addURLs({
71
- urls,
72
- path: resolvedPath,
73
- isBasePath,
74
- start,
75
- tags,
76
- });
77
- request.onComplete(callback);
78
- request.send();
79
- settings_1.default.set(user, { id: 'startTorrentsOnLoad', data: start });
80
- },
81
- checkHash(user, services, hashes, callback) {
82
- const request = new ClientRequest_1.default(user, services);
83
- request.checkHash({ hashes });
84
- request.onComplete((response, error) => {
85
- services.torrentService.fetchTorrentList();
86
- callback(response, error);
87
- });
88
- request.send();
89
- },
90
- downloadFiles(user, services, hash, fileString, res) {
91
- try {
92
- const selectedTorrent = services.torrentService.getTorrent(hash);
93
- if (!selectedTorrent)
94
- return res.status(404).json({ error: 'Torrent not found.' });
95
- this.getTorrentDetails(user, services, hash, (torrentDetails) => {
96
- if (!torrentDetails)
97
- return res.status(404).json({ error: 'Torrent details not found' });
98
- let files;
99
- if (!fileString) {
100
- files = torrentDetails.fileTree.files.map((x, i) => `${i}`);
101
- }
102
- else {
103
- files = fileString.split(',');
104
- }
105
- const filePathsToDownload = this.findFilesByIndicies(files, torrentDetails.fileTree).map((file) => path_1.default.join(selectedTorrent.directory, file.path));
106
- if (filePathsToDownload.length === 1) {
107
- const file = filePathsToDownload[0];
108
- if (!fs_1.default.existsSync(file))
109
- return res.status(404).json({ error: 'File not found.' });
110
- res.attachment(path_1.default.basename(file));
111
- return res.download(file);
112
- }
113
- res.attachment(`${selectedTorrent.name}.tar`);
114
- const pack = tar_stream_1.default.pack();
115
- pack.pipe(res);
116
- const tasks = filePathsToDownload.map((filePath) => {
117
- const filename = path_1.default.basename(filePath);
118
- return (next) => {
119
- fs_1.default.stat(filePath, (err, stats) => {
120
- if (err)
121
- return next(err);
122
- const stream = fs_1.default.createReadStream(filePath);
123
- const entry = pack.entry({
124
- name: filename,
125
- size: stats.size,
126
- }, next);
127
- stream.pipe(entry);
128
- });
129
- };
130
- });
131
- run_series_1.default(tasks, (error) => {
132
- if (error)
133
- return res.status(500).json(error);
134
- pack.finalize();
135
- });
136
- });
137
- }
138
- catch (error) {
139
- res.status(500).json(error);
140
- }
141
- },
142
- findFilesByIndicies(indices, fileTree = {}) {
143
- const { directories, files = [] } = fileTree;
144
- let selectedFiles = files.filter((file) => indices.includes(`${file.index}`));
145
- if (directories != null) {
146
- selectedFiles = selectedFiles.concat(Object.keys(directories).reduce((accumulator, directory) => accumulator.concat(this.findFilesByIndicies(indices, directories[directory])), []));
147
- }
148
- return selectedFiles;
149
- },
150
- getSettings(user, services, options, callback) {
151
- let requestedSettingsKeys = [];
152
- const request = new ClientRequest_1.default(user, services);
153
- const response = {};
154
- const outboundTransformation = {
155
- throttleGlobalDownMax: (apiResponse) => Number(apiResponse) / 1024,
156
- throttleGlobalUpMax: (apiResponse) => Number(apiResponse) / 1024,
157
- piecesMemoryMax: (apiResponse) => Number(apiResponse) / (1024 * 1024),
158
- };
159
- request.fetchSettings({
160
- options,
161
- setRequestedKeysArr: (requestedSettingsKeysArr) => {
162
- requestedSettingsKeys = requestedSettingsKeysArr;
163
- },
164
- });
165
- request.postProcess((data) => {
166
- if (!data) {
167
- return null;
168
- }
169
- data.forEach((datum, index) => {
170
- let value = datum[0];
171
- const settingsKey = clientSettingsMap_1.clientSettingsMap[requestedSettingsKeys[index]];
172
- if (outboundTransformation[settingsKey]) {
173
- value = outboundTransformation[settingsKey](value);
174
- }
175
- response[settingsKey] = value;
176
- });
177
- return response;
178
- });
179
- request.onComplete(callback);
180
- request.send();
181
- },
182
- getTorrentDetails(user, services, hash, callback) {
183
- const request = new ClientRequest_1.default(user, services);
184
- request.getTorrentDetails({
185
- hash,
186
- fileProps: torrentFilePropsMap_1.default.methods,
187
- peerProps: torrentPeerPropsMap_1.default.methods,
188
- trackerProps: torrentTrackerPropsMap_1.default.methods,
189
- });
190
- request.postProcess(clientResponseUtil_1.default.processTorrentDetails);
191
- request.onComplete(callback);
192
- request.send();
193
- },
194
- listMethods(user, services, method, args, callback) {
195
- const request = new ClientRequest_1.default(user, services);
196
- request.listMethods({ method, args });
197
- request.onComplete(callback);
198
- request.send();
199
- },
200
- moveTorrents(user, services, data, callback) {
201
- const destinationPath = data.destination;
202
- const { isBasePath, hashes, filenames, moveFiles, sourcePaths, isCheckHash } = data;
203
- const mainRequest = new ClientRequest_1.default(user, services);
204
- const resolvedPath = fileUtil_1.default.sanitizePath(destinationPath);
205
- if (!fileUtil_1.default.isAllowedPath(resolvedPath)) {
206
- callback(null, fileUtil_1.default.accessDeniedError());
207
- return;
208
- }
209
- const hashesToRestart = hashes.filter((hash) => !services.torrentService.getTorrent(hash).status.includes(torrentStatusMap_1.default.stopped));
210
- let afterCheckHash;
211
- if (hashesToRestart.length) {
212
- afterCheckHash = () => {
213
- const startTorrentsRequest = new ClientRequest_1.default(user, services);
214
- startTorrentsRequest.startTorrents({ hashes: hashesToRestart });
215
- startTorrentsRequest.onComplete(callback);
216
- startTorrentsRequest.send();
217
- };
218
- }
219
- else {
220
- afterCheckHash = callback;
221
- }
222
- let checkHash;
223
- if (isCheckHash) {
224
- checkHash = () => {
225
- const checkHashRequest = new ClientRequest_1.default(user, services);
226
- checkHashRequest.checkHash({ hashes });
227
- checkHashRequest.onComplete(afterCheckHash);
228
- checkHashRequest.send();
229
- };
230
- }
231
- else {
232
- checkHash = afterCheckHash;
233
- }
234
- const moveTorrents = () => {
235
- const moveTorrentsRequest = new ClientRequest_1.default(user, services);
236
- moveTorrentsRequest.onComplete(checkHash);
237
- moveTorrentsRequest.moveTorrents({
238
- filenames,
239
- sourcePaths,
240
- resolvedPath,
241
- });
242
- };
243
- let afterSetPath = checkHash;
244
- if (moveFiles) {
245
- afterSetPath = moveTorrents;
246
- }
247
- mainRequest.stopTorrents({ hashes });
248
- mainRequest.setDownloadPath({ hashes, path: resolvedPath, isBasePath });
249
- mainRequest.onComplete(afterSetPath);
250
- mainRequest.send();
251
- },
252
- setFilePriority(user, services, hashes, data, callback) {
253
- // TODO Add support for multiple hashes.
254
- const { fileIndices } = data;
255
- const request = new ClientRequest_1.default(user, services);
256
- request.setFilePriority({ hashes, fileIndices, priority: data.priority });
257
- request.onComplete((response, error) => {
258
- services.torrentService.fetchTorrentList();
259
- callback(response, error);
260
- });
261
- request.send();
262
- },
263
- setPriority(user, services, hashes, data, callback) {
264
- const request = new ClientRequest_1.default(user, services);
265
- request.setPriority({ hashes, priority: data.priority });
266
- request.onComplete((response, error) => {
267
- services.torrentService.fetchTorrentList();
268
- callback(response, error);
269
- });
270
- request.send();
271
- },
272
- setSettings(user, services, payloads, callback) {
273
- const request = new ClientRequest_1.default(user, services);
274
- if (payloads.length === 0)
275
- return callback({});
276
- const inboundTransformations = new Map();
277
- inboundTransformations
278
- .set('throttleGlobalDownMax', (userInput) => ({
279
- id: userInput.id,
280
- data: Number(userInput.data) * 1024,
281
- }))
282
- .set('throttleGlobalUpMax', (userInput) => ({
283
- id: userInput.id,
284
- data: Number(userInput.data) * 1024,
285
- }))
286
- .set('piecesMemoryMax', (userInput) => ({
287
- id: userInput.id,
288
- data: (Number(userInput.data) * 1024 * 1024).toString(),
289
- }));
290
- const transformedPayloads = payloads.map((payload) => {
291
- if (inboundTransformations.has(payload.id)) {
292
- const inboundTransformation = inboundTransformations.get(payload.id);
293
- return inboundTransformation(payload);
294
- }
295
- return payload;
296
- });
297
- request.setSettings({ settings: transformedPayloads });
298
- request.onComplete(callback);
299
- request.send();
300
- },
301
- setSpeedLimits(user, services, data, callback) {
302
- const request = new ClientRequest_1.default(user, services);
303
- request.setThrottle({
304
- direction: data.direction,
305
- throttle: data.throttle,
306
- });
307
- request.onComplete(callback);
308
- request.send();
309
- },
310
- setTaxonomy(user, services, data, callback) {
311
- const request = new ClientRequest_1.default(user, services);
312
- request.setTaxonomy(data);
313
- request.onComplete((response, error) => {
314
- // Fetch the latest torrent list to re-index the taxonomy.
315
- services.torrentService.fetchTorrentList();
316
- callback(response, error);
317
- });
318
- request.send();
319
- },
320
- setTracker(user, services, data, callback) {
321
- const request = new ClientRequest_1.default(user, services);
322
- request.getSessionPath();
323
- request.setTracker(data);
324
- request.postProcess((response) => {
325
- // Modify tracker URL in torrent files
326
- const { tracker, hashes } = data;
327
- const sessionPath = `${response.shift()}`;
328
- if (typeof sessionPath === 'string') {
329
- // Deduplicate hashes via Set() to avoid file ops on the same files
330
- [...new Set(hashes)].forEach((hash) => {
331
- const torrent = path_1.default.join(sessionPath, sanitize_filename_1.default(`${hash}.torrent`));
332
- torrentFileUtil_1.default.setTracker(torrent, tracker);
333
- });
334
- }
335
- return response;
336
- });
337
- request.onComplete((response, error) => {
338
- // Fetch the latest torrent list to re-index trackerURI.
339
- services.torrentService.fetchTorrentList();
340
- callback(response, error);
341
- });
342
- request.send();
343
- },
344
- stopTorrent(user, services, hashes, callback) {
345
- const request = new ClientRequest_1.default(user, services);
346
- request.stopTorrents({ hashes });
347
- request.onComplete((response, error) => {
348
- services.torrentService.fetchTorrentList();
349
- callback(response, error);
350
- });
351
- request.send();
352
- },
353
- startTorrent(user, services, hashes, callback) {
354
- const request = new ClientRequest_1.default(user, services);
355
- request.startTorrents({ hashes });
356
- request.onComplete((response, error) => {
357
- services.torrentService.fetchTorrentList();
358
- callback(response, error);
359
- });
360
- request.send();
361
- },
362
- };
363
- exports.default = client;
@@ -1,119 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const nedb_1 = __importDefault(require("nedb"));
7
- const noop_1 = __importDefault(require("lodash/noop"));
8
- const path_1 = __importDefault(require("path"));
9
- const config_1 = __importDefault(require("../../config"));
10
- const databases = new Map();
11
- const changedKeys = {
12
- downloadRate: 'downRate',
13
- downloadTotal: 'downTotal',
14
- uploadRate: 'upRate',
15
- uploadTotal: 'upTotal',
16
- connectedPeers: 'peersConnected',
17
- totalPeers: 'peersTotal',
18
- connectedSeeds: 'seedsConnected',
19
- totalSeeds: 'seedsTotal',
20
- added: 'dateAdded',
21
- creationDate: 'dateCreated',
22
- trackers: 'trackerURIs',
23
- };
24
- const removedKeys = ['freeDiskSpace'];
25
- /**
26
- * Check settings for old torrent propery keys. If the old keys exist and have
27
- * been assigned values, then check that the new key doesn't also exist. When
28
- * the new key does not exist, add the new key and assign it the old key's
29
- * value.
30
- *
31
- * @param {Object} settings - the stored settings object.
32
- * @return {Object} - the settings object, altered if legacy keys exist.
33
- */
34
- const transformLegacyKeys = (settings) => {
35
- if (settings.sortTorrents && settings.sortTorrents.property in changedKeys) {
36
- settings.sortTorrents.property = changedKeys[settings.sortTorrents.property];
37
- }
38
- if (settings.torrentDetails) {
39
- settings.torrentDetails = settings.torrentDetails.reduce((accumulator, detailItem) => {
40
- if (detailItem &&
41
- detailItem.id in changedKeys &&
42
- !settings.torrentDetails.some((subDetailItem) => subDetailItem.id === changedKeys[detailItem.id])) {
43
- detailItem.id = changedKeys[detailItem.id];
44
- }
45
- if (!removedKeys.includes(detailItem.id)) {
46
- accumulator.push(detailItem);
47
- }
48
- return accumulator;
49
- }, []);
50
- }
51
- if (settings.torrentListColumnWidths) {
52
- Object.keys(settings.torrentListColumnWidths).forEach((columnID) => {
53
- if (columnID in changedKeys && !(changedKeys[columnID] in settings.torrentListColumnWidths)) {
54
- settings.torrentListColumnWidths[changedKeys[columnID]] = settings.torrentListColumnWidths[columnID];
55
- }
56
- });
57
- }
58
- return settings;
59
- };
60
- function getDb(user) {
61
- const userId = user._id;
62
- if (databases.has(userId)) {
63
- return databases.get(userId);
64
- }
65
- const database = new nedb_1.default({
66
- autoload: true,
67
- filename: path_1.default.join(config_1.default.dbPath, userId, 'settings', 'settings.db'),
68
- });
69
- databases.set(userId, database);
70
- return database;
71
- }
72
- const settings = {
73
- get: (user, opts, callback) => {
74
- const query = {};
75
- const settingsToReturn = {};
76
- if (opts.property) {
77
- query.id = opts.property;
78
- }
79
- getDb(user)
80
- .find(query)
81
- .exec((err, docs) => {
82
- if (err) {
83
- callback(null, err);
84
- return;
85
- }
86
- docs.forEach((doc) => {
87
- settingsToReturn[doc.id] = doc.data;
88
- });
89
- callback(transformLegacyKeys(settingsToReturn));
90
- });
91
- },
92
- set: (user, payloads, callback = noop_1.default) => {
93
- const docsResponse = [];
94
- if (!Array.isArray(payloads)) {
95
- payloads = [payloads];
96
- }
97
- if (payloads && payloads.length) {
98
- let error;
99
- payloads.forEach((payload) => {
100
- getDb(user).update({ id: payload.id }, { $set: { data: payload.data } }, { upsert: true }, (err, docs) => {
101
- docsResponse.push(docs);
102
- if (err) {
103
- error = err;
104
- }
105
- });
106
- });
107
- if (error) {
108
- callback(null, error);
109
- }
110
- else {
111
- callback(docsResponse);
112
- }
113
- }
114
- else {
115
- callback();
116
- }
117
- },
118
- };
119
- exports.default = settings;
@@ -1,69 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const express_1 = __importDefault(require("express"));
7
- const passport_1 = __importDefault(require("passport"));
8
- const appendUserServices_1 = __importDefault(require("../middleware/appendUserServices"));
9
- const ajaxUtil_1 = __importDefault(require("../util/ajaxUtil"));
10
- const client_1 = __importDefault(require("../models/client"));
11
- const client_2 = __importDefault(require("./client"));
12
- const clientActivityStream_1 = __importDefault(require("../middleware/clientActivityStream"));
13
- const eventStream_1 = __importDefault(require("../middleware/eventStream"));
14
- const Filesystem_1 = __importDefault(require("../models/Filesystem"));
15
- const mediainfo_1 = __importDefault(require("../util/mediainfo"));
16
- const settings_1 = __importDefault(require("../models/settings"));
17
- const router = express_1.default.Router();
18
- router.use('/', passport_1.default.authenticate('jwt', { session: false }), appendUserServices_1.default);
19
- router.use('/client', client_2.default);
20
- router.get('/activity-stream', eventStream_1.default, clientActivityStream_1.default);
21
- router.get('/download', (req, res) => {
22
- client_1.default.downloadFiles(req.user, req.services, req.query.hash, req.query.files, res);
23
- });
24
- router.delete('/feed-monitor/:id', (req, res) => {
25
- req.services.feedService.removeItem(req.params.id, ajaxUtil_1.default.getResponseFn(res));
26
- });
27
- router.get('/feed-monitor', (req, res) => {
28
- req.services.feedService.getAll(ajaxUtil_1.default.getResponseFn(res));
29
- });
30
- router.get('/feed-monitor/feeds', (req, res) => {
31
- req.services.feedService.getFeeds(req.body.query, ajaxUtil_1.default.getResponseFn(res));
32
- });
33
- router.put('/feed-monitor/feeds', (req, res) => {
34
- req.services.feedService.addFeed(req.body, ajaxUtil_1.default.getResponseFn(res));
35
- });
36
- router.put('/feed-monitor/feeds/:id', (req, res) => {
37
- req.services.feedService.modifyFeed(req.params.id, req.body, ajaxUtil_1.default.getResponseFn(res));
38
- });
39
- router.get('/feed-monitor/rules', (req, res) => {
40
- req.services.feedService.getRules(req.body.query, ajaxUtil_1.default.getResponseFn(res));
41
- });
42
- router.put('/feed-monitor/rules', (req, res) => {
43
- req.services.feedService.addRule(req.body, ajaxUtil_1.default.getResponseFn(res));
44
- });
45
- router.get('/feed-monitor/items', (req, res) => {
46
- req.services.feedService.getItems(req.query, ajaxUtil_1.default.getResponseFn(res));
47
- });
48
- router.get('/directory-list', (req, res) => {
49
- Filesystem_1.default.getDirectoryList(req.query, ajaxUtil_1.default.getResponseFn(res));
50
- });
51
- router.get('/history', (req, res) => {
52
- req.services.historyService.getHistory(req.query, ajaxUtil_1.default.getResponseFn(res));
53
- });
54
- router.get('/mediainfo', (req, res) => {
55
- mediainfo_1.default.getMediainfo(req.user, req.query, ajaxUtil_1.default.getResponseFn(res));
56
- });
57
- router.get('/notifications', (req, res) => {
58
- req.services.notificationService.getNotifications(req.query, ajaxUtil_1.default.getResponseFn(res));
59
- });
60
- router.delete('/notifications', (req, res) => {
61
- req.services.notificationService.clearNotifications(req.query, ajaxUtil_1.default.getResponseFn(res));
62
- });
63
- router.get('/settings', (req, res) => {
64
- settings_1.default.get(req.user, req.query, ajaxUtil_1.default.getResponseFn(res));
65
- });
66
- router.patch('/settings', (req, res) => {
67
- settings_1.default.set(req.user, req.body, ajaxUtil_1.default.getResponseFn(res));
68
- });
69
- exports.default = router;