Difference between revisions of "Authenticated Chat"
Jump to navigation
Jump to search
Gigs Taggart (talk | contribs) (new) |
m |
||
Line 1: | Line 1: | ||
Here's a method of | Here's a method of authenticating chat with shared secret. | ||
<pre> | <pre> | ||
//By: Gigs Taggart | //By: Gigs Taggart | ||
//Modified by Strife Onizuka | |||
//Released under BSD license | //Released under BSD license | ||
string gSetupNotecardName = "setup"; | string gSetupNotecardName = "setup"; | ||
string gPassword; | string gPassword; | ||
integer gSeed; | |||
key gSetupQueryId; | |||
integer gSetupNotecardLine; | |||
//to sign a message we hash message+gSecret+llGetKey() | //to sign a message we hash message+gSecret+llGetKey() | ||
string sign_message(string message) | string sign_message(string message) | ||
{ | { | ||
string hash = llMD5String(message + gPassword + (string)llGetKey(), gSeed); | |||
return message + hash; | |||
} | } | ||
//to verify a message we do all the same stuff except we get the sender's key | //to verify a message we do all the same stuff except we get the sender's key | ||
integer verify_message(string | integer verify_message(string raw, key sender) | ||
{ | { | ||
string hash = llMD5String(llDeleteSubString(message, -32, -1) + gPassword + (string)sender, gSeed); | |||
string hash=llMD5String( | return llGetSubString(message, -32, -1) == hash; | ||
} | } | ||
Line 37: | Line 32: | ||
{ | { | ||
gSetupNotecardLine = 0; | gSetupNotecardLine = 0; | ||
gSetupQueryId = llGetNotecardLine(gSetupNotecardName,gSetupNotecardLine); | gSetupQueryId = llGetNotecardLine(gSetupNotecardName, gSetupNotecardLine); | ||
} | } | ||
Line 53: | Line 48: | ||
if(data != EOF) | if(data != EOF) | ||
{ | { | ||
integer split = llSubStringIndex(data, "="); | |||
if(~split) | |||
if ( | |||
{ | { | ||
string setting = llDeleteSubString(data, split, -1); | |||
string value = llDeleteSubString(data, 0, split); | |||
if (setting == "password") | |||
{ | |||
gPassword = value; | |||
} | |||
else if(setting == "seed") | |||
{ | |||
gSeed = (integer)value; | |||
} | |||
} | } | ||
gSetupQueryId = llGetNotecardLine(gSetupNotecardName, ++gSetupNotecardLine); | |||
gSetupQueryId = llGetNotecardLine(gSetupNotecardName,++gSetupNotecardLine); | |||
} | } | ||
else | else | ||
Line 82: | Line 84: | ||
} | } | ||
} | } | ||
</pre> | |||
====Notecard==== | |||
'''Name:''' "setup" | |||
<pre> | |||
password=secret | |||
seed=0xdeadbeef | |||
</pre> | </pre> | ||
{{LSLC|Examples|Authenticated Chat}} | {{LSLC|Examples|Authenticated Chat}} |
Revision as of 19:55, 29 August 2007
Here's a method of authenticating chat with shared secret.
//By: Gigs Taggart //Modified by Strife Onizuka //Released under BSD license string gSetupNotecardName = "setup"; string gPassword; integer gSeed; key gSetupQueryId; integer gSetupNotecardLine; //to sign a message we hash message+gSecret+llGetKey() string sign_message(string message) { string hash = llMD5String(message + gPassword + (string)llGetKey(), gSeed); return message + hash; } //to verify a message we do all the same stuff except we get the sender's key integer verify_message(string raw, key sender) { string hash = llMD5String(llDeleteSubString(message, -32, -1) + gPassword + (string)sender, gSeed); return llGetSubString(message, -32, -1) == hash; } readSettingsNotecard() { gSetupNotecardLine = 0; gSetupQueryId = llGetNotecardLine(gSetupNotecardName, gSetupNotecardLine); } default { state_entry() { readSettingsNotecard(); } dataserver(key queryId, string data) { if(queryId == gSetupQueryId) { if(data != EOF) { integer split = llSubStringIndex(data, "="); if(~split) { string setting = llDeleteSubString(data, split, -1); string value = llDeleteSubString(data, 0, split); if (setting == "password") { gPassword = value; } else if(setting == "seed") { gSeed = (integer)value; } } gSetupQueryId = llGetNotecardLine(gSetupNotecardName, ++gSetupNotecardLine); } else { state running; } } } changed(integer change) { llResetScript(); } } state running { changed(integer change) { llResetScript(); } }
Notecard
Name: "setup"
password=secret seed=0xdeadbeef