wpseek.com
A WordPress-centric search engine for devs and theme authors



get_comment_author_email_link › WordPress Function

Since2.7.0
Deprecatedn/a
get_comment_author_email_link ( $link_text = '', $before = '', $after = '', $comment = null )
Parameters: (4)
  • (string) $link_text Optional. Text to display instead of the comment author's email address. Default empty.
    Required: No
    Default: (empty)
  • (string) $before Optional. Text or HTML to display before the email link. Default empty.
    Required: No
    Default: (empty)
  • (string) $after Optional. Text or HTML to display after the email link. Default empty.
    Required: No
    Default: (empty)
  • (int|WP_Comment) $comment Optional. Comment ID or WP_Comment object. Default is the current comment.
    Required: No
    Default: null
Returns:
  • (string) HTML markup for the comment author email link. By default, the email address is obfuscated via the {@see 'comment_email'} filter with antispambot().
Defined at:
Codex:
Change Log:
  • 4.6.0

Returns the HTML email link to the author of the current comment.

Care should be taken to protect the email address and assure that email harvesters do not capture your commenter's email address. Most assume that their email address will not appear in raw form on the site. Doing so will enable anyone, including those that people don't want to get the email address and use it for their own means good and bad.


Source

function get_comment_author_email_link( $link_text = '', $before = '', $after = '', $comment = null ) {
	$comment = get_comment( $comment );

	/**
	 * Filters the comment author's email for display.
	 *
	 * Care should be taken to protect the email address and assure that email
	 * harvesters do not capture your commenter's email address.
	 *
	 * @since 1.2.0
	 * @since 4.1.0 The `$comment` parameter was added.
	 *
	 * @param string     $comment_author_email The comment author's email address.
	 * @param WP_Comment $comment              The comment object.
	 */
	$comment_author_email = apply_filters( 'comment_email', $comment->comment_author_email, $comment );

	if ( ( ! empty( $comment_author_email ) ) && ( '@' !== $comment_author_email ) ) {
		$display = ( '' !== $link_text ) ? $link_text : $comment_author_email;

		$comment_author_email_link = $before . sprintf(
			'<a href="%1$s">%2$s</a>',
			esc_url( 'mailto:' . $comment_author_email ),
			esc_html( $display )
		) . $after;

		return $comment_author_email_link;
	} else {
		return '';
	}
}