Browse Source

OpenID delegation in profile page

pull/1/head
fabrixxm 11 years ago
parent
commit
fa756ffcb9
  1. 1
      database.sql
  2. 27
      mod/profile.php

1
database.sql

@ -377,6 +377,7 @@ CREATE TABLE IF NOT EXISTS `user` (
`allow_gid` mediumtext NOT NULL,
`deny_cid` mediumtext NOT NULL,
`deny_gid` mediumtext NOT NULL,
`openidserver` text NOT NULL,
PRIMARY KEY (`uid`),
KEY `nickname` (`nickname`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

27
mod/profile.php

@ -18,6 +18,31 @@ function profile_init(&$a) {
profile_load($a,$which,$profile);
if (!get_config('system','no_openid') && $a->profile['openid']!=""){
if (!isset($a->profile['openidserver'])){
die('friendika user table must be updated. `openidserver` field is missing');
}
if ($a->profile['openidserver']==''){
require_once('library/openid.php');
$openid = new LightOpenID;
$openid->identity = $a->profile['openid'];
$a->profile['openidserver'] = $openid->discover($openid->identity);
q("UPDATE `user` SET `openidserver` = '%s' WHERE `uid` = %d LIMIT 1",
dbesc($a->profile['openidserver']),
intval($a->profile['uid'])
);
}
$a->page['htmlhead'] .= '<link rel="openid.server" href="'.$a->profile['openidserver'].'" />'. "\r\n";
$a->page['htmlhead'] .= '<link rel="openid.delegate" href="'.$a->profile['openid'].'" />'. "\r\n";
}
$a->page['htmlhead'] .= '<meta name="dfrn-global-visibility" content="' . (($a->profile['net-publish']) ? 'true' : 'false') . '" />' . "\r\n" ;
$a->page['htmlhead'] .= '<link rel="alternate" type="application/atom+xml" href="' . $a->get_baseurl() . '/dfrn_poll/' . $which .'" />' . "\r\n" ;
$uri = urlencode('acct:' . $a->profile['nickname'] . '@' . $a->get_hostname() . (($a->path) ? '/' . $a->path : ''));
@ -365,4 +390,4 @@ function profile_content(&$a, $update = 0) {
$o .= paginate($a);
return $o;
}
}

Loading…
Cancel
Save