Change WordPress user roles and capabilities Forums Bug Reports Administrator Menu Access module and custom posts (editing)

Tagged: , , ,

Viewing 5 posts - 1 through 5 (of 5 total)
  • Author
    Posts
  • #3365
    dhokeefe
    Participant

    Hi,

    I have turned on “Administrator Menu Access module” and it is causing problems with editing custom posts.

    Example:
    – I have custom post type “company_latest_news”
    – I update a role under “Admin Menu” – select “Block menu items ‘Not Selected'” and select my Company Latest News (edit.php?post_type=company_latest_news)
    – when I login with that role. Everything is good except when I click to edit the custom post it redirects back to the dashboaard (if I am allowing that) or to the page “/edit.php?post_type=company_latest_news”
    – So for example I click on one of my custom posts and it wants to go to this page “localhost/wp-admin/post.php?post=85&action=edit” but redirects back.
    – If i turn off “Activate Administrator Menu Access module” everything works fine but obviously the admin menu is not restricted at all

    Am I missing how I should be setting this up? I know I can use “Block menu items selected” but that seems to hide them but not actually restrict access, also if I have multiple roles the rules overwrite each other and no menu items are visible at all.

    Essentially I am trying to create a set of roles – each one granting access to a specific menu item and multiple roles can be selected when creating a user to give access to each section. All sections comprise custom post types.

    Any help or guidance would be very much appreciated!

    Thanks
    Donal

    #3367
    Vladimir
    Keymaster

    Hi Donal,

    When you select a menu item to be blocked, URE does not simply hides it. URE blocks the URL assigned to the hidden menu item. Any try to use blocked URL leads to the redirection to URL, assigned to the 1st available (not blocked) menu item.

    When we work with ‘block not selected’ model – all URLs from the main admin menu except apparently selected become blocked. So I suppose that you have some menu item with similar URL, like ‘wp-admin/post.php?post=nn&action=edit’ and it’s counted as blocked.

    I can not repeat described situation at my development environment though, as I don’t have supposed menu item.

    All selected URLs under “block selected’ model should be really blocked. Can you show an example when you turn ON some checkbox but still can access that URL typing it directly at a browser address bar?

    Combining “Admin menu access” data from multiple roles assigned to the same user, you have to take into account this logic:
    – assigned restrictions take effect in the assigned roles order. Admin menu blocking data from the 1st (primary) role takes effect always;
    – data from the rest roles are taking into account only if they use the same blocking model. For example, if the 1st role has ‘block selected’ model, but the 2nd role has ‘block not selected’ model, the 2nd role ‘admin menu access’ data is ignored.
    – ‘admin menu access’ data from other roles with the same blocking model are added to the data from the 1st role.

    If you have an example when the rules described above don’t work, let’s discuss it. I will try to repeat the situation and fix the bug if we discover it.

    #3370
    dhokeefe
    Participant

    Thanks Vladimir for the details,

    The notes on how the order of assigned roles affects the access probably explains some of the results I have had.

    If I understand correctly though. I can’t use “Block Not Selected” if I’m working with custom post types – as these are always edited with a URL similar to “wp-admin/post.php?post=nn&action=edit’. Is that correct?

    #3371
    Vladimir
    Keymaster

    I can’t use “Block Not Selected” if I’m working with custom post types – as these are always edited with a URL similar to “wp-admin/post.php?post=nn&action=edit’. Is that correct?

    No, in general, it’s possible to use “block not selected” option with custom post types. I suppose, that a possible source of a problem in your case is that the link like ‘wp-admin/post.php?post=nn&action=edit’ would be associated with one of the existed (but not selected and thus blocked) admin menu item, created by a theme or plugin. URE does not block any link except selected, just not selected links included into admin menu should be blocked.

    Try to look for similar URL at the list of URLs shown at the dialog window when you click ‘Admin menu’ for the role. Is there such URL? To what plugin does it belong?

    #3372
    dhokeefe
    Participant

    This makes sense – thanks so much for your feedback and help.

Viewing 5 posts - 1 through 5 (of 5 total)
  • You must be logged in to reply to this topic.