This source file includes following definitions.
- EndsWithSpace
- DecryptPasswordSpecifics
- SyncAPINameToServerName
- ServerNameToSyncAPIName
- IsNameServerIllegalAfterTrimming
- AreSpecificsEqual
#include "sync/internal_api/syncapi_internal.h"
#include "base/memory/scoped_ptr.h"
#include "sync/protocol/password_specifics.pb.h"
#include "sync/protocol/sync.pb.h"
#include "sync/util/cryptographer.h"
namespace syncer {
namespace {
bool EndsWithSpace(const std::string& string) {
return !string.empty() && *string.rbegin() == ' ';
}
}
sync_pb::PasswordSpecificsData* DecryptPasswordSpecifics(
const sync_pb::EntitySpecifics& specifics, Cryptographer* crypto) {
if (!specifics.has_password())
return NULL;
const sync_pb::PasswordSpecifics& password_specifics = specifics.password();
if (!password_specifics.has_encrypted())
return NULL;
const sync_pb::EncryptedData& encrypted = password_specifics.encrypted();
scoped_ptr<sync_pb::PasswordSpecificsData> data(
new sync_pb::PasswordSpecificsData);
if (!crypto->Decrypt(encrypted, data.get()))
return NULL;
return data.release();
}
static const char* kForbiddenServerNames[] = { "", ".", ".." };
void SyncAPINameToServerName(const std::string& syncer_name,
std::string* out) {
*out = syncer_name;
if (IsNameServerIllegalAfterTrimming(*out))
out->append(" ");
}
void ServerNameToSyncAPIName(const std::string& server_name,
std::string* out) {
CHECK(out);
int length_to_copy = server_name.length();
if (IsNameServerIllegalAfterTrimming(server_name) &&
EndsWithSpace(server_name)) {
--length_to_copy;
}
*out = server_name.substr(0, length_to_copy);
}
bool IsNameServerIllegalAfterTrimming(const std::string& name) {
size_t untrimmed_count = name.find_last_not_of(' ') + 1;
for (size_t i = 0; i < arraysize(kForbiddenServerNames); ++i) {
if (name.compare(0, untrimmed_count, kForbiddenServerNames[i]) == 0)
return true;
}
return false;
}
bool AreSpecificsEqual(const Cryptographer* cryptographer,
const sync_pb::EntitySpecifics& left,
const sync_pb::EntitySpecifics& right) {
std::string left_plaintext, right_plaintext;
if (left.has_encrypted()) {
if (!cryptographer->CanDecrypt(left.encrypted())) {
NOTREACHED() << "Attempting to compare undecryptable data.";
return false;
}
left_plaintext = cryptographer->DecryptToString(left.encrypted());
} else {
left_plaintext = left.SerializeAsString();
}
if (right.has_encrypted()) {
if (!cryptographer->CanDecrypt(right.encrypted())) {
NOTREACHED() << "Attempting to compare undecryptable data.";
return false;
}
right_plaintext = cryptographer->DecryptToString(right.encrypted());
} else {
right_plaintext = right.SerializeAsString();
}
if (left_plaintext == right_plaintext) {
return true;
}
return false;
}
}