diff options
author | UbitUmarov | 2019-01-18 22:18:49 +0000 |
---|---|---|
committer | UbitUmarov | 2019-01-18 22:18:49 +0000 |
commit | 796a8efe25e74253b25d3c8a265635e8517d5f05 (patch) | |
tree | 8f716f2e36c8dc835193312192be0d6481edbd31 /OpenSim/Region/CoreModules/Framework/EntityTransfer | |
parent | fix HG tp detection (diff) | |
download | opensim-SC-796a8efe25e74253b25d3c8a265635e8517d5f05.zip opensim-SC-796a8efe25e74253b25d3c8a265635e8517d5f05.tar.gz opensim-SC-796a8efe25e74253b25d3c8a265635e8517d5f05.tar.bz2 opensim-SC-796a8efe25e74253b25d3c8a265635e8517d5f05.tar.xz |
a few changes to tp home
Diffstat (limited to 'OpenSim/Region/CoreModules/Framework/EntityTransfer')
-rw-r--r-- | OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs | 91 | ||||
-rw-r--r-- | OpenSim/Region/CoreModules/Framework/EntityTransfer/HGEntityTransferModule.cs | 84 |
2 files changed, 118 insertions, 57 deletions
diff --git a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs index 53061a4..ce88e6b 100644 --- a/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs +++ b/OpenSim/Region/CoreModules/Framework/EntityTransfer/EntityTransferModule.cs | |||
@@ -391,7 +391,6 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
391 | 391 | ||
392 | try | 392 | try |
393 | { | 393 | { |
394 | |||
395 | if (regionHandle == sp.Scene.RegionInfo.RegionHandle) | 394 | if (regionHandle == sp.Scene.RegionInfo.RegionHandle) |
396 | { | 395 | { |
397 | if(!sp.AllowMovement) | 396 | if(!sp.AllowMovement) |
@@ -486,7 +485,13 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
486 | { | 485 | { |
487 | position.Z = posZLimit; | 486 | position.Z = posZLimit; |
488 | } | 487 | } |
489 | 488 | /* | |
489 | if(!sp.CheckLocalTPLandingPoint(ref position)) | ||
490 | { | ||
491 | sp.ControllingClient.SendTeleportFailed("Not allowed at destination"); | ||
492 | return; | ||
493 | } | ||
494 | */ | ||
490 | if (sp.Flying) | 495 | if (sp.Flying) |
491 | teleportFlags |= (uint)TeleportFlags.IsFlying; | 496 | teleportFlags |= (uint)TeleportFlags.IsFlying; |
492 | 497 | ||
@@ -1389,45 +1394,67 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
1389 | 1394 | ||
1390 | public virtual bool TeleportHome(UUID id, IClientAPI client) | 1395 | public virtual bool TeleportHome(UUID id, IClientAPI client) |
1391 | { | 1396 | { |
1392 | m_log.DebugFormat( | 1397 | bool isSame = false; |
1393 | "[ENTITY TRANSFER MODULE]: Request to teleport {0} {1} home", client.Name, client.AgentId); | 1398 | if (client != null && id == client.AgentId) |
1399 | { | ||
1400 | isSame = true; | ||
1401 | m_log.DebugFormat( | ||
1402 | "[ENTITY TRANSFER MODULE]: Request to teleport {0} {1} home", client.Name, id); | ||
1403 | } | ||
1404 | else | ||
1405 | m_log.DebugFormat( | ||
1406 | "[ENTITY TRANSFER MODULE]: Request to teleport {0} home by {1} {2}", id, client.Name, client.AgentId); | ||
1394 | 1407 | ||
1395 | //OpenSim.Services.Interfaces.PresenceInfo pinfo = Scene.PresenceService.GetAgent(client.SessionId); | 1408 | ScenePresence sp = ((Scene)(client.Scene)).GetScenePresence(id); |
1396 | GridUserInfo uinfo = Scene.GridUserService.GetGridUserInfo(client.AgentId.ToString()); | 1409 | if (sp == null || sp.IsDeleted || sp.IsChildAgent || sp.ControllingClient == null || !sp.ControllingClient.IsActive) |
1410 | { | ||
1411 | if (isSame) | ||
1412 | client.SendTeleportFailed("Internal error, agent presence not found"); | ||
1413 | m_log.DebugFormat("[ENTITY TRANSFER MODULE]: Agent not found in the scene where it is supposed to be"); | ||
1414 | return false; | ||
1415 | } | ||
1397 | 1416 | ||
1398 | if (uinfo != null) | 1417 | if (sp.IsInTransit) |
1399 | { | 1418 | { |
1400 | if (uinfo.HomeRegionID == UUID.Zero) | 1419 | if (isSame) |
1401 | { | 1420 | client.SendTeleportFailed("Already processing a teleport"); |
1402 | // can't find the Home region: Tell viewer and abort | 1421 | m_log.DebugFormat("[ENTITY TRANSFER MODULE]: Agent still in teleport"); |
1403 | m_log.ErrorFormat("{0} No grid user info found for {1} {2}. Cannot send home.", | 1422 | return false; |
1404 | LogHeader, client.Name, client.AgentId); | 1423 | } |
1405 | client.SendTeleportFailed("You don't have a home position set."); | ||
1406 | return false; | ||
1407 | } | ||
1408 | GridRegion regionInfo = Scene.GridService.GetRegionByUUID(UUID.Zero, uinfo.HomeRegionID); | ||
1409 | if (regionInfo == null) | ||
1410 | { | ||
1411 | // can't find the Home region: Tell viewer and abort | ||
1412 | client.SendTeleportFailed("Your home region could not be found."); | ||
1413 | return false; | ||
1414 | } | ||
1415 | 1424 | ||
1416 | m_log.DebugFormat("[ENTITY TRANSFER MODULE]: Home region of {0} is {1} ({2}-{3})", | 1425 | //OpenSim.Services.Interfaces.PresenceInfo pinfo = Scene.PresenceService.GetAgent(client.SessionId); |
1417 | client.Name, regionInfo.RegionName, regionInfo.RegionCoordX, regionInfo.RegionCoordY); | 1426 | GridUserInfo uinfo = Scene.GridUserService.GetGridUserInfo(id.ToString()); |
1427 | if(uinfo == null) | ||
1428 | { | ||
1429 | m_log.ErrorFormat("[ENTITY TRANSFER MODULE] Griduser info not found for {1}. Cannot send home.", id); | ||
1430 | if (isSame) | ||
1431 | client.SendTeleportFailed("Your home region could not be found."); | ||
1432 | return false; | ||
1433 | } | ||
1418 | 1434 | ||
1419 | // a little eekie that this goes back to Scene and with a forced cast, will fix that at some point... | 1435 | if (uinfo.HomeRegionID == UUID.Zero) |
1420 | ((Scene)(client.Scene)).RequestTeleportLocation( | 1436 | { |
1421 | client, regionInfo.RegionHandle, uinfo.HomePosition, uinfo.HomeLookAt, | 1437 | // can't find the Home region: Tell viewer and abort |
1422 | (uint)(Constants.TeleportFlags.SetLastToTarget | Constants.TeleportFlags.ViaHome)); | 1438 | m_log.ErrorFormat("[ENTITY TRANSFER MODULE] no home set {0}", id); |
1423 | return true; | 1439 | if (isSame) |
1440 | client.SendTeleportFailed("home position set not"); | ||
1441 | return false; | ||
1424 | } | 1442 | } |
1425 | else | 1443 | |
1444 | GridRegion regionInfo = Scene.GridService.GetRegionByUUID(UUID.Zero, uinfo.HomeRegionID); | ||
1445 | if (regionInfo == null) | ||
1426 | { | 1446 | { |
1427 | // can't find the Home region: Tell viewer and abort | 1447 | // can't find the Home region: Tell viewer and abort |
1428 | client.SendTeleportFailed("Your home region could not be found."); | 1448 | m_log.ErrorFormat("[ENTITY TRANSFER MODULE] {0} home region {1} not found", id, uinfo.HomeRegionID); |
1449 | if (isSame) | ||
1450 | client.SendTeleportFailed("Your home region could not be found."); | ||
1451 | return false; | ||
1429 | } | 1452 | } |
1430 | return false; | 1453 | |
1454 | Teleport(sp, regionInfo.RegionHandle, uinfo.HomePosition, uinfo.HomeLookAt, | ||
1455 | (uint)(Constants.TeleportFlags.SetLastToTarget | Constants.TeleportFlags.ViaHome)); | ||
1456 | |||
1457 | return true; | ||
1431 | } | 1458 | } |
1432 | 1459 | ||
1433 | #endregion | 1460 | #endregion |
diff --git a/OpenSim/Region/CoreModules/Framework/EntityTransfer/HGEntityTransferModule.cs b/OpenSim/Region/CoreModules/Framework/EntityTransfer/HGEntityTransferModule.cs index 56c654f..c82d93a 100644 --- a/OpenSim/Region/CoreModules/Framework/EntityTransfer/HGEntityTransferModule.cs +++ b/OpenSim/Region/CoreModules/Framework/EntityTransfer/HGEntityTransferModule.cs | |||
@@ -38,13 +38,14 @@ using OpenSim.Services.Connectors.Hypergrid; | |||
38 | using OpenSim.Services.Interfaces; | 38 | using OpenSim.Services.Interfaces; |
39 | using OpenSim.Server.Base; | 39 | using OpenSim.Server.Base; |
40 | 40 | ||
41 | using GridRegion = OpenSim.Services.Interfaces.GridRegion; | ||
42 | |||
43 | using OpenMetaverse; | 41 | using OpenMetaverse; |
44 | using log4net; | 42 | using log4net; |
45 | using Nini.Config; | 43 | using Nini.Config; |
46 | using Mono.Addins; | 44 | using Mono.Addins; |
47 | 45 | ||
46 | using GridRegion = OpenSim.Services.Interfaces.GridRegion; | ||
47 | |||
48 | |||
48 | namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | 49 | namespace OpenSim.Region.CoreModules.Framework.EntityTransfer |
49 | { | 50 | { |
50 | [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "HGEntityTransferModule")] | 51 | [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "HGEntityTransferModule")] |
@@ -436,9 +437,6 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
436 | 437 | ||
437 | public override bool TeleportHome(UUID id, IClientAPI client) | 438 | public override bool TeleportHome(UUID id, IClientAPI client) |
438 | { | 439 | { |
439 | m_log.DebugFormat( | ||
440 | "[ENTITY TRANSFER MODULE]: Request to teleport {0} {1} home", client.Name, client.AgentId); | ||
441 | |||
442 | // Let's find out if this is a foreign user or a local user | 440 | // Let's find out if this is a foreign user or a local user |
443 | IUserManagement uMan = Scene.RequestModuleInterface<IUserManagement>(); | 441 | IUserManagement uMan = Scene.RequestModuleInterface<IUserManagement>(); |
444 | if (uMan != null && uMan.IsLocalGridUser(id)) | 442 | if (uMan != null && uMan.IsLocalGridUser(id)) |
@@ -448,23 +446,53 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
448 | return base.TeleportHome(id, client); | 446 | return base.TeleportHome(id, client); |
449 | } | 447 | } |
450 | 448 | ||
449 | bool issame = false; | ||
450 | if (client != null && id == client.AgentId) | ||
451 | { | ||
452 | issame = true; | ||
453 | m_log.DebugFormat( | ||
454 | "[HG ENTITY TRANSFER MODULE]: Request to teleport {0} {1} home", client.Name, id); | ||
455 | } | ||
456 | else | ||
457 | m_log.DebugFormat( | ||
458 | "[HG ENTITY TRANSFER MODULE]: Request to teleport {0} home by {1} {2}", id, client.Name, client.AgentId); | ||
459 | |||
460 | ScenePresence sp = ((Scene)(client.Scene)).GetScenePresence(id); | ||
461 | if (sp == null || sp.IsDeleted || sp.IsChildAgent || sp.ControllingClient == null || !sp.ControllingClient.IsActive) | ||
462 | { | ||
463 | if (issame) | ||
464 | client.SendTeleportFailed("Internal error, agent presence not found"); | ||
465 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent not found in the scene"); | ||
466 | return false; | ||
467 | } | ||
468 | |||
469 | if (sp.IsInTransit) | ||
470 | { | ||
471 | if (issame) | ||
472 | client.SendTeleportFailed("Already processing a teleport"); | ||
473 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent still in teleport"); | ||
474 | return false; | ||
475 | } | ||
476 | |||
451 | // Foreign user wants to go home | 477 | // Foreign user wants to go home |
452 | // | 478 | // |
453 | AgentCircuitData aCircuit = ((Scene)(client.Scene)).AuthenticateHandler.GetAgentCircuitData(client.CircuitCode); | 479 | AgentCircuitData aCircuit = sp.Scene.AuthenticateHandler.GetAgentCircuitData(sp.ControllingClient.CircuitCode); |
454 | if (aCircuit == null || (aCircuit != null && !aCircuit.ServiceURLs.ContainsKey("HomeURI"))) | 480 | if (aCircuit == null || !aCircuit.ServiceURLs.ContainsKey("HomeURI")) |
455 | { | 481 | { |
456 | client.SendTeleportFailed("Your information has been lost"); | 482 | if (issame) |
483 | client.SendTeleportFailed("Agent Home information has been lost"); | ||
457 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Unable to locate agent's gateway information"); | 484 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Unable to locate agent's gateway information"); |
458 | return false; | 485 | return false; |
459 | } | 486 | } |
487 | string homeURI = aCircuit.ServiceURLs["HomeURI"].ToString(); | ||
460 | 488 | ||
461 | IUserAgentService userAgentService = new UserAgentServiceConnector(aCircuit.ServiceURLs["HomeURI"].ToString()); | 489 | IUserAgentService userAgentService = new UserAgentServiceConnector(homeURI); |
462 | Vector3 position = Vector3.UnitY, lookAt = Vector3.UnitY; | 490 | Vector3 position = Vector3.UnitY, lookAt = Vector3.UnitY; |
463 | 491 | ||
464 | GridRegion finalDestination = null; | 492 | GridRegion finalDestination = null; |
465 | try | 493 | try |
466 | { | 494 | { |
467 | finalDestination = userAgentService.GetHomeRegion(aCircuit.AgentID, out position, out lookAt); | 495 | finalDestination = userAgentService.GetHomeRegion(id, out position, out lookAt); |
468 | } | 496 | } |
469 | catch (Exception e) | 497 | catch (Exception e) |
470 | { | 498 | { |
@@ -473,20 +501,21 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
473 | 501 | ||
474 | if (finalDestination == null) | 502 | if (finalDestination == null) |
475 | { | 503 | { |
476 | client.SendTeleportFailed("Your home region could not be found"); | 504 | if (issame) |
505 | client.SendTeleportFailed("Home region could not be found"); | ||
477 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent's home region not found"); | 506 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent's home region not found"); |
478 | return false; | 507 | return false; |
479 | } | 508 | } |
480 | 509 | ||
481 | ScenePresence sp = ((Scene)(client.Scene)).GetScenePresence(client.AgentId); | 510 | if (sp.IsDeleted || sp.IsChildAgent || sp.IsInTransit) |
482 | if (sp == null) | ||
483 | { | 511 | { |
484 | client.SendTeleportFailed("Internal error"); | 512 | if (issame) |
485 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent not found in the scene where it is supposed to be"); | 513 | client.SendTeleportFailed("Agent lost or started other tp"); |
514 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: Agent lost or started other tp"); | ||
486 | return false; | 515 | return false; |
487 | } | 516 | } |
488 | 517 | ||
489 | GridRegion homeGatekeeper = MakeRegion(aCircuit); | 518 | GridRegion homeGatekeeper = MakeGateKeeperRegion(homeURI); |
490 | 519 | ||
491 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: teleporting user {0} {1} home to {2} via {3}:{4}", | 520 | m_log.DebugFormat("[HG ENTITY TRANSFER MODULE]: teleporting user {0} {1} home to {2} via {3}:{4}", |
492 | aCircuit.firstname, aCircuit.lastname, finalDestination.RegionName, homeGatekeeper.ServerURI, homeGatekeeper.RegionName); | 521 | aCircuit.firstname, aCircuit.lastname, finalDestination.RegionName, homeGatekeeper.ServerURI, homeGatekeeper.RegionName); |
@@ -525,8 +554,13 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
525 | { | 554 | { |
526 | // Foreign region | 555 | // Foreign region |
527 | GatekeeperServiceConnector gConn = new GatekeeperServiceConnector(); | 556 | GatekeeperServiceConnector gConn = new GatekeeperServiceConnector(); |
528 | GridRegion gatekeeper = new GridRegion(); | 557 | GridRegion gatekeeper = MakeGateKeeperRegion(lm.Gatekeeper); |
529 | gatekeeper.ServerURI = lm.Gatekeeper; | 558 | if (gatekeeper == null) |
559 | { | ||
560 | remoteClient.SendTeleportFailed("Could not parse landmark destiny URI"); | ||
561 | return; | ||
562 | } | ||
563 | |||
530 | string homeURI = Scene.GetAgentHomeURI(remoteClient.AgentId); | 564 | string homeURI = Scene.GetAgentHomeURI(remoteClient.AgentId); |
531 | 565 | ||
532 | string message; | 566 | string message; |
@@ -741,20 +775,20 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer | |||
741 | 775 | ||
742 | #endregion | 776 | #endregion |
743 | 777 | ||
744 | private GridRegion MakeRegion(AgentCircuitData aCircuit) | 778 | private GridRegion MakeGateKeeperRegion(string wantedURI) |
745 | { | 779 | { |
746 | GridRegion region = new GridRegion(); | 780 | Uri uri; |
747 | 781 | if(!Uri.TryCreate(wantedURI, UriKind.Absolute, out uri)) | |
748 | Uri uri = null; | ||
749 | if (!aCircuit.ServiceURLs.ContainsKey("HomeURI") || | ||
750 | (aCircuit.ServiceURLs.ContainsKey("HomeURI") && !Uri.TryCreate(aCircuit.ServiceURLs["HomeURI"].ToString(), UriKind.Absolute, out uri))) | ||
751 | return null; | 782 | return null; |
752 | 783 | ||
784 | GridRegion region = new GridRegion(); | ||
785 | |||
753 | region.ExternalHostName = uri.Host; | 786 | region.ExternalHostName = uri.Host; |
754 | region.HttpPort = (uint)uri.Port; | 787 | region.HttpPort = (uint)uri.Port; |
755 | region.ServerURI = aCircuit.ServiceURLs["HomeURI"].ToString(); | 788 | region.ServerURI = wantedURI; //uri.AbsoluteUri for some reason default ports are needed |
756 | region.RegionName = string.Empty; | 789 | region.RegionName = string.Empty; |
757 | region.InternalEndPoint = new System.Net.IPEndPoint(System.Net.IPAddress.Parse("0.0.0.0"), (int)0); | 790 | region.InternalEndPoint = new System.Net.IPEndPoint(System.Net.IPAddress.Parse("0.0.0.0"), (int)0); |
791 | region.RegionFlags = OpenSim.Framework.RegionFlags.Hyperlink; | ||
758 | return region; | 792 | return region; |
759 | } | 793 | } |
760 | } | 794 | } |