Skip to content
Snippets Groups Projects
Unverified Commit f38676d1 authored by Patrick Cloke's avatar Patrick Cloke Committed by GitHub
Browse files

Add type hints to matrix federation client / agent. (#8806)

parent b08dc7ef
No related branches found
No related tags found
No related merge requests found
Add type hints to matrix federation client and agent.
...@@ -45,7 +45,9 @@ files = ...@@ -45,7 +45,9 @@ files =
synapse/handlers/saml_handler.py, synapse/handlers/saml_handler.py,
synapse/handlers/sync.py, synapse/handlers/sync.py,
synapse/handlers/ui_auth, synapse/handlers/ui_auth,
synapse/http/federation/matrix_federation_agent.py,
synapse/http/federation/well_known_resolver.py, synapse/http/federation/well_known_resolver.py,
synapse/http/matrixfederationclient.py,
synapse/http/server.py, synapse/http/server.py,
synapse/http/site.py, synapse/http/site.py,
synapse/logging, synapse/logging,
......
...@@ -12,21 +12,25 @@ ...@@ -12,21 +12,25 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
import logging import logging
import urllib import urllib.parse
from typing import List from typing import List, Optional
from netaddr import AddrFormatError, IPAddress from netaddr import AddrFormatError, IPAddress
from zope.interface import implementer from zope.interface import implementer
from twisted.internet import defer from twisted.internet import defer
from twisted.internet.endpoints import HostnameEndpoint, wrapClientTLS from twisted.internet.endpoints import HostnameEndpoint, wrapClientTLS
from twisted.internet.interfaces import IStreamClientEndpoint from twisted.internet.interfaces import (
from twisted.web.client import Agent, HTTPConnectionPool IProtocolFactory,
IReactorCore,
IStreamClientEndpoint,
)
from twisted.web.client import URI, Agent, HTTPConnectionPool
from twisted.web.http_headers import Headers from twisted.web.http_headers import Headers
from twisted.web.iweb import IAgent, IAgentEndpointFactory from twisted.web.iweb import IAgent, IAgentEndpointFactory, IBodyProducer
from synapse.crypto.context_factory import FederationPolicyForHTTPS
from synapse.http.federation.srv_resolver import Server, SrvResolver from synapse.http.federation.srv_resolver import Server, SrvResolver
from synapse.http.federation.well_known_resolver import WellKnownResolver from synapse.http.federation.well_known_resolver import WellKnownResolver
from synapse.logging.context import make_deferred_yieldable, run_in_background from synapse.logging.context import make_deferred_yieldable, run_in_background
...@@ -44,30 +48,30 @@ class MatrixFederationAgent: ...@@ -44,30 +48,30 @@ class MatrixFederationAgent:
Doesn't implement any retries. (Those are done in MatrixFederationHttpClient.) Doesn't implement any retries. (Those are done in MatrixFederationHttpClient.)
Args: Args:
reactor (IReactor): twisted reactor to use for underlying requests reactor: twisted reactor to use for underlying requests
tls_client_options_factory (FederationPolicyForHTTPS|None): tls_client_options_factory:
factory to use for fetching client tls options, or none to disable TLS. factory to use for fetching client tls options, or none to disable TLS.
user_agent (bytes): user_agent:
The user agent header to use for federation requests. The user agent header to use for federation requests.
_srv_resolver (SrvResolver|None): _srv_resolver:
SRVResolver impl to use for looking up SRV records. None to use a default SrvResolver implementation to use for looking up SRV records. None
implementation. to use a default implementation.
_well_known_resolver (WellKnownResolver|None): _well_known_resolver:
WellKnownResolver to use to perform well-known lookups. None to use a WellKnownResolver to use to perform well-known lookups. None to use a
default implementation. default implementation.
""" """
def __init__( def __init__(
self, self,
reactor, reactor: IReactorCore,
tls_client_options_factory, tls_client_options_factory: Optional[FederationPolicyForHTTPS],
user_agent, user_agent: bytes,
_srv_resolver=None, _srv_resolver: Optional[SrvResolver] = None,
_well_known_resolver=None, _well_known_resolver: Optional[WellKnownResolver] = None,
): ):
self._reactor = reactor self._reactor = reactor
self._clock = Clock(reactor) self._clock = Clock(reactor)
...@@ -99,15 +103,20 @@ class MatrixFederationAgent: ...@@ -99,15 +103,20 @@ class MatrixFederationAgent:
self._well_known_resolver = _well_known_resolver self._well_known_resolver = _well_known_resolver
@defer.inlineCallbacks @defer.inlineCallbacks
def request(self, method, uri, headers=None, bodyProducer=None): def request(
self,
method: bytes,
uri: bytes,
headers: Optional[Headers] = None,
bodyProducer: Optional[IBodyProducer] = None,
) -> defer.Deferred:
""" """
Args: Args:
method (bytes): HTTP method: GET/POST/etc method: HTTP method: GET/POST/etc
uri (bytes): Absolute URI to be retrieved uri: Absolute URI to be retrieved
headers (twisted.web.http_headers.Headers|None): headers:
HTTP headers to send with the request, or None to HTTP headers to send with the request, or None to send no extra headers.
send no extra headers. bodyProducer:
bodyProducer (twisted.web.iweb.IBodyProducer|None):
An object which can generate bytes to make up the An object which can generate bytes to make up the
body of this request (for example, the properly encoded contents of body of this request (for example, the properly encoded contents of
a file for a file upload). Or None if the request is to have a file for a file upload). Or None if the request is to have
...@@ -123,6 +132,9 @@ class MatrixFederationAgent: ...@@ -123,6 +132,9 @@ class MatrixFederationAgent:
# explicit port. # explicit port.
parsed_uri = urllib.parse.urlparse(uri) parsed_uri = urllib.parse.urlparse(uri)
# There must be a valid hostname.
assert parsed_uri.hostname
# If this is a matrix:// URI check if the server has delegated matrix # If this is a matrix:// URI check if the server has delegated matrix
# traffic using well-known delegation. # traffic using well-known delegation.
# #
...@@ -179,7 +191,12 @@ class MatrixHostnameEndpointFactory: ...@@ -179,7 +191,12 @@ class MatrixHostnameEndpointFactory:
"""Factory for MatrixHostnameEndpoint for parsing to an Agent. """Factory for MatrixHostnameEndpoint for parsing to an Agent.
""" """
def __init__(self, reactor, tls_client_options_factory, srv_resolver): def __init__(
self,
reactor: IReactorCore,
tls_client_options_factory: Optional[FederationPolicyForHTTPS],
srv_resolver: Optional[SrvResolver],
):
self._reactor = reactor self._reactor = reactor
self._tls_client_options_factory = tls_client_options_factory self._tls_client_options_factory = tls_client_options_factory
...@@ -203,15 +220,20 @@ class MatrixHostnameEndpoint: ...@@ -203,15 +220,20 @@ class MatrixHostnameEndpoint:
resolution (i.e. via SRV). Does not check for well-known delegation. resolution (i.e. via SRV). Does not check for well-known delegation.
Args: Args:
reactor (IReactor) reactor: twisted reactor to use for underlying requests
tls_client_options_factory (ClientTLSOptionsFactory|None): tls_client_options_factory:
factory to use for fetching client tls options, or none to disable TLS. factory to use for fetching client tls options, or none to disable TLS.
srv_resolver (SrvResolver): The SRV resolver to use srv_resolver: The SRV resolver to use
parsed_uri (twisted.web.client.URI): The parsed URI that we're wanting parsed_uri: The parsed URI that we're wanting to connect to.
to connect to.
""" """
def __init__(self, reactor, tls_client_options_factory, srv_resolver, parsed_uri): def __init__(
self,
reactor: IReactorCore,
tls_client_options_factory: Optional[FederationPolicyForHTTPS],
srv_resolver: SrvResolver,
parsed_uri: URI,
):
self._reactor = reactor self._reactor = reactor
self._parsed_uri = parsed_uri self._parsed_uri = parsed_uri
...@@ -231,13 +253,13 @@ class MatrixHostnameEndpoint: ...@@ -231,13 +253,13 @@ class MatrixHostnameEndpoint:
self._srv_resolver = srv_resolver self._srv_resolver = srv_resolver
def connect(self, protocol_factory): def connect(self, protocol_factory: IProtocolFactory) -> defer.Deferred:
"""Implements IStreamClientEndpoint interface """Implements IStreamClientEndpoint interface
""" """
return run_in_background(self._do_connect, protocol_factory) return run_in_background(self._do_connect, protocol_factory)
async def _do_connect(self, protocol_factory): async def _do_connect(self, protocol_factory: IProtocolFactory) -> None:
first_exception = None first_exception = None
server_list = await self._resolve_server() server_list = await self._resolve_server()
...@@ -303,20 +325,20 @@ class MatrixHostnameEndpoint: ...@@ -303,20 +325,20 @@ class MatrixHostnameEndpoint:
return [Server(host, 8448)] return [Server(host, 8448)]
def _is_ip_literal(host): def _is_ip_literal(host: bytes) -> bool:
"""Test if the given host name is either an IPv4 or IPv6 literal. """Test if the given host name is either an IPv4 or IPv6 literal.
Args: Args:
host (bytes) host: The host name to check
Returns: Returns:
bool True if the hostname is an IP address literal.
""" """
host = host.decode("ascii") host_str = host.decode("ascii")
try: try:
IPAddress(host) IPAddress(host_str)
return True return True
except AddrFormatError: except AddrFormatError:
return False return False
...@@ -12,7 +12,6 @@ ...@@ -12,7 +12,6 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
import logging import logging
import random import random
import time import time
...@@ -21,10 +20,11 @@ from typing import Callable, Dict, Optional, Tuple ...@@ -21,10 +20,11 @@ from typing import Callable, Dict, Optional, Tuple
import attr import attr
from twisted.internet import defer from twisted.internet import defer
from twisted.internet.interfaces import IReactorTime
from twisted.web.client import RedirectAgent, readBody from twisted.web.client import RedirectAgent, readBody
from twisted.web.http import stringToDatetime from twisted.web.http import stringToDatetime
from twisted.web.http_headers import Headers from twisted.web.http_headers import Headers
from twisted.web.iweb import IResponse from twisted.web.iweb import IAgent, IResponse
from synapse.logging.context import make_deferred_yieldable from synapse.logging.context import make_deferred_yieldable
from synapse.util import Clock, json_decoder from synapse.util import Clock, json_decoder
...@@ -81,11 +81,11 @@ class WellKnownResolver: ...@@ -81,11 +81,11 @@ class WellKnownResolver:
def __init__( def __init__(
self, self,
reactor, reactor: IReactorTime,
agent, agent: IAgent,
user_agent, user_agent: bytes,
well_known_cache=None, well_known_cache: Optional[TTLCache] = None,
had_well_known_cache=None, had_well_known_cache: Optional[TTLCache] = None,
): ):
self._reactor = reactor self._reactor = reactor
self._clock = Clock(reactor) self._clock = Clock(reactor)
...@@ -127,7 +127,7 @@ class WellKnownResolver: ...@@ -127,7 +127,7 @@ class WellKnownResolver:
with Measure(self._clock, "get_well_known"): with Measure(self._clock, "get_well_known"):
result, cache_period = await self._fetch_well_known( result, cache_period = await self._fetch_well_known(
server_name server_name
) # type: Tuple[Optional[bytes], float] ) # type: Optional[bytes], float
except _FetchWellKnownFailure as e: except _FetchWellKnownFailure as e:
if prev_result and e.temporary: if prev_result and e.temporary:
......
This diff is collapsed.
...@@ -27,7 +27,8 @@ import logging ...@@ -27,7 +27,8 @@ import logging
import os import os
from typing import TYPE_CHECKING, Any, Callable, Dict, List, Optional, TypeVar, cast from typing import TYPE_CHECKING, Any, Callable, Dict, List, Optional, TypeVar, cast
import twisted import twisted.internet.base
import twisted.internet.tcp
from twisted.mail.smtp import sendmail from twisted.mail.smtp import sendmail
from twisted.web.iweb import IPolicyForHTTPS from twisted.web.iweb import IPolicyForHTTPS
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment