// Copyright (c) 2010 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // // Implement the storage of service tokens in memory. #include "chrome/browser/sync/util/user_settings.h" #include "base/logging.h" #include "chrome/browser/password_manager/encryptor.h" #include "chrome/common/sqlite_utils.h" namespace browser_sync { void UserSettings::SetAuthTokenForService( const std::string& email, const std::string& service_name, const std::string& long_lived_service_token) { VLOG(1) << "Saving auth token " << long_lived_service_token << " for " << email << "for service " << service_name; std::string encrypted_service_token; if (!Encryptor::EncryptString(long_lived_service_token, &encrypted_service_token)) { LOG(ERROR) << "Encrytion failed: " << long_lived_service_token; return; } ScopedDBHandle dbhandle(this); SQLStatement statement; statement.prepare(dbhandle.get(), "INSERT INTO cookies " "(email, service_name, service_token) " "values (?, ?, ?)"); statement.bind_string(0, email); statement.bind_string(1, service_name); statement.bind_blob(2, encrypted_service_token.data(), encrypted_service_token.size()); if (SQLITE_DONE != statement.step()) { LOG(FATAL) << sqlite3_errmsg(dbhandle.get()); } } bool UserSettings::GetLastUserAndServiceToken(const std::string& service_name, std::string* username, std::string* service_token) { ScopedDBHandle dbhandle(this); SQLStatement query; query.prepare(dbhandle.get(), "SELECT email, service_token FROM cookies" " WHERE service_name = ?"); query.bind_string(0, service_name.c_str()); if (SQLITE_ROW == query.step()) { std::string encrypted_service_token; query.column_blob_as_string(1, &encrypted_service_token); if (!Encryptor::DecryptString(encrypted_service_token, service_token)) { LOG(ERROR) << "Decryption failed: " << encrypted_service_token; return false; } *username = query.column_string(0); VLOG(1) << "Found service token for:" << *username << " @ " << service_name << " returning: " << *service_token; return true; } VLOG(1) << "Couldn't find service token for " << service_name; return false; } } // namespace browser_sync