Отключение поддержки Gravatar.com в WordPress и использование Simple Local Avatars
В настоящее время я использую плагин Simple Local Avatars на нескольких своих блогах, позволяя пользователям загружать свои собственные аватары.
Насколько я понимаю, Simple Local Avatars использует функцию get_avatar
для проверки наличия пользовательского аватара, и если его нет, по умолчанию загружает с Gravatar.com.
Возможно ли как-то отключить Gravatar.com, полностью запретив его использование и возвращая локально размещенное изображение, если пользовательский аватар не выбран?
Надеюсь, будет уместно разместить это здесь, но вот файл Simple Local Avatars:
<?php
/*
Название плагина: Simple Local Avatars
URI плагина: http://www.get10up.com/plugins/simple-local-avatars-wordpress/
Описание: Добавляет поле для загрузки аватара в профиль пользователя, если у текущего пользователя есть права на загрузку медиа. Генерирует запрашиваемые размеры по требованию, как Gravatar! Просто и легко.
Версия: 1.2.3
Автор: Jake Goldman (10up), Oomph Inc
URI автора: http://www.get10up.com
*/
// добавляем поле в профили пользователей
class simple_local_avatars {
function simple_local_avatars() {
add_filter('get_avatar', array($this, 'get_avatar'), 10, 5);
add_action('admin_init', array($this, 'admin_init'));
add_action('show_user_profile', array($this, 'edit_user_profile'));
add_action('edit_user_profile', array($this, 'edit_user_profile'));
add_action('personal_options_update', array($this, 'edit_user_profile_update'));
add_action('edit_user_profile_update', array($this, 'edit_user_profile_update'));
add_filter('avatar_defaults', array($this, 'avatar_defaults'));
}
function get_avatar($avatar = '', $id_or_email, $size = '96', $default = '', $alt = false) {
if (is_numeric($id_or_email))
$user_id = (int) $id_or_email;
elseif (is_string($id_or_email)) {
if ($user = get_user_by_email($id_or_email))
$user_id = $user->ID;
} elseif (is_object($id_or_email) && !empty($id_or_email->user_id))
$user_id = (int) $id_or_email->user_id;
if (!empty($user_id))
$local_avatars = get_user_meta($user_id, 'simple_local_avatar', true);
if (!isset($local_avatars) || empty($local_avatars) || !isset($local_avatars['full'])) {
if (!empty($avatar)) // если вызвано фильтром
return $avatar;
remove_filter('get_avatar', 'get_simple_local_avatar');
$avatar = get_avatar($id_or_email, $size, $default);
add_filter('get_avatar', 'get_simple_local_avatar', 10, 5);
return $avatar;
}
if (!is_numeric($size)) // проверяем допустимый размер
$size = '96';
if (empty($alt))
$alt = get_the_author_meta('display_name', $user_id);
// генерируем новый размер
if (empty($local_avatars[$size])) {
$upload_path = wp_upload_dir();
$avatar_full_path = str_replace($upload_path['baseurl'], $upload_path['basedir'], $local_avatars['full']);
$image_sized = image_resize($avatar_full_path, $size, $size, true);
if (is_wp_error($image_sized)) // если исходное изображение больше или равно оригиналу (или нет возможности изменить размер)
$local_avatars[$size] = $local_avatars['full'];
else
$local_avatars[$size] = str_replace($upload_path['basedir'], $upload_path['baseurl'], $image_sized);
update_user_meta($user_id, 'simple_local_avatar', $local_avatars);
} elseif (substr($local_avatars[$size], 0, 4) != 'http')
$local_avatars[$size] = site_url($local_avatars[$size]);
$author_class = is_author($user_id) ? ' current-author' : '';
$avatar = "<img alt='" . esc_attr($alt) . "' src='" . $local_avatars[$size] . "' class='avatar avatar-{$size}{$author_class} photo' height='{$size}' width='{$size}' />";
return $avatar;
}
function admin_init() {
load_plugin_textdomain('simple-local-avatars', false, dirname(plugin_basename(__FILE__)) . '/localization/');
register_setting('discussion', 'simple_local_avatars_caps', array($this, 'sanitize_options'));
add_settings_field('simple-local-avatars-caps', __('Права на локальные аватары', 'simple-local-avatars'), array($this, 'avatar_settings_field'), 'discussion', 'avatars');
}
function sanitize_options($input) {
$new_input['simple_local_avatars_caps'] = empty($input['simple_local_avatars_caps']) ? 0 : 1;
return $new_input;
}
function avatar_settings_field($args) {
$options = get_option('simple_local_avatars_caps');
echo '
<label for="simple_local_avatars_caps">
<input type="checkbox" name="simple_local_avatars_caps" id="simple_local_avatars_caps" value="1" ' . @checked($options['simple_local_avatars_caps'], 1, false) . ' />
' . __('Разрешить загрузку локальных аватаров только пользователям с правами загрузки файлов (Авторы и выше)', 'simple-local-avatars') . '
</label>
';
}
function edit_user_profile($profileuser) {
?>
<h3><?php _e('Аватар', 'simple-local-avatars'); ?></h3>
<table class="form-table">
<tr>
<th><label for="simple-local-avatar"><?php _e('Загрузить аватар', 'simple-local-avatars'); ?></label></th>
<td style="width: 50px;" valign="top">
<?php echo get_avatar($profileuser->ID); ?>
</td>
<td>
<?php
$options = get_option('simple_local_avatars_caps');
if (empty($options['simple_local_avatars_caps']) || current_user_can('upload_files')) {
do_action('simple_local_avatar_notices');
wp_nonce_field('simple_local_avatar_nonce', '_simple_local_avatar_nonce', false);
?>
<input type="file" name="simple-local-avatar" id="simple-local-avatar" /><br />
<?php
if (empty($profileuser->simple_local_avatar))
echo '<span class="description">' . __('Локальный аватар не установлен. Используйте поле загрузки, чтобы добавить локальный аватар.', 'simple-local-avatars') . '</span>';
else
echo '
<input type="checkbox" name="simple-local-avatar-erase" value="1" /> ' . __('Удалить локальный аватар', 'simple-local-avatars') . '<br />
<span class="description">' . __('Замените локальный аватар, загрузив новый, или удалите его (с возвратом к граватару), отметив опцию удаления.', 'simple-local-avatars') . '</span>
';
} else {
if (empty($profileuser->simple_local_avatar))
echo '<span class="description">' . __('Локальный аватар не установлен. Настройте свой аватар на Gravatar.com.', 'simple-local-avatars') . '</span>';
else
echo '<span class="description">' . __('У вас нет прав на управление медиа. Чтобы изменить локальный аватар, обратитесь к администратору блога.', 'simple-local-avatars') . '</span>';
}
?>
</td>
</tr>
</table>
<script type="text/javascript">
var form = document.getElementById('your-profile');
form.encoding = 'multipart/form-data';
form.setAttribute('enctype', 'multipart/form-data');
</script>
<?php
}
function edit_user_profile_update($user_id) {
if (!wp_verify_nonce($_POST['_simple_local_avatar_nonce'], 'simple_local_avatar_nonce')) // защита
return;
if (!empty($_FILES['simple-local-avatar']['name'])) {
$mimes = array(
'jpg|jpeg|jpe' => 'image/jpeg',
'gif' => 'image/gif',
'png' => 'image/png',
'bmp' => 'image/bmp',
'tif|tiff' => 'image/tiff'
);
$avatar = wp_handle_upload($_FILES['simple-local-avatar'], array('mimes' => $mimes, 'test_form' => false));
if (empty($avatar['file'])) // обработка ошибок
{
switch ($avatar['error']) {
case 'File type does not meet security guidelines. Try another.':
add_action('user_profile_update_errors', create_function('$a', '$a->add("avatar_error",__("Пожалуйста, загрузите корректный файл изображения для аватара.","simple-local-avatars"));'));
break;
default:
add_action('user_profile_update_errors', create_function('$a', '$a->add("avatar_error","<strong>".__("Ошибка при загрузке аватара:","simple-local-avatars")."</strong> ' . esc_attr($avatar['error']) . '");'));
}
return;
}
$this->avatar_delete($user_id); // удаляем старые изображения при успешной загрузке
update_user_meta($user_id, 'simple_local_avatar', array('full' => $avatar['url'])); // сохраняем информацию о пользователе (перезаписывая старую)
} elseif (isset($_POST['simple-local-avatar-erase']) && $_POST['simple-local-avatar-erase'] == 1)
$this->avatar_delete($user_id);
}
// удаляем кастомный хук get_avatar для вывода списка аватаров по умолчанию на options-discussion.php
function avatar_defaults($avatar_defaults) {
remove_action('get_avatar', array($this, 'get_avatar'));
return $avatar_defaults;
}
// удаляем аватары по ID пользователя
function avatar_delete($user_id) {
$old_avatars = get_user_meta($user_id, 'simple_local_avatar', true);
$upload_path = wp_upload_dir();
if (is_array($old_avatars)) {
foreach ($old_avatars as $old_avatar) {
$old_avatar_path = str_replace($upload_path['baseurl'], $upload_path['basedir'], $old_avatar);
@unlink($old_avatar_path);
}
}
delete_user_meta($user_id, 'simple_local_avatar');
}
}
$simple_local_avatars = new simple_local_avatars;
if (!function_exists('get_simple_local_avatar')):
/*
* более эффективно вызывать simple local avatar напрямую в теме, избегая настройки граватара
*
* @param int|string|object $id_or_email ID пользователя, email или объект комментария
* @param int $size Размер изображения аватара
* @param string $default URL изображения по умолчанию, если аватар недоступен
* @param string $alt Альтернативный текст для тега изображения. По умолчанию пустой
* @return string тег <img> для аватара пользователя
*/
function get_simple_local_avatar($id_or_email, $size = '96', $default = '', $alt = false) {
global $simple_local_avatars;
return $simple_local_avatars->get_avatar('', $id_or_email, $size, $default, $alt);
}
endif;
// при удалении плагина удаляем кастомное поле у пользователей и локальные аватары
register_uninstall_hook(__FILE__, 'simple_local_avatars_uninstall');
function simple_local_avatars_uninstall() {
$simple_local_avatars = new simple_local_avatars;
$users = get_users_of_blog();
foreach ($users as $user)
$simple_local_avatars->avatar_delete($user->user_id);
delete_option('simple_local_avatars_caps');
}
Если вам нужно сверхлегкое решение и вы не против немного покопаться в коде, добавьте это в ваш functions.php
:
function __default_local_avatar()
{
// предполагается, что default_avatar.png находится в wp-content/themes/active-theme/images
return get_bloginfo('template_directory') . '/images/default_avatar.png';
}
add_filter( 'pre_option_avatar_default', '__default_local_avatar' );
Альтернативно, если вам нужно больше возможностей и управление через админку, посмотрите плагин Add New Default Avatar.
ОБНОВЛЕНИЕ: Я написал небольшой плагин для использования вместе с Simple Local Avatars.
<?php
/**
* Plugin Name: Disable Default Avatars
* Plugin URI: http://wordpress.stackexchange.com/questions/17413
* Description: Используется вместе с <a href="http://www.get10up.com/plugins/simple-local-avatars-wordpress/">Simple Local Avatars</a>, отключает все стандартные аватары и использует одно изображение по умолчанию. Используйте фильтр <code>local_default_avatar</code> для указания пути к изображению.
* Version: 1.0
* Author: TheDeadMedic
* Author URI: http://wordpress.stackexchange.com/users/1685/thedeadmedic
*/
if ( !function_exists( 'get_avatar' ) ) :
/**
* Получает аватар пользователя по ID или email.
*
* @since 2.5
* @param int|string|object $id_or_email ID пользователя, email или объект комментария
* @param int $size Размер изображения аватара
* @param string $default URL изображения по умолчанию, если аватар недоступен
* @param string $alt Альтернативный текст для тега img. По умолчанию пустой
* @return string Тег <img> с аватаром пользователя
*/
function get_avatar( $id_or_email, $size = '96', $default = '', $alt = false ) {
if ( ! get_option('show_avatars') )
return false;
static $default_url; // используем статическую переменную для небольшого кэширования
if ( !isset( $default_url ) )
$default_url = apply_filters( 'local_default_avatar', get_template_directory_uri() . '/images/default_avatar.png' );
if ( false === $alt)
$safe_alt = '';
else
$safe_alt = esc_attr( $alt );
if ( !is_numeric( $size ) )
$size = '96';
$avatar = "<img alt='{$safe_alt}' src='{$default_url}' class='avatar avatar-{$size} photo avatar-default' height='{$size}' width='{$size}' />";
return apply_filters( 'get_avatar', $avatar, $id_or_email, $size, $default, $alt );
}
endif;
function __limit_default_avatars_setting( $default )
{
return 'local_default';
}
add_filter( 'pre_option_avatar_default', '__limit_default_avatars_setting' );
if ( is_admin() ) :
function __limit_default_avatars( $defaults )
{
return array( 'local_default' => get_bloginfo( 'name' ) . ' Default' );
}
add_filter( 'avatar_defaults', '__limit_default_avatars' );
endif;
?>
Описание плагина говорит само за себя: по умолчанию используется аватар http://wordpress-theme-path/images/default_avatar.png
, который можно изменить через фильтр в вашем functions.php
, если он находится в другом месте:
function __my_theme_default_avatar( $url )
{
return 'http://somewhere/else.jpg';
}
add_filter( 'local_default_avatar', '__my_theme_default_avatar' );

Почти :) Это устанавливает новый аватар по умолчанию вместо, например, таинственного человека. Можно ли также полностью отключить поддержку Gravatar и просто иметь возможность выбирать между вашим плагином и Simple Local Avatars?

Я успешно заменил все аватары с gravatar.com на собственное локально размещенное изображение, добавив следующий код в файл function.php
моей темы:
define('DEFAULT_AVATAR_URL', get_template_directory_uri() . '/images/user.png');
function no_gravatars( $avatar ) {
return preg_replace( "/http.*?gravatar\.com[^\']*/", DEFAULT_AVATAR_URL, $avatar );
}
add_filter( 'get_avatar', 'no_gravatars' );
Это предполагает, что у вас есть локальный аватар по умолчанию с именем user.png
в подкаталоге images
вашей темы.
В админ-панели в настройках обсуждения (discussion settings
) убедитесь, что отмечена опция "Показывать аватары" ("Show Avatars").
Я не тестировал это с плагином Simple Local Avatars, но отлично работает с Basic User Avatars (это облегченная версия Simple Local Avatars).
СОВЕТ: Если вы создаете собственный аватар по умолчанию, я рекомендую сделать его размером 300x300 пикселей, чтобы он хорошо выглядел на экранах с высоким разрешением ("retina"), когда WordPress отображает его в размере "150x150". Затем вы можете значительно уменьшить размер файла изображения, сжав его на tinyPNG.com.

Расширение к исходному вопросу: Если вы хотите убрать или заменить заметку "Вы можете изменить изображение профиля на Gravatar" на странице профиля WordPress, добавьте следующий код в файл functions.php вашей активной темы:
/**
* Отключает заметку о Gravatar в настройках профиля WP
*/
function replace_wp_gravatar_note()
{
// убрать:
return null;
// заменить:
// return 'Вы можете изменить изображение профиля <a href="' . get_site_url(null, 'user', 'https') . '">здесь</a>.';
}
add_filter( 'user_profile_picture_description', 'replace_wp_gravatar_note' );

Полностью удалить аватары. Поместите этот код в файл functions.php вашей активной темы.
add_action( 'init', 'qmas_remove_avatars' );
if (!function_exists('qmas_remove_avatars')) {
function qmas_remove_avatars() {
add_filter( 'bp_core_fetch_avatar', function () { return ''; } );
add_filter( 'get_avatar', function () { return ''; } );
add_filter( 'bp_get_signup_avatar', function () { return ''; } );
}
}

Заменяет тег IMG на пустую строку. Также возвращает пустую строку в URL аватара. Оставляя стандартное назначение WordPress.
