Hypergrid Protocol
From OpenSimulator
(Difference between revisions)
(→Teleport of an agent into a foreign grid) |
(→Teleport of an agent into a foreign grid) |
||
Line 47: | Line 47: | ||
# Destination region waits for initial client seed [[capabilities]] connection. | # Destination region waits for initial client seed [[capabilities]] connection. | ||
## On receipt verifies client with source grid's User Agent service that user agent originates from there. | ## On receipt verifies client with source grid's User Agent service that user agent originates from there. | ||
− | ## In the simulator this point is indicated in the log with | + | ## In the simulator this point is indicated in the log with a message such as ''"[SCENE]: Incoming client Joe Bloggs in region my-region via HG login"''. |
## Hence, the home grid of the incoming agent must have a UserAgent service that is reacahable by the simulator receiving the connection. | ## Hence, the home grid of the incoming agent must have a UserAgent service that is reacahable by the simulator receiving the connection. | ||
− | ## If verification is successful, then one would see a simulator debug log message such as "[SCENE]: User Client Verification for Joe Bloggs in my-region returned true". | + | ## If verification is successful, then one would see a simulator debug log message such as ''"[SCENE]: User Client Verification for Joe Bloggs in my-region returned true"''. |
− | ## If verification fails (almost always because the user agent service could not be contacted), then one would see a simulator debug log message such as "[SCENE]: User Client Verification for Joe Bloggs in my-region returned false". The user will be denied access to the region. | + | ## If verification fails (almost always because the user agent service could not be contacted), then one would see a simulator debug log message such as ''"[SCENE]: User Client Verification for Joe Bloggs in my-region returned false"''. The user will be denied access to the region. |
# Receives incoming attachments for foreign agent. | # Receives incoming attachments for foreign agent. | ||
[[Category:Hypergrid]] | [[Category:Hypergrid]] |
Revision as of 15:30, 1 December 2014
Contents[hide] |
Introduction
This page begins to describe the protocol level details for Hypergrid. It will apply only to Hypergrid 2.0 and later.
Components
Grid Services
Gatekeeper service
- Provides information to callers about Hypergrid accessible regions on the grid.
- Controls and manages user agent access to the grid - similar to the login service for non-Hypergrid users.
- Authenticates an incoming connection with the source grid's User Agent VerifyAgent call.
User Agent service
- Provides a VerifyAgent call so that the Gatekeeper service can authenticate that an incoming user agent originates from its given source grid.
Simulator
As source of teleport
- Initiates teleport process once requested by a viewer.
- Makes contact with destination grid's gatekeeper service.
- On approval, signals client to begin teleport and starts hand off to source region.
- Part of this is sending attachments information over to the foreign region.
As destination of teleport
- Verify's user agent with source installation's User Agent service.
- Relays inventory requests to home grid inventory service.
- On rezzing objects, inspects referenced assets and requests from home grid asset service.
- If assets can be imported, then copies to local asset service.
Viewer
- Speaks to the current and target simulators using LLUDP and capabilities.
- No interation with grid services to complete teleport.
Protocol Flow
Teleport of an agent into a foreign grid
- Gatekeeper service receives a request from the source grid for information about a region with a given UUID.
- If the gatekeeper can find the region in the grid service, the details are returned to the requester.
- The most crucial is the ExternalHostName and InternalPort (a misleading name as it is also the external port) as set up in the Regions configuration file. This is the address (along with the simulators HTTP port) that the viewer will use to transfer to the destination region from its source region.
- If teleporting direct to regions is disallowed by the grid then the a gateway region may be returned instead.
- If the region is not found then a failure response is returned.
- Gatekeeper service receives login request for a given agent (e.g. Joe Bloggs @ http://grid-source.com:8002).
- Gatekeeper service authenticates with source grid's User Agent service that user agent originates from there.
- Gatekeeper service notifies destination region that a connection is incoming.
- Destination region waits for initial client seed capabilities connection.
- On receipt verifies client with source grid's User Agent service that user agent originates from there.
- In the simulator this point is indicated in the log with a message such as "[SCENE]: Incoming client Joe Bloggs in region my-region via HG login".
- Hence, the home grid of the incoming agent must have a UserAgent service that is reacahable by the simulator receiving the connection.
- If verification is successful, then one would see a simulator debug log message such as "[SCENE]: User Client Verification for Joe Bloggs in my-region returned true".
- If verification fails (almost always because the user agent service could not be contacted), then one would see a simulator debug log message such as "[SCENE]: User Client Verification for Joe Bloggs in my-region returned false". The user will be denied access to the region.
- Receives incoming attachments for foreign agent.