diff --git a/commands/bgg-collection.js b/commands/bgg-collection.js index 6b874a1..6b739e3 100644 --- a/commands/bgg-collection.js +++ b/commands/bgg-collection.js @@ -131,7 +131,7 @@ module.exports = { .setTitle(username + '\'s collection') .setURL(collection_url) .setDescription(collection_url) - .setAuthor({ name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() }) + .setAuthor(user ? { name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() } : null) .addFields( { name: 'Total', @@ -176,7 +176,7 @@ module.exports = { } if (isObject && !hasErrors && result.items['$'].totalitems > 0) { - interaction.editReply({ embeds: [this.collectionToEmbed(result, username, interaction.member.user)] }); + interaction.editReply({ embeds: [this.collectionToEmbed(result, username, interaction?.member?.user)] }); } else { interaction.editReply(`No results found for "${username}".`); diff --git a/commands/bgg-search.js b/commands/bgg-search.js index acbc9d7..34c02fd 100644 --- a/commands/bgg-search.js +++ b/commands/bgg-search.js @@ -17,7 +17,7 @@ module.exports = { value: 'suggest', }) ), - cache_ttl: 1000 * 60 * 60 * 24, + cache_ttl: 1000 * 60 * 60 * 24 * 7, /** * Preforms BGG API search call. * @return {Promise} @@ -165,7 +165,7 @@ module.exports = { .setURL(`https://boardgamegeek.com/${item['$'].type}/${item['$'].id}`) .setThumbnail(item.thumbnail[0]) .setDescription(he.decode(item.description[0]).substring(0, 200)+'...') - .setAuthor({ name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() }) + .setAuthor(user ? { name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() } : null) .addFields( { name: ':hash: Number of Players', @@ -189,7 +189,7 @@ module.exports = { if(bggSearchResult.found) { const result = await this.bggThing(bggSearchResult.thing_id); await interaction.reply({ - embeds: [this.itemToSearchEmbed(result.items.item[0], interaction.member.user)] + embeds: [this.itemToSearchEmbed(result.items.item[0], interaction?.member?.user)] }); } else { @@ -214,7 +214,7 @@ module.exports = { .setThumbnail(item.thumbnail[0]) .setDescription(he.decode(item.description[0]).substring(0, 200)+'...') .setFooter({ text: '( 👍 Interested | 📖 Can Teach | ❌ End Suggestion )'}) - .setAuthor({ name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() }) + .setAuthor(user ? { name: user.username, url: user.avatarURL(), iconURL: user.displayAvatarURL() } : null) .addFields( { name: ':hash: Number of Players', @@ -250,7 +250,7 @@ module.exports = { if(bggSearchResult.found) { this.bggThing(bggSearchResult.thing_id) .then(result => { - let embed = this.itemToSuggestEmbed(result.items.item[0], interaction.member.user); + let embed = this.itemToSuggestEmbed(result.items.item[0], interaction?.member?.user); interaction.reply({ embeds: [embed], fetchReply: true }).then(embedMessage => { try { embedMessage.react("👍"); @@ -312,7 +312,7 @@ module.exports = { }); const deleteFilter = (reaction, user) => { - return reaction.emoji.name == '❌' && user.id === interaction.member.user.id; + return reaction.emoji.name == '❌' && user.id === interaction?.member?.user?.id; }; const deleteCollector = embedMessage.createReactionCollector({ filter: deleteFilter }); deleteCollector.on('collect', () => { diff --git a/package.json b/package.json index b5b1cc0..97f3df6 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "discord-bgg-bot", - "version": "2.1.4", + "version": "2.1.5", "description": "Board Game Geek Discord Bot", "main": "index.js", "scripts": {