Skip to:
Content

BuddyPress.org


Ignore:
Timestamp:
05/10/2021 03:07:41 PM (4 years ago)
Author:
dcavins
Message:

Member Invites: Centralize access logic.

  • User must be logged in to pass bp_members_send_invitation cap.
  • Add new capabilities bp_members_invitations_view_screens

and bp_members_invitations_view_send_screen.

  • Use new capabilities in bp_members_admin_bar_add_invitations_menu()

and bp_members_invitations_setup_nav() so that the logic is
consistent in both places.

See #8139.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/bp-members/bp-members-invitations.php

    r12923 r12945  
    1616    }
    1717
    18     $user_has_access  = bp_user_has_access();
    19     $user_can_send    = bp_user_can( bp_displayed_user_id(), 'bp_members_send_invitation' );
    20     $user_has_invites = bp_members_invitations_user_has_sent_invites( bp_displayed_user_id() );
     18    $user_has_access     = bp_user_has_access();
     19    $default_subnav_slug = ( bp_is_my_profile() && bp_user_can( bp_displayed_user_id(), 'bp_members_invitations_view_send_screen' ) ) ? 'send-invites' : 'list-invites';
    2120
    2221    /* Add 'Invitations' to the main user profile navigation */
     
    2726            'position'                => 80,
    2827            'screen_function'         => 'members_screen_send_invites',
    29             'default_subnav_slug'     => ( $user_can_send && bp_is_my_profile() ) ? 'send-invites' : 'list-invites',
    30             'show_for_displayed_user' => $user_has_access && ( $user_can_send || $user_has_invites )
     28            'default_subnav_slug'     => $default_subnav_slug,
     29            'show_for_displayed_user' => $user_has_access && bp_user_can( bp_displayed_user_id(), 'bp_members_invitations_view_screens' )
    3130        )
    3231    );
     
    4342            'screen_function' => 'members_screen_send_invites',
    4443            'position'        => 10,
    45             'user_has_access' => $user_has_access && $user_can_send && bp_is_my_profile()
     44            'user_has_access' => $user_has_access && bp_is_my_profile() && bp_user_can( bp_displayed_user_id(), 'bp_members_invitations_view_send_screen' )
    4645        )
    4746    );
     
    5554            'screen_function' => 'members_screen_list_sent_invites',
    5655            'position'        => 20,
    57             'user_has_access' => $user_has_access && ( $user_can_send || $user_has_invites )
     56            'user_has_access' => $user_has_access && bp_user_can( bp_displayed_user_id(), 'bp_members_invitations_view_screens' )
    5857        )
    5958    );
Note: See TracChangeset for help on using the changeset viewer.