From: paulr Date: Fri, 3 Dec 2010 03:10:23 +0000 (+1100) Subject: lots of work on the authserver... tho mostly proof of concept X-Git-Url: http://git.pjr.cc/?a=commitdiff_plain;h=bd517aaa43fe3437889f4199730bcab1a8519168;p=ga4php.git lots of work on the authserver... tho mostly proof of concept --- diff --git a/authserver/authd/authd.php b/authserver/authd/authd.php index 7755688..616eab7 100644 --- a/authserver/authd/authd.php +++ b/authserver/authd/authd.php @@ -1,24 +1,69 @@ authenticateUser($username, $passcode)); + break; + case MSG_ADD_USER: + echo "add user\n"; + $username = $msg["username"]; + global $myga; + msg_send($cl_queue, MSG_ADD_USER, $myga->setUser($username)); + break; + case MSG_DELETE_USER: + break; + default: + echo "um??\n"; + + } + echo "Back to wait\n"; + } } ?> \ No newline at end of file diff --git a/authserver/authuser.php b/authserver/authuser.php index bf6ca8c..f6ff83c 100644 --- a/authserver/authuser.php +++ b/authserver/authuser.php @@ -1,6 +1,6 @@ authUser($argv[2], $argv[3])==1) { + echo "Pass!"; + } else { + echo "Fail!"; + } + break; + case "add": + $myAC->addUser($argv[2]); + break; +} ?> \ No newline at end of file diff --git a/authserver/lib/authClient.php b/authserver/lib/authClient.php new file mode 100644 index 0000000..64093e2 --- /dev/null +++ b/authserver/lib/authClient.php @@ -0,0 +1,61 @@ + \ No newline at end of file diff --git a/authserver/lib/lib.php b/authserver/lib/lib.php index dadbc0f..efc6d95 100644 --- a/authserver/lib/lib.php +++ b/authserver/lib/lib.php @@ -1,9 +1,122 @@ query($sql); + } + return $dbobject; +} +function closeDatabase($db) { + // doesnt do anything yet +} + +class gaasGA extends GoogleAuthenticator { + function getData($username) { + + // get our database connection + $dbObject = getDatabase(); + + // set the sql for retreiving the data + $sql = "select users_tokendata from users where users_username='$username'"; + + // run the query + $result = $dbObject->query($sql); + + // check the result + if(!$result) return false; + + // now just retreieve all the data (there should only be one, but whatever) + $tokendata = false; + foreach($result as $row) { + $tokendata = $row["users_tokendata"]; + } + + // now we have our data, we just return it. If we got no data + // we'll just return false by default + return $tokendata; + + // and there you have it, simple eh? + } + + + // now we need a function for putting the data back into our user table. + // in this example, we wont check anything, we'll just overwrite it. + function putData($username, $data) { + // get our database connection + $dbObject = getDatabase(); + + // set the sql for updating the data + // token data is stored as a base64 encoded string, it should + // not need to be escaped in any way prior to storing in a database + // but feel free to call your databases "addslashes" (or whatever) + // function on $data prior to doing the SQL. + $sql = "delete from users where users_username='$username'"; + $dbObject->query($sql); + + $sql = "insert into users values (NULL, '$username', '$data')"; + + + // now execute the sql and return straight away - you should probably + // clean up after yourselves, but im going to assume pdo does this + // for us anyway in this exmaple + if($dbObject->query($sql)) { + return true; + } else { + return false; + } + + // even simpler! + } + + function getUsers() { + // get our database connection + $dbObject = getDatabase(); + + // now the sql again + $sql = "select users_username from users"; + + // run the query + $result = $dbObject->query($sql); + + // iterate over the results - we expect a simple array containing + // a list of usernames + $i = 0; + $users = array(); + foreach($result as $row) { + $users[$i] = $row["username"]; + $i++; + } + + // now return the list + return $users; + } } ?> \ No newline at end of file