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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
// Copyright (c) 2006-2009 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.
#include "webkit/plugins/npapi/plugin_list.h"
#import <Foundation/Foundation.h>
#include "base/file_util.h"
#include "base/mac/mac_util.h"
#include "base/string_number_conversions.h"
#include "base/string_split.h"
#include "base/string_util.h"
#include "base/utf_string_conversions.h"
#include "webkit/plugins/npapi/plugin_lib.h"
namespace webkit {
namespace npapi {
namespace {
void GetPluginCommonDirectory(std::vector<FilePath>* plugin_dirs,
bool user) {
// Note that there are no NSSearchPathDirectory constants for these
// directories so we can't use Cocoa's NSSearchPathForDirectoriesInDomains().
// Interestingly, Safari hard-codes the location (see
// WebKit/WebKit/mac/Plugins/WebPluginDatabase.mm's +_defaultPlugInPaths).
FSRef ref;
OSErr err = FSFindFolder(user ? kUserDomain : kLocalDomain,
kInternetPlugInFolderType, false, &ref);
if (err)
return;
plugin_dirs->push_back(FilePath(base::mac::PathFromFSRef(ref)));
}
// Returns true if the plugin should be prevented from loading.
bool IsBlacklistedPlugin(const WebPluginInfo& info) {
// We blacklist Gears by included MIME type, since that is more stable than
// its name. Be careful about adding any more plugins to this list though,
// since it's easy to accidentally blacklist plugins that support lots of
// MIME types.
for (std::vector<WebPluginMimeType>::const_iterator i =
info.mime_types.begin(); i != info.mime_types.end(); ++i) {
// The Gears plugin is Safari-specific, so don't load it.
if (i->mime_type == "application/x-googlegears")
return true;
}
// Versions of Flip4Mac 2.3 before 2.3.6 often hang the renderer, so don't
// load them.
if (StartsWith(info.name, ASCIIToUTF16("Flip4Mac Windows Media"), false) &&
StartsWith(info.version, ASCIIToUTF16("2.3"), false)) {
std::vector<string16> components;
base::SplitString(info.version, '.', &components);
int bugfix_version = 0;
return (components.size() >= 3 &&
base::StringToInt(components[2], &bugfix_version) &&
bugfix_version < 6);
}
return false;
}
} // namespace
void PluginList::PlatformInit() {
}
void PluginList::GetPluginDirectories(std::vector<FilePath>* plugin_dirs) {
// Load from the user's area
GetPluginCommonDirectory(plugin_dirs, true);
// Load from the machine-wide area
GetPluginCommonDirectory(plugin_dirs, false);
}
void PluginList::LoadPluginsFromDir(const FilePath &path,
ScopedVector<PluginGroup>* plugin_groups,
std::set<FilePath>* visited_plugins) {
file_util::FileEnumerator enumerator(path,
false, // not recursive
file_util::FileEnumerator::DIRECTORIES);
for (FilePath path = enumerator.Next(); !path.value().empty();
path = enumerator.Next()) {
LoadPlugin(path, plugin_groups);
visited_plugins->insert(path);
}
}
bool PluginList::ShouldLoadPlugin(const WebPluginInfo& info,
ScopedVector<PluginGroup>* plugin_groups) {
if (IsBlacklistedPlugin(info))
return false;
// Hierarchy check
// (we're loading plugins hierarchically from Library folders, so plugins we
// encounter earlier must override plugins we encounter later)
for (size_t i = 0; i < plugin_groups->size(); ++i) {
const std::vector<WebPluginInfo>& plugins =
(*plugin_groups)[i]->web_plugins_info();
for (size_t j = 0; j < plugins.size(); ++j) {
if (plugins[j].path.BaseName() == info.path.BaseName()) {
return false; // Already have a loaded plugin higher in the hierarchy.
}
}
}
return true;
}
} // namespace npapi
} // namespace webkit
|