// // System.Data.OleDb.OleDbConnection // // Authors: // Rodrigo Moya (rodrigo@ximian.com) // Tim Coleman (tim@timcoleman.com) // // Copyright (C) Rodrigo Moya, 2002 // 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.ComponentModel; using System.Data; using System.Data.Common; using System.EnterpriseServices; using System.Transactions; namespace System.Data.OleDb { [DefaultEvent ("InfoMessage")] public sealed class OleDbConnection : DbConnection, ICloneable { #region Fields string connectionString; int connectionTimeout; IntPtr gdaConnection; #endregion #region Constructors public OleDbConnection () { gdaConnection = IntPtr.Zero; connectionTimeout = 15; } public OleDbConnection (string connectionString) : this () { this.connectionString = connectionString; } #endregion // Constructors #region Properties [DataCategory ("Data")] [DefaultValue ("")] [EditorAttribute ("Microsoft.VSDesigner.Data.ADO.Design.OleDbConnectionStringEditor, "+ Consts.AssemblyMicrosoft_VSDesigner, "System.Drawing.Design.UITypeEditor, "+ Consts.AssemblySystem_Drawing )] [RecommendedAsConfigurable (true)] [RefreshPropertiesAttribute (RefreshProperties.All)] public override string ConnectionString { get { if (connectionString == null) return string.Empty; return connectionString; } set { connectionString = value; } } [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)] public override int ConnectionTimeout { get { return connectionTimeout; } } [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)] public override string Database { get { if (gdaConnection != IntPtr.Zero && libgda.gda_connection_is_open (gdaConnection)) { return libgda.gda_connection_get_database (gdaConnection); } return string.Empty; } } [BrowsableAttribute (true)] public override string DataSource { get { if (gdaConnection != IntPtr.Zero && libgda.gda_connection_is_open (gdaConnection)) { return libgda.gda_connection_get_dsn (gdaConnection); } return string.Empty; } } [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)] [BrowsableAttribute (true)] public string Provider { get { if (gdaConnection != IntPtr.Zero && libgda.gda_connection_is_open (gdaConnection)) { return libgda.gda_connection_get_provider (gdaConnection); } return string.Empty; } } public override string ServerVersion { get { if (State == ConnectionState.Closed) throw ExceptionHelper.ConnectionClosed (); return libgda.gda_connection_get_server_version (gdaConnection); } } [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)] [BrowsableAttribute (false)] public override ConnectionState State { get { if (gdaConnection != IntPtr.Zero) { if (libgda.gda_connection_is_open (gdaConnection)) return ConnectionState.Open; } return ConnectionState.Closed; } } internal IntPtr GdaConnection { get { return gdaConnection; } } #endregion // Properties #region Methods public new OleDbTransaction BeginTransaction () { if (State == ConnectionState.Closed) throw ExceptionHelper.ConnectionClosed (); return new OleDbTransaction (this); } public new OleDbTransaction BeginTransaction (IsolationLevel isolationLevel) { if (State == ConnectionState.Closed) throw ExceptionHelper.ConnectionClosed (); return new OleDbTransaction (this, isolationLevel); } protected override DbTransaction BeginDbTransaction(IsolationLevel isolationLevel) { return BeginTransaction (isolationLevel); } protected override DbCommand CreateDbCommand() { return CreateCommand (); } public override void ChangeDatabase (string value) { if (State != ConnectionState.Open) throw new InvalidOperationException (); if (!libgda.gda_connection_change_database (gdaConnection, value)) throw new OleDbException (this); } public override void Close () { if (State == ConnectionState.Open) { libgda.gda_connection_close (gdaConnection); gdaConnection = IntPtr.Zero; } } public new OleDbCommand CreateCommand () { if (State == ConnectionState.Open) return new OleDbCommand (null, this); return null; } [MonoTODO] protected override void Dispose (bool disposing) { throw new NotImplementedException (); } [MonoTODO] public DataTable GetOleDbSchemaTable (Guid schema, object[] restrictions) { throw new NotImplementedException (); } [MonoTODO] object ICloneable.Clone () { throw new NotImplementedException(); } public override void Open () { // string provider = "Default"; // string gdaCncStr = string.Empty; // string[] args; // int len; // char [] separator = { ';' }; if (State == ConnectionState.Open) throw new InvalidOperationException (); libgda.gda_init ("System.Data.OleDb", "1.0", 0, new string [0]); gdaConnection = libgda.gda_client_open_connection (libgda.GdaClient, ConnectionString, string.Empty, string.Empty, 0); if (gdaConnection == IntPtr.Zero) throw new OleDbException (this); /* convert the connection string to its GDA equivalent */ //args = connectionString.Split (';'); //len = args.Length; //for (int i = 0; i < len; i++) { // string[] values = args[i].Split (separator, 2); // if (values[0] == "Provider") { // if (values[1] == "SQLOLEDB") // provider = "FreeTDS"; // else if (values[1] == "MSDAORA") // provider = "Oracle"; // else if (values[2] == "Microsoft.Jet.OLEDB.4.0") // provider = "MS Access"; // else // provider = values[2]; // } // else if (values[0] == "Addr" || values[0] == "Address") // gdaCncStr = String.Concat (gdaCncStr, "HOST=", values[1], ";"); // else if (values[0] == "Database") // gdaCncStr = String.Concat (gdaCncStr, "DATABASE=", values[1], ";"); // else if (values[0] == "Connection Lifetime") // connectionTimeout = System.Convert.ToInt32 (values[1]); // else if (values[0] == "File Name") // gdaCncStr = String.Concat (gdaCncStr, "FILENAME=", values[1], ";"); // else if (values[0] == "Password" || values[0] == "Pwd") // gdaCncStr = String.Concat (gdaCncStr, "PASSWORD=", values[1], ";"); // else if (values[0] == "User ID") // gdaCncStr = String.Concat (gdaCncStr, "USERNAME=", values[1], ";"); //} /* open the connection */ //System.Console.WriteLine ("Opening connection for provider " + // provider + " with " + gdaCncStr); //gdaConnection = libgda.gda_client_open_connection_from_string (libgda.GdaClient, // provider, // gdaCncStr); } [MonoTODO] public static void ReleaseObjectPool () { throw new NotImplementedException (); } [MonoTODO] public void EnlistDistributedTransaction (ITransaction transaction) { throw new NotImplementedException (); } [MonoTODO] public override void EnlistTransaction (Transaction transaction) { throw new NotImplementedException (); } [MonoTODO] public override DataTable GetSchema () { if (State == ConnectionState.Closed) throw ExceptionHelper.ConnectionClosed (); throw new NotImplementedException (); } [MonoTODO] public override DataTable GetSchema(string collectionName) { return GetSchema (collectionName, null); } [MonoTODO] public override DataTable GetSchema (String collectionName, string [] restrictionValues) { if (State == ConnectionState.Closed) throw ExceptionHelper.ConnectionClosed (); throw new NotImplementedException (); } [MonoTODO] [EditorBrowsable (EditorBrowsableState.Advanced)] public void ResetState () { throw new NotImplementedException (); } #endregion #region Events and Delegates [DataCategory ("DataCategory_InfoMessage")] public event OleDbInfoMessageEventHandler InfoMessage; #endregion } }