public override RequestContext ReceiveRequest(TimeSpan timeout) { if (timeout <= TimeSpan.Zero) { throw new ArgumentException(String.Format("Timeout value must be positive value. It was {0}", timeout)); } // FIXME: use timeout if (client == null) { client = ((TcpChannelListener <IReplyChannel>)Manager).AcceptTcpClient(timeout); } NetworkStream ns = client.GetStream(); frame = new TcpBinaryFrameManager(TcpBinaryFrameManager.SingletonUnsizedMode, ns, true) { Encoder = this.Encoder }; // FIXME: use timeout if (!frame.ProcessPreambleRecipient()) { return(null); } frame.ProcessPreambleAckRecipient(); var msg = frame.ReadUnsizedMessage(timeout); Logger.LogMessage(MessageLogSourceKind.TransportReceive, ref msg, info.BindingElement.MaxReceivedMessageSize); // LAMESPEC: it contradicts the protocol explanation at section 3.1.1.1.1 in [MC-NMF]. // Moving ReadEndRecord() after context's WriteUnsizedMessage() causes TCP connection blocking. frame.ReadEndRecord(); return(new TcpRequestContext(this, msg)); }
protected override void OnOpen(TimeSpan timeout) { if (!is_service_side) { NetworkStream ns = client.GetStream(); frame = new TcpBinaryFrameManager(TcpBinaryFrameManager.DuplexMode, ns, is_service_side) { Encoder = this.Encoder, Via = this.Via }; frame.ProcessPreambleInitiator(); frame.ProcessPreambleAckInitiator(); session = new TcpDuplexSession(this); // make sure to shutdown the session once it has initiated one. } else { // server side Stream s = client.GetStream(); frame = new TcpBinaryFrameManager(TcpBinaryFrameManager.DuplexMode, s, is_service_side) { Encoder = this.Encoder }; // FIXME: use retrieved record properties in the request processing. frame.ProcessPreambleRecipient(); frame.ProcessPreambleAckRecipient(); } }
public override RequestContext ReceiveRequest (TimeSpan timeout) { if (timeout <= TimeSpan.Zero) throw new ArgumentException (String.Format ("Timeout value must be positive value. It was {0}", timeout)); DateTime start = DateTime.Now; // FIXME: use timeout if (client == null) client = ((TcpChannelListener<IReplyChannel>) Manager).AcceptTcpClient (timeout); NetworkStream ns = client.GetStream (); frame = new TcpBinaryFrameManager (TcpBinaryFrameManager.SingletonUnsizedMode, ns, true) { Encoder = this.Encoder }; // FIXME: use timeout if (!frame.ProcessPreambleRecipient ()) return null; frame.ProcessPreambleAckRecipient (); var msg = frame.ReadUnsizedMessage (timeout); Logger.LogMessage (MessageLogSourceKind.TransportReceive, ref msg, info.BindingElement.MaxReceivedMessageSize); // LAMESPEC: it contradicts the protocol explanation at section 3.1.1.1.1 in [MC-NMF]. // Moving ReadEndRecord() after context's WriteUnsizedMessage() causes TCP connection blocking. frame.ReadEndRecord (); return new TcpRequestContext (this, msg); }