disable memory security feature by default; once it is turned on it can't be turned off
[sqlcipher.git] / CHANGELOG.md
blobeb755310e46765c7276e89e6b5929eb10d018c60
1 # SQLCipher Change Log
2 All notable changes to this project will be documented in this file.
4 ## [4.4.3] - (February 2021 - [4.4.3 changes])
5 - Updates baseline to ustream SQLite 3.34.1
6 - Fixes sqlcipher_export handling of NULL parameters
7 - Removes randomization of rekey-delete tests to avoid false test failures
8 - Changes internal usage of sqlite_master to sqlite_schema
9 - Omits unusued profiling function under certain defines to avoid compiler warnings
11 ## [4.4.2] - (November 2020 - [4.4.2 changes])
12 - Improve error handling to resolve potential corruption if an encryption operation failed while operating in WAL mode
13 - Changes to OpenSSL library cryptographic provider to reduce initialization complexity
14 - Adjust cipher_integrity_check to skip locking page to avoid a spurious error report for very large databases
15 - Miscellaneous code and comment cleanup
17 ## [4.4.1] - (October 2020 - [4.4.1 changes])
18 - Updates baseline to upstream SQLite 3.33.0
19 - Fixes double-free bug in cipher_default_plaintext_header_size
20 - Changes SQLCipher tests to use suite runner
21 - Improvement to cipher_integrity_check tests to minimize false negatives
22 - Deprecates PRAGMA cipher_store_pass
24 ## [4.4.0] - (May 2020 - [4.4.0 changes])
25 - Updates baseline to upstream SQLite 3.31.0
26 - Adjusts shell to report SQLCipher version alongside SQLite version
27 - Fixes various build warnings under several compilers
28 - Removes unused id and status functions from provider interface
30 ## [4.3.0] - (November 2019 - [4.3.0 changes])
31 - Updates baseline to upstream SQLite 3.30.1
32 - PRAGMA key now returns text result value "ok" after execution
33 - Adjusts backup API so that encrypted to encrypted backups are permitted
34 - Adds NSS crypto provider implementation
35 - Fixes OpenSSL provider compatibility with BoringSSL
36 - Separates memory related traces to reduce verbosity of logging
37 - Fixes output of PRAGMA cipher_integrity_check on big endian platforms
38 - Cryptograpic provider interface cleanup
39 - Rework of mutex allocation and management
40 - Resolves miscellaneous build warnings
41 - Force error state at database pager level if SQLCipher initialization fails
43 ## [4.2.0] - (May 2019 - [4.2.0 changes])
44 - Adds PRAGMA cipher_integrity_check to perform independent verification of page HMACs
45 - Updates baseline to upstream SQLite 3.28.0
46 - Improves PRAGMA cipher_migrate to handle keys containing non-terminating zero bytes
48 ## [4.1.0] - (March 2019 - [4.1.0 changes])
49 - Defer reading salt from header until key derivation is triggered
50 - Clarify usage of sqlite3_rekey for plaintext databases in header
51 - Normalize attach behavior when key is not yet derived
52 - Adds PRAGMA cipher_settings to query current database codec settings
53 - Adds PRAGMA cipher_default_settings to query current default SQLCipher options
54 - PRAGMA cipher_hmac_pgno is now deprecated
55 - PRAGMA cipher_hmac_salt_mask is now deprecated
56 - PRAGMA fast_kdf_iter is now deprecated
57 - Improve sqlcipher_export routine and restore all database flags
58 - Clear codec data buffers if a crypographic provider operation fails
59 - Disable backup API for encrypted databases (this was previously documented as not-working and non-supported, but will now explicitly error out on initialization)
60 - Updates baseline to upstream SQLite 3.27.2
62 ## [4.0.1] - (December 2018 - [4.0.1 changes])
63 - Based on upstream SQLite 3.26.0 (addresses SQLite “Magellan” issue)
64 - Adds PRAGMA cipher_compatibility and cipher_default_compatibility which take automatcially configure appropriate compatibility settings for the specified SQLCipher major version number
65 - Filters attach statements with KEY parameters from readline history
66 - Fixes crash in command line shell with empty input (i.e. ^D)
67 - Fixes warnings when compiled with strict-prototypes
69 ## [4.0.0] - (November 2018 - [4.0.0 changes])
70 ### Changed
71 - Default page size for databases increased to 4096 bytes (up from 1024) *
72 - Default PBKDF2 iterations increased to 256,000 (up from 64,000) *
73 - Default KDF algorithm is now PBKDF2-HMAC-SHA512 (from PBKDF2-HMAC-SHA1) *
74 - Default HMAC algorithm is now HMAC-SHA512 (from HMAC-SHA1) *
75 - PRAGMA cipher is now disabled and no longer supported (after multi-year deprecation) *
76 - PRAGMA rekey_cipher is now disabled and no longer supported *
77 - PRAGMA rekey_kdf_iter is now disabled and no longer supported *
78 - By default all memory allocated internally by SQLite before the memory is wiped before it is freed 
79 - PRAGMA cipher_memory_security: allows full memory wiping to be disabled for performance when the feature is not required
80 - PRAGMA cipher_kdf_algorithm, cipher_default_kdf_algorithm to control KDF algorithm selection between PBKDF2-HMAC-SHA1, PBKDF2-HMAC-SHA256 and PBKDF2-HMAC-SHA512
81 - PRAGMA cipher_hmac_algorithm, cipher_default_hmac_algorithm to control HMAC algorithm selection between HMAC-SHA1, HMAC-SHA256 and PBKDF2-HMAC-SHA512
82 - Based on upstream SQLite 3.25.2
83 - When compiled with readline support, PRAGMA key and rekey lines will no longer be
84   saved to history
85 - Adds second optional parameter to sqlcipher_export to specify source database to
86   support bidirectional exports
87 - Fixes compatibility with LibreSSL 2.7.0+
88 - Fixes compatibility with OpenSSL 1.1.x
89 - Simplified and improved performance for PRAGMA cipher_migrate when migrating older database versions
90 - Refactoring of SQLCipher tests into separate files by test type
91 - PRAGMA cipher_plaintext_header_size and cipher_default_plaintext_header_size: allocates a portion of the database header which will not be encrypted to allow identification as a SQLite database
92 - PRAGMA cipher_salt: retrieve or set the salt value for the database
93 - Adds Podspec for using tagged versions of SQLCipher
94 - Define SQLCIPHER_PROFILE_USE_FOPEN for WinXP support
95 - Improved error handling for cryptographic providers
96 - Improved memory handling for PRAGMA commands that return values
97 - Improved version reporting to assist with identification of distribution
98 - Major rewrite and simplification of internal codec and pager extension
99 - Fixes compilation with --disable-amalgamation
100 - Removes sqlcipher.xcodeproj build support
102 ## [3.4.2] - (December 2017 - [3.4.2 changes])
103 ### Added
104 - Added support for building with LibreSSL
106 ### Changed
107 - Merge upstream SQLite 3.20.1
108 - Text strings for `SQLITE_ERROR` and `SQLITE_NOTADB` changed to match upstream SQLite
109 - Remove static modifier for codec password functions
110 - Page alignment for `mlock`
111 - Fix segfault in `sqlcipher_cipher_ctx_cmp` during rekey operation
112 - Fix `sqlcipher_export` and `cipher_migrate` when tracing API in use
113 - Validate codec page size when setting
114 - Guard OpenSSL initialization and cleanup routines
115 - Allow additional linker options to be passed via command line for Windows platforms
117 ## [3.4.1] - (December 2016 - [3.4.1 changes])
118 ### Added
119 - Added support for OpenSSL 1.1.0
121 ### Changed
122 - Merged upstream SQLite 3.15.2
124 ## [3.4.0] - (April 2016 - [3.4.0 changes])
125 ### Added
126 - Added `PRAGMA cipher_provider_version`
128 ### Changed
129 - Merged upstream SQLite 3.11.0
131 ### Deprecated
132 - Deprecated `PRAGMA cipher` command
134 ## [3.3.1] - (July 2015 - [3.3.1 changes])
135 ### Changed
136 - Merge upstream SQLite 3.8.10.2
137 - Fixed segfault when provided an invalid cipher name
138 - Check for codec context when performing `PRAGMA cipher_store_pass`
139 - Remove extraneous null check in `PRAGMA cipher_migrate`
141 ## [3.3.0] - (March 2015 - [3.3.0 changes])
142 ### Added
143 - Added FIPS API calls within the OpenSSL crypto provider
144 - `PRAGMA cipher_default_page_size` - support for attaching non-default page sizes
146 ### Changed
147 - Merged upstream SQLite 3.8.8.3
149 ## [3.2.0] - (September 2014 - [3.2.0 changes])
150 ### Added
151 - Added `PRAGMA cipher_store_pass`
153 ### Changed
154 - Merged upstream SQLite 3.8.6
155 - Renmed README to README.md
157 ## [3.1.0] - (April 2014 - [3.1.0 changes])
158 ### Added
159 - Added `PRAGMA cipher_profile`
161 ### Changed
162 - Merged upstream SQLite 3.8.4.3
164 ## [3.0.1] - (December 2013 - [3.0.1 changes])
165 ### Added
166 - Added `PRAGMA cipher_add_random` to source external entropy
168 ### Changed
169 - Fix `PRAGMA cipher_migrate` to handle passphrases longer than 64 characters & raw keys
170 - Improvements to the libtomcrypt provider
172 ## [3.0.0] - (November 2013 - [3.0.0 changes])
173 ### Added
174 - Added `PRAGMA cipher_migrate` to migrate older database file formats
176 ### Changed
177 - Merged upstream SQLite 3.8.0.2
178 - Remove usage of VirtualLock/Unlock on WinRT and Windows Phone
179 - Ignore HMAC read during Btree file copy
180 - Fix lib naming for pkg-config
181 - Use _v2 version of `sqlite3_key` and `sqlite3_rekey`
182 - Update xcodeproj file
184 ### Security
185 - Change KDF iteration length from 4,000 to 64,000
187 [unreleased]: https://github.com/sqlcipher/sqlcipher/compare/v4.4.3...prerelease
188 [4.4.3]: https://github.com/sqlcipher/sqlcipher/tree/v4.4.3
189 [4.4.3 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.4.2...v4.4.3
190 [4.4.2]: https://github.com/sqlcipher/sqlcipher/tree/v4.4.2
191 [4.4.2 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.4.1...v4.4.2
192 [4.4.1]: https://github.com/sqlcipher/sqlcipher/tree/v4.4.1
193 [4.4.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.4.0...v4.4.1
194 [4.4.0]: https://github.com/sqlcipher/sqlcipher/tree/v4.4.0
195 [4.4.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.3.0...v4.4.0
196 [4.3.0]: https://github.com/sqlcipher/sqlcipher/tree/v4.3.0
197 [4.3.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.2.0...v4.3.0
198 [4.2.0]: https://github.com/sqlcipher/sqlcipher/tree/v4.2.0
199 [4.2.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.1.0...v4.2.0
200 [4.1.0]: https://github.com/sqlcipher/sqlcipher/tree/v4.1.0
201 [4.1.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.0.1...v4.1.0
202 [4.0.1]: https://github.com/sqlcipher/sqlcipher/tree/v4.0.1
203 [4.0.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v4.0.0...v4.0.1
204 [4.0.0]: https://github.com/sqlcipher/sqlcipher/tree/v4.0.0
205 [4.0.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.4.2...v4.0.0
206 [3.4.2]: https://github.com/sqlcipher/sqlcipher/tree/v3.4.2
207 [3.4.2 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.4.1...v3.4.2
208 [3.4.1]: https://github.com/sqlcipher/sqlcipher/tree/v3.4.1
209 [3.4.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.4.0...v3.4.1
210 [3.4.0]: https://github.com/sqlcipher/sqlcipher/tree/v3.4.0
211 [3.4.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.3.1...v3.4.0
212 [3.3.1]: https://github.com/sqlcipher/sqlcipher/tree/v3.3.1
213 [3.3.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.3.0...v3.3.1
214 [3.3.0]: https://github.com/sqlcipher/sqlcipher/tree/v3.3.0
215 [3.3.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.2.0...v3.3.0
216 [3.2.0]: https://github.com/sqlcipher/sqlcipher/tree/v3.2.0
217 [3.2.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.1.0...v3.2.0
218 [3.1.0]: https://github.com/sqlcipher/sqlcipher/tree/v3.1.0
219 [3.1.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.0.1...v3.1.0
220 [3.0.1]: https://github.com/sqlcipher/sqlcipher/tree/v3.0.1
221 [3.0.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v3.0.0...v3.0.1
222 [3.0.0]: https://github.com/sqlcipher/sqlcipher/tree/v3.0.0
223 [3.0.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.2.0...v3.0.0
224 [2.2.0]: https://github.com/sqlcipher/sqlcipher/tree/v2.2.0
225 [2.2.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.1.1...v2.2.0
226 [2.1.1]: https://github.com/sqlcipher/sqlcipher/tree/v2.1.1
227 [2.1.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.1.0...v2.1.1
228 [2.1.0]: https://github.com/sqlcipher/sqlcipher/tree/v2.1.0
229 [2.1.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.0.6...v2.1.0
230 [2.0.6]: https://github.com/sqlcipher/sqlcipher/tree/v2.0.6
231 [2.0.6 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.0.5...v2.0.6
232 [2.0.5]: https://github.com/sqlcipher/sqlcipher/tree/v2.0.5
233 [2.0.5 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.0.3...v2.0.5
234 [2.0.3]: https://github.com/sqlcipher/sqlcipher/tree/v2.0.3
235 [2.0.3 changes]: https://github.com/sqlcipher/sqlcipher/compare/v2.0.0...v2.0.3
236 [2.0.0]: https://github.com/sqlcipher/sqlcipher/tree/v2.0.0
237 [2.0.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.10...v2.0.0
238 [1.1.10]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.10
239 [1.1.10 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.9...v1.1.10
240 [1.1.9]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.9
241 [1.1.9 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.8...v1.1.9
242 [1.1.8]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.8
243 [1.1.8 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.7...v1.1.8
244 [1.1.7]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.7
245 [1.1.7 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.6...v1.1.7
246 [1.1.6]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.6
247 [1.1.6 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.5...v1.1.6
248 [1.1.5]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.5
249 [1.1.5 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.4...v1.1.5
250 [1.1.4]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.4
251 [1.1.4 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.3...v1.1.4
252 [1.1.3]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.3
253 [1.1.3 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.2...v1.1.3
254 [1.1.2]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.2
255 [1.1.2 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.1...v1.1.1
256 [1.1.1]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.1
257 [1.1.1 changes]: https://github.com/sqlcipher/sqlcipher/compare/v1.1.0...v1.1.1
258 [1.1.0]: https://github.com/sqlcipher/sqlcipher/tree/v1.1.0
259 [1.1.0 changes]: https://github.com/sqlcipher/sqlcipher/compare/617ed01...v1.1.0