changeset 3960:4836b81c5f31

plugin XEP-0373: minor renaming + set `gpg_provider` in client: - `sat` and `self.__sat` have been renamed to `host` and `self.host` for consistency with other plugins. - `gpg_provider` is set in client while profile is connecting, so the instance is easily accessible to plugins depending on XEP-0373 rel 381
author Goffi <goffi@goffi.org>
date Sun, 30 Oct 2022 01:06:32 +0200 (2022-10-29)
parents da0e772881c3
children a15c171836bb
files sat/plugins/plugin_xep_0373.py
diffstat 1 files changed, 21 insertions(+), 18 deletions(-) [+]
line wrap: on
line diff
--- a/sat/plugins/plugin_xep_0373.py	Fri Oct 28 18:47:17 2022 +0200
+++ b/sat/plugins/plugin_xep_0373.py	Sun Oct 30 01:06:32 2022 +0200
@@ -1004,23 +1004,23 @@
     Implementation of XEP-0373: OpenPGP for XMPP under namespace ``urn:xmpp:openpgp:0``.
     """
 
-    def __init__(self, sat: SAT) -> None:
+    def __init__(self, host: SAT) -> None:
         """
         @param sat: The SAT instance.
         """
 
-        self.__sat = sat
+        self.host = host
 
         # Add configuration option to choose between manual trust and BTBV as the trust
         # model
-        sat.memory.updateParams(DEFAULT_TRUST_MODEL_PARAM)
+        host.memory.updateParams(DEFAULT_TRUST_MODEL_PARAM)
 
-        self.__xep_0045 = cast(Optional[XEP_0045], sat.plugins.get("XEP-0045"))
-        self.__xep_0060 = cast(XEP_0060, sat.plugins["XEP-0060"])
+        self.__xep_0045 = cast(Optional[XEP_0045], host.plugins.get("XEP-0045"))
+        self.__xep_0060 = cast(XEP_0060, host.plugins["XEP-0060"])
 
         self.__storage: Dict[str, persistent.LazyPersistentBinaryDict] = {}
 
-        xep_0163 = cast(XEP_0163, sat.plugins["XEP-0163"])
+        xep_0163 = cast(XEP_0163, host.plugins["XEP-0163"])
         xep_0163.addPEPEvent(
             "OX_PUBLIC_KEYS_LIST",
             PUBLIC_KEYS_LIST_NODE,
@@ -1029,6 +1029,9 @@
             )
         )
 
+    async def profileConnecting(self, client):
+        client.gpg_provider = get_gpg_provider(self.host, client)
+
     async def profileConnected(  # pylint: disable=invalid-name
         self,
         client: SatXMPPClient
@@ -1058,7 +1061,7 @@
         @param profile: The profile this event belongs to.
         """
 
-        client = self.__sat.getClient(profile)
+        client = self.host.getClient(profile)
 
         sender = cast(jid.JID, items_event.sender)
         items = cast(List[domish.Element], items_event.items)
@@ -1156,7 +1159,7 @@
         @return: The set of public keys available for this JID.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         return gpg_provider.list_public_keys(f"xmpp:{jid.userhost()}")
 
@@ -1167,7 +1170,7 @@
         @return: The set of secret keys available for this JID.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         return gpg_provider.list_secret_keys(f"xmpp:{client.jid.userhost()}")
 
@@ -1180,7 +1183,7 @@
         @return: The new key.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         secret_key = gpg_provider.create_key(f"xmpp:{client.jid.userhost()}")
 
@@ -1308,7 +1311,7 @@
         @return: The ``<openpgp/>`` element.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         # TODO: I'm not sure whether we want to sign with all keys by default or choose
         # just one key/a subset of keys to sign with.
@@ -1369,7 +1372,7 @@
             the calling code.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         decryption_keys = set(filter(
             lambda secret_key: gpg_provider.can_encrypt(secret_key.public_key),
@@ -1457,7 +1460,7 @@
         @raise XMPPInteractionFailed: if any interaction via XMPP failed.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         packet = gpg_provider.export_public_key(public_key)
 
@@ -1561,7 +1564,7 @@
         @raise XMPPInteractionFailed: if any interaction via XMPP failed.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         node = f"urn:xmpp:openpgp:0:public-keys:{fingerprint}"
 
@@ -1738,7 +1741,7 @@
         """
 
         try:
-            infos = cast(DiscoInfo, await self.__sat.memory.disco.getInfos(
+            infos = cast(DiscoInfo, await self.host.memory.disco.getInfos(
                 client,
                 client.jid.userhostJID()
             ))
@@ -1813,7 +1816,7 @@
         @raise XMPPInteractionFailed: if any interaction via XMPP failed.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         await self.__prepare_secret_key_synchronization(client)
 
@@ -1901,7 +1904,7 @@
         @raise DecryptionFailed: on decryption failure.
         """
 
-        gpg_provider = get_gpg_provider(self.__sat, client)
+        gpg_provider = get_gpg_provider(self.host, client)
 
         return gpg_provider.restore_secret_keys(gpg_provider.decrypt_symmetrically(
             ciphertext,
@@ -2045,7 +2048,7 @@
 
             return {}
 
-        submit_id = self.__sat.registerCallback(callback, with_data=True, one_shot=True)
+        submit_id = self.host.registerCallback(callback, with_data=True, one_shot=True)
 
         result = xml_tools.XMLUI(
             panel_type=C.XMLUI_FORM,