• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 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 #ifndef CHROME_BROWSER_EXTENSIONS_UPDATER_EXTENSION_DOWNLOADER_DELEGATE_H_
6 #define CHROME_BROWSER_EXTENSIONS_UPDATER_EXTENSION_DOWNLOADER_DELEGATE_H_
7 
8 #include <set>
9 #include <string>
10 
11 #include "base/time/time.h"
12 #include "extensions/browser/updater/manifest_fetch_data.h"
13 
14 class GURL;
15 
16 namespace base {
17 class FilePath;
18 }
19 
20 namespace extensions {
21 
22 class ExtensionDownloaderDelegate {
23  public:
24   virtual ~ExtensionDownloaderDelegate();
25 
26   // Passed as an argument to ExtensionDownloader::OnExtensionDownloadFailed()
27   // to detail the reason for the failure.
28   enum Error {
29     // Background networking is disabled.
30     DISABLED,
31 
32     // Failed to fetch the manifest for this extension.
33     MANIFEST_FETCH_FAILED,
34 
35     // The manifest couldn't be parsed.
36     MANIFEST_INVALID,
37 
38     // The manifest was fetched and parsed, and there are no updates for
39     // this extension.
40     NO_UPDATE_AVAILABLE,
41 
42     // There was an update for this extension but the download of the crx
43     // failed.
44     CRX_FETCH_FAILED,
45   };
46 
47   // Passed as an argument to the completion callbacks to signal whether
48   // the extension update sent a ping.
49   struct PingResult {
50     PingResult();
51     ~PingResult();
52 
53     // Whether a ping was sent.
54     bool did_ping;
55 
56     // The start of day, from the server's perspective. This is only valid
57     // when |did_ping| is true.
58     base::Time day_start;
59   };
60 
61   // One of the following 3 methods is always invoked for a given extension
62   // id, if AddExtension() or AddPendingExtension() returned true when that
63   // extension was added to the ExtensionDownloader.
64   // To avoid duplicate work, ExtensionDownloader might merge multiple identical
65   // requests, so there is not necessarily a separate invocation of one of these
66   // methods for each call to AddExtension/AddPendingExtension. If it is
67   // important to be able to match up AddExtension calls with
68   // OnExtensionDownload callbacks, you need to make sure that for every call to
69   // AddExtension/AddPendingExtension the combination of extension id and
70   // request id is unique. The OnExtensionDownload related callbacks will then
71   // be called with all request ids that resulted in that extension being
72   // checked.
73 
74   // Invoked if the extension couldn't be downloaded. |error| contains the
75   // failure reason.
76   virtual void OnExtensionDownloadFailed(const std::string& id,
77                                          Error error,
78                                          const PingResult& ping_result,
79                                          const std::set<int>& request_ids);
80 
81   // Invoked if the extension had an update available and its crx was
82   // successfully downloaded to |path|. |ownership_passed| is true if delegate
83   // should get ownership of the file.
84   virtual void OnExtensionDownloadFinished(
85       const std::string& id,
86       const base::FilePath& path,
87       bool file_ownership_passed,
88       const GURL& download_url,
89       const std::string& version,
90       const PingResult& ping_result,
91       const std::set<int>& request_ids) = 0;
92 
93   // The remaining methods are used by the ExtensionDownloader to retrieve
94   // information about extensions from the delegate.
95 
96   // Invoked to fill the PingData for the given extension id. Returns false
97   // if PingData should not be included for this extension's update check
98   // (this is the default).
99   virtual bool GetPingDataForExtension(const std::string& id,
100                                        ManifestFetchData::PingData* ping);
101 
102   // Invoked to get the update url data for this extension's update url, if
103   // there is any. The default implementation returns an empty string.
104   virtual std::string GetUpdateUrlData(const std::string& id);
105 
106   // Invoked to determine whether extension |id| is currently
107   // pending installation.
108   virtual bool IsExtensionPending(const std::string& id) = 0;
109 
110   // Invoked to get the current version of extension |id|. Returns false if
111   // that extension is not installed.
112   virtual bool GetExtensionExistingVersion(const std::string& id,
113                                            std::string* version) = 0;
114 
115   // Determines if a given extension should be forced to update and (if so)
116   // what the source of this forcing is (i.e. what string will be passed
117   // in |installsource| as part of the update query parameters). The default
118   // implementation always returns |false|.
119   virtual bool ShouldForceUpdate(const std::string& id,
120                                  std::string* source);
121 };
122 
123 }  // namespace extensions
124 
125 #endif  // CHROME_BROWSER_EXTENSIONS_UPDATER_EXTENSION_DOWNLOADER_DELEGATE_H_
126