annotate libervia/backend/plugins/plugin_exp_gre.py @ 4346:62746042e6d9

plugin gre encrypter: implement GRE Encrypter: OpenPGP: rel 455
author Goffi <goffi@goffi.org>
date Mon, 13 Jan 2025 01:23:22 +0100
parents 95f8309f86cf
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4344
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
1 #!/usr/bin/env python3
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
2
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
3 # Libervia plugin
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
4 # Copyright (C) 2009-2025 Jérôme Poisson (goffi@goffi.org)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
5
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
6 # This program is free software: you can redistribute it and/or modify
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
7 # it under the terms of the GNU Affero General Public License as published by
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
8 # the Free Software Foundation, either version 3 of the License, or
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
9 # (at your option) any later version.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
10
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
11 # This program is distributed in the hope that it will be useful,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
14 # GNU Affero General Public License for more details.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
15
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
16 # You should have received a copy of the GNU Affero General Public License
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
18
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
19 from abc import ABC, abstractmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
20 from typing import Final, TYPE_CHECKING, Self, Type, cast
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
21
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
22 from twisted.internet import defer
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
23 from twisted.words.protocols.jabber import jid, error as jabber_error
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
24 from twisted.words.protocols.jabber import xmlstream
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
25 from twisted.words.protocols.jabber.xmlstream import XMPPHandler
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
26 from twisted.words.xish import domish
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
27 from wokkel import data_form, disco, iwokkel
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
28 from zope.interface import implementer
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
29
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
30 from libervia.backend.core import exceptions
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
31 from libervia.backend.core.constants import Const as C
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
32 from libervia.backend.core.core_types import SatXMPPEntity
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
33 from libervia.backend.core.i18n import _
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
34 from libervia.backend.core.log import getLogger
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
35 from libervia.backend.plugins.plugin_xep_0106 import XEP_0106
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
36 from libervia.backend.tools import xml_tools
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
37
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
38 if TYPE_CHECKING:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
39 from libervia.backend.core.main import LiberviaBackend
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
40
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
41 log = getLogger(__name__)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
42
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
43
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
44 PLUGIN_INFO = {
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
45 C.PI_NAME: "Gateway Relayer Encryption",
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
46 C.PI_IMPORT_NAME: "GRE",
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
47 C.PI_TYPE: "XEP",
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
48 C.PI_MODES: C.PLUG_MODE_BOTH,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
49 C.PI_PROTOCOLS: [],
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
50 C.PI_DEPENDENCIES: ["XEP-0106"],
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
51 C.PI_RECOMMENDATIONS: [],
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
52 C.PI_MAIN: "GRE",
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
53 C.PI_HANDLER: "yes",
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
54 C.PI_DESCRIPTION: _(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
55 "Handle formatting and encryption to support end-to-end encryption with gateways."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
56 ),
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
57 }
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
58
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
59 NS_GRE_PREFIX: Final = "urn:xmpp:gre:"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
60 NS_GRE: Final = f"{NS_GRE_PREFIX}0"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
61 NS_GRE_FORMATTER_PREFIX: Final = f"{NS_GRE_PREFIX}formatter:"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
62 NS_GRE_ENCRYPTER_PREFIX: Final = f"{NS_GRE_PREFIX}encrypter:"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
63 NS_GRE_DATA: Final = f"{NS_GRE_PREFIX}data"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
64
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
65 IQ_DATA_REQUEST = C.IQ_GET + '/data[@xmlns="' + NS_GRE + '"]'
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
66
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
67
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
68 class Formatter(ABC):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
69
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
70 formatters_classes: dict[str, Type[Self]] = {}
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
71 name: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
72 namespace: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
73 _instance: Self | None = None
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
74
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
75 def __init_subclass__(cls, **kwargs) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
76 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
77 Registers the subclass in the formatters dictionary.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
78
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
79 @param kwargs: Additional keyword arguments.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
80 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
81 assert cls.name and cls.namespace, "name and namespace must be set"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
82 super().__init_subclass__(**kwargs)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
83 cls.formatters_classes[cls.namespace] = cls
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
84
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
85 def __init__(self, host: "LiberviaBackend") -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
86 assert self.__class__._instance is None, "Formatter class must be singleton."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
87 self.__class__._instance = self
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
88 self.host = host
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
89
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
90 @classmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
91 def get_instance(cls) -> Self:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
92 if cls._instance is None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
93 raise exceptions.InternalError("Formatter instance should be set.")
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
94 return cls._instance
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
95
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
96 @abstractmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
97 async def format(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
98 self,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
99 client: SatXMPPEntity,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
100 recipient_id: str,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
101 message_elt: domish.Element,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
102 encryption_data_form: data_form.Form,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
103 ) -> bytes:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
104 raise NotImplementedError
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
105
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
106
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
107 class Encrypter(ABC):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
108
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
109 encrypters_classes: dict[str, Type[Self]] = {}
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
110 name: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
111 namespace: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
112 _instance: Self | None = None
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
113
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
114 def __init_subclass__(cls, **kwargs) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
115 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
116 Registers the subclass in the encrypters dictionary.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
117
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
118 @param kwargs: Additional keyword arguments.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
119 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
120 assert cls.name and cls.namespace, "name and namespace must be set"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
121 super().__init_subclass__(**kwargs)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
122 cls.encrypters_classes[cls.namespace] = cls
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
123
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
124 def __init__(self, host: "LiberviaBackend") -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
125 assert self.__class__._instance is None, "Encrypter class must be singleton."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
126 self.__class__._instance = self
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
127 self.host = host
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
128
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
129 @classmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
130 def get_instance(cls) -> Self:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
131 if cls._instance is None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
132 raise exceptions.InternalError("Encrypter instance should be set.")
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
133 return cls._instance
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
134
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
135 @abstractmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
136 async def encrypt(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
137 self,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
138 client: SatXMPPEntity,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
139 recipient_id: str,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
140 message_elt: domish.Element,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
141 formatted_payload: bytes,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
142 encryption_data_form: data_form.Form,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
143 ) -> str:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
144 raise NotImplementedError
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
145
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
146
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
147 class GetDataHandler(ABC):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
148 gre_formatters: list[str] = []
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
149 gre_encrypters: list[str] = []
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
150
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
151 def __init_subclass__(cls, **kwargs):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
152 super().__init_subclass__(**kwargs)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
153 if not cls.gre_formatters or not cls.gre_encrypters:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
154 raise TypeError(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
155 f'{cls.__name__} must define "gre_formatters" and "gre_encrypters"'
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
156 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
157
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
158 @abstractmethod
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
159 async def on_relayed_encryption_data(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
160 self, client: SatXMPPEntity, iq_elt: domish.Element, form: data_form.Form
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
161 ) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
162 raise NotImplementedError
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
163
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
164
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
165 class GRE:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
166 namespace = NS_GRE
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
167
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
168 def __init__(self, host: "LiberviaBackend") -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
169 log.info(f"plugin {PLUGIN_INFO[C.PI_NAME]!r} initialization")
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
170 self.host = host
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
171 self._e = cast(XEP_0106, host.plugins["XEP-0106"])
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
172 self._data_handlers: dict[SatXMPPEntity, GetDataHandler] = {}
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
173 host.register_namespace("gre", NS_GRE)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
174 self.host.register_encryption_plugin(self, "Relayed", NS_GRE)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
175 host.trigger.add("send", self.send_trigger, priority=0)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
176
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
177 def register_get_data_handler(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
178 self, client: SatXMPPEntity, handler: GetDataHandler
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
179 ) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
180 if client in self._data_handlers:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
181 raise exceptions.InternalError(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
182 '"register_get_data_handler" should not be called twice for the same '
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
183 "handler."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
184 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
185 self._data_handlers[client] = handler
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
186
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
187 def _on_component_data_request(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
188 self, iq_elt: domish.Element, client: SatXMPPEntity
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
189 ) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
190 iq_elt.handled = True
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
191 defer.ensureDeferred(self.on_component_data_request(client, iq_elt))
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
192
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
193 async def on_component_data_request(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
194 self, client: SatXMPPEntity, iq_elt: domish.Element
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
195 ) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
196 form = data_form.Form(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
197 "result", "Relayed Data Encryption", formNamespace=NS_GRE_DATA
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
198 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
199 try:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
200 handler = self._data_handlers[client]
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
201 except KeyError:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
202 pass
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
203 else:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
204 await handler.on_relayed_encryption_data(client, iq_elt, form)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
205 iq_result_elt = xmlstream.toResponse(iq_elt, "result")
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
206 data_elt = iq_result_elt.addElement((NS_GRE, "data"))
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
207 data_elt.addChild(form.toElement())
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
208 client.send(iq_result_elt)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
209
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
210 async def get_formatter_and_encrypter(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
211 self, client: SatXMPPEntity, gateway_jid: jid.JID
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
212 ) -> tuple[Formatter, Encrypter]:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
213 """Retrieve Formatter and Encrypter instances for given gateway.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
214
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
215 @param client: client session.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
216 @param gateway_jid: bare jid of the gateway.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
217 @return: Formatter and Encrypter instances.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
218 @raise exceptions.FeatureNotFound: No relevant Formatter or Encrypter could be
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
219 found.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
220 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
221 disco_infos = await self.host.memory.disco.get_infos(client, gateway_jid)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
222 try:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
223 formatter_ns = next(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
224 f for f in disco_infos.features if f.startswith(NS_GRE_FORMATTER_PREFIX)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
225 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
226 encrypter_ns = next(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
227 f for f in disco_infos.features if f.startswith(NS_GRE_ENCRYPTER_PREFIX)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
228 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
229 formatter_cls = Formatter.formatters_classes[formatter_ns]
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
230 encrypter_cls = Encrypter.encrypters_classes[encrypter_ns]
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
231 except StopIteration as e:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
232 raise exceptions.FeatureNotFound("No relayed encryption found.") from e
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
233 except KeyError as e:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
234 raise exceptions.FeatureNotFound(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
235 "No compatible relayed encryption found."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
236 ) from e
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
237
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
238 return formatter_cls.get_instance(), encrypter_cls.get_instance()
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
239
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
240 def get_encrypted_payload(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
241 self,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
242 message_elt: domish.Element,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
243 ) -> str | None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
244 """Return encrypted payload if any.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
245
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
246 @param message_elt: The message element.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
247 @return: Encrypted payload if any, None otherwise.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
248 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
249 encrypted_elt = next(message_elt.elements(NS_GRE, "encrypted"), None)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
250 if encrypted_elt is None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
251 return None
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
252 return str(encrypted_elt)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
253
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
254 async def send_trigger(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
255 self, client: SatXMPPEntity, stanza_elt: domish.Element
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
256 ) -> bool:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
257 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
258 @param client: Profile session.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
259 @param stanza: The stanza that is about to be sent.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
260 @return: Whether the send message flow should continue or not.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
261 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
262 if stanza_elt.name != "message":
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
263 return True
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
264
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
265 try:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
266 recipient = jid.JID(stanza_elt["to"])
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
267 except (jabber_error.StanzaError, RuntimeError, jid.InvalidFormat) as e:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
268 raise exceptions.InternalError(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
269 "Message without recipient encountered. Blocking further processing to"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
270 f" avoid leaking plaintext data: {stanza_elt.toXml()}"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
271 ) from e
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
272
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
273 recipient_bare_jid = recipient.userhostJID()
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
274
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
275 encryption_session = client.encryption.getSession(recipient_bare_jid)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
276 if encryption_session is None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
277 return True
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
278 if encryption_session["plugin"].namespace != NS_GRE:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
279 return True
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
280
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
281 # We are in a relayed encryption session.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
282
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
283 encryption_data_form = await self.get_data(client, recipient_bare_jid)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
284
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
285 formatter, encrypter = await self.get_formatter_and_encrypter(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
286 client, recipient_bare_jid
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
287 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
288
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
289 try:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
290 recipient_id = self._e.unescape(recipient.user)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
291 except ValueError as e:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
292 raise exceptions.DataError('"to" attribute is not in expected fomat') from e
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
293
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
294 formatted_payload = await formatter.format(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
295 client, recipient_id, stanza_elt, encryption_data_form
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
296 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
297 encrypted_payload = await encrypter.encrypt(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
298 client, recipient_id, stanza_elt, formatted_payload, encryption_data_form
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
299 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
300
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
301 for body_elt in list(stanza_elt.elements(None, "body")):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
302 stanza_elt.children.remove(body_elt)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
303 for subject_elt in list(stanza_elt.elements(None, "subject")):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
304 stanza_elt.children.remove(subject_elt)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
305
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
306 encrypted_elt = stanza_elt.addElement(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
307 (NS_GRE, "encrypted"), content=encrypted_payload
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
308 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
309 encrypted_elt["formatter"] = formatter.namespace
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
310 encrypted_elt["encrypter"] = encrypter.namespace
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
311
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
312 return True
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
313
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
314 async def get_data(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
315 self, client: SatXMPPEntity, recipient_jid: jid.JID
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
316 ) -> data_form.Form:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
317 """Retrieve relayed encryption data form.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
318
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
319 @param client: Client session.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
320 @param recipient_id: Bare jid of the entity to whom we want to send encrypted
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
321 mesasge.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
322 @return: Found data form, or None if no data form has been found.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
323 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
324 assert recipient_jid.resource is None, "recipient_jid must be a bare jid."
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
325 iq_elt = client.IQ("get")
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
326 iq_elt["to"] = recipient_jid.full()
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
327 data_elt = iq_elt.addElement((NS_GRE, "data"))
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
328 iq_result_elt = await iq_elt.send()
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
329 try:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
330 data_elt = next(iq_result_elt.elements(NS_GRE, "data"))
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
331 except StopIteration:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
332 raise exceptions.DataError(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
333 f"Relayed data payload is missing: {iq_result_elt.toXml()}"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
334 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
335 form = data_form.findForm(data_elt, NS_GRE_DATA)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
336 if form is None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
337 raise exceptions.DataError(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
338 f"Relayed data form is missing: {iq_result_elt.toXml()}"
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
339 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
340 return form
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
341
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
342 async def get_trust_ui(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
343 self, client: SatXMPPEntity, entity: jid.JID
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
344 ) -> xml_tools.XMLUI:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
345 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
346 @param client: The client session.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
347 @param entity: The entity whose device trust levels to manage.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
348 @return: An XMLUI Dialog to handle trust for given entity.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
349 """
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
350 # We just return an enmpty form for now.
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
351 return xml_tools.XMLUI(C.XMLUI_FORM)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
352
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
353 def get_handler(self, client: SatXMPPEntity) -> XMPPHandler:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
354 return GREHandler(self)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
355
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
356
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
357 @implementer(iwokkel.IDisco)
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
358 class GREHandler(XMPPHandler):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
359
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
360 def __init__(self, plugin_parent: GRE) -> None:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
361 self.plugin_parent = plugin_parent
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
362
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
363 def connectionInitialized(self):
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
364 assert self.parent is not None and self.xmlstream is not None
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
365 if self.parent.is_component:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
366 self.xmlstream.addObserver(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
367 IQ_DATA_REQUEST,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
368 self.plugin_parent._on_component_data_request,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
369 client=self.parent,
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
370 )
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
371
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
372 def getDiscoInfo(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
373 self, requestor: jid.JID, target: jid.JID, nodeIdentifier: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
374 ) -> list[disco.DiscoFeature]:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
375 return [
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
376 disco.DiscoFeature(NS_GRE),
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
377 ]
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
378
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
379 def getDiscoItems(
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
380 self, requestor: jid.JID, target: jid.JID, nodeIdentifier: str = ""
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
381 ) -> list[disco.DiscoItems]:
95f8309f86cf plugin GRE: implements Gateway Relayed Encryption:
Goffi <goffi@goffi.org>
parents:
diff changeset
382 return []