diff options
author | Amber Brown <hawkowl@atleastfornow.net> | 2018-05-30 12:51:42 +1000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-30 12:51:42 +1000 |
commit | 872cf4351698e9723edd5b58c436087be2986a32 (patch) | |
tree | f4fbbc979dff69f61db5ee66a418915de04d590f /synapse/storage/keys.py | |
parent | Merge pull request #3281 from NotAFile/py3-six-isinstance (diff) | |
parent | add remaining memoryview changes (diff) | |
download | synapse-872cf4351698e9723edd5b58c436087be2986a32.tar.xz |
Merge pull request #3303 from NotAFile/py3-memoryview
use memoryview in py3
Diffstat (limited to 'synapse/storage/keys.py')
-rw-r--r-- | synapse/storage/keys.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/synapse/storage/keys.py b/synapse/storage/keys.py index 0540c2b0b1..0f13b61da8 100644 --- a/synapse/storage/keys.py +++ b/synapse/storage/keys.py @@ -17,6 +17,7 @@ from ._base import SQLBaseStore from synapse.util.caches.descriptors import cachedInlineCallbacks from twisted.internet import defer +import six import OpenSSL from signedjson.key import decode_verify_key_bytes @@ -26,6 +27,13 @@ import logging logger = logging.getLogger(__name__) +# py2 sqlite has buffer hardcoded as only binary type, so we must use it, +# despite being deprecated and removed in favor of memoryview +if six.PY2: + db_binary_type = buffer +else: + db_binary_type = memoryview + class KeyStore(SQLBaseStore): """Persistence for signature verification keys and tls X.509 certificates @@ -72,7 +80,7 @@ class KeyStore(SQLBaseStore): values={ "from_server": from_server, "ts_added_ms": time_now_ms, - "tls_certificate": buffer(tls_certificate_bytes), + "tls_certificate": db_binary_type(tls_certificate_bytes), }, desc="store_server_certificate", ) @@ -135,7 +143,7 @@ class KeyStore(SQLBaseStore): values={ "from_server": from_server, "ts_added_ms": time_now_ms, - "verify_key": buffer(verify_key.encode()), + "verify_key": db_binary_type(verify_key.encode()), }, ) txn.call_after( @@ -172,7 +180,7 @@ class KeyStore(SQLBaseStore): "from_server": from_server, "ts_added_ms": ts_now_ms, "ts_valid_until_ms": ts_expires_ms, - "key_json": buffer(key_json_bytes), + "key_json": db_binary_type(key_json_bytes), }, desc="store_server_keys_json", ) |