diff options
| author | 2019-07-22 21:09:03 -0400 | |
|---|---|---|
| committer | 2019-07-22 21:21:05 -0400 | |
| commit | 33fc6c798d6b4e32d028e7a506d056782b15ce12 (patch) | |
| tree | ca630a87fe8ba9f347ff2b82c40a35be865f0fe9 /bot/seasons/evergreen/issues.py | |
| parent | Apply suggestions from code review (diff) | |
Additional review comment resolution
* Remove duplicate easter egg facts, fix punctuation
* Simplify egg fact JSON load
* Simplify egg fact embed generation
* Simplify issues command, remove redundant calls, and make some variables more explicit
* Truncate issue body if its length is greater than 1024 characters (embed field limitation)
Co-Authored-By: Mark <[email protected]>
Diffstat (limited to 'bot/seasons/evergreen/issues.py')
| -rw-r--r-- | bot/seasons/evergreen/issues.py | 35 |
1 files changed, 22 insertions, 13 deletions
diff --git a/bot/seasons/evergreen/issues.py b/bot/seasons/evergreen/issues.py index c6dbe344..04531c54 100644 --- a/bot/seasons/evergreen/issues.py +++ b/bot/seasons/evergreen/issues.py @@ -16,23 +16,32 @@ class Issues(commands.Cog): 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}" - status = {"404": f"Issue #{str(number)} doesn't exist in the repository {user}/{repository}.", - "403": f"Rate limit exceeded. Please wait a while before trying again!"} + 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: json_data = await r.json() + response_code = r.status - if str(r.status) in status: - return await ctx.send(status.get(str(r.status))) - - valid = discord.Embed(colour=0x00ff37) - valid.add_field(name="Repository", value=f"{user}/{repository}", inline=False) - valid.add_field(name="Issue Number", value=f"#{number}", inline=False) - valid.add_field(name="Status", value=json_data["state"].title()) - valid.add_field(name="Link", value=url, inline=False) - if len(json_data.get("body")) < 1024: - valid.add_field(name="Description", value=json_data.get("body"), inline=False) - await ctx.send(embed=valid) + 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}", 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=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}" + + issue_embed.add_field(name="Description", value=description, inline=False) + + await ctx.send(embed=issue_embed) def setup(bot): |