WordPress Settings API "Cheatin' Uh?" Error
-
To follow the previous conversation leading to this post view the thread here.
Looks like a fix for the Cheatin Uh error for roles who don’t have access to manage_options with the Settings API make it into version 3.3 of WordPress. To follow the progress on this check out the current standing track ticket https://core.trac.www.ads-software.com/ticket/14365.
In the meantime here is a workaround below for those of us who want to create special roles like “Admin Light” and still use the settings API without giving them manage_options access. It isn’t the best solution, but will have to do for now unless somebody comes up with something better. Hopefully this saves you several traumatizing hours of searching and banging your head on a keyboard.
1. You’ll need to add manage_options to the role type.
2. Strip the settings menu from the role type with the code below. While they might be still be able to access this with the exact URL structure, this should be enough to keep them out of the settings they don’t belong in and plugins. The odds of them chucking in the exact URL structure are slim to none so please don’t argue with me on this. Also, this means you’ll want to include your special menu somewhere other than Settings.
In functions.php
function remove_menus () { // Choose an option that the custom role doesn't have access to if(! current_user_can('update_core')) { global $menu; $restricted = array(__('Settings')); end ($menu); while (prev($menu)){ $value = explode(' ',$menu[key($menu)][0]); if(in_array($value[0] != NULL?$value[0]:"" , $restricted)){unset($menu[key($menu)]);} } } } add_action('admin_menu', 'remove_menus');
Does anyone have a better solution for this other than editing the WP core files?
- The topic ‘WordPress Settings API "Cheatin' Uh?" Error’ is closed to new replies.