Changeset 27698
- Timestamp:
- 03/25/2014 08:55:44 AM (10 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/wp-includes/meta.php
r27689 r27698 17 17 * @since 2.9.0 18 18 * @uses $wpdb WordPress database object for queries. 19 * @uses do_action() Calls 'added_{$meta_type}_meta' with meta_id of added metadata entry,20 * object ID, meta key, and meta value21 19 * 22 20 * @param string $meta_type Type of object metadata is for (e.g., comment, post, or user) … … 48 46 $meta_value = sanitize_meta( $meta_key, $meta_value, $meta_type ); 49 47 48 /** 49 * Filter whether to add metadata of a specific type. 50 * 51 * The dynamic portion of the hook, $meta_type, refers to the meta 52 * object type (comment, post, or user). Returning a non-null value 53 * will effectively short-circuit the function. 54 * 55 * @since 3.1.0 56 * 57 * @param null|bool $check Whether to allow adding metadata for the given type. 58 * @param int $object_id Object ID. 59 * @param string $meta_key Meta key. 60 * @param mixed $meta_value Meta value. Must be serializable if non-scalar. 61 * @param bool $unique Whether the specified meta key should be unique 62 * for the object. Optional. Default false. 63 */ 50 64 $check = apply_filters( "add_{$meta_type}_metadata", null, $object_id, $meta_key, $meta_value, $unique ); 51 65 if ( null !== $check ) … … 60 74 $meta_value = maybe_serialize( $meta_value ); 61 75 76 /** 77 * Fires immediately before meta of a specific type is added. 78 * 79 * The dynamic portion of the hook, $meta_type, refers to the meta 80 * object type (comment, post, or user). 81 * 82 * @since 3.1.0 83 * 84 * @param int $object_id Object ID. 85 * @param string $meta_key Meta key. 86 * @param mixed $meta_value Meta value. 87 */ 62 88 do_action( "add_{$meta_type}_meta", $object_id, $meta_key, $_meta_value ); 63 89 … … 75 101 wp_cache_delete($object_id, $meta_type . '_meta'); 76 102 103 /** 104 * Fires immediately after meta of a specific type is added. 105 * 106 * The dynamic portion of the hook, $meta_type, refers to the meta 107 * object type (comment, post, or user). 108 * 109 * @since 2.9.0 110 * 111 * @param int $mid The meta ID after successful update. 112 * @param int $object_id Object ID. 113 * @param string $meta_key Meta key. 114 * @param mixed $meta_value Meta value. 115 */ 77 116 do_action( "added_{$meta_type}_meta", $mid, $object_id, $meta_key, $_meta_value ); 78 117 … … 86 125 * @since 2.9.0 87 126 * @uses $wpdb WordPress database object for queries. 88 * @uses do_action() Calls 'update_{$meta_type}_meta' before updating metadata with meta_id of89 * metadata entry to update, object ID, meta key, and meta value90 * @uses do_action() Calls 'updated_{$meta_type}_meta' after updating metadata with meta_id of91 * updated metadata entry, object ID, meta key, and meta value92 127 * 93 128 * @param string $meta_type Type of object metadata is for (e.g., comment, post, or user) … … 120 155 $meta_value = sanitize_meta( $meta_key, $meta_value, $meta_type ); 121 156 157 /** 158 * Filter whether to update metadata of a specific type. 159 * 160 * The dynamic portion of the hook, $meta_type, refers to the meta 161 * object type (comment, post, or user). Returning a non-null value 162 * will effectively short-circuit the function. 163 * 164 * @since 3.1.0 165 * 166 * @param null|bool $check Whether to allow updating metadata for the given type. 167 * @param int $object_id Object ID. 168 * @param string $meta_key Meta key. 169 * @param mixed $meta_value Meta value. Must be serializable if non-scalar. 170 * @param mixed $prev_value Optional. If specified, only update existing 171 * metadata entries with the specified value. 172 * Otherwise, update all entries. 173 */ 122 174 $check = apply_filters( "update_{$meta_type}_metadata", null, $object_id, $meta_key, $meta_value, $prev_value ); 123 175 if ( null !== $check ) … … 147 199 } 148 200 201 /** 202 * Fires immediately before updating metadata of a specific type. 203 * 204 * The dynamic portion of the hook, $meta_type, refers to the meta 205 * object type (comment, post, or user). 206 * 207 * @since 2.9.0 208 * 209 * @param int $meta_id ID of the metadata entry to update. 210 * @param int $object_id Object ID. 211 * @param string $meta_key Meta key. 212 * @param mixed $meta_value Meta value. 213 */ 149 214 do_action( "update_{$meta_type}_meta", $meta_id, $object_id, $meta_key, $_meta_value ); 150 215 151 216 if ( 'post' == $meta_type ) 217 /** 218 * Fires immediately before updating a post's metadata. 219 * 220 * @since 2.9.0 221 * 222 * @param int $meta_id ID of metadata entry to update. 223 * @param int $object_id Object ID. 224 * @param string $meta_key Meta key. 225 * @param mixed $meta_value Meta value. 226 */ 152 227 do_action( 'update_postmeta', $meta_id, $object_id, $meta_key, $meta_value ); 153 228 … … 158 233 wp_cache_delete($object_id, $meta_type . '_meta'); 159 234 235 /** 236 * Fires immediately after updating metadata of a specific type. 237 * 238 * The dynamic portion of the hook, $meta_type, refers to the meta 239 * object type (comment, post, or user). 240 * 241 * @since 2.9.0 242 * 243 * @param int $meta_id ID of updated metadata entry. 244 * @param int $object_id Object ID. 245 * @param string $meta_key Meta key. 246 * @param mixed $meta_value Meta value. 247 */ 160 248 do_action( "updated_{$meta_type}_meta", $meta_id, $object_id, $meta_key, $_meta_value ); 161 249 162 if ( 'post' == $meta_type ) 250 if ( 'post' == $meta_type ) { 251 /** 252 * Fires immediately after updating a post's metadata. 253 * 254 * @since 2.9.0 255 * 256 * @param int $meta_id ID of updated metadata entry. 257 * @param int $object_id Object ID. 258 * @param string $meta_key Meta key. 259 * @param mixed $meta_value Meta value. 260 */ 163 261 do_action( 'updated_postmeta', $meta_id, $object_id, $meta_key, $meta_value ); 262 } 164 263 165 264 return true; … … 171 270 * @since 2.9.0 172 271 * @uses $wpdb WordPress database object for queries. 173 * @uses do_action() Calls 'deleted_{$meta_type}_meta' after deleting with meta_id of174 * deleted metadata entries, object ID, meta key, and meta value175 272 * 176 273 * @param string $meta_type Type of object metadata is for (e.g., comment, post, or user) … … 202 299 $meta_value = wp_unslash($meta_value); 203 300 301 /** 302 * Filter whether to delete metadata of a specific type. 303 * 304 * The dynamic portion of the hook, $meta_type, refers to the meta 305 * object type (comment, post, or user). Returning a non-null value 306 * will effectively short-circuit the function. 307 * 308 * @since 3.1.0 309 * 310 * @param null|bool $delete Whether to allow metadata deletion of the given type. 311 * @param int $object_id Object ID. 312 * @param string $meta_key Meta key. 313 * @param mixed $meta_value Meta value. Must be serializable if non-scalar. 314 * @param bool $delete_all Whether to delete the matching metadata entries 315 * for all objects, ignoring the specified $object_id. 316 * Default false. 317 */ 204 318 $check = apply_filters( "delete_{$meta_type}_metadata", null, $object_id, $meta_key, $meta_value, $delete_all ); 205 319 if ( null !== $check ) … … 224 338 $object_ids = $wpdb->get_col( $wpdb->prepare( "SELECT $type_column FROM $table WHERE meta_key = %s", $meta_key ) ); 225 339 340 /** 341 * Fires immediately before deleting metadata of a specific type. 342 * 343 * The dynamic portion of the hook, $meta_type, refers to the meta 344 * object type (comment, post, or user). 345 * 346 * @since 3.1.0 347 * 348 * @param array $meta_ids An array of metadata entry IDs to delete. 349 * @param int $object_id Object ID. 350 * @param string $meta_key Meta key. 351 * @param mixed $meta_value Meta value. 352 */ 226 353 do_action( "delete_{$meta_type}_meta", $meta_ids, $object_id, $meta_key, $_meta_value ); 227 354 228 355 // Old-style action. 229 if ( 'post' == $meta_type ) 356 if ( 'post' == $meta_type ) { 357 /** 358 * Fires immediately before deleting metadata for a post. 359 * 360 * @since 2.9.0 361 * 362 * @param array $meta_ids An array of post metadata entry IDs to delete. 363 */ 230 364 do_action( 'delete_postmeta', $meta_ids ); 365 } 231 366 232 367 $query = "DELETE FROM $table WHERE $id_column IN( " . implode( ',', $meta_ids ) . " )"; … … 245 380 } 246 381 382 /** 383 * Fires immediatley after deleting metadata of a specific type. 384 * 385 * The dynamic portion of the hook, $meta_type, refers to the meta 386 * object type (comment, post, or user). 387 * 388 * @since 2.9.0 389 * 390 * @param array $meta_ids An array of deleted metadata entry IDs. 391 * @param int $object_id Object ID. 392 * @param string $meta_key Meta key. 393 * @param mixed $meta_value Meta value. 394 */ 247 395 do_action( "deleted_{$meta_type}_meta", $meta_ids, $object_id, $meta_key, $_meta_value ); 248 396 249 397 // Old-style action. 250 if ( 'post' == $meta_type ) 398 if ( 'post' == $meta_type ) { 399 /** 400 * Fires immediately after deleting metadata for a post. 401 * 402 * @since 2.9.0 403 * 404 * @param array $meta_ids An array of deleted post metadata entry IDs. 405 */ 251 406 do_action( 'deleted_postmeta', $meta_ids ); 407 } 252 408 253 409 return true; … … 274 430 return false; 275 431 432 /** 433 * Filter whether to retrieve metadata of a specific type. 434 * 435 * The dynamic portion of the hook, $meta_type, refers to the meta 436 * object type (comment, post, or user). Returning a non-null value 437 * will effectively short-circuit the function. 438 * 439 * @since 3.1.0 440 * 441 * @param null|array|string $value The value get_metadata() should 442 * return - a single metadata value, 443 * or an array of values. 444 * @param int $object_id Object ID. 445 * @param string $meta_key Meta key. 446 * @param string|array $single Meta value, or an array of values. 447 */ 276 448 $check = apply_filters( "get_{$meta_type}_metadata", null, $object_id, $meta_key, $single ); 277 449 if ( null !== $check ) { … … 322 494 return false; 323 495 496 /** This filter is documented in wp-includes/meta.php */ 324 497 $check = apply_filters( "get_{$meta_type}_metadata", null, $object_id, $meta_key, true ); 325 498 if ( null !== $check ) … … 432 605 $where[$id_column] = $meta_id; 433 606 607 /** This action is documented in wp-includes/meta.php */ 434 608 do_action( "update_{$meta_type}_meta", $meta_id, $object_id, $meta_key, $_meta_value ); 435 609 436 if ( 'post' == $meta_type ) 610 if ( 'post' == $meta_type ) { 611 /** This action is documented in wp-includes/meta.php */ 437 612 do_action( 'update_postmeta', $meta_id, $object_id, $meta_key, $meta_value ); 613 } 438 614 439 615 // Run the update query, all fields in $data are %s, $where is a %d. … … 445 621 wp_cache_delete($object_id, $meta_type . '_meta'); 446 622 623 /** This action is documented in wp-includes/meta.php */ 447 624 do_action( "updated_{$meta_type}_meta", $meta_id, $object_id, $meta_key, $_meta_value ); 448 625 449 if ( 'post' == $meta_type ) 626 if ( 'post' == $meta_type ) { 627 /** This action is documented in wp-includes/meta.php */ 450 628 do_action( 'updated_postmeta', $meta_id, $object_id, $meta_key, $meta_value ); 629 } 451 630 452 631 return true; … … 490 669 $object_id = $meta->{$column}; 491 670 671 /** This action is documented in wp-includes/meta.php */ 492 672 do_action( "delete_{$meta_type}_meta", (array) $meta_id, $object_id, $meta->meta_key, $meta->meta_value ); 493 673 494 674 // Old-style action. 495 if ( 'post' == $meta_type || 'comment' == $meta_type ) 675 if ( 'post' == $meta_type || 'comment' == $meta_type ) { 676 /** 677 * Fires immediately before deleting post or comment metadata of a specific type. 678 * 679 * The dynamic portion of the hook, $meta_type, refers to the meta 680 * object type (post or comment). 681 * 682 * @since 3.4.0 683 * 684 * @param int $meta_id ID of the metadata entry to delete. 685 */ 496 686 do_action( "delete_{$meta_type}meta", $meta_id ); 687 } 497 688 498 689 // Run the query, will return true if deleted, false otherwise … … 502 693 wp_cache_delete($object_id, $meta_type . '_meta'); 503 694 695 /** This action is documented in wp-includes/meta.php */ 504 696 do_action( "deleted_{$meta_type}_meta", (array) $meta_id, $object_id, $meta->meta_key, $meta->meta_value ); 505 697 506 698 // Old-style action. 507 if ( 'post' == $meta_type || 'comment' == $meta_type ) 699 if ( 'post' == $meta_type || 'comment' == $meta_type ) { 700 /** 701 * Fires immediately after deleting post or comment metadata of a specific type. 702 * 703 * The dynamic portion of the hook, $meta_type, refers to the meta 704 * object type (post or comment). 705 * 706 * @since 3.4.0 707 * 708 * @param int $meta_ids Deleted metadata entry ID. 709 */ 508 710 do_action( "deleted_{$meta_type}meta", $meta_id ); 711 } 509 712 510 713 return $result; … … 863 1066 $join = ' ' . $join; 864 1067 1068 /** 1069 * Filter the meta query's generated SQL. 1070 * 1071 * @since 3.1.0 1072 * 1073 * @param array $args { 1074 * An array of arguments. 1075 * 1076 * @type array $clauses Array containing the query's JOIN and WHERE clauses. 1077 * @type array $queries Array of meta queries. 1078 * @type string $type Type of meta. 1079 * @type string $primary_table Primary table. 1080 * @type string $primary_id_column Primary column ID. 1081 * @type object $context The main query object. 1082 * } 1083 */ 865 1084 return apply_filters_ref_array( 'get_meta_sql', array( compact( 'join', 'where' ), $this->queries, $type, $primary_table, $primary_id_column, $context ) ); 866 1085 } … … 888 1107 889 1108 /** 890 * Determine whether a meta key is protected 1109 * Determine whether a meta key is protected. 891 1110 * 892 1111 * @since 3.1.3 … … 898 1117 $protected = ( '_' == $meta_key[0] ); 899 1118 1119 /** 1120 * Filter whether a meta key is protected. 1121 * 1122 * @since 3.2.0 1123 * 1124 * @param bool $protected Whether the key is protected. Default false. 1125 * @param string $meta_key Meta key. 1126 * @param string $meta_type Meta type. 1127 */ 900 1128 return apply_filters( 'is_protected_meta', $protected, $meta_key, $meta_type ); 901 1129 } 902 1130 903 1131 /** 904 * Sanitize meta value 1132 * Sanitize meta value. 905 1133 * 906 1134 * @since 3.1.3 … … 912 1140 */ 913 1141 function sanitize_meta( $meta_key, $meta_value, $meta_type ) { 1142 1143 /** 1144 * Filter the sanitization of a specific meta key of a specific meta type. 1145 * 1146 * The dynamic portions of the hook name, $meta_type and $meta_key, refer to the 1147 * metadata object type (comment, post, or user) and the meta key value, 1148 * respectively. 1149 * 1150 * @since 3.3.0 1151 * 1152 * @param mixed $meta_value Meta value to sanitize. 1153 * @param string $meta_key Meta key. 1154 * @param string $meta_type Meta type. 1155 */ 914 1156 return apply_filters( "sanitize_{$meta_type}_meta_{$meta_key}", $meta_value, $meta_key, $meta_type ); 915 1157 }
Note: See TracChangeset
for help on using the changeset viewer.