Index: mojo/dart/packages/mojo_services/lib/mojo/web_socket.mojom.dart |
diff --git a/mojo/dart/packages/mojo_services/lib/mojo/web_socket.mojom.dart b/mojo/dart/packages/mojo_services/lib/mojo/web_socket.mojom.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..53ddcaa3b69077024d1e6b30c814553e6ed2b587 |
--- /dev/null |
+++ b/mojo/dart/packages/mojo_services/lib/mojo/web_socket.mojom.dart |
@@ -0,0 +1,1289 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+library web_socket_mojom; |
+ |
+import 'dart:async'; |
+ |
+import 'package:mojo/bindings.dart' as bindings; |
+import 'package:mojo/core.dart' as core; |
+import 'package:mojo/mojo/network_error.mojom.dart' as network_error_mojom; |
+ |
+ |
+ |
+class WebSocketConnectParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(48, 0) |
+ ]; |
+ String url = null; |
+ List<String> protocols = null; |
+ String origin = null; |
+ core.MojoDataPipeConsumer sendStream = null; |
+ Object client = null; |
+ |
+ WebSocketConnectParams() : super(kVersions.last.size); |
+ |
+ static WebSocketConnectParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketConnectParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketConnectParams result = new WebSocketConnectParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.url = decoder0.decodeString(8, false); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ var decoder1 = decoder0.decodePointer(16, false); |
+ { |
+ var si1 = decoder1.decodeDataHeaderForPointerArray(bindings.kUnspecifiedArrayLength); |
+ result.protocols = new List<String>(si1.numElements); |
+ for (int i1 = 0; i1 < si1.numElements; ++i1) { |
+ |
+ result.protocols[i1] = decoder1.decodeString(bindings.ArrayDataHeader.kHeaderSize + bindings.kPointerSize * i1, false); |
+ } |
+ } |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.origin = decoder0.decodeString(24, false); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.sendStream = decoder0.decodeConsumerHandle(32, false); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.client = decoder0.decodeServiceInterface(36, false, WebSocketClientProxy.newFromEndpoint); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeString(url, 8, false); |
+ |
+ if (protocols == null) { |
+ encoder0.encodeNullPointer(16, false); |
+ } else { |
+ var encoder1 = encoder0.encodePointerArray(protocols.length, 16, bindings.kUnspecifiedArrayLength); |
+ for (int i0 = 0; i0 < protocols.length; ++i0) { |
+ |
+ encoder1.encodeString(protocols[i0], bindings.ArrayDataHeader.kHeaderSize + bindings.kPointerSize * i0, false); |
+ } |
+ } |
+ |
+ encoder0.encodeString(origin, 24, false); |
+ |
+ encoder0.encodeConsumerHandle(sendStream, 32, false); |
+ |
+ encoder0.encodeInterface(client, 36, false); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketConnectParams(" |
+ "url: $url" ", " |
+ "protocols: $protocols" ", " |
+ "origin: $origin" ", " |
+ "sendStream: $sendStream" ", " |
+ "client: $client" ")"; |
+ } |
+ |
+ Map toJson() { |
+ throw new bindings.MojoCodecError( |
+ 'Object containing handles cannot be encoded to JSON.'); |
+ } |
+} |
+ |
+ |
+class WebSocketSendParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(24, 0) |
+ ]; |
+ bool fin = false; |
+ WebSocketMessageType type = null; |
+ int numBytes = 0; |
+ |
+ WebSocketSendParams() : super(kVersions.last.size); |
+ |
+ static WebSocketSendParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketSendParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketSendParams result = new WebSocketSendParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.fin = decoder0.decodeBool(8, 0); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.type = WebSocketMessageType.decode(decoder0, 12); |
+ if (result.type == null) { |
+ throw new bindings.MojoCodecError( |
+ 'Trying to decode null union for non-nullable WebSocketMessageType.'); |
+ } |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.numBytes = decoder0.decodeUint32(16); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeBool(fin, 8, 0); |
+ |
+ encoder0.encodeEnum(type, 12); |
+ |
+ encoder0.encodeUint32(numBytes, 16); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketSendParams(" |
+ "fin: $fin" ", " |
+ "type: $type" ", " |
+ "numBytes: $numBytes" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["fin"] = fin; |
+ map["type"] = type; |
+ map["numBytes"] = numBytes; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketFlowControlParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(16, 0) |
+ ]; |
+ int quota = 0; |
+ |
+ WebSocketFlowControlParams() : super(kVersions.last.size); |
+ |
+ static WebSocketFlowControlParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketFlowControlParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketFlowControlParams result = new WebSocketFlowControlParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.quota = decoder0.decodeInt64(8); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeInt64(quota, 8); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketFlowControlParams(" |
+ "quota: $quota" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["quota"] = quota; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketCloseParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(24, 0) |
+ ]; |
+ int code = 0; |
+ String reason = null; |
+ |
+ WebSocketCloseParams() : super(kVersions.last.size); |
+ |
+ static WebSocketCloseParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketCloseParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketCloseParams result = new WebSocketCloseParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.code = decoder0.decodeUint16(8); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.reason = decoder0.decodeString(16, false); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeUint16(code, 8); |
+ |
+ encoder0.encodeString(reason, 16, false); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketCloseParams(" |
+ "code: $code" ", " |
+ "reason: $reason" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["code"] = code; |
+ map["reason"] = reason; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketClientDidConnectParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(32, 0) |
+ ]; |
+ String selectedSubprotocol = null; |
+ String extensions = null; |
+ core.MojoDataPipeConsumer receiveStream = null; |
+ |
+ WebSocketClientDidConnectParams() : super(kVersions.last.size); |
+ |
+ static WebSocketClientDidConnectParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketClientDidConnectParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketClientDidConnectParams result = new WebSocketClientDidConnectParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.selectedSubprotocol = decoder0.decodeString(8, false); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.extensions = decoder0.decodeString(16, false); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.receiveStream = decoder0.decodeConsumerHandle(24, false); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeString(selectedSubprotocol, 8, false); |
+ |
+ encoder0.encodeString(extensions, 16, false); |
+ |
+ encoder0.encodeConsumerHandle(receiveStream, 24, false); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientDidConnectParams(" |
+ "selectedSubprotocol: $selectedSubprotocol" ", " |
+ "extensions: $extensions" ", " |
+ "receiveStream: $receiveStream" ")"; |
+ } |
+ |
+ Map toJson() { |
+ throw new bindings.MojoCodecError( |
+ 'Object containing handles cannot be encoded to JSON.'); |
+ } |
+} |
+ |
+ |
+class WebSocketClientDidReceiveDataParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(24, 0) |
+ ]; |
+ bool fin = false; |
+ WebSocketMessageType type = null; |
+ int numBytes = 0; |
+ |
+ WebSocketClientDidReceiveDataParams() : super(kVersions.last.size); |
+ |
+ static WebSocketClientDidReceiveDataParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketClientDidReceiveDataParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketClientDidReceiveDataParams result = new WebSocketClientDidReceiveDataParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.fin = decoder0.decodeBool(8, 0); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.type = WebSocketMessageType.decode(decoder0, 12); |
+ if (result.type == null) { |
+ throw new bindings.MojoCodecError( |
+ 'Trying to decode null union for non-nullable WebSocketMessageType.'); |
+ } |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.numBytes = decoder0.decodeUint32(16); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeBool(fin, 8, 0); |
+ |
+ encoder0.encodeEnum(type, 12); |
+ |
+ encoder0.encodeUint32(numBytes, 16); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientDidReceiveDataParams(" |
+ "fin: $fin" ", " |
+ "type: $type" ", " |
+ "numBytes: $numBytes" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["fin"] = fin; |
+ map["type"] = type; |
+ map["numBytes"] = numBytes; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketClientDidReceiveFlowControlParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(16, 0) |
+ ]; |
+ int quota = 0; |
+ |
+ WebSocketClientDidReceiveFlowControlParams() : super(kVersions.last.size); |
+ |
+ static WebSocketClientDidReceiveFlowControlParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketClientDidReceiveFlowControlParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketClientDidReceiveFlowControlParams result = new WebSocketClientDidReceiveFlowControlParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.quota = decoder0.decodeInt64(8); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeInt64(quota, 8); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientDidReceiveFlowControlParams(" |
+ "quota: $quota" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["quota"] = quota; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketClientDidFailParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(16, 0) |
+ ]; |
+ String message = null; |
+ |
+ WebSocketClientDidFailParams() : super(kVersions.last.size); |
+ |
+ static WebSocketClientDidFailParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketClientDidFailParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketClientDidFailParams result = new WebSocketClientDidFailParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.message = decoder0.decodeString(8, false); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeString(message, 8, false); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientDidFailParams(" |
+ "message: $message" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["message"] = message; |
+ return map; |
+ } |
+} |
+ |
+ |
+class WebSocketClientDidCloseParams extends bindings.Struct { |
+ static const List<bindings.StructDataHeader> kVersions = const [ |
+ const bindings.StructDataHeader(24, 0) |
+ ]; |
+ bool wasClean = false; |
+ int code = 0; |
+ String reason = null; |
+ |
+ WebSocketClientDidCloseParams() : super(kVersions.last.size); |
+ |
+ static WebSocketClientDidCloseParams deserialize(bindings.Message message) { |
+ var decoder = new bindings.Decoder(message); |
+ var result = decode(decoder); |
+ if (decoder.excessHandles != null) { |
+ decoder.excessHandles.forEach((h) => h.close()); |
+ } |
+ return result; |
+ } |
+ |
+ static WebSocketClientDidCloseParams decode(bindings.Decoder decoder0) { |
+ if (decoder0 == null) { |
+ return null; |
+ } |
+ WebSocketClientDidCloseParams result = new WebSocketClientDidCloseParams(); |
+ |
+ var mainDataHeader = decoder0.decodeStructDataHeader(); |
+ if (mainDataHeader.version <= kVersions.last.version) { |
+ // Scan in reverse order to optimize for more recent versions. |
+ for (int i = kVersions.length - 1; i >= 0; --i) { |
+ if (mainDataHeader.version >= kVersions[i].version) { |
+ if (mainDataHeader.size == kVersions[i].size) { |
+ // Found a match. |
+ break; |
+ } |
+ throw new bindings.MojoCodecError( |
+ 'Header size doesn\'t correspond to known version size.'); |
+ } |
+ } |
+ } else if (mainDataHeader.size < kVersions.last.size) { |
+ throw new bindings.MojoCodecError( |
+ 'Message newer than the last known version cannot be shorter than ' |
+ 'required by the last known version.'); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.wasClean = decoder0.decodeBool(8, 0); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.code = decoder0.decodeUint16(10); |
+ } |
+ if (mainDataHeader.version >= 0) { |
+ |
+ result.reason = decoder0.decodeString(16, false); |
+ } |
+ return result; |
+ } |
+ |
+ void encode(bindings.Encoder encoder) { |
+ var encoder0 = encoder.getStructEncoderAtOffset(kVersions.last); |
+ |
+ encoder0.encodeBool(wasClean, 8, 0); |
+ |
+ encoder0.encodeUint16(code, 10); |
+ |
+ encoder0.encodeString(reason, 16, false); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientDidCloseParams(" |
+ "wasClean: $wasClean" ", " |
+ "code: $code" ", " |
+ "reason: $reason" ")"; |
+ } |
+ |
+ Map toJson() { |
+ Map map = new Map(); |
+ map["wasClean"] = wasClean; |
+ map["code"] = code; |
+ map["reason"] = reason; |
+ return map; |
+ } |
+} |
+ |
+const int kWebSocket_connect_name = 0; |
+const int kWebSocket_send_name = 1; |
+const int kWebSocket_flowControl_name = 2; |
+const int kWebSocket_close_name = 3; |
+ |
+const String WebSocketName = |
+ 'mojo::WebSocket'; |
+ class WebSocketMessageType extends bindings.MojoEnum { |
+ static const CONTINUATION = const WebSocketMessageType._(0); |
+ static const TEXT = const WebSocketMessageType._(1); |
+ static const BINARY = const WebSocketMessageType._(2); |
+ |
+ const WebSocketMessageType._(int v) : super(v); |
+ |
+ static const Map<String, WebSocketMessageType> valuesMap = const { |
+ "CONTINUATION": CONTINUATION, |
+ "TEXT": TEXT, |
+ "BINARY": BINARY, |
+ }; |
+ static const List<WebSocketMessageType> values = const [ |
+ CONTINUATION, |
+ TEXT, |
+ BINARY, |
+ ]; |
+ |
+ static WebSocketMessageType valueOf(String name) => valuesMap[name]; |
+ |
+ factory WebSocketMessageType(int v) { |
+ switch (v) { |
+ case 0: |
+ return CONTINUATION; |
+ case 1: |
+ return TEXT; |
+ case 2: |
+ return BINARY; |
+ default: |
+ return null; |
+ } |
+ } |
+ |
+ static WebSocketMessageType decode(bindings.Decoder decoder0, int offset) { |
+ int v = decoder0.decodeUint32(offset); |
+ WebSocketMessageType result = new WebSocketMessageType(v); |
+ if (result == null) { |
+ throw new bindings.MojoCodecError( |
+ 'Bad value $v for enum WebSocketMessageType.'); |
+ } |
+ return result; |
+ } |
+ |
+ String toString() { |
+ switch(this) { |
+ case CONTINUATION: |
+ return 'WebSocketMessageType.CONTINUATION'; |
+ case TEXT: |
+ return 'WebSocketMessageType.TEXT'; |
+ case BINARY: |
+ return 'WebSocketMessageType.BINARY'; |
+ } |
+ } |
+ |
+ int toJson() => value; |
+} |
+ |
+abstract class WebSocket { |
+ void connect(String url, List<String> protocols, String origin, core.MojoDataPipeConsumer sendStream, Object client); |
+ void send(bool fin, WebSocketMessageType type, int numBytes); |
+ void flowControl(int quota); |
+ void close(int code, String reason); |
+ |
+ static const ABNORMAL_CLOSE_CODE = 1006; |
+} |
+ |
+ |
+class WebSocketProxyImpl extends bindings.Proxy { |
+ WebSocketProxyImpl.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) : super.fromEndpoint(endpoint); |
+ |
+ WebSocketProxyImpl.fromHandle(core.MojoHandle handle) : |
+ super.fromHandle(handle); |
+ |
+ WebSocketProxyImpl.unbound() : super.unbound(); |
+ |
+ static WebSocketProxyImpl newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketProxyImpl")); |
+ return new WebSocketProxyImpl.fromEndpoint(endpoint); |
+ } |
+ |
+ String get name => WebSocketName; |
+ |
+ void handleResponse(bindings.ServiceMessage message) { |
+ switch (message.header.type) { |
+ default: |
+ proxyError("Unexpected message type: ${message.header.type}"); |
+ close(immediate: true); |
+ break; |
+ } |
+ } |
+ |
+ String toString() { |
+ var superString = super.toString(); |
+ return "WebSocketProxyImpl($superString)"; |
+ } |
+} |
+ |
+ |
+class _WebSocketProxyCalls implements WebSocket { |
+ WebSocketProxyImpl _proxyImpl; |
+ |
+ _WebSocketProxyCalls(this._proxyImpl); |
+ void connect(String url, List<String> protocols, String origin, core.MojoDataPipeConsumer sendStream, Object client) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketConnectParams(); |
+ params.url = url; |
+ params.protocols = protocols; |
+ params.origin = origin; |
+ params.sendStream = sendStream; |
+ params.client = client; |
+ _proxyImpl.sendMessage(params, kWebSocket_connect_name); |
+ } |
+ |
+ void send(bool fin, WebSocketMessageType type, int numBytes) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketSendParams(); |
+ params.fin = fin; |
+ params.type = type; |
+ params.numBytes = numBytes; |
+ _proxyImpl.sendMessage(params, kWebSocket_send_name); |
+ } |
+ |
+ void flowControl(int quota) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketFlowControlParams(); |
+ params.quota = quota; |
+ _proxyImpl.sendMessage(params, kWebSocket_flowControl_name); |
+ } |
+ |
+ void close(int code, String reason) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketCloseParams(); |
+ params.code = code; |
+ params.reason = reason; |
+ _proxyImpl.sendMessage(params, kWebSocket_close_name); |
+ } |
+ |
+} |
+ |
+ |
+class WebSocketProxy implements bindings.ProxyBase { |
+ final bindings.Proxy impl; |
+ WebSocket ptr; |
+ final String name = WebSocketName; |
+ |
+ WebSocketProxy(WebSocketProxyImpl proxyImpl) : |
+ impl = proxyImpl, |
+ ptr = new _WebSocketProxyCalls(proxyImpl); |
+ |
+ WebSocketProxy.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) : |
+ impl = new WebSocketProxyImpl.fromEndpoint(endpoint) { |
+ ptr = new _WebSocketProxyCalls(impl); |
+ } |
+ |
+ WebSocketProxy.fromHandle(core.MojoHandle handle) : |
+ impl = new WebSocketProxyImpl.fromHandle(handle) { |
+ ptr = new _WebSocketProxyCalls(impl); |
+ } |
+ |
+ WebSocketProxy.unbound() : |
+ impl = new WebSocketProxyImpl.unbound() { |
+ ptr = new _WebSocketProxyCalls(impl); |
+ } |
+ |
+ factory WebSocketProxy.connectToService( |
+ bindings.ServiceConnector s, String url) { |
+ WebSocketProxy p = new WebSocketProxy.unbound(); |
+ s.connectToService(url, p); |
+ return p; |
+ } |
+ |
+ static WebSocketProxy newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketProxy")); |
+ return new WebSocketProxy.fromEndpoint(endpoint); |
+ } |
+ |
+ Future close({bool immediate: false}) => impl.close(immediate: immediate); |
+ |
+ Future responseOrError(Future f) => impl.responseOrError(f); |
+ |
+ Future get errorFuture => impl.errorFuture; |
+ |
+ int get version => impl.version; |
+ |
+ Future<int> queryVersion() => impl.queryVersion(); |
+ |
+ void requireVersion(int requiredVersion) { |
+ impl.requireVersion(requiredVersion); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketProxy($impl)"; |
+ } |
+} |
+ |
+ |
+class WebSocketStub extends bindings.Stub { |
+ WebSocket _impl = null; |
+ |
+ WebSocketStub.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint, [this._impl]) |
+ : super.fromEndpoint(endpoint); |
+ |
+ WebSocketStub.fromHandle(core.MojoHandle handle, [this._impl]) |
+ : super.fromHandle(handle); |
+ |
+ WebSocketStub.unbound() : super.unbound(); |
+ |
+ static WebSocketStub newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketStub")); |
+ return new WebSocketStub.fromEndpoint(endpoint); |
+ } |
+ |
+ static const String name = WebSocketName; |
+ |
+ |
+ |
+ dynamic handleMessage(bindings.ServiceMessage message) { |
+ if (bindings.ControlMessageHandler.isControlMessage(message)) { |
+ return bindings.ControlMessageHandler.handleMessage(this, |
+ 0, |
+ message); |
+ } |
+ assert(_impl != null); |
+ switch (message.header.type) { |
+ case kWebSocket_connect_name: |
+ var params = WebSocketConnectParams.deserialize( |
+ message.payload); |
+ _impl.connect(params.url, params.protocols, params.origin, params.sendStream, params.client); |
+ break; |
+ case kWebSocket_send_name: |
+ var params = WebSocketSendParams.deserialize( |
+ message.payload); |
+ _impl.send(params.fin, params.type, params.numBytes); |
+ break; |
+ case kWebSocket_flowControl_name: |
+ var params = WebSocketFlowControlParams.deserialize( |
+ message.payload); |
+ _impl.flowControl(params.quota); |
+ break; |
+ case kWebSocket_close_name: |
+ var params = WebSocketCloseParams.deserialize( |
+ message.payload); |
+ _impl.close(params.code, params.reason); |
+ break; |
+ default: |
+ throw new bindings.MojoCodecError("Unexpected message name"); |
+ break; |
+ } |
+ return null; |
+ } |
+ |
+ WebSocket get impl => _impl; |
+ set impl(WebSocket d) { |
+ assert(_impl == null); |
+ _impl = d; |
+ } |
+ |
+ String toString() { |
+ var superString = super.toString(); |
+ return "WebSocketStub($superString)"; |
+ } |
+ |
+ int get version => 0; |
+} |
+ |
+const int kWebSocketClient_didConnect_name = 0; |
+const int kWebSocketClient_didReceiveData_name = 1; |
+const int kWebSocketClient_didReceiveFlowControl_name = 2; |
+const int kWebSocketClient_didFail_name = 3; |
+const int kWebSocketClient_didClose_name = 4; |
+ |
+const String WebSocketClientName = |
+ 'mojo::WebSocketClient'; |
+ |
+abstract class WebSocketClient { |
+ void didConnect(String selectedSubprotocol, String extensions, core.MojoDataPipeConsumer receiveStream); |
+ void didReceiveData(bool fin, WebSocketMessageType type, int numBytes); |
+ void didReceiveFlowControl(int quota); |
+ void didFail(String message); |
+ void didClose(bool wasClean, int code, String reason); |
+ |
+} |
+ |
+ |
+class WebSocketClientProxyImpl extends bindings.Proxy { |
+ WebSocketClientProxyImpl.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) : super.fromEndpoint(endpoint); |
+ |
+ WebSocketClientProxyImpl.fromHandle(core.MojoHandle handle) : |
+ super.fromHandle(handle); |
+ |
+ WebSocketClientProxyImpl.unbound() : super.unbound(); |
+ |
+ static WebSocketClientProxyImpl newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketClientProxyImpl")); |
+ return new WebSocketClientProxyImpl.fromEndpoint(endpoint); |
+ } |
+ |
+ String get name => WebSocketClientName; |
+ |
+ void handleResponse(bindings.ServiceMessage message) { |
+ switch (message.header.type) { |
+ default: |
+ proxyError("Unexpected message type: ${message.header.type}"); |
+ close(immediate: true); |
+ break; |
+ } |
+ } |
+ |
+ String toString() { |
+ var superString = super.toString(); |
+ return "WebSocketClientProxyImpl($superString)"; |
+ } |
+} |
+ |
+ |
+class _WebSocketClientProxyCalls implements WebSocketClient { |
+ WebSocketClientProxyImpl _proxyImpl; |
+ |
+ _WebSocketClientProxyCalls(this._proxyImpl); |
+ void didConnect(String selectedSubprotocol, String extensions, core.MojoDataPipeConsumer receiveStream) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketClientDidConnectParams(); |
+ params.selectedSubprotocol = selectedSubprotocol; |
+ params.extensions = extensions; |
+ params.receiveStream = receiveStream; |
+ _proxyImpl.sendMessage(params, kWebSocketClient_didConnect_name); |
+ } |
+ |
+ void didReceiveData(bool fin, WebSocketMessageType type, int numBytes) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketClientDidReceiveDataParams(); |
+ params.fin = fin; |
+ params.type = type; |
+ params.numBytes = numBytes; |
+ _proxyImpl.sendMessage(params, kWebSocketClient_didReceiveData_name); |
+ } |
+ |
+ void didReceiveFlowControl(int quota) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketClientDidReceiveFlowControlParams(); |
+ params.quota = quota; |
+ _proxyImpl.sendMessage(params, kWebSocketClient_didReceiveFlowControl_name); |
+ } |
+ |
+ void didFail(String message) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketClientDidFailParams(); |
+ params.message = message; |
+ _proxyImpl.sendMessage(params, kWebSocketClient_didFail_name); |
+ } |
+ |
+ void didClose(bool wasClean, int code, String reason) { |
+ if (!_proxyImpl.isBound) { |
+ _proxyImpl.proxyError("The Proxy is closed."); |
+ return; |
+ } |
+ var params = new WebSocketClientDidCloseParams(); |
+ params.wasClean = wasClean; |
+ params.code = code; |
+ params.reason = reason; |
+ _proxyImpl.sendMessage(params, kWebSocketClient_didClose_name); |
+ } |
+ |
+} |
+ |
+ |
+class WebSocketClientProxy implements bindings.ProxyBase { |
+ final bindings.Proxy impl; |
+ WebSocketClient ptr; |
+ final String name = WebSocketClientName; |
+ |
+ WebSocketClientProxy(WebSocketClientProxyImpl proxyImpl) : |
+ impl = proxyImpl, |
+ ptr = new _WebSocketClientProxyCalls(proxyImpl); |
+ |
+ WebSocketClientProxy.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) : |
+ impl = new WebSocketClientProxyImpl.fromEndpoint(endpoint) { |
+ ptr = new _WebSocketClientProxyCalls(impl); |
+ } |
+ |
+ WebSocketClientProxy.fromHandle(core.MojoHandle handle) : |
+ impl = new WebSocketClientProxyImpl.fromHandle(handle) { |
+ ptr = new _WebSocketClientProxyCalls(impl); |
+ } |
+ |
+ WebSocketClientProxy.unbound() : |
+ impl = new WebSocketClientProxyImpl.unbound() { |
+ ptr = new _WebSocketClientProxyCalls(impl); |
+ } |
+ |
+ factory WebSocketClientProxy.connectToService( |
+ bindings.ServiceConnector s, String url) { |
+ WebSocketClientProxy p = new WebSocketClientProxy.unbound(); |
+ s.connectToService(url, p); |
+ return p; |
+ } |
+ |
+ static WebSocketClientProxy newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketClientProxy")); |
+ return new WebSocketClientProxy.fromEndpoint(endpoint); |
+ } |
+ |
+ Future close({bool immediate: false}) => impl.close(immediate: immediate); |
+ |
+ Future responseOrError(Future f) => impl.responseOrError(f); |
+ |
+ Future get errorFuture => impl.errorFuture; |
+ |
+ int get version => impl.version; |
+ |
+ Future<int> queryVersion() => impl.queryVersion(); |
+ |
+ void requireVersion(int requiredVersion) { |
+ impl.requireVersion(requiredVersion); |
+ } |
+ |
+ String toString() { |
+ return "WebSocketClientProxy($impl)"; |
+ } |
+} |
+ |
+ |
+class WebSocketClientStub extends bindings.Stub { |
+ WebSocketClient _impl = null; |
+ |
+ WebSocketClientStub.fromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint, [this._impl]) |
+ : super.fromEndpoint(endpoint); |
+ |
+ WebSocketClientStub.fromHandle(core.MojoHandle handle, [this._impl]) |
+ : super.fromHandle(handle); |
+ |
+ WebSocketClientStub.unbound() : super.unbound(); |
+ |
+ static WebSocketClientStub newFromEndpoint( |
+ core.MojoMessagePipeEndpoint endpoint) { |
+ assert(endpoint.setDescription("For WebSocketClientStub")); |
+ return new WebSocketClientStub.fromEndpoint(endpoint); |
+ } |
+ |
+ static const String name = WebSocketClientName; |
+ |
+ |
+ |
+ dynamic handleMessage(bindings.ServiceMessage message) { |
+ if (bindings.ControlMessageHandler.isControlMessage(message)) { |
+ return bindings.ControlMessageHandler.handleMessage(this, |
+ 0, |
+ message); |
+ } |
+ assert(_impl != null); |
+ switch (message.header.type) { |
+ case kWebSocketClient_didConnect_name: |
+ var params = WebSocketClientDidConnectParams.deserialize( |
+ message.payload); |
+ _impl.didConnect(params.selectedSubprotocol, params.extensions, params.receiveStream); |
+ break; |
+ case kWebSocketClient_didReceiveData_name: |
+ var params = WebSocketClientDidReceiveDataParams.deserialize( |
+ message.payload); |
+ _impl.didReceiveData(params.fin, params.type, params.numBytes); |
+ break; |
+ case kWebSocketClient_didReceiveFlowControl_name: |
+ var params = WebSocketClientDidReceiveFlowControlParams.deserialize( |
+ message.payload); |
+ _impl.didReceiveFlowControl(params.quota); |
+ break; |
+ case kWebSocketClient_didFail_name: |
+ var params = WebSocketClientDidFailParams.deserialize( |
+ message.payload); |
+ _impl.didFail(params.message); |
+ break; |
+ case kWebSocketClient_didClose_name: |
+ var params = WebSocketClientDidCloseParams.deserialize( |
+ message.payload); |
+ _impl.didClose(params.wasClean, params.code, params.reason); |
+ break; |
+ default: |
+ throw new bindings.MojoCodecError("Unexpected message name"); |
+ break; |
+ } |
+ return null; |
+ } |
+ |
+ WebSocketClient get impl => _impl; |
+ set impl(WebSocketClient d) { |
+ assert(_impl == null); |
+ _impl = d; |
+ } |
+ |
+ String toString() { |
+ var superString = super.toString(); |
+ return "WebSocketClientStub($superString)"; |
+ } |
+ |
+ int get version => 0; |
+} |
+ |
+ |