1 //-----------------------------------------------------------------------------
2 // Copyright (c) Microsoft Corporation. All rights reserved.
3 //-----------------------------------------------------------------------------
4 namespace System.Runtime.Serialization
8 using System.Security.Permissions;
9 using System.Runtime.CompilerServices;
12 public sealed class SurrogateDataContract : DataContract
14 internal sealed class SurrogateDataContract : DataContract
17 [Fx.Tag.SecurityNote(Critical = "Holds instance of CriticalHelper which keeps state that is cached statically for serialization."
18 + " Static fields are marked SecurityCritical or readonly to prevent data from being modified or leaked to other components in appdomain.")]
20 SurrogateDataContractCriticalHelper helper;
22 [Fx.Tag.SecurityNote(Critical = "Initializes SecurityCritical field 'helper'.",
23 Safe = "Doesn't leak anything.")]
24 [SecuritySafeCritical]
25 internal SurrogateDataContract(Type type, ISerializationSurrogate serializationSurrogate)
26 : base(new SurrogateDataContractCriticalHelper(type, serializationSurrogate))
28 helper = base.Helper as SurrogateDataContractCriticalHelper;
31 internal ISerializationSurrogate SerializationSurrogate
33 [Fx.Tag.SecurityNote(Critical = "Fetches the critical serializationSurrogate property.",
34 Safe = "serializationSurrogate only needs to be protected for write.")]
35 [SecuritySafeCritical]
36 get { return helper.SerializationSurrogate; }
39 public override void WriteXmlValue(XmlWriterDelegator xmlWriter, object obj, XmlObjectSerializerWriteContext context)
41 SerializationInfo serInfo = new SerializationInfo(UnderlyingType, XmlObjectSerializer.FormatterConverter, !context.UnsafeTypeForwardingEnabled);
42 SerializationSurrogateGetObjectData(obj, serInfo, context.GetStreamingContext());
43 context.WriteSerializationInfo(xmlWriter, UnderlyingType, serInfo);
46 [Fx.Tag.SecurityNote(Critical = "Calls the critical methods of ISurrogateSelector", Safe = "Demands for FullTrust")]
47 [SecuritySafeCritical]
48 [PermissionSet(SecurityAction.Demand, Unrestricted = true)]
49 [MethodImpl(MethodImplOptions.NoInlining)]
50 object SerializationSurrogateSetObjectData(object obj, SerializationInfo serInfo, StreamingContext context)
52 return SerializationSurrogate.SetObjectData(obj, serInfo, context, null);
55 [Fx.Tag.SecurityNote(Critical = "Calls the critical methods of IObjectReference", Safe = "Demands for FullTrust")]
56 [SecuritySafeCritical]
57 [PermissionSet(SecurityAction.Demand, Unrestricted = true)]
58 [MethodImpl(MethodImplOptions.NoInlining)]
59 internal static object GetRealObject(IObjectReference obj, StreamingContext context)
61 return obj.GetRealObject(context);
64 [Fx.Tag.SecurityNote(Critical = "Calls the critical methods of FormatterServices", Safe = "Demands for FullTrust")]
65 [SecuritySafeCritical]
66 [PermissionSet(SecurityAction.Demand, Unrestricted = true)]
67 [MethodImpl(MethodImplOptions.NoInlining)]
68 object GetUninitializedObject(Type objType)
70 return FormatterServices.GetUninitializedObject(objType);
73 [Fx.Tag.SecurityNote(Critical = "Calls the critical methods of ISerializationSurrogate", Safe = "Demands for FullTrust")]
74 [SecuritySafeCritical]
75 [PermissionSet(SecurityAction.Demand, Unrestricted = true)]
76 [MethodImpl(MethodImplOptions.NoInlining)]
77 void SerializationSurrogateGetObjectData(object obj, SerializationInfo serInfo, StreamingContext context)
79 SerializationSurrogate.GetObjectData(obj, serInfo, context);
82 public override object ReadXmlValue(XmlReaderDelegator xmlReader, XmlObjectSerializerReadContext context)
85 Type objType = UnderlyingType;
86 object obj = objType.IsArray ? Array.CreateInstance(objType.GetElementType(), 0) : GetUninitializedObject(objType);
87 context.AddNewObject(obj);
88 string objectId = context.GetObjectId();
89 SerializationInfo serInfo = context.ReadSerializationInfo(xmlReader, objType);
90 object newObj = SerializationSurrogateSetObjectData(obj, serInfo, context.GetStreamingContext());
93 if (newObj is IDeserializationCallback)
94 ((IDeserializationCallback)newObj).OnDeserialization(null);
95 if (newObj is IObjectReference)
96 newObj = GetRealObject((IObjectReference)newObj, context.GetStreamingContext());
97 context.ReplaceDeserializedObject(objectId, obj, newObj);
98 xmlReader.ReadEndElement();
102 [Fx.Tag.SecurityNote(Critical = "Holds all state used for for (de)serializing with ISerializationSurrogate."
103 + " Since it accesses data on the base type that is cached statically, we lock down access to it.")]
104 [SecurityCritical(SecurityCriticalScope.Everything)]
105 class SurrogateDataContractCriticalHelper : DataContract.DataContractCriticalHelper
107 ISerializationSurrogate serializationSurrogate;
109 internal SurrogateDataContractCriticalHelper(Type type, ISerializationSurrogate serializationSurrogate)
112 this.serializationSurrogate = serializationSurrogate;
114 DataContract.GetDefaultStableName(DataContract.GetClrTypeFullName(type), out name, out ns);
115 SetDataContractName(CreateQualifiedName(name, ns));
118 internal ISerializationSurrogate SerializationSurrogate
120 get { return serializationSurrogate; }