@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,55 +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 glob_1 = __importDefault(require("glob"));
8
- const path_1 = __importDefault(require("path"));
9
- const config_1 = require("../../config");
10
- const paths_1 = require("../../shared/config/paths");
11
- const staticAssets = [path_1.default.join(paths_1.appBuild, 'index.html')];
12
- const configFiles = [path_1.default.join(__dirname, '../../config.js')];
13
- // Taken from react-scripts/check-required-files, but without console.logs.
14
- const doFilesExist = (files) => {
15
- try {
16
- files.forEach((filename) => {
17
- fs_1.default.accessSync(filename, fs_1.default.constants.F_OK);
18
- });
19
- return true;
20
- }
21
- catch (err) {
22
- return false;
23
- }
24
- };
25
- const grepRecursive = (folder, match) => {
26
- return glob_1.default.sync(folder.concat('/**/*')).some((file) => {
27
- try {
28
- if (!fs_1.default.lstatSync(file).isDirectory()) {
29
- return fs_1.default.readFileSync(file, { encoding: 'utf8' }).includes(match);
30
- }
31
- return false;
32
- }
33
- catch (error) {
34
- console.error(`Error reading file: ${file}\n${error}`);
35
- return false;
36
- }
37
- });
38
- };
39
- const enforcePrerequisites = () => new Promise((resolve, reject) => {
40
- if (!doFilesExist(configFiles)) {
41
- reject(new Error(`Configuration files missing. Please check the 'Configuring' section of README.md.`));
42
- return;
43
- }
44
- if (!doFilesExist(staticAssets)) {
45
- reject(new Error(`Static assets (index.html) are missing. Please check the 'Compiling assets and starting the server' section of README.md.`));
46
- return;
47
- }
48
- // Ensures that server secret is not served to user
49
- if (grepRecursive(paths_1.appBuild, config_1.secret)) {
50
- reject(new Error(`Secret is included in static assets. Please ensure that secret is unique.`));
51
- return;
52
- }
53
- resolve();
54
- });
55
- exports.default = enforcePrerequisites;
@@ -1,41 +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 chalk_1 = __importDefault(require("chalk"));
7
- const Users_1 = __importDefault(require("../../models/Users"));
8
- const log = (data) => {
9
- if (process.env.DEBUG) {
10
- console.log(data);
11
- }
12
- };
13
- const migrate = () => {
14
- log(chalk_1.default.green('Migrating data: resolving unset isAdmin flag'));
15
- return new Promise((migrateResolve, migrateReject) => {
16
- Users_1.default.listUsers((users, migrateError) => {
17
- if (migrateError)
18
- return migrateReject(migrateError);
19
- migrateResolve(Promise.all(users.map((user) => {
20
- let userPatch = null;
21
- if (user.isAdmin == null) {
22
- userPatch = { isAdmin: true };
23
- }
24
- if (userPatch != null) {
25
- log(chalk_1.default.yellow(`Migrating user ${user.username}`));
26
- return new Promise((updateUserResolve, updateUserReject) => {
27
- Users_1.default.updateUser(user.username, userPatch, (response, updateUserError) => {
28
- if (updateUserError) {
29
- updateUserReject(updateUserError);
30
- return;
31
- }
32
- updateUserResolve(response);
33
- });
34
- });
35
- }
36
- return Promise.resolve();
37
- })));
38
- });
39
- });
40
- };
41
- exports.default = migrate;
@@ -1,67 +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 chalk_1 = __importDefault(require("chalk"));
7
- const config_1 = __importDefault(require("../../../config"));
8
- const Users_1 = __importDefault(require("../../models/Users"));
9
- const log = (data) => {
10
- if (process.env.DEBUG) {
11
- console.log(data);
12
- }
13
- };
14
- const migrate = () => {
15
- log(chalk_1.default.green('Migrating data: moving rTorrent connection information to users database'));
16
- return new Promise((migrateResolve, migrateReject) => {
17
- Users_1.default.listUsers((users, listUsersError) => {
18
- if (listUsersError)
19
- return migrateReject(listUsersError);
20
- const { scgi = {} } = config_1.default;
21
- const existingConfig = {
22
- host: scgi.host,
23
- port: scgi.port,
24
- socketPath: scgi.socketPath,
25
- };
26
- migrateResolve(Promise.all(users.map((user) => {
27
- let userPatch = null;
28
- // A bug in this script caused all of these xmlrpc values to be defined in the user db.
29
- // If they are all defined, set all to null to prompt the user to provide new connection
30
- // details.
31
- if (user.host != null && user.port != null && user.socketPath != null) {
32
- userPatch = {
33
- host: null,
34
- port: null,
35
- socketPath: null,
36
- };
37
- }
38
- // If none of the xmlrpc fields are on the user object, try to infer this from the legacy
39
- // configuration file.
40
- if (user.host == null && user.port == null && user.socketPath == null) {
41
- userPatch = { isAdmin: true };
42
- if (existingConfig.socketPath && existingConfig.socketPath.trim().length > 0) {
43
- userPatch.socketPath = existingConfig.socketPath;
44
- }
45
- else {
46
- userPatch.host = existingConfig.host;
47
- userPatch.port = existingConfig.port;
48
- }
49
- }
50
- if (userPatch != null) {
51
- log(chalk_1.default.yellow(`Migrating user ${user.username}`));
52
- return new Promise((updateUserResolve, updateUserReject) => {
53
- Users_1.default.updateUser(user.username, userPatch, (response, updateUserError) => {
54
- if (updateUserError) {
55
- updateUserReject(updateUserError);
56
- return;
57
- }
58
- updateUserResolve(response);
59
- });
60
- });
61
- }
62
- return Promise.resolve();
63
- })));
64
- });
65
- });
66
- };
67
- exports.default = migrate;
@@ -1,10 +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 per_user_rtorrent_instances_1 = __importDefault(require("./per-user-rtorrent-instances"));
7
- const fix_is_admin_flag_1 = __importDefault(require("./fix-is-admin-flag"));
8
- const migrations = [per_user_rtorrent_instances_1.default, fix_is_admin_flag_1.default];
9
- const migrate = () => Promise.all(migrations.map((migration) => migration()));
10
- exports.default = migrate;
@@ -1,18 +0,0 @@
1
- #!/usr/bin/env node
2
- "use strict";
3
- var __importDefault = (this && this.__importDefault) || function (mod) {
4
- return (mod && mod.__esModule) ? mod : { "default": mod };
5
- };
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- const chalk_1 = __importDefault(require("chalk"));
8
- const enforce_prerequisites_1 = __importDefault(require("./enforce-prerequisites"));
9
- const run_1 = __importDefault(require("./migrations/run"));
10
- const web_server_1 = __importDefault(require("./web-server"));
11
- enforce_prerequisites_1.default()
12
- .then(run_1.default)
13
- .then(web_server_1.default)
14
- .catch((error) => {
15
- console.log(chalk_1.default.red('Failed to start Flood:'));
16
- console.trace(error);
17
- process.exit(1);
18
- });
@@ -1,94 +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 chalk_1 = __importDefault(require("chalk"));
7
- const debug_1 = __importDefault(require("debug"));
8
- const fs_1 = __importDefault(require("fs"));
9
- const http_1 = __importDefault(require("http"));
10
- const spdy_1 = __importDefault(require("spdy"));
11
- const app_1 = __importDefault(require("../app"));
12
- const config_1 = __importDefault(require("../../config"));
13
- const debugFloodServer = debug_1.default('flood:server');
14
- // Normalize a port into a number, string, or false.
15
- const normalizePort = (val) => {
16
- const port = parseInt(val, 10);
17
- // Named pipe.
18
- if (Number.isNaN(port)) {
19
- return val;
20
- }
21
- // Port number.
22
- if (port >= 0) {
23
- return port;
24
- }
25
- console.error('Unexpected port or pipe');
26
- process.exit(1);
27
- return 0;
28
- };
29
- const startWebServer = () => {
30
- const port = normalizePort(config_1.default.floodServerPort);
31
- const host = config_1.default.floodServerHost;
32
- const useSSL = config_1.default.ssl;
33
- app_1.default.set('port', port);
34
- app_1.default.set('host', host);
35
- // Create HTTP or HTTPS server.
36
- let server;
37
- if (useSSL) {
38
- if (!config_1.default.sslKey || !config_1.default.sslCert) {
39
- console.error('Cannot start HTTPS server, `sslKey` or `sslCert` is missing in config.js.');
40
- process.exit(1);
41
- }
42
- server = spdy_1.default.createServer({
43
- key: fs_1.default.readFileSync(config_1.default.sslKey),
44
- cert: fs_1.default.readFileSync(config_1.default.sslCert),
45
- }, app_1.default);
46
- }
47
- else {
48
- server = http_1.default.createServer(app_1.default);
49
- }
50
- const handleError = (error) => {
51
- if (error.syscall !== 'listen') {
52
- throw error;
53
- }
54
- const bind = typeof port === 'string' ? `Pipe ${port}` : `Port ${port}`;
55
- // Handle specific listen errors with friendly messages.
56
- switch (error.code) {
57
- case 'EACCES':
58
- console.error(`${bind} requires elevated privileges`);
59
- process.exit(1);
60
- break;
61
- case 'EADDRINUSE':
62
- console.error(`${bind} is already in use`);
63
- process.exit(1);
64
- break;
65
- default:
66
- throw error;
67
- }
68
- };
69
- // Event listener for HTTP server "listening" event.
70
- const handleListening = () => {
71
- const addr = server.address();
72
- if (addr == null) {
73
- console.error('Unable to get listening address.');
74
- process.exit(1);
75
- }
76
- const bind = typeof addr === 'string' ? `pipe ${addr}` : `port ${addr.port}`;
77
- debugFloodServer(`Listening on ${bind}`);
78
- };
79
- // Listen on provided port, on all network interfaces.
80
- if (typeof port === 'string') {
81
- server.listen(port);
82
- }
83
- else {
84
- server.listen(port, host);
85
- }
86
- server.on('error', handleError);
87
- server.on('listening', handleListening);
88
- const address = chalk_1.default.underline(`${useSSL ? 'https' : 'http'}://${host}:${port}`);
89
- console.log(chalk_1.default.green(`Flood server starting on ${address}.\n`));
90
- if (config_1.default.disableUsersAndAuth) {
91
- console.log(chalk_1.default.yellow('Starting without builtin authentication\n'));
92
- }
93
- };
94
- exports.default = startWebServer;
@@ -1,32 +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 passport_jwt_1 = require("passport-jwt");
7
- const config_1 = __importDefault(require("../../config"));
8
- const Users_1 = __importDefault(require("../models/Users"));
9
- // Setup work and export for the JWT passport strategy.
10
- exports.default = (passport) => {
11
- const options = {
12
- jwtFromRequest: (req) => {
13
- let token = null;
14
- if (req && req.cookies) {
15
- token = req.cookies.jwt;
16
- }
17
- return token;
18
- },
19
- secretOrKey: config_1.default.secret,
20
- };
21
- passport.use(new passport_jwt_1.Strategy(options, (jwtPayload, callback) => {
22
- Users_1.default.lookupUser({ username: jwtPayload.username }, (err, user) => {
23
- if (err) {
24
- return callback(err, false);
25
- }
26
- if (user) {
27
- return callback(null, user);
28
- }
29
- return callback(null, false);
30
- });
31
- }));
32
- };
@@ -1,15 +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 objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
7
- const clientGatewayServiceEvents = [
8
- 'CLIENT_CONNECTION_STATE_CHANGE',
9
- 'PROCESS_TORRENT',
10
- 'PROCESS_TORRENT_LIST_END',
11
- 'PROCESS_TORRENT_LIST_START',
12
- 'PROCESS_TRANSFER_RATE_START',
13
- 'TORRENTS_REMOVED',
14
- ];
15
- exports.default = objectUtil_1.default.createSymbolMapFromArray(clientGatewayServiceEvents);
@@ -1,8 +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 objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
7
- const diskUsageServiceEvents = ['DISK_USAGE_CHANGE'];
8
- exports.default = objectUtil_1.default.createSymbolMapFromArray(diskUsageServiceEvents);
@@ -1,29 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const fileListPropMap = new Map();
4
- const defaultTransformer = (value) => value;
5
- fileListPropMap.set('path', {
6
- methodCall: 'f.path=',
7
- transformValue: defaultTransformer,
8
- });
9
- fileListPropMap.set('pathComponents', {
10
- methodCall: 'f.path_components=',
11
- transformValue: defaultTransformer,
12
- });
13
- fileListPropMap.set('priority', {
14
- methodCall: 'f.priority=',
15
- transformValue: defaultTransformer,
16
- });
17
- fileListPropMap.set('sizeBytes', {
18
- methodCall: 'f.size_bytes=',
19
- transformValue: Number,
20
- });
21
- fileListPropMap.set('sizeChunks', {
22
- methodCall: 'f.size_chunks=',
23
- transformValue: Number,
24
- });
25
- fileListPropMap.set('completedChunks', {
26
- methodCall: 'f.completed_chunks=',
27
- transformValue: Number,
28
- });
29
- exports.default = fileListPropMap;
@@ -1,18 +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 historySnapshotTypes_1 = __importDefault(require("../../shared/constants/historySnapshotTypes"));
7
- const objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
8
- const torrentServiceEvents = [
9
- 'FETCH_TRANSFER_SUMMARY_ERROR',
10
- 'FETCH_TRANSFER_SUMMARY_SUCCESS',
11
- 'TRANSFER_SUMMARY_DIFF_CHANGE',
12
- ].concat(
13
- // Create an array of event types based on the available snapshots.
14
- Object.keys(historySnapshotTypes_1.default).reduce((accumulator, snapshotType) => {
15
- accumulator.push(`${snapshotType}_SNAPSHOT_FULL_UPDATE`, `${snapshotType}_SNAPSHOT_DIFF_CHANGE`);
16
- return accumulator;
17
- }, []));
18
- exports.default = objectUtil_1.default.createSymbolMapFromArray(torrentServiceEvents);
@@ -1,8 +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 objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
7
- const notificationServiceEvents = ['NOTIFICATION_COUNT_CHANGE'];
8
- exports.default = objectUtil_1.default.createSymbolMapFromArray(notificationServiceEvents);
@@ -1,8 +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 objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
7
- const taxonomyServiceEvents = ['TAXONOMY_DIFF_CHANGE'];
8
- exports.default = objectUtil_1.default.createSymbolMapFromArray(taxonomyServiceEvents);
@@ -1,200 +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 regEx_1 = __importDefault(require("../../shared/util/regEx"));
7
- const torrentListPropMap = new Map();
8
- const booleanTransformer = (value) => value === '1';
9
- const dateTransformer = (dirtyDate) => {
10
- if (!dirtyDate) {
11
- return '';
12
- }
13
- const date = dirtyDate.trim();
14
- if (date === '0') {
15
- return '';
16
- }
17
- return date;
18
- };
19
- const defaultTransformer = (value) => value;
20
- torrentListPropMap.set('hash', {
21
- methodCall: 'd.hash=',
22
- transformValue: defaultTransformer,
23
- });
24
- torrentListPropMap.set('name', {
25
- methodCall: 'd.name=',
26
- transformValue: defaultTransformer,
27
- });
28
- torrentListPropMap.set('message', {
29
- methodCall: 'd.message=',
30
- transformValue: defaultTransformer,
31
- });
32
- torrentListPropMap.set('state', {
33
- methodCall: 'd.state=',
34
- transformValue: defaultTransformer,
35
- });
36
- torrentListPropMap.set('isStateChanged', {
37
- methodCall: 'd.state_changed=',
38
- transformValue: booleanTransformer,
39
- });
40
- torrentListPropMap.set('isActive', {
41
- methodCall: 'd.is_active=',
42
- transformValue: booleanTransformer,
43
- });
44
- torrentListPropMap.set('isComplete', {
45
- methodCall: 'd.complete=',
46
- transformValue: booleanTransformer,
47
- });
48
- torrentListPropMap.set('isHashing', {
49
- methodCall: 'd.hashing=',
50
- transformValue: defaultTransformer,
51
- });
52
- torrentListPropMap.set('isOpen', {
53
- methodCall: 'd.is_open=',
54
- transformValue: booleanTransformer,
55
- });
56
- torrentListPropMap.set('priority', {
57
- methodCall: 'd.priority=',
58
- transformValue: defaultTransformer,
59
- });
60
- torrentListPropMap.set('upRate', {
61
- methodCall: 'd.up.rate=',
62
- transformValue: Number,
63
- });
64
- torrentListPropMap.set('upTotal', {
65
- methodCall: 'd.up.total=',
66
- transformValue: Number,
67
- });
68
- torrentListPropMap.set('downRate', {
69
- methodCall: 'd.down.rate=',
70
- transformValue: Number,
71
- });
72
- torrentListPropMap.set('downTotal', {
73
- methodCall: 'd.down.total=',
74
- transformValue: Number,
75
- });
76
- torrentListPropMap.set('ratio', {
77
- methodCall: 'd.ratio=',
78
- transformValue: Number,
79
- });
80
- torrentListPropMap.set('bytesDone', {
81
- methodCall: 'd.bytes_done=',
82
- transformValue: Number,
83
- });
84
- torrentListPropMap.set('sizeBytes', {
85
- methodCall: 'd.size_bytes=',
86
- transformValue: Number,
87
- });
88
- torrentListPropMap.set('directory', {
89
- methodCall: 'd.directory=',
90
- transformValue: defaultTransformer,
91
- });
92
- torrentListPropMap.set('basePath', {
93
- methodCall: 'd.base_path=',
94
- transformValue: defaultTransformer,
95
- });
96
- torrentListPropMap.set('baseFilename', {
97
- methodCall: 'd.base_filename=',
98
- transformValue: defaultTransformer,
99
- });
100
- torrentListPropMap.set('baseDirectory', {
101
- methodCall: 'd.directory_base=',
102
- transformValue: defaultTransformer,
103
- });
104
- torrentListPropMap.set('seedingTime', {
105
- methodCall: 'd.custom=seedingtime',
106
- transformValue: defaultTransformer,
107
- });
108
- torrentListPropMap.set('dateAdded', {
109
- methodCall: 'd.custom=addtime',
110
- transformValue: dateTransformer,
111
- });
112
- torrentListPropMap.set('dateCreated', {
113
- methodCall: 'd.creation_date=',
114
- transformValue: dateTransformer,
115
- });
116
- torrentListPropMap.set('throttleName', {
117
- methodCall: 'd.throttle_name=',
118
- transformValue: defaultTransformer,
119
- });
120
- torrentListPropMap.set('isMultiFile', {
121
- methodCall: 'd.is_multi_file=',
122
- transformValue: booleanTransformer,
123
- });
124
- torrentListPropMap.set('isPrivate', {
125
- methodCall: 'd.is_private=',
126
- transformValue: booleanTransformer,
127
- });
128
- torrentListPropMap.set('tags', {
129
- methodCall: 'd.custom1=',
130
- transformValue: (value) => {
131
- if (value === '') {
132
- return [];
133
- }
134
- return value
135
- .split(',')
136
- .sort()
137
- .map((tag) => decodeURIComponent(tag));
138
- },
139
- });
140
- torrentListPropMap.set('comment', {
141
- methodCall: 'd.custom2=',
142
- transformValue: (value) => {
143
- let comment = decodeURIComponent(value);
144
- if (comment.match(/^VRS24mrker/)) {
145
- comment = comment.substr(10);
146
- }
147
- return comment;
148
- },
149
- });
150
- torrentListPropMap.set('ignoreScheduler', {
151
- methodCall: 'd.custom=sch_ignore',
152
- transformValue: booleanTransformer,
153
- });
154
- torrentListPropMap.set('trackerURIs', {
155
- methodCall: 'cat="$t.multicall=d.hash=,t.is_enabled=,t.url=,cat={|||}"',
156
- transformValue: (value) => {
157
- const trackers = value.split('|||');
158
- const trackerDomains = [];
159
- trackers.forEach((tracker) => {
160
- // Only count enabled trackers
161
- if (tracker.charAt(0) === '0') {
162
- return;
163
- }
164
- let domain = regEx_1.default.domainName.exec(tracker.substr(1));
165
- if (domain && domain[1]) {
166
- domain = domain[1];
167
- const minSubsetLength = 3;
168
- const domainSubsets = domain.split('.');
169
- let desiredSubsets = 2;
170
- if (domainSubsets.length > desiredSubsets) {
171
- const lastDesiredSubset = domainSubsets[domainSubsets.length - desiredSubsets];
172
- if (lastDesiredSubset.length <= minSubsetLength) {
173
- desiredSubsets++;
174
- }
175
- }
176
- domain = domainSubsets.slice(desiredSubsets * -1).join('.');
177
- trackerDomains.push(domain);
178
- }
179
- });
180
- // Deduplicate
181
- return [...new Set(trackerDomains)];
182
- },
183
- });
184
- torrentListPropMap.set('seedsConnected', {
185
- methodCall: 'd.peers_complete=',
186
- transformValue: Number,
187
- });
188
- torrentListPropMap.set('seedsTotal', {
189
- methodCall: 'cat="$t.multicall=d.hash=,t.scrape_complete=,cat={|||}"',
190
- transformValue: (value) => Number(value.substr(0, value.indexOf('|||'))),
191
- });
192
- torrentListPropMap.set('peersConnected', {
193
- methodCall: 'd.peers_accounted=',
194
- transformValue: Number,
195
- });
196
- torrentListPropMap.set('peersTotal', {
197
- methodCall: 'cat="$t.multicall=d.hash=,t.scrape_incomplete=,cat={|||}"',
198
- transformValue: (value) => Number(value.substr(0, value.indexOf('|||'))),
199
- });
200
- exports.default = torrentListPropMap;
@@ -1,8 +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 objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
7
- const torrentServiceEvents = ['FETCH_TORRENT_LIST_ERROR', 'FETCH_TORRENT_LIST_SUCCESS', 'TORRENT_LIST_DIFF_CHANGE'];
8
- exports.default = objectUtil_1.default.createSymbolMapFromArray(torrentServiceEvents);
@@ -1,28 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const transferSummaryPropMap = new Map();
4
- transferSummaryPropMap.set('upRate', {
5
- methodCall: 'throttle.global_up.rate',
6
- transformValue: Number,
7
- });
8
- transferSummaryPropMap.set('upTotal', {
9
- methodCall: 'throttle.global_up.total',
10
- transformValue: Number,
11
- });
12
- transferSummaryPropMap.set('upThrottle', {
13
- methodCall: 'throttle.global_up.max_rate',
14
- transformValue: Number,
15
- });
16
- transferSummaryPropMap.set('downRate', {
17
- methodCall: 'throttle.global_down.rate',
18
- transformValue: Number,
19
- });
20
- transferSummaryPropMap.set('downTotal', {
21
- methodCall: 'throttle.global_down.total',
22
- transformValue: Number,
23
- });
24
- transferSummaryPropMap.set('downThrottle', {
25
- methodCall: 'throttle.global_down.max_rate',
26
- transformValue: Number,
27
- });
28
- exports.default = transferSummaryPropMap;
@@ -1,10 +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 services_1 = __importDefault(require("../services"));
7
- exports.default = (req, res, next) => {
8
- req.services = services_1.default.getAllServices(req.user);
9
- next();
10
- };