mirror of
https://github.com/status-im/status-go.git
synced 2025-01-10 14:47:06 +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
104 lines
3.0 KiB
Go
104 lines
3.0 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.
|
|
|
|
package sqlite3
|
|
|
|
/*
|
|
|
|
#ifndef USE_LIBSQLITE3
|
|
#include <sqlite3-binding.h>
|
|
#else
|
|
#include <sqlite3.h>
|
|
#endif
|
|
#include <stdlib.h>
|
|
// These wrappers are necessary because SQLITE_TRANSIENT
|
|
// is a pointer constant, and cgo doesn't translate them correctly.
|
|
|
|
static inline void my_result_text(sqlite3_context *ctx, char *p, int np) {
|
|
sqlite3_result_text(ctx, p, np, SQLITE_TRANSIENT);
|
|
}
|
|
|
|
static inline void my_result_blob(sqlite3_context *ctx, void *p, int np) {
|
|
sqlite3_result_blob(ctx, p, np, SQLITE_TRANSIENT);
|
|
}
|
|
*/
|
|
import "C"
|
|
|
|
import (
|
|
"math"
|
|
"reflect"
|
|
"unsafe"
|
|
)
|
|
|
|
const i64 = unsafe.Sizeof(int(0)) > 4
|
|
|
|
// SQLiteContext behave sqlite3_context
|
|
type SQLiteContext C.sqlite3_context
|
|
|
|
// ResultBool sets the result of an SQL function.
|
|
func (c *SQLiteContext) ResultBool(b bool) {
|
|
if b {
|
|
c.ResultInt(1)
|
|
} else {
|
|
c.ResultInt(0)
|
|
}
|
|
}
|
|
|
|
// ResultBlob sets the result of an SQL function.
|
|
// See: sqlite3_result_blob, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultBlob(b []byte) {
|
|
if i64 && len(b) > math.MaxInt32 {
|
|
C.sqlite3_result_error_toobig((*C.sqlite3_context)(c))
|
|
return
|
|
}
|
|
var p *byte
|
|
if len(b) > 0 {
|
|
p = &b[0]
|
|
}
|
|
C.my_result_blob((*C.sqlite3_context)(c), unsafe.Pointer(p), C.int(len(b)))
|
|
}
|
|
|
|
// ResultDouble sets the result of an SQL function.
|
|
// See: sqlite3_result_double, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultDouble(d float64) {
|
|
C.sqlite3_result_double((*C.sqlite3_context)(c), C.double(d))
|
|
}
|
|
|
|
// ResultInt sets the result of an SQL function.
|
|
// See: sqlite3_result_int, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultInt(i int) {
|
|
if i64 && (i > math.MaxInt32 || i < math.MinInt32) {
|
|
C.sqlite3_result_int64((*C.sqlite3_context)(c), C.sqlite3_int64(i))
|
|
} else {
|
|
C.sqlite3_result_int((*C.sqlite3_context)(c), C.int(i))
|
|
}
|
|
}
|
|
|
|
// ResultInt64 sets the result of an SQL function.
|
|
// See: sqlite3_result_int64, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultInt64(i int64) {
|
|
C.sqlite3_result_int64((*C.sqlite3_context)(c), C.sqlite3_int64(i))
|
|
}
|
|
|
|
// ResultNull sets the result of an SQL function.
|
|
// See: sqlite3_result_null, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultNull() {
|
|
C.sqlite3_result_null((*C.sqlite3_context)(c))
|
|
}
|
|
|
|
// ResultText sets the result of an SQL function.
|
|
// See: sqlite3_result_text, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultText(s string) {
|
|
h := (*reflect.StringHeader)(unsafe.Pointer(&s))
|
|
cs, l := (*C.char)(unsafe.Pointer(h.Data)), C.int(h.Len)
|
|
C.my_result_text((*C.sqlite3_context)(c), cs, l)
|
|
}
|
|
|
|
// ResultZeroblob sets the result of an SQL function.
|
|
// See: sqlite3_result_zeroblob, http://sqlite.org/c3ref/result_blob.html
|
|
func (c *SQLiteContext) ResultZeroblob(n int) {
|
|
C.sqlite3_result_zeroblob((*C.sqlite3_context)(c), C.int(n))
|
|
}
|