dart-sdk/pkg/dds
Ben Konyi 83283a553e [ package:dds ] Prevent invalid DDS instance from being returned after
shutdown during initialization

Subtle event queue execution ordering could result in an invalid DDS
instance being returned with the HTTP server instance not yet being
initialized. Calling shutdown() on this instance would cause a
LateInitializationError when trying to cleanup the server.

Fixes https://github.com/flutter/flutter/issues/86361

Change-Id: Idf1f271925d244811af4b61b3161ddcbc05c52eb
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/209846
Reviewed-by: Siva Annamalai <asiva@google.com>
Commit-Queue: Ben Konyi <bkonyi@google.com>
2021-08-11 23:36:27 +00:00
..
bin [ CLI ] Fix IPv6 VM service support for standalone VM 2021-06-24 19:50:59 +00:00
example Reland "[ package:dds ] Add null safety support" 2021-05-24 16:59:23 +00:00
lib [ package:dds ] Prevent invalid DDS instance from being returned after 2021-08-11 23:36:27 +00:00
test [ package:dds ] Prevent invalid DDS instance from being returned after 2021-08-11 23:36:27 +00:00
tool/dap [dds] Mark not-debuggable frames as deemphasized in DAP 2021-08-10 16:54:23 +00:00
.gitignore
analysis_options.yaml replace copied code with references to package:devtools_shared 2021-07-12 17:55:04 +00:00
CHANGELOG.md [ package:dds ] Prevent invalid DDS instance from being returned after 2021-08-11 23:36:27 +00:00
dds_protocol.md Revert "Reland "[ package:dds ] Add support for caching CPU samples based on UserTag"" 2021-08-04 17:32:38 +00:00
LICENSE Update LICENSE 2021-04-07 10:28:38 +00:00
pubspec.yaml [ package:dds ] Prevent invalid DDS instance from being returned after 2021-08-11 23:36:27 +00:00
README.md [ package:dds ] Add server-sent event (SSE) support to DDS 2020-07-15 21:30:09 +00:00

A package used to spawn the Dart Developer Service (DDS), which is used to communicate with a Dart VM Service instance and provide extended functionality to the core VM Service Protocol.

Functionality

Existing VM Service clients can issue both HTTP, websocket, and SSE requests to a running DDS instance as if it were an instance of the VM Service itself. If a request corresponds to an RPC defined in the VM Service Protocol, DDS will forward the request and return the response from the VM Service. Requests corresponding to an RPC defined in the DDS Protocol will be handled directly by the DDS instance.

SSE Support

For certain web clients it may be preferrable or required to communicate with DDS using server-sent events (SSE). DDS has a SSE handler listening for requests on /$debugHandler.

SSE and package:vm_service example

import 'package:sse/sse.dart';
import 'package:vm_service/vm_service.dart';

void main() {
  // Establish connection with DDS using SSE.
  final ddsChannel = SseClient('${ddsUri}\$debugHandler');

  // Wait for ddsChannel to be established
  await ddsChannel.onOpen.first;

  // Initialize VmService using the sink and stream from ddsChannel.
  final vmService = VmService(
    ddsChannel.stream,
    (e) => ddsChannel.sink.add(e),
  );

  // You're ready to query DDS and the VM service!
  print(await vmService.getVersion());
}