[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * Post API: WP_Post class 4 * 5 * @package WordPress 6 * @subpackage Post 7 * @since 4.4.0 8 */ 9 10 /** 11 * Core class used to implement the WP_Post object. 12 * 13 * @since 3.5.0 14 * 15 * @property string $page_template 16 * 17 * @property-read int[] $ancestors 18 * @property-read int[] $post_category 19 * @property-read string[] $tags_input 20 */ 21 #[AllowDynamicProperties] 22 final class WP_Post { 23 24 /** 25 * Post ID. 26 * 27 * @since 3.5.0 28 * @var int 29 */ 30 public $ID; 31 32 /** 33 * ID of post author. 34 * 35 * A numeric string, for compatibility reasons. 36 * 37 * @since 3.5.0 38 * @var string 39 */ 40 public $post_author = 0; 41 42 /** 43 * The post's local publication time. 44 * 45 * @since 3.5.0 46 * @var string 47 */ 48 public $post_date = '0000-00-00 00:00:00'; 49 50 /** 51 * The post's GMT publication time. 52 * 53 * @since 3.5.0 54 * @var string 55 */ 56 public $post_date_gmt = '0000-00-00 00:00:00'; 57 58 /** 59 * The post's content. 60 * 61 * @since 3.5.0 62 * @var string 63 */ 64 public $post_content = ''; 65 66 /** 67 * The post's title. 68 * 69 * @since 3.5.0 70 * @var string 71 */ 72 public $post_title = ''; 73 74 /** 75 * The post's excerpt. 76 * 77 * @since 3.5.0 78 * @var string 79 */ 80 public $post_excerpt = ''; 81 82 /** 83 * The post's status. 84 * 85 * @since 3.5.0 86 * @var string 87 */ 88 public $post_status = 'publish'; 89 90 /** 91 * Whether comments are allowed. 92 * 93 * @since 3.5.0 94 * @var string 95 */ 96 public $comment_status = 'open'; 97 98 /** 99 * Whether pings are allowed. 100 * 101 * @since 3.5.0 102 * @var string 103 */ 104 public $ping_status = 'open'; 105 106 /** 107 * The post's password in plain text. 108 * 109 * @since 3.5.0 110 * @var string 111 */ 112 public $post_password = ''; 113 114 /** 115 * The post's slug. 116 * 117 * @since 3.5.0 118 * @var string 119 */ 120 public $post_name = ''; 121 122 /** 123 * URLs queued to be pinged. 124 * 125 * @since 3.5.0 126 * @var string 127 */ 128 public $to_ping = ''; 129 130 /** 131 * URLs that have been pinged. 132 * 133 * @since 3.5.0 134 * @var string 135 */ 136 public $pinged = ''; 137 138 /** 139 * The post's local modified time. 140 * 141 * @since 3.5.0 142 * @var string 143 */ 144 public $post_modified = '0000-00-00 00:00:00'; 145 146 /** 147 * The post's GMT modified time. 148 * 149 * @since 3.5.0 150 * @var string 151 */ 152 public $post_modified_gmt = '0000-00-00 00:00:00'; 153 154 /** 155 * A utility DB field for post content. 156 * 157 * @since 3.5.0 158 * @var string 159 */ 160 public $post_content_filtered = ''; 161 162 /** 163 * ID of a post's parent post. 164 * 165 * @since 3.5.0 166 * @var int 167 */ 168 public $post_parent = 0; 169 170 /** 171 * The unique identifier for a post, not necessarily a URL, used as the feed GUID. 172 * 173 * @since 3.5.0 174 * @var string 175 */ 176 public $guid = ''; 177 178 /** 179 * A field used for ordering posts. 180 * 181 * @since 3.5.0 182 * @var int 183 */ 184 public $menu_order = 0; 185 186 /** 187 * The post's type, like post or page. 188 * 189 * @since 3.5.0 190 * @var string 191 */ 192 public $post_type = 'post'; 193 194 /** 195 * An attachment's mime type. 196 * 197 * @since 3.5.0 198 * @var string 199 */ 200 public $post_mime_type = ''; 201 202 /** 203 * Cached comment count. 204 * 205 * A numeric string, for compatibility reasons. 206 * 207 * @since 3.5.0 208 * @var string 209 */ 210 public $comment_count = 0; 211 212 /** 213 * Stores the post object's sanitization level. 214 * 215 * Does not correspond to a DB field. 216 * 217 * @since 3.5.0 218 * @var string 219 */ 220 public $filter; 221 222 /** 223 * Retrieve WP_Post instance. 224 * 225 * @since 3.5.0 226 * 227 * @global wpdb $wpdb WordPress database abstraction object. 228 * 229 * @param int $post_id Post ID. 230 * @return WP_Post|false Post object, false otherwise. 231 */ 232 public static function get_instance( $post_id ) { 233 global $wpdb; 234 235 $post_id = (int) $post_id; 236 if ( ! $post_id ) { 237 return false; 238 } 239 240 $_post = wp_cache_get( $post_id, 'posts' ); 241 242 if ( ! $_post ) { 243 $_post = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $wpdb->posts WHERE ID = %d LIMIT 1", $post_id ) ); 244 245 if ( ! $_post ) { 246 return false; 247 } 248 249 $_post = sanitize_post( $_post, 'raw' ); 250 wp_cache_add( $_post->ID, $_post, 'posts' ); 251 } elseif ( empty( $_post->filter ) || 'raw' !== $_post->filter ) { 252 $_post = sanitize_post( $_post, 'raw' ); 253 } 254 255 return new WP_Post( $_post ); 256 } 257 258 /** 259 * Constructor. 260 * 261 * @since 3.5.0 262 * 263 * @param WP_Post|object $post Post object. 264 */ 265 public function __construct( $post ) { 266 foreach ( get_object_vars( $post ) as $key => $value ) { 267 $this->$key = $value; 268 } 269 } 270 271 /** 272 * Isset-er. 273 * 274 * @since 3.5.0 275 * 276 * @param string $key Property to check if set. 277 * @return bool 278 */ 279 public function __isset( $key ) { 280 if ( 'ancestors' === $key ) { 281 return true; 282 } 283 284 if ( 'page_template' === $key ) { 285 return true; 286 } 287 288 if ( 'post_category' === $key ) { 289 return true; 290 } 291 292 if ( 'tags_input' === $key ) { 293 return true; 294 } 295 296 return metadata_exists( 'post', $this->ID, $key ); 297 } 298 299 /** 300 * Getter. 301 * 302 * @since 3.5.0 303 * 304 * @param string $key Key to get. 305 * @return mixed 306 */ 307 public function __get( $key ) { 308 if ( 'page_template' === $key && $this->__isset( $key ) ) { 309 return get_post_meta( $this->ID, '_wp_page_template', true ); 310 } 311 312 if ( 'post_category' === $key ) { 313 if ( is_object_in_taxonomy( $this->post_type, 'category' ) ) { 314 $terms = get_the_terms( $this, 'category' ); 315 } 316 317 if ( empty( $terms ) ) { 318 return array(); 319 } 320 321 return wp_list_pluck( $terms, 'term_id' ); 322 } 323 324 if ( 'tags_input' === $key ) { 325 if ( is_object_in_taxonomy( $this->post_type, 'post_tag' ) ) { 326 $terms = get_the_terms( $this, 'post_tag' ); 327 } 328 329 if ( empty( $terms ) ) { 330 return array(); 331 } 332 333 return wp_list_pluck( $terms, 'name' ); 334 } 335 336 // Rest of the values need filtering. 337 if ( 'ancestors' === $key ) { 338 $value = get_post_ancestors( $this ); 339 } else { 340 $value = get_post_meta( $this->ID, $key, true ); 341 } 342 343 if ( $this->filter ) { 344 $value = sanitize_post_field( $key, $value, $this->ID, $this->filter ); 345 } 346 347 return $value; 348 } 349 350 /** 351 * {@Missing Summary} 352 * 353 * @since 3.5.0 354 * 355 * @param string $filter Filter. 356 * @return WP_Post 357 */ 358 public function filter( $filter ) { 359 if ( $this->filter === $filter ) { 360 return $this; 361 } 362 363 if ( 'raw' === $filter ) { 364 return self::get_instance( $this->ID ); 365 } 366 367 return sanitize_post( $this, $filter ); 368 } 369 370 /** 371 * Convert object to array. 372 * 373 * @since 3.5.0 374 * 375 * @return array Object as array. 376 */ 377 public function to_array() { 378 $post = get_object_vars( $this ); 379 380 foreach ( array( 'ancestors', 'page_template', 'post_category', 'tags_input' ) as $key ) { 381 if ( $this->__isset( $key ) ) { 382 $post[ $key ] = $this->__get( $key ); 383 } 384 } 385 386 return $post; 387 } 388 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |