blob: b0bf9435ddc37c5d841ae7952a952293634665d6 (
plain)
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
|
// Copyright (c) 2011 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.
#ifndef CHROME_BROWSER_INTENTS_WEB_INTENTS_REGISTRY_H_
#define CHROME_BROWSER_INTENTS_WEB_INTENTS_REGISTRY_H_
#pragma once
#include "base/hash_tables.h"
#include "base/memory/ref_counted.h"
#include "chrome/browser/extensions/extension_service.h"
#include "chrome/browser/profiles/profile_keyed_service.h"
#include "chrome/browser/webdata/web_data_service.h"
#include "webkit/glue/web_intent_service_data.h"
// Handles storing and retrieving of web intents in the web database.
// The registry provides filtering logic to retrieve specific types of intents.
class WebIntentsRegistry
: public WebDataServiceConsumer,
public ProfileKeyedService {
public:
// Unique identifier for intent queries.
typedef int QueryID;
typedef std::vector<WebIntentServiceData> IntentList;
// An interface the WebIntentsRegistry uses to notify its clients when
// it has finished loading intents data from the web database.
class Consumer {
public:
// Notifies the observer that the intents request has been completed.
virtual void OnIntentsQueryDone(
QueryID query_id,
const IntentList& intents) = 0;
protected:
virtual ~Consumer() {}
};
// Initializes, binds to a valid WebDataService.
void Initialize(scoped_refptr<WebDataService> wds,
ExtensionServiceInterface* extension_service);
// Registers a web intent provider.
virtual void RegisterIntentProvider(const WebIntentServiceData& intent);
// Removes a web intent provider from the registry.
void UnregisterIntentProvider(const WebIntentServiceData& intent);
// Requests all intent providers matching |action| and |mimetype|.
// |mimetype| can contain wildcards, i.e. "image/*" or "*".
// |consumer| must not be NULL.
QueryID GetIntentProviders(const string16& action,
const string16& mimetype,
Consumer* consumer);
// Requests all intent providers. |consumer| must not be NULL
QueryID GetAllIntentProviders(Consumer* consumer);
protected:
// Make sure that only WebIntentsRegistryFactory can create an instance of
// WebIntentsRegistry.
friend class WebIntentsRegistryFactory;
friend class WebIntentsRegistryTest;
friend class WebIntentsModelTest;
WebIntentsRegistry();
virtual ~WebIntentsRegistry();
private:
struct IntentsQuery;
// Maps web data requests to intents queries.
// Allows OnWebDataServiceRequestDone to forward to appropriate consumer.
typedef base::hash_map<WebDataService::Handle, IntentsQuery*> QueryMap;
// WebDataServiceConsumer implementation.
virtual void OnWebDataServiceRequestDone(WebDataService::Handle h,
const WDTypedResult* result);
// Map for all in-flight web data requests/intent queries.
QueryMap queries_;
// Unique identifier for next intent query.
QueryID next_query_id_;
// Local reference to Web Data Service.
scoped_refptr<WebDataService> wds_;
// Local reference to the ExtensionService.
// Shutdown/cleanup is handled by ProfileImpl. We are guaranteed that any
// ProfileKeyedService will be shut down before data on ProfileImpl is
// destroyed (i.e. |extension_service_|), so |extension_service_| is valid
// for the lifetime of the WebIntentsRegistry object.
ExtensionServiceInterface* extension_service_;
DISALLOW_COPY_AND_ASSIGN(WebIntentsRegistry);
};
#endif // CHROME_BROWSER_INTENTS_WEB_INTENTS_REGISTRY_H_
|