diff options
author | 2024-03-31 19:35:15 +0100 | |
---|---|---|
committer | 2024-03-31 19:35:15 +0100 | |
commit | 4c8ad26ae8f143fa3f249f72ab1b05dda5f890a6 (patch) | |
tree | 2372b0b882d2702125b28deb321b6608c69a6f92 | |
parent | add new API functions for pod log fetching (diff) |
add new pods logs command
-rw-r--r-- | arthur/exts/kubernetes/pods.py | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/arthur/exts/kubernetes/pods.py b/arthur/exts/kubernetes/pods.py index f69e77e..57cb89a 100644 --- a/arthur/exts/kubernetes/pods.py +++ b/arthur/exts/kubernetes/pods.py @@ -5,6 +5,8 @@ from datetime import datetime import humanize from discord.ext import commands +from kubernetes_asyncio.client.rest import ApiException +from loguru import logger from tabulate import tabulate from arthur.apis.kubernetes import pods @@ -94,6 +96,46 @@ class Pods(commands.Cog): return None + @pods_cmd.command(name="logs", aliases=["log", "tail"]) + async def pods_logs( + self, ctx: commands.Context, pod_name: str, namespace: str = "default", lines: int = 15 + ) -> None: + """ + Tail the logs of a pod in the selected namespace (defaults to default). + + We also support the syntax of `deploy/<deployment-name>` to get the logs of the first pod associated with the deployment. + """ + if pod_name.startswith("deploy/"): + pod_names = await pods.get_pod_names_from_deployment( + namespace, pod_name.removeprefix("deploy/") + ) + logger.debug(f"Resolved deployment pod name to {pod_name}") + else: + pod_names = [pod_name] + + if pod_names is None: + return await ctx.send( + generate_error_message(description="No pods found for the provided deployment.") + ) + + for pod in pod_names: + try: + logs = await pods.tail_pod(namespace, pod, lines=lines) + except ApiException as e: + return await ctx.send(generate_error_message(description=str(e))) + + if len(logs) == 0: + return await ctx.send( + generate_error_message(description="No logs found for the pod.") + ) + + if len(logs) > MAX_MESSAGE_LENGTH - 100: + logs = logs[-MAX_MESSAGE_LENGTH:] + + await ctx.send(f"**Logs for pod `{pod}` in namespace `{namespace}`**\n```\n{logs}```") + + return None + async def setup(bot: KingArthur) -> None: """Add the extension to the bot.""" |