[ Index ] |
PHP Cross Reference of BuddyPress |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * BuddyPress Groups Activity Functions. 4 * 5 * These functions handle the recording, deleting and formatting of activity 6 * for the user and for this specific component. 7 * 8 * @package BuddyPress 9 * @subpackage GroupsActivity 10 * @since 1.5.0 11 */ 12 13 // Exit if accessed directly. 14 defined( 'ABSPATH' ) || exit; 15 16 /** 17 * Register activity actions for the Groups component. 18 * 19 * @since 1.1.0 20 * 21 * @return false|null False on failure. 22 */ 23 function groups_register_activity_actions() { 24 $bp = buddypress(); 25 26 if ( ! bp_is_active( 'activity' ) ) { 27 return false; 28 } 29 30 bp_activity_set_action( 31 $bp->groups->id, 32 'created_group', 33 __( 'Created a group', 'buddypress' ), 34 'bp_groups_format_activity_action_created_group', 35 __( 'New Groups', 'buddypress' ), 36 array( 'activity', 'member', 'member_groups' ) 37 ); 38 39 bp_activity_set_action( 40 $bp->groups->id, 41 'joined_group', 42 __( 'Joined a group', 'buddypress' ), 43 'bp_groups_format_activity_action_joined_group', 44 __( 'Group Memberships', 'buddypress' ), 45 array( 'activity', 'group', 'member', 'member_groups' ) 46 ); 47 48 bp_activity_set_action( 49 $bp->groups->id, 50 'group_details_updated', 51 __( 'Group details edited', 'buddypress' ), 52 'bp_groups_format_activity_action_group_details_updated', 53 __( 'Group Updates', 'buddypress' ), 54 array( 'activity', 'group', 'member', 'member_groups' ) 55 ); 56 57 bp_activity_set_action( 58 $bp->groups->id, 59 'activity_update', 60 __( 'Posted a status update in a Group', 'buddypress' ), 61 'bp_groups_format_activity_action_group_activity_update', 62 __( 'Group Activity Updates', 'buddypress' ), 63 array( 'activity', 'group', 'member', 'member_groups' ) 64 ); 65 66 /** 67 * Fires at end of registration of the default activity actions for the Groups component. 68 * 69 * @since 1.1.0 70 */ 71 do_action( 'groups_register_activity_actions' ); 72 } 73 add_action( 'bp_register_activity_actions', 'groups_register_activity_actions' ); 74 75 /** 76 * Get the group object the activity belongs to. 77 * 78 * @since 5.0.0 79 * 80 * @param integer $group_id The group ID the activity is linked to. 81 * @return BP_Groups_Group The group object the activity belongs to. 82 */ 83 function bp_groups_get_activity_group( $group_id = 0 ) { 84 // If displaying a specific group, check the activity belongs to it. 85 if ( bp_is_group() && bp_get_current_group_id() === (int) $group_id ) { 86 $group = groups_get_current_group(); 87 88 // Otherwise get the group the activity belongs to. 89 } else { 90 $group = groups_get_group( $group_id ); 91 } 92 93 return $group; 94 } 95 96 /** 97 * Format 'created_group' activity actions. 98 * 99 * @since 2.0.0 100 * 101 * @param string $action Static activity action. 102 * @param object $activity Activity data object. 103 * @return string 104 */ 105 function bp_groups_format_activity_action_created_group( $action, $activity ) { 106 $user_link = bp_core_get_userlink( $activity->user_id ); 107 108 $group = bp_groups_get_activity_group( $activity->item_id ); 109 $group_link = '<a href="' . esc_url( bp_get_group_permalink( $group ) ) . '">' . esc_html( $group->name ) . '</a>'; 110 111 /* translators: 1: the user link. 2: the group link. */ 112 $action = sprintf( esc_html__( '%1$s created the group %2$s', 'buddypress'), $user_link, $group_link ); 113 114 /** 115 * Filters the 'created_group' activity actions. 116 * 117 * @since 1.2.0 118 * 119 * @param string $action The 'created_group' activity action. 120 * @param object $activity Activity data object. 121 */ 122 return apply_filters( 'groups_activity_created_group_action', $action, $activity ); 123 } 124 125 /** 126 * Format 'joined_group' activity actions. 127 * 128 * @since 2.0.0 129 * 130 * @param string $action Static activity action. 131 * @param object $activity Activity data object. 132 * @return string 133 */ 134 function bp_groups_format_activity_action_joined_group( $action, $activity ) { 135 $user_link = bp_core_get_userlink( $activity->user_id ); 136 137 $group = bp_groups_get_activity_group( $activity->item_id ); 138 $group_link = '<a href="' . esc_url( bp_get_group_permalink( $group ) ) . '">' . esc_html( $group->name ) . '</a>'; 139 140 /* translators: 1: the user link. 2: the group link. */ 141 $action = sprintf( esc_html__( '%1$s joined the group %2$s', 'buddypress' ), $user_link, $group_link ); 142 143 // Legacy filters (do not follow parameter patterns of other activity 144 // action filters, and requires apply_filters_ref_array()). 145 if ( has_filter( 'groups_activity_membership_accepted_action' ) ) { 146 $action = apply_filters_ref_array( 'groups_activity_membership_accepted_action', array( $action, $user_link, &$group ) ); 147 } 148 149 // Another legacy filter. 150 if ( has_filter( 'groups_activity_accepted_invite_action' ) ) { 151 $action = apply_filters_ref_array( 'groups_activity_accepted_invite_action', array( $action, $activity->user_id, &$group ) ); 152 } 153 154 /** 155 * Filters the 'joined_group' activity actions. 156 * 157 * @since 2.0.0 158 * 159 * @param string $action The 'joined_group' activity actions. 160 * @param object $activity Activity data object. 161 */ 162 return apply_filters( 'bp_groups_format_activity_action_joined_group', $action, $activity ); 163 } 164 165 /** 166 * Format 'group_details_updated' activity actions. 167 * 168 * @since 2.2.0 169 * 170 * @param string $action Static activity action. 171 * @param object $activity Activity data object. 172 * @return string 173 */ 174 function bp_groups_format_activity_action_group_details_updated( $action, $activity ) { 175 $user_link = bp_core_get_userlink( $activity->user_id ); 176 177 $group = bp_groups_get_activity_group( $activity->item_id ); 178 $group_link = '<a href="' . esc_url( bp_get_group_permalink( $group ) ) . '">' . esc_html( $group->name ) . '</a>'; 179 180 /* 181 * Changed group details are stored in groupmeta, keyed by the activity 182 * timestamp. See {@link bp_groups_group_details_updated_add_activity()}. 183 */ 184 $changed = groups_get_groupmeta( $activity->item_id, 'updated_details_' . $activity->date_recorded ); 185 186 // No changed details were found, so use a generic message. 187 if ( empty( $changed ) ) { 188 /* translators: 1: the user link. 2: the group link. */ 189 $action = sprintf( esc_html__( '%1$s updated details for the group %2$s', 'buddypress' ), $user_link, $group_link ); 190 191 // Name and description changed - to keep things short, don't describe changes in detail. 192 } elseif ( isset( $changed['name'] ) && isset( $changed['description'] ) ) { 193 /* translators: 1: the user link. 2: the group link. */ 194 $action = sprintf( esc_html__( '%1$s changed the name and description of the group %2$s', 'buddypress' ), $user_link, $group_link ); 195 196 // Name only. 197 } elseif ( ! empty( $changed['name']['old'] ) && ! empty( $changed['name']['new'] ) ) { 198 /* translators: 1: the user link. 2: the group link. 3: the old group name. 4: the new group name. */ 199 $action = sprintf( esc_html__( '%1$s changed the name of the group %2$s from "%3$s" to "%4$s"', 'buddypress' ), $user_link, $group_link, esc_html( $changed['name']['old'] ), esc_html( $changed['name']['new'] ) ); 200 201 // Description only. 202 } elseif ( ! empty( $changed['description']['old'] ) && ! empty( $changed['description']['new'] ) ) { 203 /* translators: 1: the user link. 2: the group link. 3: the old group description. 4: the new group description. */ 204 $action = sprintf( esc_html__( '%1$s changed the description of the group %2$s from "%3$s" to "%4$s"', 'buddypress' ), $user_link, $group_link, esc_html( $changed['description']['old'] ), esc_html( $changed['description']['new'] ) ); 205 206 } elseif ( ! empty( $changed['slug']['old'] ) && ! empty( $changed['slug']['new'] ) ) { 207 /* translators: 1: the user link. 2: the group link. */ 208 $action = sprintf( esc_html__( '%1$s changed the permalink of the group %2$s.', 'buddypress' ), $user_link, $group_link ); 209 } 210 211 /** 212 * Filters the 'group_details_updated' activity actions. 213 * 214 * @since 2.0.0 215 * 216 * @param string $action The 'group_details_updated' activity actions. 217 * @param object $activity Activity data object. 218 */ 219 return apply_filters( 'bp_groups_format_activity_action_joined_group', $action, $activity ); 220 } 221 222 /** 223 * Format the action for activity updates posted in a Group. 224 * 225 * @since 5.0.0 226 * 227 * @param string $action Static activity action. 228 * @param object $activity Activity data object. 229 * @return string The formatted action for activity updates posted in a Group. 230 */ 231 function bp_groups_format_activity_action_group_activity_update( $action, $activity ) { 232 $user_link = bp_core_get_userlink( $activity->user_id ); 233 $group = bp_groups_get_activity_group( $activity->item_id ); 234 235 $group_link = '<a href="' . esc_url( bp_get_group_permalink( $group ) ) . '">' . esc_html( $group->name ) . '</a>'; 236 237 // Set the Activity update posted in a Group action. 238 $action = sprintf( 239 /* translators: 1: the user link. 2: the group link. */ 240 esc_html__( '%1$s posted an update in the group %2$s', 'buddypress' ), 241 $user_link, 242 $group_link 243 ); 244 245 /** This filter is documented in wp-includes/deprecated.php */ 246 $action = apply_filters_deprecated( 'groups_activity_new_update_action', array( $action ), '5.0.0', 'bp_groups_format_activity_action_group_activity_update' ); 247 248 /** 249 * Filters the Group's activity update action. 250 * 251 * @since 5.0.0 252 * 253 * @param string $action The Group's activity update action. 254 * @param object $activity Activity data object. 255 */ 256 return apply_filters( 'bp_groups_format_activity_action_group_activity_update', $action, $activity ); 257 } 258 259 /** 260 * Fetch data related to groups at the beginning of an activity loop. 261 * 262 * This reduces database overhead during the activity loop. 263 * 264 * @since 2.0.0 265 * 266 * @param array $activities Array of activity items. 267 * @return array 268 */ 269 function bp_groups_prefetch_activity_object_data( $activities ) { 270 $group_ids = array(); 271 272 if ( empty( $activities ) ) { 273 return $activities; 274 } 275 276 foreach ( $activities as $activity ) { 277 if ( buddypress()->groups->id !== $activity->component ) { 278 continue; 279 } 280 281 $group_ids[] = $activity->item_id; 282 } 283 284 if ( ! empty( $group_ids ) ) { 285 286 // TEMPORARY - Once the 'populate_extras' issue is solved 287 // in the groups component, we can do this with groups_get_groups() 288 // rather than manually. 289 $uncached_ids = array(); 290 foreach ( $group_ids as $group_id ) { 291 if ( false === wp_cache_get( $group_id, 'bp_groups' ) ) { 292 $uncached_ids[] = $group_id; 293 } 294 } 295 296 if ( ! empty( $uncached_ids ) ) { 297 global $wpdb; 298 $bp = buddypress(); 299 $uncached_ids_sql = implode( ',', wp_parse_id_list( $uncached_ids ) ); 300 $groups = $wpdb->get_results( "SELECT * FROM {$bp->groups->table_name} WHERE id IN ({$uncached_ids_sql})" ); 301 foreach ( $groups as $group ) { 302 wp_cache_set( $group->id, $group, 'bp_groups' ); 303 } 304 } 305 } 306 307 return $activities; 308 } 309 add_filter( 'bp_activity_prefetch_object_data', 'bp_groups_prefetch_activity_object_data' ); 310 311 /** 312 * Set up activity arguments for use with the 'groups' scope. 313 * 314 * @since 2.2.0 315 * 316 * @param array $retval Empty array by default. 317 * @param array $filter Current activity arguments. 318 * @return array 319 */ 320 function bp_groups_filter_activity_scope( $retval = array(), $filter = array() ) { 321 322 // Determine the user_id. 323 if ( ! empty( $filter['user_id'] ) ) { 324 $user_id = $filter['user_id']; 325 } else { 326 $user_id = bp_displayed_user_id() 327 ? bp_displayed_user_id() 328 : bp_loggedin_user_id(); 329 } 330 331 // Determine groups of user. 332 $groups = groups_get_user_groups( $user_id ); 333 if ( empty( $groups['groups'] ) ) { 334 $groups = array( 'groups' => 0 ); 335 } 336 337 // Should we show all items regardless of sitewide visibility? 338 $show_hidden = array(); 339 if ( ! empty( $user_id ) && ( $user_id !== bp_loggedin_user_id() ) ) { 340 $show_hidden = array( 341 'column' => 'hide_sitewide', 342 'value' => 0 343 ); 344 } 345 346 $retval = array( 347 'relation' => 'AND', 348 array( 349 'relation' => 'AND', 350 array( 351 'column' => 'component', 352 'value' => buddypress()->groups->id 353 ), 354 array( 355 'column' => 'item_id', 356 'compare' => 'IN', 357 'value' => (array) $groups['groups'] 358 ), 359 ), 360 $show_hidden, 361 362 // Overrides. 363 'override' => array( 364 'filter' => array( 'user_id' => 0 ), 365 'show_hidden' => true 366 ), 367 ); 368 369 return $retval; 370 } 371 add_filter( 'bp_activity_set_groups_scope_args', 'bp_groups_filter_activity_scope', 10, 2 ); 372 373 /** 374 * Enforces group membership restrictions on activity favorite queries. 375 * 376 * @since 4.3.0 377 378 * @param array $retval Query arguments. 379 * @param array $filter 380 * @return array 381 */ 382 function bp_groups_filter_activity_favorites_scope( $retval, $filter ) { 383 // Only process for viewers looking at their own favorites feed. 384 if ( ! empty( $filter['user_id'] ) ) { 385 $user_id = (int) $filter['user_id']; 386 } else { 387 $user_id = bp_displayed_user_id() ? bp_displayed_user_id() : bp_loggedin_user_id(); 388 } 389 390 if ( ! $user_id || ! is_user_logged_in() || $user_id !== bp_loggedin_user_id() ) { 391 return $retval; 392 } 393 394 $favs = bp_activity_get_user_favorites( $user_id ); 395 if ( empty( $favs ) ) { 396 return $retval; 397 } 398 399 $user_groups = bp_get_user_groups( 400 $user_id, 401 array( 402 'is_admin' => null, 403 'is_mod' => null, 404 ) 405 ); 406 407 $retval = array( 408 'relation' => 'OR', 409 410 // Allow hidden items for items unconnected to groups. 411 'non_groups' => array( 412 'relation' => 'AND', 413 array( 414 'column' => 'component', 415 'compare' => '!=', 416 'value' => buddypress()->groups->id, 417 ), 418 array( 419 'column' => 'hide_sitewide', 420 'compare' => 'IN', 421 'value' => array( 1, 0 ), 422 ), 423 array( 424 'column' => 'id', 425 'compare' => 'IN', 426 'value' => $favs, 427 ), 428 ), 429 430 // Trust the favorites list for group items that are not hidden sitewide. 431 'non_hidden_groups' => array( 432 'relation' => 'AND', 433 array( 434 'column' => 'component', 435 'compare' => '=', 436 'value' => buddypress()->groups->id, 437 ), 438 array( 439 'column' => 'hide_sitewide', 440 'compare' => '=', 441 'value' => 0, 442 ), 443 array( 444 'column' => 'id', 445 'compare' => 'IN', 446 'value' => $favs, 447 ), 448 ), 449 450 // For hidden group items, limit to those in the user's groups. 451 'hidden_groups' => array( 452 'relation' => 'AND', 453 array( 454 'column' => 'component', 455 'compare' => '=', 456 'value' => buddypress()->groups->id, 457 ), 458 array( 459 'column' => 'hide_sitewide', 460 'compare' => '=', 461 'value' => 1, 462 ), 463 array( 464 'column' => 'id', 465 'compare' => 'IN', 466 'value' => $favs, 467 ), 468 array( 469 'column' => 'item_id', 470 'compare' => 'IN', 471 'value' => wp_list_pluck( $user_groups, 'group_id' ), 472 ), 473 ), 474 475 'override' => array( 476 'display_comments' => true, 477 'filter' => array( 'user_id' => 0 ), 478 'show_hidden' => true, 479 ), 480 ); 481 482 return $retval; 483 } 484 add_filter( 'bp_activity_set_favorites_scope_args', 'bp_groups_filter_activity_favorites_scope', 20, 2 ); 485 486 /** 487 * Record an activity item related to the Groups component. 488 * 489 * A wrapper for {@link bp_activity_add()} that provides some Groups-specific 490 * defaults. 491 * 492 * @since 1.0.0 493 * 494 * @see bp_activity_add() for more detailed description of parameters and 495 * return values. 496 * 497 * @param array|string $args { 498 * An array of arguments for the new activity item. Accepts all parameters 499 * of {@link bp_activity_add()}. However, this wrapper provides some 500 * additional defaults, as described below: 501 * @type string $component Default: the id of your Groups component 502 * (usually 'groups'). 503 * @type bool $hide_sitewide Default: True if the current group is not 504 * public, otherwise false. 505 * } 506 * @return WP_Error|bool|int See {@link bp_activity_add()}. 507 */ 508 function groups_record_activity( $args = '' ) { 509 510 if ( ! bp_is_active( 'activity' ) ) { 511 return false; 512 } 513 514 // Set the default for hide_sitewide by checking the status of the group. 515 $hide_sitewide = false; 516 if ( ! empty( $args['item_id'] ) ) { 517 $group = bp_groups_get_activity_group( $args['item_id'] ); 518 519 if ( isset( $group->status ) && 'public' != $group->status ) { 520 $hide_sitewide = true; 521 } 522 } 523 524 $r = bp_parse_args( 525 $args, 526 array( 527 'id' => false, 528 'user_id' => bp_loggedin_user_id(), 529 'action' => '', 530 'content' => '', 531 'primary_link' => '', 532 'component' => buddypress()->groups->id, 533 'type' => false, 534 'item_id' => false, 535 'secondary_item_id' => false, 536 'recorded_time' => bp_core_current_time(), 537 'hide_sitewide' => $hide_sitewide, 538 'error_type' => 'bool', 539 ), 540 'groups_record_activity' 541 ); 542 543 return bp_activity_add( $r ); 544 } 545 546 /** 547 * Post an Activity status update affiliated with a group. 548 * 549 * @since 1.2.0 550 * @since 2.6.0 Added 'error_type' parameter to $args. 551 * 552 * @param array|string $args { 553 * Array of arguments. 554 * @type string $content The content of the update. 555 * @type int $user_id Optional. ID of the user posting the update. Default: 556 * ID of the logged-in user. 557 * @type int $group_id Optional. ID of the group to be affiliated with the 558 * update. Default: ID of the current group. 559 * } 560 * @return WP_Error|bool|int Returns the ID of the new activity item on success, or false on failure. 561 */ 562 function groups_post_update( $args = '' ) { 563 $bp = buddypress(); 564 565 $r = bp_parse_args( 566 $args, 567 array( 568 'content' => false, 569 'user_id' => bp_loggedin_user_id(), 570 'group_id' => 0, 571 'error_type' => 'bool', 572 ), 573 'groups_post_update' 574 ); 575 576 $group_id = (int) $r['group_id']; 577 if ( ! $group_id && ! empty( $bp->groups->current_group->id ) ) { 578 $group_id = (int) $bp->groups->current_group->id; 579 } 580 581 $content = $r['content']; 582 $user_id = (int) $r['user_id']; 583 if ( ! $content || ! strlen( trim( $content ) ) || ! $user_id || ! $group_id ) { 584 return false; 585 } 586 587 $bp->groups->current_group = groups_get_group( $group_id ); 588 589 // Be sure the user is a member of the group before posting. 590 if ( ! bp_current_user_can( 'bp_moderate' ) && ! groups_is_user_member( $user_id, $group_id ) ) { 591 return false; 592 } 593 594 /** 595 * Filters the content for the new group activity update. 596 * 597 * @since 1.2.0 598 * 599 * @param string $content The content of the update. 600 */ 601 $content_filtered = apply_filters( 'groups_activity_new_update_content', $content ); 602 603 $activity_id = groups_record_activity( array( 604 'user_id' => $user_id, 605 'content' => $content_filtered, 606 'type' => 'activity_update', 607 'item_id' => $group_id, 608 'error_type' => $r['error_type'], 609 ) ); 610 611 groups_update_groupmeta( $group_id, 'last_activity', bp_core_current_time() ); 612 613 /** 614 * Fires after posting of an Activity status update affiliated with a group. 615 * 616 * @since 1.2.0 617 * 618 * @param string $content The content of the update. 619 * @param int $user_id ID of the user posting the update. 620 * @param int $group_id ID of the group being posted to. 621 * @param bool $activity_id Whether or not the activity recording succeeded. 622 */ 623 do_action( 'bp_groups_posted_update', $content, $user_id, $group_id, $activity_id ); 624 625 return $activity_id; 626 } 627 628 /** 629 * Function used to determine if a user can delete a group activity item. 630 * 631 * Used as a filter callback to 'bp_activity_user_can_delete'. 632 * 633 * @since 6.0.0 634 * 635 * @param bool $retval True if item can receive comments. 636 * @param object $activity Activity item being checked. 637 * @return bool 638 */ 639 function bp_groups_filter_activity_user_can_delete( $retval, $activity ) { 640 // Bail if no current user. 641 if ( ! is_user_logged_in() ) { 642 return $retval; 643 } 644 645 if ( isset( $activity->component ) || 'groups' !== $activity->component ) { 646 return $retval; 647 } 648 649 // Trust the passed value for administrators. 650 if ( bp_current_user_can( 'bp_moderate' ) ) { 651 return $retval; 652 } 653 654 // Group administrators or moderators can delete content in that group that doesn't belong to them. 655 $group_id = $activity->item_id; 656 if ( groups_is_user_admin( bp_loggedin_user_id(), $group_id ) || groups_is_user_mod( bp_loggedin_user_id(), $group_id ) ) { 657 $retval = true; 658 } 659 660 return $retval; 661 } 662 add_filter( 'bp_activity_user_can_delete', 'bp_groups_filter_activity_user_can_delete', 10, 2 ); 663 664 /** 665 * Function used to determine if a user can comment on a group activity item. 666 * 667 * Used as a filter callback to 'bp_activity_can_comment'. 668 * 669 * @since 3.0.0 670 * 671 * @param bool $retval True if item can receive comments. 672 * @param null|BP_Activity_Activity $activity Null by default. Pass an activity object to check against that instead. 673 * @return bool 674 */ 675 function bp_groups_filter_activity_can_comment( $retval, $activity = null ) { 676 // Bail if item cannot receive comments or if no current user. 677 if ( empty( $retval ) || ! is_user_logged_in() ) { 678 return $retval; 679 } 680 681 // Use passed activity object, if available. 682 if ( is_a( $activity, 'BP_Activity_Activity' ) ) { 683 $component = $activity->component; 684 $group_id = $activity->item_id; 685 686 // Use activity info from current activity item in the loop. 687 } else { 688 $component = bp_get_activity_object_name(); 689 $group_id = bp_get_activity_item_id(); 690 } 691 692 // If not a group activity item, bail. 693 if ( 'groups' !== $component ) { 694 return $retval; 695 } 696 697 // If current user is not a group member or is banned, user cannot comment. 698 if ( ! bp_current_user_can( 'bp_moderate' ) && 699 ( ! groups_is_user_member( bp_loggedin_user_id(), $group_id ) || groups_is_user_banned( bp_loggedin_user_id(), $group_id ) ) 700 ) { 701 $retval = false; 702 } 703 704 return $retval; 705 } 706 add_filter( 'bp_activity_can_comment', 'bp_groups_filter_activity_can_comment', 99, 1 ); 707 708 /** 709 * Function used to determine if a user can reply on a group activity comment. 710 * 711 * Used as a filter callback to 'bp_activity_can_comment_reply'. 712 * 713 * @since 3.0.0 714 * 715 * @param bool $retval True if activity comment can be replied to. 716 * @param object|bool $comment Current activity comment object. If empty, parameter is boolean false. 717 * @return bool 718 */ 719 function bp_groups_filter_activity_can_comment_reply( $retval, $comment ) { 720 // Bail if no current user, if comment is empty or if retval is already empty. 721 if ( ! is_user_logged_in() || empty( $comment ) || empty( $retval ) ) { 722 return $retval; 723 } 724 725 // Grab parent activity item. 726 $parent = new BP_Activity_Activity( $comment->item_id ); 727 728 // Check to see if user can reply to parent group activity item. 729 return bp_groups_filter_activity_can_comment( $retval, $parent ); 730 } 731 add_filter( 'bp_activity_can_comment_reply', 'bp_groups_filter_activity_can_comment_reply', 99, 2 ); 732 733 /** 734 * Add an activity stream item when a member joins a group. 735 * 736 * @since 1.9.0 737 * 738 * @param int $user_id ID of the user joining the group. 739 * @param int $group_id ID of the group. 740 * @return false|null False on failure. 741 */ 742 function bp_groups_membership_accepted_add_activity( $user_id, $group_id ) { 743 744 // Bail if Activity is not active. 745 if ( ! bp_is_active( 'activity' ) ) { 746 return false; 747 } 748 749 // Get the group so we can get it's name. 750 $group = groups_get_group( $group_id ); 751 752 /** 753 * Filters the 'membership_accepted' activity actions. 754 * 755 * @since 1.2.0 756 * 757 * @param string $value The 'membership_accepted' activity action. 758 * @param int $user_id ID of the user joining the group. 759 * @param int $group_id ID of the group. Passed by reference. 760 */ 761 $action = apply_filters_ref_array( 'groups_activity_membership_accepted_action', array( sprintf( __( '%1$s joined the group %2$s', 'buddypress' ), bp_core_get_userlink( $user_id ), '<a href="' . bp_get_group_permalink( $group ) . '">' . esc_attr( $group->name ) . '</a>' ), $user_id, &$group ) ); 762 763 // Record in activity streams. 764 groups_record_activity( array( 765 'action' => $action, 766 'type' => 'joined_group', 767 'item_id' => $group_id, 768 'user_id' => $user_id 769 ) ); 770 } 771 add_action( 'groups_membership_accepted', 'bp_groups_membership_accepted_add_activity', 10, 2 ); 772 773 /** 774 * Add an activity item when a group's details are updated. 775 * 776 * @since 2.2.0 777 * 778 * @param int $group_id ID of the group. 779 * @param BP_Groups_Group $old_group Group object before the details had been changed. 780 * @param bool $notify_members True if the admin has opted to notify group members, otherwise false. 781 * @return null|WP_Error|bool|int The ID of the activity on success. False on error. 782 */ 783 function bp_groups_group_details_updated_add_activity( $group_id, $old_group, $notify_members ) { 784 785 // Bail if Activity is not active. 786 if ( ! bp_is_active( 'activity' ) ) { 787 return false; 788 } 789 790 if ( ! isset( $old_group->name ) || ! isset( $old_group->slug ) || ! isset( $old_group->description ) ) { 791 return false; 792 } 793 794 // If the admin has opted not to notify members, don't post an activity item either. 795 if ( empty( $notify_members ) ) { 796 return; 797 } 798 799 $group = groups_get_group( array( 800 'group_id' => $group_id, 801 ) ); 802 803 /* 804 * Store the changed data, which will be used to generate the activity 805 * action. Since we haven't yet created the activity item, we store the 806 * old group data in groupmeta, keyed by the timestamp that we'll put 807 * on the activity item. 808 */ 809 $changed = array(); 810 811 if ( $group->name !== $old_group->name ) { 812 $changed['name'] = array( 813 'old' => $old_group->name, 814 'new' => $group->name, 815 ); 816 } 817 818 if ( $group->slug !== $old_group->slug ) { 819 $changed['slug'] = array( 820 'old' => $old_group->slug, 821 'new' => $group->slug, 822 ); 823 } 824 825 if ( $group->description !== $old_group->description ) { 826 $changed['description'] = array( 827 'old' => $old_group->description, 828 'new' => $group->description, 829 ); 830 } 831 832 // If there are no changes, don't post an activity item. 833 if ( empty( $changed ) ) { 834 return; 835 } 836 837 $time = bp_core_current_time(); 838 groups_update_groupmeta( $group_id, 'updated_details_' . $time, $changed ); 839 840 // Record in activity streams. 841 return groups_record_activity( array( 842 'type' => 'group_details_updated', 843 'item_id' => $group_id, 844 'user_id' => bp_loggedin_user_id(), 845 'recorded_time' => $time, 846 847 ) ); 848 849 } 850 add_action( 'groups_details_updated', 'bp_groups_group_details_updated_add_activity', 10, 3 ); 851 852 /** 853 * Delete all activity items related to a specific group. 854 * 855 * @since 1.9.0 856 * 857 * @param int $group_id ID of the group. 858 */ 859 function bp_groups_delete_group_delete_all_activity( $group_id ) { 860 if ( bp_is_active( 'activity' ) ) { 861 bp_activity_delete_by_item_id( array( 862 'item_id' => $group_id, 863 'component' => buddypress()->groups->id 864 ) ); 865 } 866 } 867 add_action( 'groups_delete_group', 'bp_groups_delete_group_delete_all_activity', 10 ); 868 869 /** 870 * Delete group member activity if they leave or are removed within 5 minutes of membership modification. 871 * 872 * If the user joined this group less than five minutes ago, remove the 873 * joined_group activity so users cannot flood the activity stream by 874 * joining/leaving the group in quick succession. 875 * 876 * @since 1.9.0 877 * 878 * @param int $group_id ID of the group. 879 * @param int $user_id ID of the user leaving the group. 880 */ 881 function bp_groups_leave_group_delete_recent_activity( $group_id, $user_id ) { 882 883 // Bail if Activity component is not active. 884 if ( ! bp_is_active( 'activity' ) ) { 885 return; 886 } 887 888 // Get the member's group membership information. 889 $membership = new BP_Groups_Member( $user_id, $group_id ); 890 891 // Check the time period, and maybe delete their recent group activity. 892 if ( time() <= strtotime( '+5 minutes', (int) strtotime( $membership->date_modified ) ) ) { 893 bp_activity_delete( array( 894 'component' => buddypress()->groups->id, 895 'type' => 'joined_group', 896 'user_id' => $user_id, 897 'item_id' => $group_id 898 ) ); 899 } 900 } 901 add_action( 'groups_leave_group', 'bp_groups_leave_group_delete_recent_activity', 10, 2 ); 902 add_action( 'groups_remove_member', 'bp_groups_leave_group_delete_recent_activity', 10, 2 ); 903 add_action( 'groups_ban_member', 'bp_groups_leave_group_delete_recent_activity', 10, 2 );
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Tue Nov 12 01:00:54 2024 | Cross-referenced by PHPXref 0.7.1 |