Merge branch 'avination-current' of ssh://3dhosting.de/var/git/careminster into avination-current
						commit
						fc1bd4567d
					
				|  | @ -41,6 +41,7 @@ namespace OpenSim.Framework | ||||||
| 
 | 
 | ||||||
|         // "Out of band" managemnt https |         // "Out of band" managemnt https | ||||||
|         public bool ssl_listener = false; |         public bool ssl_listener = false; | ||||||
|  |         public bool ssl_external = false; | ||||||
|         public uint https_port = 0; |         public uint https_port = 0; | ||||||
|         public string cert_path = String.Empty; |         public string cert_path = String.Empty; | ||||||
|         public string cert_pass = String.Empty; |         public string cert_pass = String.Empty; | ||||||
|  | @ -64,6 +65,7 @@ namespace OpenSim.Framework | ||||||
| 
 | 
 | ||||||
|             // "Out of band management https" |             // "Out of band management https" | ||||||
|             ssl_listener = config.Configs["Network"].GetBoolean("https_listener",false); |             ssl_listener = config.Configs["Network"].GetBoolean("https_listener",false); | ||||||
|  |             ssl_external = config.Configs["Network"].GetBoolean("https_external",false); | ||||||
|             if( ssl_listener) |             if( ssl_listener) | ||||||
|             { |             { | ||||||
|                 cert_path = config.Configs["Network"].GetString("cert_path",String.Empty); |                 cert_path = config.Configs["Network"].GetString("cert_path",String.Empty); | ||||||
|  |  | ||||||
|  | @ -224,10 +224,12 @@ namespace OpenSim.Framework | ||||||
|         // |         // | ||||||
|         public RegionInfo(string description, XmlNode xmlNode, bool skipConsoleConfig, IConfigSource configSource) |         public RegionInfo(string description, XmlNode xmlNode, bool skipConsoleConfig, IConfigSource configSource) | ||||||
|         { |         { | ||||||
|             // m_configSource = configSource; |             XmlElement elem = (XmlElement)xmlNode; | ||||||
|             configMember = |             string name = elem.GetAttribute("Name"); | ||||||
|                 new ConfigurationMember(xmlNode, description, loadConfigurationOptions, handleIncomingConfiguration, !skipConsoleConfig); |             string xmlstr = "<Nini>" + xmlNode.OuterXml + "</Nini>"; | ||||||
|             configMember.performConfigurationRetrieve(); |             XmlConfigSource source = new XmlConfigSource(XmlReader.Create(new StringReader(xmlstr))); | ||||||
|  |             ReadNiniConfig(source, name); | ||||||
|  | 
 | ||||||
|             m_serverURI = string.Empty; |             m_serverURI = string.Empty; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -93,7 +93,7 @@ namespace OpenSim.Framework.RegionLoader.Web | ||||||
| 										xmlSource.Length); | 										xmlSource.Length); | ||||||
| 							XmlDocument xmlDoc = new XmlDocument(); | 							XmlDocument xmlDoc = new XmlDocument(); | ||||||
| 							xmlDoc.LoadXml(xmlSource); | 							xmlDoc.LoadXml(xmlSource); | ||||||
| 							if (xmlDoc.FirstChild.Name == "Regions") | 							if (xmlDoc.FirstChild.Name == "Nini") | ||||||
|                             { |                             { | ||||||
| 								regionCount = xmlDoc.FirstChild.ChildNodes.Count; | 								regionCount = xmlDoc.FirstChild.ChildNodes.Count; | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
|  | @ -2232,10 +2232,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void SendAgentDataUpdate(UUID agentid, UUID activegroupid, string firstname, string lastname, ulong grouppowers, string groupname, string grouptitle) |         public void SendAgentDataUpdate(UUID agentid, UUID activegroupid, string firstname, string lastname, ulong grouppowers, string groupname, string grouptitle) | ||||||
|  |         { | ||||||
|  |             if (agentid == AgentId) | ||||||
|             { |             { | ||||||
|                 m_activeGroupID = activegroupid; |                 m_activeGroupID = activegroupid; | ||||||
|                 m_activeGroupName = groupname; |                 m_activeGroupName = groupname; | ||||||
|                 m_activeGroupPowers = grouppowers; |                 m_activeGroupPowers = grouppowers; | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             AgentDataUpdatePacket sendAgentDataUpdate = (AgentDataUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentDataUpdate); |             AgentDataUpdatePacket sendAgentDataUpdate = (AgentDataUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentDataUpdate); | ||||||
|             sendAgentDataUpdate.AgentData.ActiveGroupID = activegroupid; |             sendAgentDataUpdate.AgentData.ActiveGroupID = activegroupid; | ||||||
|  |  | ||||||
|  | @ -99,6 +99,8 @@ namespace OpenSim.Region.ClientStack | ||||||
| 
 | 
 | ||||||
|             // "OOB" Server |             // "OOB" Server | ||||||
|             if (m_networkServersInfo.ssl_listener) |             if (m_networkServersInfo.ssl_listener) | ||||||
|  |             { | ||||||
|  |                 if (!m_networkServersInfo.ssl_external) | ||||||
|                 { |                 { | ||||||
|                     BaseHttpServer server = new BaseHttpServer( |                     BaseHttpServer server = new BaseHttpServer( | ||||||
|                         m_networkServersInfo.https_port, m_networkServersInfo.ssl_listener, m_networkServersInfo.cert_path, |                         m_networkServersInfo.https_port, m_networkServersInfo.ssl_listener, m_networkServersInfo.cert_path, | ||||||
|  | @ -108,6 +110,16 @@ namespace OpenSim.Region.ClientStack | ||||||
|                     MainServer.AddHttpServer(server); |                     MainServer.AddHttpServer(server); | ||||||
|                     server.Start(); |                     server.Start(); | ||||||
|                 } |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     BaseHttpServer server = new BaseHttpServer( | ||||||
|  |                         m_networkServersInfo.https_port); | ||||||
|  | 
 | ||||||
|  |                     m_log.InfoFormat("[REGION SERVER]: Starting HTTP server on port {0} for external HTTPS", server.Port); | ||||||
|  |                     MainServer.AddHttpServer(server); | ||||||
|  |                     server.Start(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|              |              | ||||||
|             base.StartupSpecific(); |             base.StartupSpecific(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -40,6 +40,13 @@ using OpenSim.Region.Framework.Scenes; | ||||||
| 
 | 
 | ||||||
| namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | ||||||
| { | { | ||||||
|  |     public struct SendReply | ||||||
|  |     { | ||||||
|  |         public bool Success; | ||||||
|  |         public string Message; | ||||||
|  |         public int Disposition; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "OfflineMessageModule")] |     [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "OfflineMessageModule")] | ||||||
|     public class OfflineMessageModule : ISharedRegionModule |     public class OfflineMessageModule : ISharedRegionModule | ||||||
|     { |     { | ||||||
|  | @ -50,6 +57,7 @@ namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | ||||||
|         private string m_RestURL = String.Empty; |         private string m_RestURL = String.Empty; | ||||||
|         IMessageTransferModule m_TransferModule = null; |         IMessageTransferModule m_TransferModule = null; | ||||||
|         private bool m_ForwardOfflineGroupMessages = true; |         private bool m_ForwardOfflineGroupMessages = true; | ||||||
|  |         private Dictionary<IClientAPI, List<UUID>> m_repliesSent= new Dictionary<IClientAPI, List<UUID>>(); | ||||||
| 
 | 
 | ||||||
|         public void Initialise(IConfigSource config) |         public void Initialise(IConfigSource config) | ||||||
|         { |         { | ||||||
|  | @ -169,6 +177,12 @@ namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | ||||||
|         private void OnNewClient(IClientAPI client) |         private void OnNewClient(IClientAPI client) | ||||||
|         { |         { | ||||||
|             client.OnRetrieveInstantMessages += RetrieveInstantMessages; |             client.OnRetrieveInstantMessages += RetrieveInstantMessages; | ||||||
|  |             client.OnLogout += OnClientLoggedOut; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public void OnClientLoggedOut(IClientAPI client) | ||||||
|  |         { | ||||||
|  |             m_repliesSent.Remove(client); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void RetrieveInstantMessages(IClientAPI client) |         private void RetrieveInstantMessages(IClientAPI client) | ||||||
|  | @ -228,7 +242,7 @@ namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | ||||||
|             if (scene == null) |             if (scene == null) | ||||||
|                 scene = m_SceneList[0]; |                 scene = m_SceneList[0]; | ||||||
| 
 | 
 | ||||||
|             bool success = SynchronousRestObjectRequester.MakeRequest<GridInstantMessage, bool>( |             SendReply reply = SynchronousRestObjectRequester.MakeRequest<GridInstantMessage, SendReply>( | ||||||
|                     "POST", m_RestURL+"/SaveMessage/?scope=" + |                     "POST", m_RestURL+"/SaveMessage/?scope=" + | ||||||
|                     scene.RegionInfo.ScopeID.ToString(), im); |                     scene.RegionInfo.ScopeID.ToString(), im); | ||||||
| 
 | 
 | ||||||
|  | @ -238,15 +252,40 @@ namespace OpenSim.Region.CoreModules.Avatar.InstantMessage | ||||||
|                 if (client == null) |                 if (client == null) | ||||||
|                     return; |                     return; | ||||||
| 
 | 
 | ||||||
|  |                 if (reply.Message == String.Empty) | ||||||
|  |                     reply.Message = "User is not logged in. " + (reply.Success ? "Message saved." : "Message not saved"); | ||||||
|  | 
 | ||||||
|  |                 bool sendReply = true; | ||||||
|  | 
 | ||||||
|  |                 switch (reply.Disposition) | ||||||
|  |                 { | ||||||
|  |                 case 0: // Normal | ||||||
|  |                     break; | ||||||
|  |                 case 1: // Only once per user | ||||||
|  |                     if (m_repliesSent.ContainsKey(client) && m_repliesSent[client].Contains(new UUID(im.toAgentID))) | ||||||
|  |                     { | ||||||
|  |                         sendReply = false; | ||||||
|  |                     } | ||||||
|  |                     else | ||||||
|  |                     { | ||||||
|  |                         if (!m_repliesSent.ContainsKey(client)) | ||||||
|  |                             m_repliesSent[client] = new List<UUID>(); | ||||||
|  |                         m_repliesSent[client].Add(new UUID(im.toAgentID)); | ||||||
|  |                     } | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (sendReply) | ||||||
|  |                 { | ||||||
|                     client.SendInstantMessage(new GridInstantMessage( |                     client.SendInstantMessage(new GridInstantMessage( | ||||||
|                             null, new UUID(im.toAgentID), |                             null, new UUID(im.toAgentID), | ||||||
|                             "System", new UUID(im.fromAgentID), |                             "System", new UUID(im.fromAgentID), | ||||||
|                             (byte)InstantMessageDialog.MessageFromAgent, |                             (byte)InstantMessageDialog.MessageFromAgent, | ||||||
|                         "User is not logged in. "+ |                             reply.Message, | ||||||
|                         (success ? "Message saved." : "Message not saved"), |  | ||||||
|                             false, new Vector3())); |                             false, new Vector3())); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -96,6 +96,10 @@ namespace OpenSim.Region.CoreModules.World.Estate | ||||||
| 
 | 
 | ||||||
|             m_commands = new EstateManagementCommands(this); |             m_commands = new EstateManagementCommands(this); | ||||||
|             m_commands.Initialise(); |             m_commands.Initialise(); | ||||||
|  | 
 | ||||||
|  |             m_regionChangeTimer.Interval = 10000; | ||||||
|  |             m_regionChangeTimer.Elapsed += RaiseRegionInfoChange; | ||||||
|  |             m_regionChangeTimer.AutoReset = false; | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         public void RemoveRegion(Scene scene) {}             |         public void RemoveRegion(Scene scene) {}             | ||||||
|  |  | ||||||
|  | @ -565,7 +565,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                     requiredPowers = GroupPowers.LandManageBanned; |                     requiredPowers = GroupPowers.LandManageBanned; | ||||||
| 
 | 
 | ||||||
|                 if (m_scene.Permissions.CanEditParcelProperties(agentID, |                 if (m_scene.Permissions.CanEditParcelProperties(agentID, | ||||||
|                         land, requiredPowers)) |                         land, requiredPowers, false)) | ||||||
|                 { |                 { | ||||||
|                     land.UpdateAccessList(flags, transactionID, sequenceID, |                     land.UpdateAccessList(flags, transactionID, sequenceID, | ||||||
|                             sections, entries, remote_client); |                             sections, entries, remote_client); | ||||||
|  | @ -927,7 +927,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
| 
 | 
 | ||||||
|             //If we are still here, then they are subdividing within one piece of land |             //If we are still here, then they are subdividing within one piece of land | ||||||
|             //Check owner |             //Check owner | ||||||
|             if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, startLandObject, GroupPowers.LandDivideJoin)) |             if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, startLandObject, GroupPowers.LandDivideJoin, true)) | ||||||
|             { |             { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  | @ -996,7 +996,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|             { |             { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, masterLandObject, GroupPowers.LandDivideJoin)) |             if (!m_scene.Permissions.CanEditParcelProperties(attempting_user_id, masterLandObject, GroupPowers.LandDivideJoin, true)) | ||||||
|             { |             { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  | @ -1727,7 +1727,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
| 
 | 
 | ||||||
|             if (land == null) return; |             if (land == null) return; | ||||||
| 
 | 
 | ||||||
|             if (!m_scene.Permissions.CanEditParcelProperties(remoteClient.AgentId, land, GroupPowers.LandOptions)) |             if (!m_scene.Permissions.CanEditParcelProperties(remoteClient.AgentId, land, GroupPowers.LandOptions, false)) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|             land.LandData.OtherCleanTime = otherCleanTime; |             land.LandData.OtherCleanTime = otherCleanTime; | ||||||
|  | @ -1827,7 +1827,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|             if (targetAvatar.UserLevel == 0) |             if (targetAvatar.UserLevel == 0) | ||||||
|             { |             { | ||||||
|                 ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); |                 ILandObject land = ((Scene)client.Scene).LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); | ||||||
|                 if (!((Scene)client.Scene).Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze)) |                 if (!((Scene)client.Scene).Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze, true)) | ||||||
|                     return; |                     return; | ||||||
|                 if (flags == 0) |                 if (flags == 0) | ||||||
|                 { |                 { | ||||||
|  | @ -1876,7 +1876,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
| 
 | 
 | ||||||
|             // Check if you even have permission to do this |             // Check if you even have permission to do this | ||||||
|             ILandObject land = m_scene.LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); |             ILandObject land = m_scene.LandChannel.GetLandObject(targetAvatar.AbsolutePosition.X, targetAvatar.AbsolutePosition.Y); | ||||||
|             if (!m_scene.Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze) && |             if (!m_scene.Permissions.CanEditParcelProperties(client.AgentId, land, GroupPowers.LandEjectAndFreeze, true) && | ||||||
|                 !m_scene.Permissions.IsAdministrator(client.AgentId)) |                 !m_scene.Permissions.IsAdministrator(client.AgentId)) | ||||||
|                 return; |                 return; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -286,7 +286,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|             // ParcelFlags.ForSaleObjects |             // ParcelFlags.ForSaleObjects | ||||||
|             // ParcelFlags.LindenHome |             // ParcelFlags.LindenHome | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions, false)) | ||||||
|             { |             { | ||||||
|                 allowedDelta |= (uint)(ParcelFlags.AllowLandmark | |                 allowedDelta |= (uint)(ParcelFlags.AllowLandmark | | ||||||
|                         ParcelFlags.AllowTerraform | |                         ParcelFlags.AllowTerraform | | ||||||
|  | @ -301,7 +301,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                         ParcelFlags.AllowFly); |                         ParcelFlags.AllowFly); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandSetSale)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandSetSale, true)) | ||||||
|             { |             { | ||||||
|                 if (args.AuthBuyerID != newData.AuthBuyerID || |                 if (args.AuthBuyerID != newData.AuthBuyerID || | ||||||
|                     args.SalePrice != newData.SalePrice) |                     args.SalePrice != newData.SalePrice) | ||||||
|  | @ -324,7 +324,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                 allowedDelta |= (uint)ParcelFlags.ForSale; |                 allowedDelta |= (uint)ParcelFlags.ForSale; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.FindPlaces)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.FindPlaces, false)) | ||||||
|             { |             { | ||||||
|                 newData.Category = args.Category; |                 newData.Category = args.Category; | ||||||
| 
 | 
 | ||||||
|  | @ -333,21 +333,21 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                         ParcelFlags.MaturePublish) | (uint)(1 << 23); |                         ParcelFlags.MaturePublish) | (uint)(1 << 23); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandChangeIdentity)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandChangeIdentity, false)) | ||||||
|             { |             { | ||||||
|                 newData.Description = args.Desc; |                 newData.Description = args.Desc; | ||||||
|                 newData.Name = args.Name; |                 newData.Name = args.Name; | ||||||
|                 newData.SnapshotID = args.SnapshotID; |                 newData.SnapshotID = args.SnapshotID; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.SetLandingPoint)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.SetLandingPoint, false)) | ||||||
|             { |             { | ||||||
|                 newData.LandingType = args.LandingType; |                 newData.LandingType = args.LandingType; | ||||||
|                 newData.UserLocation = args.UserLocation; |                 newData.UserLocation = args.UserLocation; | ||||||
|                 newData.UserLookAt = args.UserLookAt; |                 newData.UserLookAt = args.UserLookAt; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.ChangeMedia)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.ChangeMedia, false)) | ||||||
|             { |             { | ||||||
|                 newData.MediaAutoScale = args.MediaAutoScale; |                 newData.MediaAutoScale = args.MediaAutoScale; | ||||||
|                 newData.MediaID = args.MediaID; |                 newData.MediaID = args.MediaID; | ||||||
|  | @ -368,7 +368,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                         ParcelFlags.UseEstateVoiceChan); |                         ParcelFlags.UseEstateVoiceChan); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandManagePasses)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId,this, GroupPowers.LandManagePasses, false)) | ||||||
|             { |             { | ||||||
|                 newData.PassHours = args.PassHours; |                 newData.PassHours = args.PassHours; | ||||||
|                 newData.PassPrice = args.PassPrice; |                 newData.PassPrice = args.PassPrice; | ||||||
|  | @ -376,26 +376,28 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|                 allowedDelta |= (uint)ParcelFlags.UsePassList; |                 allowedDelta |= (uint)ParcelFlags.UsePassList; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageAllowed)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageAllowed, false)) | ||||||
|             { |             { | ||||||
|                 allowedDelta |= (uint)(ParcelFlags.UseAccessGroup | |                 allowedDelta |= (uint)(ParcelFlags.UseAccessGroup | | ||||||
|                         ParcelFlags.UseAccessList); |                         ParcelFlags.UseAccessList); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageBanned)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandManageBanned, false)) | ||||||
|             { |             { | ||||||
|                 allowedDelta |= (uint)(ParcelFlags.UseBanList | |                 allowedDelta |= (uint)(ParcelFlags.UseBanList | | ||||||
|                         ParcelFlags.DenyAnonymous | |                         ParcelFlags.DenyAnonymous | | ||||||
|                         ParcelFlags.DenyAgeUnverified); |                         ParcelFlags.DenyAgeUnverified); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             if (allowedDelta != (uint)ParcelFlags.None) | ||||||
|  |             { | ||||||
|                 uint preserve = LandData.Flags & ~allowedDelta; |                 uint preserve = LandData.Flags & ~allowedDelta; | ||||||
|                 newData.Flags = preserve | (args.ParcelFlags & allowedDelta); |                 newData.Flags = preserve | (args.ParcelFlags & allowedDelta); | ||||||
| 
 | 
 | ||||||
|                 m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); |                 m_scene.LandChannel.UpdateLandObject(LandData.LocalID, newData); | ||||||
| 
 |  | ||||||
|                 SendLandUpdateToAvatarsOverMe(snap_selection); |                 SendLandUpdateToAvatarsOverMe(snap_selection); | ||||||
|             } |             } | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         public void UpdateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area) |         public void UpdateLandSold(UUID avatarID, UUID groupID, bool groupOwned, uint AuctionID, int claimprice, int area) | ||||||
|         { |         { | ||||||
|  | @ -950,7 +952,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
| 
 | 
 | ||||||
|         public void SendForceObjectSelect(int local_id, int request_type, List<UUID> returnIDs, IClientAPI remote_client) |         public void SendForceObjectSelect(int local_id, int request_type, List<UUID> returnIDs, IClientAPI remote_client) | ||||||
|         { |         { | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions, true)) | ||||||
|             { |             { | ||||||
|                 List<uint> resultLocalIDs = new List<uint>(); |                 List<uint> resultLocalIDs = new List<uint>(); | ||||||
|                 try |                 try | ||||||
|  | @ -1000,7 +1002,7 @@ namespace OpenSim.Region.CoreModules.World.Land | ||||||
|         /// </param> |         /// </param> | ||||||
|         public void SendLandObjectOwners(IClientAPI remote_client) |         public void SendLandObjectOwners(IClientAPI remote_client) | ||||||
|         { |         { | ||||||
|             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions)) |             if (m_scene.Permissions.CanEditParcelProperties(remote_client.AgentId, this, GroupPowers.LandOptions, true)) | ||||||
|             { |             { | ||||||
|                 Dictionary<UUID, int> primCount = new Dictionary<UUID, int>(); |                 Dictionary<UUID, int> primCount = new Dictionary<UUID, int>(); | ||||||
|                 List<UUID> groups = new List<UUID>(); |                 List<UUID> groups = new List<UUID>(); | ||||||
|  |  | ||||||
|  | @ -1047,7 +1047,7 @@ namespace OpenSim.Region.CoreModules.World.Permissions | ||||||
|             return GenericObjectPermission(editorID, objectID, false); |             return GenericObjectPermission(editorID, objectID, false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers p, Scene scene) |         private bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers p, Scene scene, bool allowManager) | ||||||
|         { |         { | ||||||
|             DebugPermissionInformation(MethodInfo.GetCurrentMethod().Name); |             DebugPermissionInformation(MethodInfo.GetCurrentMethod().Name); | ||||||
|             if (m_bypassPermissions) return m_bypassPermissionsValue; |             if (m_bypassPermissions) return m_bypassPermissionsValue; | ||||||
|  |  | ||||||
|  | @ -70,7 +70,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|     public delegate bool IsGridGodHandler(UUID user, Scene requestFromScene); |     public delegate bool IsGridGodHandler(UUID user, Scene requestFromScene); | ||||||
|     public delegate bool IsAdministratorHandler(UUID user); |     public delegate bool IsAdministratorHandler(UUID user); | ||||||
|     public delegate bool EditParcelHandler(UUID user, ILandObject parcel, Scene scene); |     public delegate bool EditParcelHandler(UUID user, ILandObject parcel, Scene scene); | ||||||
|     public delegate bool EditParcelPropertiesHandler(UUID user, ILandObject parcel, GroupPowers p, Scene scene); |     public delegate bool EditParcelPropertiesHandler(UUID user, ILandObject parcel, GroupPowers p, Scene scene, bool allowManager); | ||||||
|     public delegate bool SellParcelHandler(UUID user, ILandObject parcel, Scene scene); |     public delegate bool SellParcelHandler(UUID user, ILandObject parcel, Scene scene); | ||||||
|     public delegate bool AbandonParcelHandler(UUID user, ILandObject parcel, Scene scene); |     public delegate bool AbandonParcelHandler(UUID user, ILandObject parcel, Scene scene); | ||||||
|     public delegate bool ReclaimParcelHandler(UUID user, ILandObject parcel, Scene scene); |     public delegate bool ReclaimParcelHandler(UUID user, ILandObject parcel, Scene scene); | ||||||
|  | @ -763,7 +763,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         #region EDIT PARCEL |         #region EDIT PARCEL | ||||||
| 
 | 
 | ||||||
|         public bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers p) |         public bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers p, bool allowManager) | ||||||
|         { |         { | ||||||
|             EditParcelPropertiesHandler handler = OnEditParcelProperties; |             EditParcelPropertiesHandler handler = OnEditParcelProperties; | ||||||
|             if (handler != null) |             if (handler != null) | ||||||
|  | @ -771,7 +771,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                 Delegate[] list = handler.GetInvocationList(); |                 Delegate[] list = handler.GetInvocationList(); | ||||||
|                 foreach (EditParcelPropertiesHandler h in list) |                 foreach (EditParcelPropertiesHandler h in list) | ||||||
|                 { |                 { | ||||||
|                     if (h(user, parcel, p, m_scene) == false) |                     if (h(user, parcel, p, m_scene, allowManager) == false) | ||||||
|                         return false; |                         return false; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -1886,6 +1886,8 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|             { |             { | ||||||
|                 SceneObjectPart part = parts[i]; |                 SceneObjectPart part = parts[i]; | ||||||
| 
 | 
 | ||||||
|  |                 if (Scene != null) | ||||||
|  |                 { | ||||||
|                     Scene.ForEachRootScenePresence(delegate(ScenePresence avatar) |                     Scene.ForEachRootScenePresence(delegate(ScenePresence avatar) | ||||||
|                     { |                     { | ||||||
|                         if (avatar.ParentID == LocalId) |                         if (avatar.ParentID == LocalId) | ||||||
|  | @ -1904,7 +1906,7 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
|                 } |                 } | ||||||
| 
 |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void AddScriptLPS(int count) |         public void AddScriptLPS(int count) | ||||||
|  |  | ||||||
|  | @ -635,15 +635,15 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.VivoxVoice | ||||||
|                 // TODO: EstateSettings don't seem to get propagated... |                 // TODO: EstateSettings don't seem to get propagated... | ||||||
|                 if (!scene.RegionInfo.EstateSettings.AllowVoice) |                 if (!scene.RegionInfo.EstateSettings.AllowVoice) | ||||||
|                 { |                 { | ||||||
|                     m_log.DebugFormat("[VivoxVoice][PARCELVOICE]: region \"{0}\": voice not enabled in estate settings", |                     //m_log.DebugFormat("[VivoxVoice][PARCELVOICE]: region \"{0}\": voice not enabled in estate settings", | ||||||
|                                       scene.RegionInfo.RegionName); |                     //                  scene.RegionInfo.RegionName); | ||||||
|                     channel_uri = String.Empty; |                     channel_uri = String.Empty; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 if ((land.Flags & (uint)ParcelFlags.AllowVoiceChat) == 0) |                 if ((land.Flags & (uint)ParcelFlags.AllowVoiceChat) == 0) | ||||||
|                 { |                 { | ||||||
|                     m_log.DebugFormat("[VivoxVoice][PARCELVOICE]: region \"{0}\": Parcel \"{1}\" ({2}): avatar \"{3}\": voice not enabled for parcel", |                     //m_log.DebugFormat("[VivoxVoice][PARCELVOICE]: region \"{0}\": Parcel \"{1}\" ({2}): avatar \"{3}\": voice not enabled for parcel", | ||||||
|                                       scene.RegionInfo.RegionName, land.Name, land.LocalID, avatarName); |                     //                  scene.RegionInfo.RegionName, land.Name, land.LocalID, avatarName); | ||||||
|                     channel_uri = String.Empty; |                     channel_uri = String.Empty; | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|  |  | ||||||
|  | @ -105,9 +105,9 @@ namespace OpenSim.Region.RegionCombinerModule | ||||||
|             return m_rootScene.Permissions.CanEditObject(objectid, editorid); |             return m_rootScene.Permissions.CanEditObject(objectid, editorid); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers g, Scene scene) |         public bool CanEditParcelProperties(UUID user, ILandObject parcel, GroupPowers g, Scene scene, bool allowManager) | ||||||
|         { |         { | ||||||
|             return m_rootScene.Permissions.CanEditParcelProperties(user, parcel, g); |             return m_rootScene.Permissions.CanEditParcelProperties(user, parcel, g, allowManager); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool CanInstantMessage(UUID user, UUID target, Scene startscene) |         public bool CanInstantMessage(UUID user, UUID target, Scene startscene) | ||||||
|  |  | ||||||
|  | @ -7106,7 +7106,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             UUID key; |             UUID key; | ||||||
|             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); |             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); | ||||||
| 
 | 
 | ||||||
|             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned)) |             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned, false)) | ||||||
|             { |             { | ||||||
|                 int expires = 0; |                 int expires = 0; | ||||||
|                 if (hours != 0) |                 if (hours != 0) | ||||||
|  | @ -10431,7 +10431,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             // according to the docs, this command only works if script owner and land owner are the same |             // according to the docs, this command only works if script owner and land owner are the same | ||||||
|             // lets add estate owners and gods, too, and use the generic permission check. |             // lets add estate owners and gods, too, and use the generic permission check. | ||||||
|             ILandObject landObject = World.LandChannel.GetLandObject(m_host.AbsolutePosition); |             ILandObject landObject = World.LandChannel.GetLandObject(m_host.AbsolutePosition); | ||||||
|             if (!World.Permissions.CanEditParcelProperties(m_host.OwnerID, landObject, GroupPowers.ChangeMedia)) return; |             if (!World.Permissions.CanEditParcelProperties(m_host.OwnerID, landObject, GroupPowers.ChangeMedia, false)) return; | ||||||
| 
 | 
 | ||||||
|             bool update = false; // send a ParcelMediaUpdate (and possibly change the land's media URL)? |             bool update = false; // send a ParcelMediaUpdate (and possibly change the land's media URL)? | ||||||
|             byte loop = 0; |             byte loop = 0; | ||||||
|  | @ -10874,7 +10874,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             m_host.AddScriptLPS(1); |             m_host.AddScriptLPS(1); | ||||||
|             UUID key; |             UUID key; | ||||||
|             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); |             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); | ||||||
|             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned)) |             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned, false)) | ||||||
|             { |             { | ||||||
|                 int expires = 0; |                 int expires = 0; | ||||||
|                 if (hours != 0) |                 if (hours != 0) | ||||||
|  | @ -10915,7 +10915,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             m_host.AddScriptLPS(1); |             m_host.AddScriptLPS(1); | ||||||
|             UUID key; |             UUID key; | ||||||
|             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); |             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); | ||||||
|             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageAllowed)) |             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageAllowed, false)) | ||||||
|             { |             { | ||||||
|                 if (UUID.TryParse(avatar, out key)) |                 if (UUID.TryParse(avatar, out key)) | ||||||
|                 { |                 { | ||||||
|  | @ -10942,7 +10942,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             m_host.AddScriptLPS(1); |             m_host.AddScriptLPS(1); | ||||||
|             UUID key; |             UUID key; | ||||||
|             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); |             ILandObject land = World.LandChannel.GetLandObject(m_host.AbsolutePosition); | ||||||
|             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned)) |             if (World.Permissions.CanEditParcelProperties(m_host.OwnerID, land, GroupPowers.LandManageBanned, false)) | ||||||
|             { |             { | ||||||
|                 if (UUID.TryParse(avatar, out key)) |                 if (UUID.TryParse(avatar, out key)) | ||||||
|                 { |                 { | ||||||
|  |  | ||||||
|  | @ -1434,7 +1434,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (!World.Permissions.CanEditParcelProperties(m_host.OwnerID, startLandObject, GroupPowers.LandOptions)) |             if (!World.Permissions.CanEditParcelProperties(m_host.OwnerID, startLandObject, GroupPowers.LandOptions, false)) | ||||||
|             { |             { | ||||||
|                 OSSLShoutError("You do not have permission to modify the parcel"); |                 OSSLShoutError("You do not have permission to modify the parcel"); | ||||||
|                 return; |                 return; | ||||||
|  |  | ||||||
|  | @ -40,7 +40,7 @@ namespace OpenSim.Server.Base | ||||||
| { | { | ||||||
|     public class HttpServerBase : ServicesServerBase |     public class HttpServerBase : ServicesServerBase | ||||||
|     { |     { | ||||||
| //        private static readonly ILog m_Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |         private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | ||||||
| 
 | 
 | ||||||
|         private uint m_consolePort; |         private uint m_consolePort; | ||||||
| 
 | 
 | ||||||
|  | @ -69,6 +69,7 @@ namespace OpenSim.Server.Base | ||||||
| 
 | 
 | ||||||
|             bool ssl_main = networkConfig.GetBoolean("https_main",false); |             bool ssl_main = networkConfig.GetBoolean("https_main",false); | ||||||
|             bool ssl_listener = networkConfig.GetBoolean("https_listener",false); |             bool ssl_listener = networkConfig.GetBoolean("https_listener",false); | ||||||
|  |             bool ssl_external = networkConfig.GetBoolean("https_external",false); | ||||||
| 
 | 
 | ||||||
|             m_consolePort = (uint)networkConfig.GetInt("ConsolePort", 0); |             m_consolePort = (uint)networkConfig.GetInt("ConsolePort", 0); | ||||||
| 
 | 
 | ||||||
|  | @ -113,6 +114,9 @@ namespace OpenSim.Server.Base | ||||||
| 
 | 
 | ||||||
|                 uint https_port = (uint)networkConfig.GetInt("https_port", 0); |                 uint https_port = (uint)networkConfig.GetInt("https_port", 0); | ||||||
| 
 | 
 | ||||||
|  |                 m_log.WarnFormat("[SSL]: External flag is {0}", ssl_external); | ||||||
|  |                 if (!ssl_external) | ||||||
|  |                 { | ||||||
|                     string cert_path = networkConfig.GetString("cert_path",String.Empty); |                     string cert_path = networkConfig.GetString("cert_path",String.Empty); | ||||||
|                     if ( cert_path == String.Empty ) |                     if ( cert_path == String.Empty ) | ||||||
|                     { |                     { | ||||||
|  | @ -128,6 +132,12 @@ namespace OpenSim.Server.Base | ||||||
| 
 | 
 | ||||||
|                     MainServer.AddHttpServer(new BaseHttpServer(https_port, ssl_listener, cert_path, cert_pass)); |                     MainServer.AddHttpServer(new BaseHttpServer(https_port, ssl_listener, cert_path, cert_pass)); | ||||||
|                 } |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     m_log.WarnFormat("[SSL]: SSL port is active but no SSL is used because external SSL was requested."); | ||||||
|  |                     MainServer.AddHttpServer(new BaseHttpServer(https_port)); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected override void Initialise() |         protected override void Initialise() | ||||||
|  |  | ||||||
|  | @ -86,6 +86,66 @@ namespace OpenSim.Services.Connectors | ||||||
|             m_ServerURI = serviceURI.TrimEnd('/'); |             m_ServerURI = serviceURI.TrimEnd('/'); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public bool RemoveMapTile(int x, int y, out string reason) | ||||||
|  |         { | ||||||
|  |             reason = string.Empty; | ||||||
|  |             int tickstart = Util.EnvironmentTickCount(); | ||||||
|  |             Dictionary<string, object> sendData = new Dictionary<string, object>(); | ||||||
|  |             sendData["X"] = x.ToString(); | ||||||
|  |             sendData["Y"] = y.ToString(); | ||||||
|  | 
 | ||||||
|  |             string reqString = ServerUtils.BuildQueryString(sendData); | ||||||
|  |             string uri = m_ServerURI + "/removemap"; | ||||||
|  | 
 | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 string reply = SynchronousRestFormsRequester.MakeRequest("POST", | ||||||
|  |                         uri, | ||||||
|  |                         reqString); | ||||||
|  |                 if (reply != string.Empty) | ||||||
|  |                 { | ||||||
|  |                     Dictionary<string, object> replyData = ServerUtils.ParseXmlResponse(reply); | ||||||
|  | 
 | ||||||
|  |                     if (replyData.ContainsKey("Result") && (replyData["Result"].ToString().ToLower() == "success")) | ||||||
|  |                     { | ||||||
|  |                         return true; | ||||||
|  |                     } | ||||||
|  |                     else if (replyData.ContainsKey("Result") && (replyData["Result"].ToString().ToLower() == "failure")) | ||||||
|  |                     { | ||||||
|  |                         m_log.DebugFormat("[MAP IMAGE CONNECTOR]: Delete failed: {0}", replyData["Message"].ToString()); | ||||||
|  |                         reason = replyData["Message"].ToString(); | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     else if (!replyData.ContainsKey("Result")) | ||||||
|  |                     { | ||||||
|  |                         m_log.DebugFormat("[MAP IMAGE CONNECTOR]: reply data does not contain result field"); | ||||||
|  |                     } | ||||||
|  |                     else | ||||||
|  |                     { | ||||||
|  |                         m_log.DebugFormat("[MAP IMAGE CONNECTOR]: unexpected result {0}", replyData["Result"].ToString()); | ||||||
|  |                         reason = "Unexpected result " + replyData["Result"].ToString(); | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     m_log.DebugFormat("[MAP IMAGE CONNECTOR]: Map post received null reply"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             catch (Exception e) | ||||||
|  |             { | ||||||
|  |                 m_log.DebugFormat("[MAP IMAGE CONNECTOR]: Exception when contacting map server at {0}: {1}", uri, e.Message); | ||||||
|  |             } | ||||||
|  |             finally | ||||||
|  |             { | ||||||
|  |                 // This just dumps a warning for any operation that takes more than 100 ms | ||||||
|  |                 int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); | ||||||
|  |                 m_log.DebugFormat("[MAP IMAGE CONNECTOR]: map tile deleted in {0}ms", tickdiff); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         public bool AddMapTile(int x, int y, byte[] jpgData, out string reason) |         public bool AddMapTile(int x, int y, byte[] jpgData, out string reason) | ||||||
|         { |         { | ||||||
|             reason = string.Empty; |             reason = string.Empty; | ||||||
|  |  | ||||||
|  | @ -283,7 +283,7 @@ namespace OpenSim.Services.GridService | ||||||
| 
 | 
 | ||||||
|             int flags = Convert.ToInt32(region.Data["flags"]); |             int flags = Convert.ToInt32(region.Data["flags"]); | ||||||
| 
 | 
 | ||||||
|             if (!m_DeleteOnUnregister || (flags & (int)OpenSim.Framework.RegionFlags.Persistent) != 0) |             if ((!m_DeleteOnUnregister) || ((flags & (int)OpenSim.Framework.RegionFlags.Persistent) != 0)) | ||||||
|             { |             { | ||||||
|                 flags &= ~(int)OpenSim.Framework.RegionFlags.RegionOnline; |                 flags &= ~(int)OpenSim.Framework.RegionFlags.RegionOnline; | ||||||
|                 region.Data["flags"] = flags.ToString(); |                 region.Data["flags"] = flags.ToString(); | ||||||
|  | @ -298,7 +298,6 @@ namespace OpenSim.Services.GridService | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 return true; |                 return true; | ||||||
| 
 |  | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             return m_Database.Delete(regionID); |             return m_Database.Delete(regionID); | ||||||
|  |  | ||||||
|  | @ -35,6 +35,7 @@ namespace OpenSim.Services.Interfaces | ||||||
|     { |     { | ||||||
|         //List<MapBlockData> GetMapBlocks(UUID scopeID, int minX, int minY, int maxX, int maxY); |         //List<MapBlockData> GetMapBlocks(UUID scopeID, int minX, int minY, int maxX, int maxY); | ||||||
|         bool AddMapTile(int x, int y, byte[] imageData, out string reason); |         bool AddMapTile(int x, int y, byte[] imageData, out string reason); | ||||||
|  |         bool RemoveMapTile(int x, int y, out string reason); | ||||||
|         byte[] GetMapTile(string fileName, out string format); |         byte[] GetMapTile(string fileName, out string format); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -112,9 +112,38 @@ namespace OpenSim.Services.MapImageService | ||||||
|                     reason = e.Message; |                     reason = e.Message; | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|                 // Also save in png format? |             return UpdateMultiResolutionFiles(x, y, out reason); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|  |         public bool RemoveMapTile(int x, int y, out string reason) | ||||||
|  |         { | ||||||
|  |             reason = String.Empty; | ||||||
|  |             string fileName = GetFileName(1, x, y); | ||||||
|  | 
 | ||||||
|  |             lock (m_Sync) | ||||||
|  |             { | ||||||
|  |                 try | ||||||
|  |                 { | ||||||
|  |                     File.Delete(fileName); | ||||||
|  |                 } | ||||||
|  |                 catch (Exception e) | ||||||
|  |                 { | ||||||
|  |                     m_log.WarnFormat("[MAP IMAGE SERVICE]: Unable to save delete file {0}: {1}", fileName, e); | ||||||
|  |                     reason = e.Message; | ||||||
|  |                     return false; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return UpdateMultiResolutionFiles(x, y, out reason); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private bool UpdateMultiResolutionFiles(int x, int y, out string reason) | ||||||
|  |         { | ||||||
|  |             reason = String.Empty; | ||||||
|  |             lock (m_Sync) | ||||||
|  |             { | ||||||
|                 // Stitch seven more aggregate tiles together |                 // Stitch seven more aggregate tiles together | ||||||
|                 for (uint zoomLevel = 2; zoomLevel <= ZOOM_LEVELS; zoomLevel++) |                 for (uint zoomLevel = 2; zoomLevel <= ZOOM_LEVELS; zoomLevel++) | ||||||
|                 { |                 { | ||||||
|  | @ -126,7 +155,7 @@ namespace OpenSim.Services.MapImageService | ||||||
| 
 | 
 | ||||||
|                     if (!CreateTile(zoomLevel, x1, y1)) |                     if (!CreateTile(zoomLevel, x1, y1)) | ||||||
|                     { |                     { | ||||||
|                         m_log.WarnFormat("[MAP IMAGE SERVICE]: Unable to create tile for {0} at zoom level {1}", fileName, zoomLevel); |                         m_log.WarnFormat("[MAP IMAGE SERVICE]: Unable to create tile for {0},{1} at zoom level {1}", x, y, zoomLevel); | ||||||
|                         reason = string.Format("Map tile at zoom level {0} failed", zoomLevel); |                         reason = string.Format("Map tile at zoom level {0} failed", zoomLevel); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 UbitUmarov
						UbitUmarov