Link Search Menu Expand Document (external link)

Installation

Table of contents

Overview

Build files for the supported platforms - Windows, Linux, and OSX - are provided.

The build files for Windows platforms are generated with Premake 5. For regenerating the build files it is recommended to use Premake 5.0 alpha 15 or later.

For Linux and OSX build files based on the autoconf/automake toolchain are provided.

Releases and Binaries

Releases of SQLite3 Multiple Ciphers are typically made available shortly after releases of SQLite. Usually, an archive with the amalgamated source code, pre-built binaries for Windows and Android (see SQLite Android Bindings) are provided with every release.

Language Bindings

Several language bindings for SQLite3 Multiple Ciphers exist in separate projects:

Note

If you know about further language bindings, please drop a note (for example, via a GitHub discussion).

Drop-in replacement for SQLite

In principle, the SQLite3 Multiple Ciphers source code or binaries can be used as a drop-in replacement for SQLite.

If your project uses the SQLite amalgamation source file sqlite3.c, this file could be replaced by the SQLite3 Multiple Ciphers amalgamation source file sqlite3mc_amalgamation.c (as distributed with the releases).

If your project references SQLite’s shared library (for example, sqlite3.dll on Windows), SQLite3 Multiple Ciphers’ shared library could be referenced instead by renaming the shared library and making it available on the library search path.

Windows builds

Ready to use project files are provided for Visual C++ 2010, 2012, 2013, 2015, 2017, 2019, and 2022. Additionally, GNU Makefiles are provided supporting GCC (for example, Mingw-w64 or recent versions of tdm-gcc).

For Visual Studio 2010+ solutions it is possible to customize the build by creating a wx_local.props file in the build directory which is used by the projects, if it exists. The settings in that file override the default values for the properties. The typical way to make the file is to copy wx_setup.props to wx_local.props and then edit locally.

For GNU Makefiles the file config.gcc serves the same purpose as the file wx_setup.props for Visual C++ projects.

The customization files wx_setup.props resp. config.gcc allow to customize certain settings like for example the default cipher scheme.

For adjusting the build configuration edit file premake5.lua in the root directory, and then run

premake5 [action]

where action is one of the following: vs2010, vs2012, vs2013, vs2015, vs2017, vs2019, or gmake2.

When building on Win32 or Win64, you can use the makefiles or one of the Microsoft Visual Studio solution files in the build folder.

For Visual C++ the debugging properties are set up in such a way that debugging the sample applications should work right out of the box.

Linux / OSX builds

When building on Linux or OSX, the first setup is to recreate the configure script doing:

  autoreconf

Thereafter you should create a build directory

  mkdir build-gtk [or any other suitable name]
  cd build-gtk
  ../configure
  make

Type ../configure --help for more info.

The autoconf-based system also supports a make install target which builds the library and then copies the headers of the component to /usr/local/include and the lib to /usr/local/lib.

WebAssembly

Starting with version 3.40 the SQLite project provides WebAssembly- and JavaScript-related APIs, which enable the use of SQLite3 in modern WASM-capable browsers.

SQLite3 Multiple Ciphers can add encryption support to WASM-based applications. In principle, building JS/WASM support for SQLite3 Multiple Ciphers follows closely the documentation given on the SQLite website.

The build process is very similar to the description of Building for SQLite Encryption Extension (SEE), the official (commercial) SQLite Encryption Extension.

The following steps describe the preliminary actions:

  1. Generate or download the amalgamation source code of SQLite3 Multiple Ciphers, matching the SQLite version, you want to build WASM support for,
  2. Copy the file sqlite3mc_amalgamation.c to the top-most directory of the SQLite source tree,
  3. Rename sqlite3mc_amalgamation.c to sqlite3-see.c, or pass sqlite3.c=/path/to/sqlite3mc_amalgamation.c when running make or gmake from the ext/wasm directory,
  4. Adjust the file ext/wasm/GNUmakefile by adding the compile time flag -D__WASM__ (2 places),
  5. (Optional) Add support for the SQLite3 Multiple Ciphers C API:
    • Add the SQLite3 Multiple Ciphers API function names to file ext/wasm/api/EXPORTED_FUNCTIONS.sqlite3-see, prefixing them with an underscore character,
    • Add the signatures of the SQLite3 Multiple Ciphers API functions to ext/wasm/api/sqlite3-api-glue.js (search for sqlite3_activate_see).

Thereafter WASM support can be built according to the SQLite documentation.

Support for ICU (International Components for Unicode)

On Windows the SQLite3 Multiple Ciphers library can be built with or without ICU support. ICU support for SQLite3 is currently based on pre-built ICU Libraries, which were compiled with Visual Studio 2019. The required ICU DLLs are not included in the repository, but can be downloaded from the latest ICU release. However, the pre-built binary packages for Windows include the required ICU DLLs.

Using the build files coming with SQLite3 Multiple Ciphers for building the library with ICU support, requires to define the environment variable LIBICU_PATH that must point to the directory to which the archive with the pre-built ICU libraries was extracted.

In addition, the Visual C++ 2019 runtime is required to be installed, because the ICU DLLs depend on it.

In principle, the ICU DLLs should be compatible with Visual C++ 2015 and Visual C++ 2017 as well.

Default settings

Currently the cipher scheme sqleet: ChaCha20 is set as the default. However, this can be changed by setting the preprocessor symbol CODEC_TYPE to one of the values listed in the following table:

Preprocessor SymbolCipher
CODEC_TYPE_AES128wxSQLite3: AES 128 Bit
CODEC_TYPE_AES256wxSQLite3: AES 256 Bit
CODEC_TYPE_CHACHA20sqleet: ChaCha20
CODEC_TYPE_SQLCIPHERSQLCipher: AES 256 Bit
CODEC_TYPE_RC4System.Data.SQLite: RC4
CODEC_TYPE_ASCON128Ascon: Ascon-128 v1.2

Notes

  • If compatibility with legacy sqleet is required, it is necessary to explicitly define the preprocessor symbol SQLITE3MC_USE_SQLEET_LEGACY.
  • If compatibility with legacy SQLCipher is required, it is necessary to explicitly define the preprocessor symbol SQLITE3MC_USE_SQLCIPHER_LEGACY. If not the latest SQLCipher version, but a specific older one, should be selected, then the preprocessor symbol SQLCIPHER_VERSION_DEFAULT=version needs to be defined, where version can have one of the values 1, 2, 3, or 4.

Optional features

SQLite has many optional features and offers a vast number of optional extensions. The below table lists the features that are enabled for SQLite3 Multiple Ciphers as default. For details, please see SQLite Compile Time Options.

SymbolDescription
SQLITE_DQS=0Disable double quoted string literals
SQLITE_ENABLE_COLUMN_METADATA=1Access to meta-data about tables and queries
SQLITE_ENABLE_DEBUG=0Enable additional debug features (default: off)
SQLITE_ENABLE_DESERIALIZE=1Enable the deserialization interface
SQLITE_ENABLE_EXPLAIN_COMMENTS=1Enable additional comments in EXPLAIN output
SQLITE_ENABLE_CARRAY=1C array extension
SQLITE_ENABLE_CSV=1CSV extension
SQLITE_ENABLE_FTS3=1Version 3 of the full-text search engine
SQLITE_ENABLE_FTS3_PARENTHESIS=1Additional operators for query pattern parser
SQLITE_ENABLE_FTS4=1Version 4 of the full-text search engine
SQLITE_ENABLE_FTS5=1Version 5 of the full-text search engine
SQLITE_ENABLE_GEOPOLY=1GeoPoly extension
SQLITE_ENABLE_JSON1=1JSON SQL functions
SQLITE_ENABLE_RTREE=1R*Tree index extension
SQLITE_ENABLE_EXTFUNC=1Extension with mathematical and string functions
SQLITE_ENABLE_FILEIO=1Extension with file I/O SQL functions
SQLITE_ENABLE_REGEXP=1Regular expression extension
SQLITE_ENABLE_SERIES=1Series extension
SQLITE_ENABLE_SHA3=1SHA3 extension
SQLITE_ENABLE_UUID=1UUID extension
SQLITE_MAX_ATTACHED=10Maximum Number Of Attached Databases (max. 125)
SQLITE_SECURE_DELETE=1Overwrite deleted content with zeros
SQLITE_SOUNDEX=1Enable soundex SQL function
SQLITE_USE_URI=1Enable URI file names
SQLITE_USER_AUTHENTICATION=1User authentication extension

Note

  • In case of memory constraints it is of course possible to disable unneeded features. However, this will require to modify the build files.

The source code of 3 extensions that require ZLIB support is also included, but is not enabled by default:

To enable one or more of those extensions, it is required to specify the corresponding preprocessor symbol:

SymbolDescription
SQLITE_ENABLE_COMPRESS=1Enable extension COMPRESS
SQLITE_ENABLE_SQLAR=1Enable extension SQLAR
SQLITE_ENABLE_ZIPFILE=1Enable extension ZIPFILE

To successfully compile these extensions it is required to specify for the compiler, where the ZLIB header can be found, and for the linker, the name and location of the ZLIB library. Alternatively, it is possible to use the included MINIZ library, a subset of ZLIB, by specifying the preprocessor symbol SQLITE3MC_USE_MINIZ=1. This allows to remove the external dependency on the ZLIB library.

TCL Interface

SQLite offers an implementation of a TCL interface and a TCL command shell. The source code of this interface is included with SQLite3 Multiple Ciphers.

SymbolDescription
SQLITE_ENABLE_TCL=1Enable the TCL interface

Please consult the original SQLite documentation Compiling the TCL interface for further information, how to build the TCL interface and TCL command shell, since SQLite3 Multiple Ciphers does not contain build support for this feature.


Copyright © 2020-2024 Ulrich Telle. Distributed under an MIT license.