aboutsummaryrefslogtreecommitdiffstats
path: root/cryptography
diff options
context:
space:
mode:
authorPaul Kehrer <paul.l.kehrer@gmail.com>2013-11-22 19:57:37 -0600
committerPaul Kehrer <paul.l.kehrer@gmail.com>2013-11-29 17:19:45 -0600
commita4bfc08b8d2ed312eeb1b0558ac20f285feb8cc2 (patch)
tree3548f67d5eb42eaf5ca5b4eda3d661f369fcc399 /cryptography
parentce9c611feb4db781fcab5b7bbc68b936816d6a73 (diff)
downloadcryptography-a4bfc08b8d2ed312eeb1b0558ac20f285feb8cc2.tar.gz
cryptography-a4bfc08b8d2ed312eeb1b0558ac20f285feb8cc2.tar.bz2
cryptography-a4bfc08b8d2ed312eeb1b0558ac20f285feb8cc2.zip
invalidtag exception for gcm
This exception is probably not safe. It depends on the assumption that if ERR_get_error returns a 0 then it is an AEAD tag error.
Diffstat (limited to 'cryptography')
-rw-r--r--cryptography/exceptions.py4
-rw-r--r--cryptography/hazmat/bindings/openssl/backend.py5
2 files changed, 7 insertions, 2 deletions
diff --git a/cryptography/exceptions.py b/cryptography/exceptions.py
index d56db214..e9d88199 100644
--- a/cryptography/exceptions.py
+++ b/cryptography/exceptions.py
@@ -26,3 +26,7 @@ class AlreadyUpdated(Exception):
class NotYetFinalized(Exception):
pass
+
+
+class InvalidTag(Exception):
+ pass
diff --git a/cryptography/hazmat/bindings/openssl/backend.py b/cryptography/hazmat/bindings/openssl/backend.py
index fdb67628..527706bc 100644
--- a/cryptography/hazmat/bindings/openssl/backend.py
+++ b/cryptography/hazmat/bindings/openssl/backend.py
@@ -19,7 +19,7 @@ import sys
import cffi
from cryptography import utils
-from cryptography.exceptions import UnsupportedAlgorithm
+from cryptography.exceptions import UnsupportedAlgorithm, InvalidTag
from cryptography.hazmat.bindings.interfaces import (
CipherBackend, HashBackend, HMACBackend
)
@@ -200,7 +200,8 @@ class Backend(object):
def _handle_error(self):
code = self.lib.ERR_get_error()
- assert code != 0
+ if not code:
+ raise InvalidTag
lib = self.lib.ERR_GET_LIB(code)
func = self.lib.ERR_GET_FUNC(code)
reason = self.lib.ERR_GET_REASON(code)