TARGET_JVM: making public
[mono.git] / mcs / class / System.Data / System.Data.Common / DbDataPermissionAttribute.cs
index a331853beff3df1ddc1a3f6b711c59d751d201f9..f29c3d17eafe2176ce2c91b70888958ff8ea7f00 100644 (file)
@@ -2,27 +2,53 @@
 // System.Data.Common.DbDataPermissionAttribute.cs
 //
 // Authors:
-//   Rodrigo Moya (rodrigo@ximian.com)
-//   Tim Coleman (tim@timcoleman.com)
+//     Rodrigo Moya (rodrigo@ximian.com)
+//     Tim Coleman (tim@timcoleman.com)
+//     Sebastien Pouliot  <sebastien@ximian.com>
 //
 // (C) Ximian, Inc
 // Copyright (C) Tim Coleman, 2002
+// Copyright (C) 2004 Novell, Inc (http://www.novell.com)
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+// 
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+// 
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 //
 
-using System;
+using System.ComponentModel;
 using System.Security.Permissions;
+using System.Globalization;
 
 namespace System.Data.Common {
-       [AttributeUsage (AttributeTargets.Assembly | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method)]
+
+       [AttributeUsage (AttributeTargets.Assembly | AttributeTargets.Class | 
+                        AttributeTargets.Struct | AttributeTargets.Constructor | 
+                        AttributeTargets.Method, AllowMultiple=true, Inherited=false)]
        [Serializable]
-       public abstract class DBDataPermissionAttribute : CodeAccessSecurityAttribute
-       {
+       public abstract class DBDataPermissionAttribute : CodeAccessSecurityAttribute {
                #region Fields
 
-               SecurityAction securityAction;
                bool allowBlankPassword;
+               string keyRestrictions;
+#if NET_1_1
                KeyRestrictionBehavior keyRestrictionBehavior;
-               String  connectionString;
+               string connectionString;
+#endif
 
                #endregion // Fields
 
@@ -31,8 +57,6 @@ namespace System.Data.Common {
                protected DBDataPermissionAttribute (SecurityAction action) 
                        : base (action) 
                {
-                       securityAction = action;
-                       allowBlankPassword = false;
                }
 
                #endregion // Constructors
@@ -44,30 +68,57 @@ namespace System.Data.Common {
                        set { allowBlankPassword = value; }
                }
 
-               public String ConnectionString {
-                       get { return connectionString; }
+               public string KeyRestrictions {
+                       get {
+                               if (keyRestrictions == null)
+                                       return String.Empty;
+                               return keyRestrictions;
+                       }
+                       set { keyRestrictions = value; }
+               }
+
+#if NET_1_1
+               public string ConnectionString {
+                       get {
+                               if (connectionString == null)
+                                       return String.Empty;
+                               return connectionString;
+                       }
                        set { connectionString = value; }
                }
 
                public KeyRestrictionBehavior KeyRestrictionBehavior {
                        get { return keyRestrictionBehavior; }
-                       set { keyRestrictionBehavior = value; }
+                       set {
+                               if (!Enum.IsDefined (typeof (KeyRestrictionBehavior), value)) {
+                                       string msg = Locale.GetText ("Unknown value.");
+#if NET_2_0
+                                       throw new ArgumentOutOfRangeException ("KeyRestrictionBehavior", value, msg);
+#else
+                                       throw new ArgumentException ("KeyRestrictionBehavior", msg);
+#endif
+                               }
+                               keyRestrictionBehavior = value;
+                       }
                }
-               
+#endif
+
                #endregion // Properties
 
                #region // Methods
-#if NET_1_2
-               [MonoTODO]
+#if NET_2_0
+               [MonoTODO ("configurable ? why is this in the attribute class ?")]
+               [EditorBrowsableAttribute (EditorBrowsableState.Never)]
                public bool ShouldSerializeConnectionString ()
                {
-                       throw new NotImplementedException ();
+                       return false;
                }
 
-               [MonoTODO]
+               [MonoTODO ("configurable ? why is this in the attribute class ?")]
+               [EditorBrowsableAttribute (EditorBrowsableState.Never)]
                public bool ShouldSerializeKeyRestrictions ()
                {
-                       throw new NotImplementedException ();
+                       return false;
                }
 #endif
                #endregion // Methods