Last active

Embed URL

HTTPS clone URL

SSH clone URL

You can clone with HTTPS or SSH.

Download Gist

Add prefixes to WordPress post types when a theme is activated

View gist:2653299
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
<?php
/* Checks to see if new post type names (with prefixes) are being used. If not, then the old
* post type names are converted as long as there aren't conflicting post type names that are
* being registered by other plugins.
*
* @hook {action} after_setup_theme
*/
function fjarrett_prefix_post_types(){
global $wpdb;
$prefix = 'fjarrett_'; // Define the prefix you would like to use
$post_types = array( 'acme', 'foo', 'bar' ); // Create an array of existing post type names you want to add the prefix to
foreach ( $post_types as $post_type ) {
// Check first to see if another plugin is registering a conflicting post type name
if ( post_type_exists( $post_type ) ) {
continue;
}
// Check to see if database entries exist for the prefixed post type
$new_entries_exist = ( $wpdb->query( $wpdb->prepare( "SELECT * FROM " . $wpdb->posts . " WHERE post_type = %s", $prefix . $post_type ) ) ) ? true : false;
// Move along if new entries exist
if ( $new_entries_exist ) {
continue;
}
// If we make it this far, check to see if database entries exist for the old post type
$old_entries_exist = ( $wpdb->query( $wpdb->prepare( "SELECT * FROM " . $wpdb->posts . " WHERE post_type = %s", $post_type ) ) ) ? true : false;
// Add the prefix to old entries
if ( $old_entries_exist ) {
$wpdb->query(
$wpdb->prepare(
'UPDATE ' . $wpdb->posts . ' SET post_type = %s WHERE post_type = %s',
$prefix . $post_type,
$post_type
)
);
$wpdb->query(
$wpdb->prepare(
'UPDATE ' . $wpdb->posts . ' SET guid = replace( guid, "post_type = %s", "post_type = %s" )',
$post_type,
$prefix . $post_type
)
);
}
}
}
add_action( 'after_setup_theme', 'fjarrett_prefix_post_types' );
Owner

After the theme is activated the specified post types will be renamed to: fjarrett_acme, fjarrett_foo and fjarrett_bar

Owner

OK I've updated this to be a little more robust. Now we're checking to see if the new prefixed post type already exists, and if so, we kill the script.

This will prevent other plugins/themes which may use an old post type name in the future from also being converted. After post types are converted once the DB update will never run again.

Nice dude. Looks like it should work just fine for converting existing post types. I'd like to implement this into EDD so that the post type is named something like "edd_download", instead of just "download".

I'll test it out soon.

Owner

Sadly, there is not a hook yet that fires only when themes are activated.

The after_setup_theme action is a little misleading in that it fires when WordPress sets up the current theme, not when an admin activates and/or configures the current theme. So, it's basically firing with every load of WP when the theme is active.

Someone first made a patch for this 3 years ago and it looks like it's finally being revisited now: http://core.trac.wordpress.org/ticket/7795

The changelog for register_activation_hook() looks depressing as well: http://codex.wordpress.org/Function_Reference/register_activation_hook#Changelog

Yeah, sad indeed. after_theme_setup is probably the best one to use for now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Something went wrong with that request. Please try again.