blob: ee07f68a879394c618ec5548f2f2f3cfa56f8400 [file] [log] [blame]
[email protected]90e800c2012-06-12 23:11:001// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]8703b2b2011-03-15 09:51:502// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "base/value_conversions.h"
6
avi9b6f42932015-12-26 22:15:147#include <stdint.h>
8
yucliud62536a2017-08-01 06:06:309#include <algorithm>
[email protected]c014f2b32013-09-03 23:29:1210#include <string>
yucliud62536a2017-08-01 06:06:3011#include <vector>
[email protected]c014f2b32013-09-03 23:29:1212
[email protected]57999812013-02-24 05:40:5213#include "base/files/file_path.h"
vabrbce355c2017-03-23 18:52:4314#include "base/memory/ptr_util.h"
[email protected]dfa049e2013-02-07 02:57:2215#include "base/strings/string_number_conversions.h"
[email protected]8f9a3a52013-06-28 15:14:1816#include "base/time/time.h"
yucliud62536a2017-08-01 06:06:3017#include "base/unguessable_token.h"
[email protected]8703b2b2011-03-15 09:51:5018#include "base/values.h"
19
20namespace base {
yucliud62536a2017-08-01 06:06:3021namespace {
22// Helper for serialize/deserialize UnguessableToken.
23union UnguessableTokenRepresentation {
24 struct Field {
25 uint64_t high;
26 uint64_t low;
27 } field;
28
29 uint8_t buffer[sizeof(Field)];
30};
31} // namespace
[email protected]8703b2b2011-03-15 09:51:5032
[email protected]8703b2b2011-03-15 09:51:5033// |Value| internally stores strings in UTF-8, so we have to convert from the
34// system native code to UTF-8 and back.
Christian Dullweber13740082018-07-26 13:09:0935Value CreateFilePathValue(const FilePath& in_value) {
36 return Value(in_value.AsUTF8Unsafe());
[email protected]8703b2b2011-03-15 09:51:5037}
38
39bool GetValueAsFilePath(const Value& value, FilePath* file_path) {
40 std::string str;
41 if (!value.GetAsString(&str))
42 return false;
43 if (file_path)
[email protected]45440512011-11-02 04:55:2344 *file_path = FilePath::FromUTF8Unsafe(str);
[email protected]8703b2b2011-03-15 09:51:5045 return true;
46}
47
Xiaohan Wangec1c552a2019-02-07 18:29:0848// It is recommended in time.h to use ToDeltaSinceWindowsEpoch() and
49// FromDeltaSinceWindowsEpoch() for opaque serialization and
50// deserialization of time values.
51Value CreateTimeValue(const Time& time) {
52 return CreateTimeDeltaValue(time.ToDeltaSinceWindowsEpoch());
53}
54
55bool GetValueAsTime(const Value& value, Time* time) {
56 TimeDelta time_delta;
57 if (!GetValueAsTimeDelta(value, &time_delta))
58 return false;
59
60 if (time)
61 *time = Time::FromDeltaSinceWindowsEpoch(time_delta);
62 return true;
63}
64
[email protected]90e800c2012-06-12 23:11:0065// |Value| does not support 64-bit integers, and doubles do not have enough
66// precision, so we store the 64-bit time value as a string instead.
Xiaohan Wangec1c552a2019-02-07 18:29:0867Value CreateTimeDeltaValue(const TimeDelta& time_delta) {
68 std::string string_value = base::Int64ToString(time_delta.InMicroseconds());
Christian Dullweber13740082018-07-26 13:09:0969 return Value(string_value);
[email protected]90e800c2012-06-12 23:11:0070}
71
Xiaohan Wangec1c552a2019-02-07 18:29:0872bool GetValueAsTimeDelta(const Value& value, TimeDelta* time_delta) {
[email protected]90e800c2012-06-12 23:11:0073 std::string str;
avi9b6f42932015-12-26 22:15:1474 int64_t int_value;
[email protected]90e800c2012-06-12 23:11:0075 if (!value.GetAsString(&str) || !base::StringToInt64(str, &int_value))
76 return false;
Xiaohan Wangec1c552a2019-02-07 18:29:0877 if (time_delta)
78 *time_delta = TimeDelta::FromMicroseconds(int_value);
[email protected]90e800c2012-06-12 23:11:0079 return true;
80}
81
Christian Dullweber13740082018-07-26 13:09:0982Value CreateUnguessableTokenValue(const UnguessableToken& token) {
yucliud62536a2017-08-01 06:06:3083 UnguessableTokenRepresentation representation;
84 representation.field.high = token.GetHighForSerialization();
85 representation.field.low = token.GetLowForSerialization();
86
Christian Dullweber13740082018-07-26 13:09:0987 return Value(HexEncode(representation.buffer, sizeof(representation.buffer)));
yucliud62536a2017-08-01 06:06:3088}
89
90bool GetValueAsUnguessableToken(const Value& value, UnguessableToken* token) {
91 if (!value.is_string()) {
92 return false;
93 }
94
95 // TODO(dcheng|yucliu): Make a function that accepts non vector variant and
96 // reads a fixed number of bytes.
97 std::vector<uint8_t> high_low_bytes;
98 if (!HexStringToBytes(value.GetString(), &high_low_bytes)) {
99 return false;
100 }
101
102 UnguessableTokenRepresentation representation;
103 if (high_low_bytes.size() != sizeof(representation.buffer)) {
104 return false;
105 }
106
107 std::copy(high_low_bytes.begin(), high_low_bytes.end(),
108 std::begin(representation.buffer));
109 *token = UnguessableToken::Deserialize(representation.field.high,
110 representation.field.low);
111 return true;
112}
113
[email protected]8703b2b2011-03-15 09:51:50114} // namespace base