2 using System.Runtime.InteropServices;
\r
5 namespace IBM.Data.DB2
\r
7 internal sealed class DB2ConnectionSettings
\r
9 private string connectionString;
\r
10 private string userName = "";
\r
11 private string passWord = "";
\r
12 private string databaseAlias = "";
\r
13 private string server = "";
\r
14 private bool pooling = true;
\r
15 private TimeSpan connectTimeout = new TimeSpan(0, 0, 15);
\r
16 private TimeSpan connectionLifeTime = new TimeSpan(0, 0, 15); // 15 seconds
\r
17 private int connectionPoolSizeMin = 0;
\r
18 private int connectionPoolSizeMax = -1; // no maximum
\r
20 private DB2ConnectionPool pool;
\r
22 private DB2ConnectionSettings(string connectionString)
\r
24 this.connectionString = connectionString;
\r
28 public static DB2ConnectionSettings GetConnectionSettings(string connectionString)
\r
30 DB2ConnectionPool pool = DB2ConnectionPool.FindConnectionPool(connectionString);
\r
33 return pool.ConnectionSettings;
\r
35 DB2ConnectionSettings settings = new DB2ConnectionSettings(connectionString);
\r
36 if(settings.Pooling)
\r
38 settings.pool = DB2ConnectionPool.GetConnectionPool(settings);
\r
43 public DB2OpenConnection GetRealOpenConnection(DB2Connection connection)
\r
47 return pool.GetOpenConnection(connection);
\r
51 return new DB2OpenConnection(this, connection);
\r
55 public DB2ConnectionPool Pool
\r
57 get { return pool; }
\r
60 public string ConnectionString
\r
62 get { return connectionString; }
\r
65 public string UserName
\r
67 get { return userName; }
\r
70 public string PassWord
\r
72 get { return passWord; }
\r
76 /// database alias (for cataloged database)
\r
78 public string DatabaseAlias
\r
80 get { return databaseAlias; }
\r
84 /// server name with optional port number for direct connection (<server name/ip address>[:<port>])
\r
86 public string Server
\r
88 get { return server; }
\r
91 public TimeSpan ConnectTimeout
\r
93 get { return connectTimeout; }
\r
97 /// Connection pooling yes/no
\r
101 get { return pooling; }
\r
104 public int ConnectionPoolSizeMin
\r
106 get { return connectionPoolSizeMin; }
\r
109 public int ConnectionPoolSizeMax
\r
111 get { return connectionPoolSizeMin; }
\r
114 public TimeSpan ConnectionLifeTime
\r
116 get { return connectionLifeTime; }
\r
121 /// parsed according to IBM DB2 .NET data provider help
\r
123 public void Parse()
\r
125 string[] parts = connectionString.Split(new char[]{';'});
\r
126 foreach(string part in parts)
\r
128 string[] pairs = part.Split(new char[]{'='});
\r
129 switch(pairs[0].ToLower())
\r
133 databaseAlias = pairs[1];
\r
137 userName = pairs[1];
\r
141 passWord = pairs[1];
\r
147 pooling = (pairs[1].ToLower() == "true") || (pairs[1]== "1");
\r
149 case "connect timeout":
\r
151 case "connection timeout":
\r
152 connectTimeout = new TimeSpan(0, 0, int.Parse(pairs[1]));
\r
154 case "min pool size":
\r
155 connectionPoolSizeMin = int.Parse(pairs[1]);
\r
157 case "max pool size":
\r
158 connectionPoolSizeMax = int.Parse(pairs[1]);
\r
160 case "connection lifetime":
\r
161 connectionLifeTime = new TimeSpan(0, 0, int.Parse(pairs[1]));
\r
165 if(connectionLifeTime.Ticks <= 0)
\r
171 public override int GetHashCode()
\r
173 return connectionString.GetHashCode ();
\r
176 public override bool Equals(object obj)
\r
178 return connectionString.Equals (obj);
\r