OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "sql/connection.h" | 5 #include "sql/connection.h" |
6 | 6 |
7 #include <string.h> | 7 #include <string.h> |
8 | 8 |
9 #include "base/files/file_path.h" | 9 #include "base/files/file_path.h" |
10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
(...skipping 150 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
161 // handler. In that case maintain the sense of |was_valid_| which | 161 // handler. In that case maintain the sense of |was_valid_| which |
162 // previously held for this ref. | 162 // previously held for this ref. |
163 was_valid_ = was_valid_ && forced; | 163 was_valid_ = was_valid_ && forced; |
164 } | 164 } |
165 | 165 |
166 Connection::Connection() | 166 Connection::Connection() |
167 : db_(NULL), | 167 : db_(NULL), |
168 page_size_(0), | 168 page_size_(0), |
169 cache_size_(0), | 169 cache_size_(0), |
170 exclusive_locking_(false), | 170 exclusive_locking_(false), |
| 171 restrict_to_user_(false), |
171 transaction_nesting_(0), | 172 transaction_nesting_(0), |
172 needs_rollback_(false), | 173 needs_rollback_(false), |
173 in_memory_(false), | 174 in_memory_(false), |
174 poisoned_(false) { | 175 poisoned_(false) { |
175 } | 176 } |
176 | 177 |
177 Connection::~Connection() { | 178 Connection::~Connection() { |
178 Close(); | 179 Close(); |
179 } | 180 } |
180 | 181 |
(...skipping 540 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
721 // Histogram failures specific to initial open for debugging | 722 // Histogram failures specific to initial open for debugging |
722 // purposes. | 723 // purposes. |
723 UMA_HISTOGRAM_ENUMERATION("Sqlite.OpenFailure", err & 0xff, 50); | 724 UMA_HISTOGRAM_ENUMERATION("Sqlite.OpenFailure", err & 0xff, 50); |
724 | 725 |
725 OnSqliteError(err, NULL); | 726 OnSqliteError(err, NULL); |
726 Close(); | 727 Close(); |
727 db_ = NULL; | 728 db_ = NULL; |
728 return false; | 729 return false; |
729 } | 730 } |
730 | 731 |
| 732 // TODO(shess): OS_WIN support? |
| 733 #if defined(OS_POSIX) |
| 734 if (restrict_to_user_) { |
| 735 DCHECK_NE(file_name, std::string(":memory")); |
| 736 base::FilePath file_path(file_name); |
| 737 int mode = 0; |
| 738 // TODO(shess): Arguably, failure to retrieve and change |
| 739 // permissions should be fatal if the file exists. |
| 740 if (file_util::GetPosixFilePermissions(file_path, &mode)) { |
| 741 mode &= file_util::FILE_PERMISSION_USER_MASK; |
| 742 file_util::SetPosixFilePermissions(file_path, mode); |
| 743 |
| 744 // SQLite sets the permissions on these files from the main |
| 745 // database on create. Set them here in case they already exist |
| 746 // at this point. Failure to set these permissions should not |
| 747 // be fatal unless the file doesn't exist. |
| 748 base::FilePath journal_path(file_name + FILE_PATH_LITERAL("-journal")); |
| 749 base::FilePath wal_path(file_name + FILE_PATH_LITERAL("-wal")); |
| 750 file_util::SetPosixFilePermissions(journal_path, mode); |
| 751 file_util::SetPosixFilePermissions(wal_path, mode); |
| 752 } |
| 753 } |
| 754 #endif // defined(OS_POSIX) |
| 755 |
731 // SQLite uses a lookaside buffer to improve performance of small mallocs. | 756 // SQLite uses a lookaside buffer to improve performance of small mallocs. |
732 // Chromium already depends on small mallocs being efficient, so we disable | 757 // Chromium already depends on small mallocs being efficient, so we disable |
733 // this to avoid the extra memory overhead. | 758 // this to avoid the extra memory overhead. |
734 // This must be called immediatly after opening the database before any SQL | 759 // This must be called immediatly after opening the database before any SQL |
735 // statements are run. | 760 // statements are run. |
736 sqlite3_db_config(db_, SQLITE_DBCONFIG_LOOKASIDE, NULL, 0, 0); | 761 sqlite3_db_config(db_, SQLITE_DBCONFIG_LOOKASIDE, NULL, 0, 0); |
737 | 762 |
738 // sqlite3_open() does not actually read the database file (unless a | 763 // sqlite3_open() does not actually read the database file (unless a |
739 // hot journal is found). Successfully executing this pragma on an | 764 // hot journal is found). Successfully executing this pragma on an |
740 // existing database requires a valid header on page 1. | 765 // existing database requires a valid header on page 1. |
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
902 } | 927 } |
903 | 928 |
904 // Best effort to put things back as they were before. | 929 // Best effort to put things back as they were before. |
905 const char kNoWritableSchema[] = "PRAGMA writable_schema = OFF"; | 930 const char kNoWritableSchema[] = "PRAGMA writable_schema = OFF"; |
906 ignore_result(Execute(kNoWritableSchema)); | 931 ignore_result(Execute(kNoWritableSchema)); |
907 | 932 |
908 return ret; | 933 return ret; |
909 } | 934 } |
910 | 935 |
911 } // namespace sql | 936 } // namespace sql |
OLD | NEW |