diff options
author | Kevin Jurczyk <oss@k-jurczyk.de> | 2016-11-10 11:21:14 -0500 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2016-11-10 16:29:16 -0500 |
commit | e81660d5c0ace2a805557d6dbb0f190991aaeaec (patch) | |
tree | 569c22196f6c469e8c4ff69dc70664588cbd24fb | |
parent | 33e277e856fe9ab5d959fc226cf3fc5483891e15 (diff) | |
download | sqlalchemy-e81660d5c0ace2a805557d6dbb0f190991aaeaec.tar.gz |
Add conditional import for pysqlcipher3
This is a Py3K supporting DBAPI for pysqlcipher.
Change-Id: I2a625274a371908f4de9d37f33e05408894b334b
Pull-request: https://github.com/zzzeek/sqlalchemy/pull/320
-rw-r--r-- | doc/build/changelog/changelog_11.rst | 8 | ||||
-rw-r--r-- | lib/sqlalchemy/dialects/sqlite/pysqlcipher.py | 18 |
2 files changed, 24 insertions, 2 deletions
diff --git a/doc/build/changelog/changelog_11.rst b/doc/build/changelog/changelog_11.rst index 57017b4d3..1123e084e 100644 --- a/doc/build/changelog/changelog_11.rst +++ b/doc/build/changelog/changelog_11.rst @@ -77,6 +77,14 @@ if your MySQL enum is linking values to objects, you still get the blank string back. + .. change:: + :tags: bug, sqlite, py3k + + Added an optional import for the pysqlcipher3 DBAPI when using the + pysqlcipher dialect. This package will attempt to be imported + if the Python-2 only pysqlcipher DBAPI is non-present. + Pull request courtesy Kevin Jurczyk. + .. changelog:: :version: 1.1.3 :released: October 27, 2016 diff --git a/lib/sqlalchemy/dialects/sqlite/pysqlcipher.py b/lib/sqlalchemy/dialects/sqlite/pysqlcipher.py index 4a501acac..bea3bd8cf 100644 --- a/lib/sqlalchemy/dialects/sqlite/pysqlcipher.py +++ b/lib/sqlalchemy/dialects/sqlite/pysqlcipher.py @@ -15,7 +15,12 @@ ``pysqlcipher`` is a fork of the standard ``pysqlite`` driver to make use of the `SQLCipher <https://www.zetetic.net/sqlcipher>`_ backend. - .. versionadded:: 0.9.9 + ``pysqlcipher3`` is a fork of ``pysqlcipher`` for Python 3. This dialect + will attempt to import it if ``pysqlcipher`` is non-present. + + .. versionadded:: 1.1.4 - added fallback import for pysqlcipher3 + + .. versionadded:: 0.9.9 - added pysqlcipher dialect Driver ------ @@ -26,6 +31,9 @@ introduces new PRAGMA commands to SQLite which allows the setting of a passphrase and other encryption parameters, allowing the database file to be encrypted. +`pysqlcipher3` is a fork of `pysqlcipher` with support for Python 3, +the driver is the same. + Connect Strings --------------- @@ -80,7 +88,13 @@ class SQLiteDialect_pysqlcipher(SQLiteDialect_pysqlite): @classmethod def dbapi(cls): - from pysqlcipher import dbapi2 as sqlcipher + try: + from pysqlcipher import dbapi2 as sqlcipher + except ImportError as e: + try: + from pysqlcipher3 import dbapi2 as sqlcipher + except ImportError: + raise e return sqlcipher @classmethod |