2013-08-12 09:49:28 +02:00
|
|
|
<?php #
|
2011-12-13 12:29:05 +01:00
|
|
|
|
|
|
|
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);
|
2012-03-22 04:19:23 +01:00
|
|
|
$propbag->add('author', 'Grischa Brockhaus, Rob Richards');
|
2018-04-05 14:17:19 +02:00
|
|
|
$propbag->add('version', '1.2.3');
|
2011-12-13 12:29:05 +01:00
|
|
|
$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,
|
2012-03-24 03:28:54 +01:00
|
|
|
'frontend_header' => true,
|
|
|
|
'external_plugin' => true
|
2011-12-13 12:29:05 +01:00
|
|
|
));
|
|
|
|
|
2018-04-05 14:17:19 +02:00
|
|
|
$propbag->add('legal', array(
|
|
|
|
'services' => array(
|
|
|
|
'openID' => array(
|
|
|
|
'url' => '#',
|
|
|
|
'desc' => 'OpenID provides will receive login data'
|
|
|
|
),
|
|
|
|
),
|
|
|
|
'frontend' => array(
|
|
|
|
'When a openID login provider is selected, logging in to the blog will transmit data from and to the selected OpenID provider.',
|
|
|
|
),
|
|
|
|
'backend' => array(
|
|
|
|
'When a openID login provider is selected, logging in to the blog will transmit data from and to the selected OpenID provider.',
|
|
|
|
),
|
|
|
|
'cookies' => array(
|
|
|
|
),
|
|
|
|
'stores_user_input' => false,
|
|
|
|
'stores_ip' => false,
|
|
|
|
'uses_ip' => true,
|
|
|
|
'transmits_user_input' => true
|
|
|
|
));
|
|
|
|
|
2011-12-13 12:29:05 +01:00
|
|
|
$propbag->add('configuration', array(
|
2012-03-24 02:26:09 +01:00
|
|
|
'plugin_desc',
|
2012-03-27 01:09:25 +02:00
|
|
|
'select_authors',
|
2012-03-24 02:26:09 +01:00
|
|
|
'delegation_desc',
|
2011-12-13 12:29:05 +01:00
|
|
|
'server',
|
|
|
|
'delegate',
|
2012-03-29 14:01:39 +02:00
|
|
|
'xrds_location',
|
|
|
|
'openid_version'
|
2011-12-13 12:29:05 +01:00
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
function introspect_config_item($name, &$propbag)
|
|
|
|
{
|
|
|
|
switch($name) {
|
2012-03-24 02:26:09 +01:00
|
|
|
case 'plugin_desc':
|
|
|
|
$propbag->add('type', 'content');
|
|
|
|
$propbag->add('default', PLUGIN_OPENID_DESCRIPTION);
|
|
|
|
break;
|
2012-03-27 01:09:25 +02:00
|
|
|
case 'select_authors':
|
|
|
|
$propbag->add('type', 'boolean');
|
|
|
|
$propbag->add('name', PLUGIN_OPENID_LOGIN_USERS);
|
|
|
|
$propbag->add('description', PLUGIN_OPENID_LOGIN_USERS_DESC);
|
|
|
|
$propbag->add('default', 'true');
|
|
|
|
break;
|
2012-03-24 02:26:09 +01:00
|
|
|
case 'delegation_desc':
|
|
|
|
$propbag->add('type', 'content');
|
|
|
|
$propbag->add('default', PLUGIN_OPENID_DELEGATION_DESCRIPTION);
|
2011-12-13 12:29:05 +01:00
|
|
|
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;
|
2012-03-29 14:01:39 +02:00
|
|
|
case 'openid_version':
|
|
|
|
$id_services = array(
|
|
|
|
'both' => PLUGIN_OPENID_VERSION_SUPPORTED_BOTH,
|
|
|
|
'v2' => PLUGIN_OPENID_VERSION_SUPPORTED_V2,
|
|
|
|
'v1' => PLUGIN_OPENID_VERSION_SUPPORTED_V1,
|
|
|
|
);
|
|
|
|
$propbag->add('type', 'select');
|
|
|
|
$propbag->add('name', PLUGIN_OPENID_VERSION_SUPPORTED);
|
|
|
|
$propbag->add('description', PLUGIN_OPENID_VERSION_SUPPORTED_DESC);
|
|
|
|
$propbag->add('select_values', $id_services);
|
|
|
|
$propbag->add('default', 'both');
|
|
|
|
break;
|
2011-12-13 12:29:05 +01:00
|
|
|
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) {
|
|
|
|
|
2012-03-24 03:28:54 +01:00
|
|
|
case 'external_plugin' :
|
|
|
|
if ($eventData=="openid.png") {
|
|
|
|
header('Content-Type: image/png');
|
2012-03-26 02:09:08 +02:00
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/openid.png');
|
|
|
|
}
|
|
|
|
elseif ($eventData=="oid_google.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/google.png');
|
|
|
|
}
|
|
|
|
elseif ($eventData=="oids_google.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/google_small.png');
|
|
|
|
}
|
|
|
|
elseif ($eventData=="oid_yahoo.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/yahoo.png');
|
|
|
|
}
|
|
|
|
elseif ($eventData=="oids_yahoo.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/yahoo_small.png');
|
2012-03-24 03:28:54 +01:00
|
|
|
}
|
2012-03-26 03:08:31 +02:00
|
|
|
elseif ($eventData=="oid_aol.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/aol.png');
|
|
|
|
}
|
|
|
|
elseif ($eventData=="oids_aol.png") {
|
|
|
|
header('Content-Type: image/png');
|
|
|
|
echo file_get_contents(dirname(__FILE__). '/img/aol_small.png');
|
|
|
|
}
|
2012-03-24 03:28:54 +01:00
|
|
|
break;
|
2011-12-13 12:29:05 +01:00
|
|
|
case 'frontend_header':
|
2012-03-29 14:01:39 +02:00
|
|
|
$this->print_header();
|
2012-03-24 15:42:51 +01:00
|
|
|
break;
|
2011-12-13 12:29:05 +01:00
|
|
|
|
|
|
|
case 'backend_login_page':
|
|
|
|
$hidden = array('action'=>'admin');
|
2012-03-27 01:09:25 +02:00
|
|
|
$useAutorSelector = $this->get_config('select_authors',true);
|
2012-03-24 16:12:55 +01:00
|
|
|
$eventData['header'] .= '<br/><div align="center">'.
|
2012-03-27 01:09:25 +02:00
|
|
|
serendipity_common_openid::loginform('serendipity_admin.php', $hidden, $useAutorSelector).
|
2012-03-24 16:12:55 +01:00
|
|
|
'</div>';
|
2011-12-13 12:29:05 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'backend_login':
|
2012-03-29 14:01:39 +02:00
|
|
|
return $this->do_login($eventData);
|
2012-03-26 02:09:08 +02:00
|
|
|
|
2011-12-13 12:29:05 +01:00
|
|
|
case 'backend_sidebar_entries_event_display_profiles':
|
2012-03-29 14:01:39 +02:00
|
|
|
$this->print_sidebar();
|
2011-12-13 12:29:05 +01:00
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2012-03-29 14:01:39 +02:00
|
|
|
|
|
|
|
function do_login(&$eventData) {
|
|
|
|
global $serendipity;
|
|
|
|
|
|
|
|
$inOpenIdChange = !empty($serendipity['POST']['openidflag']) && ($serendipity['POST']['openidflag']==3);
|
|
|
|
if ($eventData && !$inOpenIdChange) { // Eventdata holds "isAuthentificated". So if she is, let her in.
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$openidurl = NULL;
|
|
|
|
if (!empty($serendipity['POST']['openid_url'])) {
|
|
|
|
$openidurl = $serendipity['POST']['openid_url'];
|
|
|
|
}
|
|
|
|
elseif (isset($_POST['openIDLoginGoogle_x']) || isset($_POST['openIDLoginGoogle_y'])) { // If the Google Button was pressed
|
|
|
|
$openidurl = "https://www.google.com/accounts/o8/id";
|
|
|
|
}
|
|
|
|
elseif (isset($_POST['openIDLoginYahoo_x']) || isset($_POST['openIDLoginYahoo_y'])) { // If the Google Button was pressed
|
|
|
|
$openidurl = "https://me.yahoo.com";
|
|
|
|
}
|
|
|
|
elseif (isset($_POST['openIDLoginAol_x']) || isset($_POST['openIDLoginAol_y'])) { // If the Google Button was pressed
|
|
|
|
$openidurl = "https://www.aol.com";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($_SESSION['serendipityAuthedUser'] == true) {
|
|
|
|
$eventData = serendipity_common_openid::reauth_openid();
|
|
|
|
if (!empty($openidurl) && !empty($serendipity['POST']['openidflag'])) {
|
|
|
|
/* Check that openid isn't already associated with another login */
|
|
|
|
$tmpRet = serendipity_common_openid::redir_openidserver($openidurl, $this->get_consumertest_path(), 3);
|
2012-03-24 02:26:09 +01:00
|
|
|
|
2012-03-29 14:01:39 +02:00
|
|
|
/* 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;
|
|
|
|
} elseif (!empty($serendipity['POST']['openidflag'])) {
|
|
|
|
$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($openidurl) && ! empty($serendipity['POST']['action'])) {
|
|
|
|
$eventData = serendipity_common_openid::redir_openidserver($openidurl, $this->get_consumertest_path(), 1);
|
|
|
|
}
|
|
|
|
return $eventData;
|
|
|
|
}
|
|
|
|
|
|
|
|
function print_header() {
|
|
|
|
$server = $this->get_config('server');
|
|
|
|
$openidurl = $this->get_config('delegate');
|
|
|
|
$xrdsloc = $this->get_config('xrds_location');
|
|
|
|
if (! empty($server) && (! empty($openidurl) || ! empty($xrdsloc))) {
|
|
|
|
$supported_version = $this->get_config('openid_version', 'both');
|
|
|
|
if ('v1'==$supported_version) {
|
|
|
|
$rel_oserver = "openid.server";
|
|
|
|
$rel_odelegate = "openid.delegate";
|
|
|
|
}
|
|
|
|
elseif ('v2'==$supported_version) {
|
|
|
|
$rel_oserver = "openid2.provider";
|
|
|
|
$rel_odelegate = "openid2.local_id";
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$rel_oserver = "openid.server openid2.provider";
|
|
|
|
$rel_odelegate = "openid.delegate openid2.local_id";
|
|
|
|
}
|
|
|
|
/* Make sure linefeeds exist otherwise OpenID does not always work correctly */
|
|
|
|
echo "\n";
|
|
|
|
echo '<link rel="' . $rel_oserver .'" href="'.$server.'" /> '."\n";
|
|
|
|
if (! empty($openidurl)) {
|
|
|
|
echo '<link rel="' . $rel_odelegate .'" href="'.$openidurl.'" /> '."\n";
|
|
|
|
}
|
|
|
|
if (! empty($xrdsloc)) {
|
|
|
|
echo '<meta http-equiv="X-XRDS-Location" content="'.$xrdsloc.'" /> '."\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function print_sidebar() {
|
|
|
|
global $serendipity;
|
|
|
|
|
|
|
|
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'])) {
|
2014-11-25 01:15:57 +01:00
|
|
|
echo '<strong>' . (function_exists('serendipity_specialchars') ? serendipity_specialchars(PLUGIN_OPENID_UPDATE_SUCCESS) : htmlspecialchars(PLUGIN_OPENID_UPDATE_SUCCESS, ENT_COMPAT, LANG_CHARSET)) . '</strong><br /><br />';
|
2012-03-29 14:01:39 +02:00
|
|
|
} else {
|
2014-11-25 01:15:57 +01:00
|
|
|
echo '<strong>' . (function_exists('serendipity_specialchars') ? serendipity_specialchars(PLUGIN_OPENID_UPDATE_FAIL) : htmlspecialchars(PLUGIN_OPENID_UPDATE_FAIL, ENT_COMPAT, LANG_CHARSET)) . '</strong><br /><br />';
|
2012-03-29 14:01:39 +02:00
|
|
|
}
|
|
|
|
} else {
|
2014-11-25 01:15:57 +01:00
|
|
|
echo '<strong>' . (function_exists('serendipity_specialchars') ? serendipity_specialchars(PLUGIN_OPENID_INVALID_RESPONSE) : htmlspecialchars(PLUGIN_OPENID_INVALID_RESPONSE, ENT_COMPAT, LANG_CHARSET)) . '</strong><br /><br />';
|
2012-03-29 14:01:39 +02:00
|
|
|
}
|
|
|
|
// Job done.
|
|
|
|
unset($serendipity['GET']['openidflag']);
|
|
|
|
} elseif (! empty($serendipity['POST']['openidflag']) && ($serendipity['POST']['openidflag']==3)) {
|
2014-11-25 01:15:57 +01:00
|
|
|
echo '<strong>' . (function_exists('serendipity_specialchars') ? serendipity_specialchars(PLUGIN_OPENID_INVALID_RESPONSE) : htmlspecialchars(PLUGIN_OPENID_INVALID_RESPONSE, ENT_COMPAT, LANG_CHARSET)) . '</strong><br /><br />';
|
2012-03-29 14:01:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$imgopenid = $serendipity['baseURL'] . 'index.php?/plugin/openid.png';
|
|
|
|
$imggoogle = $serendipity['baseURL'] . 'index.php?/plugin/oids_google.png';
|
|
|
|
$imgyahoo = $serendipity['baseURL'] . 'index.php?/plugin/oids_yahoo.png';
|
|
|
|
$imgaol = $serendipity['baseURL'] . 'index.php?/plugin/oids_aol.png';
|
|
|
|
|
|
|
|
echo '<div>';
|
2014-11-25 01:15:57 +01:00
|
|
|
echo '<strong>' . (function_exists('serendipity_specialchars') ? serendipity_specialchars(PLUGIN_EVENT_OPENID_SELECT) : htmlspecialchars(PLUGIN_EVENT_OPENID_SELECT, ENT_COMPAT, LANG_CHARSET)) . '</strong><br /><br />';
|
2012-03-29 14:01:39 +02:00
|
|
|
|
|
|
|
// To allow ENTER in the input line we have to create two forms:
|
|
|
|
|
|
|
|
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 '<img src="' . $imgopenid . '" 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 . '" placeholder="' . PLUGIN_OPENID_LOGIN_INPUT . '"/>';
|
|
|
|
echo '</form>';
|
|
|
|
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 '<input name="openIDLoginGoogle" type="image" src="' . $imggoogle . '" alt="' . PLUGIN_OPENID_SET_GOOGLE_OID .'" title="'. PLUGIN_OPENID_SET_GOOGLE_OID .'"/> ';
|
|
|
|
echo '<input name="openIDLoginYahoo" type="image" src="' . $imgyahoo . '" alt="' . PLUGIN_OPENID_SET_YAHOO_OID .'" title="'. PLUGIN_OPENID_SET_YAHOO_OID .'"/> ';
|
|
|
|
echo '<input name="openIDLoginAol" type="image" src="' . $imgaol . '" alt="' . PLUGIN_OPENID_SET_AOL_OID .'" title="'. PLUGIN_OPENID_SET_AOL_OID .'"/> ';
|
|
|
|
echo '</form>';
|
|
|
|
|
|
|
|
echo '</div><br /><hr />';
|
|
|
|
}
|
|
|
|
|
2012-03-24 02:26:09 +01:00
|
|
|
function get_consumertest_path() {
|
|
|
|
global $serendipity;
|
|
|
|
|
|
|
|
return $serendipity['serendipityPath'] . PATH_SMARTY_COMPILE . '/_php_consumer_test';
|
|
|
|
}
|
2011-12-13 12:29:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* vim: set sts=4 ts=4 expandtab : */
|