electron/atom/browser/api/atom_api_certificate_trust_mac.mm

81 lines
2.3 KiB
Text
Raw Normal View History

2017-03-30 21:25:44 +00:00
// 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 "atom/browser/api/atom_api_certificate_trust.h"
#import <Cocoa/Cocoa.h>
#import <CoreServices/CoreServices.h>
#import <SecurityInterface/SFCertificateTrustPanel.h>
#include "atom/browser/native_window.h"
#include "base/files/file_util.h"
#include "base/mac/foundation_util.h"
#include "base/mac/mac_util.h"
#include "base/mac/scoped_cftyperef.h"
#include "base/strings/sys_string_conversions.h"
#include "net/cert/x509_certificate.h"
2017-04-01 01:51:29 +00:00
#include "net/cert/cert_database.h"
2017-03-30 21:25:44 +00:00
2017-04-03 17:21:44 +00:00
@interface Trampoline : NSObject
- (void)createPanelDidEnd:(NSWindow *)sheet
returnCode:(int)returnCode
contextInfo:(void *)contextInfo;
@end
@implementation Trampoline
- (void)createPanelDidEnd:(NSWindow *)sheet
returnCode:(int)returnCode
contextInfo:(void *)contextInfo {
void (^block)(int) = (void (^)(int))contextInfo;
block(returnCode);
[(id)block autorelease];
}
@end
2017-03-30 21:25:44 +00:00
namespace atom {
namespace api {
void ShowCertificateTrustUI(atom::NativeWindow* parent_window,
2017-03-31 17:53:42 +00:00
const scoped_refptr<net::X509Certificate>& cert,
2017-03-30 21:25:44 +00:00
std::string message,
const ShowTrustCallback& callback) {
auto sec_policy = SecPolicyCreateBasicX509();
2017-04-03 17:21:44 +00:00
auto cert_chain = cert->CreateOSCertChainForCert();
2017-03-30 21:25:44 +00:00
SecTrustRef trust = nullptr;
2017-04-03 17:21:44 +00:00
SecTrustCreateWithCertificates(cert_chain, sec_policy, &trust);
2017-03-30 21:25:44 +00:00
2017-04-03 17:21:44 +00:00
SFCertificateTrustPanel *panel = [[SFCertificateTrustPanel alloc] init];
2017-03-30 21:25:44 +00:00
2017-04-03 17:21:44 +00:00
void (^callbackBlock)(int) = [^(int returnCode) {
// if (returnCode == NSFileHandlingPanelOKButton) {
auto cert_db = net::CertDatabase::GetInstance();
// This forces Chromium to reload the certificate since it might be trusted
// now.
cert_db->NotifyObserversCertDBChanged(cert.get());
// }
2017-03-30 21:25:44 +00:00
2017-04-03 17:21:44 +00:00
callback.Run(returnCode);
2017-04-01 01:51:29 +00:00
2017-04-03 17:21:44 +00:00
[panel autorelease];
CFRelease(trust);
CFRelease(cert_chain);
CFRelease(sec_policy);
} copy];
2017-03-30 21:25:44 +00:00
2017-04-03 17:21:44 +00:00
NSWindow* window = parent_window ?
parent_window->GetNativeWindow() :
NULL;
auto msg = base::SysUTF8ToNSString(message);
[panel beginSheetForWindow:window modalDelegate:nil didEndSelector:NULL contextInfo:callbackBlock trust:trust message:msg];
2017-03-30 21:25:44 +00:00
}
} // namespace api
} // namespace atom