// // PeerChannelListener.cs // // Author: // Atsushi Enomoto // // Copyright (C) 2009 Novell, Inc. http://www.novell.com // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Net; using System.Net.Security; using System.ServiceModel; using System.ServiceModel.Description; using System.ServiceModel.Security; using System.Text; namespace System.ServiceModel.Channels { internal class PeerChannelListener : InternalChannelListenerBase, IPeerChannelManager where TChannel : class, IChannel { PeerTransportBindingElement source; BindingContext context; Uri listen_uri; List channels = new List (); MessageEncoder encoder; public PeerChannelListener (PeerTransportBindingElement source, BindingContext context) : base (context.Binding) { // FIXME: consider ListenUriMode // FIXME: there should be some way to post-provide Uri in case of null listenerUri in context. listen_uri = context.ListenUriBaseAddress != null ? new Uri (context.ListenUriBaseAddress, context.ListenUriRelativeAddress) : null; foreach (BindingElement be in context.RemainingBindingElements) { MessageEncodingBindingElement mbe = be as MessageEncodingBindingElement; if (mbe != null) { encoder = CreateEncoder (mbe); break; } } if (encoder == null) encoder = new BinaryMessageEncoder (); } public PeerResolver Resolver { get; set; } public PeerTransportBindingElement Source { get { return source; } } public MessageEncoder MessageEncoder { get { return encoder; } } public override Uri Uri { get { return listen_uri; } } protected override TChannel OnAcceptChannel (TimeSpan timeout) { TChannel ch = PopulateChannel (timeout); channels.Add (ch); return ch; } TChannel PopulateChannel (TimeSpan timeout) { if (typeof (TChannel) == typeof (IInputChannel)) return (TChannel) (object) new PeerDuplexChannel (this); // FIXME: handle timeout somehow. if (typeof (TChannel) == typeof (IDuplexChannel)) return (TChannel) (object) new PeerDuplexChannel (this); throw new InvalidOperationException (String.Format ("Not supported channel '{0}' (mono bug; it is incorrectly allowed at construction time)", typeof (TChannel))); } protected override bool OnWaitForChannel (TimeSpan timeout) { throw new NotImplementedException (); } protected override void OnOpen (TimeSpan timeout) { throw new NotImplementedException (); } protected override void OnClose (TimeSpan timeout) { if (ServiceHostingEnvironment.InAspNet) return; foreach (TChannel ch in channels) ch.Close(timeout); } [MonoTODO ("find out what to do here.")] protected override void OnAbort () { } } }