PartialTrustHelpers.cs 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. //------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //------------------------------------------------------------
  4. namespace System.Runtime
  5. {
  6. using System.Security;
  7. using System.Security.Permissions;
  8. using System.Runtime.CompilerServices;
  9. using System.Reflection;
  10. static class PartialTrustHelpers
  11. {
  12. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  13. [SecurityCritical]
  14. static Type aptca;
  15. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  16. [SecurityCritical]
  17. static volatile bool checkedForFullTrust;
  18. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  19. [SecurityCritical]
  20. static bool inFullTrust;
  21. internal static bool ShouldFlowSecurityContext
  22. {
  23. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  24. [SecurityCritical]
  25. get
  26. {
  27. return SecurityManager.CurrentThreadRequiresSecurityContextCapture();
  28. }
  29. }
  30. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  31. [SecurityCritical]
  32. internal static bool IsInFullTrust()
  33. {
  34. #if FEATURE_MONO_CAS
  35. if (!SecurityManager.CurrentThreadRequiresSecurityContextCapture())
  36. {
  37. return true;
  38. }
  39. try
  40. {
  41. DemandForFullTrust();
  42. return true;
  43. }
  44. catch (SecurityException)
  45. {
  46. return false;
  47. }
  48. #else
  49. return true;
  50. #endif
  51. }
  52. #if FEATURE_COMPRESSEDSTACK
  53. [Fx.Tag.SecurityNote(Critical = "Captures security context with identity flow suppressed, " +
  54. "this requires satisfying a LinkDemand for infrastructure.")]
  55. [SecurityCritical]
  56. internal static SecurityContext CaptureSecurityContextNoIdentityFlow()
  57. {
  58. // capture the security context but never flow windows identity
  59. if (SecurityContext.IsWindowsIdentityFlowSuppressed())
  60. {
  61. return SecurityContext.Capture();
  62. }
  63. else
  64. {
  65. using (SecurityContext.SuppressFlowWindowsIdentity())
  66. {
  67. return SecurityContext.Capture();
  68. }
  69. }
  70. }
  71. #endif
  72. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  73. [SecurityCritical]
  74. internal static bool IsTypeAptca(Type type)
  75. {
  76. Assembly assembly = type.Assembly;
  77. return IsAssemblyAptca(assembly) || !IsAssemblySigned(assembly);
  78. }
  79. [SecuritySafeCritical]
  80. [PermissionSet(SecurityAction.Demand, Unrestricted = true)]
  81. [MethodImpl(MethodImplOptions.NoInlining)]
  82. internal static void DemandForFullTrust()
  83. {
  84. }
  85. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  86. [SecurityCritical]
  87. static bool IsAssemblyAptca(Assembly assembly)
  88. {
  89. if (aptca == null)
  90. {
  91. aptca = typeof(AllowPartiallyTrustedCallersAttribute);
  92. }
  93. return assembly.GetCustomAttributes(aptca, false).Length > 0;
  94. }
  95. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  96. [SecurityCritical]
  97. [FileIOPermission(SecurityAction.Assert, Unrestricted = true)]
  98. static bool IsAssemblySigned(Assembly assembly)
  99. {
  100. byte[] publicKeyToken = assembly.GetName().GetPublicKeyToken();
  101. return publicKeyToken != null & publicKeyToken.Length > 0;
  102. }
  103. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  104. [SecurityCritical]
  105. internal static bool CheckAppDomainPermissions(PermissionSet permissions)
  106. {
  107. #if FEATURE_MONO_CAS
  108. return AppDomain.CurrentDomain.IsHomogenous &&
  109. permissions.IsSubsetOf(AppDomain.CurrentDomain.PermissionSet);
  110. #else
  111. return true;
  112. #endif
  113. }
  114. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision")]
  115. [SecurityCritical]
  116. internal static bool HasEtwPermissions()
  117. {
  118. #if FEATURE_MONO_CAS
  119. //Currently unrestricted permissions are required to create Etw provider.
  120. PermissionSet permissions = new PermissionSet(PermissionState.Unrestricted);
  121. return CheckAppDomainPermissions(permissions);
  122. #else
  123. return true;
  124. #endif
  125. }
  126. internal static bool AppDomainFullyTrusted
  127. {
  128. [Fx.Tag.SecurityNote(Critical = "used in a security-sensitive decision",
  129. Safe = "Does not leak critical resources")]
  130. [SecuritySafeCritical]
  131. get
  132. {
  133. #if FEATURE_MONO_CAS
  134. if (!checkedForFullTrust)
  135. {
  136. inFullTrust = AppDomain.CurrentDomain.IsFullyTrusted;
  137. checkedForFullTrust = true;
  138. }
  139. return inFullTrust;
  140. #else
  141. return true;
  142. #endif
  143. }
  144. }
  145. }
  146. }