OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/android/preferences/pref_service_bridge.h" | 5 #include "chrome/browser/android/preferences/pref_service_bridge.h" |
6 | 6 |
7 #include <jni.h> | 7 #include <jni.h> |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 | 9 |
10 #include <memory> | 10 #include <memory> |
(...skipping 586 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
597 } | 597 } |
598 | 598 |
599 static void ClearBrowsingData( | 599 static void ClearBrowsingData( |
600 JNIEnv* env, | 600 JNIEnv* env, |
601 const JavaParamRef<jobject>& obj, | 601 const JavaParamRef<jobject>& obj, |
602 const JavaParamRef<jintArray>& data_types, | 602 const JavaParamRef<jintArray>& data_types, |
603 jint time_period, | 603 jint time_period, |
604 const JavaParamRef<jobjectArray>& jexcluding_domains) { | 604 const JavaParamRef<jobjectArray>& jexcluding_domains) { |
605 BrowsingDataRemover* browsing_data_remover = | 605 BrowsingDataRemover* browsing_data_remover = |
606 BrowsingDataRemoverFactory::GetForBrowserContext(GetOriginalProfile()); | 606 BrowsingDataRemoverFactory::GetForBrowserContext(GetOriginalProfile()); |
607 // ClearBrowsingDataObserver deletes itself when |browsing_data_remover| is | |
608 // done. | |
609 new ClearBrowsingDataObserver(env, obj, browsing_data_remover); | |
610 | 607 |
611 std::vector<int> data_types_vector; | 608 std::vector<int> data_types_vector; |
612 base::android::JavaIntArrayToIntVector(env, data_types, &data_types_vector); | 609 base::android::JavaIntArrayToIntVector(env, data_types, &data_types_vector); |
613 | 610 |
614 int remove_mask = 0; | 611 int remove_mask = 0; |
615 for (const int data_type : data_types_vector) { | 612 for (const int data_type : data_types_vector) { |
616 switch (static_cast<browsing_data::BrowsingDataType>(data_type)) { | 613 switch (static_cast<browsing_data::BrowsingDataType>(data_type)) { |
617 case browsing_data::HISTORY: | 614 case browsing_data::HISTORY: |
618 remove_mask |= BrowsingDataRemover::REMOVE_HISTORY; | 615 remove_mask |= BrowsingDataRemover::REMOVE_HISTORY; |
619 break; | 616 break; |
(...skipping 14 matching lines...) Expand all Loading... |
634 // Bookmarks are deleted separately on the Java side. | 631 // Bookmarks are deleted separately on the Java side. |
635 NOTREACHED(); | 632 NOTREACHED(); |
636 break; | 633 break; |
637 case browsing_data::NUM_TYPES: | 634 case browsing_data::NUM_TYPES: |
638 NOTREACHED(); | 635 NOTREACHED(); |
639 } | 636 } |
640 } | 637 } |
641 std::vector<std::string> excluding_domains; | 638 std::vector<std::string> excluding_domains; |
642 base::android::AppendJavaStringArrayToStringVector( | 639 base::android::AppendJavaStringArrayToStringVector( |
643 env, jexcluding_domains.obj(), &excluding_domains); | 640 env, jexcluding_domains.obj(), &excluding_domains); |
644 RegistrableDomainFilterBuilder filter_builder( | 641 std::unique_ptr<RegistrableDomainFilterBuilder> filter_builder( |
645 BrowsingDataFilterBuilder::BLACKLIST); | 642 new RegistrableDomainFilterBuilder(BrowsingDataFilterBuilder::BLACKLIST)); |
646 for (const std::string& domain : excluding_domains) { | 643 for (const std::string& domain : excluding_domains) { |
647 filter_builder.AddRegisterableDomain(domain); | 644 filter_builder->AddRegisterableDomain(domain); |
648 } | 645 } |
649 | 646 |
650 if (!excluding_domains.empty()) { | 647 if (!excluding_domains.empty()) { |
651 ImportantSitesUtil::RecordMetricsForBlacklistedSites(GetOriginalProfile(), | 648 ImportantSitesUtil::RecordMetricsForBlacklistedSites(GetOriginalProfile(), |
652 excluding_domains); | 649 excluding_domains); |
653 } | 650 } |
654 | 651 |
655 browsing_data_remover->RemoveWithFilter( | 652 // ClearBrowsingDataObserver deletes itself when |browsing_data_remover| is |
| 653 // done. |
| 654 ClearBrowsingDataObserver* observer = |
| 655 new ClearBrowsingDataObserver(env, obj, browsing_data_remover); |
| 656 |
| 657 browsing_data_remover->RemoveWithFilterAndReply( |
656 BrowsingDataRemover::Period( | 658 BrowsingDataRemover::Period( |
657 static_cast<browsing_data::TimePeriod>(time_period)), | 659 static_cast<browsing_data::TimePeriod>(time_period)), |
658 remove_mask, BrowsingDataHelper::UNPROTECTED_WEB, filter_builder); | 660 remove_mask, BrowsingDataHelper::UNPROTECTED_WEB, |
| 661 std::move(filter_builder), observer); |
659 } | 662 } |
660 | 663 |
661 static jboolean CanDeleteBrowsingHistory(JNIEnv* env, | 664 static jboolean CanDeleteBrowsingHistory(JNIEnv* env, |
662 const JavaParamRef<jobject>& obj) { | 665 const JavaParamRef<jobject>& obj) { |
663 return GetPrefService()->GetBoolean(prefs::kAllowDeletingBrowserHistory); | 666 return GetPrefService()->GetBoolean(prefs::kAllowDeletingBrowserHistory); |
664 } | 667 } |
665 | 668 |
666 static void FetchImportantSites(JNIEnv* env, | 669 static void FetchImportantSites(JNIEnv* env, |
667 const JavaParamRef<jclass>& clazz, | 670 const JavaParamRef<jclass>& clazz, |
668 const JavaParamRef<jobject>& java_callback) { | 671 const JavaParamRef<jobject>& java_callback) { |
(...skipping 494 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1163 | 1166 |
1164 return ConvertJavaStringToUTF8(android_permission); | 1167 return ConvertJavaStringToUTF8(android_permission); |
1165 } | 1168 } |
1166 | 1169 |
1167 static void SetSupervisedUserId(JNIEnv* env, | 1170 static void SetSupervisedUserId(JNIEnv* env, |
1168 const JavaParamRef<jobject>& obj, | 1171 const JavaParamRef<jobject>& obj, |
1169 const JavaParamRef<jstring>& pref) { | 1172 const JavaParamRef<jstring>& pref) { |
1170 GetPrefService()->SetString(prefs::kSupervisedUserId, | 1173 GetPrefService()->SetString(prefs::kSupervisedUserId, |
1171 ConvertJavaStringToUTF8(env, pref)); | 1174 ConvertJavaStringToUTF8(env, pref)); |
1172 } | 1175 } |
OLD | NEW |