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

Unified Diff: chrome/browser/ui/pdf/pdf_unsupported_feature.cc

Issue 10263022: Move version metadata from PluginGroup into PluginInstaller. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review Created 8 years, 7 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/resources/plugins_win.json ('k') | chrome/browser/ui/webui/plugins_ui.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/pdf/pdf_unsupported_feature.cc
diff --git a/chrome/browser/ui/pdf/pdf_unsupported_feature.cc b/chrome/browser/ui/pdf/pdf_unsupported_feature.cc
index 340dba0a6855407393fd81875ebfd3967cb774ee..46c1b274399f20fd91a1aa9e496d0172733dd1e7 100644
--- a/chrome/browser/ui/pdf/pdf_unsupported_feature.cc
+++ b/chrome/browser/ui/pdf/pdf_unsupported_feature.cc
@@ -10,6 +10,8 @@
#include "base/version.h"
#include "chrome/browser/chrome_plugin_service_filter.h"
#include "chrome/browser/infobars/infobar_tab_helper.h"
+#include "chrome/browser/plugin_finder.h"
+#include "chrome/browser/plugin_installer.h"
#include "chrome/browser/plugin_prefs.h"
#include "chrome/browser/prefs/pref_service.h"
#include "chrome/browser/profiles/profile.h"
@@ -46,9 +48,6 @@ using webkit::WebPluginInfo;
namespace {
-// Only launch Adobe Reader X or later.
-static const uint16 kMinReaderVersionToUse = 10;
-
static const char kReaderUpdateUrl[] =
"http://www.adobe.com/go/getreader_chrome";
@@ -250,9 +249,10 @@ class PDFUnsupportedFeatureInterstitial
// PDFEnableAdobeReaderInfoBarDelegate.
class PDFUnsupportedFeatureInfoBarDelegate : public ConfirmInfoBarDelegate {
public:
- // |reader_group| is NULL if Adobe Reader isn't installed.
+ // |reader| is NULL if Adobe Reader isn't installed.
PDFUnsupportedFeatureInfoBarDelegate(TabContentsWrapper* tab_contents,
- const PluginGroup* reader_group);
+ const webkit::WebPluginInfo* reader,
+ PluginFinder* plugin_finder);
virtual ~PDFUnsupportedFeatureInfoBarDelegate();
// ConfirmInfoBarDelegate
@@ -278,10 +278,11 @@ class PDFUnsupportedFeatureInfoBarDelegate : public ConfirmInfoBarDelegate {
PDFUnsupportedFeatureInfoBarDelegate::PDFUnsupportedFeatureInfoBarDelegate(
TabContentsWrapper* tab_contents,
- const PluginGroup* reader_group)
+ const webkit::WebPluginInfo* reader,
+ PluginFinder* plugin_finder)
: ConfirmInfoBarDelegate(tab_contents->infobar_tab_helper()),
tab_contents_(tab_contents),
- reader_installed_(!!reader_group),
+ reader_installed_(!!reader),
reader_vulnerable_(false) {
if (!reader_installed_) {
content::RecordAction(
@@ -290,18 +291,14 @@ PDFUnsupportedFeatureInfoBarDelegate::PDFUnsupportedFeatureInfoBarDelegate(
}
content::RecordAction(UserMetricsAction("PDF_UseReaderInfoBarShown"));
- const std::vector<WebPluginInfo>& plugins =
- reader_group->web_plugin_infos();
- DCHECK_EQ(plugins.size(), 1u);
- reader_webplugininfo_ = plugins[0];
-
- reader_vulnerable_ = reader_group->IsVulnerable(reader_webplugininfo_);
- if (!reader_vulnerable_) {
- scoped_ptr<Version> version(PluginGroup::CreateVersionFromString(
- reader_webplugininfo_.version));
- reader_vulnerable_ =
- version.get() && (version->components()[0] < kMinReaderVersionToUse);
- }
+ reader_webplugininfo_ = *reader;
+
+ PluginInstaller* installer =
+ plugin_finder->FindPluginWithIdentifier("adobe-reader");
+
+ reader_vulnerable_ =
+ installer->GetSecurityStatus(*reader) !=
+ PluginInstaller::SECURITY_STATUS_UP_TO_DATE;
}
PDFUnsupportedFeatureInfoBarDelegate::~PDFUnsupportedFeatureInfoBarDelegate() {
@@ -377,6 +374,7 @@ void PDFUnsupportedFeatureInfoBarDelegate::OnNo() {
void GotPluginGroupsCallback(int process_id,
int routing_id,
+ PluginFinder* plugin_finder,
const std::vector<PluginGroup>& groups) {
WebContents* web_contents =
tab_util::GetWebContentsByID(process_id, routing_id);
@@ -389,7 +387,6 @@ void GotPluginGroupsCallback(int process_id,
return;
string16 reader_group_name(ASCIIToUTF16(PluginGroup::kAdobeReaderGroupName));
-
// If the Reader plugin is disabled by policy, don't prompt them.
PluginPrefs* plugin_prefs = PluginPrefs::GetForProfile(tab->profile());
if (plugin_prefs->PolicyStatusForPlugin(reader_group_name) ==
@@ -397,16 +394,27 @@ void GotPluginGroupsCallback(int process_id,
return;
}
- const PluginGroup* reader_group = NULL;
+ const webkit::WebPluginInfo* reader = NULL;
for (size_t i = 0; i < groups.size(); ++i) {
if (groups[i].GetGroupName() == reader_group_name) {
- reader_group = &groups[i];
+ const std::vector<WebPluginInfo>& plugins =
+ groups[i].web_plugin_infos();
+ DCHECK_EQ(plugins.size(), 1u);
+ reader = &plugins[0];
break;
}
}
tab->infobar_tab_helper()->AddInfoBar(
- new PDFUnsupportedFeatureInfoBarDelegate(tab, reader_group));
+ new PDFUnsupportedFeatureInfoBarDelegate(tab, reader, plugin_finder));
+}
+
+void GotPluginFinderCallback(int process_id,
+ int routing_id,
+ PluginFinder* plugin_finder) {
+ PluginService::GetInstance()->GetPluginGroups(
+ base::Bind(&GotPluginGroupsCallback, process_id, routing_id,
+ base::Unretained(plugin_finder)));
}
} // namespace
@@ -418,8 +426,7 @@ void PDFHasUnsupportedFeature(TabContentsWrapper* tab) {
return;
#endif
- PluginService::GetInstance()->GetPluginGroups(
- base::Bind(&GotPluginGroupsCallback,
- tab->web_contents()->GetRenderProcessHost()->GetID(),
- tab->web_contents()->GetRenderViewHost()->GetRoutingID()));
+ PluginFinder::Get(base::Bind(&GotPluginFinderCallback,
+ tab->web_contents()->GetRenderProcessHost()->GetID(),
+ tab->web_contents()->GetRenderViewHost()->GetRoutingID()));
}
« no previous file with comments | « chrome/browser/resources/plugins_win.json ('k') | chrome/browser/ui/webui/plugins_ui.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698