From 24973fbfde1bcdc6ba8237d6d18a723ff8bab7a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20Mar=C3=ADa=20Fern=C3=A1ndez?= Date: Mon, 11 Feb 2019 15:16:00 +0100 Subject: [PATCH 1/2] Fixed compatibility with OpenSSL 1.1.0. Also should work with OpenSSL 1.0.2 --- attic/crypto.pyx | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/attic/crypto.pyx b/attic/crypto.pyx index 1a5bc87b..27645383 100644 --- a/attic/crypto.pyx +++ b/attic/crypto.pyx @@ -23,8 +23,9 @@ cdef extern from "openssl/evp.h": pass const EVP_MD *EVP_sha256() const EVP_CIPHER *EVP_aes_256_ctr() - void EVP_CIPHER_CTX_init(EVP_CIPHER_CTX *a) - void EVP_CIPHER_CTX_cleanup(EVP_CIPHER_CTX *a) + EVP_CIPHER_CTX *EVP_CIPHER_CTX_new() + const unsigned char *EVP_CIPHER_CTX_iv(const EVP_CIPHER_CTX *a) + void EVP_CIPHER_CTX_free(EVP_CIPHER_CTX *a) int EVP_EncryptInit_ex(EVP_CIPHER_CTX *ctx,const EVP_CIPHER *cipher, ENGINE *impl, const unsigned char *key, const unsigned char *iv) @@ -84,16 +85,16 @@ def get_random_bytes(n): cdef class AES: """A thin wrapper around the OpenSSL EVP cipher API """ - cdef EVP_CIPHER_CTX ctx + cdef EVP_CIPHER_CTX * ctx def __cinit__(self, key, iv=None): - EVP_CIPHER_CTX_init(&self.ctx) - if not EVP_EncryptInit_ex(&self.ctx, EVP_aes_256_ctr(), NULL, NULL, NULL): + self.ctx = EVP_CIPHER_CTX_new(); + if not EVP_EncryptInit_ex(self.ctx, EVP_aes_256_ctr(), NULL, NULL, NULL): raise Exception('EVP_EncryptInit_ex failed') self.reset(key, iv) def __dealloc__(self): - EVP_CIPHER_CTX_cleanup(&self.ctx) + EVP_CIPHER_CTX_free(self.ctx) def reset(self, key=None, iv=None): cdef const unsigned char *key2 = NULL @@ -102,12 +103,12 @@ cdef class AES: key2 = key if iv: iv2 = iv - if not EVP_EncryptInit_ex(&self.ctx, NULL, NULL, key2, iv2): + if not EVP_EncryptInit_ex(self.ctx, NULL, NULL, key2, iv2): raise Exception('EVP_EncryptInit_ex failed') @property def iv(self): - return self.ctx.iv[:16] + return EVP_CIPHER_CTX_iv(self.ctx)[:16] def encrypt(self, data): cdef int inl = len(data) @@ -116,7 +117,7 @@ cdef class AES: if not out: raise MemoryError try: - if not EVP_EncryptUpdate(&self.ctx, out, &outl, data, inl): + if not EVP_EncryptUpdate(self.ctx, out, &outl, data, inl): raise Exception('EVP_EncryptUpdate failed') return out[:inl] finally: From 7b297457580f9198bf67549dd7e81f1d5257292e Mon Sep 17 00:00:00 2001 From: Aaron Webster Date: Wed, 28 Jul 2021 15:45:17 -0700 Subject: [PATCH 2/2] Add dependencies section. --- README.rst | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/README.rst b/README.rst index 0903f04f..298f3178 100644 --- a/README.rst +++ b/README.rst @@ -1,3 +1,10 @@ +Dependencies +------------ + +```` + apt install libssl-dev libacl1-dev +```` + What is Attic? -------------- Attic is a deduplicating backup program. The main goal of Attic is to provide