private async Task ConnectedCallback(UvConnectRequest connect, int status, UvException error, TaskCompletionSource <int> tcs) { connect.Dispose(); if (error != null) { tcs.SetException(error); return; } var writeReq = new UvWriteReq(Log); try { DispatchPipe.ReadStart( (handle, status2, state) => ((UvListenerSecondary)state)._buf, (handle, status2, state) => ((UvListenerSecondary)state).ReadStartCallback(handle, status2), this); writeReq.Init(_thread); var result = await writeReq.WriteAsync( DispatchPipe, new ArraySegment <ArraySegment <byte> >(new[] { new ArraySegment <byte>(_pipeMessage) })); if (result.Error != null) { tcs.SetException(result.Error); } else { tcs.SetResult(0); } } catch (Exception ex) { DispatchPipe.Dispose(); tcs.SetException(ex); } finally { writeReq.Dispose(); } }
private void StartedCallback(TaskCompletionSource <int> tcs) { var connect = new UvConnectRequest(Log); try { DispatchPipe.Init(_thread.Loop, _thread.QueueCloseHandle, true); connect.Init(_thread); connect.Connect( DispatchPipe, _pipeName, (connect2, status, error, state) => ConnectCallback(connect2, status, error, (TaskCompletionSource <int>)state), tcs); } catch (Exception ex) { DispatchPipe.Dispose(); connect.Dispose(); tcs.SetException(ex); } }
private void ReadStartCallback(UvStreamHandle handle, int status) { if (status < 0) { if (status != UvConstants.EOF) { _thread.Loop.Libuv.Check(status, out var ex); Log.LogError(0, ex, "DispatchPipe.ReadStart"); } DispatchPipe.Dispose(); return; } if (_closed || DispatchPipe.PendingCount() == 0) { return; } var acceptSocket = CreateAcceptSocket(); try { DispatchPipe.Accept(acceptSocket); // REVIEW: This task should be tracked by the server for graceful shutdown // Today it's handled specifically for http but not for aribitrary middleware _ = HandleConnectionAsync(acceptSocket); } catch (UvException ex) when(UvConstants.IsConnectionReset(ex.StatusCode)) { Log.ConnectionReset("(null)"); acceptSocket.Dispose(); } catch (UvException ex) { Log.LogError(0, ex, "DispatchPipe.Accept"); acceptSocket.Dispose(); } }