aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Data/MSSQL/MSSQLUserData.cs
diff options
context:
space:
mode:
authorCharles Krinke2009-05-17 18:18:48 +0000
committerCharles Krinke2009-05-17 18:18:48 +0000
commit7a8a481f8801d9840a9ec05dd18adb2a1ccaebf7 (patch)
tree2b8d4a2dac75de73ef32e9ea8631a939d3090233 /OpenSim/Data/MSSQL/MSSQLUserData.cs
parentThank you kindly, Jonc, for a patch that solves (diff)
downloadopensim-SC-7a8a481f8801d9840a9ec05dd18adb2a1ccaebf7.zip
opensim-SC-7a8a481f8801d9840a9ec05dd18adb2a1ccaebf7.tar.gz
opensim-SC-7a8a481f8801d9840a9ec05dd18adb2a1ccaebf7.tar.bz2
opensim-SC-7a8a481f8801d9840a9ec05dd18adb2a1ccaebf7.tar.xz
Thank you kindly, StrawberryFride, for a patch that:
Adds maturity & access logic for MSSQL platform to mirror that of MySQL as committed in 9502.
Diffstat (limited to '')
-rw-r--r--OpenSim/Data/MSSQL/MSSQLUserData.cs261
1 files changed, 136 insertions, 125 deletions
diff --git a/OpenSim/Data/MSSQL/MSSQLUserData.cs b/OpenSim/Data/MSSQL/MSSQLUserData.cs
index 379b8bf..1bff28d 100644
--- a/OpenSim/Data/MSSQL/MSSQLUserData.cs
+++ b/OpenSim/Data/MSSQL/MSSQLUserData.cs
@@ -69,7 +69,6 @@ namespace OpenSim.Data.MSSQL
69 /// <remarks>use mssql_connection.ini</remarks> 69 /// <remarks>use mssql_connection.ini</remarks>
70 override public void Initialise(string connect) 70 override public void Initialise(string connect)
71 { 71 {
72
73 if (!string.IsNullOrEmpty(connect)) 72 if (!string.IsNullOrEmpty(connect))
74 { 73 {
75 database = new MSSQLManager(connect); 74 database = new MSSQLManager(connect);
@@ -106,11 +105,12 @@ namespace OpenSim.Data.MSSQL
106 /// <returns>A user profile</returns> 105 /// <returns>A user profile</returns>
107 override public UserProfileData GetUserByName(string user, string last) 106 override public UserProfileData GetUserByName(string user, string last)
108 { 107 {
109 using (AutoClosingSqlCommand command = database.Query("SELECT * FROM " + m_usersTableName + " WHERE username = @first AND lastname = @second")) 108 string sql = string.Format(@"SELECT * FROM {0}
109 WHERE username = @first AND lastname = @second", m_usersTableName);
110 using (AutoClosingSqlCommand command = database.Query(sql))
110 { 111 {
111 command.Parameters.Add(database.CreateParameter("first", user)); 112 command.Parameters.Add(database.CreateParameter("first", user));
112 command.Parameters.Add(database.CreateParameter("second", last)); 113 command.Parameters.Add(database.CreateParameter("second", last));
113
114 try 114 try
115 { 115 {
116 using (SqlDataReader reader = command.ExecuteReader()) 116 using (SqlDataReader reader = command.ExecuteReader())
@@ -120,7 +120,7 @@ namespace OpenSim.Data.MSSQL
120 } 120 }
121 catch (Exception e) 121 catch (Exception e)
122 { 122 {
123 m_log.Error("[USER DB] Error getting user profile, error: " + e.Message); 123 m_log.ErrorFormat("[USER DB] Error getting user profile for {0} {1}: {2}", user, last, e.Message);
124 return null; 124 return null;
125 } 125 }
126 } 126 }
@@ -133,20 +133,20 @@ namespace OpenSim.Data.MSSQL
133 /// <returns></returns> 133 /// <returns></returns>
134 override public UserProfileData GetUserByUUID(UUID uuid) 134 override public UserProfileData GetUserByUUID(UUID uuid)
135 { 135 {
136 using (AutoClosingSqlCommand command = database.Query("SELECT * FROM " + m_usersTableName + " WHERE UUID = @uuid")) 136 string sql = string.Format("SELECT * FROM {0} WHERE UUID = @uuid", m_usersTableName);
137 using (AutoClosingSqlCommand command = database.Query(sql))
137 { 138 {
138 command.Parameters.Add(database.CreateParameter("uuid", uuid)); 139 command.Parameters.Add(database.CreateParameter("uuid", uuid));
139
140 try 140 try
141 { 141 {
142 using (IDataReader reader = command.ExecuteReader()) 142 using (SqlDataReader reader = command.ExecuteReader())
143 { 143 {
144 return ReadUserRow(reader); 144 return ReadUserRow(reader);
145 } 145 }
146 } 146 }
147 catch (Exception e) 147 catch (Exception e)
148 { 148 {
149 m_log.Error("[USER DB] Error getting user profile by UUID, error: " + e.Message); 149 m_log.ErrorFormat("[USER DB] Error getting user profile by UUID {0}, error: {1}", uuid, e.Message);
150 return null; 150 return null;
151 } 151 }
152 } 152 }
@@ -173,7 +173,7 @@ namespace OpenSim.Data.MSSQL
173 } 173 }
174 catch (Exception e) 174 catch (Exception e)
175 { 175 {
176 m_log.Error("[USER DB] Error adding new profile, error: " + e.Message); 176 m_log.ErrorFormat("[USER DB] Error adding new profile, error: {0}", e.Message);
177 } 177 }
178 } 178 }
179 179
@@ -184,36 +184,37 @@ namespace OpenSim.Data.MSSQL
184 /// <returns></returns> 184 /// <returns></returns>
185 override public bool UpdateUserProfile(UserProfileData user) 185 override public bool UpdateUserProfile(UserProfileData user)
186 { 186 {
187 using (AutoClosingSqlCommand command = database.Query("UPDATE " + m_usersTableName + " set UUID = @uuid, " + 187 string sql = string.Format(@"UPDATE {0}
188 "username = @username, " + 188 SET UUID = @uuid,
189 "lastname = @lastname," + 189 username = @username,
190 "email = @email," + 190 lastname = @lastname,
191 "passwordHash = @passwordHash," + 191 email = @email,
192 "passwordSalt = @passwordSalt," + 192 passwordHash = @passwordHash,
193 "homeRegion = @homeRegion," + 193 passwordSalt = @passwordSalt,
194 "homeLocationX = @homeLocationX," + 194 homeRegion = @homeRegion,
195 "homeLocationY = @homeLocationY," + 195 homeLocationX = @homeLocationX,
196 "homeLocationZ = @homeLocationZ," + 196 homeLocationY = @homeLocationY,
197 "homeLookAtX = @homeLookAtX," + 197 homeLocationZ = @homeLocationZ,
198 "homeLookAtY = @homeLookAtY," + 198 homeLookAtX = @homeLookAtX,
199 "homeLookAtZ = @homeLookAtZ," + 199 homeLookAtY = @homeLookAtY,
200 "created = @created," + 200 homeLookAtZ = @homeLookAtZ,
201 "lastLogin = @lastLogin," + 201 created = @created,
202 "userInventoryURI = @userInventoryURI," + 202 lastLogin = @lastLogin,
203 "userAssetURI = @userAssetURI," + 203 userInventoryURI = @userInventoryURI,
204 "profileCanDoMask = @profileCanDoMask," + 204 userAssetURI = @userAssetURI,
205 "profileWantDoMask = @profileWantDoMask," + 205 profileCanDoMask = @profileCanDoMask,
206 "profileAboutText = @profileAboutText," + 206 profileWantDoMask = @profileWantDoMask,
207 "profileFirstText = @profileFirstText," + 207 profileAboutText = @profileAboutText,
208 "profileImage = @profileImage," + 208 profileFirstText = @profileFirstText,
209 "profileFirstImage = @profileFirstImage, " + 209 profileImage = @profileImage,
210 "webLoginKey = @webLoginKey, " + 210 profileFirstImage = @profileFirstImage,
211 "homeRegionID = @homeRegionID, " + 211 webLoginKey = @webLoginKey,
212 "userFlags = @userFlags, " + 212 homeRegionID = @homeRegionID,
213 "godLevel = @godLevel, " + 213 userFlags = @userFlags,
214 "customType = @customType, " + 214 godLevel = @godLevel,
215 "partner = @partner where " + 215 customType = @customType,
216 "UUID = @keyUUUID;")) 216 partner = @partner WHERE UUID = @keyUUUID;",m_usersTableName);
217 using (AutoClosingSqlCommand command = database.Query(sql))
217 { 218 {
218 command.Parameters.Add(database.CreateParameter("uuid", user.ID)); 219 command.Parameters.Add(database.CreateParameter("uuid", user.ID));
219 command.Parameters.Add(database.CreateParameter("username", user.FirstName)); 220 command.Parameters.Add(database.CreateParameter("username", user.FirstName));
@@ -239,7 +240,6 @@ namespace OpenSim.Data.MSSQL
239 command.Parameters.Add(database.CreateParameter("profileImage", user.Image)); 240 command.Parameters.Add(database.CreateParameter("profileImage", user.Image));
240 command.Parameters.Add(database.CreateParameter("profileFirstImage", user.FirstLifeImage)); 241 command.Parameters.Add(database.CreateParameter("profileFirstImage", user.FirstLifeImage));
241 command.Parameters.Add(database.CreateParameter("webLoginKey", user.WebLoginKey)); 242 command.Parameters.Add(database.CreateParameter("webLoginKey", user.WebLoginKey));
242 //
243 command.Parameters.Add(database.CreateParameter("homeRegionID", user.HomeRegionID)); 243 command.Parameters.Add(database.CreateParameter("homeRegionID", user.HomeRegionID));
244 command.Parameters.Add(database.CreateParameter("userFlags", user.UserFlags)); 244 command.Parameters.Add(database.CreateParameter("userFlags", user.UserFlags));
245 command.Parameters.Add(database.CreateParameter("godLevel", user.GodLevel)); 245 command.Parameters.Add(database.CreateParameter("godLevel", user.GodLevel));
@@ -254,7 +254,7 @@ namespace OpenSim.Data.MSSQL
254 } 254 }
255 catch (Exception e) 255 catch (Exception e)
256 { 256 {
257 m_log.Error("[USER DB] Error updating profile, error: " + e.Message); 257 m_log.ErrorFormat("[USER DB] Error updating profile, error: {0}", e.Message);
258 } 258 }
259 } 259 }
260 return false; 260 return false;
@@ -293,7 +293,8 @@ namespace OpenSim.Data.MSSQL
293 /// <returns>The users session</returns> 293 /// <returns>The users session</returns>
294 override public UserAgentData GetAgentByUUID(UUID uuid) 294 override public UserAgentData GetAgentByUUID(UUID uuid)
295 { 295 {
296 using (AutoClosingSqlCommand command = database.Query("SELECT * FROM " + m_agentsTableName + " WHERE UUID = @uuid")) 296 string sql = string.Format("SELECT * FROM {0} WHERE UUID = @uuid", m_agentsTableName);
297 using (AutoClosingSqlCommand command = database.Query(sql))
297 { 298 {
298 command.Parameters.Add(database.CreateParameter("uuid", uuid)); 299 command.Parameters.Add(database.CreateParameter("uuid", uuid));
299 try 300 try
@@ -305,7 +306,7 @@ namespace OpenSim.Data.MSSQL
305 } 306 }
306 catch (Exception e) 307 catch (Exception e)
307 { 308 {
308 m_log.Error("[USER DB] Error updating agentdata by UUID, error: " + e.Message); 309 m_log.ErrorFormat("[USER DB] Error updating agentdata by UUID, error: {0}", e.Message);
309 return null; 310 return null;
310 } 311 }
311 } 312 }
@@ -323,7 +324,7 @@ namespace OpenSim.Data.MSSQL
323 } 324 }
324 catch (Exception e) 325 catch (Exception e)
325 { 326 {
326 m_log.Error("[USER DB] Error adding new agentdata, error: " + e.Message); 327 m_log.ErrorFormat("[USER DB] Error adding new agentdata, error: {0}", e.Message);
327 } 328 }
328 } 329 }
329 330
@@ -340,12 +341,11 @@ namespace OpenSim.Data.MSSQL
340 override public void AddNewUserFriend(UUID friendlistowner, UUID friend, uint perms) 341 override public void AddNewUserFriend(UUID friendlistowner, UUID friend, uint perms)
341 { 342 {
342 int dtvalue = Util.UnixTimeSinceEpoch(); 343 int dtvalue = Util.UnixTimeSinceEpoch();
343 344 string sql = string.Format(@"INSERT INTO {0}
344 using (AutoClosingSqlCommand command = database.Query( 345 (ownerID,friendID,friendPerms,datetimestamp)
345 "INSERT INTO " + m_userFriendsTableName + " " + 346 VALUES
346 "(ownerID,friendID,friendPerms,datetimestamp) " + 347 (@ownerID,@friendID,@friendPerms,@datetimestamp)", m_userFriendsTableName);
347 "VALUES " + 348 using (AutoClosingSqlCommand command = database.Query(sql))
348 "(@ownerID,@friendID,@friendPerms,@datetimestamp)"))
349 { 349 {
350 command.Parameters.Add(database.CreateParameter("ownerID", friendlistowner)); 350 command.Parameters.Add(database.CreateParameter("ownerID", friendlistowner));
351 command.Parameters.Add(database.CreateParameter("friendID", friend)); 351 command.Parameters.Add(database.CreateParameter("friendID", friend));
@@ -355,14 +355,16 @@ namespace OpenSim.Data.MSSQL
355 355
356 try 356 try
357 { 357 {
358 command.CommandText = string.Format("INSERT INTO {0} (ownerID,friendID,friendPerms,datetimestamp) VALUES (@friendID,@ownerID,@friendPerms,@datetimestamp)", 358 sql = string.Format(@"INSERT INTO {0}
359 m_userFriendsTableName); 359 (ownerID,friendID,friendPerms,datetimestamp)
360 360 VALUES
361 (@friendID,@ownerID,@friendPerms,@datetimestamp)", m_userFriendsTableName);
362 command.CommandText = sql;
361 command.ExecuteNonQuery(); 363 command.ExecuteNonQuery();
362 } 364 }
363 catch (Exception e) 365 catch (Exception e)
364 { 366 {
365 m_log.Error("[USER DB] Error adding new userfriend, error: " + e.Message); 367 m_log.ErrorFormat("[USER DB] Error adding new userfriend, error: {0}", e.Message);
366 return; 368 return;
367 } 369 }
368 } 370 }
@@ -375,21 +377,25 @@ namespace OpenSim.Data.MSSQL
375 /// <param name="friend">UUID of the not-so-friendly user to remove from the list</param> 377 /// <param name="friend">UUID of the not-so-friendly user to remove from the list</param>
376 override public void RemoveUserFriend(UUID friendlistowner, UUID friend) 378 override public void RemoveUserFriend(UUID friendlistowner, UUID friend)
377 { 379 {
378 using (AutoClosingSqlCommand command = database.Query("delete from " + m_userFriendsTableName + " where ownerID = @ownerID and friendID = @friendID")) 380 string sql = string.Format(@"DELETE from {0}
381 WHERE ownerID = @ownerID
382 AND friendID = @friendID", m_userFriendsTableName);
383 using (AutoClosingSqlCommand command = database.Query(sql))
379 { 384 {
380 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner)); 385 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner));
381 command.Parameters.Add(database.CreateParameter("@friendID", friend)); 386 command.Parameters.Add(database.CreateParameter("@friendID", friend));
382 command.ExecuteNonQuery(); 387 command.ExecuteNonQuery();
383 388 sql = string.Format(@"DELETE from {0}
384 command.CommandText = "delete from " + m_userFriendsTableName + 389 WHERE ownerID = @friendID
385 " where ownerID = @friendID and friendID = @ownerID"; 390 AND friendID = @ownerID", m_userFriendsTableName);
391 command.CommandText = sql;
386 try 392 try
387 { 393 {
388 command.ExecuteNonQuery(); 394 command.ExecuteNonQuery();
389 } 395 }
390 catch (Exception e) 396 catch (Exception e)
391 { 397 {
392 m_log.Error("[USER DB] Error removing userfriend, error: " + e.Message); 398 m_log.ErrorFormat("[USER DB] Error removing userfriend, error: {0}", e.Message);
393 } 399 }
394 } 400 }
395 } 401 }
@@ -402,10 +408,10 @@ namespace OpenSim.Data.MSSQL
402 /// <param name="perms">new permission flag</param> 408 /// <param name="perms">new permission flag</param>
403 override public void UpdateUserFriendPerms(UUID friendlistowner, UUID friend, uint perms) 409 override public void UpdateUserFriendPerms(UUID friendlistowner, UUID friend, uint perms)
404 { 410 {
405 using (AutoClosingSqlCommand command = database.Query( 411 string sql = string.Format(@"UPDATE {0} SET friendPerms = @friendPerms
406 "update " + m_userFriendsTableName + 412 WHERE ownerID = @ownerID
407 " SET friendPerms = @friendPerms " + 413 AND friendID = @friendID", m_userFriendsTableName);
408 "where ownerID = @ownerID and friendID = @friendID")) 414 using (AutoClosingSqlCommand command = database.Query(sql))
409 { 415 {
410 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner)); 416 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner));
411 command.Parameters.Add(database.CreateParameter("@friendID", friend)); 417 command.Parameters.Add(database.CreateParameter("@friendID", friend));
@@ -417,7 +423,7 @@ namespace OpenSim.Data.MSSQL
417 } 423 }
418 catch (Exception e) 424 catch (Exception e)
419 { 425 {
420 m_log.Error("[USER DB] Error updating userfriend, error: " + e.Message); 426 m_log.ErrorFormat("[USER DB] Error updating userfriend, error: {0}", e.Message);
421 } 427 }
422 } 428 }
423 } 429 }
@@ -432,15 +438,17 @@ namespace OpenSim.Data.MSSQL
432 List<FriendListItem> friendList = new List<FriendListItem>(); 438 List<FriendListItem> friendList = new List<FriendListItem>();
433 439
434 //Left Join userfriends to itself 440 //Left Join userfriends to itself
435 using (AutoClosingSqlCommand command = database.Query( 441 string sql = string.Format(@"SELECT a.ownerID, a.friendID, a.friendPerms, b.friendPerms AS ownerperms
436 "select a.ownerID,a.friendID,a.friendPerms,b.friendPerms as ownerperms from " + m_userFriendsTableName + " as a, " + m_userFriendsTableName + " as b" + 442 FROM {0} as a, {0} as b
437 " where a.ownerID = @ownerID and b.ownerID = a.friendID and b.friendID = a.ownerID")) 443 WHERE a.ownerID = @ownerID
444 AND b.ownerID = a.friendID
445 AND b.friendID = a.ownerID", m_userFriendsTableName);
446 using (AutoClosingSqlCommand command = database.Query(sql))
438 { 447 {
439 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner)); 448 command.Parameters.Add(database.CreateParameter("@ownerID", friendlistowner));
440
441 try 449 try
442 { 450 {
443 using (IDataReader reader = command.ExecuteReader()) 451 using (SqlDataReader reader = command.ExecuteReader())
444 { 452 {
445 while (reader.Read()) 453 while (reader.Read())
446 { 454 {
@@ -451,17 +459,15 @@ namespace OpenSim.Data.MSSQL
451 459
452 // This is not a real column in the database table, it's a joined column from the opposite record 460 // This is not a real column in the database table, it's a joined column from the opposite record
453 fli.FriendListOwnerPerms = (uint)Convert.ToInt32(reader["ownerperms"]); 461 fli.FriendListOwnerPerms = (uint)Convert.ToInt32(reader["ownerperms"]);
454
455 friendList.Add(fli); 462 friendList.Add(fli);
456 } 463 }
457 } 464 }
458 } 465 }
459 catch (Exception e) 466 catch (Exception e)
460 { 467 {
461 m_log.Error("[USER DB] Error updating userfriend, error: " + e.Message); 468 m_log.ErrorFormat("[USER DB] Error updating userfriend, error: {0}", e.Message);
462 } 469 }
463 } 470 }
464
465 return friendList; 471 return friendList;
466 } 472 }
467 473
@@ -472,12 +478,12 @@ namespace OpenSim.Data.MSSQL
472 { 478 {
473 foreach (UUID uuid in uuids) 479 foreach (UUID uuid in uuids)
474 { 480 {
475 using (AutoClosingSqlCommand command = database.Query( 481 string sql = string.Format(@"SELECT agentOnline,currentHandle
476 "select agentOnline,currentHandle from " + m_agentsTableName + " where UUID = @uuid")) 482 FROM {0} WHERE UUID = @uuid", m_agentsTableName);
483 using (AutoClosingSqlCommand command = database.Query(sql))
477 { 484 {
478 command.Parameters.Add(database.CreateParameter("@uuid", uuid)); 485 command.Parameters.Add(database.CreateParameter("@uuid", uuid));
479 486 using (SqlDataReader reader = command.ExecuteReader())
480 using (IDataReader reader = command.ExecuteReader())
481 { 487 {
482 while (reader.Read()) 488 while (reader.Read())
483 { 489 {
@@ -541,11 +547,11 @@ namespace OpenSim.Data.MSSQL
541 try 547 try
542 { 548 {
543 AvatarAppearance appearance = new AvatarAppearance(); 549 AvatarAppearance appearance = new AvatarAppearance();
544 550 string sql = "SELECT * FROM avatarappearance WHERE owner = @UUID";
545 using (AutoClosingSqlCommand command = database.Query("SELECT * FROM avatarappearance WHERE owner = @UUID")) 551 using (AutoClosingSqlCommand command = database.Query(sql))
546 { 552 {
547 command.Parameters.Add(database.CreateParameter("@UUID", user)); 553 command.Parameters.Add(database.CreateParameter("@UUID", user));
548 using (IDataReader reader = command.ExecuteReader()) 554 using (SqlDataReader reader = command.ExecuteReader())
549 { 555 {
550 if (reader.Read()) 556 if (reader.Read())
551 appearance = readUserAppearance(reader); 557 appearance = readUserAppearance(reader);
@@ -564,12 +570,11 @@ namespace OpenSim.Data.MSSQL
564 } 570 }
565 catch (Exception e) 571 catch (Exception e)
566 { 572 {
567 m_log.Error("[USER DB] Error updating userfriend, error: " + e.Message); 573 m_log.ErrorFormat("[USER DB] Error updating userfriend, error: {0}", e.Message);
568 } 574 }
569 return null; 575 return null;
570 } 576 }
571 577
572
573 /// <summary> 578 /// <summary>
574 /// Update a user appearence into database 579 /// Update a user appearence into database
575 /// </summary> 580 /// </summary>
@@ -577,20 +582,23 @@ namespace OpenSim.Data.MSSQL
577 /// <param name="appearance">the appearence</param> 582 /// <param name="appearance">the appearence</param>
578 override public void UpdateUserAppearance(UUID user, AvatarAppearance appearance) 583 override public void UpdateUserAppearance(UUID user, AvatarAppearance appearance)
579 { 584 {
580 m_log.Error("[USER DB] updating user appearance for user ID " + user.Guid); 585 string sql = @"DELETE FROM avatarappearance WHERE owner=@owner;
581 string sql = String.Empty; 586 INSERT INTO avatarappearance
582 sql += "DELETE FROM avatarappearance WHERE owner=@owner "; 587 (owner, serial, visual_params, texture, avatar_height,
583 sql += "INSERT INTO avatarappearance "; 588 body_item, body_asset, skin_item, skin_asset, hair_item,
584 sql += "(owner, serial, visual_params, texture, avatar_height, "; 589 hair_asset, eyes_item, eyes_asset, shirt_item, shirt_asset,
585 sql += "body_item, body_asset, skin_item, skin_asset, hair_item, hair_asset, eyes_item, eyes_asset, "; 590 pants_item, pants_asset, shoes_item, shoes_asset, socks_item,
586 sql += "shirt_item, shirt_asset, pants_item, pants_asset, shoes_item, shoes_asset, socks_item, socks_asset, "; 591 socks_asset, jacket_item, jacket_asset, gloves_item, gloves_asset,
587 sql += "jacket_item, jacket_asset, gloves_item, gloves_asset, undershirt_item, undershirt_asset, underpants_item, underpants_asset, "; 592 undershirt_item, undershirt_asset, underpants_item, underpants_asset,
588 sql += "skirt_item, skirt_asset) values ("; 593 skirt_item, skirt_asset)
589 sql += "@owner, @serial, @visual_params, @texture, @avatar_height, "; 594 VALUES
590 sql += "@body_item, @body_asset, @skin_item, @skin_asset, @hair_item, @hair_asset, @eyes_item, @eyes_asset, "; 595 (@owner, @serial, @visual_params, @texture, @avatar_height,
591 sql += "@shirt_item, @shirt_asset, @pants_item, @pants_asset, @shoes_item, @shoes_asset, @socks_item, @socks_asset, "; 596 @body_item, @body_asset, @skin_item, @skin_asset, @hair_item,
592 sql += "@jacket_item, @jacket_asset, @gloves_item, @gloves_asset, @undershirt_item, @undershirt_asset, @underpants_item, @underpants_asset, "; 597 @hair_asset, @eyes_item, @eyes_asset, @shirt_item, @shirt_asset,
593 sql += "@skirt_item, @skirt_asset)"; 598 @pants_item, @pants_asset, @shoes_item, @shoes_asset, @socks_item,
599 @socks_asset, @jacket_item, @jacket_asset, @gloves_item, @gloves_asset,
600 @undershirt_item, @undershirt_asset, @underpants_item, @underpants_asset,
601 @skirt_item, @skirt_asset)";
594 602
595 using (AutoClosingSqlCommand cmd = database.Query(sql)) 603 using (AutoClosingSqlCommand cmd = database.Query(sql))
596 { 604 {
@@ -632,10 +640,9 @@ namespace OpenSim.Data.MSSQL
632 } 640 }
633 catch (Exception e) 641 catch (Exception e)
634 { 642 {
635 m_log.Error("[USER DB] Error updating user appearance, error: " + e.Message); 643 m_log.ErrorFormat("[USER DB] Error updating user appearance, error: {0}", e.Message);
636 } 644 }
637 } 645 }
638
639 UpdateUserAttachments(user, appearance.GetAttachments()); 646 UpdateUserAttachments(user, appearance.GetAttachments());
640 } 647 }
641 648
@@ -651,7 +658,8 @@ namespace OpenSim.Data.MSSQL
651 public Hashtable GetUserAttachments(UUID agentID) 658 public Hashtable GetUserAttachments(UUID agentID)
652 { 659 {
653 Hashtable returnTable = new Hashtable(); 660 Hashtable returnTable = new Hashtable();
654 using (AutoClosingSqlCommand command = database.Query("select attachpoint, item, asset from avatarattachments where UUID = @uuid", database.CreateParameter("@uuid", agentID))) 661 string sql = "select attachpoint, item, asset from avatarattachments where UUID = @uuid";
662 using (AutoClosingSqlCommand command = database.Query(sql, database.CreateParameter("@uuid", agentID)))
655 { 663 {
656 using (SqlDataReader reader = command.ExecuteReader()) 664 using (SqlDataReader reader = command.ExecuteReader())
657 { 665 {
@@ -678,7 +686,7 @@ namespace OpenSim.Data.MSSQL
678 /// <param name="data">data with all items on attachmentpoints</param> 686 /// <param name="data">data with all items on attachmentpoints</param>
679 public void UpdateUserAttachments(UUID agentID, Hashtable data) 687 public void UpdateUserAttachments(UUID agentID, Hashtable data)
680 { 688 {
681 string sql = "delete from avatarattachments where UUID = @uuid"; 689 string sql = "DELETE FROM avatarattachments WHERE UUID = @uuid";
682 690
683 using (AutoClosingSqlCommand command = database.Query(sql)) 691 using (AutoClosingSqlCommand command = database.Query(sql))
684 { 692 {
@@ -688,7 +696,8 @@ namespace OpenSim.Data.MSSQL
688 if (data == null) 696 if (data == null)
689 return; 697 return;
690 698
691 sql = "insert into avatarattachments (UUID, attachpoint, item, asset) values (@uuid, @attachpoint, @item, @asset)"; 699 sql = @"INSERT INTO avatarattachments (UUID, attachpoint, item, asset)
700 VALUES (@uuid, @attachpoint, @item, @asset)";
692 701
693 using (AutoClosingSqlCommand command = database.Query(sql)) 702 using (AutoClosingSqlCommand command = database.Query(sql))
694 { 703 {
@@ -730,7 +739,8 @@ namespace OpenSim.Data.MSSQL
730 /// <param name="agentID">agentID.</param> 739 /// <param name="agentID">agentID.</param>
731 override public void ResetAttachments(UUID agentID) 740 override public void ResetAttachments(UUID agentID)
732 { 741 {
733 using (AutoClosingSqlCommand command = database.Query("update avatarattachments set asset = '00000000-0000-0000-0000-000000000000' where UUID = @uuid")) 742 string sql = "UPDATE avatarattachments SET asset = '00000000-0000-0000-0000-000000000000' WHERE UUID = @uuid";
743 using (AutoClosingSqlCommand command = database.Query(sql))
734 { 744 {
735 command.Parameters.Add(database.CreateParameter("uuid", agentID)); 745 command.Parameters.Add(database.CreateParameter("uuid", agentID));
736 command.ExecuteNonQuery(); 746 command.ExecuteNonQuery();
@@ -759,12 +769,14 @@ namespace OpenSim.Data.MSSQL
759 { 769 {
760 try 770 try
761 { 771 {
762 using (AutoClosingSqlCommand command = database.Query("SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username LIKE @first AND lastname LIKE @second")) 772 string sql = string.Format(@"SELECT UUID,username,lastname FROM {0}
773 WHERE username LIKE @first AND lastname LIKE @second", m_usersTableName);
774 using (AutoClosingSqlCommand command = database.Query(sql))
763 { 775 {
764 //Add wildcard to the search 776 //Add wildcard to the search
765 command.Parameters.Add(database.CreateParameter("first", querysplit[0] + "%")); 777 command.Parameters.Add(database.CreateParameter("first", querysplit[0] + "%"));
766 command.Parameters.Add(database.CreateParameter("second", querysplit[1] + "%")); 778 command.Parameters.Add(database.CreateParameter("second", querysplit[1] + "%"));
767 using (IDataReader reader = command.ExecuteReader()) 779 using (SqlDataReader reader = command.ExecuteReader())
768 { 780 {
769 while (reader.Read()) 781 while (reader.Read())
770 { 782 {
@@ -786,11 +798,13 @@ namespace OpenSim.Data.MSSQL
786 { 798 {
787 try 799 try
788 { 800 {
789 using (AutoClosingSqlCommand command = database.Query("SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username LIKE @first OR lastname LIKE @first")) 801 string sql = string.Format(@"SELECT UUID,username,lastname FROM {0}
802 WHERE username LIKE @first OR lastname LIKE @first", m_usersTableName);
803 using (AutoClosingSqlCommand command = database.Query(sql))
790 { 804 {
791 command.Parameters.Add(database.CreateParameter("first", querysplit[0] + "%")); 805 command.Parameters.Add(database.CreateParameter("first", querysplit[0] + "%"));
792 806
793 using (IDataReader reader = command.ExecuteReader()) 807 using (SqlDataReader reader = command.ExecuteReader())
794 { 808 {
795 while (reader.Read()) 809 while (reader.Read())
796 { 810 {
@@ -822,7 +836,6 @@ namespace OpenSim.Data.MSSQL
822 UserProfileData user = GetUserByUUID(AgentID); 836 UserProfileData user = GetUserByUUID(AgentID);
823 user.WebLoginKey = WebLoginKey; 837 user.WebLoginKey = WebLoginKey;
824 UpdateUserProfile(user); 838 UpdateUserProfile(user);
825
826 } 839 }
827 840
828 /// <summary> 841 /// <summary>
@@ -852,7 +865,7 @@ namespace OpenSim.Data.MSSQL
852 /// </summary> 865 /// </summary>
853 /// <param name="reader">The SQL Result</param> 866 /// <param name="reader">The SQL Result</param>
854 /// <returns>the item read</returns> 867 /// <returns>the item read</returns>
855 private static AvatarAppearance readUserAppearance(IDataReader reader) 868 private static AvatarAppearance readUserAppearance(SqlDataReader reader)
856 { 869 {
857 try 870 try
858 { 871 {
@@ -962,7 +975,7 @@ ELSE
962 /// </summary> 975 /// </summary>
963 /// <param name="reader">An active database reader</param> 976 /// <param name="reader">An active database reader</param>
964 /// <returns>A user session agent</returns> 977 /// <returns>A user session agent</returns>
965 private UserAgentData readAgentRow(IDataReader reader) 978 private UserAgentData readAgentRow(SqlDataReader reader)
966 { 979 {
967 UserAgentData retval = new UserAgentData(); 980 UserAgentData retval = new UserAgentData();
968 981
@@ -1038,18 +1051,20 @@ ELSE
1038 UUID profileImage, UUID firstImage, UUID webLoginKey, UUID homeRegionID, 1051 UUID profileImage, UUID firstImage, UUID webLoginKey, UUID homeRegionID,
1039 int godLevel, int userFlags, string customType, UUID partnerID) 1052 int godLevel, int userFlags, string customType, UUID partnerID)
1040 { 1053 {
1041 string sql = "INSERT INTO " + m_usersTableName; 1054 string sql = string.Format(@"INSERT INTO {0}
1042 sql += " ([UUID], [username], [lastname], [email], [passwordHash], [passwordSalt], [homeRegion], "; 1055 ([UUID], [username], [lastname], [email], [passwordHash], [passwordSalt],
1043 sql += "[homeLocationX], [homeLocationY], [homeLocationZ], [homeLookAtX], [homeLookAtY], [homeLookAtZ], [created], "; 1056 [homeRegion], [homeLocationX], [homeLocationY], [homeLocationZ], [homeLookAtX],
1044 sql += "[lastLogin], [userInventoryURI], [userAssetURI], [profileCanDoMask], [profileWantDoMask], [profileAboutText], "; 1057 [homeLookAtY], [homeLookAtZ], [created], [lastLogin], [userInventoryURI],
1045 sql += "[profileFirstText], [profileImage], [profileFirstImage], [webLoginKey], "; 1058 [userAssetURI], [profileCanDoMask], [profileWantDoMask], [profileAboutText],
1046 sql += "[homeRegionID], [userFlags], [godLevel], [customType], [partner]) VALUES "; 1059 [profileFirstText], [profileImage], [profileFirstImage], [webLoginKey],
1047 1060 [homeRegionID], [userFlags], [godLevel], [customType], [partner])
1048 sql += "(@UUID, @username, @lastname, @email, @passwordHash, @passwordSalt, @homeRegion, "; 1061 VALUES
1049 sql += "@homeLocationX, @homeLocationY, @homeLocationZ, @homeLookAtX, @homeLookAtY, @homeLookAtZ, @created, "; 1062 (@UUID, @username, @lastname, @email, @passwordHash, @passwordSalt,
1050 sql += "@lastLogin, @userInventoryURI, @userAssetURI, @profileCanDoMask, @profileWantDoMask, @profileAboutText, "; 1063 @homeRegion, @homeLocationX, @homeLocationY, @homeLocationZ, @homeLookAtX,
1051 sql += "@profileFirstText, @profileImage, @profileFirstImage, @webLoginKey, "; 1064 @homeLookAtY, @homeLookAtZ, @created, @lastLogin, @userInventoryURI,
1052 sql += "@homeRegionID, @userFlags, @godLevel, @customType, @partner)"; 1065 @userAssetURI, @profileCanDoMask, @profileWantDoMask, @profileAboutText,
1066 @profileFirstText, @profileImage, @profileFirstImage, @webLoginKey,
1067 @homeRegionID, @userFlags, @godLevel, @customType, @partner)", m_usersTableName);
1053 1068
1054 try 1069 try
1055 { 1070 {
@@ -1079,13 +1094,11 @@ ELSE
1079 command.Parameters.Add(database.CreateParameter("profileImage", profileImage)); 1094 command.Parameters.Add(database.CreateParameter("profileImage", profileImage));
1080 command.Parameters.Add(database.CreateParameter("profileFirstImage", firstImage)); 1095 command.Parameters.Add(database.CreateParameter("profileFirstImage", firstImage));
1081 command.Parameters.Add(database.CreateParameter("webLoginKey", webLoginKey)); 1096 command.Parameters.Add(database.CreateParameter("webLoginKey", webLoginKey));
1082 //
1083 command.Parameters.Add(database.CreateParameter("homeRegionID", homeRegionID)); 1097 command.Parameters.Add(database.CreateParameter("homeRegionID", homeRegionID));
1084 command.Parameters.Add(database.CreateParameter("userFlags", userFlags)); 1098 command.Parameters.Add(database.CreateParameter("userFlags", userFlags));
1085 command.Parameters.Add(database.CreateParameter("godLevel", godLevel)); 1099 command.Parameters.Add(database.CreateParameter("godLevel", godLevel));
1086 command.Parameters.Add(database.CreateParameter("customType", customType)); 1100 command.Parameters.Add(database.CreateParameter("customType", customType));
1087 command.Parameters.Add(database.CreateParameter("partner", partnerID)); 1101 command.Parameters.Add(database.CreateParameter("partner", partnerID));
1088
1089 1102
1090 command.ExecuteNonQuery(); 1103 command.ExecuteNonQuery();
1091 return; 1104 return;
@@ -1096,7 +1109,6 @@ ELSE
1096 m_log.Error(e.ToString()); 1109 m_log.Error(e.ToString());
1097 return; 1110 return;
1098 } 1111 }
1099
1100 } 1112 }
1101 1113
1102 /// <summary> 1114 /// <summary>
@@ -1104,7 +1116,7 @@ ELSE
1104 /// </summary> 1116 /// </summary>
1105 /// <param name="reader">An active database reader</param> 1117 /// <param name="reader">An active database reader</param>
1106 /// <returns>A user profile</returns> 1118 /// <returns>A user profile</returns>
1107 private static UserProfileData ReadUserRow(IDataReader reader) 1119 private static UserProfileData ReadUserRow(SqlDataReader reader)
1108 { 1120 {
1109 UserProfileData retval = new UserProfileData(); 1121 UserProfileData retval = new UserProfileData();
1110 1122
@@ -1149,7 +1161,6 @@ ELSE
1149 } 1161 }
1150 return retval; 1162 return retval;
1151 } 1163 }
1152
1153 #endregion 1164 #endregion
1154 } 1165 }
1155 1166