diff options
author | Melanie Thielker | 2008-11-21 07:33:13 +0000 |
---|---|---|
committer | Melanie Thielker | 2008-11-21 07:33:13 +0000 |
commit | ee4d4d784eb9b51b29fe4bda3fc9ec3594d24f5a (patch) | |
tree | 9ce899e33c2550d61048ca0690ba5e103aa8abd6 /OpenSim/Region/Environment/Scenes | |
parent | Allow selecting group objects and selecting objects by owner from the (diff) | |
download | opensim-SC-ee4d4d784eb9b51b29fe4bda3fc9ec3594d24f5a.zip opensim-SC-ee4d4d784eb9b51b29fe4bda3fc9ec3594d24f5a.tar.gz opensim-SC-ee4d4d784eb9b51b29fe4bda3fc9ec3594d24f5a.tar.bz2 opensim-SC-ee4d4d784eb9b51b29fe4bda3fc9ec3594d24f5a.tar.xz |
Fully implement object return from the parcel dialog
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/Environment/Scenes/ReturnInfo.cs | 1 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Scenes/Scene.Inventory.cs | 144 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Scenes/Scene.cs | 90 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs | 2 |
4 files changed, 58 insertions, 179 deletions
diff --git a/OpenSim/Region/Environment/Scenes/ReturnInfo.cs b/OpenSim/Region/Environment/Scenes/ReturnInfo.cs index 68c563d..898baab 100644 --- a/OpenSim/Region/Environment/Scenes/ReturnInfo.cs +++ b/OpenSim/Region/Environment/Scenes/ReturnInfo.cs | |||
@@ -34,5 +34,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
34 | public int count; | 34 | public int count; |
35 | public Vector3 location; | 35 | public Vector3 location; |
36 | public string objectName; | 36 | public string objectName; |
37 | public string reason; | ||
37 | } | 38 | } |
38 | } | 39 | } |
diff --git a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs index 79d79ef..19b8e16 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs | |||
@@ -1610,6 +1610,10 @@ namespace OpenSim.Region.Environment.Scenes | |||
1610 | ExternalChecks.ExternalChecksCanDeleteObject( | 1610 | ExternalChecks.ExternalChecksCanDeleteObject( |
1611 | grp.UUID, | 1611 | grp.UUID, |
1612 | remoteClient.AgentId); | 1612 | remoteClient.AgentId); |
1613 | if (permissionToDelete) | ||
1614 | { | ||
1615 | AddReturn(grp.OwnerID, grp.Name, grp.AbsolutePosition, "parcel owner return"); | ||
1616 | } | ||
1613 | } | 1617 | } |
1614 | else // Auto return passes through here with null agent | 1618 | else // Auto return passes through here with null agent |
1615 | { | 1619 | { |
@@ -2207,145 +2211,13 @@ namespace OpenSim.Region.Environment.Scenes | |||
2207 | 2211 | ||
2208 | public virtual bool returnObjects(SceneObjectGroup[] returnobjects, UUID AgentId) | 2212 | public virtual bool returnObjects(SceneObjectGroup[] returnobjects, UUID AgentId) |
2209 | { | 2213 | { |
2210 | string message = ""; | 2214 | foreach (SceneObjectGroup grp in returnobjects) |
2211 | if (returnobjects.Length <= 0) | ||
2212 | return false; | ||
2213 | |||
2214 | // for the moment we're going to store them individually.. however, in the future, the rezObject | ||
2215 | // will be able to have more items. | ||
2216 | |||
2217 | //string returnstring = ""; | ||
2218 | //returnstring += "<scene>\n"; | ||
2219 | //for (int i = 0; i < returnobjects.Length; i++) | ||
2220 | //{ | ||
2221 | // returnstring += grp.ToXmlString2(); | ||
2222 | //} | ||
2223 | //returnstring += "</scene>\n"; | ||
2224 | |||
2225 | bool permissionToDelete = false; | ||
2226 | |||
2227 | for (int i = 0; i < returnobjects.Length; i++) | ||
2228 | { | ||
2229 | CachedUserInfo userInfo = | ||
2230 | CommsManager.UserProfileCacheService.GetUserDetails(returnobjects[i].OwnerID); | ||
2231 | if (userInfo == null) | ||
2232 | { | ||
2233 | CommsManager.UserProfileCacheService.AddNewUser(returnobjects[i].OwnerID); | ||
2234 | |||
2235 | } | ||
2236 | if (userInfo != null) | ||
2237 | { | ||
2238 | if (userInfo.HasReceivedInventory) | ||
2239 | { | ||
2240 | UUID folderID = UUID.Zero; | ||
2241 | |||
2242 | List<InventoryFolderBase> subrootfolders = userInfo.RootFolder.RequestListOfFolders(); | ||
2243 | foreach (InventoryFolderBase flder in subrootfolders) | ||
2244 | { | ||
2245 | if (flder.Name == "Lost And Found") | ||
2246 | { | ||
2247 | folderID = flder.ID; | ||
2248 | break; | ||
2249 | } | ||
2250 | } | ||
2251 | |||
2252 | if (folderID == UUID.Zero) | ||
2253 | { | ||
2254 | folderID = userInfo.RootFolder.ID; | ||
2255 | } | ||
2256 | permissionToDelete = ExternalChecks.ExternalChecksCanReturnObject(returnobjects[i].UUID, AgentId); | ||
2257 | |||
2258 | // If the user doesn't have permission, go on to the next one. | ||
2259 | if (!permissionToDelete) | ||
2260 | continue; | ||
2261 | |||
2262 | string sceneObjectXml = returnobjects[i].ToXmlString2(); | ||
2263 | AssetBase asset = CreateAsset( | ||
2264 | returnobjects[i].GetPartName(returnobjects[i].LocalId), | ||
2265 | returnobjects[i].GetPartDescription(returnobjects[i].LocalId), | ||
2266 | (sbyte)AssetType.Object, | ||
2267 | Utils.StringToBytes(sceneObjectXml)); | ||
2268 | AssetCache.AddAsset(asset); | ||
2269 | |||
2270 | InventoryItemBase item = new InventoryItemBase(); | ||
2271 | item.Creator = returnobjects[i].RootPart.CreatorID; | ||
2272 | item.Owner = returnobjects[i].OwnerID; | ||
2273 | item.ID = UUID.Random(); | ||
2274 | item.AssetID = asset.FullID; | ||
2275 | item.Description = asset.Description; | ||
2276 | item.Name = asset.Name; | ||
2277 | item.AssetType = asset.Type; | ||
2278 | item.InvType = (int)InventoryType.Object; | ||
2279 | item.Folder = folderID; | ||
2280 | |||
2281 | if ((AgentId != returnobjects[i].RootPart.OwnerID) && ExternalChecks.ExternalChecksPropagatePermissions()) | ||
2282 | { | ||
2283 | uint perms = returnobjects[i].GetEffectivePermissions(); | ||
2284 | uint nextPerms = (perms & 7) << 13; | ||
2285 | if ((nextPerms & (uint)PermissionMask.Copy) == 0) | ||
2286 | perms &= ~(uint)PermissionMask.Copy; | ||
2287 | if ((nextPerms & (uint)PermissionMask.Transfer) == 0) | ||
2288 | perms &= ~(uint)PermissionMask.Transfer; | ||
2289 | if ((nextPerms & (uint)PermissionMask.Modify) == 0) | ||
2290 | perms &= ~(uint)PermissionMask.Modify; | ||
2291 | |||
2292 | item.BasePermissions = perms & returnobjects[i].RootPart.NextOwnerMask; | ||
2293 | item.CurrentPermissions = item.BasePermissions; | ||
2294 | item.NextPermissions = returnobjects[i].RootPart.NextOwnerMask; | ||
2295 | item.EveryOnePermissions = returnobjects[i].RootPart.EveryoneMask & returnobjects[i].RootPart.NextOwnerMask; | ||
2296 | item.GroupPermissions = returnobjects[i].RootPart.GroupMask & returnobjects[i].RootPart.NextOwnerMask; | ||
2297 | item.CurrentPermissions |= 8; // Slam! | ||
2298 | } | ||
2299 | else | ||
2300 | { | ||
2301 | item.BasePermissions = returnobjects[i].GetEffectivePermissions(); | ||
2302 | item.CurrentPermissions = returnobjects[i].GetEffectivePermissions(); | ||
2303 | item.NextPermissions = returnobjects[i].RootPart.NextOwnerMask; | ||
2304 | item.EveryOnePermissions = returnobjects[i].RootPart.EveryoneMask; | ||
2305 | item.GroupPermissions = returnobjects[i].RootPart.GroupMask; | ||
2306 | } | ||
2307 | |||
2308 | // TODO: add the new fields (Flags, Sale info, etc) | ||
2309 | |||
2310 | userInfo.AddItem(item); | ||
2311 | |||
2312 | ScenePresence notifyUser = GetScenePresence(item.Owner); | ||
2313 | if (notifyUser != null) | ||
2314 | { | ||
2315 | notifyUser.ControllingClient.SendInventoryItemCreateUpdate(item); | ||
2316 | } | ||
2317 | |||
2318 | SceneObjectGroup ObjectDeleting = returnobjects[i]; | ||
2319 | |||
2320 | returnobjects[i] = null; | ||
2321 | |||
2322 | DeleteSceneObject(ObjectDeleting, false); | ||
2323 | ObjectDeleting = null; | ||
2324 | } | ||
2325 | else | ||
2326 | { | ||
2327 | CommsManager.UserProfileCacheService.RequestInventoryForUser(returnobjects[i].OwnerID); | ||
2328 | message = "Still waiting on the inventory service, some of the items won't be returned until the inventory services completes it's task. Try again shortly."; | ||
2329 | } | ||
2330 | } | ||
2331 | else | ||
2332 | { | ||
2333 | message = "Still waiting on the inventory service, some of the items won't be returned until the inventory services completes it's task. Try again shortly."; | ||
2334 | } | ||
2335 | //return true; | ||
2336 | } | ||
2337 | |||
2338 | if (message.Length != 0) | ||
2339 | { | 2215 | { |
2340 | ScenePresence returningavatar = GetScenePresence(AgentId); | 2216 | AddReturn(grp.OwnerID, grp.Name, grp.AbsolutePosition, "parcel owner return"); |
2341 | if (returningavatar != null) | 2217 | DeRezObject(null, grp.RootPart.LocalId, |
2342 | { | 2218 | grp.RootPart.GroupID, 9, UUID.Zero); |
2343 | returningavatar.ControllingClient.SendAlertMessage(message); | ||
2344 | } | ||
2345 | return false; | ||
2346 | } | 2219 | } |
2347 | return true; | 2220 | return true; |
2348 | |||
2349 | } | 2221 | } |
2350 | 2222 | ||
2351 | public void SetScriptRunning(IClientAPI controllingClient, UUID objectID, UUID itemID, bool running) | 2223 | public void SetScriptRunning(IClientAPI controllingClient, UUID objectID, UUID itemID, bool running) |
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index f37ba25..741c47e 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs | |||
@@ -966,54 +966,60 @@ namespace OpenSim.Region.Environment.Scenes | |||
966 | /// <returns></returns> | 966 | /// <returns></returns> |
967 | public void Backup() | 967 | public void Backup() |
968 | { | 968 | { |
969 | m_returns.Clear(); | 969 | lock(m_returns) |
970 | 970 | { | |
971 | EventManager.TriggerOnBackup(m_storageManager.DataStore); | 971 | EventManager.TriggerOnBackup(m_storageManager.DataStore); |
972 | m_backingup = false; | 972 | m_backingup = false; |
973 | |||
974 | foreach (KeyValuePair<UUID, ReturnInfo> ret in m_returns) | ||
975 | { | ||
976 | UUID transaction = UUID.Random(); | ||
977 | |||
978 | GridInstantMessage msg = new GridInstantMessage(); | ||
979 | msg.fromAgentID = new Guid(UUID.Zero.ToString()); // From server | ||
980 | msg.toAgentID = new Guid(ret.Key.ToString()); | ||
981 | msg.imSessionID = new Guid(transaction.ToString()); | ||
982 | msg.timestamp = (uint)Util.UnixTimeSinceEpoch(); | ||
983 | msg.fromAgentName = "Server"; | ||
984 | msg.dialog = (byte)19; // Object msg | ||
985 | msg.fromGroup = false; | ||
986 | msg.offline = (byte)1; | ||
987 | msg.ParentEstateID = RegionInfo.EstateSettings.ParentEstateID; | ||
988 | msg.Position = Vector3.Zero; | ||
989 | msg.RegionID = RegionInfo.RegionID.Guid; | ||
990 | msg.binaryBucket = new byte[0]; | ||
991 | if (ret.Value.count > 1) | ||
992 | msg.message = string.Format("Your {0} objects were returned from {1} in region {2} due to parcel auto return", ret.Value.count, ret.Value.location.ToString(), RegionInfo.RegionName); | ||
993 | else | ||
994 | msg.message = string.Format("Your object {0} was returned from {1} in region {2} due to parcel auto return", ret.Value.objectName, ret.Value.location.ToString(), RegionInfo.RegionName); | ||
995 | 973 | ||
996 | IMessageTransferModule tr = RequestModuleInterface<IMessageTransferModule>(); | 974 | foreach (KeyValuePair<UUID, ReturnInfo> ret in m_returns) |
997 | if (tr != null) | 975 | { |
998 | tr.SendInstantMessage(msg, delegate(bool success) {} ); | 976 | UUID transaction = UUID.Random(); |
977 | |||
978 | GridInstantMessage msg = new GridInstantMessage(); | ||
979 | msg.fromAgentID = new Guid(UUID.Zero.ToString()); // From server | ||
980 | msg.toAgentID = new Guid(ret.Key.ToString()); | ||
981 | msg.imSessionID = new Guid(transaction.ToString()); | ||
982 | msg.timestamp = (uint)Util.UnixTimeSinceEpoch(); | ||
983 | msg.fromAgentName = "Server"; | ||
984 | msg.dialog = (byte)19; // Object msg | ||
985 | msg.fromGroup = false; | ||
986 | msg.offline = (byte)1; | ||
987 | msg.ParentEstateID = RegionInfo.EstateSettings.ParentEstateID; | ||
988 | msg.Position = Vector3.Zero; | ||
989 | msg.RegionID = RegionInfo.RegionID.Guid; | ||
990 | msg.binaryBucket = new byte[0]; | ||
991 | if (ret.Value.count > 1) | ||
992 | msg.message = string.Format("Your {0} objects were returned from {1} in region {2} due to {3}", ret.Value.count, ret.Value.location.ToString(), RegionInfo.RegionName, ret.Value.reason); | ||
993 | else | ||
994 | msg.message = string.Format("Your object {0} was returned from {1} in region {2} due to {3}", ret.Value.objectName, ret.Value.location.ToString(), RegionInfo.RegionName, ret.Value.reason); | ||
995 | |||
996 | IMessageTransferModule tr = RequestModuleInterface<IMessageTransferModule>(); | ||
997 | if (tr != null) | ||
998 | tr.SendInstantMessage(msg, delegate(bool success) {} ); | ||
999 | } | ||
1000 | m_returns.Clear(); | ||
999 | } | 1001 | } |
1000 | } | 1002 | } |
1001 | 1003 | ||
1002 | public void AddReturn(UUID agentID, string objectName, Vector3 location) | 1004 | public void AddReturn(UUID agentID, string objectName, Vector3 location, string reason) |
1003 | { | 1005 | { |
1004 | if (m_returns.ContainsKey(agentID)) | 1006 | lock(m_returns) |
1005 | { | ||
1006 | ReturnInfo info = m_returns[agentID]; | ||
1007 | info.count++; | ||
1008 | m_returns[agentID] = info; | ||
1009 | } | ||
1010 | else | ||
1011 | { | 1007 | { |
1012 | ReturnInfo info = new ReturnInfo(); | 1008 | if (m_returns.ContainsKey(agentID)) |
1013 | info.count = 1; | 1009 | { |
1014 | info.objectName = objectName; | 1010 | ReturnInfo info = m_returns[agentID]; |
1015 | info.location = location; | 1011 | info.count++; |
1016 | m_returns[agentID] = info; | 1012 | m_returns[agentID] = info; |
1013 | } | ||
1014 | else | ||
1015 | { | ||
1016 | ReturnInfo info = new ReturnInfo(); | ||
1017 | info.count = 1; | ||
1018 | info.objectName = objectName; | ||
1019 | info.location = location; | ||
1020 | info.reason = reason; | ||
1021 | m_returns[agentID] = info; | ||
1022 | } | ||
1017 | } | 1023 | } |
1018 | } | 1024 | } |
1019 | 1025 | ||
diff --git a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs index 82ab4eb..e8eaef8 100644 --- a/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs +++ b/OpenSim/Region/Environment/Scenes/SceneObjectGroup.cs | |||
@@ -1224,7 +1224,7 @@ namespace OpenSim.Region.Environment.Scenes | |||
1224 | parcel.landData.OtherCleanTime) | 1224 | parcel.landData.OtherCleanTime) |
1225 | { | 1225 | { |
1226 | m_log.InfoFormat("[SCENE] Returning object {0} due to parcel auto return", RootPart.UUID.ToString()); | 1226 | m_log.InfoFormat("[SCENE] Returning object {0} due to parcel auto return", RootPart.UUID.ToString()); |
1227 | m_scene.AddReturn(OwnerID, Name, AbsolutePosition); | 1227 | m_scene.AddReturn(OwnerID, Name, AbsolutePosition, "parcel auto return"); |
1228 | m_scene.DeRezObject(null, RootPart.LocalId, | 1228 | m_scene.DeRezObject(null, RootPart.LocalId, |
1229 | RootPart.GroupID, 9, UUID.Zero); | 1229 | RootPart.GroupID, 9, UUID.Zero); |
1230 | 1230 | ||