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

Unified Diff: runtime/bin/tls_socket.h

Issue 10916081: Add secure sockets to dart:io (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Allow TLS sockets to build with both Chromium NSS and upstream NSS Created 8 years, 3 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/tls_socket.h
diff --git a/runtime/bin/tls_socket.h b/runtime/bin/tls_socket.h
new file mode 100644
index 0000000000000000000000000000000000000000..a0c0dece870227c4bffdec87c04c303dce3e42b6
--- /dev/null
+++ b/runtime/bin/tls_socket.h
@@ -0,0 +1,66 @@
+// Copyright (c) 2012, 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 BIN_TLS_SOCKET_H_
+#define BIN_TLS_SOCKET_H_
+
+#include <stdlib.h>
+#include <string.h>
+#include <stdio.h>
+#include <sys/types.h>
+
+#include "bin/builtin.h"
+#include "bin/dartutils.h"
+#include "platform/globals.h"
+#include "platform/thread.h"
+
+static Dart_Handle HandleError(Dart_Handle handle) {
Mads Ager (google) 2012/09/28 12:03:57 As you know, I'm on the fence on this one. If we w
Bill Hesse 2012/10/31 16:33:29 Done. On 2012/09/28 12:03:57, Mads Ager wrote:
+ if (Dart_IsError(handle)) Dart_PropagateError(handle);
+ return handle;
+}
+
+
+class TlsFilterPlatformData;
+
+class TlsFilter {
+ public:
+ enum BufferIndex { kReadPlaintext,
+ kWritePlaintext,
+ kReadEncrypted,
+ kWriteEncrypted,
+ kNumBuffers};
+
+ TlsFilter();
+ void Init(Dart_Handle dart_this);
+ void Connect();
+ void Destroy();
+ void DestroyPlatformIndependent();
+ void RegisterHandshakeCallbacks(Dart_Handle start, Dart_Handle finish);
+ static void InitializeLibrary(const char* pkcert_directory);
+
+ intptr_t ProcessBuffer(int bufferIndex);
+
+ private:
+ // static const char* bufferNames_[kNumBuffers];
+ static bool library_initialized_; // Should be mutex protected.
+
+ uint8_t* buffers_[kNumBuffers];
+ int64_t buffer_size_;
+ Dart_Handle stringStart_;
+ Dart_Handle stringLength_;
+ Dart_Handle dart_buffer_objects_[kNumBuffers];
+ Dart_Handle handshake_start_;
+ Dart_Handle handshake_finish_;
+ bool in_handshake_;
+ TlsFilterPlatformData* data_;
+
+ void InitializeBuffers(Dart_Handle dart_this);
+ void InitializePlatformData();
+ static void LockInitMutex() {}
+ static void UnlockInitMutex() {}
+
+ DISALLOW_COPY_AND_ASSIGN(TlsFilter);
+};
+
+#endif // BIN_TLS_SOCKET_H_

Powered by Google App Engine
This is Rietveld 408576698