aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules')
-rw-r--r--OpenSim/Region/CoreModules/World/Estate/EstateManagementCommands.cs184
-rw-r--r--OpenSim/Region/CoreModules/World/Estate/EstateManagementModule.cs25
2 files changed, 21 insertions, 188 deletions
diff --git a/OpenSim/Region/CoreModules/World/Estate/EstateManagementCommands.cs b/OpenSim/Region/CoreModules/World/Estate/EstateManagementCommands.cs
index b1c4429..702b503 100644
--- a/OpenSim/Region/CoreModules/World/Estate/EstateManagementCommands.cs
+++ b/OpenSim/Region/CoreModules/World/Estate/EstateManagementCommands.cs
@@ -52,10 +52,6 @@ namespace OpenSim.Region.CoreModules.World.Estate
52 52
53 protected EstateManagementModule m_module; 53 protected EstateManagementModule m_module;
54 54
55 // used to prevent multiple processing of commands when called from root region
56 private static string[] m_currentCmd = null;
57 private static EstateSettings m_estateSettings = null;
58
59 public EstateManagementCommands(EstateManagementModule module) 55 public EstateManagementCommands(EstateManagementModule module)
60 { 56 {
61 m_module = module; 57 m_module = module;
@@ -87,15 +83,6 @@ namespace OpenSim.Region.CoreModules.World.Estate
87 83
88 m_module.Scene.AddCommand( 84 m_module.Scene.AddCommand(
89 "Estates", m_module, "estate show", "estate show", "Shows all estates on the simulator.", ShowEstatesCommand); 85 "Estates", m_module, "estate show", "estate show", "Shows all estates on the simulator.", ShowEstatesCommand);
90
91 m_module.Scene.AddCommand(
92 "Estates", m_module, "estate set owner", "estate set owner <estate-id>[ <UUID> | <Firstname> <Lastname> ]",
93 "Sets the owner of the specified estate to the specified UUID or user. ", SetEstateOwnerCommand);
94
95 m_module.Scene.AddCommand(
96 "Estates", m_module, "estate set name", "estate set name <estate-id> <new name>",
97 "Sets the name of the specified estate to the specified value. " +
98 "New name must be unique.", SetEstateNameCommand);
99 } 86 }
100 87
101 public void Close() {} 88 public void Close() {}
@@ -237,178 +224,7 @@ namespace OpenSim.Region.CoreModules.World.Estate
237 es.EstateName, es.EstateID, m_module.UserManager.GetUserName(es.EstateOwner)); 224 es.EstateName, es.EstateID, m_module.UserManager.GetUserName(es.EstateOwner));
238 225
239 MainConsole.Instance.Output(report.ToString()); 226 MainConsole.Instance.Output(report.ToString());
240 }
241
242 protected void SetEstateOwnerCommand(string module, string[] args)
243 {
244 string response = null;
245
246 EstateSettings es = m_module.Scene.RegionInfo.EstateSettings;
247
248 if (args == m_currentCmd)
249 {
250 // HACK to propagate new estate info to Scene Regions
251 if (m_estateSettings != null && es.EstateID == m_estateSettings.EstateID)
252 es.EstateOwner = m_estateSettings.EstateOwner;
253
254 return;
255 }
256
257 // new command... clear out the old value
258 m_currentCmd = args;
259
260 if (args.Length == 3)
261 {
262 response = "No estate specified.";
263 }
264 else
265 {
266 int estateId;
267 if (!int.TryParse(args[3], out estateId))
268 {
269 response = String.Format("\"{0}\" is not a valid ID for an Estate", args[3]);
270 }
271 else
272 {
273 if (args.Length == 4)
274 {
275 response = "No user specified.";
276 }
277 else
278 {
279 UserAccount account = null;
280
281 // TODO: Is there a better choice here?
282 UUID scopeID = UUID.Zero;
283
284 string s1 = args[4];
285 if (args.Length == 5)
286 {
287 // attempt to get account by UUID
288 UUID u;
289 if (UUID.TryParse(s1, out u))
290 {
291 account = m_module.Scene.UserAccountService.GetUserAccount(scopeID, u);
292 if (account == null)
293 response = String.Format("Could not find user {0}", s1);
294 }
295 else
296 {
297 response = String.Format("Invalid UUID {0}", s1);
298 }
299 }
300 else
301 {
302 // attempt to get account by Firstname, Lastname
303 string s2 = args[5];
304 account = m_module.Scene.UserAccountService.GetUserAccount(scopeID, s1, s2);
305 if (account == null)
306 response = String.Format("Could not find user {0} {1}", s1, s2);
307 }
308
309 // If it's valid, send it off for processing.
310 if (account != null)
311 response = m_module.SetEstateOwner(estateId, account);
312
313 if (response == String.Empty)
314 {
315 response = String.Format("Estate owner changed to {0} ({1} {2})", account.PrincipalID, account.FirstName, account.LastName);
316
317 // save data for propagation to other Scene Regions
318 m_estateSettings = new EstateSettings();
319 m_estateSettings.EstateID = (uint)estateId;
320 m_estateSettings.EstateOwner = account.PrincipalID;
321
322 // update current Scene Region if appropriate
323 if (es.EstateID == estateId)
324 es.EstateOwner = account.PrincipalID;
325 }
326 else
327 {
328 m_estateSettings = null;
329 }
330 }
331 }
332 }
333
334 // give the user some feedback
335 if (response != null)
336 MainConsole.Instance.Output(response);
337 } 227 }
338
339 protected void SetEstateNameCommand(string module, string[] args)
340 {
341 string response = null;
342
343 EstateSettings es = m_module.Scene.RegionInfo.EstateSettings;
344
345 if (args == m_currentCmd)
346 {
347 // HACK to propagate new estate info to Scene Regions
348 if (m_estateSettings != null && es.EstateID == m_estateSettings.EstateID)
349 es.EstateName = m_estateSettings.EstateName;
350
351 return;
352 }
353
354 // new command... clear out the old value
355 m_currentCmd = args;
356
357 if (args.Length == 3)
358 {
359 response = "No estate specified.";
360 }
361 else
362 {
363 int estateId;
364 if (!int.TryParse(args[3], out estateId))
365 {
366 response = String.Format("\"{0}\" is not a valid ID for an Estate", args[3]);
367 }
368 else
369 {
370 if (args.Length == 4)
371 {
372 response = "No name specified.";
373 }
374 else
375 {
376 // everything after the estate ID is "name"
377 StringBuilder sb = new StringBuilder(args[4]);
378 for (int i = 5; i < args.Length; i++)
379 sb.Append (" " + args[i]);
380
381 string estateName = sb.ToString();
382
383 // send it off for processing.
384 response = m_module.SetEstateName(estateId, estateName);
385
386 if (response == String.Empty)
387 {
388 response = String.Format("Estate {0} renamed from \"{1}\" to \"{2}\"", estateId, es.EstateName, estateName);
389
390 // save data for propagation to other Scene Regions
391 m_estateSettings = new EstateSettings();
392 m_estateSettings.EstateID = (uint)estateId;
393 m_estateSettings.EstateName = estateName;
394
395 // update current Scene Region if appropriate
396 if (es.EstateID == estateId)
397 es.EstateName = estateName;
398 }
399 else
400 {
401 m_estateSettings = null;
402 }
403 }
404 }
405 }
406
407 // give the user some feedback
408 if (response != null)
409 MainConsole.Instance.Output(response);
410 }
411
412 #endregion 228 #endregion
413 } 229 }
414} \ No newline at end of file 230} \ No newline at end of file
diff --git a/OpenSim/Region/CoreModules/World/Estate/EstateManagementModule.cs b/OpenSim/Region/CoreModules/World/Estate/EstateManagementModule.cs
index ae956e6..54a7302 100644
--- a/OpenSim/Region/CoreModules/World/Estate/EstateManagementModule.cs
+++ b/OpenSim/Region/CoreModules/World/Estate/EstateManagementModule.cs
@@ -251,8 +251,17 @@ namespace OpenSim.Region.CoreModules.World.Estate
251 m_log.InfoFormat("[ESTATE]: Estate Owner for {0} changed to {1} ({2} {3})", dbSettings.EstateName, 251 m_log.InfoFormat("[ESTATE]: Estate Owner for {0} changed to {1} ({2} {3})", dbSettings.EstateName,
252 account.PrincipalID, account.FirstName, account.LastName); 252 account.PrincipalID, account.FirstName, account.LastName);
253 253
254 TriggerEstateInfoChange(); 254 // propagate the change
255 sendRegionHandshakeToAll(); 255 List<UUID> regions = Scene.GetEstateRegions(estateID);
256 UUID regionId = (regions.Count() > 0) ? regions.ElementAt(0) : UUID.Zero;
257 if (regionId != UUID.Zero)
258 {
259 ChangeDelegate change = OnEstateInfoChange;
260
261 if (change != null)
262 change(regionId);
263 }
264
256 } 265 }
257 return response; 266 return response;
258 } 267 }
@@ -289,8 +298,16 @@ namespace OpenSim.Region.CoreModules.World.Estate
289 // make sure there's a log entry to document the change 298 // make sure there's a log entry to document the change
290 m_log.InfoFormat("[ESTATE]: Estate {0} renamed from \"{1}\" to \"{2}\"", estateID, oldName, newName); 299 m_log.InfoFormat("[ESTATE]: Estate {0} renamed from \"{1}\" to \"{2}\"", estateID, oldName, newName);
291 300
292 TriggerEstateInfoChange(); 301 // propagate the change
293 sendRegionHandshakeToAll(); 302 List<UUID> regions = Scene.GetEstateRegions(estateID);
303 UUID regionId = (regions.Count() > 0) ? regions.ElementAt(0) : UUID.Zero;
304 if (regionId != UUID.Zero)
305 {
306 ChangeDelegate change = OnEstateInfoChange;
307
308 if (change != null)
309 change(regionId);
310 }
294 } 311 }
295 } 312 }
296 return response; 313 return response;