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
- DbMetaDataFactory.cs
- XamlTypeMapper.cs
- AdPostCacheSubstitution.cs
- WindowVisualStateTracker.cs
- NonVisualControlAttribute.cs
- DesignerPerfEventProvider.cs
- FilterEventArgs.cs
- Empty.cs
- HostingEnvironmentSection.cs
- Dispatcher.cs
- XmlDataSourceNodeDescriptor.cs
- EndOfStreamException.cs
- GlyphInfoList.cs
- RpcCryptoRequest.cs
- bidPrivateBase.cs
- JournalEntryListConverter.cs
- CalloutQueueItem.cs
- RemotingException.cs
- VerificationException.cs
- WebUtil.cs
- XPathNavigatorKeyComparer.cs
- AttributeSetAction.cs
- HttpResponseMessageProperty.cs
- TreeViewEvent.cs
- DesignerSerializationOptionsAttribute.cs
- CompModSwitches.cs
- LineGeometry.cs
- VectorConverter.cs
- FrameworkElementFactoryMarkupObject.cs
- DefaultPropertiesToSend.cs
- SlipBehavior.cs
- MenuItemStyle.cs
- BaseComponentEditor.cs
- TypeConverter.cs
- TextBounds.cs
- TraceUtility.cs
- EventToken.cs
- RadioButton.cs
- OptimizedTemplateContentHelper.cs
- Pair.cs
- Pair.cs
- MenuItemCollection.cs
- NativeRightsManagementAPIsStructures.cs
- InstanceData.cs
- CheckBoxField.cs
- TableDetailsCollection.cs
- TemplatedMailWebEventProvider.cs
- Timer.cs
- IOThreadScheduler.cs
- ParseChildrenAsPropertiesAttribute.cs
- XamlSerializerUtil.cs
- WaveHeader.cs
- ObjectListCommandsPage.cs
- HandledEventArgs.cs
- ElementAtQueryOperator.cs
- ToolStripLabel.cs
- ActiveXHelper.cs
- EditorResources.cs
- _ListenerResponseStream.cs
- References.cs
- ForwardPositionQuery.cs
- ReliableMessagingVersion.cs
- CommandValueSerializer.cs
- BaseDataList.cs
- Simplifier.cs
- XmlDataCollection.cs
- FontSource.cs
- StrongNamePublicKeyBlob.cs
- QueryCursorEventArgs.cs
- XmlILAnnotation.cs
- XmlnsDefinitionAttribute.cs
- Gdiplus.cs
- ListViewPagedDataSource.cs
- PropertyItem.cs
- XmlMembersMapping.cs
- PictureBox.cs
- UpdateTracker.cs
- HeaderCollection.cs
- QilUnary.cs
- MetadataUtil.cs
- ScriptReferenceEventArgs.cs
- StorageFunctionMapping.cs
- Dump.cs
- SignatureHelper.cs
- Label.cs
- WSHttpBindingBase.cs
- PageAdapter.cs
- ErrorFormatterPage.cs
- AppLevelCompilationSectionCache.cs
- WebPartConnectionCollection.cs
- XmlTextWriter.cs
- RecognizedWordUnit.cs
- TextEditorDragDrop.cs
- EntityContainer.cs
- CodeIndexerExpression.cs
- Vector3DIndependentAnimationStorage.cs
- UrlMappingsModule.cs
- InputLangChangeRequestEvent.cs
- filewebresponse.cs
- PageThemeCodeDomTreeGenerator.cs