Difference between revisions of "LlRequestUsername"

From Second Life Wiki
Jump to navigation Jump to search
m
m
 
(One intermediate revision by one other user not shown)
Line 9: Line 9:
If {{LSLPT|id}} is not the UUID of an avatar, the [[dataserver]] event is not raised.
If {{LSLPT|id}} is not the UUID of an avatar, the [[dataserver]] event is not raised.
|p1_type=key|p1_name=id
|p1_type=key|p1_name=id
|func_footnote
|func_desc=Requests the '''[[Usernames|Username]]''' of the agent identified by {{LSLPT|id}}. When the '''[[Usernames|Username]]''' is available the [[dataserver]] event will be raised. The agent identified by {{LSLPT|id}} does not need to be in the same region or online at the time of the request.
|func_desc=Requests the '''[[Usernames|Username]]''' of the agent identified by {{LSLPT|id}}. When the '''[[Usernames|Username]]''' is available the [[dataserver]] event will be raised. The agent identified by {{LSLPT|id}} does not need to be in the same region or online at the time of the request.
|func_footnote=If the name has been changed some time in the past, this provides only the current name.
|spec
|spec
|caveats=
|caveats=
*If you merely wish to show the agent username in the viewer window, it may be more straightforward to use [[Viewer URI Name Space]] and avoid a dataserver event, e.g.:<source lang="lsl2">llSay(0, "secondlife:///app/agent/" + (string)id + "/username");</source>
*If you merely wish to show the agent username in the viewer window, it may be more straightforward to use [[Viewer URI Name Space]] and avoid a dataserver event, e.g.:<source lang="lsl2">llSay(0, "secondlife:///app/agent/" + (string)id + "/username");</source>
* This function is throttled. The throttle is undocumented, but as of October 2018 the function appears to support bursts of up to 20 requests and sustained use at an average rate of 1.9 requests per second. Once tripped, the function fails and says "Too many llRequestUsername requests.  Throttled until average falls." on [[DEBUG_CHANNEL]].
* This function is throttled. The throttle is undocumented, but as of October 2018 the function appears to support bursts of up to 20 requests and sustained use at an average rate of 1.9 requests per second per owner, per region. (Meaning the throttle applies to all objects in the region with the same owner.) Once tripped, the function fails and says "Too many llRequestUsername requests.  Throttled until average falls." on [[DEBUG_CHANNEL]].
|constants
|constants
|examples=<source lang="lsl2">key owner_name_query;
|examples=<source lang="lsl2">key owner_name_query;
Line 34: Line 34:
}</source>
}</source>
|helpers
|helpers
|also_functions={{LSL DefineRow||[[llGetUsername]]|}}
|also_functions=
{{LSL DefineRow||[[llGetUsername]]|works only for avatars that are present}}
{{LSL DefineRow||[[llRequestUserKey]]|general way to translate a name to a key}}
|also_tests
|also_tests
|also_events={{LSL DefineRow||[[dataserver]]|}}
|also_events={{LSL DefineRow||[[dataserver]]|}}

Latest revision as of 14:00, 27 February 2020

Summary

Function: key llRequestUsername( key id );
0.0 Forced Delay
10.0 Energy

Requests the Username of the agent identified by id. When the Username is available the dataserver event will be raised. The agent identified by id does not need to be in the same region or online at the time of the request.
Returns a handle (a key) that is used to identify the dataserver event when it is raised. If id is not the UUID of an avatar, the dataserver event is not raised.

• key id avatar UUID

If the name has been changed some time in the past, this provides only the current name.

Caveats

  • If you merely wish to show the agent username in the viewer window, it may be more straightforward to use Viewer URI Name Space and avoid a dataserver event, e.g.:
    llSay(0, "secondlife:///app/agent/" + (string)id + "/username");
    
  • This function is throttled. The throttle is undocumented, but as of October 2018 the function appears to support bursts of up to 20 requests and sustained use at an average rate of 1.9 requests per second per owner, per region. (Meaning the throttle applies to all objects in the region with the same owner.) Once tripped, the function fails and says "Too many llRequestUsername requests. Throttled until average falls." on DEBUG_CHANNEL.

Examples

key owner_name_query;
 
default
{
    state_entry()
    {
        owner_name_query = llRequestUsername(llGetOwner());
    }

    dataserver(key queryid, string data)
    {
        if ( owner_name_query == queryid )
        {
            llSay(0, "The username of the owner of this script : " + data);
        }
    }
}

See Also

Events

•  dataserver

Functions

•  llGetUsername works only for avatars that are present
•  llRequestUserKey general way to translate a name to a key

Deep Notes

Signature

function key llRequestUsername( key id );