blob: e5a2a3f296cd9beabb13d87de14c2519377cce31 (
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
|
// Copyright 2014 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 EXTENSIONS_BROWSER_UPDATER_EXTENSION_CACHE_H_
#define EXTENSIONS_BROWSER_UPDATER_EXTENSION_CACHE_H_
#include <string>
#include "base/callback_forward.h"
#include "base/files/file_path.h"
#include "base/macros.h"
namespace extensions {
// ExtensionCache interface that caches extensions .crx files to share them
// between multiple users and profiles on the machine.
class ExtensionCache {
public:
// Callback that is invoked when the file placed when PutExtension done.
typedef base::Callback<void(const base::FilePath& file_path,
bool file_ownership_passed)> PutExtensionCallback;
ExtensionCache() {}
virtual ~ExtensionCache() {}
// Initialize cache in background. The |callback| is called when cache ready.
// Can be called multiple times. The |callback| can be called immediately if
// cache is ready.
virtual void Start(const base::Closure& callback) = 0;
// Shut down the cache. Must be called at most once on browser shutdown.
virtual void Shutdown(const base::Closure& callback) = 0;
// Allow caching for the extension with given |id|. User specific extensions
// should not be cached for privacy reasons. But default apps including policy
// configured can be cached. Can be called before Init.
virtual void AllowCaching(const std::string& id) = 0;
// If extension with |id| exists in the cache, returns |true|, |file_path| and
// |version| for the extension. Extension will be marked as used with current
// timestamp.
virtual bool GetExtension(const std::string& id,
const std::string& expected_hash,
base::FilePath* file_path,
std::string* version) = 0;
// Put extension with |id| and |version| into local cache. Older version in
// the cache will removed be on next run so it can be safely used. Extension
// will be marked as used with current timestamp. The file will be available
// via GetExtension when |callback| is called. Original |file_path| won't be
// deleted from the disk. There is no guarantee that |callback| will be
// called.
virtual void PutExtension(const std::string& id,
const std::string& expected_hash,
const base::FilePath& file_path,
const std::string& version,
const PutExtensionCallback& callback) = 0;
private:
DISALLOW_COPY_AND_ASSIGN(ExtensionCache);
};
} // namespace extensions
#endif // EXTENSIONS_BROWSER_UPDATER_EXTENSION_CACHE_H_
|