diff options
| author | Kali Kaneko <kali@leap.se> | 2013-12-17 00:45:05 -0400 | 
|---|---|---|
| committer | Kali Kaneko <kali@leap.se> | 2013-12-17 00:45:05 -0400 | 
| commit | 06868daa749cf6ab4fc8038676f55a4500f13ec2 (patch) | |
| tree | d3f05ae98d5f7ccc746eb46295bb0890393b3bda /keymanager/src | |
| parent | e1f661d5832de4e32f1b06039750006a5b9c4669 (diff) | |
memoize call to get_key
Diffstat (limited to 'keymanager/src')
| -rw-r--r-- | keymanager/src/leap/keymanager/__init__.py | 7 | 
1 files changed, 5 insertions, 2 deletions
| diff --git a/keymanager/src/leap/keymanager/__init__.py b/keymanager/src/leap/keymanager/__init__.py index 6cfbf71..5b1d8d9 100644 --- a/keymanager/src/leap/keymanager/__init__.py +++ b/keymanager/src/leap/keymanager/__init__.py @@ -46,6 +46,7 @@ import requests  from leap.common.check import leap_assert, leap_assert_type  from leap.common.events import signal  from leap.common.events import events_pb2 as proto +from leap.common.decorators import memoized_method  from leap.keymanager.errors import KeyNotFound @@ -250,6 +251,7 @@ class KeyManager(object):          self._put(uri, data)          signal(proto.KEYMANAGER_DONE_UPLOADING_KEYS, self._address) +    @memoized_method      def get_key(self, address, ktype, private=False, fetch_remote=True):          """          Return a key of type C{ktype} bound to C{address}. @@ -266,9 +268,10 @@ class KeyManager(object):          :return: A key of type C{ktype} bound to C{address}.          :rtype: EncryptionKey -        @raise KeyNotFound: If the key was not found both locally and in -            keyserver. +        :raise KeyNotFound: If the key was not found both locally and in +                            keyserver.          """ +        logger.debug("getting key for %s" % (address,))          leap_assert(              ktype in self._wrapper_map,              'Unkown key type: %s.' % str(ktype)) | 
