Occasionally, you may find you need to access or transform data on your WordPress.com site. If it’s more than a dozen posts affected, it’s often more efficient to write what we call a “bin script.” In writing a bin script, you can easily change strings, assign categories, or add post meta across hundreds or thousands of posts. However, with great power comes great responsibility — any small mistake you make with your logic could have negative repercussions across your entire dataset.
Here are some guidelines we’d encourage you to follow when writing a bin script.
Use WP-CLI #
To keep your scripts as lean and mean as possible, we highly encourage you to leverage WP-CLI, an awesome community framework.
When using WP-CLI, all you’ll need to write for your bin script is what’s called a “command.” Your command accepts zero or more arguments and performs a bit of logic. You won’t need to switch to the proper blog, handle arguments, etc., as all of that is done automatically.
Check out the great documentation on how to write a command. Once you’ve written your command and tested it throughly in your local environment, you can commit it to your theme in a manner similar to this:
if ( defined('WP_CLI') && WP_CLI ) require_once( dirname( __FILE__ ) . '/php/class-wp-cli.php' );
When you’ve done so, open a ticket with us with explanation of what you’re trying to accomplish. We’ll review, test, and run it.
Keep These Points In Mind #
Again, it can be easy to make a minor mistake with your script that causes a lot of pain. We encourage you to do the following:
- Comment well and provide clear usage instructions. It’s important to be very clear about what each part is doing and why — commenting each step of your logic is a good sanity check. Comments are especially helpful when something maybe doesn’t work as intended and we need to debug to figure out why.
- Allow for varying levels of verbosity. Similarly, provide a summary at the end with all results of the script.
- Offer a way to do a test run without affecting live data. We can compare what the actual impact is versus the expected impact.
- If you’re modifying lots of data on a live site, make sure to include sleep() in key places. This will help with load associated with cache invalidation and replication.
- If you’re writing an importer, make sure to
define( 'WP_IMPORTING', true );at the top of your subcommand. This will ensure only the minimum of extra actions are fired.
- Use core functions as much as possible, except when they might have undesired consequences. For instance, wp_update_post() fires a number of hooks you may not want fired when replacing strings in post_content. In this context, a direct SQL query would be a better choice, followed by clean_post_cache().