TeaEncode: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
|  (Fixed syntaxhighlight tags for script examples) |  (Added important note about how shit this function is(So, use encodeString instead)) | ||
| Line 5: | Line 5: | ||
| This functions performs the [https://en.wikipedia.org/wiki/Tiny_Encryption_Algorithm Tiny Encryption Algorithm] on the given string and returns the [https://en.wikipedia.org/wiki/Base64 base64] representation of the encrypted string. | This functions performs the [https://en.wikipedia.org/wiki/Tiny_Encryption_Algorithm Tiny Encryption Algorithm] on the given string and returns the [https://en.wikipedia.org/wiki/Base64 base64] representation of the encrypted string. | ||
| }} | }} | ||
| {{Important Note|Use [[encodeString]] instead, because teaEncode inflates the file size by as high as ~77%(or by ~33% if the input isn't binary converted to base64 string}} | |||
| ==Syntax== | ==Syntax== | ||
Revision as of 15:41, 16 August 2018
This functions performs the Tiny Encryption Algorithm on the given string and returns the base64 representation of the encrypted string.
| Important Note: Use encodeString instead, because teaEncode inflates the file size by as high as ~77%(or by ~33% if the input isn't binary converted to base64 string | 
Syntax
string teaEncode ( string text , string key )
Required Arguments
- text: The string you want to encrypt. (See second example if you want to encode binary data)
- key: The key that should be used for encryption (Only first 16 characters are used)
Returns
Returns the base64 representation of the encrypted string if the encryption process was successfully completed, false otherwise.
Example
Click to collapse [-]
ClientThis example creates a /teaencrypt command, which performs the TEA on a given string with the specified key, if any.
function encryptString( cmd, theString, theKey )
    if ( theString ) then
        if ( not theKey ) then
            theKey = string.rep( string.char( math.random( string.byte( "a" ), string.byte( "Z" ) ) ), 10 ) -- Generate a random key of 10 characters if no key was passed in as an argument
        end
        local encodedString = teaEncode( theString, theKey ) -- Encode the string with the key
        outputChatBox( "The encoded string is: " .. tostring( encodedString ) .. " (used key: " .. theKey .. ")" )
    else
        outputChatBox( "Syntax: /" .. cmd .. " [string] <[key]>" )
    end
end
addCommandHandler( "teaencrypt", encryptString )
This shows how to use teaEncode/teaDecode with binary data:
function teaEncodeBinary( data, key )
    return teaEncode( base64Encode( data ), key )
end
function teaDecodeBinary( data, key )
    return base64Decode( teaDecode( data, key ) )
end
See Also
- addDebugHook
- debugSleep
- decodeString
- encodeString
- fromJSON
- generateKeyPair
- getColorFromString
- getDevelopmentMode
- getDistanceBetweenPoints2D
- getDistanceBetweenPoints3D
- getEasingValue
- getNetworkStats
- getNetworkUsageData
- getPerformanceStats
- getRealTime
- getTickCount
- getTimerDetails
- getTimers
- getFPSLimit
- getUserdataType
- getVersion
- gettok
- isTransferBoxVisible
- setTransferBoxVisible
- hash
- inspect
- interpolateBetween
- iprint
- isOOPEnabled
- isTimer
- killTimer
- md5
- passwordHash
- passwordVerify
- pregFind
- pregMatch
- pregReplace
- removeDebugHook
- resetTimer
- setDevelopmentMode
- setFPSLimit
- setTimer
- ref
- deref
- sha256
- split
- teaDecode
- teaEncode
- toJSON
- tocolor
- getProcessMemoryStats
- utfChar
- utfCode
- utfLen
- utfSeek
- utfSub
- bitAnd
- bitNot
- bitOr
- bitXor
- bitTest
- bitLRotate
- bitRRotate
- bitLShift
- bitRShift
- bitArShift
- bitExtract
- bitReplace