guilds.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. const cheerio = require('cheerio');
  2. const {defaultPermissions} = require('../util/default.json');
  3. const {settingsData, createNotice} = require('./util.js');
  4. const forms = {
  5. settings: require('./settings.js').get,
  6. verification: require('./verification.js').get,
  7. rcscript: require('./rcscript.js').get
  8. };
  9. const DiscordOauth2 = require('discord-oauth2');
  10. const oauth = new DiscordOauth2( {
  11. clientId: process.env.bot,
  12. clientSecret: process.env.secret,
  13. redirectUri: process.env.dashboard
  14. } );
  15. const file = require('fs').readFileSync('./dashboard/index.html');
  16. /**
  17. * Let a user view settings
  18. * @param {import('http').ServerResponse} res - The server response
  19. * @param {String} state - The user state
  20. * @param {URL} reqURL - The used url
  21. * @param {String} [action] - The action the user made
  22. * @param {String[]} [actionArgs] - The arguments for the action
  23. */
  24. function dashboard_guilds(res, state, reqURL, action, actionArgs) {
  25. reqURL.pathname = reqURL.pathname.replace( /^(\/(?:guild\/\d+(?:\/(?:settings|verification|rcscript)(?:\/(?:\d+|new))?)?)?)(?:\/.*)?$/, '$1' );
  26. var args = reqURL.pathname.split('/');
  27. args = reqURL.pathname.split('/');
  28. var settings = settingsData.get(state);
  29. var $ = cheerio.load(file);
  30. if ( process.env.READONLY ) createNotice($, 'readonly');
  31. if ( action ) createNotice($, action, actionArgs);
  32. $('head').append(
  33. $('<script>').text(`history.replaceState(null, null, '${reqURL.pathname}');`)
  34. );
  35. $('#logout img').attr('src', settings.user.avatar);
  36. $('#logout span').text(`${settings.user.username} #${settings.user.discriminator}`);
  37. $('.guild#invite a').attr('href', oauth.generateAuthUrl( {
  38. scope: ['identify', 'guilds', 'bot'],
  39. permissions: defaultPermissions, state
  40. } ));
  41. $('.guild#refresh a').attr('href', '/refresh?return=' + reqURL.pathname);
  42. if ( settings.guilds.isMember.size ) {
  43. $('<div class="guild">').append(
  44. $('<div class="separator">')
  45. ).insertBefore('.guild#last-separator');
  46. settings.guilds.isMember.forEach( guild => {
  47. $('<div class="guild">').attr('id', guild.id).append(
  48. $('<div class="bar">'),
  49. $('<a>').attr('href', `/guild/${guild.id}/settings`).attr('alt', guild.name).append(
  50. ( guild.icon ?
  51. $('<img class="avatar">').attr('src', `${guild.icon}?size=64`).attr('alt', guild.name)
  52. : $('<div class="avatar noicon">').text(guild.acronym) )
  53. )
  54. ).insertBefore('.guild#last-separator');
  55. } );
  56. }
  57. if ( settings.guilds.notMember.size ) {
  58. $('<div class="guild">').append(
  59. $('<div class="separator">')
  60. ).insertBefore('.guild#last-separator');
  61. settings.guilds.notMember.forEach( guild => {
  62. $('<div class="guild">').attr('id', guild.id).append(
  63. $('<div class="bar">'),
  64. $('<a>').attr('href', `/guild/${guild.id}`).attr('alt', guild.name).append(
  65. ( guild.icon ?
  66. $('<img class="avatar">').attr('src', `${guild.icon}?size=64`).attr('alt', guild.name)
  67. : $('<div class="avatar noicon">').text(guild.acronym) )
  68. )
  69. ).insertBefore('.guild#last-separator');
  70. } );
  71. }
  72. if ( args[1] === 'guild' ) {
  73. let id = args[2];
  74. $(`.guild#${id}`).addClass('selected');
  75. if ( settings.guilds.isMember.has(id) ) {
  76. let guild = settings.guilds.isMember.get(id);
  77. $('head title').text(`${guild.name} – ` + $('head title').text());
  78. $('<script>').text(`const isPatreon = ${guild.patreon};`).insertBefore('script#indexjs');
  79. $('.channel#settings').attr('href', `/guild/${guild.id}/settings`);
  80. $('.channel#verification').attr('href', `/guild/${guild.id}/verification`);
  81. $('.channel#rcscript').attr('href', `/guild/${guild.id}/rcscript`);
  82. if ( args[3] === 'settings' ) return forms.settings(res, $, guild, args);
  83. if ( args[3] === 'verification' ) return forms.verification(res, $, guild, args);
  84. if ( args[3] === 'rcscript' ) return forms.rcscript(res, $, guild, args);
  85. return forms.settings(res, $, guild, args);
  86. }
  87. else if ( settings.guilds.notMember.has(id) ) {
  88. let guild = settings.guilds.notMember.get(id);
  89. $('head title').text(`${guild.name} – ` + $('head title').text());
  90. res.setHeader('Set-Cookie', [`guild="${guild.id}/settings"; HttpOnly; Path=/`]);
  91. let url = oauth.generateAuthUrl( {
  92. scope: ['identify', 'guilds', 'bot'],
  93. permissions: defaultPermissions,
  94. guildId: guild.id, state
  95. } );
  96. $('<a>').attr('href', url).text(guild.name).appendTo('#text .description');
  97. }
  98. else {
  99. $('head title').text('Unknown Server – ' + $('head title').text());
  100. $('#text .description').text('You are missing the <code>MANAGE_GUILD</code> permission.');
  101. }
  102. }
  103. else {
  104. $('head title').text('Server Selector – ' + $('head title').text());
  105. $('#channellist').empty();
  106. $('#text .description').text('This is a list of all servers you can change settings on. Please select a server:');
  107. if ( settings.guilds.isMember.size ) {
  108. $('<h2 id="with-wikibot">').text('Server with Wiki-Bot').appendTo('#text');
  109. $('<a class="channel">').attr('href', '#with-wikibot').append(
  110. $('<img>').attr('src', '/src/channel.svg'),
  111. $('<div>').text('Server with Wiki-Bot')
  112. ).appendTo('#channellist');
  113. $('<div class="server-selector" id="isMember">').appendTo('#text');
  114. settings.guilds.isMember.forEach( guild => {
  115. $('<a class="server">').attr('href', `/guild/${guild.id}/settings`).append(
  116. ( guild.icon ?
  117. $('<img class="avatar">').attr('src', `${guild.icon}?size=256`).attr('alt', guild.name)
  118. : $('<div class="avatar noicon">').text(guild.acronym) ),
  119. $('<div class="server-name description">').text(guild.name)
  120. ).appendTo('.server-selector#isMember');
  121. } );
  122. }
  123. if ( settings.guilds.notMember.size ) {
  124. $('<h2 id="without-wikibot">').text('Server without Wiki-Bot').appendTo('#text');
  125. $('<a class="channel">').attr('href', '#without-wikibot').append(
  126. $('<img>').attr('src', '/src/channel.svg'),
  127. $('<div>').text('Server without Wiki-Bot')
  128. ).appendTo('#channellist');
  129. $('<div class="server-selector" id="notMember">').appendTo('#text');
  130. settings.guilds.notMember.forEach( guild => {
  131. $('<a class="server">').attr('href', `/guild/${guild.id}`).append(
  132. ( guild.icon ?
  133. $('<img class="avatar">').attr('src', `${guild.icon}?size=256`).attr('alt', guild.name)
  134. : $('<div class="avatar noicon">').text(guild.acronym) ),
  135. $('<div class="server-name description">').text(guild.name)
  136. ).appendTo('.server-selector#notMember');
  137. } );
  138. }
  139. if ( !settings.guilds.count ) {
  140. $('#text .description').text('You currently don\'t have the MANAGE_GUILD permission on any servers, are you logged into the correct account?');
  141. $('<a class="channel">').attr('href', oauth.generateAuthUrl( {
  142. scope: ['identify', 'guilds'],
  143. prompt: 'consent', state
  144. } )).append(
  145. $('<img>').attr('src', '/src/channel.svg'),
  146. $('<div>').text('Switch accounts')
  147. ).appendTo('#channellist');
  148. }
  149. }
  150. let body = $.html();
  151. res.writeHead(200, {'Content-Length': body.length});
  152. res.write( body );
  153. return res.end();
  154. }
  155. module.exports = dashboard_guilds;