189 lines
9.1 KiB
PHP
189 lines
9.1 KiB
PHP
<?php # $Id$
|
|
|
|
include_once dirname(__FILE__) . '/common.inc.php';
|
|
|
|
|
|
class serendipity_event_openid extends serendipity_event
|
|
{
|
|
function introspect(&$propbag)
|
|
{
|
|
global $serendipity;
|
|
|
|
$propbag->add('name', PLUGIN_OPENID_NAME);
|
|
$propbag->add('description', PLUGIN_OPENID_DESC);
|
|
$propbag->add('stackable', false);
|
|
$propbag->add('author', 'Grischa Brockhaus, Rob Richards');
|
|
$propbag->add('version', '0.6');
|
|
$propbag->add('requirements', array(
|
|
'serendipity' => '1.2',
|
|
'smarty' => '2.6.7',
|
|
'php' => '5.1.3'
|
|
));
|
|
$propbag->add('groups', array('BACKEND_USERMANAGEMENT'));
|
|
$propbag->add('event_hooks', array(
|
|
'backend_login' => true,
|
|
'backend_login_page' => true,
|
|
'backend_sidebar_entries_event_display_profiles' => true,
|
|
'frontend_header' => true,
|
|
'external_plugin' => true
|
|
));
|
|
|
|
$propbag->add('configuration', array(
|
|
'plugin_desc',
|
|
'delegation_desc',
|
|
'server',
|
|
'delegate',
|
|
'xrds_location'
|
|
));
|
|
}
|
|
|
|
function introspect_config_item($name, &$propbag)
|
|
{
|
|
switch($name) {
|
|
case 'plugin_desc':
|
|
$propbag->add('type', 'content');
|
|
$propbag->add('default', PLUGIN_OPENID_DESCRIPTION);
|
|
break;
|
|
case 'delegation_desc':
|
|
$propbag->add('type', 'content');
|
|
$propbag->add('default', PLUGIN_OPENID_DELEGATION_DESCRIPTION);
|
|
break;
|
|
case 'server':
|
|
$propbag->add('type', 'string');
|
|
$propbag->add('name', PLUGIN_OPENID_SERVER);
|
|
$propbag->add('description', PLUGIN_OPENID_SERVER_DESC);
|
|
$propbag->add('default', '');
|
|
break;
|
|
case 'delegate':
|
|
$propbag->add('type', 'string');
|
|
$propbag->add('name', PLUGIN_OPENID_DELEGATE);
|
|
$propbag->add('description', PLUGIN_OPENID_DELEGATE_DESC);
|
|
$propbag->add('default', '');
|
|
break;
|
|
case 'xrds_location':
|
|
$propbag->add('type', 'string');
|
|
$propbag->add('name', PLUGIN_OPENID_XRDS_LOC);
|
|
$propbag->add('description', PLUGIN_OPENID_XRDS_LOC_DESC);
|
|
$propbag->add('default', '');
|
|
break;
|
|
default:
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
function generate_content(&$title) {
|
|
$title = PLUGIN_OPENID_NAME;
|
|
}
|
|
|
|
function event_hook($event, &$bag, &$eventData, $addData = null) {
|
|
global $serendipity;
|
|
static $login_url = null;
|
|
|
|
if ($login_url === null) {
|
|
$login_url = $serendipity['baseURL'] . $serendipity['indexFile'] . '?/plugin/loginbox';
|
|
}
|
|
|
|
$hooks = &$bag->get('event_hooks');
|
|
|
|
if (isset($hooks[$event])) {
|
|
switch($event) {
|
|
|
|
case 'external_plugin' :
|
|
if ($eventData=="openid.png") {
|
|
header('Content-Type: image/png');
|
|
echo file_get_contents(dirname(__FILE__). '/openid.png');
|
|
}
|
|
break;
|
|
case 'frontend_header':
|
|
$server = $this->get_config('server');
|
|
$openidurl = $this->get_config('delegate');
|
|
$xrdsloc = $this->get_config('xrds_location');
|
|
if (! empty($server) && (! empty($openidurl) || ! empty($xrdsloc))) {
|
|
/* Make sure linefeeds exist otherwise OpenID does not always work correctly */
|
|
echo "\n";
|
|
echo '<link rel="openid.server" href="'.$server.'" /> '."\n";
|
|
if (! empty($openidurl)) {
|
|
echo '<link rel="openid.delegate" href="'.$openidurl.'" /> '."\n";
|
|
}
|
|
if (! empty($xrdsloc)) {
|
|
echo '<meta http-equiv="X-XRDS-Location" content="'.$xrdsloc.'" /> '."\n";
|
|
}
|
|
}
|
|
break;
|
|
|
|
case 'backend_login_page':
|
|
$hidden = array('action'=>'admin');
|
|
$eventData['header'] .= '<br/><div align="center">'.
|
|
serendipity_common_openid::loginform('serendipity_admin.php', $hidden, NULL).
|
|
'</div>';
|
|
break;
|
|
|
|
case 'backend_login':
|
|
if ($eventData) {
|
|
return true;
|
|
}
|
|
if ($_SESSION['serendipityAuthedUser'] == true) {
|
|
$eventData = serendipity_common_openid::reauth_openid();
|
|
if (! empty($serendipity['POST']['openid_url']) && ! empty($serendipity['POST']['openidflag'])) {
|
|
/* Check that openid isn't already associated with another login */
|
|
$tmpRet = serendipity_common_openid::redir_openidserver($serendipity['POST']['openid_url'], $this->get_consumertest_path(), 3);
|
|
|
|
/* If updating an OpenID it is not a real login attempt */
|
|
if (($tmpRet === false) && (($serendipity['GET']['openidflag']==3) || ($serendipity['POST']['openidflag']==3))) {
|
|
return;
|
|
}
|
|
$eventData = $tmpRet;
|
|
} else {
|
|
$eventData = serendipity_common_openid::reauth_openid();
|
|
}
|
|
} else if (! empty($serendipity['GET']['openidflag']) && ($serendipity['GET']['openidflag']==1)) {
|
|
$eventData = serendipity_common_openid::authenticate_openid($_GET, $this->get_consumertest_path());
|
|
} else if (! empty($serendipity['POST']['openid_url']) && ! empty($serendipity['POST']['action'])) {
|
|
$eventData = serendipity_common_openid::redir_openidserver($serendipity['POST']['openid_url'], $this->get_consumertest_path(), 1);
|
|
}
|
|
return;
|
|
|
|
case 'backend_sidebar_entries_event_display_profiles':
|
|
if (($_SESSION['serendipityAuthedUser'] == true)) {
|
|
if (! empty($serendipity['GET']['openidflag']) && ($serendipity['GET']['openidflag']==3)) {
|
|
if ($checkRet = serendipity_common_openid::authenticate_openid($_GET, $this->get_consumertest_path(), true)) {
|
|
if (serendipity_common_openid::updateOpenID($checkRet['openID'], $serendipity['authorid'])) {
|
|
echo '<strong>' . htmlspecialchars(PLUGIN_OPENID_UPDATE_SUCCESS) . '</strong><br /><br />';
|
|
} else {
|
|
echo '<strong>' . htmlspecialchars(PLUGIN_OPENID_UPDATE_FAIL) . '</strong><br /><br />';
|
|
}
|
|
} else {
|
|
echo '<strong>' . htmlspecialchars(PLUGIN_OPENID_INVALID_RESPONSE) . '</strong><br /><br />';
|
|
}
|
|
} elseif (! empty($serendipity['POST']['openidflag']) && ($serendipity['POST']['openidflag']==3)) {
|
|
echo '<strong>' . htmlspecialchars(PLUGIN_OPENID_INVALID_RESPONSE) . '</strong><br /><br />';
|
|
}
|
|
}
|
|
$imgpath = $serendipity['baseURL'] . 'index.php?/plugin/openid.png';
|
|
echo '<form action="?" method="post">';
|
|
echo '<input type="hidden" name="serendipity[adminModule]" value="event_display" />';
|
|
echo '<input type="hidden" name="serendipity[adminAction]" value="profiles" />';
|
|
echo '<input type="hidden" name="serendipity[openidflag]" value="3" />';
|
|
echo '<div>';
|
|
echo '<strong>' . htmlspecialchars(PLUGIN_EVENT_OPENID_SELECT) . '</strong><br /><br />';
|
|
echo '<img src="' . $imgpath . '" alt="OpenID URL"> <input type="text" size="50" name="serendipity[openid_url]" value="'. serendipity_common_openid::getOpenID($serendipity['authorid']) .'" />';
|
|
echo ' <input type="submit" name="submit" value="' . EDIT . '" />';
|
|
echo '</div><br /><hr /></form>';
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
function get_consumertest_path() {
|
|
global $serendipity;
|
|
|
|
return $serendipity['serendipityPath'] . PATH_SMARTY_COMPILE . '/_php_consumer_test';
|
|
}
|
|
}
|
|
|
|
/* vim: set sts=4 ts=4 expandtab : */
|