* adding XmppPresenceStanza and deserialization/reification support
having reached the intermediate level of .NET's XmlSudoku, i've now figured out how to do deserialization using different XmlSerializers (this stuff begins to grow on me, sigh). [still not used code, work-in-progress] * adding convenience property on OSHttpRequest.cs (from awebb)0.6.0-stable
parent
0cacdd370c
commit
caee0288fb
|
@ -59,6 +59,11 @@ namespace OpenSim.Framework.Communications.XMPP
|
||||||
{
|
{
|
||||||
Text = message;
|
Text = message;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public string ToString()
|
||||||
|
{
|
||||||
|
return Text;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[XmlRoot("message")]
|
[XmlRoot("message")]
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) Contributors, http://opensimulator.org/
|
||||||
|
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* * Neither the name of the OpenSim Project nor the
|
||||||
|
* names of its contributors may be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
|
||||||
|
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
namespace OpenSim.Framework.Communications.XMPP
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Message types.
|
||||||
|
/// </summary>
|
||||||
|
public enum XmppPresenceType
|
||||||
|
{
|
||||||
|
[XmlEnum("unavailable")] unavailable,
|
||||||
|
[XmlEnum("subscribe")] subscribe,
|
||||||
|
[XmlEnum("subscribed")] subscribed,
|
||||||
|
[XmlEnum("unsubscribe")] unsubscribe,
|
||||||
|
[XmlEnum("unsubscribed")] unsubscribed,
|
||||||
|
[XmlEnum("probe")] probe,
|
||||||
|
[XmlEnum("error")] error,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[XmlRoot("message")]
|
||||||
|
public class XmppPresenceStanza: XmppStanza
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// IQ type: one of set, get, result, error
|
||||||
|
/// </summary>
|
||||||
|
[XmlAttribute("type")]
|
||||||
|
public XmppPresenceType PresenceType;
|
||||||
|
|
||||||
|
// [XmlAttribute("error")]
|
||||||
|
// public XmppError Error;
|
||||||
|
|
||||||
|
public XmppPresenceStanza() : base()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public XmppPresenceStanza(string fromJid, string toJid, XmppPresenceType pType) :
|
||||||
|
base(fromJid, toJid)
|
||||||
|
{
|
||||||
|
PresenceType = pType;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -28,21 +28,27 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Xml;
|
using System.Xml;
|
||||||
using System.Xml.Serialization;
|
using System.Xml.Serialization;
|
||||||
|
using log4net;
|
||||||
|
|
||||||
namespace OpenSim.Framework.Communications.XMPP
|
namespace OpenSim.Framework.Communications.XMPP
|
||||||
{
|
{
|
||||||
public class XMPPSerializer
|
public class XmppSerializer
|
||||||
{
|
{
|
||||||
|
private static readonly ILog _log =
|
||||||
|
LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
// need to do it this way, as XmlSerializer(type, extratypes)
|
// need to do it this way, as XmlSerializer(type, extratypes)
|
||||||
// does not work on mono (at least).
|
// does not work on mono (at least).
|
||||||
private Dictionary<Type, XmlSerializer> _serializers = new Dictionary<Type, XmlSerializer>();
|
private Dictionary<Type, XmlSerializer> _serializerForType = new Dictionary<Type, XmlSerializer>();
|
||||||
|
private Dictionary<string, XmlSerializer> _serializerForName = new Dictionary<string, XmlSerializer>();
|
||||||
private XmlSerializerNamespaces _xmlNs;
|
private XmlSerializerNamespaces _xmlNs;
|
||||||
private string _defaultNS;
|
private string _defaultNS;
|
||||||
|
|
||||||
public XMPPSerializer(bool server)
|
public XmppSerializer(bool server)
|
||||||
{
|
{
|
||||||
_xmlNs = new XmlSerializerNamespaces();
|
_xmlNs = new XmlSerializerNamespaces();
|
||||||
_xmlNs.Add(String.Empty, String.Empty);
|
_xmlNs.Add(String.Empty, String.Empty);
|
||||||
|
@ -51,15 +57,27 @@ namespace OpenSim.Framework.Communications.XMPP
|
||||||
else
|
else
|
||||||
_defaultNS = "jabber:client";
|
_defaultNS = "jabber:client";
|
||||||
|
|
||||||
_serializers[typeof(XmppMessageStanza)] = new XmlSerializer(typeof(XmppMessageStanza), _defaultNS);
|
// TODO: do this via reflection
|
||||||
|
_serializerForType[typeof(XmppMessageStanza)] = _serializerForName["message"] =
|
||||||
|
new XmlSerializer(typeof(XmppMessageStanza), _defaultNS);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Serialize(XmlWriter xw, object o)
|
public void Serialize(XmlWriter xw, object o)
|
||||||
{
|
{
|
||||||
if (!_serializers.ContainsKey(o.GetType()))
|
if (!_serializerForType.ContainsKey(o.GetType()))
|
||||||
throw new ArgumentException(String.Format("no serializer available for type {0}", o.GetType()));
|
throw new ArgumentException(String.Format("no serializer available for type {0}", o.GetType()));
|
||||||
|
|
||||||
_serializers[o.GetType()].Serialize(xw, o, _xmlNs);
|
_serializerForType[o.GetType()].Serialize(xw, o, _xmlNs);
|
||||||
|
}
|
||||||
|
|
||||||
|
public object Deserialize(XmlReader xr)
|
||||||
|
{
|
||||||
|
// position on next element
|
||||||
|
xr.Read();
|
||||||
|
if (!_serializerForName.ContainsKey(xr.LocalName))
|
||||||
|
throw new ArgumentException(String.Format("no serializer available for name {0}", xr.LocalName));
|
||||||
|
|
||||||
|
return _serializerForName[xr.LocalName].Deserialize(xr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,11 @@ namespace OpenSim.Framework.Servers
|
||||||
get { return _contentLength64; }
|
get { return _contentLength64; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public long ContentLength64
|
||||||
|
{
|
||||||
|
get { return _contentLength64; }
|
||||||
|
}
|
||||||
|
|
||||||
public string ContentType
|
public string ContentType
|
||||||
{
|
{
|
||||||
get { return _contentType; }
|
get { return _contentType; }
|
||||||
|
|
Loading…
Reference in New Issue