2 // System.Security.SecurityException.cs
5 // Nick Drochak(ndrochak@gol.com)
6 // Sebastien Pouliot <sebastien@ximian.com>
9 // (C) 2004 Motus Technologies Inc. (http://www.motus.com)
10 // Copyright (C) 2004-2005 Novell, Inc (http://www.novell.com)
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
32 using System.Globalization;
33 using System.Reflection;
34 using System.Runtime.InteropServices;
35 using System.Runtime.Serialization;
36 using System.Security.Permissions;
37 using System.Security.Policy;
40 namespace System.Security {
44 public class SecurityException : SystemException {
46 string permissionState;
48 private string _granted;
49 private string _refused;
50 private object _demanded;
51 private IPermission _firstperm;
52 // private IPermission _permfailed;
53 private MethodInfo _method;
54 private Evidence _evidence;
56 private SecurityAction _action;
57 private object _denyset;
58 private object _permitset;
59 private AssemblyName _assembly;
61 private SecurityZone _zone;
66 public SecurityAction Action {
67 get { return _action; }
68 set { _action = value; }
72 public object DenySetInstance {
73 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
74 get { return _denyset; }
75 set { _denyset = value; }
79 public AssemblyName FailedAssemblyInfo {
80 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
81 get { return _assembly; }
82 set { _assembly = value; }
86 public MethodInfo Method {
87 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
88 get { return _method; }
89 set { _method = value; }
93 public object PermitOnlySetInstance {
94 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
95 get { return _permitset; }
96 set { _permitset = value; }
100 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
102 set { _url = value; }
105 public SecurityZone Zone {
106 get { return _zone; }
107 set { _zone = value; }
111 public object Demanded {
112 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
113 get { return _demanded; }
114 set { _demanded = value; }
117 public IPermission FirstPermissionThatFailed {
118 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
119 get { return _firstperm; }
120 set { _firstperm = value; }
123 public string PermissionState {
124 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
125 get { return permissionState; }
126 set { permissionState = value; }
129 public Type PermissionType {
130 get { return permissionType; }
131 set { permissionType = value; }
134 public string GrantedSet {
135 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
136 get { return _granted; }
137 set { _granted = value; }
140 public string RefusedSet {
141 [SecurityPermission (SecurityAction.Demand, ControlEvidence=true, ControlPolicy=true)]
142 get { return _refused; }
143 set { _refused = value; }
148 public SecurityException ()
149 : base (Locale.GetText ("A security error has been detected."))
151 base.HResult = unchecked ((int)0x8013150A);
154 public SecurityException (string message)
157 base.HResult = unchecked ((int)0x8013150A);
160 protected SecurityException (SerializationInfo info, StreamingContext context)
161 : base (info, context)
163 base.HResult = unchecked ((int)0x8013150A);
164 // depending on the security policy the info about PermissionState may
165 // not be available (but the serializable must work)
166 SerializationInfoEnumerator e = info.GetEnumerator ();
167 while (e.MoveNext ()) {
168 if (e.Name == "PermissionState") {
169 permissionState = (string) e.Value;
175 public SecurityException (string message, Exception inner)
176 : base (message, inner)
178 base.HResult = unchecked ((int)0x8013150A);
181 public SecurityException (string message, Type type)
184 base.HResult = unchecked ((int)0x8013150A);
185 permissionType = type;
188 public SecurityException (string message, Type type, string state)
191 base.HResult = unchecked ((int)0x8013150A);
192 permissionType = type;
193 permissionState = state;
196 internal SecurityException (string message, PermissionSet granted, PermissionSet refused)
199 base.HResult = unchecked ((int)0x8013150A);
200 _granted = granted.ToString ();
201 _refused = refused.ToString ();
204 public SecurityException (string message, object deny, object permitOnly, MethodInfo method,
205 object demanded, IPermission permThatFailed)
208 base.HResult = unchecked ((int)0x8013150A);
210 _permitset = permitOnly;
212 _demanded = demanded;
213 _firstperm = permThatFailed;
216 public SecurityException (string message, AssemblyName assemblyName, PermissionSet grant,
217 PermissionSet refused, MethodInfo method, SecurityAction action, object demanded,
218 IPermission permThatFailed, Evidence evidence)
221 base.HResult = unchecked ((int)0x8013150A);
222 _assembly = assemblyName;
223 _granted = (grant == null) ? String.Empty : grant.ToString ();
224 _refused = (refused == null) ? String.Empty : refused.ToString ();
227 _demanded = demanded;
228 _firstperm = permThatFailed;
229 if (_firstperm != null)
230 permissionType = _firstperm.GetType ();
231 _evidence = evidence;
235 public override void GetObjectData (SerializationInfo info, StreamingContext context)
237 base.GetObjectData (info, context);
239 info.AddValue ("PermissionState", PermissionState);
241 catch (SecurityException) {
242 // serialize only if permitted to do so
246 public override string ToString ()
248 StringBuilder sb = new StringBuilder (base.ToString ());
250 if (permissionType != null) {
251 sb.AppendFormat ("{0}Type: {1}", Environment.NewLine, PermissionType);
253 if (_method != null) {
254 // method string representation doesn't include the type
255 string m = _method.ToString ();
256 int ret = m.IndexOf (" ") + 1;
257 sb.AppendFormat ("{0}Method: {1} {2}.{3}", Environment.NewLine,
258 _method.ReturnType.Name, _method.ReflectedType, m.Substring (ret));
260 if (permissionState != null) {
261 sb.AppendFormat ("{0}State: {1}", Environment.NewLine, PermissionState);
263 if ((_granted != null) && (_granted.Length > 0)) {
264 sb.AppendFormat ("{0}Granted: {1}", Environment.NewLine, GrantedSet);
266 if ((_refused != null) && (_refused.Length > 0)) {
267 sb.AppendFormat ("{0}Refused: {1}", Environment.NewLine, RefusedSet);
269 if (_demanded != null) {
270 sb.AppendFormat ("{0}Demanded: {1}", Environment.NewLine, Demanded);
272 if (_firstperm != null) {
273 sb.AppendFormat ("{0}Failed Permission: {1}", Environment.NewLine, FirstPermissionThatFailed);
275 if (_evidence != null) {
276 sb.AppendFormat ("{0}Evidences:", Environment.NewLine);
277 foreach (object o in _evidence) {
278 // Hash evidence is way much too verbose to be useful to anyone
280 sb.AppendFormat ("{0}\t{1}", Environment.NewLine, o);
284 catch (SecurityException) {
285 // some informations can't be displayed
287 return sb.ToString ();