]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Factor out DB protection lift and restore in CLI
authorlarrybr <larrybr@noemail.net>
Sun, 23 Jan 2022 20:54:25 +0000 (20:54 +0000)
committerlarrybr <larrybr@noemail.net>
Sun, 23 Jan 2022 20:54:25 +0000 (20:54 +0000)
FossilOrigin-Name: 4462ed896459ee0312f1989d9a813c65150347ebdd15b59b2aa86bbce3abec1c

manifest
manifest.uuid
src/shell.c.in

index 8bf5c320ab8f2228c485cc9604c18213e9866c4f..792037e6b766bdf6d52568e81b880a43517049f2 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Shell\srefinements,\sseeargs,\sbooleans,\sundocumented\scommands
-D 2022-01-23T04:19:52.352
+C Factor\sout\sDB\sprotection\slift\sand\srestore\sin\sCLI
+D 2022-01-23T20:54:25.776
 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
@@ -553,7 +553,7 @@ F src/random.c 097dc8b31b8fba5a9aca1697aeb9fd82078ec91be734c16bffda620ced7ab83c
 F src/resolve.c 359bc0e445d427583d2ab6110433a5dc777f64a0ecdf8d24826d8b475233ead9
 F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
 F src/select.c ab5717255420972e69b9b9ce4d1c4730fe82cfbdc14b7743e389a8bdb79ca027
-F src/shell.c.in 606bfe3ca0483b06c850da59b4fb4f47e16dfbee49422214267dd7c268d26fbf
+F src/shell.c.in 8c152178d813b1565d13e01a4e9f48a75185b11756dafc36c353aaff2fff68a8
 F src/sqlite.h.in 31c2c8d737814369bd3b71f3849c4a97ef7ede0aa3ce976ecb11632fa5f1f863
 F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
 F src/sqlite3ext.h 5d54cf13d3406d8eb65d921a0d3c349de6126b732e695e79ecd4830ce86b4f8a
@@ -1941,8 +1941,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
 F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 3f13df296b7d623085d2abb1a84fb9117f79f8e653a35956266da83727eeecba
-R 1835fab59c38083072a9387a8873dd19
+P 8735caf13fc7e30da2fc5dc90921acbb3109f965c63dbf69fa70ef19c02308c0
+R 6253b464049656a2fb8c9361c4f1fbc9
 U larrybr
-Z 6bc6450e96a876f9bc34f811c8b01b49
+Z 54f5d49a44974e01c687a7b7befc32d9
 # Remove this line to create a well-formed Fossil manifest.
index 300911993a47eb2fb88b0b7e4e128216ec12cfb0..5ff7000aa12ee61054f5deb8792934f9d82cb4ff 100644 (file)
@@ -1 +1 @@
-8735caf13fc7e30da2fc5dc90921acbb3109f965c63dbf69fa70ef19c02308c0
\ No newline at end of file
+4462ed896459ee0312f1989d9a813c65150347ebdd15b59b2aa86bbce3abec1c
\ No newline at end of file
index a5a30cb04111e55877cfbed2fcdc2563dd4371f9..d365a4ff80739707a702b72fa12caeafefd3f840 100644 (file)
@@ -3029,22 +3029,38 @@ static void restore_debug_trace_modes(void){
   sqlite3_test_control(SQLITE_TESTCTRL_TRACEFLAGS, 3, &savedWhereTrace);
 }
 
+/* DB schema protection for use by next two utility functions */
+typedef struct DbProtectState {
+  int wrSchema;
+  int defensiveMode;
+} DbProtectState;
+
+/* Allow system (sqlite_*) schema changes, return prior protection state. */
+static DbProtectState allow_sys_schema_change(sqlite3 *db){
+  DbProtectState rv;
+  sqlite3_db_config(db, SQLITE_DBCONFIG_DEFENSIVE, -1, &rv.defensiveMode);
+  sqlite3_db_config(db, SQLITE_DBCONFIG_DEFENSIVE, 0, 0);
+  sqlite3_db_config(db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, -1, &rv.wrSchema);
+  sqlite3_db_config(db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, 1, 0);
+  return rv;
+}
+
+/* Restore protection state using allow_sys_schema_change() return. */
+static void restore_sys_schema_protection( sqlite3 *db, DbProtectState *pPS ){
+  sqlite3_db_config(db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, pPS->wrSchema, 0);
+  sqlite3_db_config(db, SQLITE_DBCONFIG_DEFENSIVE, pPS->defensiveMode, 0);
+}
+
 /* Create the TEMP table used to store parameter bindings */
 static void bind_table_init(ShellState *p){
-  int wrSchema = 0;
-  int defensiveMode = 0;
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_DEFENSIVE, -1, &defensiveMode);
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_DEFENSIVE, 0, 0);
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, -1, &wrSchema);
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, 1, 0);
+  DbProtectState dps = allow_sys_schema_change(p->db);
   sqlite3_exec(p->db,
     "CREATE TABLE IF NOT EXISTS temp.sqlite_parameters(\n"
     "  key TEXT PRIMARY KEY,\n"
     "  value\n"
     ") WITHOUT ROWID;",
     0, 0, 0);
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_WRITABLE_SCHEMA, wrSchema, 0);
-  sqlite3_db_config(p->db, SQLITE_DBCONFIG_DEFENSIVE, defensiveMode, 0);
+  restore_sys_schema_protection( p->db, &dps );
 }
 
 /*