2007-05-22 07:12:38 +02:00
< ? php
2007-05-28 02:51:24 +02:00
$wp_taxonomies = array ();
$wp_taxonomies [ 'category' ] = ( object ) array ( 'name' => 'category' , 'object_type' => 'post' , 'hierarchical' => true , 'update_count_callback' => '_update_post_term_count' );
$wp_taxonomies [ 'post_tag' ] = ( object ) array ( 'name' => 'post_tag' , 'object_type' => 'post' , 'hierarchical' => false , 'update_count_callback' => '_update_post_term_count' );
$wp_taxonomies [ 'link_category' ] = ( object ) array ( 'name' => 'link_category' , 'object_type' => 'link' , 'hierarchical' => false );
2007-05-23 12:32:33 +02:00
function is_taxonomy ( $taxonomy ) {
global $wp_taxonomies ;
return isset ( $wp_taxonomies [ $taxonomy ]);
}
function get_taxonomy ( $taxonomy ) {
global $wp_taxonomies ;
if ( ! is_taxonomy ( $taxonomy ) )
return false ;
return $wp_taxonomies [ $taxonomy ];
}
2007-05-24 00:03:24 +02:00
function is_taxonomy_hierarchical ( $taxonomy ) {
if ( ! is_taxonomy ( $taxonomy ) )
return false ;
$taxonomy = get_taxonomy ( $taxonomy );
2007-05-28 02:51:24 +02:00
return $taxonomy -> hierarchical ;
2007-05-24 00:03:24 +02:00
}
2007-05-23 12:32:33 +02:00
function register_taxonomy ( $taxonomy , $object_type , $args = array () ) {
global $wp_taxonomies ;
2007-05-28 02:51:24 +02:00
$defaults = array ( 'hierarchical' => false , 'update_count_callback' => '' );
$args = wp_parse_args ( $args , $defaults );
$args [ 'name' ] = $taxonomy ;
2007-05-23 12:32:33 +02:00
$args [ 'object_type' ] = $object_type ;
2007-05-28 02:51:24 +02:00
$wp_taxonomies [ $taxonomy ] = ( object ) $args ;
2007-05-23 12:32:33 +02:00
}
2007-05-30 03:05:44 +02:00
function wp_count_terms ( $taxonomy , $args = array () ) {
2007-05-27 21:32:45 +02:00
global $wpdb ;
2007-05-30 03:05:44 +02:00
$defaults = array ( 'ignore_empty' => false );
$args = wp_parse_args ( $args , $defaults );
extract ( $args );
$where = '' ;
if ( $ignore_empty )
$where = 'AND count > 0' ;
return $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->term_taxonomy WHERE taxonomy = ' $taxonomy ' $where " );
2007-05-27 21:32:45 +02:00
}
2007-05-22 07:12:38 +02:00
/**
* Adds a new term to the database . Optionally marks it as an alias of an existing term .
2007-05-23 07:42:31 +02:00
* @ param int | string $term The term to add or update .
2007-05-22 07:12:38 +02:00
* @ param string $taxonomy The taxonomy to which to add the term
* @ param int | string $alias_of The id or slug of the new term ' s alias .
*/
2007-05-23 07:42:31 +02:00
function wp_insert_term ( $term , $taxonomy , $args = array () ) {
2007-05-22 07:12:38 +02:00
global $wpdb ;
2007-05-23 12:32:33 +02:00
if ( ! is_taxonomy ( $taxonomy ) )
return new WP_Error ( 'invalid_taxonomy' , __ ( 'Invalid taxonomy' ));
2007-05-23 07:42:31 +02:00
$defaults = array ( 'alias_of' => '' , 'description' => '' , 'parent' => 0 , 'slug' => '' );
2007-05-22 07:12:38 +02:00
$args = wp_parse_args ( $args , $defaults );
2007-06-05 02:57:23 +02:00
$args [ 'name' ] = $term ;
$args = sanitize_term ( $args , $taxonomy , 'db' );
2007-05-22 07:12:38 +02:00
extract ( $args );
2007-05-23 07:42:31 +02:00
if ( empty ( $slug ) )
$slug = sanitize_title ( $name );
else
$slug = sanitize_title ( $slug );
2007-05-22 07:12:38 +02:00
$term_group = 0 ;
if ( $alias_of ) {
$alias = $wpdb -> fetch_row ( " SELECT term_id, term_group FROM $wpdb->terms WHERE slug = ' $alias_of ' " );
if ( $alias -> term_group ) {
// The alias we want is already in a group, so let's use that one.
$term_group = $alias -> term_group ;
} else {
// The alias isn't in a group, so let's create a new one and firstly add the alias term to it.
2007-05-26 19:47:20 +02:00
$term_group = $wpdb -> get_var ( " SELECT MAX(term_group) FROM $wpdb->terms GROUP BY term_group " ) + 1 ;
2007-05-22 07:12:38 +02:00
$wpdb -> query ( " UPDATE $wpdb->terms SET term_group = $term_group WHERE term_id = $alias->term_id " );
}
}
2007-05-23 19:28:13 +02:00
if ( ! $term_id = is_term ( $slug ) ) {
2007-05-23 07:42:31 +02:00
$wpdb -> query ( " INSERT INTO $wpdb->terms (name, slug, term_group) VALUES (' $name ', ' $slug ', ' $term_group ') " );
2007-05-22 07:12:38 +02:00
$term_id = ( int ) $wpdb -> insert_id ;
}
2007-05-23 07:42:31 +02:00
if ( empty ( $slug ) ) {
$slug = sanitize_title ( $slug , $term_id );
$wpdb -> query ( " UPDATE $wpdb->terms SET slug = ' $slug ' WHERE term_id = ' $term_id ' " );
}
2007-06-14 04:25:30 +02:00
2007-05-22 07:12:38 +02:00
$tt_id = $wpdb -> get_var ( " SELECT tt.term_taxonomy_id FROM $wpdb->term_taxonomy AS tt INNER JOIN $wpdb->terms AS t ON tt.term_id = t.term_id WHERE tt.taxonomy = ' $taxonomy ' AND t.term_id = $term_id " );
2007-05-23 19:28:13 +02:00
if ( ! empty ( $tt_id ) )
2007-05-23 07:42:31 +02:00
return array ( 'term_id' => $term_id , 'term_taxonomy_id' => $tt_id );
2007-05-23 19:28:13 +02:00
$wpdb -> query ( " INSERT INTO $wpdb->term_taxonomy (term_id, taxonomy, description, parent, count) VALUES (' $term_id ', ' $taxonomy ', ' $description ', ' $parent ', '0') " );
$tt_id = ( int ) $wpdb -> insert_id ;
2007-05-23 07:42:31 +02:00
2007-05-23 19:28:13 +02:00
do_action ( " create_term " , $term_id , $tt_id );
do_action ( " create_ $taxonomy " , $term_id , $tt_id );
2007-05-23 09:26:52 +02:00
2007-05-23 19:28:13 +02:00
$term_id = apply_filters ( 'term_id_filter' , $term_id , $tt_id );
2007-05-23 09:26:52 +02:00
2007-05-27 01:32:06 +02:00
clean_term_cache ( $term_id , $taxonomy );
2007-05-23 09:26:52 +02:00
2007-05-23 19:28:13 +02:00
do_action ( " created_term " , $term_id , $tt_id );
do_action ( " created_ $taxonomy " , $term_id , $tt_id );
2007-05-23 09:26:52 +02:00
2007-05-22 22:39:26 +02:00
return array ( 'term_id' => $term_id , 'term_taxonomy_id' => $tt_id );
2007-05-22 07:12:38 +02:00
}
2007-05-27 07:15:18 +02:00
function wp_delete_object_term_relationships ( $object_id , $taxonomies ) {
global $wpdb ;
$object_id = ( int ) $object_id ;
if ( ! is_array ( $taxonomies ) )
$taxonomies = array ( $taxonomies );
2007-05-27 08:17:50 +02:00
foreach ( $taxonomies as $taxonomy ) {
$terms = get_object_terms ( $object_id , $taxonomy , 'fields=tt_ids' );
$in_terms = " ' " . implode ( " ', ' " , $terms ) . " ' " ;
$wpdb -> query ( " DELETE FROM $wpdb->term_relationships WHERE object_id = ' $object_id ' AND term_taxonomy_id IN ( $in_terms ) " );
2007-05-27 07:15:18 +02:00
2007-05-27 08:17:50 +02:00
wp_update_term_count ( $terms , $taxonomy );
}
2007-06-14 04:25:30 +02:00
2007-05-27 07:15:18 +02:00
// TODO clear the cache
}
2007-05-22 07:12:38 +02:00
/**
* Removes a term from the database .
*/
2007-05-24 00:03:24 +02:00
function wp_delete_term ( $term , $taxonomy , $args = array () ) {
global $wpdb ;
$term = ( int ) $term ;
if ( ! $ids = is_term ( $term , $taxonomy ) )
return false ;
$tt_id = $ids [ 'term_taxonomy_id' ];
$defaults = array ();
$args = wp_parse_args ( $args , $defaults );
extract ( $args );
if ( isset ( $default ) ) {
$default = ( int ) $default ;
if ( ! is_term ( $default , $taxonomy ) )
unset ( $default );
}
// Update children to point to new parent
if ( is_taxonomy_hierarchical ( $taxonomy ) ) {
$term_obj = get_term ( $term , $taxonomy );
$parent = $term_obj -> parent ;
$wpdb -> query ( " UPDATE $wpdb->term_taxonomy SET parent = ' $parent ' WHERE parent = ' $term_obj->term_id ' AND taxonomy = ' $taxonomy ' " );
}
$objects = $wpdb -> get_col ( " SELECT object_id FROM $wpdb->term_relationships WHERE term_taxonomy_id = ' $tt_id ' " );
foreach ( ( array ) $objects as $object ) {
2007-05-26 20:54:16 +02:00
$terms = get_object_terms ( $object , $taxonomy , 'fields=ids' );
2007-05-24 00:03:24 +02:00
if ( 1 == count ( $terms ) && isset ( $default ) )
$terms = array ( $default );
else
$terms = array_diff ( $terms , array ( $term ));
wp_set_object_terms ( $object , $terms , $taxonomy );
}
$wpdb -> query ( " DELETE FROM $wpdb->term_taxonomy WHERE term_taxonomy_id = ' $tt_id ' " );
2007-05-27 08:29:52 +02:00
// Delete the term if no taxonomies use it.
if ( ! $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->term_taxonomy WHERE term_id = ' $term ' " ) )
$wpdb -> query ( " DELETE FROM $wpdb->terms WHERE term_id = ' $term ' " );
2007-05-27 01:32:06 +02:00
clean_term_cache ( $term , $taxonomy );
2007-05-24 00:03:24 +02:00
do_action ( " delete_ $taxonomy " , $term , $tt_id );
return true ;
}
2007-05-23 07:42:31 +02:00
2007-05-23 19:28:13 +02:00
function wp_update_term ( $term , $taxonomy , $args = array () ) {
global $wpdb ;
if ( ! is_taxonomy ( $taxonomy ) )
return new WP_Error ( 'invalid_taxonomy' , __ ( 'Invalid taxonomy' ));
2007-05-23 07:42:31 +02:00
2007-05-23 19:28:13 +02:00
$term_id = ( int ) $term ;
// First, get all of the original args
$term = get_term ( $term_id , $taxonomy , ARRAY_A );
2007-05-23 07:42:31 +02:00
2007-06-05 02:57:23 +02:00
$term = sanitize_term ( $term , $taxonomy , 'db' );
2007-05-23 07:42:31 +02:00
// Escape data pulled from DB.
$term = add_magic_quotes ( $term );
2007-05-23 19:28:13 +02:00
// Merge old and new args with new args overwriting old ones.
$args = array_merge ( $term , $args );
$defaults = array ( 'alias_of' => '' , 'description' => '' , 'parent' => 0 , 'slug' => '' );
$args = wp_parse_args ( $args , $defaults );
extract ( $args );
if ( empty ( $slug ) )
$slug = sanitize_title ( $name );
else
$slug = sanitize_title ( $slug );
if ( $alias_of ) {
$alias = $wpdb -> fetch_row ( " SELECT term_id, term_group FROM $wpdb->terms WHERE slug = ' $alias_of ' " );
if ( $alias -> term_group ) {
// The alias we want is already in a group, so let's use that one.
$term_group = $alias -> term_group ;
} else {
// The alias isn't in a group, so let's create a new one and firstly add the alias term to it.
2007-06-05 02:57:23 +02:00
$term_group = $wpdb -> get_var ( " SELECT MAX(term_group) FROM $wpdb->terms GROUP BY term_group " ) + 1 ;
2007-05-23 19:28:13 +02:00
$wpdb -> query ( " UPDATE $wpdb->terms SET term_group = $term_group WHERE term_id = $alias->term_id " );
}
}
$wpdb -> query ( " UPDATE $wpdb->terms SET name = ' $name ', slug = ' $slug ', term_group = ' $term_group ' WHERE term_id = ' $term_id ' " );
2007-05-23 07:42:31 +02:00
2007-05-23 19:28:13 +02:00
if ( empty ( $slug ) ) {
2007-06-06 18:10:52 +02:00
$slug = sanitize_title ( $name , $term_id );
2007-05-23 19:28:13 +02:00
$wpdb -> query ( " UPDATE $wpdb->terms SET slug = ' $slug ' WHERE term_id = ' $term_id ' " );
}
2007-06-14 04:25:30 +02:00
2007-05-23 19:28:13 +02:00
$tt_id = $wpdb -> get_var ( " SELECT tt.term_taxonomy_id FROM $wpdb->term_taxonomy AS tt INNER JOIN $wpdb->terms AS t ON tt.term_id = t.term_id WHERE tt.taxonomy = ' $taxonomy ' AND t.term_id = $term_id " );
2007-06-05 02:57:23 +02:00
$wpdb -> query ( " UPDATE $wpdb->term_taxonomy SET term_id = ' $term_id ', taxonomy = ' $taxonomy ', description = ' $description ', parent = ' $parent ' WHERE term_taxonomy_id = ' $tt_id ' " );
2007-05-23 19:28:13 +02:00
do_action ( " edit_term " , $term_id , $tt_id );
do_action ( " edit_ $taxonomy " , $term_id , $tt_id );
$term_id = apply_filters ( 'term_id_filter' , $term_id , $tt_id );
2007-05-27 01:32:06 +02:00
clean_term_cache ( $term_id , $taxonomy );
2007-05-23 19:28:13 +02:00
do_action ( " edited_term " , $term_id , $tt_id );
do_action ( " edited_ $taxonomy " , $term_id , $tt_id );
return array ( 'term_id' => $term_id , 'term_taxonomy_id' => $tt_id );
2007-05-23 07:42:31 +02:00
}
2007-05-27 08:17:50 +02:00
function wp_update_term_count ( $terms , $taxonomy ) {
2007-05-27 19:21:04 +02:00
global $wpdb ;
2007-05-27 07:15:18 +02:00
if ( empty ( $terms ) )
return false ;
if ( ! is_array ( $terms ) )
$terms = array ( $terms );
$terms = array_map ( 'intval' , $terms );
2007-05-27 08:17:50 +02:00
$taxonomy = get_taxonomy ( $taxonomy );
2007-05-28 02:51:24 +02:00
if ( isset ( $taxonomy -> update_count_callback ) )
return call_user_func ( $taxonomy -> update_count_callback , $terms );
2007-05-27 08:17:50 +02:00
// Default count updater
$count = $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->term_relationships WHERE term_taxonomy_id = ' $term ' " );
$wpdb -> query ( " UPDATE $wpdb->term_taxonomy SET count = ' $count ' WHERE term_taxonomy_id = ' $term ' " );
2007-05-27 07:15:18 +02:00
return true ;
}
2007-05-22 07:12:38 +02:00
/**
* Returns the index of a defined term , or 0 ( false ) if the term doesn ' t exist .
*/
function is_term ( $term , $taxonomy = '' ) {
global $wpdb ;
2007-05-22 22:39:26 +02:00
if ( is_int ( $term ) ) {
$where = " t.term_id = ' $term ' " ;
} else {
if ( ! $term = sanitize_title ( $term ) )
return 0 ;
$where = " t.slug = ' $term ' " ;
}
$term_id = $wpdb -> get_var ( " SELECT term_id FROM $wpdb->terms as t WHERE $where " );
if ( empty ( $taxonomy ) || empty ( $term_id ) )
return $term_id ;
return $wpdb -> get_row ( " SELECT tt.term_id, tt.term_taxonomy_id FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy as tt ON tt.term_id = t.term_id WHERE $where AND tt.taxonomy = ' $taxonomy ' " , ARRAY_A );
2007-05-22 07:12:38 +02:00
}
2007-06-14 04:25:30 +02:00
2007-05-22 07:12:38 +02:00
/**
* Given an array of terms , returns those that are defined term slugs . Ignores integers .
* @ param array $terms The term slugs to check for a definition .
*/
function get_defined_terms ( $terms ) {
global $wpdb ;
foreach ( $terms as $term ) {
if ( ! is_int ( $term ) )
$searches [] = $term ;
}
$terms = " ' " . implode ( " ', ' " , $searches ) . " ' " ;
return $wpdb -> get_col ( " SELECT slug FROM $wpdb->terms WHERE slug IN ( $terms ) " );
}
2007-06-14 04:25:30 +02:00
2007-05-22 07:12:38 +02:00
/**
* Relates an object ( post , link etc ) to a term and taxonomy type . Creates the term and taxonomy
* relationship if it doesn 't already exist. Creates a term if it doesn' t exist ( using the slug ) .
* @ param int $object_id The object to relate to .
2007-05-22 22:39:26 +02:00
* @ param array | int | string $term The slug or id of the term .
2007-05-27 07:15:18 +02:00
* @ param array | string $taxonomy The context in which to relate the term to the object .
2007-05-22 07:12:38 +02:00
*/
2007-05-27 07:15:18 +02:00
function wp_set_object_terms ( $object_id , $terms , $taxonomy , $append = false ) {
2007-05-22 07:12:38 +02:00
global $wpdb ;
2007-05-22 22:39:26 +02:00
$object_id = ( int ) $object_id ;
2007-05-27 07:15:18 +02:00
if ( ! is_taxonomy ( $taxonomy ) )
return false ;
2007-06-14 04:25:30 +02:00
2007-05-22 07:12:38 +02:00
if ( ! is_array ( $terms ) )
$terms = array ( $terms );
2007-05-27 08:17:50 +02:00
if ( ! $append )
$old_terms = get_object_terms ( $object_id , $taxonomy , 'fields=tt_ids' );
2007-05-22 07:12:38 +02:00
2007-05-22 22:39:26 +02:00
$tt_ids = array ();
2007-05-27 07:15:18 +02:00
$term_ids = array ();
foreach ( $terms as $term ) {
if ( ! $id = is_term ( $term , $taxonomy ) )
$id = wp_insert_term ( $term , $taxonomy );
$term_ids [] = $id [ 'term_id' ];
$id = $id [ 'term_taxonomy_id' ];
$tt_ids [] = $id ;
2007-05-28 02:51:24 +02:00
2007-05-27 07:15:18 +02:00
if ( $wpdb -> get_var ( " SELECT term_taxonomy_id FROM $wpdb->term_relationships WHERE object_id = ' $object_id ' AND term_taxonomy_id = ' $id ' " ) )
continue ;
$wpdb -> query ( " INSERT INTO $wpdb->term_relationships (object_id, term_taxonomy_id) VALUES (' $object_id ', ' $id ') " );
2007-05-22 07:12:38 +02:00
}
2007-05-22 22:39:26 +02:00
2007-05-27 08:17:50 +02:00
wp_update_term_count ( $tt_ids , $taxonomy );
2007-05-27 07:15:18 +02:00
2007-05-22 22:39:26 +02:00
if ( ! $append ) {
$delete_terms = array_diff ( $old_terms , $tt_ids );
if ( $delete_terms ) {
$delete_terms = " ' " . implode ( " ', ' " , $delete_terms ) . " ' " ;
$wpdb -> query ( " DELETE FROM $wpdb->term_relationships WHERE term_taxonomy_id IN ( $delete_terms ) " );
2007-05-23 05:57:20 +02:00
$wpdb -> query ( " UPDATE $wpdb->term_taxonomy SET count = count - 1 WHERE term_taxonomy_id IN ( $delete_terms ) " );
2007-05-27 08:17:50 +02:00
wp_update_term_count ( $delete_terms , $taxonomy );
2007-05-22 07:12:38 +02:00
}
}
2007-05-22 22:39:26 +02:00
2007-05-27 08:17:50 +02:00
// TODO clean old_terms. Need term_id instead of tt_id
2007-05-27 07:15:18 +02:00
clean_term_cache ( $term_ids , $taxonomy );
2007-05-22 22:39:26 +02:00
return $tt_ids ;
2007-05-22 07:12:38 +02:00
}
2007-05-22 22:39:26 +02:00
2007-05-29 06:25:09 +02:00
function get_objects_in_term ( $terms , $taxonomies , $args = array () ) {
global $wpdb ;
if ( ! is_array ( $terms ) )
$terms = array ( $terms );
if ( ! is_array ( $taxonomies ) )
$taxonomies = array ( $taxonomies );
$defaults = array ( 'order' => 'ASC' );
$args = wp_parse_args ( $args , $defaults );
extract ( $args );
2007-05-29 18:52:31 +02:00
$terms = array_map ( 'intval' , $terms );
2007-05-29 06:25:09 +02:00
$taxonomies = " ' " . implode ( " ', ' " , $taxonomies ) . " ' " ;
$terms = " ' " . implode ( " ', ' " , $terms ) . " ' " ;
2007-05-31 05:51:03 +02:00
$object_ids = $wpdb -> get_col ( " SELECT tr.object_id FROM $wpdb->term_relationships AS tr INNER JOIN $wpdb->term_taxonomy AS tt ON tr.term_taxonomy_id = tt.term_taxonomy_id WHERE tt.taxonomy IN ( $taxonomies ) AND tt.term_id IN ( $terms ) ORDER BY tr.object_id $order " );
2007-05-29 06:25:09 +02:00
if ( ! $object_ids )
return array ();
return $object_ids ;
}
2007-05-31 23:38:33 +02:00
function get_object_taxonomies ( $object_type ) {
global $wp_taxonomies ;
$taxonomies = array ();
foreach ( $wp_taxonomies as $taxonomy ) {
if ( $object_type == $taxonomy -> object_type )
$taxonomies [] = $taxonomy -> name ;
}
return $taxonomies ;
}
2007-05-22 07:12:38 +02:00
/**
* Returns the terms associated with the given object ( s ), in the supplied taxonomies .
* @ param int | array $object_id The id of the object ( s )) to retrieve for .
* @ param string | array $taxonomies The taxonomies to retrieve terms from .
* @ return array The requested term data .
*/
2007-05-27 07:15:18 +02:00
function get_object_terms ( $object_ids , $taxonomies , $args = array ()) {
2007-05-22 07:12:38 +02:00
global $wpdb ;
2007-05-31 23:38:33 +02:00
2007-05-27 07:15:18 +02:00
if ( ! is_array ( $taxonomies ) )
$taxonomies = array ( $taxonomies );
if ( ! is_array ( $object_ids ) )
$object_ids = array ( $object_ids );
$object_ids = array_map ( 'intval' , $object_ids );
2007-05-22 07:12:38 +02:00
2007-05-26 20:54:16 +02:00
$defaults = array ( 'orderby' => 'name' , 'order' => 'ASC' , 'fields' => 'all' );
2007-05-23 09:15:10 +02:00
$args = wp_parse_args ( $args , $defaults );
extract ( $args );
if ( 'count' == $orderby )
$orderby = 'tt.count' ;
else if ( 'name' == $orderby )
$orderby = 't.name' ;
2007-05-22 22:39:26 +02:00
$taxonomies = " ' " . implode ( " ', ' " , $taxonomies ) . " ' " ;
2007-05-23 05:57:20 +02:00
$object_ids = implode ( ', ' , $object_ids );
2007-05-22 07:12:38 +02:00
2007-05-26 20:54:16 +02:00
if ( 'all' == $fields )
2007-05-30 05:36:59 +02:00
$select_this = 't.*, tt.*' ;
2007-05-26 20:54:16 +02:00
else if ( 'ids' == $fields )
2007-05-23 09:15:10 +02:00
$select_this = 't.term_id' ;
2007-05-30 05:36:59 +02:00
else if ( 'all_with_object_id' == $fields )
$select_this = 't.*, tt.*, tr.object_id' ;
2007-05-23 09:15:10 +02:00
$query = " SELECT $select_this FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON tt.term_id = t.term_id INNER JOIN $wpdb->term_relationships AS tr ON tr.term_taxonomy_id = tt.term_taxonomy_id WHERE tt.taxonomy IN ( $taxonomies ) AND tr.object_id IN ( $object_ids ) ORDER BY $orderby $order " ;
2007-05-30 05:36:59 +02:00
if ( 'all' == $fields || 'all_with_object_id' == $fields ) {
$terms = $wpdb -> get_results ( $query );
update_term_cache ( $terms );
} else if ( 'ids' == $fields ) {
$terms = $wpdb -> get_col ( $query );
} else if ( 'tt_ids' == $fields ) {
$terms = $wpdb -> get_col ( " SELECT tr.term_taxonomy_id FROM $wpdb->term_relationships AS tr INNER JOIN $wpdb->term_taxonomy AS tt ON tr.term_taxonomy_id = tt.term_taxonomy_id WHERE tr.object_id IN ( $object_ids ) AND tt.taxonomy IN ( $taxonomies ) ORDER BY tr.term_taxonomy_id $order " );
}
2007-05-23 09:15:10 +02:00
2007-05-30 05:36:59 +02:00
if ( ! $terms )
2007-05-23 09:15:10 +02:00
return array ();
2007-05-30 05:36:59 +02:00
return $terms ;
2007-05-23 05:57:20 +02:00
}
function & get_terms ( $taxonomies , $args = '' ) {
global $wpdb ;
2007-05-23 12:32:33 +02:00
$single_taxonomy = false ;
if ( ! is_array ( $taxonomies ) ) {
$single_taxonomy = true ;
2007-05-23 05:57:20 +02:00
$taxonomies = array ( $taxonomies );
2007-05-23 12:32:33 +02:00
}
2007-05-23 05:57:20 +02:00
$in_taxonomies = " ' " . implode ( " ', ' " , $taxonomies ) . " ' " ;
$defaults = array ( 'orderby' => 'name' , 'order' => 'ASC' ,
'hide_empty' => true , 'exclude' => '' , 'include' => '' ,
2007-05-26 20:54:16 +02:00
'number' => '' , 'fields' => 'all' , 'slug' => '' , 'parent' => '' ,
'hierarchical' => true , 'child_of' => 0 , 'get' => '' );
2007-05-23 05:57:20 +02:00
$args = wp_parse_args ( $args , $defaults );
$args [ 'number' ] = ( int ) $args [ 'number' ];
2007-06-01 04:24:07 +02:00
if ( ! $single_taxonomy || ! is_taxonomy_hierarchical ( $taxonomies [ 0 ]) ||
'' != $args [ 'parent' ] ) {
2007-05-26 20:54:16 +02:00
$args [ 'child_of' ] = 0 ;
$args [ 'hierarchical' ] = false ;
}
2007-06-01 04:24:07 +02:00
2007-05-26 20:54:16 +02:00
if ( 'all' == $args [ 'get' ] ) {
$args [ 'child_of' ] = 0 ;
$args [ 'hide_empty' ] = 0 ;
$args [ 'hierarchical' ] = false ;
2007-05-23 12:32:33 +02:00
}
2007-05-23 05:57:20 +02:00
extract ( $args );
2007-05-31 05:44:18 +02:00
if ( $child_of ) {
$hierarchy = _get_term_hierarchy ( $taxonomies [ 0 ]);
if ( ! isset ( $hierarchy [ $child_of ]) )
return array ();
}
2007-06-01 04:24:07 +02:00
if ( $parent ) {
$hierarchy = _get_term_hierarchy ( $taxonomies [ 0 ]);
if ( ! isset ( $hierarchy [ $parent ]) )
return array ();
}
2007-05-23 12:32:33 +02:00
$key = md5 ( serialize ( $args ) . serialize ( $taxonomies ) );
if ( $cache = wp_cache_get ( 'get_terms' , 'terms' ) ) {
if ( isset ( $cache [ $key ] ) )
return apply_filters ( 'get_terms' , $cache [ $key ], $taxonomies , $args );
}
2007-05-23 05:57:20 +02:00
if ( 'count' == $orderby )
$orderby = 'tt.count' ;
else if ( 'name' == $orderby )
$orderby = 't.name' ;
2007-05-23 12:32:33 +02:00
else
$orderby = 't.term_id' ;
2007-05-23 05:57:20 +02:00
$where = '' ;
$inclusions = '' ;
if ( ! empty ( $include ) ) {
$exclude = '' ;
$interms = preg_split ( '/[\s,]+/' , $include );
if ( count ( $interms ) ) {
foreach ( $interms as $interm ) {
if ( empty ( $inclusions ))
$inclusions = ' AND ( t.term_id = ' . intval ( $interm ) . ' ' ;
else
$inclusions .= ' OR t.term_id = ' . intval ( $interm ) . ' ' ;
}
}
}
if ( ! empty ( $inclusions ) )
$inclusions .= ')' ;
$where .= $inclusions ;
$exclusions = '' ;
if ( ! empty ( $exclude ) ) {
$exterms = preg_split ( '/[\s,]+/' , $exclude );
if ( count ( $exterms ) ) {
foreach ( $exterms as $exterm ) {
if ( empty ( $exclusions ))
$exclusions = ' AND ( t.term_id <> ' . intval ( $exterm ) . ' ' ;
else
$exclusions .= ' AND t.term_id <> ' . intval ( $exterm ) . ' ' ;
}
}
}
if ( ! empty ( $exclusions ) )
$exclusions .= ')' ;
$exclusions = apply_filters ( 'list_terms_exclusions' , $exclusions , $args );
$where .= $exclusions ;
2007-05-23 12:32:33 +02:00
if ( ! empty ( $slug ) ) {
$slug = sanitize_title ( $slug );
$where = " AND t.slug = ' $slug ' " ;
}
2007-06-01 04:24:07 +02:00
if ( '' != $parent ) {
2007-05-23 12:32:33 +02:00
$parent = ( int ) $parent ;
$where = " AND tt.parent = ' $parent ' " ;
}
if ( $hide_empty && ! $hierarchical )
2007-05-23 05:57:20 +02:00
$where .= ' AND tt.count > 0' ;
if ( ! empty ( $number ) )
$number = 'LIMIT ' . $number ;
else
$number = '' ;
2007-05-26 20:54:16 +02:00
if ( 'all' == $fields )
2007-05-23 09:15:10 +02:00
$select_this = 't.*, tt.*' ;
2007-05-26 20:54:16 +02:00
else if ( 'ids' == $fields )
2007-05-23 09:15:10 +02:00
$select_this = 't.term_id' ;
$query = " SELECT $select_this FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy IN ( $in_taxonomies ) $where ORDER BY $orderby $order $number " ;
2007-05-30 05:36:59 +02:00
if ( 'all' == $fields ) {
2007-05-23 09:15:10 +02:00
$terms = $wpdb -> get_results ( $query );
2007-05-30 05:36:59 +02:00
update_term_cache ( $terms );
} else if ( 'ids' == $fields ) {
2007-05-23 09:15:10 +02:00
$terms = $wpdb -> get_col ( $query );
2007-05-30 05:36:59 +02:00
}
2007-05-23 05:57:20 +02:00
if ( empty ( $terms ) )
return array ();
2007-05-23 12:32:33 +02:00
if ( $child_of || $hierarchical ) {
$children = _get_term_hierarchy ( $taxonomies [ 0 ]);
if ( ! empty ( $children ) )
2007-05-27 07:15:18 +02:00
$terms = & _get_term_children ( $child_of , $terms , $taxonomies [ 0 ]);
2007-05-23 12:32:33 +02:00
}
/*
// Update category counts to include children.
if ( $pad_counts )
_pad_category_counts ( $type , $categories );
// Make sure we show empty categories that have children.
if ( $hierarchical && $hide_empty ) {
foreach ( $categories as $k => $category ) {
if ( ! $category -> { 'link' == $type ? 'link_count' : 'category_count' } ) {
$children = _get_cat_children ( $category -> cat_ID , $categories );
foreach ( $children as $child )
if ( $child -> { 'link' == $type ? 'link_count' : 'category_count' } )
continue 2 ;
// It really is empty
unset ( $categories [ $k ]);
}
}
}
reset ( $categories );
*/
$cache [ $key ] = $terms ;
2007-05-30 05:36:59 +02:00
wp_cache_set ( 'get_terms' , $cache , 'term' );
2007-05-23 12:32:33 +02:00
2007-05-23 05:57:20 +02:00
$terms = apply_filters ( 'get_terms' , $terms , $taxonomies , $args );
return $terms ;
}
function & get_term ( & $term , $taxonomy , $output = OBJECT ) {
global $wpdb ;
if ( empty ( $term ) )
return null ;
if ( is_object ( $term ) ) {
2007-05-23 12:32:33 +02:00
wp_cache_add ( $term -> term_id , $term , $taxonomy );
2007-05-23 05:57:20 +02:00
$_term = $term ;
} else {
$term = ( int ) $term ;
2007-05-23 12:32:33 +02:00
if ( ! $_term = wp_cache_get ( $term , $taxonomy ) ) {
2007-05-23 05:57:20 +02:00
$_term = $wpdb -> get_row ( " SELECT t.*, tt.* FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy = ' $taxonomy ' AND t.term_id = ' $term ' LIMIT 1 " );
2007-05-23 12:32:33 +02:00
wp_cache_add ( $term , $_term , $taxonomy );
2007-05-23 05:57:20 +02:00
}
}
$_term = apply_filters ( 'get_term' , $_term , $taxonomy );
2007-05-23 12:32:33 +02:00
$_term = apply_filters ( " get_ $taxonomy " , $_term , $taxonomy );
2007-05-23 05:57:20 +02:00
if ( $output == OBJECT ) {
return $_term ;
} elseif ( $output == ARRAY_A ) {
return get_object_vars ( $_term );
} elseif ( $output == ARRAY_N ) {
return array_values ( get_object_vars ( $_term ));
} else {
return $_term ;
}
}
2007-05-22 07:12:38 +02:00
2007-05-23 12:32:33 +02:00
function get_term_by ( $field , $value , $taxonomy , $output = OBJECT ) {
global $wpdb ;
if ( ! is_taxonomy ( $taxonomy ) )
return false ;
if ( 'slug' == $field ) {
$field = 't.slug' ;
$value = sanitize_title ( $field );
if ( empty ( $value ) )
return false ;
} else if ( 'name' == $field ) {
// Assume already escaped
$field = 't.name' ;
} else {
$field = 't.term_id' ;
$value = ( int ) $value ;
}
$term = $wpdb -> get_row ( " SELECT t.*, tt.* FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy = ' $taxonomy ' AND $field = ' $value ' LIMIT 1 " );
if ( ! $term )
return false ;
wp_cache_add ( $term -> term_id , $term , $taxonomy );
if ( $output == OBJECT ) {
return $term ;
} elseif ( $output == ARRAY_A ) {
return get_object_vars ( $term );
} elseif ( $output == ARRAY_N ) {
return array_values ( get_object_vars ( $term ));
} else {
return $term ;
}
}
2007-05-29 23:27:49 +02:00
function get_term_children ( $term , $taxonomy ) {
$terms = _get_term_hierarchy ( $taxonomy );
if ( ! isset ( $terms [ $term ]) )
return array ();
$children = $terms [ $term ];
foreach ( $terms [ $term ] as $child ) {
if ( isset ( $terms [ $child ]) )
$children = array_merge ( $children , get_term_children ( $child , $taxonomy ));
}
return $children ;
}
2007-06-05 02:57:23 +02:00
function get_term_field ( $field , $term , $taxonomy , $context = 'display' ) {
$term = ( int ) $term ;
$term = get_term ( $term , $taxonomy );
2007-05-30 05:36:59 +02:00
2007-06-05 02:57:23 +02:00
if ( ! is_object ( $term ) )
return '' ;
if ( ! isset ( $term -> $field ) )
return '' ;
return sanitize_term_field ( $field , $term -> $field , $term -> term_id , $taxonomy , $context );
}
function get_term_to_edit ( $id , $taxonomy ) {
$term = get_term ( $id , $taxonomy );
if ( ! is_object ( $term ) )
return '' ;
return sanitize_term ( $term , $taxonomy , 'edit' );
}
function sanitize_term ( $term , $taxonomy , $context = 'display' ) {
$fields = array ( 'term_id' , 'name' , 'description' , 'slug' , 'count' , 'term_group' );
$do_object = false ;
if ( is_object ( $term ) )
$do_object = true ;
foreach ( $fields as $field ) {
if ( $do_object )
$term -> $field = sanitize_term_field ( $field , $term -> $field , $term -> term_id , $taxonomy , $context );
else
$term [ $field ] = sanitize_term_field ( $field , $term [ $field ], $term [ 'term_id' ], $taxonomy , $context );
2007-05-30 05:36:59 +02:00
}
2007-06-05 02:57:23 +02:00
return $term ;
2007-05-30 05:36:59 +02:00
}
2007-06-05 02:57:23 +02:00
function sanitize_term_field ( $field , $value , $term_id , $taxonomy , $context ) {
if ( 'parent' == $field || 'term_id' == $field || 'count' == $field
|| 'term_group' == $field )
$value = ( int ) $value ;
if ( 'edit' == $context ) {
$value = apply_filters ( " edit_term_ $field " , $value , $term_id , $taxonomy );
$value = apply_filters ( " edit_ ${ taxonomy } _ $field " , $value , $term_id );
if ( 'description' == $field )
$value = format_to_edit ( $value );
else
$value = attribute_escape ( $value );
} else if ( 'db' == $context ) {
$value = apply_filters ( " pre_term_ $field " , $value , $taxonomy );
$value = apply_filters ( " pre_ ${ taxonomy } _ $field " , $value );
} else {
// Use display filters by default.
$value = apply_filters ( " term_ $field " , $value , $term_id , $taxonomy , $context );
$value = apply_filters ( " ${ taxonomy } _ $field " , $value , $term_id , $context );
}
// TODO: attribute is usually done in an edit context, so display filters probably
// not appropriate.
if ( 'attribute' == $context )
$value = attribute_escape ( $value );
else if ( 'js' == $context )
$value = js_escape ( $value );
return $value ;
}
//
// Cache
//
2007-05-27 07:15:18 +02:00
function clean_term_cache ( $ids , $taxonomy ) {
if ( ! is_array ( $ids ) )
$ids = array ( $ids );
foreach ( $ids as $id ) {
wp_cache_delete ( $id , $taxonomy );
}
2007-05-27 01:32:06 +02:00
wp_cache_delete ( 'all_ids' , $taxonomy );
wp_cache_delete ( 'get' , $taxonomy );
delete_option ( " { $taxonomy } _children " );
wp_cache_delete ( 'get_terms' , 'terms' );
}
2007-06-05 02:57:23 +02:00
function update_term_cache ( $terms , $taxonomy = '' ) {
foreach ( $terms as $term ) {
$term_taxonomy = $taxonomy ;
if ( empty ( $term_taxonomy ) )
$term_taxonomy = $term -> taxonomy ;
wp_cache_add ( $term -> term_id , $term , $term_taxonomy );
}
}
2007-05-31 23:38:33 +02:00
function clean_object_term_cache ( $object_ids , $object_type ) {
global $object_term_cache , $blog_id ;
if ( ! is_array ( $ids ) )
$ids = array ( $ids );
$taxonomies = get_object_taxonomies ( $object_type );
foreach ( $ids as $id ) {
foreach ( $taxonomies as $taxonomy ) {
if ( isset ( $object_term_cache [ $blog_id ][ $id ][ $taxonomy ]) )
unset ( $object_term_cache [ $blog_id ][ $id ][ $taxonomy ]);
}
}
}
function & get_object_term_cache ( $id , $taxonomy ) {
global $object_term_cache , $blog_id ;
if ( isset ( $object_term_cache [ $blog_id ][ $id ][ $taxonomy ]) )
return $object_term_cache [ $blog_id ][ $id ][ $taxonomy ];
if ( isset ( $object_term_cache [ $blog_id ][ $id ]) )
return array ();
return false ;
}
function update_object_term_cache ( $object_ids , $object_type ) {
global $wpdb , $object_term_cache , $blog_id ;
if ( empty ( $object_ids ) )
return ;
if ( ! is_array ( $object_ids ) )
$object_ids = explode ( ',' , $object_ids );
$count = count ( $object_ids );
for ( $i = 0 ; $i < $count ; $i ++ ) {
$object_id = ( int ) $object_ids [ $i ];
if ( isset ( $object_term_cache [ $blog_id ][ $object_id ] ) ) {
unset ( $object_ids [ $i ] );
continue ;
}
}
if ( count ( $object_ids ) == 0 )
return ;
$terms = get_object_terms ( $object_ids , get_object_taxonomies ( $object_type ), 'fields=all_with_object_id' );
if ( empty ( $terms ) )
return ;
foreach ( $terms as $term )
$object_term_cache [ $blog_id ][ $term -> object_id ][ $term -> taxonomy ][ $term -> term_id ] = $term ;
foreach ( $object_ids as $id ) {
if ( ! isset ( $object_term_cache [ $blog_id ][ $id ]) )
$object_term_cache [ $blog_id ][ $id ] = array ();
}
}
2007-06-05 02:57:23 +02:00
//
// Private
//
2007-05-23 12:32:33 +02:00
function _get_term_hierarchy ( $taxonomy ) {
// TODO Make sure taxonomy is hierarchical
$children = get_option ( " { $taxonomy } _children " );
if ( is_array ( $children ) )
return $children ;
$children = array ();
2007-05-30 03:39:47 +02:00
$terms = get_terms ( $taxonomy , 'get=all' );
2007-05-23 12:32:33 +02:00
foreach ( $terms as $term ) {
if ( $term -> parent > 0 )
2007-05-30 03:39:47 +02:00
$children [ $term -> parent ][] = $term -> term_id ;
2007-05-23 12:32:33 +02:00
}
update_option ( " { $taxonomy } _children " , $children );
return $children ;
}
2007-05-27 07:15:18 +02:00
function & _get_term_children ( $term_id , $terms , $taxonomy ) {
2007-05-23 12:32:33 +02:00
if ( empty ( $terms ) )
return array ();
$term_list = array ();
2007-05-27 07:15:18 +02:00
$has_children = _get_term_hierarchy ( $taxonomy );
2007-05-23 12:32:33 +02:00
if ( ( 0 != $term_id ) && ! isset ( $has_children [ $term_id ]) )
return array ();
foreach ( $terms as $term ) {
2007-05-29 23:50:00 +02:00
$use_id = false ;
if ( ! is_object ( $term ) ) {
$term = get_term ( $term , $taxonomy );
$use_id = true ;
}
2007-05-23 12:32:33 +02:00
if ( $term -> term_id == $term_id )
continue ;
if ( $term -> parent == $term_id ) {
2007-05-29 23:50:00 +02:00
if ( $use_id )
$term_list [] = $term -> term_id ;
else
$term_list [] = $term ;
2007-05-23 12:32:33 +02:00
if ( ! isset ( $has_children [ $term -> term_id ]) )
continue ;
2007-05-27 07:15:18 +02:00
if ( $children = _get_term_children ( $term -> term_id , $terms , $taxonomy ) )
2007-05-23 12:32:33 +02:00
$term_list = array_merge ( $term_list , $children );
}
}
return $term_list ;
}
2007-05-27 07:15:18 +02:00
//
// Default callbacks
//
function _update_post_term_count ( $terms ) {
global $wpdb ;
foreach ( $terms as $term ) {
$count = $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->term_relationships , $wpdb->posts WHERE $wpdb->posts .ID = $wpdb->term_relationships .object_id AND post_status = 'publish' AND post_type = 'post' AND term_taxonomy_id = ' $term ' " );
$wpdb -> query ( " UPDATE $wpdb->term_taxonomy SET count = ' $count ' WHERE term_taxonomy_id = ' $term ' " );
}
}
2007-05-22 07:12:38 +02:00
?>