PHP 8.2.31
Preview: wp-trackback.php Size: 5.09 KB
/home/nshryvcy/radiantskinclinics.org/wp-trackback.php

<?php
/**
 * Handle Trackbacks and Pingbacks Sent to WordPress
 *
 * @since 0.71
 *
 * @package WordPress
 * @subpackage Trackbacks
 */

if ( empty( $wp ) ) {
	require_once __DIR__ . '/wp-load.php';
	wp( array( 'tb' => '1' ) );
}

// Always run as an unauthenticated user.
wp_set_current_user( 0 );

/**
 * Response to a trackback.
 *
 * Responds with an error or success XML message.
 *
 * @since 0.71
 *
 * @param int|bool $error         Whether there was an error.
 *                                Default '0'. Accepts '0' or '1', true or false.
 * @param string   $error_message Error message if an error occurred. Default empty string.
 */
function trackback_response( $error = 0, $error_message = '' ) {
	header( 'Content-Type: text/xml; charset=' . get_option( 'blog_charset' ) );

	if ( $error ) {
		echo '<?xml version="1.0" encoding="utf-8"?' . ">\n";
		echo "<response>\n";
		echo "<error>1</error>\n";
		echo "<message>$error_message</message>\n";
		echo '</response>';
		die();
	} else {
		echo '<?xml version="1.0" encoding="utf-8"?' . ">\n";
		echo "<response>\n";
		echo "<error>0</error>\n";
		echo '</response>';
	}
}

if ( ! isset( $_GET['tb_id'] ) || ! $_GET['tb_id'] ) {
	$post_id = explode( '/', $_SERVER['REQUEST_URI'] );
	$post_id = (int) $post_id[ count( $post_id ) - 1 ];
}

$trackback_url = isset( $_POST['url'] ) ? sanitize_url( $_POST['url'] ) : '';
$charset       = isset( $_POST['charset'] ) ? sanitize_text_field( $_POST['charset'] ) : '';

// These three are stripslashed here so they can be properly escaped after mb_convert_encoding().
$title     = isset( $_POST['title'] ) ? sanitize_text_field( wp_unslash( $_POST['title'] ) ) : '';
$excerpt   = isset( $_POST['excerpt'] ) ? sanitize_textarea_field( wp_unslash( $_POST['excerpt'] ) ) : '';
$blog_name = isset( $_POST['blog_name'] ) ? sanitize_text_field( wp_unslash( $_POST['blog_name'] ) ) : '';

if ( $charset ) {
	$charset = str_replace( array( ',', ' ' ), '', strtoupper( trim( $charset ) ) );

	// Validate the specified "sender" charset is available on the receiving site.
	if ( function_exists( 'mb_list_encodings' ) && ! in_array( $charset, mb_list_encodings(), true ) ) {
		$charset = '';
	}
}

if ( ! $charset ) {
	$charset = 'ASCII, UTF-8, ISO-8859-1, JIS, EUC-JP, SJIS';
}

// No valid uses for UTF-7.
if ( str_contains( $charset, 'UTF-7' ) ) {
	die;
}

// For international trackbacks.
if ( function_exists( 'mb_convert_encoding' ) ) {
	$title     = mb_convert_encoding( $title, get_option( 'blog_charset' ), $charset );
	$excerpt   = mb_convert_encoding( $excerpt, get_option( 'blog_charset' ), $charset );
	$blog_name = mb_convert_encoding( $blog_name, get_option( 'blog_charset' ), $charset );
}

// Escape values to use in the trackback.
$title     = wp_slash( $title );
$excerpt   = wp_slash( $excerpt );
$blog_name = wp_slash( $blog_name );

if ( is_single() || is_page() ) {
	$post_id = $posts[0]->ID;
}

if ( ! isset( $post_id ) || ! (int) $post_id ) {
	trackback_response( 1, __( 'I really need an ID for this to work.' ) );
}

if ( empty( $title ) && empty( $trackback_url ) && empty( $blog_name ) ) {
	// If it doesn't look like a trackback at all.
	wp_redirect( get_permalink( $post_id ) );
	exit;
}

if ( ! empty( $trackback_url ) && ! empty( $title ) ) {
	/**
	 * Fires before the trackback is added to a post.
	 *
	 * @since 4.7.0
	 *
	 * @param int    $post_id       Post ID related to the trackback.
	 * @param string $trackback_url Trackback URL.
	 * @param string $charset       Character set.
	 * @param string $title         Trackback title.
	 * @param string $excerpt       Trackback excerpt.
	 * @param string $blog_name     Site name.
	 */
	do_action( 'pre_trackback_post', $post_id, $trackback_url, $charset, $title, $excerpt, $blog_name );

	header( 'Content-Type: text/xml; charset=' . get_option( 'blog_charset' ) );

	if ( ! pings_open( $post_id ) ) {
		trackback_response( 1, __( 'Sorry, trackbacks are closed for this item.' ) );
	}

	$title   = wp_html_excerpt( $title, 250, '&#8230;' );
	$excerpt = wp_html_excerpt( $excerpt, 252, '&#8230;' );

	$comment_post_id      = (int) $post_id;
	$comment_author       = $blog_name;
	$comment_author_email = '';
	$comment_author_url   = $trackback_url;
	$comment_content      = "<strong>$title</strong>\n\n$excerpt";
	$comment_type         = 'trackback';

	$dupe = $wpdb->get_results(
		$wpdb->prepare(
			"SELECT * FROM $wpdb->comments WHERE comment_post_ID = %d AND comment_author_url = %s",
			$comment_post_id,
			$comment_author_url
		)
	);

	if ( $dupe ) {
		trackback_response( 1, __( 'There is already a ping from that URL for this post.' ) );
	}

	$commentdata = array(
		'comment_post_ID' => $comment_post_id,
	);

	$commentdata += compact(
		'comment_author',
		'comment_author_email',
		'comment_author_url',
		'comment_content',
		'comment_type'
	);

	$result = wp_new_comment( $commentdata );

	if ( is_wp_error( $result ) ) {
		trackback_response( 1, $result->get_error_message() );
	}

	$trackback_id = $wpdb->insert_id;

	/**
	 * Fires after a trackback is added to a post.
	 *
	 * @since 1.2.0
	 *
	 * @param int $trackback_id Trackback ID.
	 */
	do_action( 'trackback_post', $trackback_id );

	trackback_response( 0 );
}

Directory Contents

Dirs: 7 × Files: 25

Name Size Perms Modified Actions
- drwxr-xr-x 2022-07-28 06:02:53
Edit Download
cgi-bin DIR
- drwxr-xr-x 2026-02-23 02:01:21
Edit Download
images DIR
- drwxr-xr-x 2026-02-23 02:01:21
Edit Download
keys DIR
- drwxr-xr-x 2022-07-25 07:01:53
Edit Download
wp-admin DIR
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
- drwxr-xr-x 2026-06-09 18:18:29
Edit Download
- drwxr-xr-x 2026-05-21 12:19:03
Edit Download
1.43 KB lrw-r--r-- 2026-05-27 02:52:29
Edit Download
1.99 KB lrw-r--r-- 2026-02-19 09:02:08
Edit Download
297 B lrw-r--r-- 2026-06-09 01:37:34
Edit Download
8.25 MB lrw-r--r-- 2026-06-09 23:39:10
Edit Download
405 B lrw-r--r-- 2020-02-06 11:33:12
Edit Download
19.44 KB lrw-r--r-- 2026-01-01 05:07:30
Edit Download
17.64 KB lrw-r--r-- 2026-06-02 17:39:57
Edit Download
7.23 KB lrw-r--r-- 2026-01-09 16:47:48
Edit Download
77 B lrw-r--r-- 2026-02-23 02:00:22
Edit Download
1 B lrw-r--r-- 2026-02-23 02:00:15
Edit Download
7.20 KB lrw-r--r-- 2026-02-17 22:05:44
Edit Download
351 B lrw-r--r-- 2020-02-06 11:33:12
Edit Download
2.27 KB lrw-r--r-- 2023-06-14 18:11:16
Edit Download
3.26 KB lrw-r--r-- 2025-08-12 18:47:32
Edit Download
3.52 KB lrw-r--r-- 2026-05-04 08:07:25
Edit Download
5.49 KB lrw-r--r-- 2024-08-02 23:40:16
Edit Download
2.43 KB lrw-r--r-- 2025-04-30 16:52:30
Edit Download
47.82 KB lrw-r--r-- 2026-02-23 01:52:25
Edit Download
3.84 KB lrw-r--r-- 2024-03-11 14:05:16
Edit Download
50.63 KB lrw-r--r-- 2026-03-01 03:57:46
Edit Download
8.52 KB lrw-r--r-- 2025-04-03 02:25:26
Edit Download
31.88 KB lrw-r--r-- 2026-05-08 19:59:44
Edit Download
33.81 KB lrw-r--r-- 2026-02-17 22:05:44
Edit Download
5.09 KB lrw-r--r-- 2025-08-19 16:30:32
Edit Download
3.13 KB lrw-r--r-- 2024-11-08 20:52:18
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).