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

Side by Side Diff: chrome/browser/profile_resetter/triggered_profile_resetter_factory.cc

Issue 1294923003: Add a triggered profile reset mechanism. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: grt nits Created 5 years, 3 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/profile_resetter/triggered_profile_resetter_factory.h"
6
7 #include "base/memory/singleton.h"
8 #include "chrome/browser/profile_resetter/triggered_profile_resetter.h"
9 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/common/pref_names.h"
11 #include "components/keyed_service/content/browser_context_dependency_manager.h"
12 #include "components/pref_registry/pref_registry_syncable.h"
13 #include "content/public/browser/browser_context.h"
14
15 // static
16 TriggeredProfileResetter* TriggeredProfileResetterFactory::GetForBrowserContext(
17 content::BrowserContext* context) {
18 return static_cast<TriggeredProfileResetter*>(
19 GetInstance()->GetServiceForBrowserContext(context, true));
20 }
21
22 // static
23 TriggeredProfileResetterFactory*
24 TriggeredProfileResetterFactory::GetInstance() {
25 return base::Singleton<TriggeredProfileResetterFactory>::get();
26 }
27
28 // static
29 void TriggeredProfileResetterFactory::SetGlobalTestingFactory(
30 TestingFactoryFunction testing_factory) {
31 GetInstance()->testing_factory_function_ = testing_factory;
32 }
33
34 TriggeredProfileResetterFactory::TriggeredProfileResetterFactory()
35 : BrowserContextKeyedServiceFactory(
36 "TriggeredProfileResetter",
37 BrowserContextDependencyManager::GetInstance()) {}
38
39 TriggeredProfileResetterFactory::~TriggeredProfileResetterFactory() {}
40
41 KeyedService* TriggeredProfileResetterFactory::BuildServiceInstanceFor(
42 content::BrowserContext* context) const {
43 Profile* profile = Profile::FromBrowserContext(context);
44
45 TriggeredProfileResetter* service = nullptr;
46 if (testing_factory_function_) {
47 service = static_cast<TriggeredProfileResetter*>(
48 testing_factory_function_(context).release());
49 } else {
50 service = new TriggeredProfileResetter(profile);
51 }
52
53 if (service)
54 service->Activate();
55
56 return service;
57 }
58
59 void TriggeredProfileResetterFactory::RegisterProfilePrefs(
60 user_prefs::PrefRegistrySyncable* registry) {
61 #if defined(OS_WIN)
engedy 2015/09/14 16:08:29 Hmm, any reasons we are not excluding building the
robertshield 2015/09/21 04:16:22 Not really. I could #ifdef / gyp magic the whole t
engedy 2015/09/21 12:56:10 If we have other platforms in mind then I think it
robertshield 2015/09/21 22:04:30 Acknowledged.
62 registry->RegisterInt64Pref(prefs::kLastProfileResetTimestamp, 0L);
63 #endif
64 }
65
66 bool TriggeredProfileResetterFactory::ServiceIsCreatedWithBrowserContext()
67 const {
68 return true;
69 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698