mirror of
https://github.com/status-im/status-go.git
synced 2025-01-11 23:25:29 +00:00
e8c4b7647f
* chore(upgradeSQLCipher): Upgrading SQLCipher to version 5.4.5 Changes: ### github.com/mutecomm/go-sqlcipher 1. The improved crypto argorighms from go-sqlcipher v3 are merged in v4 Tags: v4.4.2-status.1 - merge `burn_stack` improvement v4.4.2-status.2 - merge `SHA1` improvement v4.4.2-status.4- merge 'AES' improvement 2. Fixed `go-sqlcipher` to support v3 database in compatibility mode (`sqlcipher` already supports this) (Tag: v4.4.2-status.3) 3. Upgrade `sqlcipher` to v5.4.5 (Tag: v4.5.4-status.1) ### github.com/status-im/migrate/v4 1. Upgrade `go-sqlcipher` version in `github.com/status-im/migrate/v4` ### status-go 1. Upgrade `go-sqlcipher` and `migrate` modules in status-go 2. Configure the DB connections to open the DB in v3 compatibility mode * chore(upgradeSQLCipher): Use sqlcipher v3 configuration to encrypt a plain text database * chore(upgradeSQLCipher): Scanning NULL BLOB value should return nil Fixing failing tests: TestSyncDeviceSuite/TestPairingSyncDeviceClientAsReceiver; TestSyncDeviceSuite/TestPairingSyncDeviceClientAsSender Considering the following configuration: 1. Table with BLOB column has 1 NULL value 2. Query the value 3. Rows.Scan(&dest sql.NullString) Expected: dest.Valid == false; dest.String == nil Actual: dest.Valid == true; dest.String == "" * chore: Bump go-sqlcipher version to include NULL BLOB fix
85 lines
1.8 KiB
Go
85 lines
1.8 KiB
Go
// Copyright (C) 2019 Yasuhiro Matsumoto <mattn.jp@gmail.com>.
|
|
//
|
|
// Use of this source code is governed by an MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build !sqlite_omit_load_extension
|
|
|
|
package sqlite3
|
|
|
|
/*
|
|
#ifndef USE_LIBSQLITE3
|
|
#include <sqlite3-binding.h>
|
|
#else
|
|
#include <sqlite3.h>
|
|
#endif
|
|
#include <stdlib.h>
|
|
*/
|
|
import "C"
|
|
import (
|
|
"errors"
|
|
"unsafe"
|
|
)
|
|
|
|
func (c *SQLiteConn) loadExtensions(extensions []string) error {
|
|
rv := C.sqlite3_enable_load_extension(c.db, 1)
|
|
if rv != C.SQLITE_OK {
|
|
return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
|
|
}
|
|
|
|
for _, extension := range extensions {
|
|
if err := c.loadExtension(extension, nil); err != nil {
|
|
C.sqlite3_enable_load_extension(c.db, 0)
|
|
return err
|
|
}
|
|
}
|
|
|
|
rv = C.sqlite3_enable_load_extension(c.db, 0)
|
|
if rv != C.SQLITE_OK {
|
|
return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// LoadExtension load the sqlite3 extension.
|
|
func (c *SQLiteConn) LoadExtension(lib string, entry string) error {
|
|
rv := C.sqlite3_enable_load_extension(c.db, 1)
|
|
if rv != C.SQLITE_OK {
|
|
return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
|
|
}
|
|
|
|
if err := c.loadExtension(lib, &entry); err != nil {
|
|
C.sqlite3_enable_load_extension(c.db, 0)
|
|
return err
|
|
}
|
|
|
|
rv = C.sqlite3_enable_load_extension(c.db, 0)
|
|
if rv != C.SQLITE_OK {
|
|
return errors.New(C.GoString(C.sqlite3_errmsg(c.db)))
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c *SQLiteConn) loadExtension(lib string, entry *string) error {
|
|
clib := C.CString(lib)
|
|
defer C.free(unsafe.Pointer(clib))
|
|
|
|
var centry *C.char
|
|
if entry != nil {
|
|
centry = C.CString(*entry)
|
|
defer C.free(unsafe.Pointer(centry))
|
|
}
|
|
|
|
var errMsg *C.char
|
|
defer C.sqlite3_free(unsafe.Pointer(errMsg))
|
|
|
|
rv := C.sqlite3_load_extension(c.db, clib, centry, &errMsg)
|
|
if rv != C.SQLITE_OK {
|
|
return errors.New(C.GoString(errMsg))
|
|
}
|
|
|
|
return nil
|
|
}
|