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
|
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_UI_VIEWS_PAGE_INFO_PAGE_INFO_SECURITY_CONTENT_VIEW_H_
#define CHROME_BROWSER_UI_VIEWS_PAGE_INFO_PAGE_INFO_SECURITY_CONTENT_VIEW_H_
#include "base/gtest_prod_util.h"
#include "base/memory/raw_ptr.h"
#include "chrome/browser/ui/views/controls/rich_hover_button.h"
#include "chrome/browser/ui/views/page_info/security_information_view.h"
#include "components/page_info/page_info_ui.h"
#include "ui/base/metadata/metadata_header_macros.h"
#include "ui/views/view.h"
// The view that contains `SecurityInformationView` and a certificate button.
// It is used as a content of the security subpage or is directly integrated in
// the main page if connection isn't secure.
class PageInfoSecurityContentView : public views::View, public PageInfoUI {
METADATA_HEADER(PageInfoSecurityContentView, views::View)
public:
// `is_standalone_page` is true, when this view is used as a content view of
// a subpage and this view becomes current UI for `PageInfo` by calling
// `InitializeUiState()`. Otherwise, it is part of another page (part of the
// main page if connection isn't secure).
PageInfoSecurityContentView(PageInfo* presenter, bool is_standalone_page);
~PageInfoSecurityContentView() override;
// PageInfoUI implementations.
void SetIdentityInfo(const IdentityInfo& identity_info) override;
private:
FRIEND_TEST_ALL_PREFIXES(PageInfoBubbleViewTest, CheckHeaderInteractions);
void ResetDecisionsClicked();
void SecurityDetailsClicked(const ui::Event& event);
raw_ptr<PageInfo, DanglingUntriaged> presenter_;
// The button that opens the "Certificate" dialog.
raw_ptr<RichHoverButton> certificate_button_ = nullptr;
// The views that shows the status of the site's identity check.
raw_ptr<SecurityInformationView> security_view_ = nullptr;
// The view that shows the QWAC status of the site, if it is a 1-QWAC.
raw_ptr<SecurityInformationView> one_qwac_view_ = nullptr;
// The button that displays identity information of a 2-QWAC and opens the
// certificate viewer for the 2-QWAC cert.
raw_ptr<RichHoverButton> two_qwac_button_ = nullptr;
// The certificate provided by the site, if one exists.
scoped_refptr<net::X509Certificate> certificate_;
// The 2-QWAC certificate for the site, if it has a valid 2-QWAC.
scoped_refptr<net::X509Certificate> two_qwac_;
// TODO(crbug.com/40754666): Add plumbing to check this in tests or rewrite
// tests not use it.
PageInfoUI::SecurityDescriptionType security_description_type_ =
PageInfoUI::SecurityDescriptionType::CONNECTION;
};
#endif // CHROME_BROWSER_UI_VIEWS_PAGE_INFO_PAGE_INFO_SECURITY_CONTENT_VIEW_H_
|