Difference between revisions of "User:Takat Su/Name2Key"
Line 11: | Line 11: | ||
I put a kind of "library" and a sample of usage for your convenience | I put a kind of "library" and a sample of usage for your convenience | ||
To use, you make an llHttpRequest to the application running on the Google Application Server (a free service for moderate users). The URL looks like this: http://name2key.appspot.com/?name=firstname%20lastname i.e. the first name of the person you want to look up is separated from their last name by "%20" (this is how the space character is coded in URLs). The application doesn't care if you get the case correct. The application will format the body of the return as follows: firstname lastname:key, where firstname and lastname will be capitalized correctly and the key is either the key for the person or the null key (00000000-0000-0000-0000-000000000000). It really isn't much code if you prefer to code it into your main script rather than rely on an external script for the lookup. | To use, you make an llHttpRequest to the application running on the Google Application Server (a free service for moderate users). The URL looks like this: http://name2key.appspot.com/?name=firstname%20lastname i.e. the first name of the person you want to look up is separated from their last name by "%20" (this is how the space character is coded in URLs). The application doesn't care if you get the case correct. The application will format the body of the return as follows: firstname lastname:key, where firstname and lastname will be capitalized correctly and the key is either the key for the person or the null key (00000000-0000-0000-0000-000000000000) if the name doesn't exist. It really isn't much code if you prefer to code it into your main script rather than rely on an external script for the lookup. | ||
<b>DONE</b>: Alter the python code so that it fails gracefully if the name given in the URL does not exist or if Linden Search is down. | <b>DONE</b>: Alter the python code so that it fails gracefully if the name given in the URL does not exist or if Linden Search is down. |
Revision as of 20:40, 13 June 2013
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Name2Key
This is an update to Maeva Anatine's excellent suggestion for an updated name2key function. Rather than overwrite all her work, I created this page. The idea is DEFINITELY hers - I just am creating an alternate implementation.
Still missing Name2Key functions in your code? Still relying on external databases that are not always up to date with latests SL subscribers?
Well now you can solve this by yourself, within your LSL script! All you have to do is to rely on LL Search engine!
I put a kind of "library" and a sample of usage for your convenience
To use, you make an llHttpRequest to the application running on the Google Application Server (a free service for moderate users). The URL looks like this: http://name2key.appspot.com/?name=firstname%20lastname i.e. the first name of the person you want to look up is separated from their last name by "%20" (this is how the space character is coded in URLs). The application doesn't care if you get the case correct. The application will format the body of the return as follows: firstname lastname:key, where firstname and lastname will be capitalized correctly and the key is either the key for the person or the null key (00000000-0000-0000-0000-000000000000) if the name doesn't exist. It really isn't much code if you prefer to code it into your main script rather than rely on an external script for the lookup.
DONE: Alter the python code so that it fails gracefully if the name given in the URL does not exist or if Linden Search is down.
Library
<lsl> integer cmdName2Key = 19790; integer cmdName2KeyResponse = 19791;
list gRequests;
key requestName2Key( string inName ) {
list lNameParts = llParseString2List( inName, [" "], [] ); string lFirstName = llList2String( lNameParts, 0 ); string lLastName = llList2String( lNameParts, 1 ); return llHTTPRequest( "http://name2key.appspot.com/?name=" + lFirstName + "%20" + lLastName, [], "" );
}
default {
link_message( integer inFromPrim, integer inCommand, string inName, key inKey ) { if( inCommand == cmdName2Key ) gRequests += [requestName2Key( inName ), inKey ]; } http_response(key inKey, integer inStatus, list inMetaData, string inBody ) { integer lPosition = llListFindList( gRequests, [inKey]); if( lPosition != -1 ) { llMessageLinked( LINK_SET, cmdName2KeyResponse, inBody, llList2Key( gRequests, lPosition+1 ) ); gRequests = llDeleteSubList( gRequests, lPosition, lPosition + 1 ); } }
} </lsl>
Usage sample
<lsl> integer cmdName2Key = 19790; integer cmdName2KeyResponse = 19791;
default {
state_entry() { llMessageLinked( LINK_SET, cmdName2Key, "Test Name", NULL_KEY ); } link_message( integer inFromPrim, integer inCommand, string inKeyData, key inReturnedKey ) { if( inCommand == cmdName2KeyResponse ) { list lParts = llParseString2List( inKeyData, [":"], [] ); string lName = llList2String( lParts, 0 ); key lKey = (key)llList2String(lParts, 1 ); } }}</lsl>
Google App Python Code
<python>
- Updated by Kisamin Resident for the latest google app engine
import webapp2
import urllib
kURL = "http://vwrsearch.secondlife.com/client_search.php?session=00000000-0000-0000-0000-000000000000&q=" kProfile = "Resident profile" kResult = "secondlife:///app/agent/"
class MainHandler( webapp2.RequestHandler ):
def get(self): l_Name = self.request.get("name").upper() if not isinstance( l_Name, str): l_Name = l_Name.decode("utf-8") l_name = l_Name.replace (" ", "%20") l_foundName = l_Name l_key = '00000000-0000-0000-0000-000000000000' try: l_data = urllib.urlopen(kURL + l_name).read() l_start = l_data.index (kProfile) l_foundName = l_data[l_start+18:l_start+18+len(l_Name)] l_key = '00000000-0000-0000-0000-000000000000' if l_foundName.upper () == l_Name: l_start = l_data.index (kResult) l_key = l_data[l_start+len(kResult):l_start+len(kResult)+36] else: l_foundName = l_Name except: l_fFoundName = l_Name finally: self.response.out.write ("%s:%s" % (l_foundName, l_key))
app = webapp2.WSGIApplication([
('/', MainHandler)
], debug=True)
</python>app.yaml file
<xml> application: avatarkeyfromname version: 1 runtime: python27 api_version: 1 threadsafe: yes
handlers: - url: .*
script: main.app
libraries: - name: webapp2
version: "2.5.2"</xml>
Name2Key PHP Code
In case you wanted to use PHP instead
<php> <?php function findit ($in_RawName) { $kURL = 'http://vwrsearch.secondlife.com/client_search.php?session=00000000-0000-0000-0000-000000000000&q='; $kProfile = 'Resident profile'; $kResult = 'secondlife:///app/agent/';
$l_RawName = strtoupper($in_RawName); $l_URLName = str_replace (' ', '%20', $l_RawName); $l_FoundName = $l_RawName; $l_Key = '00000000-0000-0000-0000-000000000000';
$l_HTML = file_get_contents ($kURL . $l_URLName); $l_Start = strpos ($l_HTML, $kProfile); $l_FoundName = substr($l_HTML, $l_Start+18, strlen($l_RawName));
if (strtoupper($l_FoundName) == $l_RawName) { $l_Start = strpos($l_HTML, $kResult); $l_Key = substr ($l_HTML, $l_Start + strlen($kResult), 36); } else $l_FoundName = $l_RawName; return $l_FoundName . ":" . $l_Key; }
parse_str ($_SERVER['QUERY_STRING']); print findit ($name); ?>
</php>Comments
Updated 13-Jun-2013 for latest Google App-Engine. It also now properly handles non-existent account names, returning an all-upper-case name and a null-key. Also added PHP version for people who don't want to host on the Google App Engine
The main difference is that I wrote an app for the google app engine that act as a relay. Since I was going that far, it also parses the return, strips out all the extraneous stuff and just returns you the name and key separated by a colon.