wp_set_comment_cookies()WP 3.4.0

Устанавливает куки (имя, почту, сайт), которые используются для идентификации неавторизованного пользователя при комментировании.

Хуки из функции

Возвращает

null.

Использование

wp_set_comment_cookies( $comment, $user );
$comment(WP_Comment) (обязательный)
Объект комментария.
$user(объект) (обязательный)

Объект автора комментария.

Функция не будет ничего делать, если указанный пользователь существует. Это делается для того, чтобы куки хранились только для неавторизованных комментаторов.

$cookies_consent(true/false)
Дал ли согласие автор комментария сохранять куки.
Default: true

Примеры

0

#1 Установка куков комментатора

Вообще в Wordpress такие куки устанавливаются при публикации комментария, через событие

do_action( 'set_comment_cookies', $comment, $user );

в файле wp-comments-post.php

Но в этом примере мы установим их отдельно, например когда мы публикуем комментарий не через файл wp-comments-post.php, а как-то по-своему...

$user = wp_get_current_user();
$comment = get_comment( $id = 255 );

wp_set_comment_cookies( $comment, $user );

Список изменений

С версии 3.4.0 Введена.
С версии 4.9.6 The $cookies_consent parameter was added.

Код wp_set_comment_cookies() WP 6.5.2

function wp_set_comment_cookies( $comment, $user, $cookies_consent = true ) {
	// If the user already exists, or the user opted out of cookies, don't set cookies.
	if ( $user->exists() ) {
		return;
	}

	if ( false === $cookies_consent ) {
		// Remove any existing cookies.
		$past = time() - YEAR_IN_SECONDS;
		setcookie( 'comment_author_' . COOKIEHASH, ' ', $past, COOKIEPATH, COOKIE_DOMAIN );
		setcookie( 'comment_author_email_' . COOKIEHASH, ' ', $past, COOKIEPATH, COOKIE_DOMAIN );
		setcookie( 'comment_author_url_' . COOKIEHASH, ' ', $past, COOKIEPATH, COOKIE_DOMAIN );

		return;
	}

	/**
	 * Filters the lifetime of the comment cookie in seconds.
	 *
	 * @since 2.8.0
	 *
	 * @param int $seconds Comment cookie lifetime. Default 30000000.
	 */
	$comment_cookie_lifetime = time() + apply_filters( 'comment_cookie_lifetime', 30000000 );

	$secure = ( 'https' === parse_url( home_url(), PHP_URL_SCHEME ) );

	setcookie( 'comment_author_' . COOKIEHASH, $comment->comment_author, $comment_cookie_lifetime, COOKIEPATH, COOKIE_DOMAIN, $secure );
	setcookie( 'comment_author_email_' . COOKIEHASH, $comment->comment_author_email, $comment_cookie_lifetime, COOKIEPATH, COOKIE_DOMAIN, $secure );
	setcookie( 'comment_author_url_' . COOKIEHASH, esc_url( $comment->comment_author_url ), $comment_cookie_lifetime, COOKIEPATH, COOKIE_DOMAIN, $secure );
}