bug.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. const {MessageEmbed} = require('discord.js');
  2. function minecraft_bug(lang, msg, args, title, cmd, querystring, fragment, reaction, spoiler) {
  3. var invoke = args[0];
  4. args = args.slice(1);
  5. if ( invoke && /\d+$/.test(invoke) && !args.length ) {
  6. if ( /^\d+$/.test(invoke) ) invoke = 'MC-' + invoke;
  7. var link = 'https://bugs.mojang.com/browse/';
  8. got.get( 'https://bugs.mojang.com/rest/api/2/issue/' + encodeURIComponent( invoke ) + '?fields=summary,issuelinks,fixVersions,resolution,status', {
  9. responseType: 'json'
  10. } ).then( response => {
  11. var body = response.body;
  12. if ( response.statusCode !== 200 || !body || body['status-code'] === 404 || body.errorMessages || body.errors ) {
  13. if ( body && body.errorMessages ) {
  14. if ( body.errorMessages.includes( 'Issue Does Not Exist' ) ) {
  15. msg.reactEmoji('🤷');
  16. }
  17. else if ( body.errorMessages.includes( 'You do not have the permission to see the specified issue.' ) ) {
  18. msg.sendChannel( spoiler + lang.get('minecraft.private') + '\n<' + link + invoke + '>' + spoiler );
  19. }
  20. else {
  21. console.log( '- ' + ( response && response.statusCode ) + ': Error while getting the issue: ' + body.errorMessages.join(' - ') );
  22. msg.reactEmoji('error');
  23. }
  24. }
  25. else {
  26. console.log( '- ' + response.statusCode + ': Error while getting the issue: ' + ( body && body.message ) );
  27. if ( body && body['status-code'] === 404 ) msg.reactEmoji('error');
  28. else msg.sendChannelError( spoiler + '<' + link + invoke + '>' + spoiler );
  29. }
  30. }
  31. else {
  32. if ( !body.fields ) {
  33. msg.reactEmoji('error');
  34. }
  35. else {
  36. var bugs = body.fields.issuelinks.filter( bug => bug.outwardIssue || ( bug.inwardIssue && bug.type.name != 'Duplicate' ) );
  37. if ( bugs.length ) {
  38. var embed = new MessageEmbed();
  39. var extrabugs = [];
  40. bugs.forEach( bug => {
  41. var ward = ( bug.outwardIssue ? 'outward' : 'inward' );
  42. var issue = bug[ward + 'Issue'];
  43. var name = bug.type[ward] + ' ' + issue.key;
  44. var value = issue.fields.status.name + ': [' + issue.fields.summary.escapeFormatting() + '](' + link + issue.key + ')';
  45. if ( embed.fields.length < 25 ) embed.addField( name, value );
  46. else extrabugs.push({name,value,inline:false});
  47. } );
  48. if ( extrabugs.length ) embed.setFooter( lang.get('minecraft.more').replaceSave( '%s', extrabugs.length ) );
  49. }
  50. var status = '**' + ( body.fields.resolution ? body.fields.resolution.name : body.fields.status.name ) + ':** ';
  51. var fixed = '';
  52. if ( body.fields.resolution && body.fields.fixVersions && body.fields.fixVersions.length ) {
  53. fixed = '\n' + lang.get('minecraft.fixed') + ' ' + body.fields.fixVersions.map( v => v.name ).join(', ');
  54. }
  55. msg.sendChannel( spoiler + status + body.fields.summary.escapeFormatting() + '\n<' + link + body.key + '>' + fixed + spoiler, {embed} );
  56. }
  57. }
  58. }, error => {
  59. console.log( '- Error while getting the issue: ' + error );
  60. msg.sendChannelError( spoiler + '<' + link + invoke + '>' + spoiler );
  61. } ).finally( () => {
  62. if ( reaction ) reaction.removeEmoji();
  63. } );
  64. }
  65. else if ( invoke && invoke.toLowerCase() === 'version' && args.length && args.join(' ').length < 100 ) {
  66. var jql = 'fixVersion="' + args.join(' ').replace( /(["\\])/g, '\\$1' ).toSearch() + '"+order+by+key';
  67. var link = 'https://bugs.mojang.com/issues/?jql=' + jql;
  68. got.get( 'https://bugs.mojang.com/rest/api/2/search?fields=summary,resolution,status&jql=' + jql + '&maxResults=25', {
  69. responseType: 'json'
  70. } ).then( response => {
  71. var body = response.body;
  72. if ( response.statusCode !== 200 || !body || body['status-code'] === 404 || body.errorMessages || body.errors ) {
  73. if ( body && body.errorMessages ) {
  74. if ( body.errorMessages.includes( 'The value \'' + args.join(' ') + '\' does not exist for the field \'fixVersion\'.' ) ) {
  75. msg.reactEmoji('🤷');
  76. }
  77. else {
  78. console.log( '- ' + response.statusCode + ': Error while getting the issues: ' + body.errorMessages.join(' - ') );
  79. msg.reactEmoji('error');
  80. }
  81. }
  82. else {
  83. console.log( '- ' + response.statusCode + ': Error while getting the issues: ' + ( body && body.message ) );
  84. if ( body && body['status-code'] === 404 ) msg.reactEmoji('error');
  85. else msg.sendChannelError( spoiler + '<' + link + '>' + spoiler );
  86. }
  87. }
  88. else {
  89. if ( !body.issues ) {
  90. msg.reactEmoji('error');
  91. }
  92. else {
  93. if ( body.total > 0 ) {
  94. var embed = new MessageEmbed();
  95. body.issues.forEach( bug => {
  96. var status = ( bug.fields.resolution ? bug.fields.resolution.name : bug.fields.status.name );
  97. var value = status + ': [' + bug.fields.summary.escapeFormatting() + '](https://bugs.mojang.com/browse/' + bug.key + ')';
  98. embed.addField( bug.key, value );
  99. } );
  100. if ( body.total > 25 ) embed.setFooter( lang.get('minecraft.more').replaceSave( '%s', body.total - 25 ) );
  101. }
  102. var total = '**' + args.join(' ') + ':** ' + lang.get('minecraft.total').replaceSave( '%s', body.total );
  103. msg.sendChannel( spoiler + total + '\n<' + link + '>' + spoiler, {embed} );
  104. }
  105. }
  106. }, error => {
  107. console.log( '- Error while getting the issues: ' + error );
  108. msg.sendChannelError( spoiler + '<' + link + '>' + spoiler );
  109. } ).finally( () => {
  110. if ( reaction ) reaction.removeEmoji();
  111. } );
  112. }
  113. else {
  114. msg.notMinecraft = true;
  115. this.WIKI.gamepedia(lang, msg, title, lang.get('minecraft.link'), cmd, reaction, spoiler, querystring, fragment);
  116. }
  117. }
  118. module.exports = {
  119. name: 'bug',
  120. run: minecraft_bug
  121. };