aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Environment/EstateManager.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Environment/EstateManager.cs81
1 files changed, 43 insertions, 38 deletions
diff --git a/OpenSim/Region/Environment/EstateManager.cs b/OpenSim/Region/Environment/EstateManager.cs
index 92e1956..30d206f 100644
--- a/OpenSim/Region/Environment/EstateManager.cs
+++ b/OpenSim/Region/Environment/EstateManager.cs
@@ -39,7 +39,6 @@ using Avatar = OpenSim.Region.Environment.Scenes.ScenePresence;
39 39
40namespace OpenSim.Region.Environment 40namespace OpenSim.Region.Environment
41{ 41{
42
43 /// <summary> 42 /// <summary>
44 /// Processes requests regarding estates. Refer to EstateSettings.cs in OpenSim.Framework. Types for all of the core settings 43 /// Processes requests regarding estates. Refer to EstateSettings.cs in OpenSim.Framework. Types for all of the core settings
45 /// </summary> 44 /// </summary>
@@ -48,9 +47,9 @@ namespace OpenSim.Region.Environment
48 private Scene m_scene; 47 private Scene m_scene;
49 private RegionInfo m_regInfo; 48 private RegionInfo m_regInfo;
50 49
51 public EstateManager(Scene scene,RegionInfo reginfo) 50 public EstateManager(Scene scene, RegionInfo reginfo)
52 { 51 {
53 m_scene = scene; 52 m_scene = scene;
54 m_regInfo = reginfo; 53 m_regInfo = reginfo;
55 } 54 }
56 55
@@ -125,7 +124,8 @@ namespace OpenSim.Region.Environment
125 /// <param name="TerrainLowerLimit">Minimum amount terrain can be lowered from previous baking</param> 124 /// <param name="TerrainLowerLimit">Minimum amount terrain can be lowered from previous baking</param>
126 /// <param name="UseFixedSun">Use a fixed time of day on the sun?</param> 125 /// <param name="UseFixedSun">Use a fixed time of day on the sun?</param>
127 /// <param name="SunHour">The offset hour of the day</param> 126 /// <param name="SunHour">The offset hour of the day</param>
128 public void setRegionSettings(float WaterHeight, float TerrainRaiseLimit, float TerrainLowerLimit, bool UseFixedSun, float SunHour) 127 public void setRegionSettings(float WaterHeight, float TerrainRaiseLimit, float TerrainLowerLimit,
128 bool UseFixedSun, float SunHour)
129 { 129 {
130 // Water Height 130 // Water Height
131 m_regInfo.estateSettings.waterHeight = WaterHeight; 131 m_regInfo.estateSettings.waterHeight = WaterHeight;
@@ -144,13 +144,12 @@ namespace OpenSim.Region.Environment
144 144
145 #region Packet Handlers 145 #region Packet Handlers
146 146
147
148 public void handleEstateOwnerMessage(EstateOwnerMessagePacket packet, IClientAPI remote_client) 147 public void handleEstateOwnerMessage(EstateOwnerMessagePacket packet, IClientAPI remote_client)
149 { 148 {
150 switch (Helpers.FieldToUTF8String(packet.MethodData.Method)) 149 switch (Helpers.FieldToUTF8String(packet.MethodData.Method))
151 { 150 {
152 case "getinfo": 151 case "getinfo":
153 this.sendRegionInfoPacketToAll(); 152 sendRegionInfoPacketToAll();
154 break; 153 break;
155 case "setregioninfo": 154 case "setregioninfo":
156 if (m_scene.PermissionsMngr.CanEditEstateTerrain(remote_client.AgentId)) 155 if (m_scene.PermissionsMngr.CanEditEstateTerrain(remote_client.AgentId))
@@ -193,47 +192,54 @@ namespace OpenSim.Region.Environment
193 192
194 if (convertParamStringToBool(packet.ParamList[0].Parameter)) 193 if (convertParamStringToBool(packet.ParamList[0].Parameter))
195 { 194 {
196 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.BlockTerraform; 195 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
196 Simulator.RegionFlags.BlockTerraform;
197 } 197 }
198 198
199 if (convertParamStringToBool(packet.ParamList[1].Parameter)) 199 if (convertParamStringToBool(packet.ParamList[1].Parameter))
200 { 200 {
201 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.NoFly; 201 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
202 Simulator.RegionFlags.NoFly;
202 } 203 }
203 204
204 if (convertParamStringToBool(packet.ParamList[2].Parameter)) 205 if (convertParamStringToBool(packet.ParamList[2].Parameter))
205 { 206 {
206 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.AllowDamage; 207 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
208 Simulator.RegionFlags.AllowDamage;
207 } 209 }
208 210
209 if (convertParamStringToBool(packet.ParamList[3].Parameter) == false) 211 if (convertParamStringToBool(packet.ParamList[3].Parameter) == false)
210 { 212 {
211 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.BlockLandResell; 213 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
214 Simulator.RegionFlags.BlockLandResell;
212 } 215 }
213 216
214 217
215 int tempMaxAgents = Convert.ToInt16(Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[4].Parameter))); 218 int tempMaxAgents =
216 m_regInfo.estateSettings.maxAgents = (byte)tempMaxAgents; 219 Convert.ToInt16(Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[4].Parameter)));
220 m_regInfo.estateSettings.maxAgents = (byte) tempMaxAgents;
217 221
218 float tempObjectBonusFactor = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter)); 222 float tempObjectBonusFactor =
223 (float) Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter));
219 m_regInfo.estateSettings.objectBonusFactor = tempObjectBonusFactor; 224 m_regInfo.estateSettings.objectBonusFactor = tempObjectBonusFactor;
220 225
221 int tempMatureLevel = Convert.ToInt16(Helpers.FieldToUTF8String(packet.ParamList[6].Parameter)); 226 int tempMatureLevel = Convert.ToInt16(Helpers.FieldToUTF8String(packet.ParamList[6].Parameter));
222 m_regInfo.estateSettings.simAccess = (Simulator.SimAccess)tempMatureLevel; 227 m_regInfo.estateSettings.simAccess = (Simulator.SimAccess) tempMatureLevel;
223 228
224 229
225 if (convertParamStringToBool(packet.ParamList[7].Parameter)) 230 if (convertParamStringToBool(packet.ParamList[7].Parameter))
226 { 231 {
227 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.RestrictPushObject; 232 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
233 Simulator.RegionFlags.RestrictPushObject;
228 } 234 }
229 235
230 if (convertParamStringToBool(packet.ParamList[8].Parameter)) 236 if (convertParamStringToBool(packet.ParamList[8].Parameter))
231 { 237 {
232 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags | Simulator.RegionFlags.AllowParcelChanges; 238 m_regInfo.estateSettings.regionFlags = m_regInfo.estateSettings.regionFlags |
239 Simulator.RegionFlags.AllowParcelChanges;
233 } 240 }
234 241
235 sendRegionInfoPacketToAll(); 242 sendRegionInfoPacketToAll();
236
237 } 243 }
238 } 244 }
239 245
@@ -245,11 +251,13 @@ namespace OpenSim.Region.Environment
245 } 251 }
246 else 252 else
247 { 253 {
248 float WaterHeight = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[0].Parameter)); 254 float WaterHeight = (float) Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[0].Parameter));
249 float TerrainRaiseLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[1].Parameter)); 255 float TerrainRaiseLimit =
250 float TerrainLowerLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[2].Parameter)); 256 (float) Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[1].Parameter));
251 bool UseFixedSun = this.convertParamStringToBool(packet.ParamList[4].Parameter); 257 float TerrainLowerLimit =
252 float SunHour = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter)); 258 (float) Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[2].Parameter));
259 bool UseFixedSun = convertParamStringToBool(packet.ParamList[4].Parameter);
260 float SunHour = (float) Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter));
253 261
254 setRegionSettings(WaterHeight, TerrainRaiseLimit, TerrainLowerLimit, UseFixedSun, SunHour); 262 setRegionSettings(WaterHeight, TerrainRaiseLimit, TerrainLowerLimit, UseFixedSun, SunHour);
255 263
@@ -265,10 +273,9 @@ namespace OpenSim.Region.Environment
265 string[] splitField = s.Split(' '); 273 string[] splitField = s.Split(' ');
266 if (splitField.Length == 3) 274 if (splitField.Length == 3)
267 { 275 {
268
269 Int16 corner = Convert.ToInt16(splitField[0]); 276 Int16 corner = Convert.ToInt16(splitField[0]);
270 float lowValue = (float)Convert.ToDecimal(splitField[1]); 277 float lowValue = (float) Convert.ToDecimal(splitField[1]);
271 float highValue = (float)Convert.ToDecimal(splitField[2]); 278 float highValue = (float) Convert.ToDecimal(splitField[2]);
272 279
273 setEstateTextureRange(corner, lowValue, highValue); 280 setEstateTextureRange(corner, lowValue, highValue);
274 } 281 }
@@ -279,7 +286,6 @@ namespace OpenSim.Region.Environment
279 { 286 {
280 foreach (EstateOwnerMessagePacket.ParamListBlock block in packet.ParamList) 287 foreach (EstateOwnerMessagePacket.ParamListBlock block in packet.ParamList)
281 { 288 {
282
283 string s = Helpers.FieldToUTF8String(block.Parameter); 289 string s = Helpers.FieldToUTF8String(block.Parameter);
284 string[] splitField = s.Split(' '); 290 string[] splitField = s.Split(' ');
285 if (splitField.Length == 2) 291 if (splitField.Length == 2)
@@ -326,12 +332,12 @@ namespace OpenSim.Region.Environment
326 332
327 public void sendRegionInfoPacketToAll() 333 public void sendRegionInfoPacketToAll()
328 { 334 {
329 List<Avatar> avatars = m_scene.RequestAvatarList(); 335 List<Avatar> avatars = m_scene.RequestAvatarList();
330 336
331 for (int i = 0; i < avatars.Count; i++) 337 for (int i = 0; i < avatars.Count; i++)
332 { 338 {
333 this.sendRegionInfoPacket(avatars[i].ControllingClient); 339 sendRegionInfoPacket(avatars[i].ControllingClient);
334 } 340 }
335 } 341 }
336 342
337 public void sendRegionHandshakeToAll() 343 public void sendRegionHandshakeToAll()
@@ -340,8 +346,8 @@ namespace OpenSim.Region.Environment
340 346
341 for (int i = 0; i < avatars.Count; i++) 347 for (int i = 0; i < avatars.Count; i++)
342 { 348 {
343 this.sendRegionHandshake(avatars[i].ControllingClient); 349 sendRegionHandshake(avatars[i].ControllingClient);
344 } 350 }
345 } 351 }
346 352
347 public void sendRegionInfoPacket(IClientAPI remote_client) 353 public void sendRegionInfoPacket(IClientAPI remote_client)
@@ -361,9 +367,9 @@ namespace OpenSim.Region.Environment
361 regionInfoPacket.RegionInfo.PricePerMeter = m_regInfo.estateSettings.pricePerMeter; 367 regionInfoPacket.RegionInfo.PricePerMeter = m_regInfo.estateSettings.pricePerMeter;
362 regionInfoPacket.RegionInfo.RedirectGridX = m_regInfo.estateSettings.redirectGridX; 368 regionInfoPacket.RegionInfo.RedirectGridX = m_regInfo.estateSettings.redirectGridX;
363 regionInfoPacket.RegionInfo.RedirectGridY = m_regInfo.estateSettings.redirectGridY; 369 regionInfoPacket.RegionInfo.RedirectGridY = m_regInfo.estateSettings.redirectGridY;
364 regionInfoPacket.RegionInfo.RegionFlags = (uint)m_regInfo.estateSettings.regionFlags; 370 regionInfoPacket.RegionInfo.RegionFlags = (uint) m_regInfo.estateSettings.regionFlags;
365 regionInfoPacket.RegionInfo.SimAccess = (byte)m_regInfo.estateSettings.simAccess; 371 regionInfoPacket.RegionInfo.SimAccess = (byte) m_regInfo.estateSettings.simAccess;
366 regionInfoPacket.RegionInfo.SimName = _enc.GetBytes( m_regInfo.RegionName); 372 regionInfoPacket.RegionInfo.SimName = _enc.GetBytes(m_regInfo.RegionName);
367 regionInfoPacket.RegionInfo.SunHour = m_regInfo.estateSettings.sunHour; 373 regionInfoPacket.RegionInfo.SunHour = m_regInfo.estateSettings.sunHour;
368 regionInfoPacket.RegionInfo.TerrainLowerLimit = m_regInfo.estateSettings.terrainLowerLimit; 374 regionInfoPacket.RegionInfo.TerrainLowerLimit = m_regInfo.estateSettings.terrainLowerLimit;
369 regionInfoPacket.RegionInfo.TerrainRaiseLimit = m_regInfo.estateSettings.terrainRaiseLimit; 375 regionInfoPacket.RegionInfo.TerrainRaiseLimit = m_regInfo.estateSettings.terrainRaiseLimit;
@@ -379,6 +385,5 @@ namespace OpenSim.Region.Environment
379 } 385 }
380 386
381 #endregion 387 #endregion
382
383 } 388 }
384} 389} \ No newline at end of file