plugin_e2ee: new format_fingerprint method to be overriden by plugin

Signed-off-by: Maxime “pep” Buquet <pep@bouah.net>
This commit is contained in:
Maxime “pep” Buquet 2022-03-21 01:11:43 +01:00
parent b2de905464
commit 433d5e6f76

View file

@ -34,7 +34,7 @@ from poezio.tabs import (
StaticConversationTab, StaticConversationTab,
) )
from poezio.plugin import BasePlugin from poezio.plugin import BasePlugin
from poezio.theming import get_theme, dump_tuple from poezio.theming import Theme, get_theme, dump_tuple
from poezio.config import config from poezio.config import config
from poezio.decorators import command_args_parser from poezio.decorators import command_args_parser
@ -273,17 +273,24 @@ class E2EEPlugin(BasePlugin):
'Info', 'Info',
) )
@staticmethod
def format_fingerprint(fingerprint: str, theme: Theme) -> str:
return fingerprint
async def _show_fingerprints(self, jid: JID) -> None: async def _show_fingerprints(self, jid: JID) -> None:
"""Display encryption fingerprints for a JID.""" """Display encryption fingerprints for a JID."""
theme = get_theme()
fprs = await self.get_fingerprints(jid) fprs = await self.get_fingerprints(jid)
if len(fprs) == 1: if len(fprs) == 1:
fingerprint = self.format_fingerprint(fprs[0], theme)
self.api.information( self.api.information(
f'Fingerprint for {jid}: {fprs[0]}', f'Fingerprint for {jid}: {fingerprint}',
'Info', 'Info',
) )
elif fprs: elif fprs:
fmt_fprs = map(lambda fp: self.format_fingerprint(fp, theme), fprs)
self.api.information( self.api.information(
'Fingerprints for %s:\n\t%s' % (jid, '\n\t'.join(fprs)), 'Fingerprints for %s:\n\t%s' % (jid, '\n\t'.join(fmt_fprs)),
'Info', 'Info',
) )
else: else: