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

Unified Diff: runtime/bin/secure_socket_filter.h

Issue 2903743002: Porting SecureSocket to use BoringSSL on OSX (Closed)
Patch Set: Additional cleanup Created 3 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
Index: runtime/bin/secure_socket_filter.h
diff --git a/runtime/bin/secure_socket_boringssl.h b/runtime/bin/secure_socket_filter.h
similarity index 66%
rename from runtime/bin/secure_socket_boringssl.h
rename to runtime/bin/secure_socket_filter.h
index e14171d555854675d6d6b53a32115da3300f15cf..9f2bd6b4f523468eea85ce05fdee937a59456a04 100644
--- a/runtime/bin/secure_socket_boringssl.h
+++ b/runtime/bin/secure_socket_filter.h
@@ -1,30 +1,21 @@
-// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
+// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
-#ifndef RUNTIME_BIN_SECURE_SOCKET_BORINGSSL_H_
-#define RUNTIME_BIN_SECURE_SOCKET_BORINGSSL_H_
-
-#if !defined(RUNTIME_BIN_SECURE_SOCKET_H_)
-#error Do not include secure_socket_boringssl.h directly. Use secure_socket.h.
-#endif
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <sys/types.h>
+#ifndef RUNTIME_BIN_SECURE_SOCKET_FILTER_H_
+#define RUNTIME_BIN_SECURE_SOCKET_FILTER_H_
#include <openssl/bio.h>
-#include <openssl/err.h>
#include <openssl/ssl.h>
#include <openssl/x509.h>
+#include "platform/globals.h"
zra 2017/06/02 22:56:24 Is this header file needed?
bkonyi 2017/06/05 20:25:51 Apparently not. Removed.
+
#include "bin/builtin.h"
-#include "bin/dartutils.h"
#include "bin/reference_counting.h"
-#include "bin/socket.h"
-#include "bin/thread.h"
-#include "bin/utils.h"
+#include "bin/secure_socket.h"
+#include "bin/security_context.h"
+#include "platform/utils.h"
namespace dart {
namespace bin {
@@ -33,44 +24,8 @@ namespace bin {
extern const unsigned char* root_certificates_pem;
extern unsigned int root_certificates_pem_length;
-class SSLContext {
- public:
- static const intptr_t kApproximateSize;
-
- explicit SSLContext(SSL_CTX* context)
- : context_(context), alpn_protocol_string_(NULL) {}
+int CertificateCallback(int preverify_ok, X509_STORE_CTX* store_ctx);
- ~SSLContext() {
- SSL_CTX_free(context_);
- if (alpn_protocol_string_ != NULL) {
- free(alpn_protocol_string_);
- }
- }
-
- SSL_CTX* context() const { return context_; }
-
- uint8_t* alpn_protocol_string() const { return alpn_protocol_string_; }
- void set_alpn_protocol_string(uint8_t* protocol_string) {
- if (alpn_protocol_string_ != NULL) {
- free(alpn_protocol_string_);
- }
- alpn_protocol_string_ = protocol_string;
- }
-
- private:
- SSL_CTX* context_;
- uint8_t* alpn_protocol_string_;
-
- DISALLOW_COPY_AND_ASSIGN(SSLContext);
-};
-
-/*
- * SSLFilter encapsulates the SSL(TLS) code in a filter, that communicates
- * with the containing _SecureFilterImpl Dart object through four shared
- * ExternalByteArray buffers, for reading and writing plaintext, and
- * reading and writing encrypted text. The filter handles handshaking
- * and certificate verification.
- */
class SSLFilter : public ReferenceCounted<SSLFilter> {
public:
// These enums must agree with those in sdk/lib/io/secure_socket.dart.
@@ -84,6 +39,9 @@ class SSLFilter : public ReferenceCounted<SSLFilter> {
};
static const intptr_t kApproximateSize;
+ static const int kSSLFilterNativeFieldIndex = 0;
+
+ static Dart_Handle WrappedX509Certificate(X509* certificate);
SSLFilter()
: callback_error(NULL),
@@ -100,7 +58,7 @@ class SSLFilter : public ReferenceCounted<SSLFilter> {
Dart_Handle Init(Dart_Handle dart_this);
void Connect(const char* hostname,
- SSL_CTX* context,
+ SSLCertContext* context,
bool is_server,
bool request_client_certificate,
bool require_client_certificate,
@@ -133,15 +91,17 @@ class SSLFilter : public ReferenceCounted<SSLFilter> {
// The index of the external data field in _ssl that points to the SSLFilter.
static int filter_ssl_index;
- // TODO(whesse): make private:
- SSL* ssl_;
- BIO* socket_side_;
-
private:
+ void RegisterCallbacks(SSLCertContext* cert_ctx);
zra 2017/06/02 22:56:24 Can this be a public method on SSLCertContext? You
bkonyi 2017/06/05 20:25:51 Done.
+ int CertificateCallback(int preverify_ok, X509_STORE_CTX* store_ctx);
+
static const intptr_t kInternalBIOSize;
static bool library_initialized_;
static Mutex* mutex_; // To protect library initialization.
+ SSL* ssl_;
+ BIO* socket_side_;
+
uint8_t* buffers_[kNumBuffers];
int buffer_size_;
int encrypted_buffer_size_;
@@ -154,7 +114,7 @@ class SSLFilter : public ReferenceCounted<SSLFilter> {
bool is_server_;
char* hostname_;
- static bool isBufferEncrypted(int i) {
+ static bool IsBufferEncrypted(int i) {
return static_cast<BufferIndex>(i) >= kFirstEncrypted;
}
Dart_Handle InitializeBuffers(Dart_Handle dart_this);
@@ -166,4 +126,4 @@ class SSLFilter : public ReferenceCounted<SSLFilter> {
} // namespace bin
} // namespace dart
-#endif // RUNTIME_BIN_SECURE_SOCKET_BORINGSSL_H_
+#endif // RUNTIME_BIN_SECURE_SOCKET_FILTER_H_

Powered by Google App Engine
This is Rietveld 408576698