permissions.ts 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. import config from "config";
  2. import { UserRole } from "@/modules/DataModule/models/users/UserRole";
  3. const guest = {};
  4. const user = { ...guest };
  5. const dj = { ...user };
  6. const owner = { ...dj };
  7. const moderator = {
  8. ...owner,
  9. // DataModule importJobs model
  10. "data.importJobs.create": true,
  11. "data.importJobs.findById.*": true,
  12. "data.importJobs.getData": true,
  13. "data.importJobs.deleteById.*": true,
  14. "data.importJobs.updateById.*": true,
  15. // DataModule news model
  16. "data.news.create": true,
  17. "data.news.getData": true,
  18. "data.news.updateById.*": true,
  19. "data.news.findManyById.*": true,
  20. // DataModule playlists model
  21. "data.playlists.addSongById.*": true,
  22. "data.playlists.create.admin": true,
  23. "data.playlists.findById.*": true,
  24. "data.playlists.getData": true,
  25. "data.playlists.removeSongById.*": true,
  26. "data.playlists.repositionSongById.*": true,
  27. "data.playlists.updateDisplayNameById.*": true,
  28. "data.playlists.updatePrivacyById.*": true,
  29. // DataModule punishments model
  30. "data.punishments.banIP": true,
  31. "data.punishments.findById.*": true,
  32. "data.punishments.getData": true,
  33. // DataModule reports model
  34. "data.reports.findById.*": true,
  35. "data.reports.getData": true,
  36. "data.reports.updateById.*": true,
  37. // DataModule songs model
  38. "data.songs.create": true,
  39. "data.songs.findById.*": true,
  40. "data.songs.getData": true,
  41. "data.songs.updateById.*": true,
  42. "data.songs.verifyById.*": true,
  43. // DataModule stations model
  44. "data.stations.create.official": true,
  45. "data.stations.findById.*": true,
  46. "data.stations.getData": true,
  47. "data.stations.index.adminFilter": true,
  48. "data.stations.updateById.*": true,
  49. "data.stations.findManyById.*": true,
  50. // DataModule users model
  51. "data.users.banById.*": true,
  52. "data.users.findById.*": true,
  53. "data.users.getData": true,
  54. "data.users.requestPasswordResetById.*": !!config.get("mail.enabled"),
  55. "data.users.resendVerifyEmailById.*": !!config.get("mail.enabled"),
  56. "data.users.updateById.*": true,
  57. // "data.users.findManyById.*": true,
  58. // DataModule youtubeVideos model
  59. "data.youtubeVideos.getData": true,
  60. "data.youtubeVideos.requestSet": true,
  61. // DiscogsModule
  62. "discogs.search": !!config.get("apis.discogs.enabled"),
  63. // Frontend admin views
  64. "admin.view": true,
  65. "admin.view.import": true,
  66. "admin.view.news": true,
  67. "admin.view.playlists": true,
  68. "admin.view.punishments": true,
  69. "admin.view.reports": true,
  70. "admin.view.songs": true,
  71. "admin.view.stations": true,
  72. "admin.view.users": true,
  73. "admin.view.youtubeVideos": true
  74. // // Experimental SoundCloud
  75. // ...(config.get("experimental.soundcloud")
  76. // ? {
  77. // "admin.view.soundcloudTracks": true,
  78. // "admin.view.soundcloud": true,
  79. // "soundcloud.getArtist": true
  80. // }
  81. // : {}),
  82. // // Experimental Spotify
  83. // ...(config.get("experimental.spotify")
  84. // ? {
  85. // "admin.view.spotify": true,
  86. // "spotify.getTracksFromMediaSources": true,
  87. // "spotify.getAlbumsFromIds": true,
  88. // "spotify.getArtistsFromIds": true,
  89. // "spotify.getAlternativeArtistSourcesForArtists": true,
  90. // "spotify.getAlternativeAlbumSourcesForAlbums": true,
  91. // "spotify.getAlternativeMediaSourcesForTracks": true,
  92. // "admin.view.youtubeChannels": true,
  93. // "youtube.getChannel": true
  94. // }
  95. // : {})
  96. };
  97. const admin = {
  98. ...moderator,
  99. // DataModule dataRequests model
  100. "data.dataRequests.findById.*": true,
  101. "data.dataRequests.getData": true,
  102. "data.dataRequests.resolveById.*": true,
  103. // DataModule importJobs model
  104. "data.importJobs.deleteById.*": true,
  105. // DataModule news model
  106. "data.news.deleteById.*": true,
  107. "data.news.deleteManyById.*": true,
  108. // DataModule playlists model
  109. "data.playlists.clearAndRefillById.*": true,
  110. "data.playlists.clearAndRefillAll": true,
  111. "data.playlists.createMissing": true,
  112. "data.playlists.deleteOrphaned": true,
  113. "data.playlists.deleteById.*": true,
  114. "data.playlists.requestOrphanedPlaylistSongs": true,
  115. // DataModule punishments model
  116. "data.punishments.deactivateById.*": true,
  117. // DataModule ratings model
  118. "data.ratings.recalculateAll": true,
  119. // DataModule reports model
  120. "data.reports.deleteById.*": true,
  121. // DataModule songs model
  122. "data.songs.deleteById.*": true,
  123. "data.songs.updateAll": true,
  124. // DataModule stations model
  125. "data.stations.clearEveryStationQueue": true,
  126. "data.stations.deleteById.*": true,
  127. "data.stations.deleteManyById.*": true,
  128. // DataModule users model
  129. "data.users.deleteById.*": true,
  130. "data.users.deleteSessionsById.*": true,
  131. "data.users.updateById.*": true,
  132. "data.users.deleteManyById.*": true,
  133. // DataModule youtubeApiRequests model
  134. "data.youtubeApiRequests.findById.*": true,
  135. "data.youtubeApiRequests.getData": true,
  136. "data.youtubeApiRequests.deleteAll": true,
  137. "data.youtubeApiRequests.deleteById.*": true,
  138. // DataModule youtubeVideos model
  139. "data.youtubeVideos.getMissing": true,
  140. "data.youtubeVideos.deleteById.*": true,
  141. "data.youtubeVideos.migrateV1ToV2.*": true,
  142. // Frontend admin views
  143. "admin.view.dataRequests": true,
  144. "admin.view.statistics": true,
  145. "admin.view.youtube": true,
  146. // // Experimental SoundCloud
  147. // ...(config.get("experimental.soundcloud")
  148. // ? {
  149. // "soundcloud.fetchNewApiKey": true,
  150. // "soundcloud.testApiKey": true
  151. // }
  152. // : {}),
  153. // // Experimental Spotify
  154. // ...(config.get("experimental.spotify")
  155. // ? {
  156. // "youtube.getMissingChannels": true
  157. // }
  158. // : {})
  159. "event.model.news.created": true // WIP - regular users need to be able to subscribe to certain news subscribe events
  160. };
  161. const permissions: Record<
  162. UserRole | "owner" | "dj" | "guest",
  163. Record<string, boolean>
  164. > = {
  165. guest,
  166. user,
  167. dj,
  168. owner,
  169. moderator,
  170. admin
  171. };
  172. export default permissions;