header('HTTP/1.0 500 Internal Server Error');
require 'www-header.php';
-function getOrCreateUser($mode, $name, $email)
+function getOrCreateUser($mode, $name, $imageurl, $email)
{
if ($mode == 'anonymous') {
$name = 'Anonymous';
$name = 'Anonymous';
}
}
- $imageurl = getImageUrl($email);
+ if ($imageurl == '') {
+ $imageurl = getImageUrl($email);
+ }
$storage = new Storage();
$id = $storage->findUser($name, $imageurl);
$response_type = getOptionalParameter($_GET, 'response_type', 'id');
$scope = getOptionalParameter($_GET, 'scope', null);
- //FIXME: if $me is an actual user, load his data
+ $id = array(
+ 'mode' => 'anonymous',
+ 'name' => '',
+ 'imageurl' => '',
+ );
+ $userbaseurl = Urls::full('/user/');
+ if (substr($me, 0, strlen($userbaseurl)) == $userbaseurl) {
+ //actual user URL - loads his data
+ $userid = substr($me, strrpos($me, '/') + 1, -4);
+ if (intval($userid) == $userid) {
+ $storage = new Storage();
+ $rowUser = $storage->getUser($userid);
+ if ($rowUser !== null) {
+ $id['mode'] = 'data';
+ $id['name'] = $rowUser->user_name;
+ $id['imageurl'] = $rowUser->user_imageurl;
+ if ($id['imageurl'] == Urls::userImg()) {
+ $id['imageurl'] = '';
+ }
+ }
+ }
+ }
//let the user choose his identity
header('HTTP/1.0 200 OK');
'response_type' => $response_type,
'scope' => $scope,
),
+ 'id' => $id,
'formaction' => '/auth.php?action=login',
)
);
verifyParameter($id, 'mode');
$userId = getOrCreateUser(
- $id['mode'], trim($id['name']), trim($id['email'])
+ $id['mode'], trim($id['name']), trim($id['imageurl']),
+ trim($id['email'])
);
$me = Urls::full(Urls::user($userId));