@jesec/flood 0.0.0-master.485bb1f → 0.0.0-master.4867480

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 (383) hide show
  1. package/CHANGELOG.md +606 -103
  2. package/README.md +111 -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/739.37bdb6f87f387ec14604.css +1 -0
  15. package/dist/assets/static/css/main.1e2641565fedeca72205.css +1 -0
  16. package/dist/assets/static/js/179.3c561f18.chunk.js +1 -0
  17. package/dist/assets/static/js/739.8137a4e3.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.bbba23c0.chunk.js +1 -0
  25. package/dist/assets/static/js/i18n1.525034ab.chunk.js +1 -0
  26. package/dist/assets/static/js/i18n10.04799933.chunk.js +1 -0
  27. package/dist/assets/static/js/i18n11.d3db204f.chunk.js +1 -0
  28. package/dist/assets/static/js/i18n12.9521b48f.chunk.js +1 -0
  29. package/dist/assets/static/js/i18n13.c8168e17.chunk.js +1 -0
  30. package/dist/assets/static/js/i18n14.9410308a.chunk.js +1 -0
  31. package/dist/assets/static/js/i18n15.1b73c9b5.chunk.js +1 -0
  32. package/dist/assets/static/js/i18n16.d878b440.chunk.js +1 -0
  33. package/dist/assets/static/js/i18n17.13747eb1.chunk.js +1 -0
  34. package/dist/assets/static/js/i18n18.5eaf9fbc.chunk.js +1 -0
  35. package/dist/assets/static/js/i18n19.dd724997.chunk.js +1 -0
  36. package/dist/assets/static/js/i18n2.314f9d9b.chunk.js +1 -0
  37. package/dist/assets/static/js/i18n20.73fe1003.chunk.js +1 -0
  38. package/dist/assets/static/js/i18n21.ddacc27d.chunk.js +1 -0
  39. package/dist/assets/static/js/i18n22.cfce8716.chunk.js +1 -0
  40. package/dist/assets/static/js/i18n23.2a7653e9.chunk.js +1 -0
  41. package/dist/assets/static/js/i18n24.8f60cf8b.chunk.js +1 -0
  42. package/dist/assets/static/js/i18n25.7daba586.chunk.js +1 -0
  43. package/dist/assets/static/js/i18n26.97969f67.chunk.js +1 -0
  44. package/dist/assets/static/js/i18n27.8637db59.chunk.js +1 -0
  45. package/dist/assets/static/js/i18n28.ded89a8a.chunk.js +1 -0
  46. package/dist/assets/static/js/i18n3.47250d33.chunk.js +1 -0
  47. package/dist/assets/static/js/i18n4.dd4ca73b.chunk.js +1 -0
  48. package/dist/assets/static/js/i18n5.1788a7d3.chunk.js +1 -0
  49. package/dist/assets/static/js/i18n6.de9fcab7.chunk.js +1 -0
  50. package/dist/assets/static/js/i18n8.6320258a.chunk.js +1 -0
  51. package/dist/assets/static/js/i18n9.c97c17ff.chunk.js +1 -0
  52. package/dist/assets/static/js/main.07277f9f.js +1 -0
  53. package/dist/index.js +145865 -0
  54. package/package.json +212 -144
  55. package/dist/assets/android-chrome-192x192.png +0 -0
  56. package/dist/assets/android-chrome-512x512.png +0 -0
  57. package/dist/assets/apple-touch-icon.png +0 -0
  58. package/dist/assets/asset-manifest.json +0 -257
  59. package/dist/assets/browserconfig.xml +0 -9
  60. package/dist/assets/favicon-16x16.png +0 -0
  61. package/dist/assets/favicon-32x32.png +0 -0
  62. package/dist/assets/mstile-144x144.png +0 -0
  63. package/dist/assets/mstile-150x150.png +0 -0
  64. package/dist/assets/mstile-310x150.png +0 -0
  65. package/dist/assets/mstile-310x310.png +0 -0
  66. package/dist/assets/mstile-70x70.png +0 -0
  67. package/dist/assets/static/js/1.71ae8956.chunk.js +0 -1
  68. package/dist/assets/static/js/10.a45a228e.chunk.js +0 -1
  69. package/dist/assets/static/js/11.7f6bbbb3.chunk.js +0 -1
  70. package/dist/assets/static/js/12.3f02638d.chunk.js +0 -1
  71. package/dist/assets/static/js/13.003145b8.chunk.js +0 -1
  72. package/dist/assets/static/js/14.bbe409ac.chunk.js +0 -1
  73. package/dist/assets/static/js/15.ce71c4e1.chunk.js +0 -1
  74. package/dist/assets/static/js/16.f4193ed8.chunk.js +0 -1
  75. package/dist/assets/static/js/17.581fdacc.chunk.js +0 -1
  76. package/dist/assets/static/js/18.59a0c94f.chunk.js +0 -1
  77. package/dist/assets/static/js/19.a839a65b.chunk.js +0 -1
  78. package/dist/assets/static/js/2.58962026.chunk.js +0 -1
  79. package/dist/assets/static/js/20.818f1b24.chunk.js +0 -1
  80. package/dist/assets/static/js/21.04285aec.chunk.js +0 -1
  81. package/dist/assets/static/js/22.1e571711.chunk.js +0 -1
  82. package/dist/assets/static/js/23.97097f6f.chunk.js +0 -1
  83. package/dist/assets/static/js/24.9603687d.chunk.js +0 -1
  84. package/dist/assets/static/js/25.af7435f0.chunk.js +0 -1
  85. package/dist/assets/static/js/26.ce65fd84.chunk.js +0 -1
  86. package/dist/assets/static/js/27.71fcd72e.chunk.js +0 -1
  87. package/dist/assets/static/js/28.b40ebdf2.chunk.js +0 -1
  88. package/dist/assets/static/js/3.1a68b7c7.chunk.js +0 -1
  89. package/dist/assets/static/js/4.12725714.chunk.js +0 -1
  90. package/dist/assets/static/js/5.edc14adb.chunk.js +0 -1
  91. package/dist/assets/static/js/6.102dfd16.chunk.js +0 -1
  92. package/dist/assets/static/js/7.458ee78a.chunk.js +0 -1
  93. package/dist/assets/static/js/8.070d774c.chunk.js +0 -1
  94. package/dist/assets/static/js/9.9f52d404.chunk.js +0 -1
  95. package/dist/assets/static/js/main.1797aead.js +0 -347
  96. package/dist/assets/static/media/ABOUT.d02918c9.md +0 -13
  97. package/dist/assets/static/media/Roboto-500.64e69384.woff +0 -0
  98. package/dist/assets/static/media/Roboto-500.7f8f0146.eot +0 -0
  99. package/dist/assets/static/media/Roboto-500.916656a2.ttf +0 -0
  100. package/dist/assets/static/media/Roboto-500.abd255e8.svg +0 -305
  101. package/dist/assets/static/media/Roboto-700.8d11d1e1.ttf +0 -0
  102. package/dist/assets/static/media/Roboto-700.9c9c164e.svg +0 -310
  103. package/dist/assets/static/media/Roboto-700.c65552c8.eot +0 -0
  104. package/dist/assets/static/media/Roboto-700.ee82bda2.woff +0 -0
  105. package/dist/assets/static/media/Roboto-700italic.1dc5bfed.eot +0 -0
  106. package/dist/assets/static/media/Roboto-700italic.686da014.woff +0 -0
  107. package/dist/assets/static/media/Roboto-700italic.896656dc.ttf +0 -0
  108. package/dist/assets/static/media/Roboto-700italic.cacb9681.svg +0 -325
  109. package/dist/assets/static/media/Roboto-italic.09ed2f27.svg +0 -323
  110. package/dist/assets/static/media/Roboto-italic.c1421604.woff +0 -0
  111. package/dist/assets/static/media/Roboto-italic.c38ecad2.ttf +0 -0
  112. package/dist/assets/static/media/Roboto-italic.f7677a07.eot +0 -0
  113. package/dist/assets/static/media/Roboto-regular.5107f918.eot +0 -0
  114. package/dist/assets/static/media/Roboto-regular.6a307cf2.woff +0 -0
  115. package/dist/assets/static/media/Roboto-regular.81dc9b21.ttf +0 -0
  116. package/dist/assets/static/media/Roboto-regular.bcf2ba9e.svg +0 -308
  117. package/dist/config.js +0 -173
  118. package/dist/server/app.js +0 -79
  119. package/dist/server/bin/enforce-prerequisites.js +0 -55
  120. package/dist/server/bin/migrations/fix-is-admin-flag.js +0 -41
  121. package/dist/server/bin/migrations/per-user-rtorrent-instances.js +0 -67
  122. package/dist/server/bin/migrations/run.js +0 -10
  123. package/dist/server/bin/start.js +0 -18
  124. package/dist/server/bin/web-server.js +0 -93
  125. package/dist/server/config/passport.js +0 -32
  126. package/dist/server/constants/clientGatewayServiceEvents.js +0 -15
  127. package/dist/server/constants/diskUsageServiceEvents.js +0 -8
  128. package/dist/server/constants/fileListPropMap.js +0 -29
  129. package/dist/server/constants/historyServiceEvents.js +0 -18
  130. package/dist/server/constants/notificationServiceEvents.js +0 -8
  131. package/dist/server/constants/taxonomyServiceEvents.js +0 -8
  132. package/dist/server/constants/torrentListPropMap.js +0 -200
  133. package/dist/server/constants/torrentServiceEvents.js +0 -8
  134. package/dist/server/constants/transferSummaryPropMap.js +0 -28
  135. package/dist/server/middleware/appendUserServices.js +0 -10
  136. package/dist/server/middleware/booleanCoerce.js +0 -9
  137. package/dist/server/middleware/clientActivityStream.js +0 -124
  138. package/dist/server/middleware/eventStream.js +0 -25
  139. package/dist/server/middleware/requireAdmin.js +0 -8
  140. package/dist/server/models/ClientRequest.js +0 -310
  141. package/dist/server/models/Feed.js +0 -65
  142. package/dist/server/models/Filesystem.js +0 -44
  143. package/dist/server/models/HistoryEra.js +0 -168
  144. package/dist/server/models/ServerEvent.js +0 -27
  145. package/dist/server/models/TemporaryStorage.js +0 -20
  146. package/dist/server/models/Users.js +0 -160
  147. package/dist/server/models/client.js +0 -363
  148. package/dist/server/models/settings.js +0 -119
  149. package/dist/server/routes/api.js +0 -69
  150. package/dist/server/routes/auth.js +0 -184
  151. package/dist/server/routes/client.js +0 -101
  152. package/dist/server/services/BaseService.js +0 -24
  153. package/dist/server/services/clientGatewayService.js +0 -220
  154. package/dist/server/services/clientRequestManager.js +0 -76
  155. package/dist/server/services/diskUsageService.js +0 -133
  156. package/dist/server/services/feedService.js +0 -290
  157. package/dist/server/services/historyService.js +0 -181
  158. package/dist/server/services/index.js +0 -108
  159. package/dist/server/services/notificationService.js +0 -108
  160. package/dist/server/services/taxonomyService.js +0 -107
  161. package/dist/server/services/torrentService.js +0 -235
  162. package/dist/server/util/ajaxUtil.js +0 -19
  163. package/dist/server/util/clientResponseUtil.js +0 -99
  164. package/dist/server/util/fileUtil.js +0 -45
  165. package/dist/server/util/mediainfo.js +0 -34
  166. package/dist/server/util/methodCallUtil.js +0 -22
  167. package/dist/server/util/numberUtils.js +0 -7
  168. package/dist/server/util/rTorrentDeserializer.js +0 -104
  169. package/dist/server/util/rTorrentPropMap.js +0 -13
  170. package/dist/server/util/scgiUtil.js +0 -36
  171. package/dist/server/util/torrentFileUtil.js +0 -23
  172. package/dist/shared/config/paths.js +0 -41
  173. package/dist/shared/constants/clientSettingsMap.js +0 -53
  174. package/dist/shared/constants/diffActionTypes.js +0 -6
  175. package/dist/shared/constants/historySnapshotTypes.js +0 -11
  176. package/dist/shared/constants/serverEventTypes.js +0 -18
  177. package/dist/shared/constants/torrentFilePropsMap.js +0 -6
  178. package/dist/shared/constants/torrentPeerPropsMap.js +0 -32
  179. package/dist/shared/constants/torrentStatusMap.js +0 -17
  180. package/dist/shared/constants/torrentTrackerPropsMap.js +0 -6
  181. package/dist/shared/util/formatUtil.js +0 -73
  182. package/dist/shared/util/objectUtil.js +0 -56
  183. package/dist/shared/util/regEx.js +0 -7
  184. /package/dist/assets/{safari-pinned-tab.svg → icon.svg} +0 -0
  185. /package/dist/assets/static/{images/flags/ad.png → media/ad.1b24595d.png} +0 -0
  186. /package/dist/assets/static/{images/flags/ae.png → media/ae.4dd8f55e.png} +0 -0
  187. /package/dist/assets/static/{images/flags/af.png → media/af.4ce660eb.png} +0 -0
  188. /package/dist/assets/static/{images/flags/ag.png → media/ag.fd9409e4.png} +0 -0
  189. /package/dist/assets/static/{images/flags/al.png → media/al.a297aacf.png} +0 -0
  190. /package/dist/assets/static/{images/flags/am.png → media/am.c84ee0cf.png} +0 -0
  191. /package/dist/assets/static/{images/flags/ao.png → media/ao.a7c9214e.png} +0 -0
  192. /package/dist/assets/static/{images/flags/ar.png → media/ar.7e57ef92.png} +0 -0
  193. /package/dist/assets/static/{images/flags/at.png → media/at.5aa9728a.png} +0 -0
  194. /package/dist/assets/static/{images/flags/au.png → media/au.155b51d8.png} +0 -0
  195. /package/dist/assets/static/{images/flags/az.png → media/az.63afef5b.png} +0 -0
  196. /package/dist/assets/static/{images/flags/ba.png → media/ba.5ce8f273.png} +0 -0
  197. /package/dist/assets/static/{images/flags/bb.png → media/bb.f369fc62.png} +0 -0
  198. /package/dist/assets/static/{images/flags/bd.png → media/bd.516278fc.png} +0 -0
  199. /package/dist/assets/static/{images/flags/be.png → media/be.08ec4a8d.png} +0 -0
  200. /package/dist/assets/static/{images/flags/bf.png → media/bf.50bfcb31.png} +0 -0
  201. /package/dist/assets/static/{images/flags/bg.png → media/bg.d9346b96.png} +0 -0
  202. /package/dist/assets/static/{images/flags/bh.png → media/bh.f06d5914.png} +0 -0
  203. /package/dist/assets/static/{images/flags/bi.png → media/bi.4923e3a3.png} +0 -0
  204. /package/dist/assets/static/{images/flags/bj.png → media/bj.019fa79b.png} +0 -0
  205. /package/dist/assets/static/{images/flags/bn.png → media/bn.077671e2.png} +0 -0
  206. /package/dist/assets/static/{images/flags/bo.png → media/bo.8fb15fc6.png} +0 -0
  207. /package/dist/assets/static/{images/flags/br.png → media/br.ec051f0c.png} +0 -0
  208. /package/dist/assets/static/{images/flags/bs.png → media/bs.a74a126f.png} +0 -0
  209. /package/dist/assets/static/{images/flags/bt.png → media/bt.4217b804.png} +0 -0
  210. /package/dist/assets/static/{images/flags/bw.png → media/bw.21fe1567.png} +0 -0
  211. /package/dist/assets/static/{images/flags/by.png → media/by.d247fe16.png} +0 -0
  212. /package/dist/assets/static/{images/flags/bz.png → media/bz.98ec59f6.png} +0 -0
  213. /package/dist/assets/static/{images/flags/ca.png → media/ca.25743e11.png} +0 -0
  214. /package/dist/assets/static/{images/flags/cd.png → media/cd.a5bfda53.png} +0 -0
  215. /package/dist/assets/static/{images/flags/cf.png → media/cf.de7d5d92.png} +0 -0
  216. /package/dist/assets/static/{images/flags/cg.png → media/cg.a47b626b.png} +0 -0
  217. /package/dist/assets/static/{images/flags/ch.png → media/ch.445f47a1.png} +0 -0
  218. /package/dist/assets/static/{images/flags/ci.png → media/ci.a6009c5b.png} +0 -0
  219. /package/dist/assets/static/{images/flags/cl.png → media/cl.de1d715e.png} +0 -0
  220. /package/dist/assets/static/{images/flags/cm.png → media/cm.3ce8a86a.png} +0 -0
  221. /package/dist/assets/static/{images/flags/cn.png → media/cn.e6a26073.png} +0 -0
  222. /package/dist/assets/static/{images/flags/co.png → media/co.e9244faa.png} +0 -0
  223. /package/dist/assets/static/{images/flags/cr.png → media/cr.c895e035.png} +0 -0
  224. /package/dist/assets/static/{images/flags/cu.png → media/cu.e486c055.png} +0 -0
  225. /package/dist/assets/static/{images/flags/cv.png → media/cv.a9585acf.png} +0 -0
  226. /package/dist/assets/static/{images/flags/cw.png → media/cw.df13039d.png} +0 -0
  227. /package/dist/assets/static/{images/flags/cy.png → media/cy.b31f43a9.png} +0 -0
  228. /package/dist/assets/static/{images/flags/cz.png → media/cz.8ec5948b.png} +0 -0
  229. /package/dist/assets/static/{images/flags/de.png → media/de.d12f391a.png} +0 -0
  230. /package/dist/assets/static/{images/flags/dj.png → media/dj.154c3580.png} +0 -0
  231. /package/dist/assets/static/{images/flags/dk.png → media/dk.da382fe2.png} +0 -0
  232. /package/dist/assets/static/{images/flags/dm.png → media/dm.f452e6cd.png} +0 -0
  233. /package/dist/assets/static/{images/flags/do.png → media/do.c6bd7637.png} +0 -0
  234. /package/dist/assets/static/{images/flags/dz.png → media/dz.672a69c0.png} +0 -0
  235. /package/dist/assets/static/{images/flags/ec.png → media/ec.349d9bd7.png} +0 -0
  236. /package/dist/assets/static/{images/flags/ee.png → media/ee.2396205f.png} +0 -0
  237. /package/dist/assets/static/{images/flags/eg.png → media/eg.ccbf3f45.png} +0 -0
  238. /package/dist/assets/static/{images/flags/eh.png → media/eh.af65674a.png} +0 -0
  239. /package/dist/assets/static/{images/flags/er.png → media/er.21afb638.png} +0 -0
  240. /package/dist/assets/static/{images/flags/es.png → media/es.2a6eaee4.png} +0 -0
  241. /package/dist/assets/static/{images/flags/et.png → media/et.8beb65c8.png} +0 -0
  242. /package/dist/assets/static/{images/flags/fi.png → media/fi.331f70fd.png} +0 -0
  243. /package/dist/assets/static/{images/flags/fj.png → media/fj.7724d800.png} +0 -0
  244. /package/dist/assets/static/{images/flags/fm.png → media/fm.eeaf71e9.png} +0 -0
  245. /package/dist/assets/static/{images/flags/fr.png → media/fr.5d5ab008.png} +0 -0
  246. /package/dist/assets/static/{images/flags/ga.png → media/ga.77ed474c.png} +0 -0
  247. /package/dist/assets/static/{images/flags/gb.png → media/gb.e00065bf.png} +0 -0
  248. /package/dist/assets/static/{images/flags/gd.png → media/gd.b4522267.png} +0 -0
  249. /package/dist/assets/static/{images/flags/ge.png → media/ge.91a7654d.png} +0 -0
  250. /package/dist/assets/static/{images/flags/gh.png → media/gh.4759f92f.png} +0 -0
  251. /package/dist/assets/static/{images/flags/gm.png → media/gm.81cd9f75.png} +0 -0
  252. /package/dist/assets/static/{images/flags/gn.png → media/gn.9f3d376e.png} +0 -0
  253. /package/dist/assets/static/{images/flags/gq.png → media/gq.e8ad58be.png} +0 -0
  254. /package/dist/assets/static/{images/flags/gr.png → media/gr.26f3ac0b.png} +0 -0
  255. /package/dist/assets/static/{images/flags/gt.png → media/gt.9d81c52e.png} +0 -0
  256. /package/dist/assets/static/{images/flags/gw.png → media/gw.dc906982.png} +0 -0
  257. /package/dist/assets/static/{images/flags/gy.png → media/gy.a4f62b6c.png} +0 -0
  258. /package/dist/assets/static/{images/flags/hk.png → media/hk.56555c3f.png} +0 -0
  259. /package/dist/assets/static/{images/flags/hn.png → media/hn.64ee6aad.png} +0 -0
  260. /package/dist/assets/static/{images/flags/hr.png → media/hr.93ebecd3.png} +0 -0
  261. /package/dist/assets/static/{images/flags/ht.png → media/ht.42ca1596.png} +0 -0
  262. /package/dist/assets/static/{images/flags/hu.png → media/hu.bb30f05d.png} +0 -0
  263. /package/dist/assets/static/{images/flags/id.png → media/id.2cb49f2d.png} +0 -0
  264. /package/dist/assets/static/{images/flags/ie.png → media/ie.b4dd1f19.png} +0 -0
  265. /package/dist/assets/static/{images/flags/il.png → media/il.cd1d1faf.png} +0 -0
  266. /package/dist/assets/static/{images/flags/in.png → media/in.2df03847.png} +0 -0
  267. /package/dist/assets/static/{images/flags/iq.png → media/iq.a9b670ab.png} +0 -0
  268. /package/dist/assets/static/{images/flags/ir.png → media/ir.9a3de085.png} +0 -0
  269. /package/dist/assets/static/{images/flags/is.png → media/is.d88f4fc9.png} +0 -0
  270. /package/dist/assets/static/{images/flags/it.png → media/it.b73713e3.png} +0 -0
  271. /package/dist/assets/static/{images/flags/je.png → media/je.0353f56a.png} +0 -0
  272. /package/dist/assets/static/{images/flags/jm.png → media/jm.20330ef4.png} +0 -0
  273. /package/dist/assets/static/{images/flags/jo.png → media/jo.eb66f1d1.png} +0 -0
  274. /package/dist/assets/static/{images/flags/jp.png → media/jp.63e382ae.png} +0 -0
  275. /package/dist/assets/static/{images/flags/ke.png → media/ke.ab2e43b8.png} +0 -0
  276. /package/dist/assets/static/{images/flags/kg.png → media/kg.2c47c2af.png} +0 -0
  277. /package/dist/assets/static/{images/flags/kh.png → media/kh.4732c810.png} +0 -0
  278. /package/dist/assets/static/{images/flags/ki.png → media/ki.5fba09fd.png} +0 -0
  279. /package/dist/assets/static/{images/flags/km.png → media/km.7bbed3e9.png} +0 -0
  280. /package/dist/assets/static/{images/flags/kn.png → media/kn.a9595a16.png} +0 -0
  281. /package/dist/assets/static/{images/flags/kp.png → media/kp.8a4dc30a.png} +0 -0
  282. /package/dist/assets/static/{images/flags/kr.png → media/kr.5273be1d.png} +0 -0
  283. /package/dist/assets/static/{images/flags/ks.png → media/ks.99f78645.png} +0 -0
  284. /package/dist/assets/static/{images/flags/kw.png → media/kw.af3521bc.png} +0 -0
  285. /package/dist/assets/static/{images/flags/kz.png → media/kz.ea47ef79.png} +0 -0
  286. /package/dist/assets/static/{images/flags/la.png → media/la.78a598d7.png} +0 -0
  287. /package/dist/assets/static/{images/flags/lb.png → media/lb.7a7c15a9.png} +0 -0
  288. /package/dist/assets/static/{images/flags/lc.png → media/lc.6083a4ff.png} +0 -0
  289. /package/dist/assets/static/{images/flags/li.png → media/li.61c564a4.png} +0 -0
  290. /package/dist/assets/static/{images/flags/lk.png → media/lk.6fa85802.png} +0 -0
  291. /package/dist/assets/static/{images/flags/lr.png → media/lr.8063f7db.png} +0 -0
  292. /package/dist/assets/static/{images/flags/ls.png → media/ls.901ddb71.png} +0 -0
  293. /package/dist/assets/static/{images/flags/lt.png → media/lt.9209ace3.png} +0 -0
  294. /package/dist/assets/static/{images/flags/lu.png → media/lu.c9872bc1.png} +0 -0
  295. /package/dist/assets/static/{images/flags/lv.png → media/lv.7bcacf0a.png} +0 -0
  296. /package/dist/assets/static/{images/flags/ly.png → media/ly.2830aa63.png} +0 -0
  297. /package/dist/assets/static/{images/flags/ma.png → media/ma.ce5f697b.png} +0 -0
  298. /package/dist/assets/static/{images/flags/mc.png → media/mc.4bd5d57a.png} +0 -0
  299. /package/dist/assets/static/{images/flags/md.png → media/md.fb4b5bdf.png} +0 -0
  300. /package/dist/assets/static/{images/flags/me.png → media/me.1f1d1772.png} +0 -0
  301. /package/dist/assets/static/{images/flags/mg.png → media/mg.89101bd2.png} +0 -0
  302. /package/dist/assets/static/{images/flags/mh.png → media/mh.ff11dff7.png} +0 -0
  303. /package/dist/assets/static/{images/flags/mk.png → media/mk.8420e604.png} +0 -0
  304. /package/dist/assets/static/{images/flags/ml.png → media/ml.4db47c66.png} +0 -0
  305. /package/dist/assets/static/{images/flags/mm.png → media/mm.8e4ac30a.png} +0 -0
  306. /package/dist/assets/static/{images/flags/mn.png → media/mn.dc1daa04.png} +0 -0
  307. /package/dist/assets/static/{images/flags/mr.png → media/mr.7cbca6d0.png} +0 -0
  308. /package/dist/assets/static/{images/flags/mt.png → media/mt.28a4b863.png} +0 -0
  309. /package/dist/assets/static/{images/flags/mu.png → media/mu.d93db6c7.png} +0 -0
  310. /package/dist/assets/static/{images/flags/mv.png → media/mv.7d026bf1.png} +0 -0
  311. /package/dist/assets/static/{images/flags/mw.png → media/mw.960cd4fb.png} +0 -0
  312. /package/dist/assets/static/{images/flags/mx.png → media/mx.39b78eb2.png} +0 -0
  313. /package/dist/assets/static/{images/flags/my.png → media/my.916a8392.png} +0 -0
  314. /package/dist/assets/static/{images/flags/mz.png → media/mz.facb4ea3.png} +0 -0
  315. /package/dist/assets/static/{images/flags/na.png → media/na.472666a9.png} +0 -0
  316. /package/dist/assets/static/{images/flags/ne.png → media/ne.d774701f.png} +0 -0
  317. /package/dist/assets/static/{images/flags/ng.png → media/ng.7b06a49f.png} +0 -0
  318. /package/dist/assets/static/{images/flags/ni.png → media/ni.7140131c.png} +0 -0
  319. /package/dist/assets/static/{images/flags/nl.png → media/nl.4c04aa96.png} +0 -0
  320. /package/dist/assets/static/{images/flags/no.png → media/no.c19eb00d.png} +0 -0
  321. /package/dist/assets/static/{images/flags/np.png → media/np.54fb4f2f.png} +0 -0
  322. /package/dist/assets/static/{images/flags/nr.png → media/nr.7527cc38.png} +0 -0
  323. /package/dist/assets/static/{images/flags/nz.png → media/nz.738be05b.png} +0 -0
  324. /package/dist/assets/static/{images/flags/om.png → media/om.b25e0a17.png} +0 -0
  325. /package/dist/assets/static/{images/flags/pa.png → media/pa.b28a9059.png} +0 -0
  326. /package/dist/assets/static/{images/flags/pe.png → media/pe.c1fc1d96.png} +0 -0
  327. /package/dist/assets/static/{images/flags/pg.png → media/pg.380115db.png} +0 -0
  328. /package/dist/assets/static/{images/flags/ph.png → media/ph.02199ddc.png} +0 -0
  329. /package/dist/assets/static/{images/flags/pk.png → media/pk.094f9517.png} +0 -0
  330. /package/dist/assets/static/{images/flags/pl.png → media/pl.41521283.png} +0 -0
  331. /package/dist/assets/static/{images/flags/pt.png → media/pt.1f82dc04.png} +0 -0
  332. /package/dist/assets/static/{images/flags/pw.png → media/pw.a26c2316.png} +0 -0
  333. /package/dist/assets/static/{images/flags/py.png → media/py.926c65ed.png} +0 -0
  334. /package/dist/assets/static/{images/flags/qa.png → media/qa.c6a3c20e.png} +0 -0
  335. /package/dist/assets/static/{images/flags/ro.png → media/ro.a36876c9.png} +0 -0
  336. /package/dist/assets/static/{images/flags/rs.png → media/rs.c6629de8.png} +0 -0
  337. /package/dist/assets/static/{images/flags/ru.png → media/ru.a9b948c1.png} +0 -0
  338. /package/dist/assets/static/{images/flags/rw.png → media/rw.e8aecba0.png} +0 -0
  339. /package/dist/assets/static/{images/flags/sa.png → media/sa.859049c8.png} +0 -0
  340. /package/dist/assets/static/{images/flags/sb.png → media/sb.4ad27b27.png} +0 -0
  341. /package/dist/assets/static/{images/flags/sc.png → media/sc.3293efde.png} +0 -0
  342. /package/dist/assets/static/{images/flags/sd.png → media/sd.19c94faa.png} +0 -0
  343. /package/dist/assets/static/{images/flags/se.png → media/se.195b3f93.png} +0 -0
  344. /package/dist/assets/static/{images/flags/sg.png → media/sg.19d81907.png} +0 -0
  345. /package/dist/assets/static/{images/flags/si.png → media/si.367c5443.png} +0 -0
  346. /package/dist/assets/static/{images/flags/sk.png → media/sk.4e5b8a39.png} +0 -0
  347. /package/dist/assets/static/{images/flags/sl.png → media/sl.4b174b1c.png} +0 -0
  348. /package/dist/assets/static/{images/flags/sm.png → media/sm.2cba3dac.png} +0 -0
  349. /package/dist/assets/static/{images/flags/sn.png → media/sn.a4c1041d.png} +0 -0
  350. /package/dist/assets/static/{images/flags/so.png → media/so.b455e3bf.png} +0 -0
  351. /package/dist/assets/static/{images/flags/sr.png → media/sr.5adc1c00.png} +0 -0
  352. /package/dist/assets/static/{images/flags/st.png → media/st.5ae44155.png} +0 -0
  353. /package/dist/assets/static/{images/flags/sv.png → media/sv.43aa6cdf.png} +0 -0
  354. /package/dist/assets/static/{images/flags/sy.png → media/sy.0fbd24f7.png} +0 -0
  355. /package/dist/assets/static/{images/flags/sz.png → media/sz.ff204912.png} +0 -0
  356. /package/dist/assets/static/{images/flags/td.png → media/td.c7aa2a4e.png} +0 -0
  357. /package/dist/assets/static/{images/flags/tg.png → media/tg.857c3bec.png} +0 -0
  358. /package/dist/assets/static/{images/flags/th.png → media/th.683600c7.png} +0 -0
  359. /package/dist/assets/static/{images/flags/tj.png → media/tj.d20c5570.png} +0 -0
  360. /package/dist/assets/static/{images/flags/tl.png → media/tl.5edd8ea7.png} +0 -0
  361. /package/dist/assets/static/{images/flags/tm.png → media/tm.15960215.png} +0 -0
  362. /package/dist/assets/static/{images/flags/tn.png → media/tn.40df718e.png} +0 -0
  363. /package/dist/assets/static/{images/flags/to.png → media/to.c3b054df.png} +0 -0
  364. /package/dist/assets/static/{images/flags/tr.png → media/tr.adeace6d.png} +0 -0
  365. /package/dist/assets/static/{images/flags/tt.png → media/tt.839bd7f1.png} +0 -0
  366. /package/dist/assets/static/{images/flags/tv.png → media/tv.628cae3e.png} +0 -0
  367. /package/dist/assets/static/{images/flags/tw.png → media/tw.4e885914.png} +0 -0
  368. /package/dist/assets/static/{images/flags/tz.png → media/tz.b2f0dc37.png} +0 -0
  369. /package/dist/assets/static/{images/flags/ua.png → media/ua.6b103313.png} +0 -0
  370. /package/dist/assets/static/{images/flags/ug.png → media/ug.c84042fc.png} +0 -0
  371. /package/dist/assets/static/{images/flags/us.png → media/us.8523c31d.png} +0 -0
  372. /package/dist/assets/static/{images/flags/uy.png → media/uy.a943f85e.png} +0 -0
  373. /package/dist/assets/static/{images/flags/uz.png → media/uz.25552673.png} +0 -0
  374. /package/dist/assets/static/{images/flags/va.png → media/va.a29e1b53.png} +0 -0
  375. /package/dist/assets/static/{images/flags/vc.png → media/vc.7480bd37.png} +0 -0
  376. /package/dist/assets/static/{images/flags/ve.png → media/ve.fd4273c2.png} +0 -0
  377. /package/dist/assets/static/{images/flags/vn.png → media/vn.7d2eff1b.png} +0 -0
  378. /package/dist/assets/static/{images/flags/vu.png → media/vu.48b64cf3.png} +0 -0
  379. /package/dist/assets/static/{images/flags/ws.png → media/ws.f3d9202f.png} +0 -0
  380. /package/dist/assets/static/{images/flags/ye.png → media/ye.311a0e50.png} +0 -0
  381. /package/dist/assets/static/{images/flags/za.png → media/za.090a856f.png} +0 -0
  382. /package/dist/assets/static/{images/flags/zm.png → media/zm.8371e197.png} +0 -0
  383. /package/dist/assets/static/{images/flags/zw.png → media/zw.a6809447.png} +0 -0
@@ -1,133 +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 service is not per rTorrent session, which is why it does not inherit
8
- * `BaseService` nor have any use of the per user API ie. `getService()`
9
- */
10
- const events_1 = __importDefault(require("events"));
11
- const child_process_1 = require("child_process");
12
- const util_1 = __importDefault(require("util"));
13
- const config_1 = __importDefault(require("../../config"));
14
- const diskUsageServiceEvents_1 = __importDefault(require("../constants/diskUsageServiceEvents"));
15
- const execFileAsync = util_1.default.promisify(child_process_1.execFile);
16
- const PLATFORMS_SUPPORTED = ['darwin', 'linux', 'freebsd', 'win32'];
17
- const MAX_BUFFER_SIZE = 65536;
18
- const filterMountPoint = config_1.default.diskUsageService && config_1.default.diskUsageService.watchMountPoints
19
- ? // if user has configured watchPartitions filter each line output for given
20
- // array
21
- (mountpoint) => config_1.default.diskUsageService.watchMountPoints.includes(mountpoint)
22
- : () => true; // include all mounted file systems by default
23
- const diskUsage = {
24
- linux: () => execFileAsync('df -xsquashfs -xtmpfs -xdevtmpfs | tail -n+2', {
25
- shell: true,
26
- maxBuffer: MAX_BUFFER_SIZE,
27
- }).then(({ stdout }) => stdout
28
- .trim()
29
- .split('\n')
30
- .map((disk) => disk.split(/\s+/))
31
- .filter((disk) => filterMountPoint(disk[5]))
32
- .map(([_fs, size, used, avail, _pcent, target]) => {
33
- return {
34
- size: Number.parseInt(size, 10) * 1024,
35
- used: Number.parseInt(used, 10) * 1024,
36
- avail: Number.parseInt(avail, 10) * 1024,
37
- target,
38
- };
39
- })),
40
- freebsd: () => execFileAsync('df | tail -n+2', {
41
- shell: true,
42
- maxBuffer: MAX_BUFFER_SIZE,
43
- }).then(({ stdout }) => stdout
44
- .trim()
45
- .split('\n')
46
- .map((disk) => disk.split(/\s+/))
47
- .filter((disk) => filterMountPoint(disk[5]))
48
- .map(([_fs, size, used, avail, _pcent, target]) => {
49
- return {
50
- size: Number.parseInt(size, 10) * 1024,
51
- used: Number.parseInt(used, 10) * 1024,
52
- avail: Number.parseInt(avail, 10) * 1024,
53
- target,
54
- };
55
- })),
56
- darwin: () => execFileAsync('df -kl | tail -n+2', {
57
- shell: true,
58
- maxBuffer: MAX_BUFFER_SIZE,
59
- }).then(({ stdout }) => stdout
60
- .trim()
61
- .split('\n')
62
- .map((disk) => disk.split(/\s+/))
63
- .filter((disk) => filterMountPoint(disk[8]))
64
- .map(([_fs, size, used, avail, _pcent, _iused, _ifree, _piused, target]) => {
65
- return {
66
- size: Number.parseInt(size, 10) * 1024,
67
- used: Number.parseInt(used, 10) * 1024,
68
- avail: Number.parseInt(avail, 10) * 1024,
69
- target,
70
- };
71
- })),
72
- win32: () => execFileAsync('wmic logicaldisk', {
73
- shell: true,
74
- maxBuffer: MAX_BUFFER_SIZE,
75
- }).then(({ stdout }) => stdout
76
- .trim()
77
- .split('\n')
78
- .slice(1)
79
- .map((disk) => disk.split(/\s+/))
80
- .filter((disk) => filterMountPoint(disk[1]))
81
- .map((disk) => ({
82
- size: disk[14],
83
- used: disk[14] - disk[10],
84
- avail: disk[10],
85
- target: disk[1],
86
- }))),
87
- };
88
- const INTERVAL_UPDATE = 10000;
89
- class DiskUsageService extends events_1.default {
90
- constructor() {
91
- super();
92
- this.disks = [];
93
- this.tLastChange = 0;
94
- this.interval = 0;
95
- if (!PLATFORMS_SUPPORTED.includes(process.platform)) {
96
- console.log(`warning: DiskUsageService is only supported in ${PLATFORMS_SUPPORTED.join()}`);
97
- return;
98
- }
99
- // start polling disk usage when the first listener is added
100
- this.on('newListener', (event) => {
101
- if (this.listenerCount(diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE) === 0 &&
102
- event === diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE) {
103
- this.updateInterval = setInterval(this.updateDisks.bind(this), INTERVAL_UPDATE);
104
- }
105
- });
106
- // stop polling disk usage when the last listener is removed
107
- this.on('removeListener', (event) => {
108
- if (this.listenerCount(diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE) === 0 &&
109
- event === diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE) {
110
- clearInterval(this.updateInterval);
111
- }
112
- });
113
- }
114
- updateDisks() {
115
- if (!PLATFORMS_SUPPORTED.includes(process.platform)) {
116
- return Promise.resolve([]);
117
- }
118
- return diskUsage[process.platform]().then((disks) => {
119
- if (disks.length !== this.disks.length || disks.some((d, i) => d.used !== this.disks[i].used)) {
120
- this.tLastChange = Date.now();
121
- this.disks = disks;
122
- this.emit(diskUsageServiceEvents_1.default.DISK_USAGE_CHANGE, this.getDiskUsage());
123
- }
124
- });
125
- }
126
- getDiskUsage() {
127
- return {
128
- id: this.tLastChange,
129
- disks: this.disks,
130
- };
131
- }
132
- }
133
- exports.default = new DiskUsageService();
@@ -1,290 +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 path_1 = __importDefault(require("path"));
7
- const nedb_1 = __importDefault(require("nedb"));
8
- const BaseService_1 = __importDefault(require("./BaseService"));
9
- const client_1 = __importDefault(require("../models/client"));
10
- const config_1 = __importDefault(require("../../config"));
11
- const Feed_1 = __importDefault(require("../models/Feed"));
12
- const regEx_1 = __importDefault(require("../../shared/util/regEx"));
13
- // TODO: Allow users to specify which key contains the URLs.
14
- const getTorrentUrlsFromItem = (feedItem) => {
15
- // If we've got an Array of enclosures, we'll iterate over the values and
16
- // look for the url key.
17
- if (feedItem.enclosures && Array.isArray(feedItem.enclosures)) {
18
- return feedItem.enclosures.reduce((urls, enclosure) => {
19
- if (enclosure.url) {
20
- urls.push(enclosure.url);
21
- }
22
- return urls;
23
- }, []);
24
- }
25
- // If we've got a Object of enclosures, use url key
26
- if (feedItem.enclosure && feedItem.enclosure.url) {
27
- return [feedItem.enclosure.url];
28
- }
29
- // If there are no enclosures, then use the link tag instead
30
- if (feedItem.link) {
31
- // remove CDATA tags around links
32
- const cdata = regEx_1.default.cdata.exec(feedItem.link);
33
- if (cdata && cdata[1]) {
34
- return [cdata[1]];
35
- }
36
- return [feedItem.link];
37
- }
38
- return [];
39
- };
40
- const getItemsMatchingRules = (feedItems, rules, feed) => {
41
- return feedItems.reduce((matchedItems, feedItem) => {
42
- rules.forEach((rule) => {
43
- const isMatched = new RegExp(rule.match, 'gi').test(feedItem[rule.field]);
44
- const isExcluded = rule.exclude !== '' && new RegExp(rule.exclude, 'gi').test(feedItem[rule.field]);
45
- if (isMatched && !isExcluded) {
46
- const torrentUrls = getTorrentUrlsFromItem(feedItem);
47
- const isAlreadyDownloaded = matchedItems.some((matchedItem) => torrentUrls.every((url) => matchedItem.urls.includes(url)));
48
- if (!isAlreadyDownloaded) {
49
- matchedItems.push({
50
- urls: torrentUrls,
51
- tags: rule.tags,
52
- feedID: rule.feedID,
53
- feedLabel: feed.label,
54
- matchTitle: feedItem.title,
55
- ruleID: rule._id,
56
- ruleLabel: rule.label,
57
- destination: rule.destination,
58
- startOnLoad: rule.startOnLoad,
59
- });
60
- }
61
- }
62
- });
63
- return matchedItems;
64
- }, []);
65
- };
66
- const getUrlsFromItems = (feedItems) => {
67
- return feedItems.reduce((urls, feedItem) => urls.concat(feedItem.urls), []);
68
- };
69
- class FeedService extends BaseService_1.default {
70
- constructor(...serviceConfig) {
71
- super(...serviceConfig);
72
- this.isDBReady = false;
73
- this.db = this.loadDatabase();
74
- this.init();
75
- }
76
- addFeed(feed, callback) {
77
- this.addItem('feed', feed, (newFeed) => {
78
- this.startNewFeed(newFeed);
79
- callback(newFeed);
80
- });
81
- }
82
- modifyFeed(id, feedToModify, callback) {
83
- const modifiedFeed = this.feeds.find((feed) => feed.options._id === id);
84
- modifiedFeed.stopReader();
85
- modifiedFeed.modify(feedToModify);
86
- this.modifyItem(id, feedToModify, (err) => {
87
- callback(err);
88
- });
89
- }
90
- addItem(type, item, callback) {
91
- if (!this.isDBReady)
92
- return;
93
- this.db.insert(Object.assign(item, { type }), (err, newDoc) => {
94
- if (err) {
95
- callback(null, err);
96
- return;
97
- }
98
- callback(newDoc);
99
- });
100
- }
101
- modifyItem(id, newItem, callback) {
102
- if (!this.isDBReady) {
103
- return;
104
- }
105
- this.db.update({ _id: id }, { $set: newItem }, {}, (err) => {
106
- if (err) {
107
- callback(null, err);
108
- return;
109
- }
110
- callback(null);
111
- });
112
- }
113
- addRule(rule, callback) {
114
- this.addItem('rule', rule, (newRule, error) => {
115
- if (error) {
116
- callback(null, error);
117
- return;
118
- }
119
- callback(newRule);
120
- if (this.rules[newRule.feedID] == null) {
121
- this.rules[newRule.feedID] = [];
122
- }
123
- this.rules[newRule.feedID].push(newRule);
124
- const associatedFeed = this.feeds.find((feed) => feed.options._id === newRule.feedID);
125
- if (associatedFeed) {
126
- this.handleNewItems({
127
- feed: associatedFeed.options,
128
- items: associatedFeed.getItems(),
129
- });
130
- }
131
- });
132
- }
133
- getAll(callback) {
134
- this.db.find({}, (err, docs) => {
135
- if (err) {
136
- callback(null, err);
137
- return;
138
- }
139
- callback(docs.reduce((memo, item) => {
140
- const type = `${item.type}s`;
141
- if (memo[type] == null) {
142
- memo[type] = [];
143
- }
144
- memo[type].push(item);
145
- return memo;
146
- }, {}));
147
- });
148
- }
149
- getFeeds(query, callback) {
150
- this.queryItem('feed', query, callback);
151
- }
152
- getItems(query, callback) {
153
- const selectedFeed = this.feeds.find((feed) => feed.options._id === query.id);
154
- if (selectedFeed) {
155
- const items = selectedFeed.getItems();
156
- if (query.search) {
157
- callback(items.filter((item) => item.title.toLowerCase().indexOf(query.search.toLowerCase()) !== -1));
158
- }
159
- else {
160
- callback(items);
161
- }
162
- }
163
- else {
164
- callback(null);
165
- }
166
- }
167
- getPreviouslyMatchedUrls() {
168
- return new Promise((resolve, reject) => {
169
- this.db.find({ type: 'matchedTorrents' }, (err, docs) => {
170
- if (err) {
171
- reject(err);
172
- }
173
- resolve(docs.reduce((matchedUrls, doc) => matchedUrls.concat(doc.urls), []));
174
- });
175
- });
176
- }
177
- getRules(query, callback) {
178
- this.queryItem('rule', query, callback);
179
- }
180
- handleNewItems({ items: feedItems, feed }) {
181
- this.getPreviouslyMatchedUrls()
182
- .then((previouslyMatchedUrls) => {
183
- const applicableRules = this.rules[feed._id];
184
- if (!applicableRules)
185
- return;
186
- const itemsMatchingRules = getItemsMatchingRules(feedItems, applicableRules, feed);
187
- const itemsToDownload = itemsMatchingRules.filter((item) => item.urls.some((url) => !previouslyMatchedUrls.includes(url)));
188
- const lastAddUrlCallback = () => {
189
- const urlsToAdd = getUrlsFromItems(itemsToDownload);
190
- this.db.update({ type: 'matchedTorrents' }, { $push: { urls: { $each: urlsToAdd } } }, { upsert: true });
191
- this.services.notificationService.addNotification(itemsToDownload.map((item) => ({
192
- id: 'notification.feed.downloaded.torrent',
193
- data: {
194
- feedLabel: item.feedLabel,
195
- ruleLabel: item.ruleLabel,
196
- title: item.matchTitle,
197
- },
198
- })));
199
- this.services.torrentService.fetchTorrentList();
200
- };
201
- itemsToDownload.forEach((item, index) => {
202
- client_1.default.addUrls(this.user, this.services, {
203
- urls: item.urls,
204
- destination: item.destination,
205
- start: item.startOnLoad,
206
- tags: item.tags,
207
- }, () => {
208
- if (index === itemsToDownload.length - 1) {
209
- lastAddUrlCallback();
210
- }
211
- this.db.update({ _id: item.ruleID }, { $inc: { count: 1 } }, { upsert: true });
212
- });
213
- });
214
- })
215
- .catch(console.error);
216
- }
217
- init() {
218
- this.feeds = [];
219
- this.rules = {};
220
- this.db.find({}, (err, docs) => {
221
- if (err) {
222
- return;
223
- }
224
- // Create two arrays, one for feeds and one for rules.
225
- const feedsSummary = docs.reduce((accumulator, doc) => {
226
- if (doc.type === 'feed' || doc.type === 'rule') {
227
- accumulator[`${doc.type}s`].push(doc);
228
- }
229
- return accumulator;
230
- }, { feeds: [], rules: [] });
231
- // Add all download rules to the local state.
232
- feedsSummary.rules.forEach((rule) => {
233
- if (this.rules[rule.feedID] == null) {
234
- this.rules[rule.feedID] = [];
235
- }
236
- this.rules[rule.feedID].push(rule);
237
- });
238
- // Initiate all feeds.
239
- feedsSummary.feeds.forEach((feed) => {
240
- this.startNewFeed(feed);
241
- });
242
- });
243
- }
244
- loadDatabase() {
245
- if (this.isDBReady)
246
- return;
247
- const db = new nedb_1.default({
248
- autoload: true,
249
- filename: path_1.default.join(config_1.default.dbPath, this.user._id, 'settings', 'feeds.db'),
250
- });
251
- this.isDBReady = true;
252
- return db;
253
- }
254
- queryItem(type, query, callback) {
255
- query = query || {};
256
- this.db.find(Object.assign(query, { type }), (err, docs) => {
257
- if (err) {
258
- callback(null, err);
259
- return;
260
- }
261
- callback(docs);
262
- });
263
- }
264
- removeItem(id, callback) {
265
- let indexToRemove = -1;
266
- const itemToRemove = this.feeds.find((feed, index) => {
267
- if (feed.options._id === id) {
268
- indexToRemove = index;
269
- return true;
270
- }
271
- return false;
272
- });
273
- if (itemToRemove != null) {
274
- itemToRemove.stopReader();
275
- this.feeds.splice(indexToRemove, 1);
276
- }
277
- this.db.remove({ _id: id }, {}, (err, docs) => {
278
- if (err) {
279
- callback(null, err);
280
- return;
281
- }
282
- callback(docs);
283
- });
284
- }
285
- startNewFeed(feedConfig) {
286
- feedConfig.onNewItems = this.handleNewItems.bind(this);
287
- this.feeds.push(new Feed_1.default(feedConfig));
288
- }
289
- }
290
- exports.default = FeedService;
@@ -1,181 +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 BaseService_1 = __importDefault(require("./BaseService"));
7
- const config_1 = __importDefault(require("../../config"));
8
- const HistoryEra_1 = __importDefault(require("../models/HistoryEra"));
9
- const historyServiceEvents_1 = __importDefault(require("../constants/historyServiceEvents"));
10
- const historySnapshotTypes_1 = __importDefault(require("../../shared/constants/historySnapshotTypes"));
11
- const methodCallUtil_1 = __importDefault(require("../util/methodCallUtil"));
12
- const objectUtil_1 = __importDefault(require("../../shared/util/objectUtil"));
13
- const transferSummaryPropMap_1 = __importDefault(require("../constants/transferSummaryPropMap"));
14
- const transferSummaryMethodCallConfig = methodCallUtil_1.default.getMethodCallConfigFromPropMap(transferSummaryPropMap_1.default);
15
- const processData = (opts, callback, data, error) => {
16
- if (error) {
17
- callback(null, error);
18
- return;
19
- }
20
- data = data.slice(data.length - config_1.default.maxHistoryStates);
21
- callback(data.reduce((accumulator, snapshot) => {
22
- accumulator.download.push(snapshot.dn);
23
- accumulator.upload.push(snapshot.up);
24
- accumulator.timestamps.push(snapshot.ts);
25
- return accumulator;
26
- }, { upload: [], download: [], timestamps: [] }));
27
- };
28
- class HistoryService extends BaseService_1.default {
29
- constructor(...serviceConfig) {
30
- super(...serviceConfig);
31
- this.errorCount = 0;
32
- this.lastSnapshots = {};
33
- this.pollTimeout = null;
34
- this.transferSummary = {};
35
- this.fetchCurrentTransferSummary = this.fetchCurrentTransferSummary.bind(this);
36
- this.handleFetchTransferSummaryError = this.handleFetchTransferSummaryError.bind(this);
37
- this.handleFetchTransferSummarySuccess = this.handleFetchTransferSummarySuccess.bind(this);
38
- this.yearSnapshot = new HistoryEra_1.default(this.user, {
39
- interval: 1000 * 60 * 60 * 24 * 7,
40
- maxTime: 0,
41
- name: 'yearSnapshot',
42
- });
43
- this.monthSnapshot = new HistoryEra_1.default(this.user, {
44
- interval: 1000 * 60 * 60 * 12,
45
- maxTime: 1000 * 60 * 60 * 24 * 365,
46
- name: 'monthSnapshot',
47
- nextEraUpdateInterval: 1000 * 60 * 60 * 24 * 7,
48
- nextEra: this.yearSnapshot,
49
- });
50
- this.weekSnapshot = new HistoryEra_1.default(this.user, {
51
- interval: 1000 * 60 * 60 * 4,
52
- maxTime: 1000 * 60 * 60 * 24 * 7 * 24,
53
- name: 'weekSnapshot',
54
- nextEraUpdateInterval: 1000 * 60 * 60 * 12,
55
- nextEra: this.monthSnapshot,
56
- });
57
- this.daySnapshot = new HistoryEra_1.default(this.user, {
58
- interval: 1000 * 60 * 60,
59
- maxTime: 1000 * 60 * 60 * 24 * 30,
60
- name: 'daySnapshot',
61
- nextEraUpdateInterval: 1000 * 60 * 60 * 4,
62
- nextEra: this.weekSnapshot,
63
- });
64
- this.hourSnapshot = new HistoryEra_1.default(this.user, {
65
- interval: 1000 * 60 * 15,
66
- maxTime: 1000 * 60 * 60 * 24,
67
- name: 'hourSnapshot',
68
- nextEraUpdateInterval: 1000 * 60 * 60,
69
- nextEra: this.daySnapshot,
70
- });
71
- this.thirtyMinSnapshot = new HistoryEra_1.default(this.user, {
72
- interval: 1000 * 20,
73
- maxTime: 1000 * 60 * 30,
74
- name: 'thirtyMinSnapshot',
75
- nextEraUpdateInterval: 1000 * 60 * 15,
76
- nextEra: this.hourSnapshot,
77
- });
78
- this.fiveMinSnapshot = new HistoryEra_1.default(this.user, {
79
- interval: 1000 * 5,
80
- maxTime: 1000 * 60 * 5,
81
- name: 'fiveMinSnapshot',
82
- nextEraUpdateInterval: 1000 * 20,
83
- nextEra: this.thirtyMinSnapshot,
84
- });
85
- this.fetchCurrentTransferSummary();
86
- }
87
- checkSnapshotDiffs() {
88
- Object.keys(historySnapshotTypes_1.default).forEach((snapshotType) => {
89
- this.getHistory({ snapshot: historySnapshotTypes_1.default[snapshotType] }, (nextSnapshot, error) => {
90
- if (error) {
91
- return;
92
- }
93
- const lastSnapshot = this.lastSnapshots[snapshotType] || {};
94
- const { timestamps = [] } = lastSnapshot;
95
- const nextLastTimestamp = timestamps[timestamps.length - 1];
96
- const prevLastTimestamp = nextSnapshot.timestamps[nextSnapshot.timestamps.length - 1];
97
- if (nextLastTimestamp !== prevLastTimestamp) {
98
- this.emit(historyServiceEvents_1.default[`${snapshotType}_SNAPSHOT_FULL_UPDATE`], {
99
- id: nextLastTimestamp,
100
- data: nextSnapshot,
101
- });
102
- }
103
- this.lastSnapshots[snapshotType] = nextSnapshot;
104
- });
105
- });
106
- }
107
- deferFetchTransferSummary(interval = config_1.default.torrentClientPollInterval || 2000) {
108
- this.pollTimeout = setTimeout(this.fetchCurrentTransferSummary, interval);
109
- }
110
- destroy() {
111
- clearTimeout(this.pollTimeout);
112
- }
113
- fetchCurrentTransferSummary() {
114
- if (this.pollTimeout != null) {
115
- clearTimeout(this.pollTimeout);
116
- }
117
- this.services.clientGatewayService
118
- .fetchTransferSummary(transferSummaryMethodCallConfig)
119
- .then(this.handleFetchTransferSummarySuccess.bind(this))
120
- .catch(this.handleFetchTransferSummaryError.bind(this));
121
- }
122
- getTransferSummary() {
123
- return {
124
- id: Date.now(),
125
- transferSummary: this.transferSummary,
126
- };
127
- }
128
- getHistory(opts = {}, callback) {
129
- const historyCallback = processData.bind(this, opts, callback);
130
- if (opts.snapshot === historySnapshotTypes_1.default.FIVE_MINUTE) {
131
- this.fiveMinSnapshot.getData(opts, historyCallback);
132
- }
133
- else if (opts.snapshot === historySnapshotTypes_1.default.THIRTY_MINUTE) {
134
- this.thirtyMinSnapshot.getData(opts, historyCallback);
135
- }
136
- else if (opts.snapshot === historySnapshotTypes_1.default.HOUR) {
137
- this.hourSnapshot.getData(opts, historyCallback);
138
- }
139
- else if (opts.snapshot === historySnapshotTypes_1.default.DAY) {
140
- this.daySnapshot.getData(opts, historyCallback);
141
- }
142
- else if (opts.snapshot === historySnapshotTypes_1.default.WEEK) {
143
- this.weekSnapshot.getData(opts, historyCallback);
144
- }
145
- else if (opts.snapshot === historySnapshotTypes_1.default.MONTH) {
146
- this.monthSnapshot.getData(opts, historyCallback);
147
- }
148
- else if (opts.snapshot === historySnapshotTypes_1.default.YEAR) {
149
- this.yearSnapshot.getData(opts, historyCallback);
150
- }
151
- }
152
- handleFetchTransferSummarySuccess(nextTransferSummary) {
153
- const summaryDiff = objectUtil_1.default.getDiff(this.transferSummary, nextTransferSummary);
154
- if (summaryDiff.length > 0) {
155
- this.emit(historyServiceEvents_1.default.TRANSFER_SUMMARY_DIFF_CHANGE, {
156
- diff: summaryDiff,
157
- id: Date.now(),
158
- });
159
- }
160
- this.errorCount = 0;
161
- this.transferSummary = nextTransferSummary;
162
- this.fiveMinSnapshot.addData({
163
- upload: nextTransferSummary.upRate,
164
- download: nextTransferSummary.downRate,
165
- });
166
- this.checkSnapshotDiffs();
167
- this.deferFetchTransferSummary();
168
- this.emit(historyServiceEvents_1.default.FETCH_TRANSFER_SUMMARY_SUCCESS);
169
- }
170
- handleFetchTransferSummaryError() {
171
- let nextInterval = config_1.default.torrentClientPollInterval || 2000;
172
- // If more than consecutive errors have occurred, then we delay the next
173
- // request.
174
- if (++this.errorCount >= 3) {
175
- nextInterval = Math.max(nextInterval + (this.errorCount * nextInterval) / 4, 1000 * 60);
176
- }
177
- this.deferFetchTransferSummary(nextInterval);
178
- this.emit(historyServiceEvents_1.default.FETCH_TRANSFER_SUMMARY_ERROR);
179
- }
180
- }
181
- exports.default = HistoryService;