forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaccount_mapping.cc
131 lines (105 loc) · 3.52 KB
/
account_mapping.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
// Copyright 2014 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.
#include "google_apis/gcm/engine/account_mapping.h"
#include <stdint.h>
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_split.h"
#include "base/strings/string_util.h"
namespace gcm {
namespace {
const char kSeparator[] = "&";
const uint32_t kEmailIndex = 0;
const uint32_t kStatusIndex = 1;
const uint32_t kStatusChangeTimestampIndex = 2;
const uint32_t kSizeWithNoMessage = kStatusChangeTimestampIndex + 1;
const uint32_t kMessageIdIndex = 3;
const uint32_t kSizeWithMessage = kMessageIdIndex + 1;
const char kStatusNew[] = "new";
const char kStatusAdding[] = "adding";
const char kStatusMapped[] = "mapped";
const char kStatusRemoving[] = "removing";
std::string StatusToString(AccountMapping::MappingStatus status) {
switch (status) {
case AccountMapping::NEW:
return kStatusNew;
case AccountMapping::ADDING:
return kStatusAdding;
case AccountMapping::MAPPED:
return kStatusMapped;
case AccountMapping::REMOVING:
return kStatusRemoving;
default:
NOTREACHED();
}
return std::string();
}
bool StringToStatus(const std::string& status_str,
AccountMapping::MappingStatus* status) {
if (status_str.compare(kStatusAdding) == 0)
*status = AccountMapping::ADDING;
else if (status_str.compare(kStatusMapped) == 0)
*status = AccountMapping::MAPPED;
else if (status_str.compare(kStatusRemoving) == 0)
*status = AccountMapping::REMOVING;
else if (status_str.compare(kStatusNew) == 0)
*status = AccountMapping::NEW;
else
return false;
return true;
}
} // namespace
AccountMapping::AccountMapping() : status(NEW) {
}
AccountMapping::AccountMapping(const AccountMapping& other) = default;
AccountMapping::~AccountMapping() {
}
std::string AccountMapping::SerializeAsString() const {
std::string value;
value.append(email);
value.append(kSeparator);
value.append(StatusToString(status));
value.append(kSeparator);
value.append(base::Int64ToString(status_change_timestamp.ToInternalValue()));
if (!last_message_id.empty()) {
value.append(kSeparator);
value.append(last_message_id);
}
return value;
}
bool AccountMapping::ParseFromString(const std::string& value) {
std::vector<std::string> values = base::SplitString(
value, kSeparator, base::KEEP_WHITESPACE, base::SPLIT_WANT_NONEMPTY);
if (values.size() != kSizeWithNoMessage &&
values.size() != kSizeWithMessage) {
return false;
}
if (values[kEmailIndex].empty() ||
values[kStatusChangeTimestampIndex].empty() ||
values[kStatusIndex].empty()) {
return false;
}
if (values.size() == kSizeWithMessage && values[kMessageIdIndex].empty())
return false;
MappingStatus temp_status;
if (!StringToStatus(values[kStatusIndex], &temp_status))
return false;
if (values.size() == kSizeWithNoMessage && temp_status == ADDING)
return false;
int64_t status_change_ts_internal = 0LL;
if (!base::StringToInt64(values[kStatusChangeTimestampIndex],
&status_change_ts_internal)) {
return false;
}
status_change_timestamp =
base::Time::FromInternalValue(status_change_ts_internal);
status = temp_status;
email = values[kEmailIndex];
access_token.clear();
if (values.size() == kSizeWithMessage)
last_message_id = values[kMessageIdIndex];
else
last_message_id.clear();
return true;
}
} // namespace gcm