@jesec/flood 0.0.0-master.fc39f18 → 0.0.0-master.fcbe368

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 (362) hide show
  1. package/CHANGELOG.md +606 -103
  2. package/README.md +134 -44
  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.82f95f742428b2d09013.css +1 -0
  16. package/dist/assets/static/js/179.74639e0b.chunk.js +1 -0
  17. package/dist/assets/static/js/662.dac28d6b.chunk.js +1 -0
  18. package/dist/assets/static/js/770.1f9989ff.chunk.js +1 -0
  19. package/dist/assets/static/js/996.2a53baf2.chunk.js +1 -0
  20. package/dist/assets/static/js/flag0.bb46ec33.chunk.js +1 -0
  21. package/dist/assets/static/js/flag1.f4c50ec9.chunk.js +1 -0
  22. package/dist/assets/static/js/flag2.b587d880.chunk.js +1 -0
  23. package/dist/assets/static/js/flag3.ef97056e.chunk.js +1 -0
  24. package/dist/assets/static/js/i18n0.07675919.chunk.js +1 -0
  25. package/dist/assets/static/js/i18n1.074e2d5a.chunk.js +1 -0
  26. package/dist/assets/static/js/i18n10.b99f7d09.chunk.js +1 -0
  27. package/dist/assets/static/js/i18n11.21c9a2f0.chunk.js +1 -0
  28. package/dist/assets/static/js/i18n12.804cf4da.chunk.js +1 -0
  29. package/dist/assets/static/js/i18n13.7872bf34.chunk.js +1 -0
  30. package/dist/assets/static/js/i18n14.66c9ebe5.chunk.js +1 -0
  31. package/dist/assets/static/js/i18n15.ea4e07d2.chunk.js +1 -0
  32. package/dist/assets/static/js/i18n16.d9309699.chunk.js +1 -0
  33. package/dist/assets/static/js/i18n17.21e9fc81.chunk.js +1 -0
  34. package/dist/assets/static/js/i18n18.63f43563.chunk.js +1 -0
  35. package/dist/assets/static/js/i18n19.63280231.chunk.js +1 -0
  36. package/dist/assets/static/js/i18n2.4ee01236.chunk.js +1 -0
  37. package/dist/assets/static/js/i18n20.c396e01f.chunk.js +1 -0
  38. package/dist/assets/static/js/i18n21.50b78a18.chunk.js +1 -0
  39. package/dist/assets/static/js/i18n22.f4054a1b.chunk.js +1 -0
  40. package/dist/assets/static/js/i18n23.a1cae032.chunk.js +1 -0
  41. package/dist/assets/static/js/i18n24.5b857889.chunk.js +1 -0
  42. package/dist/assets/static/js/i18n25.6b36bde1.chunk.js +1 -0
  43. package/dist/assets/static/js/i18n26.72ddc962.chunk.js +1 -0
  44. package/dist/assets/static/js/i18n27.f9276181.chunk.js +1 -0
  45. package/dist/assets/static/js/i18n28.950e91ff.chunk.js +1 -0
  46. package/dist/assets/static/js/i18n3.da232d77.chunk.js +1 -0
  47. package/dist/assets/static/js/i18n4.e88e49ab.chunk.js +1 -0
  48. package/dist/assets/static/js/i18n5.e2d59d0d.chunk.js +1 -0
  49. package/dist/assets/static/js/i18n6.483bf024.chunk.js +1 -0
  50. package/dist/assets/static/js/i18n8.434e060c.chunk.js +1 -0
  51. package/dist/assets/static/js/i18n9.193030d4.chunk.js +1 -0
  52. package/dist/assets/static/js/main.5708d913.js +1 -0
  53. package/dist/index.js +131278 -0
  54. package/package.json +212 -132
  55. package/config.js +0 -173
  56. package/dist/assets/android-chrome-192x192.png +0 -0
  57. package/dist/assets/android-chrome-512x512.png +0 -0
  58. package/dist/assets/apple-touch-icon.png +0 -0
  59. package/dist/assets/asset-manifest.json +0 -229
  60. package/dist/assets/browserconfig.xml +0 -9
  61. package/dist/assets/favicon-16x16.png +0 -0
  62. package/dist/assets/favicon-32x32.png +0 -0
  63. package/dist/assets/mstile-144x144.png +0 -0
  64. package/dist/assets/mstile-150x150.png +0 -0
  65. package/dist/assets/mstile-310x150.png +0 -0
  66. package/dist/assets/mstile-310x310.png +0 -0
  67. package/dist/assets/mstile-70x70.png +0 -0
  68. package/dist/assets/static/js/main.537275cb.js +0 -339
  69. package/dist/assets/static/media/ABOUT.d02918c9.md +0 -13
  70. package/dist/assets/static/media/Roboto-500.64e69384.woff +0 -0
  71. package/dist/assets/static/media/Roboto-500.7f8f0146.eot +0 -0
  72. package/dist/assets/static/media/Roboto-500.916656a2.ttf +0 -0
  73. package/dist/assets/static/media/Roboto-500.abd255e8.svg +0 -305
  74. package/dist/assets/static/media/Roboto-700.8d11d1e1.ttf +0 -0
  75. package/dist/assets/static/media/Roboto-700.9c9c164e.svg +0 -310
  76. package/dist/assets/static/media/Roboto-700.c65552c8.eot +0 -0
  77. package/dist/assets/static/media/Roboto-700.ee82bda2.woff +0 -0
  78. package/dist/assets/static/media/Roboto-700italic.1dc5bfed.eot +0 -0
  79. package/dist/assets/static/media/Roboto-700italic.686da014.woff +0 -0
  80. package/dist/assets/static/media/Roboto-700italic.896656dc.ttf +0 -0
  81. package/dist/assets/static/media/Roboto-700italic.cacb9681.svg +0 -325
  82. package/dist/assets/static/media/Roboto-italic.09ed2f27.svg +0 -323
  83. package/dist/assets/static/media/Roboto-italic.c1421604.woff +0 -0
  84. package/dist/assets/static/media/Roboto-italic.c38ecad2.ttf +0 -0
  85. package/dist/assets/static/media/Roboto-italic.f7677a07.eot +0 -0
  86. package/dist/assets/static/media/Roboto-regular.5107f918.eot +0 -0
  87. package/dist/assets/static/media/Roboto-regular.6a307cf2.woff +0 -0
  88. package/dist/assets/static/media/Roboto-regular.81dc9b21.ttf +0 -0
  89. package/dist/assets/static/media/Roboto-regular.bcf2ba9e.svg +0 -308
  90. package/run/db/README.md +0 -3
  91. package/run/temp/README.md +0 -3
  92. package/server/.eslintrc.js +0 -15
  93. package/server/app.js +0 -88
  94. package/server/bin/enforce-prerequisites.js +0 -63
  95. package/server/bin/migrations/fix-is-admin-flag.js +0 -49
  96. package/server/bin/migrations/per-user-rtorrent-instances.js +0 -76
  97. package/server/bin/migrations/run.js +0 -8
  98. package/server/bin/start.js +0 -16
  99. package/server/bin/web-server.js +0 -98
  100. package/server/config/passport.js +0 -36
  101. package/server/constants/clientGatewayServiceEvents.js +0 -12
  102. package/server/constants/diskUsageServiceEvents.js +0 -5
  103. package/server/constants/fileListPropMap.js +0 -34
  104. package/server/constants/historyServiceEvents.js +0 -17
  105. package/server/constants/notificationServiceEvents.js +0 -5
  106. package/server/constants/taxonomyServiceEvents.js +0 -5
  107. package/server/constants/torrentListPropMap.js +0 -247
  108. package/server/constants/torrentServiceEvents.js +0 -5
  109. package/server/constants/transferSummaryPropMap.js +0 -33
  110. package/server/middleware/appendUserServices.js +0 -6
  111. package/server/middleware/booleanCoerce.js +0 -9
  112. package/server/middleware/clientActivityStream.js +0 -150
  113. package/server/middleware/eventStream.js +0 -27
  114. package/server/middleware/requireAdmin.js +0 -6
  115. package/server/models/ClientRequest.js +0 -389
  116. package/server/models/Feed.js +0 -74
  117. package/server/models/Filesystem.js +0 -45
  118. package/server/models/HistoryEra.js +0 -205
  119. package/server/models/ServerEvent.js +0 -32
  120. package/server/models/TemporaryStorage.js +0 -20
  121. package/server/models/Users.js +0 -188
  122. package/server/models/client.js +0 -435
  123. package/server/models/settings.js +0 -138
  124. package/server/routes/api.js +0 -86
  125. package/server/routes/auth.js +0 -213
  126. package/server/routes/client.js +0 -120
  127. package/server/services/BaseService.js +0 -22
  128. package/server/services/clientGatewayService.js +0 -265
  129. package/server/services/clientRequestManager.js +0 -83
  130. package/server/services/diskUsageService.js +0 -155
  131. package/server/services/feedService.js +0 -363
  132. package/server/services/historyService.js +0 -212
  133. package/server/services/index.js +0 -127
  134. package/server/services/notificationService.js +0 -125
  135. package/server/services/taxonomyService.js +0 -133
  136. package/server/services/torrentService.js +0 -283
  137. package/server/util/ajaxUtil.js +0 -21
  138. package/server/util/clientResponseUtil.js +0 -127
  139. package/server/util/fileUtil.js +0 -47
  140. package/server/util/mediainfo.js +0 -38
  141. package/server/util/methodCallUtil.js +0 -28
  142. package/server/util/minifyUtil.js +0 -0
  143. package/server/util/numberUtils.js +0 -6
  144. package/server/util/rTorrentDeserializer.js +0 -109
  145. package/server/util/rTorrentPropMap.js +0 -12
  146. package/server/util/scgiUtil.js +0 -43
  147. package/server/util/torrentFileUtil.js +0 -24
  148. package/server/views/error.pug +0 -6
  149. package/server/views/layout.pug +0 -6
  150. package/shared/config/paths.js +0 -30
  151. package/shared/constants/clientSettingsMap.js +0 -101
  152. package/shared/constants/diffActionTypes.js +0 -7
  153. package/shared/constants/historySnapshotTypes.js +0 -12
  154. package/shared/constants/serverEventTypes.js +0 -19
  155. package/shared/constants/torrentFilePropsMap.js +0 -6
  156. package/shared/constants/torrentPeerPropsMap.js +0 -32
  157. package/shared/constants/torrentStatusMap.js +0 -19
  158. package/shared/constants/torrentTrackerPropsMap.js +0 -6
  159. package/shared/util/formatUtil.js +0 -71
  160. package/shared/util/objectUtil.js +0 -72
  161. package/shared/util/regEx.js +0 -7
  162. package/shared/util/stringUtil.js +0 -16
  163. /package/dist/assets/{safari-pinned-tab.svg → icon.svg} +0 -0
  164. /package/dist/assets/static/{images/flags/ad.png → media/ad.1b24595d.png} +0 -0
  165. /package/dist/assets/static/{images/flags/ae.png → media/ae.4dd8f55e.png} +0 -0
  166. /package/dist/assets/static/{images/flags/af.png → media/af.4ce660eb.png} +0 -0
  167. /package/dist/assets/static/{images/flags/ag.png → media/ag.fd9409e4.png} +0 -0
  168. /package/dist/assets/static/{images/flags/al.png → media/al.a297aacf.png} +0 -0
  169. /package/dist/assets/static/{images/flags/am.png → media/am.c84ee0cf.png} +0 -0
  170. /package/dist/assets/static/{images/flags/ao.png → media/ao.a7c9214e.png} +0 -0
  171. /package/dist/assets/static/{images/flags/ar.png → media/ar.7e57ef92.png} +0 -0
  172. /package/dist/assets/static/{images/flags/at.png → media/at.5aa9728a.png} +0 -0
  173. /package/dist/assets/static/{images/flags/au.png → media/au.155b51d8.png} +0 -0
  174. /package/dist/assets/static/{images/flags/az.png → media/az.63afef5b.png} +0 -0
  175. /package/dist/assets/static/{images/flags/ba.png → media/ba.5ce8f273.png} +0 -0
  176. /package/dist/assets/static/{images/flags/bb.png → media/bb.f369fc62.png} +0 -0
  177. /package/dist/assets/static/{images/flags/bd.png → media/bd.516278fc.png} +0 -0
  178. /package/dist/assets/static/{images/flags/be.png → media/be.08ec4a8d.png} +0 -0
  179. /package/dist/assets/static/{images/flags/bf.png → media/bf.50bfcb31.png} +0 -0
  180. /package/dist/assets/static/{images/flags/bg.png → media/bg.d9346b96.png} +0 -0
  181. /package/dist/assets/static/{images/flags/bh.png → media/bh.f06d5914.png} +0 -0
  182. /package/dist/assets/static/{images/flags/bi.png → media/bi.4923e3a3.png} +0 -0
  183. /package/dist/assets/static/{images/flags/bj.png → media/bj.019fa79b.png} +0 -0
  184. /package/dist/assets/static/{images/flags/bn.png → media/bn.077671e2.png} +0 -0
  185. /package/dist/assets/static/{images/flags/bo.png → media/bo.8fb15fc6.png} +0 -0
  186. /package/dist/assets/static/{images/flags/br.png → media/br.ec051f0c.png} +0 -0
  187. /package/dist/assets/static/{images/flags/bs.png → media/bs.a74a126f.png} +0 -0
  188. /package/dist/assets/static/{images/flags/bt.png → media/bt.4217b804.png} +0 -0
  189. /package/dist/assets/static/{images/flags/bw.png → media/bw.21fe1567.png} +0 -0
  190. /package/dist/assets/static/{images/flags/by.png → media/by.d247fe16.png} +0 -0
  191. /package/dist/assets/static/{images/flags/bz.png → media/bz.98ec59f6.png} +0 -0
  192. /package/dist/assets/static/{images/flags/ca.png → media/ca.25743e11.png} +0 -0
  193. /package/dist/assets/static/{images/flags/cd.png → media/cd.a5bfda53.png} +0 -0
  194. /package/dist/assets/static/{images/flags/cf.png → media/cf.de7d5d92.png} +0 -0
  195. /package/dist/assets/static/{images/flags/cg.png → media/cg.a47b626b.png} +0 -0
  196. /package/dist/assets/static/{images/flags/ch.png → media/ch.445f47a1.png} +0 -0
  197. /package/dist/assets/static/{images/flags/ci.png → media/ci.a6009c5b.png} +0 -0
  198. /package/dist/assets/static/{images/flags/cl.png → media/cl.de1d715e.png} +0 -0
  199. /package/dist/assets/static/{images/flags/cm.png → media/cm.3ce8a86a.png} +0 -0
  200. /package/dist/assets/static/{images/flags/cn.png → media/cn.e6a26073.png} +0 -0
  201. /package/dist/assets/static/{images/flags/co.png → media/co.e9244faa.png} +0 -0
  202. /package/dist/assets/static/{images/flags/cr.png → media/cr.c895e035.png} +0 -0
  203. /package/dist/assets/static/{images/flags/cu.png → media/cu.e486c055.png} +0 -0
  204. /package/dist/assets/static/{images/flags/cv.png → media/cv.a9585acf.png} +0 -0
  205. /package/dist/assets/static/{images/flags/cw.png → media/cw.df13039d.png} +0 -0
  206. /package/dist/assets/static/{images/flags/cy.png → media/cy.b31f43a9.png} +0 -0
  207. /package/dist/assets/static/{images/flags/cz.png → media/cz.8ec5948b.png} +0 -0
  208. /package/dist/assets/static/{images/flags/de.png → media/de.d12f391a.png} +0 -0
  209. /package/dist/assets/static/{images/flags/dj.png → media/dj.154c3580.png} +0 -0
  210. /package/dist/assets/static/{images/flags/dk.png → media/dk.da382fe2.png} +0 -0
  211. /package/dist/assets/static/{images/flags/dm.png → media/dm.f452e6cd.png} +0 -0
  212. /package/dist/assets/static/{images/flags/do.png → media/do.c6bd7637.png} +0 -0
  213. /package/dist/assets/static/{images/flags/dz.png → media/dz.672a69c0.png} +0 -0
  214. /package/dist/assets/static/{images/flags/ec.png → media/ec.349d9bd7.png} +0 -0
  215. /package/dist/assets/static/{images/flags/ee.png → media/ee.2396205f.png} +0 -0
  216. /package/dist/assets/static/{images/flags/eg.png → media/eg.ccbf3f45.png} +0 -0
  217. /package/dist/assets/static/{images/flags/eh.png → media/eh.af65674a.png} +0 -0
  218. /package/dist/assets/static/{images/flags/er.png → media/er.21afb638.png} +0 -0
  219. /package/dist/assets/static/{images/flags/es.png → media/es.2a6eaee4.png} +0 -0
  220. /package/dist/assets/static/{images/flags/et.png → media/et.8beb65c8.png} +0 -0
  221. /package/dist/assets/static/{images/flags/fi.png → media/fi.331f70fd.png} +0 -0
  222. /package/dist/assets/static/{images/flags/fj.png → media/fj.7724d800.png} +0 -0
  223. /package/dist/assets/static/{images/flags/fm.png → media/fm.eeaf71e9.png} +0 -0
  224. /package/dist/assets/static/{images/flags/fr.png → media/fr.5d5ab008.png} +0 -0
  225. /package/dist/assets/static/{images/flags/ga.png → media/ga.77ed474c.png} +0 -0
  226. /package/dist/assets/static/{images/flags/gb.png → media/gb.e00065bf.png} +0 -0
  227. /package/dist/assets/static/{images/flags/gd.png → media/gd.b4522267.png} +0 -0
  228. /package/dist/assets/static/{images/flags/ge.png → media/ge.91a7654d.png} +0 -0
  229. /package/dist/assets/static/{images/flags/gh.png → media/gh.4759f92f.png} +0 -0
  230. /package/dist/assets/static/{images/flags/gm.png → media/gm.81cd9f75.png} +0 -0
  231. /package/dist/assets/static/{images/flags/gn.png → media/gn.9f3d376e.png} +0 -0
  232. /package/dist/assets/static/{images/flags/gq.png → media/gq.e8ad58be.png} +0 -0
  233. /package/dist/assets/static/{images/flags/gr.png → media/gr.26f3ac0b.png} +0 -0
  234. /package/dist/assets/static/{images/flags/gt.png → media/gt.9d81c52e.png} +0 -0
  235. /package/dist/assets/static/{images/flags/gw.png → media/gw.dc906982.png} +0 -0
  236. /package/dist/assets/static/{images/flags/gy.png → media/gy.a4f62b6c.png} +0 -0
  237. /package/dist/assets/static/{images/flags/hk.png → media/hk.56555c3f.png} +0 -0
  238. /package/dist/assets/static/{images/flags/hn.png → media/hn.64ee6aad.png} +0 -0
  239. /package/dist/assets/static/{images/flags/hr.png → media/hr.93ebecd3.png} +0 -0
  240. /package/dist/assets/static/{images/flags/ht.png → media/ht.42ca1596.png} +0 -0
  241. /package/dist/assets/static/{images/flags/hu.png → media/hu.bb30f05d.png} +0 -0
  242. /package/dist/assets/static/{images/flags/id.png → media/id.2cb49f2d.png} +0 -0
  243. /package/dist/assets/static/{images/flags/ie.png → media/ie.b4dd1f19.png} +0 -0
  244. /package/dist/assets/static/{images/flags/il.png → media/il.cd1d1faf.png} +0 -0
  245. /package/dist/assets/static/{images/flags/in.png → media/in.2df03847.png} +0 -0
  246. /package/dist/assets/static/{images/flags/iq.png → media/iq.a9b670ab.png} +0 -0
  247. /package/dist/assets/static/{images/flags/ir.png → media/ir.9a3de085.png} +0 -0
  248. /package/dist/assets/static/{images/flags/is.png → media/is.d88f4fc9.png} +0 -0
  249. /package/dist/assets/static/{images/flags/it.png → media/it.b73713e3.png} +0 -0
  250. /package/dist/assets/static/{images/flags/je.png → media/je.0353f56a.png} +0 -0
  251. /package/dist/assets/static/{images/flags/jm.png → media/jm.20330ef4.png} +0 -0
  252. /package/dist/assets/static/{images/flags/jo.png → media/jo.eb66f1d1.png} +0 -0
  253. /package/dist/assets/static/{images/flags/jp.png → media/jp.63e382ae.png} +0 -0
  254. /package/dist/assets/static/{images/flags/ke.png → media/ke.ab2e43b8.png} +0 -0
  255. /package/dist/assets/static/{images/flags/kg.png → media/kg.2c47c2af.png} +0 -0
  256. /package/dist/assets/static/{images/flags/kh.png → media/kh.4732c810.png} +0 -0
  257. /package/dist/assets/static/{images/flags/ki.png → media/ki.5fba09fd.png} +0 -0
  258. /package/dist/assets/static/{images/flags/km.png → media/km.7bbed3e9.png} +0 -0
  259. /package/dist/assets/static/{images/flags/kn.png → media/kn.a9595a16.png} +0 -0
  260. /package/dist/assets/static/{images/flags/kp.png → media/kp.8a4dc30a.png} +0 -0
  261. /package/dist/assets/static/{images/flags/kr.png → media/kr.5273be1d.png} +0 -0
  262. /package/dist/assets/static/{images/flags/ks.png → media/ks.99f78645.png} +0 -0
  263. /package/dist/assets/static/{images/flags/kw.png → media/kw.af3521bc.png} +0 -0
  264. /package/dist/assets/static/{images/flags/kz.png → media/kz.ea47ef79.png} +0 -0
  265. /package/dist/assets/static/{images/flags/la.png → media/la.78a598d7.png} +0 -0
  266. /package/dist/assets/static/{images/flags/lb.png → media/lb.7a7c15a9.png} +0 -0
  267. /package/dist/assets/static/{images/flags/lc.png → media/lc.6083a4ff.png} +0 -0
  268. /package/dist/assets/static/{images/flags/li.png → media/li.61c564a4.png} +0 -0
  269. /package/dist/assets/static/{images/flags/lk.png → media/lk.6fa85802.png} +0 -0
  270. /package/dist/assets/static/{images/flags/lr.png → media/lr.8063f7db.png} +0 -0
  271. /package/dist/assets/static/{images/flags/ls.png → media/ls.901ddb71.png} +0 -0
  272. /package/dist/assets/static/{images/flags/lt.png → media/lt.9209ace3.png} +0 -0
  273. /package/dist/assets/static/{images/flags/lu.png → media/lu.c9872bc1.png} +0 -0
  274. /package/dist/assets/static/{images/flags/lv.png → media/lv.7bcacf0a.png} +0 -0
  275. /package/dist/assets/static/{images/flags/ly.png → media/ly.2830aa63.png} +0 -0
  276. /package/dist/assets/static/{images/flags/ma.png → media/ma.ce5f697b.png} +0 -0
  277. /package/dist/assets/static/{images/flags/mc.png → media/mc.4bd5d57a.png} +0 -0
  278. /package/dist/assets/static/{images/flags/md.png → media/md.fb4b5bdf.png} +0 -0
  279. /package/dist/assets/static/{images/flags/me.png → media/me.1f1d1772.png} +0 -0
  280. /package/dist/assets/static/{images/flags/mg.png → media/mg.89101bd2.png} +0 -0
  281. /package/dist/assets/static/{images/flags/mh.png → media/mh.ff11dff7.png} +0 -0
  282. /package/dist/assets/static/{images/flags/mk.png → media/mk.8420e604.png} +0 -0
  283. /package/dist/assets/static/{images/flags/ml.png → media/ml.4db47c66.png} +0 -0
  284. /package/dist/assets/static/{images/flags/mm.png → media/mm.8e4ac30a.png} +0 -0
  285. /package/dist/assets/static/{images/flags/mn.png → media/mn.dc1daa04.png} +0 -0
  286. /package/dist/assets/static/{images/flags/mr.png → media/mr.7cbca6d0.png} +0 -0
  287. /package/dist/assets/static/{images/flags/mt.png → media/mt.28a4b863.png} +0 -0
  288. /package/dist/assets/static/{images/flags/mu.png → media/mu.d93db6c7.png} +0 -0
  289. /package/dist/assets/static/{images/flags/mv.png → media/mv.7d026bf1.png} +0 -0
  290. /package/dist/assets/static/{images/flags/mw.png → media/mw.960cd4fb.png} +0 -0
  291. /package/dist/assets/static/{images/flags/mx.png → media/mx.39b78eb2.png} +0 -0
  292. /package/dist/assets/static/{images/flags/my.png → media/my.916a8392.png} +0 -0
  293. /package/dist/assets/static/{images/flags/mz.png → media/mz.facb4ea3.png} +0 -0
  294. /package/dist/assets/static/{images/flags/na.png → media/na.472666a9.png} +0 -0
  295. /package/dist/assets/static/{images/flags/ne.png → media/ne.d774701f.png} +0 -0
  296. /package/dist/assets/static/{images/flags/ng.png → media/ng.7b06a49f.png} +0 -0
  297. /package/dist/assets/static/{images/flags/ni.png → media/ni.7140131c.png} +0 -0
  298. /package/dist/assets/static/{images/flags/nl.png → media/nl.4c04aa96.png} +0 -0
  299. /package/dist/assets/static/{images/flags/no.png → media/no.c19eb00d.png} +0 -0
  300. /package/dist/assets/static/{images/flags/np.png → media/np.54fb4f2f.png} +0 -0
  301. /package/dist/assets/static/{images/flags/nr.png → media/nr.7527cc38.png} +0 -0
  302. /package/dist/assets/static/{images/flags/nz.png → media/nz.738be05b.png} +0 -0
  303. /package/dist/assets/static/{images/flags/om.png → media/om.b25e0a17.png} +0 -0
  304. /package/dist/assets/static/{images/flags/pa.png → media/pa.b28a9059.png} +0 -0
  305. /package/dist/assets/static/{images/flags/pe.png → media/pe.c1fc1d96.png} +0 -0
  306. /package/dist/assets/static/{images/flags/pg.png → media/pg.380115db.png} +0 -0
  307. /package/dist/assets/static/{images/flags/ph.png → media/ph.02199ddc.png} +0 -0
  308. /package/dist/assets/static/{images/flags/pk.png → media/pk.094f9517.png} +0 -0
  309. /package/dist/assets/static/{images/flags/pl.png → media/pl.41521283.png} +0 -0
  310. /package/dist/assets/static/{images/flags/pt.png → media/pt.1f82dc04.png} +0 -0
  311. /package/dist/assets/static/{images/flags/pw.png → media/pw.a26c2316.png} +0 -0
  312. /package/dist/assets/static/{images/flags/py.png → media/py.926c65ed.png} +0 -0
  313. /package/dist/assets/static/{images/flags/qa.png → media/qa.c6a3c20e.png} +0 -0
  314. /package/dist/assets/static/{images/flags/ro.png → media/ro.a36876c9.png} +0 -0
  315. /package/dist/assets/static/{images/flags/rs.png → media/rs.c6629de8.png} +0 -0
  316. /package/dist/assets/static/{images/flags/ru.png → media/ru.a9b948c1.png} +0 -0
  317. /package/dist/assets/static/{images/flags/rw.png → media/rw.e8aecba0.png} +0 -0
  318. /package/dist/assets/static/{images/flags/sa.png → media/sa.859049c8.png} +0 -0
  319. /package/dist/assets/static/{images/flags/sb.png → media/sb.4ad27b27.png} +0 -0
  320. /package/dist/assets/static/{images/flags/sc.png → media/sc.3293efde.png} +0 -0
  321. /package/dist/assets/static/{images/flags/sd.png → media/sd.19c94faa.png} +0 -0
  322. /package/dist/assets/static/{images/flags/se.png → media/se.195b3f93.png} +0 -0
  323. /package/dist/assets/static/{images/flags/sg.png → media/sg.19d81907.png} +0 -0
  324. /package/dist/assets/static/{images/flags/si.png → media/si.367c5443.png} +0 -0
  325. /package/dist/assets/static/{images/flags/sk.png → media/sk.4e5b8a39.png} +0 -0
  326. /package/dist/assets/static/{images/flags/sl.png → media/sl.4b174b1c.png} +0 -0
  327. /package/dist/assets/static/{images/flags/sm.png → media/sm.2cba3dac.png} +0 -0
  328. /package/dist/assets/static/{images/flags/sn.png → media/sn.a4c1041d.png} +0 -0
  329. /package/dist/assets/static/{images/flags/so.png → media/so.b455e3bf.png} +0 -0
  330. /package/dist/assets/static/{images/flags/sr.png → media/sr.5adc1c00.png} +0 -0
  331. /package/dist/assets/static/{images/flags/st.png → media/st.5ae44155.png} +0 -0
  332. /package/dist/assets/static/{images/flags/sv.png → media/sv.43aa6cdf.png} +0 -0
  333. /package/dist/assets/static/{images/flags/sy.png → media/sy.0fbd24f7.png} +0 -0
  334. /package/dist/assets/static/{images/flags/sz.png → media/sz.ff204912.png} +0 -0
  335. /package/dist/assets/static/{images/flags/td.png → media/td.c7aa2a4e.png} +0 -0
  336. /package/dist/assets/static/{images/flags/tg.png → media/tg.857c3bec.png} +0 -0
  337. /package/dist/assets/static/{images/flags/th.png → media/th.683600c7.png} +0 -0
  338. /package/dist/assets/static/{images/flags/tj.png → media/tj.d20c5570.png} +0 -0
  339. /package/dist/assets/static/{images/flags/tl.png → media/tl.5edd8ea7.png} +0 -0
  340. /package/dist/assets/static/{images/flags/tm.png → media/tm.15960215.png} +0 -0
  341. /package/dist/assets/static/{images/flags/tn.png → media/tn.40df718e.png} +0 -0
  342. /package/dist/assets/static/{images/flags/to.png → media/to.c3b054df.png} +0 -0
  343. /package/dist/assets/static/{images/flags/tr.png → media/tr.adeace6d.png} +0 -0
  344. /package/dist/assets/static/{images/flags/tt.png → media/tt.839bd7f1.png} +0 -0
  345. /package/dist/assets/static/{images/flags/tv.png → media/tv.628cae3e.png} +0 -0
  346. /package/dist/assets/static/{images/flags/tw.png → media/tw.4e885914.png} +0 -0
  347. /package/dist/assets/static/{images/flags/tz.png → media/tz.b2f0dc37.png} +0 -0
  348. /package/dist/assets/static/{images/flags/ua.png → media/ua.6b103313.png} +0 -0
  349. /package/dist/assets/static/{images/flags/ug.png → media/ug.c84042fc.png} +0 -0
  350. /package/dist/assets/static/{images/flags/us.png → media/us.8523c31d.png} +0 -0
  351. /package/dist/assets/static/{images/flags/uy.png → media/uy.a943f85e.png} +0 -0
  352. /package/dist/assets/static/{images/flags/uz.png → media/uz.25552673.png} +0 -0
  353. /package/dist/assets/static/{images/flags/va.png → media/va.a29e1b53.png} +0 -0
  354. /package/dist/assets/static/{images/flags/vc.png → media/vc.7480bd37.png} +0 -0
  355. /package/dist/assets/static/{images/flags/ve.png → media/ve.fd4273c2.png} +0 -0
  356. /package/dist/assets/static/{images/flags/vn.png → media/vn.7d2eff1b.png} +0 -0
  357. /package/dist/assets/static/{images/flags/vu.png → media/vu.48b64cf3.png} +0 -0
  358. /package/dist/assets/static/{images/flags/ws.png → media/ws.f3d9202f.png} +0 -0
  359. /package/dist/assets/static/{images/flags/ye.png → media/ye.311a0e50.png} +0 -0
  360. /package/dist/assets/static/{images/flags/za.png → media/za.090a856f.png} +0 -0
  361. /package/dist/assets/static/{images/flags/zm.png → media/zm.8371e197.png} +0 -0
  362. /package/dist/assets/static/{images/flags/zw.png → media/zw.a6809447.png} +0 -0
@@ -1,76 +0,0 @@
1
- const chalk = require('chalk');
2
- const config = require('../../../config');
3
- const Users = require('../../models/Users');
4
-
5
- const log = (data) => {
6
- if (process.env.DEBUG) {
7
- console.log(data);
8
- }
9
- };
10
-
11
- const migrate = () => {
12
- log(chalk.green('Migrating data: moving rTorrent connection information to users database'));
13
-
14
- return new Promise((migrateResolve, migrateReject) => {
15
- Users.listUsers((users, listUsersError) => {
16
- if (listUsersError) return migrateReject(listUsersError);
17
- const {scgi = {}} = config;
18
- const existingConfig = {
19
- host: scgi.host,
20
- port: scgi.port,
21
- socketPath: scgi.socketPath,
22
- };
23
-
24
- migrateResolve(
25
- Promise.all(
26
- users.map((user) => {
27
- let userPatch = null;
28
-
29
- // A bug in this script caused all of these xmlrpc values to be defined in the user db.
30
- // If they are all defined, set all to null to prompt the user to provide new connection
31
- // details.
32
- if (user.host != null && user.port != null && user.socketPath != null) {
33
- userPatch = {
34
- host: null,
35
- port: null,
36
- socketPath: null,
37
- };
38
- }
39
-
40
- // If none of the xmlrpc fields are on the user object, try to infer this from the legacy
41
- // configuration file.
42
- if (user.host == null && user.port == null && user.socketPath == null) {
43
- userPatch = {isAdmin: true};
44
-
45
- if (existingConfig.socketPath && existingConfig.socketPath.trim().length > 0) {
46
- userPatch.socketPath = existingConfig.socketPath;
47
- } else {
48
- userPatch.host = existingConfig.host;
49
- userPatch.port = existingConfig.port;
50
- }
51
- }
52
-
53
- if (userPatch != null) {
54
- log(chalk.yellow(`Migrating user ${user.username}`));
55
-
56
- return new Promise((updateUserResolve, updateUserReject) => {
57
- Users.updateUser(user.username, userPatch, (response, updateUserError) => {
58
- if (updateUserError) {
59
- updateUserReject(updateUserError);
60
- return;
61
- }
62
-
63
- updateUserResolve(response);
64
- });
65
- });
66
- }
67
-
68
- return Promise.resolve();
69
- }),
70
- ),
71
- );
72
- });
73
- });
74
- };
75
-
76
- module.exports = migrate;
@@ -1,8 +0,0 @@
1
- const perUserRtorrentInstances = require('./per-user-rtorrent-instances');
2
- const fixIsAdminFlag = require('./fix-is-admin-flag');
3
-
4
- const migrations = [perUserRtorrentInstances, fixIsAdminFlag];
5
-
6
- const migrate = () => Promise.all(migrations.map((migration) => migration()));
7
-
8
- module.exports = migrate;
@@ -1,16 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- const chalk = require('chalk');
4
-
5
- const enforcePrerequisites = require('./enforce-prerequisites');
6
- const migrateData = require('./migrations/run');
7
- const {startWebServer} = require('./web-server');
8
-
9
- enforcePrerequisites()
10
- .then(migrateData)
11
- .then(startWebServer)
12
- .catch((error) => {
13
- console.log(chalk.red('Failed to start Flood:'));
14
- console.trace(error);
15
- process.exit(1);
16
- });
@@ -1,98 +0,0 @@
1
- const chalk = require('chalk');
2
- const debug = require('debug')('flood:server');
3
- const fs = require('fs');
4
- const http = require('http');
5
- const spdy = require('spdy');
6
-
7
- const app = require('../app');
8
- const config = require('../../config');
9
-
10
- // Normalize a port into a number, string, or false.
11
- const normalizePort = (val) => {
12
- const port = parseInt(val, 10);
13
-
14
- // Named pipe.
15
- if (Number.isNaN(port)) {
16
- return val;
17
- }
18
-
19
- // Port number.
20
- if (port >= 0) {
21
- return port;
22
- }
23
-
24
- return false;
25
- };
26
-
27
- const startWebServer = () => {
28
- const port = normalizePort(config.floodServerPort);
29
- const host = config.floodServerHost;
30
- const useSSL = config.ssl;
31
-
32
- app.set('port', port);
33
- app.set('host', host);
34
-
35
- // Create HTTP or HTTPS server.
36
- let server;
37
-
38
- if (useSSL) {
39
- if (!config.sslKey || !config.sslCert) {
40
- console.error('Cannot start HTTPS server, `sslKey` or `sslCert` is missing in config.js.');
41
- process.exit(1);
42
- }
43
-
44
- server = spdy.createServer(
45
- {
46
- key: fs.readFileSync(config.sslKey),
47
- cert: fs.readFileSync(config.sslCert),
48
- },
49
- app,
50
- );
51
- } else {
52
- server = http.createServer(app);
53
- }
54
-
55
- const handleError = (error) => {
56
- if (error.syscall !== 'listen') {
57
- throw error;
58
- }
59
-
60
- const bind = typeof port === 'string' ? `Pipe ${port}` : `Port ${port}`;
61
-
62
- // Handle specific listen errors with friendly messages.
63
- switch (error.code) {
64
- case 'EACCES':
65
- console.error(`${bind} requires elevated privileges`);
66
- process.exit(1);
67
- break;
68
- case 'EADDRINUSE':
69
- console.error(`${bind} is already in use`);
70
- process.exit(1);
71
- break;
72
- default:
73
- throw error;
74
- }
75
- };
76
-
77
- // Event listener for HTTP server "listening" event.
78
- const handleListening = () => {
79
- const addr = server.address();
80
- const bind = typeof addr === 'string' ? `pipe ${addr}` : `port ${addr.port}`;
81
- debug(`Listening on ${bind}`);
82
- };
83
-
84
- // Listen on provided port, on all network interfaces.
85
- server.listen(port, host);
86
- server.on('error', handleError);
87
- server.on('listening', handleListening);
88
-
89
- const address = chalk.underline(`${useSSL ? 'https' : 'http'}://${host}:${port}`);
90
-
91
- console.log(chalk.green(`Flood server starting on ${address}.\n`));
92
-
93
- if (config.disableUsersAndAuth) {
94
- console.log(chalk.yellow('Starting without builtin authentication\n'));
95
- }
96
- };
97
-
98
- module.exports = {startWebServer};
@@ -1,36 +0,0 @@
1
- const JwtStrategy = require('passport-jwt').Strategy;
2
-
3
- const config = require('../../config');
4
- const Users = require('../models/Users');
5
-
6
- // Setup work and export for the JWT passport strategy.
7
- module.exports = (passport) => {
8
- const options = {
9
- jwtFromRequest: (req) => {
10
- let token = null;
11
-
12
- if (req && req.cookies) {
13
- token = req.cookies.jwt;
14
- }
15
-
16
- return token;
17
- },
18
- secretOrKey: config.secret,
19
- };
20
-
21
- passport.use(
22
- new JwtStrategy(options, (jwtPayload, callback) => {
23
- Users.lookupUser({username: jwtPayload.username}, (err, user) => {
24
- if (err) {
25
- return callback(err, false);
26
- }
27
-
28
- if (user) {
29
- return callback(null, user);
30
- }
31
-
32
- return callback(null, false);
33
- });
34
- }),
35
- );
36
- };
@@ -1,12 +0,0 @@
1
- const objectUtil = require('../../shared/util/objectUtil');
2
-
3
- const clientGatewayServiceEvents = [
4
- 'CLIENT_CONNECTION_STATE_CHANGE',
5
- 'PROCESS_TORRENT',
6
- 'PROCESS_TORRENT_LIST_END',
7
- 'PROCESS_TORRENT_LIST_START',
8
- 'PROCESS_TRANSFER_RATE_START',
9
- 'TORRENTS_REMOVED',
10
- ];
11
-
12
- module.exports = objectUtil.createSymbolMapFromArray(clientGatewayServiceEvents);
@@ -1,5 +0,0 @@
1
- const objectUtil = require('../../shared/util/objectUtil');
2
-
3
- const diskUsageServiceEvents = ['DISK_USAGE_CHANGE'];
4
-
5
- module.exports = objectUtil.createSymbolMapFromArray(diskUsageServiceEvents);
@@ -1,34 +0,0 @@
1
- const fileListPropMap = new Map();
2
- const defaultTransformer = (value) => value;
3
-
4
- fileListPropMap.set('path', {
5
- methodCall: 'f.path=',
6
- transformValue: defaultTransformer,
7
- });
8
-
9
- fileListPropMap.set('pathComponents', {
10
- methodCall: 'f.path_components=',
11
- transformValue: defaultTransformer,
12
- });
13
-
14
- fileListPropMap.set('priority', {
15
- methodCall: 'f.priority=',
16
- transformValue: defaultTransformer,
17
- });
18
-
19
- fileListPropMap.set('sizeBytes', {
20
- methodCall: 'f.size_bytes=',
21
- transformValue: Number,
22
- });
23
-
24
- fileListPropMap.set('sizeChunks', {
25
- methodCall: 'f.size_chunks=',
26
- transformValue: Number,
27
- });
28
-
29
- fileListPropMap.set('completedChunks', {
30
- methodCall: 'f.completed_chunks=',
31
- transformValue: Number,
32
- });
33
-
34
- module.exports = fileListPropMap;
@@ -1,17 +0,0 @@
1
- const historySnapshotTypes = require('../../shared/constants/historySnapshotTypes');
2
- const objectUtil = require('../../shared/util/objectUtil');
3
-
4
- const torrentServiceEvents = [
5
- 'FETCH_TRANSFER_SUMMARY_ERROR',
6
- 'FETCH_TRANSFER_SUMMARY_SUCCESS',
7
- 'TRANSFER_SUMMARY_DIFF_CHANGE',
8
- ].concat(
9
- // Create an array of event types based on the available snapshots.
10
- Object.keys(historySnapshotTypes).reduce((accumulator, snapshotType) => {
11
- accumulator.push(`${snapshotType}_SNAPSHOT_FULL_UPDATE`, `${snapshotType}_SNAPSHOT_DIFF_CHANGE`);
12
-
13
- return accumulator;
14
- }, []),
15
- );
16
-
17
- module.exports = objectUtil.createSymbolMapFromArray(torrentServiceEvents);
@@ -1,5 +0,0 @@
1
- const objectUtil = require('../../shared/util/objectUtil');
2
-
3
- const notificationServiceEvents = ['NOTIFICATION_COUNT_CHANGE'];
4
-
5
- module.exports = objectUtil.createSymbolMapFromArray(notificationServiceEvents);
@@ -1,5 +0,0 @@
1
- const objectUtil = require('../../shared/util/objectUtil');
2
-
3
- const taxonomyServiceEvents = ['TAXONOMY_DIFF_CHANGE'];
4
-
5
- module.exports = objectUtil.createSymbolMapFromArray(taxonomyServiceEvents);
@@ -1,247 +0,0 @@
1
- const regEx = require('../../shared/util/regEx');
2
-
3
- const torrentListPropMap = new Map();
4
-
5
- const booleanTransformer = (value) => value === '1';
6
- const dateTransformer = (dirtyDate) => {
7
- if (!dirtyDate) {
8
- return '';
9
- }
10
-
11
- const date = dirtyDate.trim();
12
-
13
- if (date === '0') {
14
- return '';
15
- }
16
-
17
- return date;
18
- };
19
- const defaultTransformer = (value) => value;
20
-
21
- torrentListPropMap.set('hash', {
22
- methodCall: 'd.hash=',
23
- transformValue: defaultTransformer,
24
- });
25
-
26
- torrentListPropMap.set('name', {
27
- methodCall: 'd.name=',
28
- transformValue: defaultTransformer,
29
- });
30
-
31
- torrentListPropMap.set('message', {
32
- methodCall: 'd.message=',
33
- transformValue: defaultTransformer,
34
- });
35
-
36
- torrentListPropMap.set('state', {
37
- methodCall: 'd.state=',
38
- transformValue: defaultTransformer,
39
- });
40
-
41
- torrentListPropMap.set('isStateChanged', {
42
- methodCall: 'd.state_changed=',
43
- transformValue: booleanTransformer,
44
- });
45
-
46
- torrentListPropMap.set('isActive', {
47
- methodCall: 'd.is_active=',
48
- transformValue: booleanTransformer,
49
- });
50
-
51
- torrentListPropMap.set('isComplete', {
52
- methodCall: 'd.complete=',
53
- transformValue: booleanTransformer,
54
- });
55
-
56
- torrentListPropMap.set('isHashing', {
57
- methodCall: 'd.hashing=',
58
- transformValue: defaultTransformer,
59
- });
60
-
61
- torrentListPropMap.set('isOpen', {
62
- methodCall: 'd.is_open=',
63
- transformValue: booleanTransformer,
64
- });
65
-
66
- torrentListPropMap.set('priority', {
67
- methodCall: 'd.priority=',
68
- transformValue: defaultTransformer,
69
- });
70
-
71
- torrentListPropMap.set('upRate', {
72
- methodCall: 'd.up.rate=',
73
- transformValue: Number,
74
- });
75
-
76
- torrentListPropMap.set('upTotal', {
77
- methodCall: 'd.up.total=',
78
- transformValue: Number,
79
- });
80
-
81
- torrentListPropMap.set('downRate', {
82
- methodCall: 'd.down.rate=',
83
- transformValue: Number,
84
- });
85
-
86
- torrentListPropMap.set('downTotal', {
87
- methodCall: 'd.down.total=',
88
- transformValue: Number,
89
- });
90
-
91
- torrentListPropMap.set('ratio', {
92
- methodCall: 'd.ratio=',
93
- transformValue: Number,
94
- });
95
-
96
- torrentListPropMap.set('bytesDone', {
97
- methodCall: 'd.bytes_done=',
98
- transformValue: Number,
99
- });
100
-
101
- torrentListPropMap.set('sizeBytes', {
102
- methodCall: 'd.size_bytes=',
103
- transformValue: Number,
104
- });
105
-
106
- torrentListPropMap.set('directory', {
107
- methodCall: 'd.directory=',
108
- transformValue: defaultTransformer,
109
- });
110
-
111
- torrentListPropMap.set('basePath', {
112
- methodCall: 'd.base_path=',
113
- transformValue: defaultTransformer,
114
- });
115
-
116
- torrentListPropMap.set('baseFilename', {
117
- methodCall: 'd.base_filename=',
118
- transformValue: defaultTransformer,
119
- });
120
-
121
- torrentListPropMap.set('baseDirectory', {
122
- methodCall: 'd.directory_base=',
123
- transformValue: defaultTransformer,
124
- });
125
-
126
- torrentListPropMap.set('seedingTime', {
127
- methodCall: 'd.custom=seedingtime',
128
- transformValue: defaultTransformer,
129
- });
130
-
131
- torrentListPropMap.set('dateAdded', {
132
- methodCall: 'd.custom=addtime',
133
- transformValue: dateTransformer,
134
- });
135
-
136
- torrentListPropMap.set('dateCreated', {
137
- methodCall: 'd.creation_date=',
138
- transformValue: dateTransformer,
139
- });
140
-
141
- torrentListPropMap.set('throttleName', {
142
- methodCall: 'd.throttle_name=',
143
- transformValue: defaultTransformer,
144
- });
145
-
146
- torrentListPropMap.set('isMultiFile', {
147
- methodCall: 'd.is_multi_file=',
148
- transformValue: booleanTransformer,
149
- });
150
-
151
- torrentListPropMap.set('isPrivate', {
152
- methodCall: 'd.is_private=',
153
- transformValue: booleanTransformer,
154
- });
155
-
156
- torrentListPropMap.set('tags', {
157
- methodCall: 'd.custom1=',
158
- transformValue: (value) => {
159
- if (value === '') {
160
- return [];
161
- }
162
-
163
- return value
164
- .split(',')
165
- .sort()
166
- .map((tag) => decodeURIComponent(tag));
167
- },
168
- });
169
-
170
- torrentListPropMap.set('comment', {
171
- methodCall: 'd.custom2=',
172
- transformValue: (value) => {
173
- let comment = decodeURIComponent(value);
174
-
175
- if (comment.match(/^VRS24mrker/)) {
176
- comment = comment.substr(10);
177
- }
178
-
179
- return comment;
180
- },
181
- });
182
-
183
- torrentListPropMap.set('ignoreScheduler', {
184
- methodCall: 'd.custom=sch_ignore',
185
- transformValue: booleanTransformer,
186
- });
187
-
188
- torrentListPropMap.set('trackerURIs', {
189
- methodCall: 'cat="$t.multicall=d.hash=,t.is_enabled=,t.url=,cat={|||}"',
190
- transformValue: (value) => {
191
- const trackers = value.split('|||');
192
- const trackerDomains = [];
193
-
194
- trackers.forEach((tracker) => {
195
- // Only count enabled trackers
196
- if (tracker.charAt(0) === '0') {
197
- return;
198
- }
199
-
200
- let domain = regEx.domainName.exec(tracker.substr(1));
201
-
202
- if (domain && domain[1]) {
203
- domain = domain[1];
204
-
205
- const minSubsetLength = 3;
206
- const domainSubsets = domain.split('.');
207
- let desiredSubsets = 2;
208
-
209
- if (domainSubsets.length > desiredSubsets) {
210
- const lastDesiredSubset = domainSubsets[domainSubsets.length - desiredSubsets];
211
- if (lastDesiredSubset.length <= minSubsetLength) {
212
- desiredSubsets++;
213
- }
214
- }
215
-
216
- domain = domainSubsets.slice(desiredSubsets * -1).join('.');
217
-
218
- trackerDomains.push(domain);
219
- }
220
- });
221
-
222
- // Deduplicate
223
- return [...new Set(trackerDomains)];
224
- },
225
- });
226
-
227
- torrentListPropMap.set('seedsConnected', {
228
- methodCall: 'd.peers_complete=',
229
- transformValue: Number,
230
- });
231
-
232
- torrentListPropMap.set('seedsTotal', {
233
- methodCall: 'cat="$t.multicall=d.hash=,t.scrape_complete=,cat={|||}"',
234
- transformValue: (value) => Number(value.substr(0, value.indexOf('|||'))),
235
- });
236
-
237
- torrentListPropMap.set('peersConnected', {
238
- methodCall: 'd.peers_accounted=',
239
- transformValue: Number,
240
- });
241
-
242
- torrentListPropMap.set('peersTotal', {
243
- methodCall: 'cat="$t.multicall=d.hash=,t.scrape_incomplete=,cat={|||}"',
244
- transformValue: (value) => Number(value.substr(0, value.indexOf('|||'))),
245
- });
246
-
247
- module.exports = torrentListPropMap;
@@ -1,5 +0,0 @@
1
- const objectUtil = require('../../shared/util/objectUtil');
2
-
3
- const torrentServiceEvents = ['FETCH_TORRENT_LIST_ERROR', 'FETCH_TORRENT_LIST_SUCCESS', 'TORRENT_LIST_DIFF_CHANGE'];
4
-
5
- module.exports = objectUtil.createSymbolMapFromArray(torrentServiceEvents);
@@ -1,33 +0,0 @@
1
- const transferSummaryPropMap = new Map();
2
-
3
- transferSummaryPropMap.set('upRate', {
4
- methodCall: 'throttle.global_up.rate',
5
- transformValue: Number,
6
- });
7
-
8
- transferSummaryPropMap.set('upTotal', {
9
- methodCall: 'throttle.global_up.total',
10
- transformValue: Number,
11
- });
12
-
13
- transferSummaryPropMap.set('upThrottle', {
14
- methodCall: 'throttle.global_up.max_rate',
15
- transformValue: Number,
16
- });
17
-
18
- transferSummaryPropMap.set('downRate', {
19
- methodCall: 'throttle.global_down.rate',
20
- transformValue: Number,
21
- });
22
-
23
- transferSummaryPropMap.set('downTotal', {
24
- methodCall: 'throttle.global_down.total',
25
- transformValue: Number,
26
- });
27
-
28
- transferSummaryPropMap.set('downThrottle', {
29
- methodCall: 'throttle.global_down.max_rate',
30
- transformValue: Number,
31
- });
32
-
33
- module.exports = transferSummaryPropMap;
@@ -1,6 +0,0 @@
1
- const services = require('../services');
2
-
3
- module.exports = (req, res, next) => {
4
- req.services = services.getAllServices(req.user);
5
- next();
6
- };
@@ -1,9 +0,0 @@
1
- module.exports = (key) => (req, res, next) => {
2
- const value = req.body && req.body[key];
3
-
4
- if (value && typeof value === 'string') {
5
- req.body[key] = value === 'true';
6
- }
7
-
8
- next();
9
- };