diff options
author | Jeremy Harris <jgh146exb@wizmail.org> | 2020-06-28 15:24:21 +0100 |
---|---|---|
committer | Jeremy Harris <jgh146exb@wizmail.org> | 2020-06-28 15:24:21 +0100 |
commit | 3d0472791a0928963a3f8184fe28479e80d1a47d (patch) | |
tree | 0cbb1ccab503d1ff3e4fd7438dbcfcbc16a98dfe /src | |
parent | 8b138ff95dfb4cfcfc2313a94632d0a7320f37fe (diff) |
Sqlite: fix segfault on bad/missing sqlite_dbfile. Bug 2606
Diffstat (limited to 'src')
-rw-r--r-- | src/src/lookups/sqlite.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/src/lookups/sqlite.c b/src/src/lookups/sqlite.c index dc4439153..1638ea401 100644 --- a/src/src/lookups/sqlite.c +++ b/src/src/lookups/sqlite.c @@ -24,16 +24,23 @@ sqlite_open(const uschar * filename, uschar ** errmsg) sqlite3 *db = NULL; int ret; -if (!filename || !*filename) filename = sqlite_dbfile; -if (*filename != '/') +if (!filename || !*filename) + { + DEBUG(D_lookup) debug_printf_indent("Using sqlite_dbfile: %s\n", sqlite_dbfile); + filename = sqlite_dbfile; + } +if (!filename || *filename != '/') *errmsg = US"absolute file name expected for \"sqlite\" lookup"; else if ((ret = sqlite3_open(CCS filename, &db)) != 0) { *errmsg = (void *)sqlite3_errmsg(db); + sqlite3_close(db); + db = NULL; DEBUG(D_lookup) debug_printf_indent("Error opening database: %s\n", *errmsg); } -sqlite3_busy_timeout(db, 1000 * sqlite_lock_timeout); +if (db) + sqlite3_busy_timeout(db, 1000 * sqlite_lock_timeout); return db; } |