aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/CoreModules/Agent/AssetTransaction/AssetXferUploader.cs35
-rw-r--r--OpenSim/Services/Connectors/Inventory/XInventoryServicesConnector.cs9
2 files changed, 33 insertions, 11 deletions
diff --git a/OpenSim/Region/CoreModules/Agent/AssetTransaction/AssetXferUploader.cs b/OpenSim/Region/CoreModules/Agent/AssetTransaction/AssetXferUploader.cs
index fdff199..fabb409 100644
--- a/OpenSim/Region/CoreModules/Agent/AssetTransaction/AssetXferUploader.cs
+++ b/OpenSim/Region/CoreModules/Agent/AssetTransaction/AssetXferUploader.cs
@@ -337,12 +337,16 @@ namespace OpenSim.Region.CoreModules.Agent.AssetTransaction
337 m_asset.Description = item.Description; 337 m_asset.Description = item.Description;
338 m_asset.Type = (sbyte)item.AssetType; 338 m_asset.Type = (sbyte)item.AssetType;
339 339
340 // We must always store the item at this point even if the asset hasn't finished uploading, in order 340 // remove redundante m_Scene.InventoryService.UpdateItem
341 // to avoid a race condition when the appearance module retrieves the item to set the asset id in 341 // if uploadState == UploadState.Complete)
342 // the AvatarAppearance structure. 342// if (m_asset.FullID != UUID.Zero)
343 item.AssetID = m_asset.FullID; 343// {
344 if (item.AssetID != UUID.Zero) 344 // We must always store the item at this point even if the asset hasn't finished uploading, in order
345 m_Scene.InventoryService.UpdateItem(item); 345 // to avoid a race condition when the appearance module retrieves the item to set the asset id in
346 // the AvatarAppearance structure.
347// item.AssetID = m_asset.FullID;
348// m_Scene.InventoryService.UpdateItem(item);
349// }
346 350
347 if (m_uploadState == UploadState.Complete) 351 if (m_uploadState == UploadState.Complete)
348 { 352 {
@@ -350,10 +354,21 @@ namespace OpenSim.Region.CoreModules.Agent.AssetTransaction
350 } 354 }
351 else 355 else
352 { 356 {
353// m_log.DebugFormat( 357 // do it here to avoid the eventual race condition
354// "[ASSET XFER UPLOADER]: Holding update inventory item request {0} for {1} pending completion of asset xfer for transaction {2}", 358 if (m_asset.FullID != UUID.Zero)
355// item.Name, remoteClient.Name, transactionID); 359 {
356 360 // We must always store the item at this point even if the asset hasn't finished uploading, in order
361 // to avoid a race condition when the appearance module retrieves the item to set the asset id in
362 // the AvatarAppearance structure.
363 item.AssetID = m_asset.FullID;
364 m_Scene.InventoryService.UpdateItem(item);
365 }
366
367
368 // m_log.DebugFormat(
369 // "[ASSET XFER UPLOADER]: Holding update inventory item request {0} for {1} pending completion of asset xfer for transaction {2}",
370 // item.Name, remoteClient.Name, transactionID);
371
357 m_updateItem = true; 372 m_updateItem = true;
358 m_updateItemData = item; 373 m_updateItemData = item;
359 } 374 }
diff --git a/OpenSim/Services/Connectors/Inventory/XInventoryServicesConnector.cs b/OpenSim/Services/Connectors/Inventory/XInventoryServicesConnector.cs
index f235446..243da52 100644
--- a/OpenSim/Services/Connectors/Inventory/XInventoryServicesConnector.cs
+++ b/OpenSim/Services/Connectors/Inventory/XInventoryServicesConnector.cs
@@ -474,7 +474,13 @@ namespace OpenSim.Services.Connectors
474 { "CreationDate", item.CreationDate.ToString() } 474 { "CreationDate", item.CreationDate.ToString() }
475 }); 475 });
476 476
477 return CheckReturn(ret); 477 bool result = CheckReturn(ret);
478 if (result)
479 {
480 m_ItemCache.AddOrUpdate(item.ID, item, CACHE_EXPIRATION_SECONDS);
481 }
482
483 return result;
478 } 484 }
479 485
480 public bool MoveItems(UUID principalID, List<InventoryItemBase> items) 486 public bool MoveItems(UUID principalID, List<InventoryItemBase> items)
@@ -551,6 +557,7 @@ namespace OpenSim.Services.Connectors
551 List<UUID> pending = new List<UUID>(); 557 List<UUID> pending = new List<UUID>();
552 InventoryItemBase item = null; 558 InventoryItemBase item = null;
553 int i = 0; 559 int i = 0;
560
554 foreach (UUID id in itemIDs) 561 foreach (UUID id in itemIDs)
555 { 562 {
556 if (m_ItemCache.TryGetValue(id, out item)) 563 if (m_ItemCache.TryGetValue(id, out item))