@jesec/flood 0.0.0-master.bf6f05c → 0.0.0-master.c0cce62

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