diff options
Diffstat (limited to 'bot/seasons/evergreen/issues.py')
-rw-r--r-- | bot/seasons/evergreen/issues.py | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/bot/seasons/evergreen/issues.py b/bot/seasons/evergreen/issues.py index 13665782..2a31a2e1 100644 --- a/bot/seasons/evergreen/issues.py +++ b/bot/seasons/evergreen/issues.py @@ -3,6 +3,8 @@ import logging import discord from discord.ext import commands +from bot.constants import Colours + log = logging.getLogger(__name__) @@ -15,29 +17,30 @@ class Issues(commands.Cog): @commands.command(aliases=("issues",)) async def issue(self, ctx, number: int, repository: str = "seasonalbot", user: str = "python-discord"): """Command to retrieve issues from a GitHub repository.""" - url = f"https://api.github.com/repos/{user}/{repository}/issues/{number}" + api_url = f"https://api.github.com/repos/{user}/{repository}/issues/{number}" failed_status = { 404: f"Issue #{number} doesn't exist in the repository {user}/{repository}.", 403: f"Rate limit exceeded. Please wait a while before trying again!" } - async with self.bot.http_session.get(url) as r: + async with self.bot.http_session.get(api_url) as r: json_data = await r.json() response_code = r.status if response_code in failed_status: return await ctx.send(failed_status[response_code]) - issue_embed = discord.Embed(colour=0x00ff37) - issue_embed.add_field(name="Repository", value=f"[{user}/{repository}](json_data['repository_url'])", inline=False) + repo_url = f"https://github.com/{user}/{repository}" + issue_embed = discord.Embed(colour=Colours.bright_green) + issue_embed.add_field(name="Repository", value=f"[{user}/{repository}]({repo_url})", inline=False) issue_embed.add_field(name="Issue Number", value=f"#{number}", inline=False) issue_embed.add_field(name="Status", value=json_data["state"].title()) - issue_embed.add_field(name="Link", value=json_data["url"], inline=False) + issue_embed.add_field(name="Link", value=json_data["html_url"], inline=False) description = json_data["body"] if len(description) > 1024: - truncation_message = "** ...\n\nContent truncated, please follow the link for more!**" - description = f"{description[:1024 - len(truncation_message)]}{truncation_message}" + placeholder = " [...]" + description = f"{description[:1024 - len(placeholder)]}{placeholder}" issue_embed.add_field(name="Description", value=description, inline=False) |