diff options
author | UbitUmarov | 2016-12-23 02:17:42 +0000 |
---|---|---|
committer | UbitUmarov | 2016-12-23 02:17:42 +0000 |
commit | 2e7e4427d06951e950019b4175f6dba9358c4d0d (patch) | |
tree | 553fb176064ac29ae621ed64b0733aafb3120122 | |
parent | Allow the use of modular configs with Robust as we already can with OpenSim (diff) | |
download | opensim-SC_OLD-2e7e4427d06951e950019b4175f6dba9358c4d0d.zip opensim-SC_OLD-2e7e4427d06951e950019b4175f6dba9358c4d0d.tar.gz opensim-SC_OLD-2e7e4427d06951e950019b4175f6dba9358c4d0d.tar.bz2 opensim-SC_OLD-2e7e4427d06951e950019b4175f6dba9358c4d0d.tar.xz |
UserProfileModule threading issues
-rw-r--r-- | OpenSim/Region/CoreModules/Avatar/UserProfiles/UserProfileModule.cs | 140 |
1 files changed, 77 insertions, 63 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/UserProfiles/UserProfileModule.cs b/OpenSim/Region/CoreModules/Avatar/UserProfiles/UserProfileModule.cs index 1ea1306..d232d82 100644 --- a/OpenSim/Region/CoreModules/Avatar/UserProfiles/UserProfileModule.cs +++ b/OpenSim/Region/CoreModules/Avatar/UserProfiles/UserProfileModule.cs | |||
@@ -438,12 +438,14 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
438 | } | 438 | } |
439 | } | 439 | } |
440 | 440 | ||
441 | if(uce == null) | 441 | lock(m_profilesCache) |
442 | uce = new UserProfileCacheEntry(); | 442 | { |
443 | uce.classifiedsLists = classifieds; | 443 | if(!m_profilesCache.TryGetValue(targetID, out uce) || uce == null) |
444 | uce = new UserProfileCacheEntry(); | ||
445 | uce.classifiedsLists = classifieds; | ||
444 | 446 | ||
445 | lock(m_profilesCache) | ||
446 | m_profilesCache.AddOrUpdate(targetID, uce, PROFILECACHEEXPIRE); | 447 | m_profilesCache.AddOrUpdate(targetID, uce, PROFILECACHEEXPIRE); |
448 | } | ||
447 | 449 | ||
448 | remoteClient.SendAvatarClassifiedReply(targetID, classifieds); | 450 | remoteClient.SendAvatarClassifiedReply(targetID, classifieds); |
449 | } | 451 | } |
@@ -512,14 +514,16 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
512 | if(foreign) | 514 | if(foreign) |
513 | cacheForeignImage(target, ad.SnapshotId); | 515 | cacheForeignImage(target, ad.SnapshotId); |
514 | 516 | ||
515 | if(uce == null) | ||
516 | uce = new UserProfileCacheEntry(); | ||
517 | if(uce.classifieds == null) | ||
518 | uce.classifieds = new Dictionary<UUID, UserClassifiedAdd>(); | ||
519 | uce.classifieds[ad.ClassifiedId] = ad; | ||
520 | |||
521 | lock(m_profilesCache) | 517 | lock(m_profilesCache) |
522 | m_profilesCache.AddOrUpdate(ad.ClassifiedId, uce, PROFILECACHEEXPIRE); | 518 | { |
519 | if(!m_profilesCache.TryGetValue(target, out uce) || uce == null) | ||
520 | uce = new UserProfileCacheEntry(); | ||
521 | if(uce.classifieds == null) | ||
522 | uce.classifieds = new Dictionary<UUID, UserClassifiedAdd>(); | ||
523 | uce.classifieds[ad.ClassifiedId] = ad; | ||
524 | |||
525 | m_profilesCache.AddOrUpdate(target, uce, PROFILECACHEEXPIRE); | ||
526 | } | ||
523 | 527 | ||
524 | Vector3 globalPos = new Vector3(); | 528 | Vector3 globalPos = new Vector3(); |
525 | Vector3.TryParse(ad.GlobalPos, out globalPos); | 529 | Vector3.TryParse(ad.GlobalPos, out globalPos); |
@@ -659,7 +663,7 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
659 | // just flush cache for now | 663 | // just flush cache for now |
660 | lock(m_profilesCache) | 664 | lock(m_profilesCache) |
661 | { | 665 | { |
662 | if(uce != null) | 666 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) |
663 | { | 667 | { |
664 | uce.classifieds = null; | 668 | uce.classifieds = null; |
665 | uce.classifiedsLists = null; | 669 | uce.classifiedsLists = null; |
@@ -679,16 +683,6 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
679 | /// </param> | 683 | /// </param> |
680 | public void ClassifiedDelete(UUID queryClassifiedID, IClientAPI remoteClient) | 684 | public void ClassifiedDelete(UUID queryClassifiedID, IClientAPI remoteClient) |
681 | { | 685 | { |
682 | // just flush cache for now | ||
683 | UserProfileCacheEntry uce = null; | ||
684 | lock(m_profilesCache) | ||
685 | { | ||
686 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
687 | { | ||
688 | uce.classifieds = null; | ||
689 | uce.classifiedsLists = null; | ||
690 | } | ||
691 | } | ||
692 | 686 | ||
693 | string serverURI = string.Empty; | 687 | string serverURI = string.Empty; |
694 | bool foreign = GetUserProfileServerURI(remoteClient.AgentId, out serverURI); | 688 | bool foreign = GetUserProfileServerURI(remoteClient.AgentId, out serverURI); |
@@ -700,6 +694,7 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
700 | remoteClient.SendAgentAlertMessage("Please change classifieds on your home grid", true); | 694 | remoteClient.SendAgentAlertMessage("Please change classifieds on your home grid", true); |
701 | return; | 695 | return; |
702 | } | 696 | } |
697 | |||
703 | UUID classifiedId; | 698 | UUID classifiedId; |
704 | if(!UUID.TryParse(queryClassifiedID.ToString(), out classifiedId)) | 699 | if(!UUID.TryParse(queryClassifiedID.ToString(), out classifiedId)) |
705 | return; | 700 | return; |
@@ -714,6 +709,17 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
714 | return; | 709 | return; |
715 | } | 710 | } |
716 | 711 | ||
712 | // flush cache | ||
713 | UserProfileCacheEntry uce = null; | ||
714 | lock(m_profilesCache) | ||
715 | { | ||
716 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
717 | { | ||
718 | uce.classifieds = null; | ||
719 | uce.classifiedsLists = null; | ||
720 | } | ||
721 | } | ||
722 | |||
717 | parameters = (OSDMap)Params; | 723 | parameters = (OSDMap)Params; |
718 | } | 724 | } |
719 | #endregion Classified | 725 | #endregion Classified |
@@ -797,12 +803,14 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
797 | picks[cid] = name; | 803 | picks[cid] = name; |
798 | } | 804 | } |
799 | 805 | ||
800 | if (uce == null) | ||
801 | uce = new UserProfileCacheEntry(); | ||
802 | uce.picksList = picks; | ||
803 | |||
804 | lock(m_profilesCache) | 806 | lock(m_profilesCache) |
807 | { | ||
808 | if(!m_profilesCache.TryGetValue(targetId, out uce) || uce == null) | ||
809 | uce = new UserProfileCacheEntry(); | ||
810 | uce.picksList = picks; | ||
811 | |||
805 | m_profilesCache.AddOrUpdate(targetId, uce, PROFILECACHEEXPIRE); | 812 | m_profilesCache.AddOrUpdate(targetId, uce, PROFILECACHEEXPIRE); |
813 | } | ||
806 | 814 | ||
807 | remoteClient.SendAvatarPicksReply(targetId, picks); | 815 | remoteClient.SendAvatarPicksReply(targetId, picks); |
808 | } | 816 | } |
@@ -903,14 +911,16 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
903 | m_log.DebugFormat("[PROFILES]: PickInfoRequest: {0} : {1}", pick.Name.ToString(), pick.SnapshotId.ToString()); | 911 | m_log.DebugFormat("[PROFILES]: PickInfoRequest: {0} : {1}", pick.Name.ToString(), pick.SnapshotId.ToString()); |
904 | 912 | ||
905 | pick.GlobalPos = globalPos.ToString(); | 913 | pick.GlobalPos = globalPos.ToString(); |
906 | if (uce == null) | ||
907 | uce = new UserProfileCacheEntry(); | ||
908 | if(uce.picks == null) | ||
909 | uce.picks = new Dictionary<UUID, UserProfilePick>(); | ||
910 | uce.picks[pick.PickId] = pick; | ||
911 | |||
912 | lock(m_profilesCache) | 914 | lock(m_profilesCache) |
915 | { | ||
916 | if(!m_profilesCache.TryGetValue(targetID, out uce) || uce == null) | ||
917 | uce = new UserProfileCacheEntry(); | ||
918 | if(uce.picks == null) | ||
919 | uce.picks = new Dictionary<UUID, UserProfilePick>(); | ||
920 | uce.picks[pick.PickId] = pick; | ||
921 | |||
913 | m_profilesCache.AddOrUpdate(targetID, uce, PROFILECACHEEXPIRE); | 922 | m_profilesCache.AddOrUpdate(targetID, uce, PROFILECACHEEXPIRE); |
923 | } | ||
914 | 924 | ||
915 | // Pull the rabbit out of the hat | 925 | // Pull the rabbit out of the hat |
916 | remoteClient.SendPickInfoReply(pick.PickId,pick.CreatorId,pick.TopPick,pick.ParcelId,pick.Name, | 926 | remoteClient.SendPickInfoReply(pick.PickId,pick.CreatorId,pick.TopPick,pick.ParcelId,pick.Name, |
@@ -950,7 +960,6 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
950 | /// </param> | 960 | /// </param> |
951 | public void PickInfoUpdate(IClientAPI remoteClient, UUID pickID, UUID creatorID, bool topPick, string name, string desc, UUID snapshotID, int sortOrder, bool enabled) | 961 | public void PickInfoUpdate(IClientAPI remoteClient, UUID pickID, UUID creatorID, bool topPick, string name, string desc, UUID snapshotID, int sortOrder, bool enabled) |
952 | { | 962 | { |
953 | //TODO: See how this works with NPC, May need to test | ||
954 | m_log.DebugFormat("[PROFILES]: Start PickInfoUpdate Name: {0} PickId: {1} SnapshotId: {2}", name, pickID.ToString(), snapshotID.ToString()); | 963 | m_log.DebugFormat("[PROFILES]: Start PickInfoUpdate Name: {0} PickId: {1} SnapshotId: {2}", name, pickID.ToString(), snapshotID.ToString()); |
955 | 964 | ||
956 | UserProfilePick pick = new UserProfilePick(); | 965 | UserProfilePick pick = new UserProfilePick(); |
@@ -1067,11 +1076,11 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1067 | { | 1076 | { |
1068 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | 1077 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) |
1069 | { | 1078 | { |
1070 | if(uce.picks != null && uce.picks.ContainsKey(queryPickID)) | 1079 | if(uce.picks != null && uce.picks.ContainsKey(queryPickID)) |
1071 | uce.picks.Remove(queryPickID); | 1080 | uce.picks.Remove(queryPickID); |
1072 | if(uce.picksList != null && uce.picksList.ContainsKey(queryPickID)) | 1081 | if(uce.picksList != null && uce.picksList.ContainsKey(queryPickID)) |
1073 | uce.picksList.Remove(queryPickID); | 1082 | uce.picksList.Remove(queryPickID); |
1074 | m_profilesCache.AddOrUpdate(remoteClient.AgentId, uce, PROFILECACHEEXPIRE); | 1083 | m_profilesCache.AddOrUpdate(remoteClient.AgentId, uce, PROFILECACHEEXPIRE); |
1075 | } | 1084 | } |
1076 | } | 1085 | } |
1077 | if(uce != null && uce.picksList != null) | 1086 | if(uce != null && uce.picksList != null) |
@@ -1259,15 +1268,6 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1259 | /// </param> | 1268 | /// </param> |
1260 | public void AvatarInterestsUpdate(IClientAPI remoteClient, uint wantmask, string wanttext, uint skillsmask, string skillstext, string languages) | 1269 | public void AvatarInterestsUpdate(IClientAPI remoteClient, uint wantmask, string wanttext, uint skillsmask, string skillstext, string languages) |
1261 | { | 1270 | { |
1262 | // flush cache for now | ||
1263 | UserProfileCacheEntry uce = null; | ||
1264 | lock(m_profilesCache) | ||
1265 | { | ||
1266 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
1267 | { | ||
1268 | uce.props = null; | ||
1269 | } | ||
1270 | } | ||
1271 | 1271 | ||
1272 | UserProfileProperties prop = new UserProfileProperties(); | 1272 | UserProfileProperties prop = new UserProfileProperties(); |
1273 | 1273 | ||
@@ -1290,6 +1290,17 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1290 | "Error updating interests", false); | 1290 | "Error updating interests", false); |
1291 | return; | 1291 | return; |
1292 | } | 1292 | } |
1293 | |||
1294 | // flush cache | ||
1295 | UserProfileCacheEntry uce = null; | ||
1296 | lock(m_profilesCache) | ||
1297 | { | ||
1298 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
1299 | { | ||
1300 | uce.props = null; | ||
1301 | } | ||
1302 | } | ||
1303 | |||
1293 | } | 1304 | } |
1294 | 1305 | ||
1295 | public void RequestAvatarProperties(IClientAPI remoteClient, UUID avatarID) | 1306 | public void RequestAvatarProperties(IClientAPI remoteClient, UUID avatarID) |
@@ -1399,15 +1410,17 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1399 | if(!m_allowUserProfileWebURLs) | 1410 | if(!m_allowUserProfileWebURLs) |
1400 | props.WebUrl =""; | 1411 | props.WebUrl =""; |
1401 | 1412 | ||
1402 | if(uce == null) | ||
1403 | uce = new UserProfileCacheEntry(); | ||
1404 | uce.props = props; | ||
1405 | uce.born = born; | ||
1406 | uce.membershipType = membershipType; | ||
1407 | uce.flags = flags; | ||
1408 | |||
1409 | lock(m_profilesCache) | 1413 | lock(m_profilesCache) |
1414 | { | ||
1415 | if(!m_profilesCache.TryGetValue(props.UserId, out uce) || uce == null) | ||
1416 | uce = new UserProfileCacheEntry(); | ||
1417 | uce.props = props; | ||
1418 | uce.born = born; | ||
1419 | uce.membershipType = membershipType; | ||
1420 | uce.flags = flags; | ||
1421 | |||
1410 | m_profilesCache.AddOrUpdate(props.UserId, uce, PROFILECACHEEXPIRE); | 1422 | m_profilesCache.AddOrUpdate(props.UserId, uce, PROFILECACHEEXPIRE); |
1423 | } | ||
1411 | 1424 | ||
1412 | remoteClient.SendAvatarProperties(props.UserId, props.AboutText, born, membershipType , props.FirstLifeText, flags, | 1425 | remoteClient.SendAvatarProperties(props.UserId, props.AboutText, born, membershipType , props.FirstLifeText, flags, |
1413 | props.FirstLifeImageId, props.ImageId, props.WebUrl, props.PartnerId); | 1426 | props.FirstLifeImageId, props.ImageId, props.WebUrl, props.PartnerId); |
@@ -1429,15 +1442,6 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1429 | { | 1442 | { |
1430 | if (remoteClient.AgentId == newProfile.ID) | 1443 | if (remoteClient.AgentId == newProfile.ID) |
1431 | { | 1444 | { |
1432 | // flush cache for now | ||
1433 | UserProfileCacheEntry uce = null; | ||
1434 | lock(m_profilesCache) | ||
1435 | { | ||
1436 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
1437 | { | ||
1438 | uce.props = null; | ||
1439 | } | ||
1440 | } | ||
1441 | 1445 | ||
1442 | UserProfileProperties prop = new UserProfileProperties(); | 1446 | UserProfileProperties prop = new UserProfileProperties(); |
1443 | 1447 | ||
@@ -1463,6 +1467,16 @@ namespace OpenSim.Region.CoreModules.Avatar.UserProfiles | |||
1463 | return; | 1467 | return; |
1464 | } | 1468 | } |
1465 | 1469 | ||
1470 | // flush cache | ||
1471 | UserProfileCacheEntry uce = null; | ||
1472 | lock(m_profilesCache) | ||
1473 | { | ||
1474 | if(m_profilesCache.TryGetValue(remoteClient.AgentId, out uce) && uce != null) | ||
1475 | { | ||
1476 | uce.props = null; | ||
1477 | } | ||
1478 | } | ||
1479 | |||
1466 | RequestAvatarProperties(remoteClient, newProfile.ID); | 1480 | RequestAvatarProperties(remoteClient, newProfile.ID); |
1467 | } | 1481 | } |
1468 | } | 1482 | } |