Skip Navigation

[Resolved] Restrict wp-admin area for certain roles with Access

This support ticket is created 5 years ago. There's a good chance that you are reading advice that it now obsolete.

This is the technical support forum for Toolset - a suite of plugins for developing WordPress sites without writing PHP.

Everyone can read this forum, but only Toolset clients can post in it. Toolset support works 6 days per week, 19 hours per day.

Sun Mon Tue Wed Thu Fri Sat
- 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 7:00 – 14:00 -
- 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 15:00 – 16:00 -

Supporter timezone: Europe/London (GMT+00:00)

This topic contains 6 replies, has 2 voices.

Last updated by Vane 4 years, 12 months ago.

Assisted by: Nigel.

Author
Posts
#1442245

Hello,

I defined a custom role with Access and I want to allow them only to create, delete, edit and publish their own CPT posts, but I don't want them to reach WP admin area, I want them to do those operations via Toolset Forms.
I created a test user with that custom role but it reaches backend and I'm not able to figure out if, where and how can I do that?

Thank you

#1442377

Nigel
Supporter

Languages: English (English ) Spanish (Español )

Timezone: Europe/London (GMT+00:00)

Toolset doesn't include any way to restrict registered users from accessing the backend pages.

You can use another plugin for this, such as https://wordpress.org/plugins/remove-dashboard-access-for-non-admins/

Or if you don't want to add a plugin, you could use a PHP snippet to redirect users to the homepage when they try to access the backend. Here's an example which you could modify for your needs: hidden link

#1442427

Hi,

thank you for your response.

[partial solution]
We have to uncheck "read" capability at Change Permission / Other capabilities.

( "Read" capability is described here:
https://wordpress.org/support/article/roles-and-capabilities/#read )

Though the top (black) admin bar is still shown and I either would like to disable it for some roles or use a custom login etc. page / URL for all roles except Admins.
In which Toolset folder / file are the custom roles and capabilities are stored?
I watched a Udemy WP course where it is modified (disable admin top bar), so I can tweak the code if I know where it is.

Thank you

#1442559

Nigel
Supporter

Languages: English (English ) Spanish (Español )

Timezone: Europe/London (GMT+00:00)

Access doesn't let you remove the read capability.

On your site, which roles do you want to be able to access the backend?

Where do you want other users that try to access the backend be redirected?

#1442569

Access allowed me to do that!
"We have to uncheck "read" capability at" ...Specific Custom Role... "Change Permission / Other capabilities."
Pls. note it is set for a CPT and not for the default WP post.

- "which roles do you want to be able to access the backend"
only Admin.

- "Where do you want other users that try to access the backend be redirected?"
either to a custom registration / login page( with embedded Forms' form ) or to a popup Forms' form used for reg / login.

#1442663

Nigel
Supporter

Languages: English (English ) Spanish (Español )

Timezone: Europe/London (GMT+00:00)

Hmm, the current versions of Access won't let me do that, but in any case it doesn't really help, because that alone doesn't achieve what you want.

If you don't want to use another plugin, you should add a PHP snippet for this. You want it to run earlier than when using Toolset > Settings > Code Snippets, so add the following to your theme's functions.php instead:

function ts_lockout_dashboard() {
    if ( is_admin() && !current_user_can('administrator') ) {
        wp_redirect( home_url( '/login/' ) );
        die();
    }
}
add_action('init', 'ts_lockout_dashboard');

You will need to create your custom login page. This code snippet assumes it has a slug of "login", which you would need to modify if you create a log-in page with a different slug.

Can you try that?

#1444625

Thank you!