diff options
author | 2024-03-30 21:11:58 +0000 | |
---|---|---|
committer | 2024-03-30 21:11:58 +0000 | |
commit | 46a3f6335c4ef94c75e102ed2fda3b63c98f039a (patch) | |
tree | 060ea34979a05d61a11aefba32e9b433e0d63e73 /arthur/exts/kubernetes/pods.py | |
parent | Run ruff format (diff) |
handle pod lists over 4,000 characters
Diffstat (limited to 'arthur/exts/kubernetes/pods.py')
-rw-r--r-- | arthur/exts/kubernetes/pods.py | 66 |
1 files changed, 40 insertions, 26 deletions
diff --git a/arthur/exts/kubernetes/pods.py b/arthur/exts/kubernetes/pods.py index d52a439..20b4133 100644 --- a/arthur/exts/kubernetes/pods.py +++ b/arthur/exts/kubernetes/pods.py @@ -9,6 +9,24 @@ from arthur.apis.kubernetes import pods from arthur.bot import KingArthur from arthur.utils import generate_error_message +MAX_MESSAGE_LENGTH = 4000 + + +def tabulate_pod_data(data: list[list[str]]) -> str: + """Tabulate the pod data to be sent to Discord.""" + table = tabulate( + data, + headers=["Status", "Pod", "Phase", "IP", "Node"], + tablefmt="psql", + colalign=("center", "left", "center", "center", "center"), + ) + + return dedent(f""" + ``` + {table} + ``` + """) + class Pods(commands.Cog): """Commands for working with Kubernetes Pods.""" @@ -26,51 +44,47 @@ class Pods(commands.Cog): """List pods in the selected namespace (defaults to default).""" pod_list = await pods.list_pods(namespace) - table_data = [] - if len(pod_list.items) == 0: return await ctx.send( generate_error_message(description="No pods found, check the namespace exists.") ) + tables = [] + for pod in pod_list.items: match pod.status.phase: case "Running": - emote = ":green_circle:" + emote = "\N{LARGE GREEN CIRCLE}" case "Pending": - emote = ":yellow_circle:" + emote = "\N{LARGE YELLOW CIRCLE}" case "Succeeded": - emote = ":white_check_mark:" + emote = "\N{WHITE HEAVY CHECK MARK}" case "Failed": - emote = ":x:" + emote = "\N{CROSS MARK}" case "Unknown": - emote = ":question:" + emote = "\N{WHITE QUESTION MARK ORNAMENT}" case _: - emote = ":grey_question:" + emote = "\N{BLACK QUESTION MARK ORNAMENT}" - table_data.append([ + table_data = [ emote, pod.metadata.name, pod.status.phase, pod.status.pod_ip, pod.spec.node_name, - ]) - - table = tabulate( - table_data, - headers=["Status", "Pod", "Phase", "IP", "Node"], - tablefmt="psql", - colalign=("center", "left", "center", "center", "center"), - ) - - return_message = dedent(""" - **Pods in namespace `{0}`** - ``` - {1} - ``` - """) - - await ctx.send(return_message.format(namespace, table)) + ] + + if len(tabulate_pod_data(tables[-1] + [table_data])) > MAX_MESSAGE_LENGTH: + tables.append([]) + tables[-1].append(table_data) + else: + tables[-1].append(table_data) + + await ctx.send(f"**Pods in namespace `{namespace}`**") + + for table in tables: + await ctx.send(tabulate_pod_data(table)) + return None |