options = (array) get_option( 'simple_local_avatars' ); $this->avatar_ratings = array( 'G' => __( 'G — Suitable for all audiences', 'simple-local-avatars' ), 'PG' => __( 'PG — Possibly offensive, usually for audiences 13 and above', 'simple-local-avatars' ), 'R' => __( 'R — Intended for adult audiences above 17', 'simple-local-avatars' ), 'X' => __( 'X — Even more mature than above', 'simple-local-avatars' ), ); $this->add_hooks(); } /** * Register actions and filters. */ public function add_hooks() { add_filter( 'pre_get_avatar_data', array( $this, 'get_avatar_data' ), 10, 2 ); add_action( 'admin_init', array( $this, 'admin_init' ) ); add_action( 'admin_enqueue_scripts', array( $this, 'admin_enqueue_scripts' ) ); 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_action( 'admin_action_remove-simple-local-avatar', array( $this, 'action_remove_simple_local_avatar' ) ); add_action( 'wp_ajax_assign_simple_local_avatar_media', array( $this, 'ajax_assign_simple_local_avatar_media' ) ); add_action( 'wp_ajax_remove_simple_local_avatar', array( $this, 'action_remove_simple_local_avatar' ) ); add_action( 'user_edit_form_tag', array( $this, 'user_edit_form_tag' ) ); add_action( 'rest_api_init', array( $this, 'register_rest_fields' ) ); } /** * Retrieve the local avatar for a user who provided a user ID, email address or post/comment object. * * @param string $avatar Avatar return by original function * @param int|string|object $id_or_email A user ID, email address, or post/comment object * @param int $size Size of the avatar image * @param string $default URL to a default image to use if no avatar is available * @param string $alt Alternative text to use in image tag. Defaults to blank * @param array $args Optional. Extra arguments to retrieve the avatar. * * @return string tag for the user's avatar */ public function get_avatar( $avatar = '', $id_or_email = '', $size = 96, $default = '', $alt = '', $args = array() ) { return apply_filters( 'simple_local_avatar', get_avatar( $id_or_email, $size, $default, $alt, $args ) ); } /** * Filter avatar data early to add avatar url if needed. This filter hooks * before Gravatar setup to prevent wasted requests. * * @since 2.2.0 * * @param array $args Arguments passed to get_avatar_data(), after processing. * @param mixed $id_or_email The Gravatar to retrieve. Accepts a user ID, Gravatar MD5 hash, * user email, WP_User object, WP_Post object, or WP_Comment object. */ public function get_avatar_data( $args, $id_or_email ) { if ( ! empty( $args['force_default'] ) ) { return $args; } $simple_local_avatar_url = $this->get_simple_local_avatar_url( $id_or_email, $args['size'] ); if ( $simple_local_avatar_url ) { $args['url'] = $simple_local_avatar_url; } // Local only mode if ( ! $simple_local_avatar_url && ! empty( $this->options['only'] ) ) { $args['url'] = $this->get_default_avatar_url( $args['size'] ); } if ( ! empty( $args['url'] ) ) { $args['found_avatar'] = true; } return $args; } /** * Get local avatar url. * * @since 2.2.0 * * @param mixed $id_or_email The Gravatar to retrieve. Accepts a user ID, Gravatar MD5 hash, * user email, WP_User object, WP_Post object, or WP_Comment object. * @param int $size Requested avatar size. */ public function get_simple_local_avatar_url( $id_or_email, $size ) { if ( is_numeric( $id_or_email ) ) { $user_id = (int) $id_or_email; } elseif ( is_string( $id_or_email ) && ( $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; } elseif ( $id_or_email instanceof WP_Post && ! empty( $id_or_email->post_author ) ) { $user_id = (int) $id_or_email->post_author; } if ( empty( $user_id ) ) { return ''; } // Fetch local avatar from meta and make sure it's properly set. $local_avatars = get_user_meta( $user_id, 'simple_local_avatar', true ); if ( empty( $local_avatars['full'] ) ) { return ''; } // check rating $avatar_rating = get_user_meta( $user_id, 'simple_local_avatar_rating', true ); if ( ! empty( $avatar_rating ) && 'G' !== $avatar_rating && ( $site_rating = get_option( 'avatar_rating' ) ) ) { $ratings = array_keys( $this->avatar_ratings ); $site_rating_weight = array_search( $site_rating, $ratings ); $avatar_rating_weight = array_search( $avatar_rating, $ratings ); if ( false !== $avatar_rating_weight && $avatar_rating_weight > $site_rating_weight ) { return ''; } } // handle "real" media if ( ! empty( $local_avatars['media_id'] ) ) { // has the media been deleted? if ( ! $avatar_full_path = get_attached_file( $local_avatars['media_id'] ) ) { return ''; } } $size = (int) $size; // Generate a new size. if ( ! array_key_exists( $size, $local_avatars ) ) { $local_avatars[ $size ] = $local_avatars['full']; // just in case of failure elsewhere // allow automatic rescaling to be turned off if ( apply_filters( 'simple_local_avatars_dynamic_resize', true ) ) : $upload_path = wp_upload_dir(); // get path for image by converting URL, unless its already been set, thanks to using media library approach if ( ! isset( $avatar_full_path ) ) { $avatar_full_path = str_replace( $upload_path['baseurl'], $upload_path['basedir'], $local_avatars['full'] ); } // generate the new size $editor = wp_get_image_editor( $avatar_full_path ); if ( ! is_wp_error( $editor ) ) { $resized = $editor->resize( $size, $size, true ); if ( ! is_wp_error( $resized ) ) { $dest_file = $editor->generate_filename(); $saved = $editor->save( $dest_file ); if ( ! is_wp_error( $saved ) ) { $local_avatars[ $size ] = str_replace( $upload_path['basedir'], $upload_path['baseurl'], $dest_file ); } } } // save updated avatar sizes update_user_meta( $user_id, 'simple_local_avatar', $local_avatars ); endif; } if ( 'http' !== substr( $local_avatars[ $size ], 0, 4 ) ) { $local_avatars[ $size ] = home_url( $local_avatars[ $size ] ); } return esc_url( $local_avatars[ $size ] ); } /** * Get default avatar url * * @since 2.2.0 * * @param int $size Requested avatar size. */ public function get_default_avatar_url( $size ) { if ( empty( $default ) ) { $avatar_default = get_option( 'avatar_default' ); if ( empty( $avatar_default ) ) { $default = 'mystery'; } else { $default = $avatar_default; } } $host = is_ssl() ? 'https://secure.gravatar.com' : 'http://0.gravatar.com'; if ( 'mystery' === $default ) { $default = "$host/avatar/ad516503a11cd5ca435acc9bb6523536?s={$size}"; // ad516503a11cd5ca435acc9bb6523536 == md5('unknown@gravatar.com') } elseif ( 'blank' === $default ) { $default = includes_url( 'images/blank.gif' ); } elseif ( 'gravatar_default' === $default ) { $default = "$host/avatar/?s={$size}"; } else { $default = "$host/avatar/?d=$default&s={$size}"; } return $default; } /** * Register admin settings. */ public function admin_init() { // upgrade pre 2.0 option if ( $old_ops = get_option( 'simple_local_avatars_caps' ) ) { if ( ! empty( $old_ops['simple_local_avatars_caps'] ) ) { update_option( 'simple_local_avatars', array( 'caps' => 1 ) ); } delete_option( 'simple_local_avatar_caps' ); } register_setting( 'discussion', 'simple_local_avatars', array( $this, 'sanitize_options' ) ); add_settings_field( 'simple-local-avatars-only', __( 'Local Avatars Only', 'simple-local-avatars' ), array( $this, 'avatar_settings_field' ), 'discussion', 'avatars', array( 'key' => 'only', 'desc' => __( 'Only allow local avatars (still uses Gravatar for default avatars)', 'simple-local-avatars' ), ) ); add_settings_field( 'simple-local-avatars-caps', __( 'Local Upload Permissions', 'simple-local-avatars' ), array( $this, 'avatar_settings_field' ), 'discussion', 'avatars', array( 'key' => 'caps', 'desc' => __( 'Only allow users with file upload capabilities to upload local avatars (Authors and above)', 'simple-local-avatars' ), ) ); } /** * Add scripts to the profile editing page * * @param string $hook_suffix Page hook */ public function admin_enqueue_scripts( $hook_suffix ) { if ( 'profile.php' !== $hook_suffix && 'user-edit.php' !== $hook_suffix ) { return; } if ( current_user_can( 'upload_files' ) ) { wp_enqueue_media(); } $user_id = ( 'profile.php' === $hook_suffix ) ? get_current_user_id() : (int) $_GET['user_id']; $this->remove_nonce = wp_create_nonce( 'remove_simple_local_avatar_nonce' ); $script_name_append = ( defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) ? '.dev' : ''; wp_enqueue_script( 'simple-local-avatars', plugins_url( '', dirname( __FILE__ ) ) . '/simple-local-avatars' . $script_name_append . '.js', array( 'jquery' ), false, true ); wp_localize_script( 'simple-local-avatars', 'i10n_SimpleLocalAvatars', array( 'user_id' => $user_id, 'insertMediaTitle' => __( 'Choose an Avatar', 'simple-local-avatars' ), 'insertIntoPost' => __( 'Set as avatar', 'simple-local-avatars' ), 'deleteNonce' => $this->remove_nonce, 'mediaNonce' => wp_create_nonce( 'assign_simple_local_avatar_nonce' ), ) ); } /** * Sanitize new settings field before saving * * @param array|string $input Passed input values to sanitize * @return array|string Sanitized input fields */ public function sanitize_options( $input ) { $new_input['caps'] = empty( $input['caps'] ) ? 0 : 1; $new_input['only'] = empty( $input['only'] ) ? 0 : 1; return $new_input; } /** * Settings field for avatar upload capabilities * * @param array $args Field arguments */ public function avatar_settings_field( $args ) { $args = wp_parse_args( $args, array( 'key' => '', 'desc' => '', ) ); if ( empty( $this->options[ $args['key'] ] ) ) { $this->options[ $args['key'] ] = 0; } echo ' '; } /** * Output new Avatar fields to user editing / profile screen * * @param object $profileuser User object */ public function edit_user_profile( $profileuser ) { ?>
ID ); remove_filter( 'pre_option_avatar_rating', '__return_null' ); ?> |
options['caps'] );
}
if ( $upload_rights ) {
do_action( 'simple_local_avatar_notices' );
wp_nonce_field( 'simple_local_avatar_nonce', '_simple_local_avatar_nonce', false );
$remove_url = add_query_arg(
array(
'action' => 'remove-simple-local-avatar',
'user_id' => $profileuser->ID,
'_wpnonce' => $this->remove_nonce,
)
);
?>
simple_local_avatar ) ? ' style="display:none;"' : ''; ?> > simple_local_avatar ) ) { echo ' ' . esc_html__( 'No local avatar is set. Set up your avatar at Gravatar.com.', 'simple-local-avatars' ) . ''; } else { echo '' . esc_html__( 'You do not have media management permissions. To change your local avatar, contact the blog administrator.', 'simple-local-avatars' ) . ''; } } ?> |
|