Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Core / CSharp / System / IO / Packaging / PackWebRequestFactory.cs / 1 / PackWebRequestFactory.cs
//------------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description:
// Creates a PackWebRequest object
//
// History:
// 10/09/2003: BruceMac: Created.
// 05/10/2004: BruceMac: Rework for Pack scheme (from CompoundFile scheme)
// 05/26/2004: BruceMac: Use ILoader cache instead of PackageCache
// 04/26/2005: BruceMac: Use PackUriHelper to obtain Authority for cache lookup
//
//-----------------------------------------------------------------------------
#if DEBUG
#define TRACE
#endif
using System;
using System.Net;
using System.Diagnostics; // for Assert
using MS.Internal.IO.Packaging; // for PackageCache
using MS.Internal.PresentationCore; // for ExceptionStringTable
using System.Security;
using System.Security.Permissions;
using MS.Internal;
namespace System.IO.Packaging
{
///
/// Invoked by .NET framework when our schema is recognized during a WebRequest
///
public sealed class PackWebRequestFactory : IWebRequestCreate
{
///
/// Critical as the BooleanSwitch has a LinkDemand
/// TreatAsSafe as this is just a diag switch, Debug-only, no input data is used,
/// and the usage is considered safe (tracing).
///
[SecurityCritical, SecurityTreatAsSafe]
static PackWebRequestFactory()
{
#if DEBUG
_traceSwitch = new BooleanSwitch("PackWebRequest", "PackWebRequest/Response and NetStream trace messages");
#endif
}
//-----------------------------------------------------
//
// IWebRequestCreate
//
//-----------------------------------------------------
///
/// Create
///
/// uri
/// PackWebRequest
/// Note that this factory may or may not be "registered" with the .NET WebRequest factory as handler
/// for "pack" scheme web requests. Because of this, callers should be sure to use the PackUriHelper static class
/// to prepare their Uri's. Calling any PackUriHelper method has the side effect of registering
/// the "pack" scheme and associating this factory class as its default handler.
///
/// Critical: Access a package instance from PreloadedPackages.
/// TreatAsSafe: because it is a public method and no Package related objects
/// are given out from this API other than a part stream
///
[SecurityCritical, SecurityTreatAsSafe]
WebRequest IWebRequestCreate.Create(Uri uri)
{
if (uri == null)
throw new ArgumentNullException("uri");
// Ensure uri is absolute - if we don't check now, the get_Scheme property will throw
// InvalidOperationException which would be misleading to the caller.
if (!uri.IsAbsoluteUri)
throw new ArgumentException(SR.Get(SRID.UriMustBeAbsolute), "uri");
// Ensure uri is correct scheme because we can be called directly. Case sensitive
// is fine because Uri.Scheme contract is to return in lower case only.
if (String.Compare(uri.Scheme, PackUriHelper.UriSchemePack, StringComparison.Ordinal) != 0)
throw new ArgumentException(SR.Get(SRID.UriSchemeMismatch, PackUriHelper.UriSchemePack), "uri");
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - responding to uri: " + uri);
#endif
// only inspect cache if part name is present because cache only contains an object, not
// the stream it was derived from
Uri packageUri;
Uri partUri;
PackUriHelper.ValidateAndGetPackUriComponents(uri, out packageUri, out partUri);
if (partUri != null)
{
// Note: we look at PreloadedPackages first before we examine the PackageStore
// This is to make sure that an app cannot override any predefine packages
// match cached object by authority component only - ignore the local path (part name)
// inspect local package cache and default to that if possible
// All predefined packages such as a package activated by DocumentApplication,
// ResourceContainer, and SiteOfOriginContainer are placed in PreloadedPackages
bool cachedPackageIsThreadSafe;
Package c = PreloadedPackages.GetPackage(packageUri, out cachedPackageIsThreadSafe);
// If we don't find anything in the preloaded packages, look into the PackageStore
bool cachedPackageIsFromPublicStore = false;
if (c == null)
{
cachedPackageIsThreadSafe = false; // always assume PackageStore packages are not thread-safe
cachedPackageIsFromPublicStore = true;
// Try to get a package from the package store
c = PackageStore.GetPackage(packageUri);
}
// do we have a package?
if (c != null)
{
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - cache hit - returning CachedPackWebRequest");
#endif
// use the cached object
return new PackWebRequest(uri, packageUri, partUri, c,
cachedPackageIsFromPublicStore, cachedPackageIsThreadSafe);
}
}
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - spawning regular PackWebRequest");
#endif
return new PackWebRequest(uri, packageUri, partUri);
}
//------------------------------------------------------
//
// Internal Methods
//
//-----------------------------------------------------
// CreateWebRequest: Explicitly calls Create on PackWebRequest if uri is pack scheme
// Ideally we would want to use RegisterPrefix and WebRequest.Create.
// However, these two functions regress 700k working set in System.dll and System.xml.dll
// which is mostly for logging and config.
// This helper function provides a way to bypass the regression
[FriendAccessAllowed]
internal static WebRequest CreateWebRequest(Uri uri)
{
if (String.Compare(uri.Scheme, PackUriHelper.UriSchemePack, StringComparison.Ordinal) == 0)
{
return ((IWebRequestCreate) _factorySingleton).Create(uri);
}
else
{
return WpfWebRequestHelper.CreateRequest(uri);
}
}
#if DEBUG
///
/// Critical: sets BooleanSwitch.Enabled which LinkDemands
/// TreatAsSafe: ok to enable tracing, and it's in debug only
///
internal static bool TraceSwitchEnabled
{
get
{
return _traceSwitch.Enabled;
}
[SecurityCritical, SecurityTreatAsSafe]
set
{
_traceSwitch.Enabled = value;
}
}
internal static System.Diagnostics.BooleanSwitch _traceSwitch;
#endif
//------------------------------------------------------
//
// Private Members
//
//------------------------------------------------------
private static PackWebRequestFactory _factorySingleton = new PackWebRequestFactory();
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
//------------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description:
// Creates a PackWebRequest object
//
// History:
// 10/09/2003: BruceMac: Created.
// 05/10/2004: BruceMac: Rework for Pack scheme (from CompoundFile scheme)
// 05/26/2004: BruceMac: Use ILoader cache instead of PackageCache
// 04/26/2005: BruceMac: Use PackUriHelper to obtain Authority for cache lookup
//
//-----------------------------------------------------------------------------
#if DEBUG
#define TRACE
#endif
using System;
using System.Net;
using System.Diagnostics; // for Assert
using MS.Internal.IO.Packaging; // for PackageCache
using MS.Internal.PresentationCore; // for ExceptionStringTable
using System.Security;
using System.Security.Permissions;
using MS.Internal;
namespace System.IO.Packaging
{
///
/// Invoked by .NET framework when our schema is recognized during a WebRequest
///
public sealed class PackWebRequestFactory : IWebRequestCreate
{
///
/// Critical as the BooleanSwitch has a LinkDemand
/// TreatAsSafe as this is just a diag switch, Debug-only, no input data is used,
/// and the usage is considered safe (tracing).
///
[SecurityCritical, SecurityTreatAsSafe]
static PackWebRequestFactory()
{
#if DEBUG
_traceSwitch = new BooleanSwitch("PackWebRequest", "PackWebRequest/Response and NetStream trace messages");
#endif
}
//-----------------------------------------------------
//
// IWebRequestCreate
//
//-----------------------------------------------------
///
/// Create
///
/// uri
/// PackWebRequest
/// Note that this factory may or may not be "registered" with the .NET WebRequest factory as handler
/// for "pack" scheme web requests. Because of this, callers should be sure to use the PackUriHelper static class
/// to prepare their Uri's. Calling any PackUriHelper method has the side effect of registering
/// the "pack" scheme and associating this factory class as its default handler.
///
/// Critical: Access a package instance from PreloadedPackages.
/// TreatAsSafe: because it is a public method and no Package related objects
/// are given out from this API other than a part stream
///
[SecurityCritical, SecurityTreatAsSafe]
WebRequest IWebRequestCreate.Create(Uri uri)
{
if (uri == null)
throw new ArgumentNullException("uri");
// Ensure uri is absolute - if we don't check now, the get_Scheme property will throw
// InvalidOperationException which would be misleading to the caller.
if (!uri.IsAbsoluteUri)
throw new ArgumentException(SR.Get(SRID.UriMustBeAbsolute), "uri");
// Ensure uri is correct scheme because we can be called directly. Case sensitive
// is fine because Uri.Scheme contract is to return in lower case only.
if (String.Compare(uri.Scheme, PackUriHelper.UriSchemePack, StringComparison.Ordinal) != 0)
throw new ArgumentException(SR.Get(SRID.UriSchemeMismatch, PackUriHelper.UriSchemePack), "uri");
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - responding to uri: " + uri);
#endif
// only inspect cache if part name is present because cache only contains an object, not
// the stream it was derived from
Uri packageUri;
Uri partUri;
PackUriHelper.ValidateAndGetPackUriComponents(uri, out packageUri, out partUri);
if (partUri != null)
{
// Note: we look at PreloadedPackages first before we examine the PackageStore
// This is to make sure that an app cannot override any predefine packages
// match cached object by authority component only - ignore the local path (part name)
// inspect local package cache and default to that if possible
// All predefined packages such as a package activated by DocumentApplication,
// ResourceContainer, and SiteOfOriginContainer are placed in PreloadedPackages
bool cachedPackageIsThreadSafe;
Package c = PreloadedPackages.GetPackage(packageUri, out cachedPackageIsThreadSafe);
// If we don't find anything in the preloaded packages, look into the PackageStore
bool cachedPackageIsFromPublicStore = false;
if (c == null)
{
cachedPackageIsThreadSafe = false; // always assume PackageStore packages are not thread-safe
cachedPackageIsFromPublicStore = true;
// Try to get a package from the package store
c = PackageStore.GetPackage(packageUri);
}
// do we have a package?
if (c != null)
{
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - cache hit - returning CachedPackWebRequest");
#endif
// use the cached object
return new PackWebRequest(uri, packageUri, partUri, c,
cachedPackageIsFromPublicStore, cachedPackageIsThreadSafe);
}
}
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId + ": " +
"PackWebRequestFactory - spawning regular PackWebRequest");
#endif
return new PackWebRequest(uri, packageUri, partUri);
}
//------------------------------------------------------
//
// Internal Methods
//
//-----------------------------------------------------
// CreateWebRequest: Explicitly calls Create on PackWebRequest if uri is pack scheme
// Ideally we would want to use RegisterPrefix and WebRequest.Create.
// However, these two functions regress 700k working set in System.dll and System.xml.dll
// which is mostly for logging and config.
// This helper function provides a way to bypass the regression
[FriendAccessAllowed]
internal static WebRequest CreateWebRequest(Uri uri)
{
if (String.Compare(uri.Scheme, PackUriHelper.UriSchemePack, StringComparison.Ordinal) == 0)
{
return ((IWebRequestCreate) _factorySingleton).Create(uri);
}
else
{
return WpfWebRequestHelper.CreateRequest(uri);
}
}
#if DEBUG
///
/// Critical: sets BooleanSwitch.Enabled which LinkDemands
/// TreatAsSafe: ok to enable tracing, and it's in debug only
///
internal static bool TraceSwitchEnabled
{
get
{
return _traceSwitch.Enabled;
}
[SecurityCritical, SecurityTreatAsSafe]
set
{
_traceSwitch.Enabled = value;
}
}
internal static System.Diagnostics.BooleanSwitch _traceSwitch;
#endif
//------------------------------------------------------
//
// Private Members
//
//------------------------------------------------------
private static PackWebRequestFactory _factorySingleton = new PackWebRequestFactory();
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- GradientStop.cs
- InvalidFilterCriteriaException.cs
- Vector3DKeyFrameCollection.cs
- OdbcConnectionHandle.cs
- LOSFormatter.cs
- RemoteArgument.cs
- Content.cs
- BamlLocalizableResourceKey.cs
- SignatureHelper.cs
- ListViewDataItem.cs
- AssociationType.cs
- NetSectionGroup.cs
- HelpKeywordAttribute.cs
- InsufficientMemoryException.cs
- LayeredChannelFactory.cs
- EventDescriptor.cs
- UInt16Storage.cs
- EntityWithChangeTrackerStrategy.cs
- EventMappingSettings.cs
- HttpModuleActionCollection.cs
- CustomAttributeBuilder.cs
- DbConnectionPoolGroupProviderInfo.cs
- CodeTypeMemberCollection.cs
- JsonFormatGeneratorStatics.cs
- FileChangeNotifier.cs
- TableItemStyle.cs
- ShimAsPublicXamlType.cs
- MarkupExtensionParser.cs
- UnmanagedMemoryStreamWrapper.cs
- SQLMoney.cs
- SvcMapFileSerializer.cs
- SoapElementAttribute.cs
- WebPartTracker.cs
- HtmlControl.cs
- keycontainerpermission.cs
- SystemIPInterfaceStatistics.cs
- UserPreferenceChangedEventArgs.cs
- FixedStringLookup.cs
- GC.cs
- GACIdentityPermission.cs
- InitializationEventAttribute.cs
- GraphicsContainer.cs
- TreeNodeClickEventArgs.cs
- WebBrowserNavigatingEventHandler.cs
- SiteMapNodeItemEventArgs.cs
- InstanceHandleConflictException.cs
- ExtendedPropertyCollection.cs
- WebConfigurationHost.cs
- ServiceDesigner.cs
- DataContractSerializerFaultFormatter.cs
- TreeView.cs
- IMembershipProvider.cs
- MsmqTransportBindingElement.cs
- SequenceDesigner.cs
- DataGridLinkButton.cs
- DataGridCommandEventArgs.cs
- TemplateBuilder.cs
- SizeKeyFrameCollection.cs
- GridEntryCollection.cs
- UserControlCodeDomTreeGenerator.cs
- WorkflowHostingEndpoint.cs
- RightsManagementInformation.cs
- DetailsViewDeletedEventArgs.cs
- BuilderPropertyEntry.cs
- shaperfactoryquerycachekey.cs
- WindowsGraphics.cs
- GACIdentityPermission.cs
- TrustLevel.cs
- TypedTableGenerator.cs
- HttpListenerException.cs
- FileDetails.cs
- HttpChannelHelpers.cs
- UInt16Storage.cs
- AdapterUtil.cs
- LinqDataSourceInsertEventArgs.cs
- XmlSchemaAll.cs
- OleDbConnection.cs
- RuntimeEnvironment.cs
- SecurityTokenTypes.cs
- EpmContentDeSerializer.cs
- AspProxy.cs
- NativeActivityTransactionContext.cs
- Validator.cs
- Durable.cs
- PropertyGridCommands.cs
- TypeBuilder.cs
- SerialErrors.cs
- formatter.cs
- bidPrivateBase.cs
- Privilege.cs
- XmlTextReaderImplHelpers.cs
- sqlstateclientmanager.cs
- ListViewInsertionMark.cs
- DllNotFoundException.cs
- SiteIdentityPermission.cs
- EmissiveMaterial.cs
- ButtonChrome.cs
- AppSettings.cs
- GeometryCombineModeValidation.cs
- GenericArgumentsUpdater.cs