@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,9 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.default = (key) => (req, res, next) => {
4
- const value = req.body && req.body[key];
5
- if (value && typeof value === 'string') {
6
- req.body[key] = value === 'true';
7
- }
8
- next();
9
- };
@@ -1,124 +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 clientGatewayServiceEvents_1 = __importDefault(require("../constants/clientGatewayServiceEvents"));
7
- const historyServiceEvents_1 = __importDefault(require("../constants/historyServiceEvents"));
8
- const historySnapshotTypes_1 = __importDefault(require("../../shared/constants/historySnapshotTypes"));
9
- const notificationServiceEvents_1 = __importDefault(require("../constants/notificationServiceEvents"));
10
- const ServerEvent_1 = __importDefault(require("../models/ServerEvent"));
11
- const serverEventTypes_1 = __importDefault(require("../../shared/constants/serverEventTypes"));
12
- const services_1 = __importDefault(require("../services"));
13
- const taxonomyServiceEvents_1 = __importDefault(require("../constants/taxonomyServiceEvents"));
14
- const torrentServiceEvents_1 = __importDefault(require("../constants/torrentServiceEvents"));
15
- const diskUsageServiceEvents_1 = __importDefault(require("../constants/diskUsageServiceEvents"));
16
- const diskUsageService_1 = __importDefault(require("../services/diskUsageService"));
17
- exports.default = (req, res) => {
18
- const { query: { historySnapshot = historySnapshotTypes_1.default.FIVE_MINUTE }, user, } = req;
19
- const serviceInstances = services_1.default.getAllServices(user);
20
- const serverEvent = new ServerEvent_1.default(res);
21
- const taxonomy = serviceInstances.taxonomyService.getTaxonomy();
22
- const torrentList = serviceInstances.torrentService.getTorrentList();
23
- const transferSummary = serviceInstances.historyService.getTransferSummary();
24
- // Hook into events and stop listening when connection is closed
25
- const handleEvents = (emitter, event, handler) => {
26
- emitter.on(event, handler);
27
- res.on('close', () => {
28
- emitter.removeListener(event, handler);
29
- });
30
- };
31
- // Emit current state immediately on connection.
32
- serverEvent.setID(Date.now());
33
- serverEvent.setType(serverEventTypes_1.default.CLIENT_CONNECTIVITY_STATUS_CHANGE);
34
- serverEvent.addData({ isConnected: !serviceInstances.clientGatewayService.hasError });
35
- serverEvent.emit();
36
- const handleDiskUsageChange = (diskUsageChange) => {
37
- serverEvent.setID(diskUsageChange.id);
38
- serverEvent.setType(serverEventTypes_1.default.DISK_USAGE_CHANGE);
39
- serverEvent.addData(diskUsageChange.disks);
40
- serverEvent.emit();
41
- };
42
- diskUsageService_1.default.updateDisks().then(() => {
43
- const diskUsage = diskUsageService_1.default.getDiskUsage();
44
- serverEvent.setID(diskUsage.id);
45
- serverEvent.setType(serverEventTypes_1.default.DISK_USAGE_CHANGE);
46
- serverEvent.addData(diskUsage.disks);
47
- serverEvent.emit();
48
- handleEvents(diskUsageService_1.default, diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE, handleDiskUsageChange);
49
- });
50
- serverEvent.setID(torrentList.id);
51
- serverEvent.setType(serverEventTypes_1.default.TORRENT_LIST_FULL_UPDATE);
52
- serverEvent.addData(torrentList.torrents);
53
- serverEvent.emit();
54
- serverEvent.setID(taxonomy.id);
55
- serverEvent.setType(serverEventTypes_1.default.TAXONOMY_FULL_UPDATE);
56
- serverEvent.addData(taxonomy.taxonomy);
57
- serverEvent.emit();
58
- serverEvent.setID(transferSummary.id);
59
- serverEvent.setType(serverEventTypes_1.default.TRANSFER_SUMMARY_FULL_UPDATE);
60
- serverEvent.addData(transferSummary.transferSummary);
61
- serverEvent.emit();
62
- serverEvent.setID(Date.now());
63
- serverEvent.setType(serverEventTypes_1.default.NOTIFICATION_COUNT_CHANGE);
64
- serverEvent.addData(serviceInstances.notificationService.getNotificationCount());
65
- serverEvent.emit();
66
- handleEvents(serviceInstances.clientGatewayService, clientGatewayServiceEvents_1.default.CLIENT_CONNECTION_STATE_CHANGE, () => {
67
- serverEvent.setID(Date.now());
68
- serverEvent.setType(serverEventTypes_1.default.CLIENT_CONNECTIVITY_STATUS_CHANGE);
69
- serverEvent.addData({ isConnected: !serviceInstances.clientGatewayService.hasError });
70
- serverEvent.emit();
71
- });
72
- if (serviceInstances.clientGatewayService.hasError) {
73
- serviceInstances.clientGatewayService.testGateway();
74
- }
75
- // TODO: Handle empty or sub-optimal history states.
76
- // Get user's specified history snapshot current history.
77
- serviceInstances.historyService.getHistory({ snapshot: historySnapshot }, (snapshot, error) => {
78
- const { timestamps: lastTimestamps = [] } = snapshot;
79
- const lastTimestamp = lastTimestamps[lastTimestamps.length - 1];
80
- if (error == null) {
81
- serverEvent.setID(lastTimestamp);
82
- serverEvent.setType(serverEventTypes_1.default.TRANSFER_HISTORY_FULL_UPDATE);
83
- serverEvent.addData(snapshot);
84
- serverEvent.emit();
85
- }
86
- });
87
- // Add user's specified history snapshot change event listener.
88
- handleEvents(serviceInstances.historyService, historyServiceEvents_1.default[`${historySnapshotTypes_1.default[historySnapshot]}_SNAPSHOT_FULL_UPDATE`], (payload) => {
89
- const { data, id } = payload;
90
- serverEvent.setID(id);
91
- serverEvent.setType(serverEventTypes_1.default.TRANSFER_HISTORY_FULL_UPDATE);
92
- serverEvent.addData(data);
93
- serverEvent.emit();
94
- });
95
- handleEvents(serviceInstances.notificationService, notificationServiceEvents_1.default.NOTIFICATION_COUNT_CHANGE, (payload) => {
96
- const { data, id } = payload;
97
- serverEvent.setID(id);
98
- serverEvent.setType(serverEventTypes_1.default.NOTIFICATION_COUNT_CHANGE);
99
- serverEvent.addData(data);
100
- serverEvent.emit();
101
- });
102
- // Add diff event listeners.
103
- handleEvents(serviceInstances.historyService, historyServiceEvents_1.default.TRANSFER_SUMMARY_DIFF_CHANGE, (payload) => {
104
- const { diff, id } = payload;
105
- serverEvent.setID(id);
106
- serverEvent.setType(serverEventTypes_1.default.TRANSFER_SUMMARY_DIFF_CHANGE);
107
- serverEvent.addData(diff);
108
- serverEvent.emit();
109
- });
110
- handleEvents(serviceInstances.taxonomyService, taxonomyServiceEvents_1.default.TAXONOMY_DIFF_CHANGE, (payload) => {
111
- const { diff, id } = payload;
112
- serverEvent.setID(id);
113
- serverEvent.setType(serverEventTypes_1.default.TAXONOMY_DIFF_CHANGE);
114
- serverEvent.addData(diff);
115
- serverEvent.emit();
116
- });
117
- handleEvents(serviceInstances.torrentService, torrentServiceEvents_1.default.TORRENT_LIST_DIFF_CHANGE, (payload) => {
118
- const { diff, id } = payload;
119
- serverEvent.setID(id);
120
- serverEvent.setType(serverEventTypes_1.default.TORRENT_LIST_DIFF_CHANGE);
121
- serverEvent.addData(diff);
122
- serverEvent.emit();
123
- });
124
- };
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.default = (req, res, next) => {
4
- req.socket.setKeepAlive(true);
5
- req.socket.setTimeout(0);
6
- res.set({
7
- 'Content-Type': 'text/event-stream',
8
- 'Cache-Control': 'no-cache',
9
- Connection: 'keep-alive',
10
- 'Cross-Origin-Resource-Policy': 'same-origin',
11
- 'X-Accel-Buffering': 'no',
12
- });
13
- res.status(200);
14
- res.write('retry: 500\n\n');
15
- // Keep the connection open by sending a message every so often.
16
- const keepAliveTimeout = setInterval(() => {
17
- res.write(':keep-alive\n\n');
18
- res.flush();
19
- }, 500);
20
- // cleanup on close
21
- res.on('close', () => {
22
- clearInterval(keepAliveTimeout);
23
- });
24
- next();
25
- };
@@ -1,8 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.default = (req, res, next) => {
4
- if (req.user == null || !req.user.isAdmin) {
5
- return res.status(403).json({ message: 'User is not admin.' }).send();
6
- }
7
- next();
8
- };
@@ -1,310 +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
- /**
7
- * This file is deprecated in favor of clientGatewayService.
8
- */
9
- const mv_1 = __importDefault(require("mv"));
10
- const path_1 = __importDefault(require("path"));
11
- const util_1 = __importDefault(require("util"));
12
- const clientSettingsMap_1 = require("../../shared/constants/clientSettingsMap");
13
- const rTorrentPropMap_1 = __importDefault(require("../util/rTorrentPropMap"));
14
- const torrentStatusMap_1 = __importDefault(require("../../shared/constants/torrentStatusMap"));
15
- const addTagsToRequest = (tagsArr, requestParameters) => {
16
- if (tagsArr && tagsArr.length) {
17
- const tags = tagsArr
18
- .reduce((accumulator, currentTag) => {
19
- const tag = encodeURIComponent(currentTag.trim());
20
- if (tag !== '' && accumulator.indexOf(tag) === -1) {
21
- accumulator.push(tag);
22
- }
23
- return accumulator;
24
- }, [])
25
- .join(',');
26
- requestParameters.push(`d.custom1.set="${tags}"`);
27
- }
28
- return requestParameters;
29
- };
30
- const getEnsuredArray = (item) => {
31
- if (!util_1.default.isArray(item)) {
32
- return [item];
33
- }
34
- return item;
35
- };
36
- const getMethodCall = (methodName, params) => {
37
- params = params || [];
38
- return { methodName, params };
39
- };
40
- class ClientRequest {
41
- constructor(user, services, options) {
42
- options = options || {};
43
- this.services = services;
44
- this.user = user;
45
- this.clientRequestManager = this.services.clientRequestManager;
46
- this.onCompleteFn = null;
47
- this.postProcessFn = null;
48
- this.requests = [];
49
- if (options.onComplete) {
50
- this.onCompleteFn = options.onComplete;
51
- }
52
- if (options.postProcess) {
53
- this.postProcessFn = options.postProcess;
54
- }
55
- if (options.name) {
56
- this.name = options.name;
57
- }
58
- }
59
- clearRequestQueue() {
60
- this.requests = [];
61
- }
62
- handleError(error) {
63
- if (error.code === 'ECONNREFUSED') {
64
- console.error(`Connection refused at ${error.address}${error.port ? `:${error.port}` : ''}. ` +
65
- 'Check these values in config.js and ensure that rTorrent is running.');
66
- }
67
- this.clearRequestQueue();
68
- if (this.onCompleteFn) {
69
- this.onCompleteFn(null, error);
70
- }
71
- }
72
- handleSuccess(data) {
73
- let response = data;
74
- this.clearRequestQueue();
75
- if (this.postProcessFn) {
76
- response = this.postProcessFn(data);
77
- }
78
- if (this.onCompleteFn) {
79
- this.onCompleteFn(response);
80
- }
81
- }
82
- onComplete(fn) {
83
- this.onCompleteFn = fn;
84
- }
85
- postProcess(fn) {
86
- this.postProcessFn = fn;
87
- }
88
- send() {
89
- const handleSuccess = this.handleSuccess.bind(this);
90
- const handleError = this.handleError.bind(this);
91
- this.clientRequestManager.methodCall('system.multicall', [this.requests]).then(handleSuccess).catch(handleError);
92
- }
93
- // TODO: Separate these and add support for additional clients.
94
- // rTorrent method calls.
95
- addFiles(options) {
96
- const files = getEnsuredArray(options.files);
97
- const { path: destinationPath, isBasePath, start, tags: tagsArr } = options;
98
- files.forEach((file) => {
99
- let methodCall = 'load.raw_start';
100
- let parameters = ['', file.buffer];
101
- const timeAdded = Math.floor(Date.now() / 1000);
102
- if (destinationPath) {
103
- if (isBasePath) {
104
- parameters.push(`d.directory_base.set="${destinationPath}"`);
105
- }
106
- else {
107
- parameters.push(`d.directory.set="${destinationPath}"`);
108
- }
109
- }
110
- parameters = addTagsToRequest(tagsArr, parameters);
111
- parameters.push(`d.custom.set=x-filename,${file.originalname}`);
112
- parameters.push(`d.custom.set=addtime,${timeAdded}`);
113
- // The start value is a string because it was appended to a FormData
114
- // object.
115
- if (start === 'false') {
116
- methodCall = 'load.raw';
117
- }
118
- this.requests.push(getMethodCall(methodCall, parameters));
119
- });
120
- }
121
- addURLs(options) {
122
- const { path: destinationPath, isBasePath, start, tags: tagsArr } = options;
123
- const urls = getEnsuredArray(options.urls);
124
- urls.forEach((url) => {
125
- let methodCall = 'load.start';
126
- let parameters = ['', url];
127
- const timeAdded = Math.floor(Date.now() / 1000);
128
- if (destinationPath) {
129
- if (isBasePath) {
130
- parameters.push(`d.directory_base.set="${destinationPath}"`);
131
- }
132
- else {
133
- parameters.push(`d.directory.set="${destinationPath}"`);
134
- }
135
- }
136
- parameters = addTagsToRequest(tagsArr, parameters);
137
- parameters.push(`d.custom.set=addtime,${timeAdded}`);
138
- if (!start) {
139
- methodCall = 'load.normal';
140
- }
141
- this.requests.push(getMethodCall(methodCall, parameters));
142
- });
143
- }
144
- checkHash(options) {
145
- const { torrentService } = this.services;
146
- const hashes = getEnsuredArray(options.hashes);
147
- const stoppedHashes = hashes.filter((hash) => torrentService.getTorrent(hash).status.includes(torrentStatusMap_1.default.stopped));
148
- const hashesToStart = [];
149
- this.stopTorrents({ hashes });
150
- hashes.forEach((hash) => {
151
- this.requests.push(getMethodCall('d.check_hash', [hash]));
152
- if (!stoppedHashes.includes(hash)) {
153
- hashesToStart.push(hash);
154
- }
155
- });
156
- if (hashesToStart.length) {
157
- this.startTorrents({ hashes: hashesToStart });
158
- }
159
- }
160
- fetchSettings(options) {
161
- let { requestedSettings } = options;
162
- if (requestedSettings == null) {
163
- requestedSettings = Object.keys(clientSettingsMap_1.clientSettings).map((settingsKey) => clientSettingsMap_1.clientSettingsMap[settingsKey]);
164
- }
165
- // Ensure client's response gets mapped to the correct requested keys.
166
- if (options.setRequestedKeysArr) {
167
- options.setRequestedKeysArr(requestedSettings);
168
- }
169
- requestedSettings.forEach((settingsKey) => {
170
- this.requests.push(getMethodCall(settingsKey));
171
- });
172
- }
173
- getTorrentDetails(options) {
174
- const peerParams = [options.hash, ''].concat(options.peerProps);
175
- const fileParams = [options.hash, ''].concat(options.fileProps);
176
- const trackerParams = [options.hash, ''].concat(options.trackerProps);
177
- this.requests.push(getMethodCall('p.multicall', peerParams));
178
- this.requests.push(getMethodCall('f.multicall', fileParams));
179
- this.requests.push(getMethodCall('t.multicall', trackerParams));
180
- }
181
- getTorrentList(options) {
182
- this.requests.push(getMethodCall('d.multicall2', options.props));
183
- }
184
- getTransferData() {
185
- Object.keys(rTorrentPropMap_1.default.transferData).forEach((key) => {
186
- this.requests.push(getMethodCall(rTorrentPropMap_1.default.transferData[key]));
187
- });
188
- }
189
- listMethods(options) {
190
- const args = getEnsuredArray(options.args);
191
- this.requests.push(getMethodCall(options.method, [args]));
192
- }
193
- moveTorrents(options) {
194
- const { destinationPath } = options;
195
- const filenames = getEnsuredArray(options.filenames);
196
- const sourcePaths = getEnsuredArray(options.sourcePaths);
197
- sourcePaths.forEach((source, index) => {
198
- let callback = () => {
199
- // empty initializer
200
- };
201
- const destination = `${destinationPath}${path_1.default.sep}${filenames[index]}`;
202
- const isLastRequest = index + 1 === sourcePaths.length;
203
- if (isLastRequest) {
204
- callback = this.handleSuccess.bind(this);
205
- }
206
- if (source !== destination) {
207
- mv_1.default(source, destination, { mkdirp: true }, callback);
208
- }
209
- else if (isLastRequest) {
210
- callback();
211
- }
212
- });
213
- }
214
- setDownloadPath(options) {
215
- const hashes = getEnsuredArray(options.hashes);
216
- let pathMethod;
217
- if (options.isBasePath) {
218
- pathMethod = 'd.directory_base.set';
219
- }
220
- else {
221
- pathMethod = 'd.directory.set';
222
- }
223
- hashes.forEach((hash) => {
224
- this.requests.push(getMethodCall(pathMethod, [hash, options.path]));
225
- this.requests.push(getMethodCall('d.open', [hash]));
226
- this.requests.push(getMethodCall('d.close', [hash]));
227
- });
228
- }
229
- setFilePriority(options) {
230
- const fileIndices = getEnsuredArray(options.fileIndices);
231
- const hashes = getEnsuredArray(options.hashes);
232
- hashes.forEach((hash) => {
233
- fileIndices.forEach((fileIndex) => {
234
- this.requests.push(getMethodCall('f.priority.set', [`${hash}:f${fileIndex}`, options.priority]));
235
- });
236
- this.requests.push(getMethodCall('d.update_priorities', [hash]));
237
- });
238
- }
239
- setPriority(options) {
240
- const hashes = getEnsuredArray(options.hashes);
241
- hashes.forEach((hash) => {
242
- this.requests.push(getMethodCall('d.priority.set', [hash, options.priority]));
243
- this.requests.push(getMethodCall('d.update_priorities', [hash]));
244
- });
245
- }
246
- setSettings(options) {
247
- const settings = getEnsuredArray(options.settings);
248
- settings.forEach((setting) => {
249
- this.requests.push(getMethodCall(`${clientSettingsMap_1.clientSettingsMap[setting.id]}.set`, ['', setting.data]));
250
- });
251
- }
252
- setTaxonomy(options) {
253
- const methodName = 'd.custom1.set';
254
- const tags = options.tags
255
- .reduce((memo, currentTag) => {
256
- const tag = encodeURIComponent(currentTag.trim());
257
- if (tag !== '' && memo.indexOf(tag) === -1) {
258
- memo.push(tag);
259
- }
260
- return memo;
261
- }, [])
262
- .join(',');
263
- getEnsuredArray(options.hashes).forEach((hash) => {
264
- this.requests.push(getMethodCall(methodName, [hash, tags]));
265
- });
266
- }
267
- setTracker(options) {
268
- const existingTrackerIndex = 0;
269
- const { tracker } = options;
270
- getEnsuredArray(options.hashes).forEach((hash) => {
271
- // Disable existing tracker
272
- this.requests.push(getMethodCall('t.disable', [`${hash}:t${existingTrackerIndex}`]));
273
- // Insert new tracker
274
- this.requests.push(getMethodCall('d.tracker.insert', [hash, `${existingTrackerIndex}`, tracker]));
275
- // Save full session to apply tracker change
276
- this.requests.push(getMethodCall('d.save_full_session', [hash]));
277
- });
278
- }
279
- setThrottle(options) {
280
- let methodName = 'throttle.global_down.max_rate.set';
281
- if (options.direction === 'upload') {
282
- methodName = 'throttle.global_up.max_rate.set';
283
- }
284
- this.requests.push(getMethodCall(methodName, ['', options.throttle]));
285
- }
286
- startTorrents(options) {
287
- if (!options.hashes) {
288
- console.error("startTorrents requires key 'hashes'.");
289
- return;
290
- }
291
- getEnsuredArray(options.hashes).forEach((hash) => {
292
- this.requests.push(getMethodCall('d.open', [hash]));
293
- this.requests.push(getMethodCall('d.start', [hash]));
294
- });
295
- }
296
- stopTorrents(options) {
297
- if (!options.hashes) {
298
- console.error("stopTorrents requires key 'hashes'.");
299
- return;
300
- }
301
- getEnsuredArray(options.hashes).forEach((hash) => {
302
- this.requests.push(getMethodCall('d.stop', [hash]));
303
- this.requests.push(getMethodCall('d.close', [hash]));
304
- });
305
- }
306
- getSessionPath() {
307
- this.requests.push(getMethodCall('session.path'));
308
- }
309
- }
310
- exports.default = ClientRequest;
@@ -1,65 +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 feedsub_1 = __importDefault(require("feedsub"));
7
- class Feed {
8
- constructor(options) {
9
- this.options = options || {};
10
- this.options.maxItemHistory = options.maxItemHistory || 100;
11
- this.items = [];
12
- if (!options.url) {
13
- console.error('Feed URL must be defined.');
14
- return null;
15
- }
16
- this.reader = new feedsub_1.default(options.url, {
17
- autoStart: true,
18
- emitOnStart: true,
19
- maxHistory: this.options.maxItemHistory,
20
- interval: options.interval ? Number(options.interval) : 15,
21
- forceInterval: true,
22
- readEveryItem: true,
23
- });
24
- this.initReader();
25
- }
26
- modify(options) {
27
- Object.assign(this.options, options);
28
- this.items = [];
29
- this.reader = new feedsub_1.default(options.url, {
30
- autoStart: true,
31
- emitOnStart: true,
32
- maxHistory: this.options.maxItemHistory,
33
- interval: options.interval ? Number(options.interval) : 15,
34
- forceInterval: true,
35
- readEveryItem: true,
36
- });
37
- this.initReader();
38
- }
39
- getItems() {
40
- return this.items;
41
- }
42
- handleFeedItems(items) {
43
- const nextLength = this.items.length + items.length;
44
- if (nextLength >= this.options.maxItemHistory) {
45
- const diff = nextLength - this.options.maxHistory;
46
- this.items = this.items.splice(0, diff);
47
- }
48
- this.items = this.items.concat(items);
49
- this.options.onNewItems({
50
- feed: this.options,
51
- items,
52
- });
53
- }
54
- initReader() {
55
- this.reader.on('items', this.handleFeedItems.bind(this));
56
- this.reader.on('error', (error) => {
57
- console.log('Feed reader error:', error);
58
- });
59
- this.reader.start();
60
- }
61
- stopReader() {
62
- this.reader.stop();
63
- }
64
- }
65
- exports.default = Feed;
@@ -1,44 +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 os_1 = __importDefault(require("os"));
8
- const path_1 = __importDefault(require("path"));
9
- const fileUtil_1 = __importDefault(require("../util/fileUtil"));
10
- const getDirectoryList = (options, callback) => {
11
- const sourcePath = (options.path || '/').replace(/^~/, os_1.default.homedir());
12
- const resolvedPath = fileUtil_1.default.sanitizePath(sourcePath);
13
- if (!fileUtil_1.default.isAllowedPath(resolvedPath)) {
14
- callback(null, fileUtil_1.default.accessDeniedError());
15
- return;
16
- }
17
- try {
18
- const directories = [];
19
- const files = [];
20
- fs_1.default.readdirSync(resolvedPath).forEach((item) => {
21
- const joinedPath = path_1.default.join(resolvedPath, item);
22
- if (fs_1.default.existsSync(joinedPath)) {
23
- if (fs_1.default.statSync(joinedPath).isDirectory()) {
24
- directories.push(item);
25
- }
26
- else {
27
- files.push(item);
28
- }
29
- }
30
- });
31
- const hasParent = /^.{0,}:?(\/|\\){1,1}\S{1,}/.test(resolvedPath);
32
- callback({
33
- directories,
34
- files,
35
- hasParent,
36
- path: resolvedPath,
37
- separator: path_1.default.sep,
38
- });
39
- }
40
- catch (error) {
41
- callback(null, error);
42
- }
43
- };
44
- exports.default = { getDirectoryList };