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

Unified Diff: components/password_manager/content/browser/password_visibility_service_factory.h

Issue 2378503002: Observe visibility of password inputs, for HTTP-bad phase 1 (Closed)
Patch Set: fix superclass createLayoutObject call Created 4 years, 2 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
Index: components/password_manager/content/browser/password_visibility_service_factory.h
diff --git a/components/password_manager/content/browser/password_visibility_service_factory.h b/components/password_manager/content/browser/password_visibility_service_factory.h
new file mode 100644
index 0000000000000000000000000000000000000000..b2308db0c1187164d11913bf396d56f2c71ff232
--- /dev/null
+++ b/components/password_manager/content/browser/password_visibility_service_factory.h
@@ -0,0 +1,59 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
vabr (Chromium) 2016/10/11 16:52:45 Seeing the amount of code duplicated amongst this
estark 2016/10/11 23:45:14 I did file a bug for this (https://crbug.com/65490
vabr (Chromium) 2016/10/12 09:45:22 Thanks, the current version looks simpler and ther
estark 2016/10/12 15:53:43 Got it, thanks for clarifying (and for the code re
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef COMPONENTS_PASSWORD_MANAGER_CONTENT_BROWSER_PASSWORD_VISIBILITY_SERVICE_FACTORY_H_
+#define COMPONENTS_PASSWORD_MANAGER_CONTENT_BROWSER_PASSWORD_VISIBILITY_SERVICE_FACTORY_H_
+
+#include <map>
+#include <memory>
+
+#include "base/macros.h"
+#include "base/supports_user_data.h"
+#include "content/public/browser/web_contents_observer.h"
+#include "third_party/WebKit/public/platform/modules/sensitive_input_visibility/sensitive_input_visibility_service.mojom.h"
+
+namespace content {
+class RenderFrameHost;
+class WebContents;
+}
+
+namespace password_manager {
+
+class PasswordVisibilityService;
+
+// Creates and owns PasswordVisibilityServices. There is one
+// factory per WebContents, and one driver per render frame.
+class PasswordVisibilityServiceFactory : public content::WebContentsObserver,
+ public base::SupportsUserData::Data {
+ public:
+ static void CreateForWebContents(content::WebContents* web_contents);
+ ~PasswordVisibilityServiceFactory() override;
+
+ static PasswordVisibilityServiceFactory* FromWebContents(
+ content::WebContents* web_contents);
+
+ static void BindSensitiveInputVisibilityService(
+ content::RenderFrameHost* render_frame_host,
+ blink::mojom::SensitiveInputVisibilityServiceRequest request);
+
+ PasswordVisibilityService* GetServiceForFrame(
+ content::RenderFrameHost* render_frame_host);
+
+ // content::WebContentsObserver:
+ void RenderFrameCreated(content::RenderFrameHost* render_frame_host) override;
+ void RenderFrameDeleted(content::RenderFrameHost* render_frame_host) override;
+
+ private:
+ PasswordVisibilityServiceFactory(content::WebContents* web_contents);
vabr (Chromium) 2016/10/11 16:52:45 Should this constructor be "explicit"?
estark 2016/10/11 23:45:14 no longer applicable
+
+ std::map<content::RenderFrameHost*,
+ std::unique_ptr<PasswordVisibilityService>>
+ frame_service_map_;
+
+ DISALLOW_COPY_AND_ASSIGN(PasswordVisibilityServiceFactory);
+};
+
+} // namespace password_manager
+
+#endif // COMPONENTS_PASSWORD_MANAGER_CONTENT_BROWSER_PASSWORD_VISIBILITY_SERVICE_FACTORY_H_

Powered by Google App Engine
This is Rietveld 408576698