Challenge auth
From Scriptwiki
; by doomie @ QuakeNet ; channel: #help.script ; written and tested on mIRC 6.31 ; ; What does this script do? ; ; auths with Q using the 'CHALLENGEAUTH' command ; ; How to use this script? ; ; if you want to auth, just type: /challengeauth ; However, you need to have the SHA2.dll by slug, which can be downloaded here: ; http://www.quakenet.org/development/challengeauth/SHA2.dll ; A general explanation can be found here: ; http://www.quakenet.org/development/challengeauth/ ; CONFIGURE ; $1 = dll function ; $2 = parameter for the dll function alias -l ChallengeAuth.PathToDll { return $mircdirSHA2.dll } ; DONT CHANGE ANYTHING UNDER THIS LINE UNLESS YOU KNOW WHAT YOU ARE DOING alias -l ChallengeAuth.Q { return Q@CServe.quakenet.org } alias -l ChallengeAuth.DLL { return $dll($ChallengeAuth.PathToDll,$1,$2) } ; $1 = string to lower alias -l ChallengeAuth.IRCToLower { return $replacex($lower($1),$chr(91),$chr(123),$chr(93),$chr(125),$chr(92),$chr(124),$chr(94),$chr(126)) } ; $1 = Challenge alias -l ChallengeAuth.Auth { var %ChallengeAuth.Username = $ChallengeAuth.IRCToLower($?="Username") if ($len(%ChallengeAuth.Username) == 0) { echo -s ChallengeAuth: No Username specified. return } var %ChallengeAuth.Password = $left($?="Password",10) if ($len(%ChallengeAuth.Password) == 0) { echo -s ChallengeAuth: No Password specified. return } var %ChallengeAuth.PasswordHash = $ChallengeAuth.DLL(sha256_hex, %ChallengeAuth.Password) var %ChallengeAuth.Key = $ChallengeAuth.DLL(sha256_hex, %ChallengeAuth.Username $+ : $+ %ChallengeAuth.PasswordHash) var %ChallengeAuth.Response = $ChallengeAuth.DLL(hmac_sha256, %ChallengeAuth.Key $1) !.msg $ChallengeAuth.Q CHALLENGEAUTH %ChallengeAuth.Username %ChallengeAuth.Response HMAC-SHA-256 } alias ChallengeAuth { if (!$isfile($ChallengeAuth.PathToDll)) { echo -s ChallengeAuth: The path to your SHA2.dll is wrong. Please configure the challengeauth script correctly and/or download the dll from echo -s ChallengeAuth: http://www.quakenet.org/development/challengeauth/SHA2.dll return } set %ChallengeAuth.Active $true echo -s ChallengeAuth: ChallengeAuth is beginning. !.msg $ChallengeAuth.Q challenge } on ^*:NOTICE:*:*: { if ($fulladdress === Q!TheQBot@CServe.quakenet.org) && ($network === QuakeNet) && ($right($server, 13) === .quakenet.org) { if ($1 === CHALLENGE) && ($len($2) == 32) && (%ChallengeAuth.Active) { if ($istok($3-, HMAC-SHA-256, 32)) { .timer 1 0 ChallengeAuth.Auth $2 } else { echo -s ChallengeAuth: HMAC-SHA-256 is not supported. ChallengeAuth is NOT continuing. } } elseif ($1- == CHALLENGE is not available once you have authed.) && (%ChallengeAuth.Active) { echo -s ChallengeAuth: You are already authed! unset %ChallengeAuth.Active } elseif ($1-6 == You are now logged in as) && (%ChallengeAuth.Active) { echo -s ChallengeAuth: You are now authed! unset %ChallengeAuth.Active } elseif ($1- == Username or password incorrect.) && (%ChallengeAuth.Active) { echo -s ChallengeAuth: Username or password incorrect. unset %ChallengeAuth.Active } } } raw 401:*: { if ($1- == $me $ChallengeAuth.Q No such nick) && (%ChallengeAuth.Active) { echo -s ChallengeAuth: Q is currently not reachable. Please try again later. unset %ChallengeAuth.Active haltdef } }