2012-04-08 22:50:48 +00:00
< ? php
/**
* Name : Gravatar Support
2018-01-20 13:57:41 +00:00
* Description : If there is no avatar image for a new user or contact this addon will look for one at Gravatar .
2012-07-14 19:11:43 +00:00
* Version : 1.1
2012-04-08 22:50:48 +00:00
* Author : Klaus Weidenbach < http :// friendica . dszdw . net / profile / klaus >
*/
2018-07-21 13:13:02 +00:00
use Friendica\App ;
2018-10-17 19:34:15 +00:00
use Friendica\BaseModule ;
2018-01-17 00:51:12 +00:00
use Friendica\Core\Addon ;
2017-11-06 23:55:24 +00:00
use Friendica\Core\Config ;
2018-01-22 19:03:11 +00:00
use Friendica\Core\L10n ;
2018-10-29 23:40:18 +00:00
use Friendica\Core\Logger ;
2018-10-31 14:55:15 +00:00
use Friendica\Core\Renderer ;
2018-07-21 13:13:02 +00:00
use Friendica\Database\DBA ;
2018-10-17 16:58:05 +00:00
use Friendica\Util\Security ;
2017-11-06 23:55:24 +00:00
2012-04-08 22:50:48 +00:00
/**
2018-01-20 13:57:41 +00:00
* Installs the addon hook
2012-04-08 22:50:48 +00:00
*/
function gravatar_install () {
2018-06-28 03:12:50 +00:00
Addon :: registerHook ( 'load_config' , 'addon/gravatar/gravatar.php' , 'gravatar_load_config' );
2018-01-17 00:51:12 +00:00
Addon :: registerHook ( 'avatar_lookup' , 'addon/gravatar/gravatar.php' , 'gravatar_lookup' );
2012-04-08 22:50:48 +00:00
2018-10-29 23:40:18 +00:00
Logger :: log ( " registered gravatar in avatar_lookup hook " );
2012-04-08 22:50:48 +00:00
}
/**
2018-01-20 13:57:41 +00:00
* Removes the addon hook
2012-04-08 22:50:48 +00:00
*/
function gravatar_uninstall () {
2018-06-28 03:12:50 +00:00
Addon :: unregisterHook ( 'load_config' , 'addon/gravatar/gravatar.php' , 'gravatar_load_config' );
2018-01-17 00:51:12 +00:00
Addon :: unregisterHook ( 'avatar_lookup' , 'addon/gravatar/gravatar.php' , 'gravatar_lookup' );
2012-04-08 22:50:48 +00:00
2018-10-29 23:40:18 +00:00
Logger :: log ( " unregistered gravatar in avatar_lookup hook " );
2012-04-08 22:50:48 +00:00
}
2018-07-21 13:13:02 +00:00
function gravatar_load_config ( App $a )
2018-06-28 03:12:50 +00:00
{
$a -> loadConfigFile ( __DIR__ . '/config/gravatar.ini.php' );
}
2012-04-08 22:50:48 +00:00
/**
* Looks up the avatar at gravatar . com and returns the URL .
*
* @ param $a array
* @ param & $b array
*/
function gravatar_lookup ( $a , & $b ) {
2018-06-28 03:12:50 +00:00
$default_avatar = Config :: get ( 'gravatar' , 'default_avatar' );
2017-11-06 23:55:24 +00:00
$rating = Config :: get ( 'gravatar' , 'rating' );
2012-04-08 22:50:48 +00:00
// setting default value if nothing configured
if ( ! $default_avatar )
2012-04-10 23:03:22 +00:00
$default_avatar = 'identicon' ; // default image will be a random pattern
2012-04-08 22:50:48 +00:00
if ( ! $rating )
$rating = 'g' ; // suitable for display on all websites with any audience type
$hash = md5 ( trim ( strtolower ( $b [ 'email' ])));
2015-05-18 14:45:41 +00:00
$url = 'https://secure.gravatar.com/avatar/' . $hash . '.jpg' ;
2012-04-08 22:50:48 +00:00
$url .= '?s=' . $b [ 'size' ] . '&r=' . $rating ;
if ( $default_avatar != " gravatar " )
$url .= '&d=' . $default_avatar ;
2018-01-15 13:15:33 +00:00
$b [ 'url' ] = $url ;
2012-04-10 23:03:22 +00:00
$b [ 'success' ] = true ;
2012-04-08 22:50:48 +00:00
}
/**
* Display admin settings for this addon
*/
2018-01-20 13:57:41 +00:00
function gravatar_addon_admin ( & $a , & $o ) {
2018-10-31 14:55:15 +00:00
$t = Renderer :: getMarkupTemplate ( " admin.tpl " , " addon/gravatar/ " );
2012-04-08 22:50:48 +00:00
2018-06-28 03:12:50 +00:00
$default_avatar = Config :: get ( 'gravatar' , 'default_avatar' );
2017-11-06 23:55:24 +00:00
$rating = Config :: get ( 'gravatar' , 'rating' );
2012-04-08 22:50:48 +00:00
// set default values for first configuration
if ( ! $default_avatar )
$default_avatar = 'identicon' ; // pseudo-random geometric pattern based on email hash
if ( ! $rating )
$rating = 'g' ; // suitable for display on all websites with any audience type
// Available options for the select boxes
2018-01-15 13:15:33 +00:00
$default_avatars = [
2018-01-22 19:03:11 +00:00
'mm' => L10n :: t ( 'generic profile image' ),
'identicon' => L10n :: t ( 'random geometric pattern' ),
'monsterid' => L10n :: t ( 'monster face' ),
'wavatar' => L10n :: t ( 'computer generated face' ),
'retro' => L10n :: t ( 'retro arcade style face' ),
2018-01-15 13:15:33 +00:00
];
$ratings = [
2012-04-08 22:50:48 +00:00
'g' => 'g' ,
'pg' => 'pg' ,
'r' => 'r' ,
'x' => 'x'
2018-01-15 13:15:33 +00:00
];
2012-04-08 22:50:48 +00:00
2012-07-14 19:11:43 +00:00
// Check if Libravatar is enabled and show warning
$r = q ( " SELECT * FROM `addon` WHERE `name` = '%s' and `installed` = 1 " ,
2018-07-21 13:13:02 +00:00
DBA :: escape ( 'libravatar' )
2012-07-14 19:11:43 +00:00
);
if ( count ( $r )) {
2018-01-22 19:03:11 +00:00
$o = '<h5>' . L10n :: t ( 'Information' ) . '</h5><p>' . L10n :: t ( 'Libravatar addon is installed, too. Please disable Libravatar addon or this Gravatar addon.<br>The Libravatar addon will fall back to Gravatar if nothing was found at Libravatar.' ) . '</p><br><br>' ;
2012-07-14 19:11:43 +00:00
}
// output Gravatar settings
2018-10-17 19:34:15 +00:00
$o .= '<input type="hidden" name="form_security_token" value="' . BaseModule :: getFormSecurityToken ( " gravatarsave " ) . '">' ;
2018-10-31 14:55:15 +00:00
$o .= Renderer :: replaceMacros ( $t , [
2018-01-22 19:03:11 +00:00
'$submit' => L10n :: t ( 'Save Settings' ),
'$default_avatar' => [ 'avatar' , L10n :: t ( 'Default avatar image' ), $default_avatar , L10n :: t ( 'Select default avatar image if none was found at Gravatar. See README' ), $default_avatars ],
'$rating' => [ 'rating' , L10n :: t ( 'Rating of images' ), $rating , L10n :: t ( 'Select the appropriate avatar rating for your site. See README' ), $ratings ],
2018-01-15 13:15:33 +00:00
]);
2012-04-08 22:50:48 +00:00
}
/**
* Save admin settings
*/
2018-01-20 13:57:41 +00:00
function gravatar_addon_admin_post ( & $a ) {
2018-10-17 19:34:15 +00:00
BaseModule :: checkFormSecurityToken ( 'gravatarsave' );
2012-04-08 22:50:48 +00:00
$default_avatar = (( x ( $_POST , 'avatar' )) ? notags ( trim ( $_POST [ 'avatar' ])) : 'identicon' );
$rating = (( x ( $_POST , 'rating' )) ? notags ( trim ( $_POST [ 'rating' ])) : 'g' );
2018-06-28 03:12:50 +00:00
Config :: set ( 'gravatar' , 'default_avatar' , $default_avatar );
2017-11-06 23:55:24 +00:00
Config :: set ( 'gravatar' , 'rating' , $rating );
2018-01-22 19:03:11 +00:00
info ( L10n :: t ( 'Gravatar settings updated.' ) . EOL );
2012-04-08 22:50:48 +00:00
}