Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(470)

Side by Side Diff: chrome/browser/android/datausage/external_data_use_observer_android.cc

Issue 1393073002: Add external data use observer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@datause_accounting_scliitle_cl_do_not_edit_2
Patch Set: Updated Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/android/datausage/external_data_use_observer_android.h"
6
7 #include <string>
8
9 #include "base/android/jni_string.h"
10 #include "base/strings/string_piece.h"
11 #include "base/strings/string_util.h"
12 #include "jni/ExternalDataUseObserverAndroid_jni.h"
13 #include "third_party/re2/re2/re2.h"
14 #include "url/gurl.h"
15
16 using base::android::ConvertUTF8ToJavaString;
17
18 namespace chrome {
19
20 namespace android {
21
22 ExternalDataUseObserverAndroid::ExternalDataUseObserverAndroid(
23 data_usage::DataUseAggregator* data_use_aggregator)
24 : data_use_aggregator_(data_use_aggregator) {
25 if (!data_use_aggregator_)
26 return;
27 JNIEnv* env = base::android::AttachCurrentThread();
28 DCHECK(j_external_data_use_observer_.is_null());
29 j_external_data_use_observer_.Reset(
30 Java_ExternalDataUseObserverAndroid_create(
31 env, base::android::GetApplicationContext(),
32 reinterpret_cast<intptr_t>(this)));
33 DCHECK(!j_external_data_use_observer_.is_null());
34 }
35
36 ExternalDataUseObserverAndroid::~ExternalDataUseObserverAndroid() {
37 DCHECK(thread_checker_.CalledOnValidThread());
38
39 if (!data_use_aggregator_)
40 return;
41 if (url_regexes_.size() > 0)
42 data_use_aggregator_->RemoveObserver(this);
43 }
44
45 bool ExternalDataUseObserverAndroid::Matches(const GURL& gurl) const {
46 if (!gurl.is_valid() || gurl.is_empty())
47 return false;
48
49 std::string gurl_spec = gurl.spec();
sclittle 2015/10/09 22:59:28 nit: To avoid the unnecessary string allocation, c
tbansal1 2015/10/12 16:47:36 Done.
50
51 for (const std::string& url_regex : url_regexes_) {
52 if (re2::RE2::FullMatch(gurl_spec, url_regex))
53 return true;
54 }
55
56 return false;
57 }
58
59 void ExternalDataUseObserverAndroid::OnDataUse(
60 const std::vector<data_usage::DataUse>& data_use_sequence) {
61 DCHECK(thread_checker_.CalledOnValidThread());
62 DCHECK(!j_external_data_use_observer_.is_null());
63
64 JNIEnv* env = base::android::AttachCurrentThread();
65
66 for (const auto& data_use : data_use_sequence) {
67 if (!Matches(data_use.url))
68 continue;
69
70 std::string tag = ""; // data_use.tab_id;
71 int64_t bytes_downloaded = data_use.rx_bytes;
72 int64_t bytes_uploaded = data_use.tx_bytes;
73 Java_ExternalDataUseObserverAndroid_onDataUse(
sclittle 2015/10/09 22:59:28 Hmmm - as the aggregator exists right now, this wi
tbansal1 2015/10/12 16:47:35 Added TODO for buffering. Plan is to report every
74 env, j_external_data_use_observer_.obj(),
75 ConvertUTF8ToJavaString(env, tag).obj(), bytes_downloaded,
76 bytes_uploaded);
77 }
78 }
79
80 void ExternalDataUseObserverAndroid::RegisterURLRegexes(
81 const std::vector<std::string>& url_regexes) {
82 DCHECK(thread_checker_.CalledOnValidThread());
83
84 bool registered_as_observer = url_regexes_.size() > 0;
85 if (!registered_as_observer && url_regexes.size() > 0) {
86 registered_as_observer = true;
87 data_use_aggregator_->AddObserver(this);
88 }
89
90 url_regexes_.clear();
91
92 for (const std::string& url_regex : url_regexes) {
93 if (url_regex.empty())
94 continue;
95 base::StringPiece url_regex_stringpiece(url_regex);
96 url_regexes_.push_back(ToLowerASCII(url_regex_stringpiece));
97 }
98
99 // Unregister as an observer if no regular expressions were received.
100 if (url_regexes_.size() == 0 && registered_as_observer)
101 data_use_aggregator_->RemoveObserver(this);
102 }
103
104 bool RegisterExternalDataUseObserverAndroid(JNIEnv* env) {
105 return RegisterNativesImpl(env);
106 }
107
108 } // namespace android
109
110 } // namespace chrome
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698