OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. |
| 4 |
| 5 part of server.manager; |
| 6 |
| 7 /** |
| 8 * A client channel that logs communication to stdout |
| 9 * and handles errors received from the server. |
| 10 */ |
| 11 class LoggingClientChannel implements ClientCommunicationChannel { |
| 12 final ClientCommunicationChannel channel; |
| 13 int serverErrorCount = 0; |
| 14 |
| 15 LoggingClientChannel(this.channel) { |
| 16 channel.notificationStream.listen((Notification notification) { |
| 17 _logNotification(notification); |
| 18 if (notification.event == 'server.error') { |
| 19 ServerErrorParams error = |
| 20 new ServerErrorParams.fromNotification(notification); |
| 21 _handleError( |
| 22 'Server reported error: ${error.message}', |
| 23 error.stackTrace); |
| 24 } |
| 25 }); |
| 26 } |
| 27 |
| 28 @override |
| 29 Stream<Notification> get notificationStream => channel.notificationStream; |
| 30 |
| 31 @override |
| 32 void set notificationStream(Stream<Notification> _notificationStream) { |
| 33 throw 'invalid operation'; |
| 34 } |
| 35 |
| 36 @override |
| 37 Stream<Response> get responseStream => channel.responseStream; |
| 38 |
| 39 @override |
| 40 void set responseStream(Stream<Response> _responseStream) { |
| 41 throw 'invalid operation'; |
| 42 } |
| 43 |
| 44 @override |
| 45 Future close() { |
| 46 print('Requesting client channel be closed'); |
| 47 return channel.close().then((_) { |
| 48 print('Client channel closed'); |
| 49 }); |
| 50 } |
| 51 |
| 52 @override |
| 53 Future<Response> sendRequest(Request request) { |
| 54 _logOperation('=>', request); |
| 55 return channel.sendRequest(request).then((Response response) { |
| 56 RequestError error = response.error; |
| 57 if (error != null) { |
| 58 error.code; |
| 59 stderr.write('Server Error ${error.code}: ${error.message}'); |
| 60 print(error.stackTrace); |
| 61 exitCode = 31; |
| 62 } |
| 63 _logOperation('<=', request); |
| 64 return response; |
| 65 }); |
| 66 } |
| 67 |
| 68 void _handleError(String errMsg, String stackTrace) { |
| 69 //error.isFatal; |
| 70 stderr.writeln('>>> Server reported exception'); |
| 71 stderr.writeln(errMsg); |
| 72 print(stackTrace); |
| 73 serverErrorCount++; |
| 74 } |
| 75 |
| 76 void _logNotification(Notification notification) { |
| 77 print('<= ${notification.event}'); |
| 78 } |
| 79 |
| 80 void _logOperation(String direction, Request request) { |
| 81 String id = request.id.padLeft(5); |
| 82 String method = request.method.padRight(20); |
| 83 print('$direction $id $method'); |
| 84 } |
| 85 } |
OLD | NEW |