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

Unified Diff: sdk/lib/isolate/capability.dart

Issue 148883009: Add Capability class. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 11 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
« no previous file with comments | « sdk/lib/_internal/lib/isolate_patch.dart ('k') | sdk/lib/isolate/isolate.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sdk/lib/isolate/capability.dart
diff --git a/sdk/lib/isolate/capability.dart b/sdk/lib/isolate/capability.dart
new file mode 100644
index 0000000000000000000000000000000000000000..a5893d55bc6902fe8803c32408973a513c905d3f
--- /dev/null
+++ b/sdk/lib/isolate/capability.dart
@@ -0,0 +1,39 @@
+// Copyright (c) 2014, 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.
+
+part of dart.isolate;
+
+/**
+ * An unforgable object that preserves its identity when passed through other
+ * isolates.
+ *
+ * Objects sent through [SendPort]s to other isolates, and back again, will
+ * generally be copied, and will not have the same identity as the original.
+ * A capability object preserves its identity when sent through other isolates.
floitsch 2014/01/29 15:26:26 Do we need the identity requirement? Equality woul
Lasse Reichstein Nielsen 2014/01/29 15:58:13 I think identity is preferable. It allows you to u
floitsch 2014/01/29 16:52:35 No doubt about that. The question is, if it's not
+ *
+ * Capabilities can be used as access guards: A remote isolate can send
+ * a request for an operation, but it is only allowed if the request contains
+ * the correct capability object.
+ *
+ * This allows exposing the same interface to multiple clients, but restricting
+ * some operations to only those clients that have also been given the
+ * corresponding capability.
+ *
+ * When comparing capabilities, always use identity comparison. That is, either
+ * use [identical] to test, or use the known capability as the left-hand side of
+ * the `==` operator. This prevents a malicious user from providing a fake
+ * capability object with a custom equality that would claim to be equal
+ * to your capability.
+ *
+ * Capabilities can be used inside a single isolate, but they have no advantage
+ * over just using `new Object` to create a unique object. The only advantage
+ * of `Capability` over `Object` is that it preserves its identity when
+ * round-tripped through other isolates.
+ */
+class Capability {
+ /**
+ * Create a new unforgable capability object.
+ */
+ external factory Capability();
+}
« no previous file with comments | « sdk/lib/_internal/lib/isolate_patch.dart ('k') | sdk/lib/isolate/isolate.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698