Skip to content
WordPress

The Complete Guide to BuddyPress WP-CLI Commands

· · 6 min read

BuddyPress is a powerful plugin that transforms your WordPress site into a full-featured social network. Managing a BuddyPress installation, especially on larger sites, can be challenging when limited to the WordPress admin interface. That’s where WP-CLI (WordPress Command Line Interface) comes in, offering a set of commands specifically designed for BuddyPress that lets you manage your social network efficiently from the command line.

In this comprehensive guide, we’ll explore all the BuddyPress WP-CLI commands available, providing practical examples to help you streamline your BuddyPress administration tasks.

Table of Contents

Installation

Prerequisites

Before you can use the BuddyPress WP-CLI commands, make sure you have:

  • WordPress installed
  • BuddyPress plugin installed and activated
  • WP-CLI installed on your server

Installing the Package

The BuddyPress WP-CLI package comes installed by default with BuddyPress. However, if you need to use the latest version, you can install it manually:

wp package install [email protected]:buddypress/wp-cli-buddypress.git

If you encounter memory issues during installation, increase the PHP memory limit:

php -d memory_limit=512M "$(which wp)" package install [email protected]:buddypress/wp-cli-buddypress.git

General Usage

All BuddyPress commands in WP-CLI follow this format:

wp bp [component] [command] [arguments] [--options]

For example, to create a new activity item:

wp bp activity create --component=groups --user-id=123 --content="Hello World"

Now, let’s explore the commands for each BuddyPress component.

Activity Commands

Activities are the lifeblood of any social network, and BuddyPress WP-CLI provides robust commands to manage them.

Creating Activities

wp bp activity create --user-id=50 --component=groups --content="Check out our new group!"

This command creates a new activity for user ID 50 in the groups component with the specified content.

Listing Activities

wp bp activity list --count=10

This returns a list of the 10 most recent activities across your site.

Generating Random Activities

Useful for testing, this command generates random activity items:

wp bp activity generate --count=50

Managing Comments

Add a comment to an activity:

wp bp activity comment 123 --user-id=50 --content="Great post!"

Delete a comment:

wp bp activity delete-comment 123 --comment-id=456 --yes

Other Activity Commands

  • wp bp activity get – Fetch a specific activity
  • wp bp activity delete – Delete an activity
  • wp bp activity spam – Mark an activity as spam
  • wp bp activity ham – Mark an activity as not spam
  • wp bp activity favorite create – Add an activity as a favorite
  • wp bp activity favorite delete – Remove an activity from favorites

Group Commands

Groups are a central feature of BuddyPress, allowing users to organize into communities.

Creating Groups

wp bp group create --name="WordPress Developers" --description="A group for WordPress developers" --status=public

Managing Group Members

Add a user to a group:

wp bp group member create --group-id=123 --user-id=50 --role=member

Promote a member to admin:

wp bp group member promote --group-id=123 --user-id=50 --role=admin

Group Invitations

Send an invitation:

wp bp group invite create --group-id=123 --user-id=50 --inviter-id=60

Accept an invitation:

wp bp group invite accept --group-id=123 --user-id=50

Other Group Commands

  • wp bp group get – Get details of a specific group
  • wp bp group delete – Delete a group
  • wp bp group list – List groups with various filters
  • wp bp group update – Update group details
  • wp bp group meta add – Add custom metadata to a group

Member Commands

Manage BuddyPress members effectively with these commands.

Generating Test Members

wp bp member generate --count=50

This creates 50 random members in your BuddyPress installation, perfect for testing.

Message Commands

Private messaging is a key communication feature in BuddyPress.

Creating Messages

Send a new message:

wp bp message create --from=50 --to=60 --subject="Hello" --content="How are you doing?"

Managing Threads

Delete a message thread:

wp bp message delete-thread 123 --user-id=50 --yes

Other Message Commands

  • wp bp message list – List messages for a user
  • wp bp message star – Star a message
  • wp bp message unstar – Unstar a message
  • wp bp message send-notice – Send a site-wide notice

Friend Commands

Manage friendship connections between members.

Creating Friendships

wp bp friend create 50 60

This creates a friendship request from user ID 50 to user ID 60.

Force accept the friendship immediately:

wp bp friend create 50 60 --force-accept

Checking Friendship Status

wp bp friend check 50 60

Other Friend Commands

  • wp bp friend delete – Remove a friendship
  • wp bp friend accept – Accept a pending friendship
  • wp bp friend reject – Reject a pending friendship
  • wp bp friend list – List a user’s friends
  • wp bp friend generate – Generate random friendships

Notification Commands

Keep users informed with the notification system.

Creating Notifications

wp bp notification create --user-id=50 --component=groups --action=new_membership

Listing Notifications

wp bp notification list --user-id=50

Other Notification Commands

  • wp bp notification get – Get details of a specific notification
  • wp bp notification delete – Delete a notification
  • wp bp notification generate – Generate random notifications

XProfile Commands

Extended profiles allow users to share more about themselves.

Managing Field Groups

Create a field group:

wp bp xprofile group create --name="Professional Info"

Managing Fields

Create a field:

wp bp xprofile field create --field-group-id=123 --name="Job Title" --type=textbox

Managing Profile Data

Set profile data:

wp bp xprofile data set --user-id=50 --field-id=123 --value="Developer"

Get profile data:

wp bp xprofile data get --user-id=50 --field-id=123

Other XProfile Commands

  • wp bp xprofile group delete – Delete a field group
  • wp bp xprofile field delete – Delete a field
  • wp bp xprofile data delete – Delete profile data

Email Commands

Customize the emails BuddyPress sends to users.

Creating Email Templates

wp bp email create --type=new-event --subject="New Event" --content="A new event has been created" --plain-text-content="A new event has been created"

Other Email Commands

  • wp bp email get-post – Get details of an email post
  • wp bp email reinstall – Reinstall default email templates

Signup Commands

Manage the signup and registration process.

Creating Signups

wp bp signup create --user-login=newuser [email protected]

Activating Signups

wp bp signup activate 123

Other Signup Commands

  • wp bp signup get – Get details of a signup
  • wp bp signup delete – Delete a signup
  • wp bp signup generate – Generate random signups
  • wp bp signup resend – Resend activation email

Tool Commands

Utility commands for BuddyPress maintenance.

Repair Tools

Fix friend counts:

wp bp tool repair friend-count

Viewing BuddyPress Version

wp bp tool version

Managing Signup Feature

Enable signups:

wp bp tool signup 1

Disable signups:

wp bp tool signup 0

Component Commands

Manage BuddyPress components (modules).

Listing Components

wp bp component list

Activating/Deactivating Components

Activate a component:

wp bp component activate groups

Deactivate a component:

wp bp component deactivate groups

Sitewide Notice Commands

Manage site-wide announcements.

Creating Notices

wp bp notice create --subject="Site Maintenance" --message="The site will be down for maintenance tonight."

Managing Notices

Activate a notice:

wp bp notice activate 123

Deactivate a notice:

wp bp notice deactivate 123

Other Notice Commands

  • wp bp notice get – Get details of a notice
  • wp bp notice delete – Delete a notice
  • wp bp notice list – List all notices

Scaffold Commands

Set up BuddyPress development environments quickly.

Scaffolding Tests

wp bp scaffold tests my-plugin

This creates BuddyPress-specific test files in your plugin directory.

Conclusion

WP-CLI commands for BuddyPress provide a powerful way to manage your social network from the command line. Whether you’re administering a small community or a large-scale social network, these commands can save you time and effort in day-to-day management tasks.

By mastering these commands, you’ll be able to:

  • Automate repetitive tasks
  • Perform bulk operations efficiently
  • Generate test data quickly
  • Troubleshoot issues more effectively

For more detailed information, check out the official BuddyPress documentation and the WP-CLI BuddyPress repository on GitHub.

Advanced Tips

  • Combining Commands: Use bash scripting to chain commands together for complex operations
  • Scheduled Tasks: Set up cron jobs that run specific BuddyPress WP-CLI commands regularly
  • Batch Processing: Use the --format=ids output with xargs to process large numbers of items

Happy BuddyPress CLI commanding!

Varun Dubey
Varun Dubey

We specialize in web design & development, search engine optimization and web marketing, eCommerce, multimedia solutions, content writing, graphic and logo design. We build web solutions, which evolve with the changing needs of your business.