Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Deployment / CmsUtils.cs / 1305376 / CmsUtils.cs
using Microsoft.Win32; using System; using System.Deployment.Internal; using System.Deployment.Internal.Isolation; using System.Deployment.Internal.Isolation.Manifest; using System.IO; using System.Globalization; using System.Runtime.Hosting; using System.Runtime.InteropServices; using System.Security.Permissions; using System.Security.Policy; using System.Text; using System.Runtime.Versioning; using System.Diagnostics.Contracts; namespace System.Deployment.Internal.Isolation.Manifest { [System.Security.SecuritySafeCritical] // auto-generated [SecurityPermissionAttribute(SecurityAction.Assert, Flags = SecurityPermissionFlag.UnmanagedCode)] internal static class CmsUtils { internal static void GetEntryPoint (ActivationContext activationContext, out string fileName, out string parameters) { parameters = null; fileName = null; ICMS appManifest = activationContext.ApplicationComponentManifest; if (appManifest == null || appManifest.EntryPointSection == null) throw new ArgumentException(Environment.GetResourceString("Argument_NoMain")); IEnumUnknown refEnum = (IEnumUnknown) appManifest.EntryPointSection._NewEnum; uint count = 0; Object[] entries = new Object[1]; // Look for the first entry point. ClickOnce semantic validation ensures exactly one entry point is present. if (refEnum.Next(1, entries, ref count) == 0 && count == 1) { IEntryPointEntry iref= (IEntryPointEntry) entries[0]; EntryPointEntry reference = iref.AllData; if (reference.CommandLine_File != null && reference.CommandLine_File.Length > 0) { fileName = reference.CommandLine_File; } else { // Locate the dependent assembly that is being refered to. Well-formed manifests should have an identity. IAssemblyReferenceEntry refEntry = null; object assemblyObj = null; if (reference.Identity != null) { ((ISectionWithReferenceIdentityKey)appManifest.AssemblyReferenceSection).Lookup(reference.Identity, out assemblyObj); refEntry = (IAssemblyReferenceEntry) assemblyObj; fileName = refEntry.DependentAssembly.Codebase; } } parameters = reference.CommandLine_Parameters; } } internal static IAssemblyReferenceEntry[] GetDependentAssemblies(ActivationContext activationContext) { IAssemblyReferenceEntry[] entries = null; ICMS appManifest = activationContext.ApplicationComponentManifest; if (appManifest == null) return null; ISection dependencySection = appManifest.AssemblyReferenceSection; uint count = (dependencySection != null) ? dependencySection.Count : 0; if (count > 0) { uint fetched = 0; entries = new IAssemblyReferenceEntry[count]; IEnumUnknown dependencyEnum = (IEnumUnknown)dependencySection._NewEnum; int hr = dependencyEnum.Next(count, entries, ref fetched); if (fetched != count || hr < 0) return null; // } return entries; } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static string GetEntryPointFullPath (ActivationArguments activationArguments) { return GetEntryPointFullPath(activationArguments.ActivationContext); } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static string GetEntryPointFullPath (ActivationContext activationContext) { string file, parameters; GetEntryPoint(activationContext, out file, out parameters); if (!String.IsNullOrEmpty(file)) { string directoryName = activationContext.ApplicationDirectory; if (directoryName == null || directoryName.Length == 0) { // If we were passed a relative path, assume the app base is the current working directory StringBuilder sb = new StringBuilder(Path.MAX_PATH + 1); if (Win32Native.GetCurrentDirectory(sb.Capacity, sb) == 0) System.IO.__Error.WinIOError(); directoryName = sb.ToString(); } file = Path.Combine(directoryName, file); } return file; } internal static bool CompareIdentities (ActivationContext activationContext1, ActivationContext activationContext2) { if (activationContext1 == null || activationContext2 == null) return activationContext1 == activationContext2; return IsolationInterop.AppIdAuthority.AreDefinitionsEqual(0, activationContext1.Identity.Identity, activationContext2.Identity.Identity); } internal static bool CompareIdentities (ApplicationIdentity applicationIdentity1, ApplicationIdentity applicationIdentity2, ApplicationVersionMatch versionMatch) { if (applicationIdentity1 == null || applicationIdentity2 == null) return applicationIdentity1 == applicationIdentity2; uint flags; switch (versionMatch) { case ApplicationVersionMatch.MatchExactVersion: flags = 0; break; case ApplicationVersionMatch.MatchAllVersions: flags = (uint) IAPPIDAUTHORITY_ARE_DEFINITIONS_EQUAL_FLAGS.IAPPIDAUTHORITY_ARE_DEFINITIONS_EQUAL_FLAG_IGNORE_VERSION; break; default: throw new ArgumentException(Environment.GetResourceString("Arg_EnumIllegalVal", (int)versionMatch), "versionMatch"); } return IsolationInterop.AppIdAuthority.AreDefinitionsEqual(flags, applicationIdentity1.Identity, applicationIdentity2.Identity); } internal static string GetFriendlyName (ActivationContext activationContext) { ICMS deplManifest = activationContext.DeploymentComponentManifest; IMetadataSectionEntry metadataSectionEntry = (IMetadataSectionEntry) deplManifest.MetadataSectionEntry; IDescriptionMetadataEntry descriptionMetadataEntry = metadataSectionEntry.DescriptionData; string friendlyName = String.Empty; if (descriptionMetadataEntry != null) { DescriptionMetadataEntry entry = descriptionMetadataEntry.AllData; friendlyName = (entry.Publisher != null ? String.Format("{0} {1}", entry.Publisher, entry.Product) : entry.Product); } return friendlyName; } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static void CreateActivationContext (string fullName, string[] manifestPaths, bool useFusionActivationContext, out ApplicationIdentity applicationIdentity, out ActivationContext activationContext) { applicationIdentity = new ApplicationIdentity(fullName); activationContext = null; if (useFusionActivationContext) { if (manifestPaths != null) activationContext = new ActivationContext(applicationIdentity, manifestPaths); else activationContext = new ActivationContext(applicationIdentity); } } // // Helper method to create an application evidence used in app model activation. // There are basically 2 cases where this method is called: // a) It is called in CreateInstanceHelper. In this case, it gathers // the application evidence passed to the CreateDomainHelper call. // b) It is also called in the server domain. In that case, the domain could // be either the default domain (in which case the input evidence is null) // or a domain created via CreateDomainHelper in which case the application // evidence already contains the application identity and possibly the activation // context. // internal static Evidence MergeApplicationEvidence (Evidence evidence, ApplicationIdentity applicationIdentity, ActivationContext activationContext, string[] activationData) { return MergeApplicationEvidence(evidence, applicationIdentity, activationContext, activationData, null); } internal static Evidence MergeApplicationEvidence(Evidence evidence, ApplicationIdentity applicationIdentity, ActivationContext activationContext, string[] activationData, ApplicationTrust applicationTrust) { Evidence appEvidence = new Evidence(); ActivationArguments activationArgs = (activationContext == null ? new ActivationArguments(applicationIdentity, activationData) : new ActivationArguments(activationContext, activationData)); appEvidence = new Evidence(); appEvidence.AddHostEvidence(activationArgs); if (applicationTrust != null) appEvidence.AddHostEvidence(applicationTrust); if (activationContext != null) { Evidence asiEvidence = new ApplicationSecurityInfo(activationContext).ApplicationEvidence; if (asiEvidence != null) appEvidence.MergeWithNoDuplicates(asiEvidence); } if (evidence != null) appEvidence.MergeWithNoDuplicates(evidence); return appEvidence; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using Microsoft.Win32; using System; using System.Deployment.Internal; using System.Deployment.Internal.Isolation; using System.Deployment.Internal.Isolation.Manifest; using System.IO; using System.Globalization; using System.Runtime.Hosting; using System.Runtime.InteropServices; using System.Security.Permissions; using System.Security.Policy; using System.Text; using System.Runtime.Versioning; using System.Diagnostics.Contracts; namespace System.Deployment.Internal.Isolation.Manifest { [System.Security.SecuritySafeCritical] // auto-generated [SecurityPermissionAttribute(SecurityAction.Assert, Flags = SecurityPermissionFlag.UnmanagedCode)] internal static class CmsUtils { internal static void GetEntryPoint (ActivationContext activationContext, out string fileName, out string parameters) { parameters = null; fileName = null; ICMS appManifest = activationContext.ApplicationComponentManifest; if (appManifest == null || appManifest.EntryPointSection == null) throw new ArgumentException(Environment.GetResourceString("Argument_NoMain")); IEnumUnknown refEnum = (IEnumUnknown) appManifest.EntryPointSection._NewEnum; uint count = 0; Object[] entries = new Object[1]; // Look for the first entry point. ClickOnce semantic validation ensures exactly one entry point is present. if (refEnum.Next(1, entries, ref count) == 0 && count == 1) { IEntryPointEntry iref= (IEntryPointEntry) entries[0]; EntryPointEntry reference = iref.AllData; if (reference.CommandLine_File != null && reference.CommandLine_File.Length > 0) { fileName = reference.CommandLine_File; } else { // Locate the dependent assembly that is being refered to. Well-formed manifests should have an identity. IAssemblyReferenceEntry refEntry = null; object assemblyObj = null; if (reference.Identity != null) { ((ISectionWithReferenceIdentityKey)appManifest.AssemblyReferenceSection).Lookup(reference.Identity, out assemblyObj); refEntry = (IAssemblyReferenceEntry) assemblyObj; fileName = refEntry.DependentAssembly.Codebase; } } parameters = reference.CommandLine_Parameters; } } internal static IAssemblyReferenceEntry[] GetDependentAssemblies(ActivationContext activationContext) { IAssemblyReferenceEntry[] entries = null; ICMS appManifest = activationContext.ApplicationComponentManifest; if (appManifest == null) return null; ISection dependencySection = appManifest.AssemblyReferenceSection; uint count = (dependencySection != null) ? dependencySection.Count : 0; if (count > 0) { uint fetched = 0; entries = new IAssemblyReferenceEntry[count]; IEnumUnknown dependencyEnum = (IEnumUnknown)dependencySection._NewEnum; int hr = dependencyEnum.Next(count, entries, ref fetched); if (fetched != count || hr < 0) return null; // } return entries; } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static string GetEntryPointFullPath (ActivationArguments activationArguments) { return GetEntryPointFullPath(activationArguments.ActivationContext); } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static string GetEntryPointFullPath (ActivationContext activationContext) { string file, parameters; GetEntryPoint(activationContext, out file, out parameters); if (!String.IsNullOrEmpty(file)) { string directoryName = activationContext.ApplicationDirectory; if (directoryName == null || directoryName.Length == 0) { // If we were passed a relative path, assume the app base is the current working directory StringBuilder sb = new StringBuilder(Path.MAX_PATH + 1); if (Win32Native.GetCurrentDirectory(sb.Capacity, sb) == 0) System.IO.__Error.WinIOError(); directoryName = sb.ToString(); } file = Path.Combine(directoryName, file); } return file; } internal static bool CompareIdentities (ActivationContext activationContext1, ActivationContext activationContext2) { if (activationContext1 == null || activationContext2 == null) return activationContext1 == activationContext2; return IsolationInterop.AppIdAuthority.AreDefinitionsEqual(0, activationContext1.Identity.Identity, activationContext2.Identity.Identity); } internal static bool CompareIdentities (ApplicationIdentity applicationIdentity1, ApplicationIdentity applicationIdentity2, ApplicationVersionMatch versionMatch) { if (applicationIdentity1 == null || applicationIdentity2 == null) return applicationIdentity1 == applicationIdentity2; uint flags; switch (versionMatch) { case ApplicationVersionMatch.MatchExactVersion: flags = 0; break; case ApplicationVersionMatch.MatchAllVersions: flags = (uint) IAPPIDAUTHORITY_ARE_DEFINITIONS_EQUAL_FLAGS.IAPPIDAUTHORITY_ARE_DEFINITIONS_EQUAL_FLAG_IGNORE_VERSION; break; default: throw new ArgumentException(Environment.GetResourceString("Arg_EnumIllegalVal", (int)versionMatch), "versionMatch"); } return IsolationInterop.AppIdAuthority.AreDefinitionsEqual(flags, applicationIdentity1.Identity, applicationIdentity2.Identity); } internal static string GetFriendlyName (ActivationContext activationContext) { ICMS deplManifest = activationContext.DeploymentComponentManifest; IMetadataSectionEntry metadataSectionEntry = (IMetadataSectionEntry) deplManifest.MetadataSectionEntry; IDescriptionMetadataEntry descriptionMetadataEntry = metadataSectionEntry.DescriptionData; string friendlyName = String.Empty; if (descriptionMetadataEntry != null) { DescriptionMetadataEntry entry = descriptionMetadataEntry.AllData; friendlyName = (entry.Publisher != null ? String.Format("{0} {1}", entry.Publisher, entry.Product) : entry.Product); } return friendlyName; } [ResourceExposure(ResourceScope.Machine)] [ResourceConsumption(ResourceScope.Machine)] internal static void CreateActivationContext (string fullName, string[] manifestPaths, bool useFusionActivationContext, out ApplicationIdentity applicationIdentity, out ActivationContext activationContext) { applicationIdentity = new ApplicationIdentity(fullName); activationContext = null; if (useFusionActivationContext) { if (manifestPaths != null) activationContext = new ActivationContext(applicationIdentity, manifestPaths); else activationContext = new ActivationContext(applicationIdentity); } } // // Helper method to create an application evidence used in app model activation. // There are basically 2 cases where this method is called: // a) It is called in CreateInstanceHelper. In this case, it gathers // the application evidence passed to the CreateDomainHelper call. // b) It is also called in the server domain. In that case, the domain could // be either the default domain (in which case the input evidence is null) // or a domain created via CreateDomainHelper in which case the application // evidence already contains the application identity and possibly the activation // context. // internal static Evidence MergeApplicationEvidence (Evidence evidence, ApplicationIdentity applicationIdentity, ActivationContext activationContext, string[] activationData) { return MergeApplicationEvidence(evidence, applicationIdentity, activationContext, activationData, null); } internal static Evidence MergeApplicationEvidence(Evidence evidence, ApplicationIdentity applicationIdentity, ActivationContext activationContext, string[] activationData, ApplicationTrust applicationTrust) { Evidence appEvidence = new Evidence(); ActivationArguments activationArgs = (activationContext == null ? new ActivationArguments(applicationIdentity, activationData) : new ActivationArguments(activationContext, activationData)); appEvidence = new Evidence(); appEvidence.AddHostEvidence(activationArgs); if (applicationTrust != null) appEvidence.AddHostEvidence(applicationTrust); if (activationContext != null) { Evidence asiEvidence = new ApplicationSecurityInfo(activationContext).ApplicationEvidence; if (asiEvidence != null) appEvidence.MergeWithNoDuplicates(asiEvidence); } if (evidence != null) appEvidence.MergeWithNoDuplicates(evidence); return appEvidence; } } } // 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
- CompositeCollection.cs
- ActiveXSite.cs
- BuildResultCache.cs
- CookieProtection.cs
- SafeNativeMethodsMilCoreApi.cs
- MapPathBasedVirtualPathProvider.cs
- XmlDocumentFragment.cs
- FixedSOMImage.cs
- XmlNamespaceMapping.cs
- PathGradientBrush.cs
- EmbeddedMailObject.cs
- ProviderException.cs
- TableLayoutPanel.cs
- TemplateBindingExpressionConverter.cs
- Cursors.cs
- CultureMapper.cs
- TransformerInfoCollection.cs
- SHA384Managed.cs
- DuplicateDetector.cs
- DashStyles.cs
- Oci.cs
- ObjectListTitleAttribute.cs
- BoolExpr.cs
- SystemWebSectionGroup.cs
- ChannelTracker.cs
- TextPenaltyModule.cs
- MemberMaps.cs
- CorruptingExceptionCommon.cs
- Form.cs
- ElapsedEventArgs.cs
- GraphicsPath.cs
- DecimalConstantAttribute.cs
- Propagator.JoinPropagator.SubstitutingCloneVisitor.cs
- SharedStream.cs
- CalendarBlackoutDatesCollection.cs
- StylusPointPropertyInfo.cs
- QfeChecker.cs
- SiteMap.cs
- AuthStoreRoleProvider.cs
- CrossAppDomainChannel.cs
- _BaseOverlappedAsyncResult.cs
- ScriptDescriptor.cs
- TypedAsyncResult.cs
- WorkflowQueue.cs
- DataGridViewControlCollection.cs
- BitmapCache.cs
- AttachedPropertyInfo.cs
- Page.cs
- DirectoryInfo.cs
- RegexTree.cs
- Matrix.cs
- IteratorFilter.cs
- CancellableEnumerable.cs
- ThreadStateException.cs
- CellConstantDomain.cs
- QueryTaskGroupState.cs
- WorkflowPersistenceContext.cs
- GlyphRunDrawing.cs
- SchemaElementDecl.cs
- UIPermission.cs
- RequestCachePolicy.cs
- FormViewDeletedEventArgs.cs
- AspNetHostingPermission.cs
- PersonalizationAdministration.cs
- PreparingEnlistment.cs
- IsolatedStorageException.cs
- VirtualDirectoryMappingCollection.cs
- BitFlagsGenerator.cs
- ActionMismatchAddressingException.cs
- IsolatedStorageFilePermission.cs
- ResXFileRef.cs
- TagMapCollection.cs
- TypeConverter.cs
- InputReferenceExpression.cs
- RegexWorker.cs
- GB18030Encoding.cs
- ClientFormsIdentity.cs
- CompilationPass2Task.cs
- Color.cs
- TimelineCollection.cs
- webeventbuffer.cs
- Int16AnimationUsingKeyFrames.cs
- CustomUserNameSecurityTokenAuthenticator.cs
- SystemColors.cs
- CharConverter.cs
- AspNetSynchronizationContext.cs
- PerformanceCounterPermission.cs
- TargetParameterCountException.cs
- OutputCacheSettings.cs
- ChtmlPageAdapter.cs
- CompositeScriptReferenceEventArgs.cs
- CommentAction.cs
- ExternalDataExchangeService.cs
- MimeTypePropertyAttribute.cs
- JsonXmlDataContract.cs
- CompilerHelpers.cs
- DomNameTable.cs
- DataGridViewTopLeftHeaderCell.cs
- WebPartConnectionCollection.cs
- RtfToken.cs