Commit 4ba1c646 authored by Tijmen de Mes's avatar Tijmen de Mes

Prevent DNS lookup for each message

parent e92a48fd
...@@ -61,39 +61,29 @@ class OutgoingMessage(object): ...@@ -61,39 +61,29 @@ class OutgoingMessage(object):
notification_center.add_observer(self, sender=self.lookup) notification_center.add_observer(self, sender=self.lookup)
self.lookup.lookup_sip_proxy(uri, settings.sip.transport_list, tls_name=self.account.sip.tls_name or uri.host) self.lookup.lookup_sip_proxy(uri, settings.sip.transport_list, tls_name=self.account.sip.tls_name or uri.host)
def send(self, session): def _send(self):
self.session = session if self.session.routes:
self._lookup()
@run_in_gui_thread
def handle_notification(self, notification):
handler = getattr(self, '_NH_%s' % notification.name, Null)
handler(notification)
def _NH_DNSLookupDidSucceed(self, notification):
notification.center.remove_observer(self, sender=notification.sender)
if notification.sender is self.lookup:
routes = notification.data.result
if routes:
from_uri = self.account.uri from_uri = self.account.uri
content = self.content if isinstance(self.content, bytes) else self.content.encode() content = self.content if isinstance(self.content, bytes) else self.content.encode()
ns = CPIMNamespace('urn:ietf:params:imdn', 'imdn')
additional_headers = [CPIMHeader('Message-ID', ns, self.id)]
additional_sip_headers = [] additional_sip_headers = []
if self.account.sms.use_cpim: if self.account.sms.use_cpim:
ns = CPIMNamespace('urn:ietf:params:imdn', 'imdn')
additional_headers = [CPIMHeader('Message-ID', ns, self.id)]
if self.account.sms.enable_imdn and self.content_type not in self.__disabled_imdn_content_types__:
additional_headers.append(CPIMHeader('Disposition-Notification', ns, 'positive-delivery, display'))
payload = CPIMPayload(content, payload = CPIMPayload(content,
self.content_type, self.content_type,
charset='utf-8', charset='utf-8',
sender=ChatIdentity(from_uri, self.account.display_name), sender=ChatIdentity(from_uri, self.account.display_name),
recipients=[ChatIdentity(self.sip_uri, None)], recipients=[ChatIdentity(self.sip_uri, None)],
timestamp=self.timestamp if self.timestamp is not None else str(ISOTimestamp.now()), timestamp=str(self.timestamp),
additional_headers=additional_headers) additional_headers=additional_headers)
payload, content_type = payload.encode() payload, content_type = payload.encode()
else: else:
payload = content payload = content
content_type = self.content_type content_type = self.content_type
route = routes[0] route = self.session.routes[0]
message_request = Message(FromHeader(from_uri, self.account.display_name), message_request = Message(FromHeader(from_uri, self.account.display_name),
ToHeader(self.sip_uri), ToHeader(self.sip_uri),
RouteHeader(route.uri), RouteHeader(route.uri),
...@@ -108,6 +98,25 @@ class OutgoingMessage(object): ...@@ -108,6 +98,25 @@ class OutgoingMessage(object):
pass pass
# TODO # TODO
def send(self, session):
self.session = session
if self.session.routes:
self._send()
else:
self._lookup()
@run_in_gui_thread
def handle_notification(self, notification):
handler = getattr(self, '_NH_%s' % notification.name, Null)
handler(notification)
def _NH_DNSLookupDidSucceed(self, notification):
notification.center.remove_observer(self, sender=notification.sender)
if notification.sender is self.lookup:
routes = notification.data.result
self.session.routes = routes
self._send()
def _NH_DNSLookupDidFail(self, notification): def _NH_DNSLookupDidFail(self, notification):
notification.center.remove_observer(self, sender=notification.sender) notification.center.remove_observer(self, sender=notification.sender)
if self.content_type.lower() == IsComposingDocument.content_type: if self.content_type.lower() == IsComposingDocument.content_type:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment