* chore: iwyu shell/browser/electron_pdf_document_helper_client.h * chore: iwyu shell/browser/hid/electron_hid_delegate.h * chore: iwyu content/public/browser/web_contents.h * chore: iwyu shell/browser/usb/electron_usb_delegate.h * chore: iwyu shell/browser/browser_observer.h * chore: iwyu shell/browser/bluetooth/electron_bluetooth_delegate.h * chore: iwyu shell/browser/serial/electron_serial_delegate.h * chore: iwyu shell/browser/api/frame_subscriber.h * chore: iwyu mojo/public/cpp/bindings/ * chore: iwyu components/ * chore: iwyu extensions/ * chore: iwyu shell/common/gin_helper/ * chore: iwyu v8/ * chore: iwyu base/containers/linked_list.h * chore: iwyu shell/browser/native_window.h * chore: iwyu shell/browser/api/electron_api_base_window.h * chore: iwyu shell/common/node_includes.h * chore: iwyu gin/handle.h * chore: iwyu base/functional/callback.h * chore: iwyu ui/gfx/ * chore: iwyu content/public/browser/render_frame_host.h * fix: mac * fix: mac * fix: win * chore: iwyu base/files/file_path.h * chore: iwyu base/unguessable_token.h * chore: iwyu ui/display/screen.h * chore: iwyu chrome/browser/predictors/preconnect_manager.h * chore: iwyu base/observer_list_types.h * chore: iwyu content/public/browser/web_contents.h * chore: iwyu chrome/browser/devtools/devtools_eye_dropper.h * chore: iwyu shell/browser/ui/inspectable_web_contents.h * chore: iwyu content/public/browser/keyboard_event_processing_result.h * chore: iwyu net/cookies/canonical_cookie.h * chore: iwyu net/base/address_list.h * chore: iwyu net/cert/x509_certificate.h * chore: iwyu net/cookies/cookie_change_dispatcher.h * chore: iwyu net/dns/public/host_resolver_results.h * fix: mac * Revert "chore: iwyu net/cert/x509_certificate.h" This reverts commit 002896f71146e90f1e29e090a1d6eede48cee11e.
		
			
				
	
	
		
			121 lines
		
	
	
	
		
			3.8 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			121 lines
		
	
	
	
		
			3.8 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
// Copyright (c) 2017 GitHub, Inc.
 | 
						|
// Use of this source code is governed by the MIT license that can be
 | 
						|
// found in the LICENSE file.
 | 
						|
 | 
						|
#include "shell/browser/ui/certificate_trust.h"
 | 
						|
 | 
						|
#include <memory>
 | 
						|
#include <string>
 | 
						|
#include <utility>
 | 
						|
 | 
						|
#import <Cocoa/Cocoa.h>
 | 
						|
#import <SecurityInterface/SFCertificateTrustPanel.h>
 | 
						|
 | 
						|
#include "base/strings/sys_string_conversions.h"
 | 
						|
#include "net/cert/cert_database.h"
 | 
						|
#include "net/cert/x509_util_apple.h"
 | 
						|
#include "shell/browser/javascript_environment.h"
 | 
						|
#include "shell/browser/native_window.h"
 | 
						|
#include "shell/common/gin_helper/promise.h"
 | 
						|
 | 
						|
@interface TrustDelegate : NSObject {
 | 
						|
 @private
 | 
						|
  std::unique_ptr<gin_helper::Promise<void>> promise_;
 | 
						|
  SFCertificateTrustPanel* panel_;
 | 
						|
  scoped_refptr<net::X509Certificate> cert_;
 | 
						|
  SecTrustRef trust_;
 | 
						|
  CFArrayRef cert_chain_;
 | 
						|
  SecPolicyRef sec_policy_;
 | 
						|
}
 | 
						|
 | 
						|
- (id)initWithPromise:(gin_helper::Promise<void>)promise
 | 
						|
                panel:(SFCertificateTrustPanel*)panel
 | 
						|
                 cert:(const scoped_refptr<net::X509Certificate>&)cert
 | 
						|
                trust:(SecTrustRef)trust
 | 
						|
            certChain:(CFArrayRef)certChain
 | 
						|
            secPolicy:(SecPolicyRef)secPolicy;
 | 
						|
 | 
						|
- (void)panelDidEnd:(NSWindow*)sheet
 | 
						|
         returnCode:(int)returnCode
 | 
						|
        contextInfo:(void*)contextInfo;
 | 
						|
 | 
						|
@end
 | 
						|
 | 
						|
@implementation TrustDelegate
 | 
						|
 | 
						|
- (void)dealloc {
 | 
						|
  CFRelease(trust_);
 | 
						|
  CFRelease(cert_chain_);
 | 
						|
  CFRelease(sec_policy_);
 | 
						|
}
 | 
						|
 | 
						|
- (id)initWithPromise:(gin_helper::Promise<void>)promise
 | 
						|
                panel:(SFCertificateTrustPanel*)panel
 | 
						|
                 cert:(const scoped_refptr<net::X509Certificate>&)cert
 | 
						|
                trust:(SecTrustRef)trust
 | 
						|
            certChain:(CFArrayRef)certChain
 | 
						|
            secPolicy:(SecPolicyRef)secPolicy {
 | 
						|
  if ((self = [super init])) {
 | 
						|
    promise_ = std::make_unique<gin_helper::Promise<void>>(std::move(promise));
 | 
						|
    panel_ = panel;
 | 
						|
    cert_ = cert;
 | 
						|
    trust_ = trust;
 | 
						|
    cert_chain_ = certChain;
 | 
						|
    sec_policy_ = secPolicy;
 | 
						|
  }
 | 
						|
 | 
						|
  return self;
 | 
						|
}
 | 
						|
 | 
						|
- (void)panelDidEnd:(NSWindow*)sheet
 | 
						|
         returnCode:(int)returnCode
 | 
						|
        contextInfo:(void*)contextInfo {
 | 
						|
  auto* cert_db = net::CertDatabase::GetInstance();
 | 
						|
  // This forces Chromium to reload the certificate since it might be trusted
 | 
						|
  // now.
 | 
						|
  cert_db->NotifyObserversTrustStoreChanged();
 | 
						|
 | 
						|
  promise_->Resolve();
 | 
						|
}
 | 
						|
 | 
						|
@end
 | 
						|
 | 
						|
namespace certificate_trust {
 | 
						|
 | 
						|
v8::Local<v8::Promise> ShowCertificateTrust(
 | 
						|
    electron::NativeWindow* parent_window,
 | 
						|
    const scoped_refptr<net::X509Certificate>& cert,
 | 
						|
    const std::string& message) {
 | 
						|
  v8::Isolate* isolate = electron::JavascriptEnvironment::GetIsolate();
 | 
						|
  gin_helper::Promise<void> promise(isolate);
 | 
						|
  v8::Local<v8::Promise> handle = promise.GetHandle();
 | 
						|
 | 
						|
  auto* sec_policy = SecPolicyCreateBasicX509();
 | 
						|
  auto cert_chain =
 | 
						|
      net::x509_util::CreateSecCertificateArrayForX509Certificate(cert.get());
 | 
						|
  SecTrustRef trust = nullptr;
 | 
						|
  SecTrustCreateWithCertificates(cert_chain.get(), sec_policy, &trust);
 | 
						|
 | 
						|
  NSWindow* window = parent_window
 | 
						|
                         ? parent_window->GetNativeWindow().GetNativeNSWindow()
 | 
						|
                         : nil;
 | 
						|
  auto msg = base::SysUTF8ToNSString(message);
 | 
						|
 | 
						|
  auto panel = [[SFCertificateTrustPanel alloc] init];
 | 
						|
  auto delegate = [[TrustDelegate alloc] initWithPromise:std::move(promise)
 | 
						|
                                                   panel:panel
 | 
						|
                                                    cert:cert
 | 
						|
                                                   trust:trust
 | 
						|
                                               certChain:cert_chain.release()
 | 
						|
                                               secPolicy:sec_policy];
 | 
						|
  [panel beginSheetForWindow:window
 | 
						|
               modalDelegate:delegate
 | 
						|
              didEndSelector:@selector(panelDidEnd:returnCode:contextInfo:)
 | 
						|
                 contextInfo:nil
 | 
						|
                       trust:trust
 | 
						|
                     message:msg];
 | 
						|
 | 
						|
  return handle;
 | 
						|
}
 | 
						|
 | 
						|
}  // namespace certificate_trust
 |