Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / MS / Internal / AppModel / SiteOfOriginContainer.cs / 1305600 / SiteOfOriginContainer.cs
//------------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// Description:
// SiteOfOriginContainer is an implementation of the abstract Package class.
// It contains nontrivial overrides for GetPartCore and Exists.
// Many of the methods on Package are not applicable to loading application
// resources, so the SiteOfOriginContainer implementations of these methods throw
// the NotSupportedException.
//
// History:
// 06/16/2005: [....] - Initial creation.
//-----------------------------------------------------------------------------
using System;
using System.IO.Packaging;
using System.IO;
using System.Collections.Generic;
using System.Windows.Resources;
using System.Resources;
using System.Reflection;
using System.Globalization;
using System.Windows;
using System.Windows.Navigation;
using System.Deployment.Application;
using System.Security;
using System.Security.Permissions;
using MS.Internal.PresentationCore;
namespace MS.Internal.AppModel
{
///
/// SiteOfOriginContainer is an implementation of the abstract Package class.
/// It contains nontrivial overrides for GetPartCore and Exists.
/// Many of the methods on Package are not applicable to loading files
/// so the SiteOfOriginContainer implementations of these methods throw
/// the NotSupportedException.
///
internal class SiteOfOriginContainer : System.IO.Packaging.Package
{
//-----------------------------------------------------
//
// Static Methods
//
//-----------------------------------------------------
#region Static Methods
internal static Uri SiteOfOrigin
{
[FriendAccessAllowed]
get
{
Uri siteOfOrigin = SiteOfOriginForClickOnceApp;
if (siteOfOrigin == null)
{
// Calling FixFileUri because BaseDirectory will be a c:\\ style path
siteOfOrigin = BaseUriHelper.FixFileUri(new Uri(System.AppDomain.CurrentDomain.BaseDirectory));
}
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId +
": SiteOfOriginContainer: returning site of origin " + siteOfOrigin);
#endif
return siteOfOrigin;
}
}
// we separated this from the rest of the code because this code is used for media permission
// tests in partial trust but we want to do this without hitting the code path for regular exe's
// as in the code above. This will get hit for click once apps, xbaps, xaml and xps
///
/// Critical: sets critical data _siteOfOriginForClickOnceApp.
/// TreatAsSafe: the source we set it to is trusted. It is also safe to get the app's site of origin.
///
internal static Uri SiteOfOriginForClickOnceApp
{
[SecurityCritical, SecurityTreatAsSafe, FriendAccessAllowed]
get
{
// The ClickOnce API, ApplicationDeployment.IsNetworkDeployed, determines whether the app is network-deployed
// by getting the ApplicationDeployment.CurrentDeployment property and catch the exception it can throw.
// The exception is a first chance exception and caught, but it often confuses developers,
// and can also have a perf impact. So we change to cache the value of SiteofOrigin in Dev10 to avoid the
// exception being thrown too many times.
// An alternative is to cache the value of ApplicationDeployment.IsNetworkDeployed.
if (_siteOfOriginForClickOnceApp == null)
{
if (_browserSource.Value != null)
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(_browserSource.Value);
}
else if (ApplicationDeployment.IsNetworkDeployed)
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(GetDeploymentUri());
}
else
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(null);
}
}
Invariant.Assert(_siteOfOriginForClickOnceApp != null);
return _siteOfOriginForClickOnceApp.Value.Value;
}
}
///
/// Critical - Whatever is set here will be treated as site of origin.
///
internal static Uri BrowserSource
{
get
{
return _browserSource.Value;
}
[SecurityCritical, FriendAccessAllowed]
set
{
_browserSource.Value = value;
}
}
#endregion
//------------------------------------------------------
//
// Public Constructors
//
//-----------------------------------------------------
#region Public Constructors
///
/// Default Constructor
///
internal SiteOfOriginContainer() : base(FileAccess.Read)
{
}
#endregion
//------------------------------------------------------
//
// Public Properties
//
//------------------------------------------------------
// None
//-----------------------------------------------------
//
// Public Methods
//
//------------------------------------------------------
#region Public Methods
///
///
public override bool PartExists(Uri uri)
{
return true;
}
#endregion
//-----------------------------------------------------
//
// Public Events
//
//-----------------------------------------------------
// None
//-----------------------------------------------------
//
// Internal Constructors
//
//------------------------------------------------------
// None
//-----------------------------------------------------
//
// Internal Properties
//
//------------------------------------------------------
#region Internal Properties
///
/// Critical: sets BooleanSwitch.Enabled which LinkDemands
/// TreatAsSafe: ok to enable tracing
///
internal static bool TraceSwitchEnabled
{
get
{
return _traceSwitch.Enabled;
}
[SecurityCritical, SecurityTreatAsSafe]
set
{
_traceSwitch.Enabled = value;
}
}
internal static System.Diagnostics.BooleanSwitch _traceSwitch =
new System.Diagnostics.BooleanSwitch("SiteOfOrigin", "SiteOfOriginContainer and SiteOfOriginPart trace messages");
#endregion
//------------------------------------------------------
//
// Internal Methods
//
//-----------------------------------------------------
// None
//------------------------------------------------------
//
// Internal Events
//
//-----------------------------------------------------
// None
//-----------------------------------------------------
//
// Protected Constructors
//
//-----------------------------------------------------
// None
//------------------------------------------------------
//
// Protected Methods
//
//-----------------------------------------------------
#region Protected Methods
///
/// This method creates a SiteOfOriginPart which will create a WebRequest
/// to access files at the site of origin.
///
///
///
protected override PackagePart GetPartCore(Uri uri)
{
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId +
": SiteOfOriginContainer: Creating SiteOfOriginPart for Uri " + uri);
#endif
return new SiteOfOriginPart(this, uri);
}
#endregion
//------------------------------------------------------
//
// Private Methods
//
//------------------------------------------------------
#region Private Methods
///
/// Critical - Performs an elevation to access ApplicationIdentity
/// TreatAsSafe - Returns the Uri the .application/.xapp was launched from if the application was network deployed.
/// This will not work for a standalone application due to the invariant assert. This information is
/// not considered critical because an application is allowed to know where it was deployed from just
/// not the local path it is running from.
/// This information is also typically available from ApplicationDeployment.CurrentDeployment.ActivationUri
/// or ApplicationDeployment.CurrentDeployment.UpdateLocation but those properties are null for applications
/// that do not take Uri parameters and do not receive updates from the web. Neither of those properties
/// requires an assert to access and are available in partial trust. We are not using them because the need
/// for a site of origin is not dependent on update or uri parameters.
///
[SecurityCritical, SecurityTreatAsSafe]
private static Uri GetDeploymentUri()
{
Invariant.Assert(ApplicationDeployment.IsNetworkDeployed);
AppDomain currentDomain = AppDomain.CurrentDomain;
ApplicationIdentity ident = null;
string codeBase = null;
SecurityPermission p1 = new SecurityPermission(SecurityPermissionFlag.ControlDomainPolicy);
p1.Assert();
try
{
ident = currentDomain.ApplicationIdentity; // ControlDomainPolicy
}
finally
{
CodeAccessPermission.RevertAssert();
}
SecurityPermission p2 = new SecurityPermission(SecurityPermissionFlag.UnmanagedCode);
p2.Assert();
try
{
codeBase = ident.CodeBase; // Unmanaged Code permission
}
finally
{
CodeAccessPermission.RevertAssert();
}
return new Uri(new Uri(codeBase), new Uri(".", UriKind.Relative));
}
#endregion
//-----------------------------------------------------
//
// Private Fields
//
//------------------------------------------------------
#region Private Members
private static SecurityCriticalDataForSet _browserSource;
private static SecurityCriticalDataForSet? _siteOfOriginForClickOnceApp;
#endregion Private Members
//-----------------------------------------------------
//
// Uninteresting (but required) overrides
//
//-----------------------------------------------------
#region Uninteresting (but required) overrides
protected override PackagePart CreatePartCore(Uri uri, string contentType, CompressionOption compressionOption)
{
return null;
}
protected override void DeletePartCore(Uri uri)
{
throw new NotSupportedException();
}
protected override PackagePart[] GetPartsCore()
{
throw new NotSupportedException();
}
protected override void FlushCore()
{
throw new NotSupportedException();
}
#endregion
}
}
// 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:
// SiteOfOriginContainer is an implementation of the abstract Package class.
// It contains nontrivial overrides for GetPartCore and Exists.
// Many of the methods on Package are not applicable to loading application
// resources, so the SiteOfOriginContainer implementations of these methods throw
// the NotSupportedException.
//
// History:
// 06/16/2005: [....] - Initial creation.
//-----------------------------------------------------------------------------
using System;
using System.IO.Packaging;
using System.IO;
using System.Collections.Generic;
using System.Windows.Resources;
using System.Resources;
using System.Reflection;
using System.Globalization;
using System.Windows;
using System.Windows.Navigation;
using System.Deployment.Application;
using System.Security;
using System.Security.Permissions;
using MS.Internal.PresentationCore;
namespace MS.Internal.AppModel
{
///
/// SiteOfOriginContainer is an implementation of the abstract Package class.
/// It contains nontrivial overrides for GetPartCore and Exists.
/// Many of the methods on Package are not applicable to loading files
/// so the SiteOfOriginContainer implementations of these methods throw
/// the NotSupportedException.
///
internal class SiteOfOriginContainer : System.IO.Packaging.Package
{
//-----------------------------------------------------
//
// Static Methods
//
//-----------------------------------------------------
#region Static Methods
internal static Uri SiteOfOrigin
{
[FriendAccessAllowed]
get
{
Uri siteOfOrigin = SiteOfOriginForClickOnceApp;
if (siteOfOrigin == null)
{
// Calling FixFileUri because BaseDirectory will be a c:\\ style path
siteOfOrigin = BaseUriHelper.FixFileUri(new Uri(System.AppDomain.CurrentDomain.BaseDirectory));
}
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId +
": SiteOfOriginContainer: returning site of origin " + siteOfOrigin);
#endif
return siteOfOrigin;
}
}
// we separated this from the rest of the code because this code is used for media permission
// tests in partial trust but we want to do this without hitting the code path for regular exe's
// as in the code above. This will get hit for click once apps, xbaps, xaml and xps
///
/// Critical: sets critical data _siteOfOriginForClickOnceApp.
/// TreatAsSafe: the source we set it to is trusted. It is also safe to get the app's site of origin.
///
internal static Uri SiteOfOriginForClickOnceApp
{
[SecurityCritical, SecurityTreatAsSafe, FriendAccessAllowed]
get
{
// The ClickOnce API, ApplicationDeployment.IsNetworkDeployed, determines whether the app is network-deployed
// by getting the ApplicationDeployment.CurrentDeployment property and catch the exception it can throw.
// The exception is a first chance exception and caught, but it often confuses developers,
// and can also have a perf impact. So we change to cache the value of SiteofOrigin in Dev10 to avoid the
// exception being thrown too many times.
// An alternative is to cache the value of ApplicationDeployment.IsNetworkDeployed.
if (_siteOfOriginForClickOnceApp == null)
{
if (_browserSource.Value != null)
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(_browserSource.Value);
}
else if (ApplicationDeployment.IsNetworkDeployed)
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(GetDeploymentUri());
}
else
{
_siteOfOriginForClickOnceApp = new SecurityCriticalDataForSet(null);
}
}
Invariant.Assert(_siteOfOriginForClickOnceApp != null);
return _siteOfOriginForClickOnceApp.Value.Value;
}
}
///
/// Critical - Whatever is set here will be treated as site of origin.
///
internal static Uri BrowserSource
{
get
{
return _browserSource.Value;
}
[SecurityCritical, FriendAccessAllowed]
set
{
_browserSource.Value = value;
}
}
#endregion
//------------------------------------------------------
//
// Public Constructors
//
//-----------------------------------------------------
#region Public Constructors
///
/// Default Constructor
///
internal SiteOfOriginContainer() : base(FileAccess.Read)
{
}
#endregion
//------------------------------------------------------
//
// Public Properties
//
//------------------------------------------------------
// None
//-----------------------------------------------------
//
// Public Methods
//
//------------------------------------------------------
#region Public Methods
///
///
public override bool PartExists(Uri uri)
{
return true;
}
#endregion
//-----------------------------------------------------
//
// Public Events
//
//-----------------------------------------------------
// None
//-----------------------------------------------------
//
// Internal Constructors
//
//------------------------------------------------------
// None
//-----------------------------------------------------
//
// Internal Properties
//
//------------------------------------------------------
#region Internal Properties
///
/// Critical: sets BooleanSwitch.Enabled which LinkDemands
/// TreatAsSafe: ok to enable tracing
///
internal static bool TraceSwitchEnabled
{
get
{
return _traceSwitch.Enabled;
}
[SecurityCritical, SecurityTreatAsSafe]
set
{
_traceSwitch.Enabled = value;
}
}
internal static System.Diagnostics.BooleanSwitch _traceSwitch =
new System.Diagnostics.BooleanSwitch("SiteOfOrigin", "SiteOfOriginContainer and SiteOfOriginPart trace messages");
#endregion
//------------------------------------------------------
//
// Internal Methods
//
//-----------------------------------------------------
// None
//------------------------------------------------------
//
// Internal Events
//
//-----------------------------------------------------
// None
//-----------------------------------------------------
//
// Protected Constructors
//
//-----------------------------------------------------
// None
//------------------------------------------------------
//
// Protected Methods
//
//-----------------------------------------------------
#region Protected Methods
///
/// This method creates a SiteOfOriginPart which will create a WebRequest
/// to access files at the site of origin.
///
///
///
protected override PackagePart GetPartCore(Uri uri)
{
#if DEBUG
if (_traceSwitch.Enabled)
System.Diagnostics.Trace.TraceInformation(
DateTime.Now.ToLongTimeString() + " " + DateTime.Now.Millisecond + " " +
System.Threading.Thread.CurrentThread.ManagedThreadId +
": SiteOfOriginContainer: Creating SiteOfOriginPart for Uri " + uri);
#endif
return new SiteOfOriginPart(this, uri);
}
#endregion
//------------------------------------------------------
//
// Private Methods
//
//------------------------------------------------------
#region Private Methods
///
/// Critical - Performs an elevation to access ApplicationIdentity
/// TreatAsSafe - Returns the Uri the .application/.xapp was launched from if the application was network deployed.
/// This will not work for a standalone application due to the invariant assert. This information is
/// not considered critical because an application is allowed to know where it was deployed from just
/// not the local path it is running from.
/// This information is also typically available from ApplicationDeployment.CurrentDeployment.ActivationUri
/// or ApplicationDeployment.CurrentDeployment.UpdateLocation but those properties are null for applications
/// that do not take Uri parameters and do not receive updates from the web. Neither of those properties
/// requires an assert to access and are available in partial trust. We are not using them because the need
/// for a site of origin is not dependent on update or uri parameters.
///
[SecurityCritical, SecurityTreatAsSafe]
private static Uri GetDeploymentUri()
{
Invariant.Assert(ApplicationDeployment.IsNetworkDeployed);
AppDomain currentDomain = AppDomain.CurrentDomain;
ApplicationIdentity ident = null;
string codeBase = null;
SecurityPermission p1 = new SecurityPermission(SecurityPermissionFlag.ControlDomainPolicy);
p1.Assert();
try
{
ident = currentDomain.ApplicationIdentity; // ControlDomainPolicy
}
finally
{
CodeAccessPermission.RevertAssert();
}
SecurityPermission p2 = new SecurityPermission(SecurityPermissionFlag.UnmanagedCode);
p2.Assert();
try
{
codeBase = ident.CodeBase; // Unmanaged Code permission
}
finally
{
CodeAccessPermission.RevertAssert();
}
return new Uri(new Uri(codeBase), new Uri(".", UriKind.Relative));
}
#endregion
//-----------------------------------------------------
//
// Private Fields
//
//------------------------------------------------------
#region Private Members
private static SecurityCriticalDataForSet _browserSource;
private static SecurityCriticalDataForSet? _siteOfOriginForClickOnceApp;
#endregion Private Members
//-----------------------------------------------------
//
// Uninteresting (but required) overrides
//
//-----------------------------------------------------
#region Uninteresting (but required) overrides
protected override PackagePart CreatePartCore(Uri uri, string contentType, CompressionOption compressionOption)
{
return null;
}
protected override void DeletePartCore(Uri uri)
{
throw new NotSupportedException();
}
protected override PackagePart[] GetPartsCore()
{
throw new NotSupportedException();
}
protected override void FlushCore()
{
throw new NotSupportedException();
}
#endregion
}
}
// 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
- AspNetHostingPermission.cs
- Accessible.cs
- ReachPageContentCollectionSerializer.cs
- VirtualPathProvider.cs
- ArithmeticLiteral.cs
- HttpPostLocalhostServerProtocol.cs
- WeakReference.cs
- TextSpan.cs
- IriParsingElement.cs
- CheckBox.cs
- webeventbuffer.cs
- KeyToListMap.cs
- ConfigurationSectionGroup.cs
- MachineKeyConverter.cs
- Lease.cs
- RijndaelManaged.cs
- AliasExpr.cs
- RelatedImageListAttribute.cs
- DependencyObjectProvider.cs
- ResetableIterator.cs
- panel.cs
- RootBrowserWindowAutomationPeer.cs
- TcpSocketManager.cs
- XPathNavigatorKeyComparer.cs
- PreApplicationStartMethodAttribute.cs
- MenuItem.cs
- SqlProviderManifest.cs
- BrushMappingModeValidation.cs
- CommandValueSerializer.cs
- ExtractedStateEntry.cs
- securitycriticaldataClass.cs
- GAC.cs
- UnmanagedBitmapWrapper.cs
- MatrixConverter.cs
- SystemUdpStatistics.cs
- RectangleConverter.cs
- SolidColorBrush.cs
- SqlNode.cs
- SqlXmlStorage.cs
- BufferedWebEventProvider.cs
- UnsafeNativeMethods.cs
- BackgroundWorker.cs
- TabItemAutomationPeer.cs
- IndentedWriter.cs
- RSAPKCS1SignatureFormatter.cs
- HMACMD5.cs
- CodeSnippetTypeMember.cs
- ClientConfigPaths.cs
- StrokeIntersection.cs
- NominalTypeEliminator.cs
- ConsoleCancelEventArgs.cs
- baseshape.cs
- ChineseLunisolarCalendar.cs
- WeakReferenceKey.cs
- IIS7UserPrincipal.cs
- SelectionItemProviderWrapper.cs
- HtmlLink.cs
- ClientScriptManagerWrapper.cs
- MessageQueueInstaller.cs
- Operator.cs
- TextPattern.cs
- XPathSingletonIterator.cs
- InputScope.cs
- IdleTimeoutMonitor.cs
- BooleanProjectedSlot.cs
- NumberAction.cs
- WebPartConnectionsDisconnectVerb.cs
- ExpandCollapsePattern.cs
- DataGridRowClipboardEventArgs.cs
- BamlResourceContent.cs
- DbProviderConfigurationHandler.cs
- SmtpAuthenticationManager.cs
- DESCryptoServiceProvider.cs
- ProcessHost.cs
- EventLogEntry.cs
- WsdlBuildProvider.cs
- FileDialogPermission.cs
- WriteTimeStream.cs
- EmptyEnumerator.cs
- Boolean.cs
- HttpCookieCollection.cs
- AttachInfo.cs
- SyncOperationState.cs
- ProxyFragment.cs
- ApplicationSecurityInfo.cs
- AccessDataSourceDesigner.cs
- PhoneCallDesigner.cs
- FixedTextPointer.cs
- GridViewCommandEventArgs.cs
- SQLBinary.cs
- SingleQueryOperator.cs
- ResourceDefaultValueAttribute.cs
- VirtualPathProvider.cs
- BindingOperations.cs
- IIS7WorkerRequest.cs
- CompilationRelaxations.cs
- BehaviorService.cs
- AuthenticationModuleElementCollection.cs
- RelationshipDetailsRow.cs
- AlignmentXValidation.cs