View Admin As

Description

The ultimate User switcher and Role manager

This plugin will add a menu item to your admin bar where you can change your view in the WordPress admin.
Switch to other users without the need to login as that user or even switch roles and temporarily change your own capabilities.

When you’re viewing as a different user, you can also change this user’s preferences; like screen settings on various admin pages.

With the “Role defaults” module you can set default screen settings and metabox locations for roles and apply them to users through various bulk actions.

It also features a “Role manager” module to add, edit or remove roles and grant or deny them capabilities.

Overview / Features

  • Switch between user accounts
    • Edit this user’s screen preferences and settings
  • Switch between roles
  • Temporarily change your own capabilities (non-destructively)
  • View your site as an unregistered visitor
  • Switch language/locale on backend and frontend
  • Make combinations of the above view types
  • Easily switch back anytime
  • Completely secure (see Security below)
  • Do all the above without logging out!

Module: Role defaults (screen settings)

  • Set default screen settings for roles
  • Apply defaults to a user
  • Apply defaults to all users of a role
  • Apply defaults when registering a new user (in a multisite this is done when a user is added to its first blog)
  • Copy defaults from one role to another (or multiple)
  • Import/Export role defaults, can also download (and upload) setting files
  • Disable the “screen settings” option and/or lock the meta boxes for all users that don’t have access to this plugin

Click here for Role Defaults documentation

Module: Role manager (role editor)

Note: Changes made with the Role Manager are permanent!

  • Add, edit or delete roles
  • Grant and/or add capabilities to roles
  • Rename roles
  • Clone roles
  • Import/Export roles, can also download (and upload) setting files
  • Update role capabilities from current view
  • Automatically migrate users to another role after deleting a role

Click here for Role Manager documentation

Compatibility & Integrations

This plugin will work with most other plugins but these are tested:

  • Advanced Access Manager (Pro version not verified)
  • bbPress
  • BuddyPress
  • Genesis Framework (and probably other theme frameworks)
  • Google Site Kit
  • Gravity Forms
  • Groups 2.1+ (Custom integration: adds a view type for groups. Pro version not tested)
  • Pods Framework 2.0+
  • Members
  • Restrict User Access 0.13+ (Custom integration: adds a view type for access levels)
  • User Roles and Capabilities
  • User Role Editor (Pro version not verified)
  • User Switching (Not sure why you’d want this but yes, switch-ception is possible!)
  • WPFront User Role Editor
  • WP Admin UI Customize 1.5.11+
  • Yoast SEO

Full list of tested plugins and details: Compatibility & Integrations

I can’t switch back!

See item 3 at FAQ.

It’s not working! / I found a bug!

Please let me know through the support and add a plugins and themes list! 🙂

Security

This plugin is completely safe and will keep your users, passwords and data secure.
For more info see item 7 at FAQ!

Developer notes

This plugin will only be useful for admins (network super admins or regular admins). It will not add functionalities for other roles unless you specifically apply custom capabilities for those users.
Also keep in mind that switching to users that have equal roles is disabled. (regular admins to regular admins + super admins to super admins)

I’ve created this at first for myself since I’m a developer and often need to see the outcome on roles which my clients use.

So, when you are developing a plugin or theme that does anything with roles or capabilities you can use this plugin to easily check if everything works.
No more hassle of creating test users and constantly logging out and in anymore!

This plugin is also useful to support your clients and/or users. For example; make screen display presets of the edit and overview pages before you let them log in.

You can find me here:

Translations

Please help translating this plugin on translate.wordpress.org!

Actions & Filters

Plugin capabilities

Click here for documentation

Ideas?

Please let me know on GitHub!

Screenshots

  • Default dropdown
  • Dropdown with grouped users
  • Search users
  • Quickly (de)select capabilities
  • Large popup for better overview of capabilities
  • Admin bar when a view is selected + the reset button location
  • Settings window
  • Module Role defaults window (tabs are normally closed)
  • Module Role manager main window (tabs are normally closed)
  • Module Role manager capability window (tabs is normally closed)
  • View combinations
  • Access levels taken from the “Restrict User Access” plugin

Installation

Installation of this plugin works like any other plugin out there. Either:

  1. Upload and unpack the zip file to the ‘/wp-content/plugins/’ directory
  2. Activate the plugin through the ‘Plugins’ menu in WordPress

Or search for “View Admin As” via your plugins menu.

Minimum Requirements

  • WordPress 4.1 or greater (Though I always recommend to update to the latest version!)

Install as a must-use plugin

Move the view-admin-as.php file into the root of your mu-plugins directory, not in the view-admin-as subdirectory.
This is a limitation of WordPress and probably won’t change soon.

Example:
All files dir: /wp-content/mu-plugins/view-admin-as/...
Main file dir: /wp-content/mu-plugins/view-admin-as.php

FAQ

1. How do I switch to a user, role or visitor?

Just click on the link in the toolbar!

If the amount of users and roles combined is more than 15 you can find the users under their roles or you can search for them.

If the amount of users is more than 100 the plugin will switch to AJAX search and won’t load users in advance for performance.
This limit can be changed through the filter: view_admin_as_user_query_limit

2. How does the capability system work?

Only the capabilities that are allowed for your user are shown.
You can deselect the capabilities by clicking on them. When you would like to see the results just click the apply button on the upper left.

Please note that as an administrator you don’t have all capabilities marked as enabled by default. This is because WP overrules some capability checks for super admins. This does not happen when you are in a view!

You can also filter the roles by name or select/deselect all capabilities.
Note: When you select/deselect capabilities while you’ve filtered them only the capabilities shown by your filter are affected!

When you disable a capability that prevents you from viewing a screen, you can reset the view, see next item.

3. I can’t switch back!

When a view is selected there is a reset button available on the dropdown.
If you get a 403 page of WordPress you can return with the link that this plugin will add to those pages.
And if even that doesn’t work just add “?reset-view” in the address bar and you’re good to go! This will work on all pages as long as you are logged in.

Example: http://www.your.domain/wp-admin/?reset-view

4. How do the Role Defaults and Role Manager modules work?

5. I can’t find a user!

Could it be that this user is an equal user to your’s? Example: you are both Admins?
If so, these are filtered. Viewing Admins can only be done when you are a Super Admin within a network installation.

Why? To protect your fellow admin! You have no power over equal users..
Unless you are a superior admin… Read more

If this is not the case, please make sure you aren’t overlooking something.
If that is not the case, please contact me! See next item.

6. It’s not working! / I found a bug!

Please let me know through the support and add a plugins and themes list! 🙂

7. Is this plugin safe? Even for production websites?

You have nothing to worry about.
All the plugin functionality is only run if the user is logged in AND is allowed to use this plugin (website admin or custom capabilities).
This plugin will do absolutely nothing if the above requirements are not met.

  • Your view is stored separately so your user will keep the normal roles and capabilities.
  • All settings, views, capabilities, etc. are verified before applied.
  • Passwords are not (and cannot be) revealed.
  • Fully written with the WordPress coding and security standards.
  • Full support for SSL (https).

So basically if your admin users are safe, this plugin will be safe.
Note: if your admin users aren’t safe, this plugin is the last one to worry about 😉

8. Does this plugin work as a must-use plugin (mu-plugin)?

Yes, see Install as a must-use plugin on the Installation tab.

Reviews

Yune 15, 2024
It works like a charm. Fast and without any errors. Essential if you use multiple roles and want to see how each user views the web page immediately. Thank you!! Funciona de maravilla, rápido y sin ningún fallo. Imprescindible si usas varios roles y quieres ver como cada usuario ve la página web de forma inmediata. Gracias!!
Aprailu 3, 2023 1 reply
I’ve installed this plugin on a woocommerce build, to help me with setting capabilites and access for the client. This plugin does it all, and is meticulously designed. Thank you to the developer. I can only imagine the herculean effort that went into this. I will donate towards continued development as soon as I’m able. Happy devving!
Nuwamba 14, 2022 1 reply
Super useful, does what it says and does it well. Thank you for your work on this. Marc.
Aprailu 13, 2022
Simply had to check the website from other point of view. Work like a charm.
Read all 47 reviews

Contributors & Developers

“View Admin As” is open source software. The following people have contributed to this plugin.

Contributors

“View Admin As” has been translated into 14 locales. Thank you to the translators for their contributions.

Translate “View Admin As” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.

Changelog

1.8.9

  • Fix: Event bubbling for select elements #130
  • Fix: Check if removable query args exists before adding removal script on front-end

Detailed info: PR on GitHub

1.8.8

  • Enhancement: RTL support. #122
  • Enhancement: User context for checking the edit_user capability.
  • Enhancement: Enhance front-end CSS by preventing theme overrides. #120
  • Enhancement/Fix: JSON/REST call checks.

Detailed info: PR on GitHub

1.8.7

  • Enhancement: Added hooks vaa_view_admin_as_reset_all_views, vaa_view_admin_as_cleanup_views, vaa_view_admin_as_reset_view, vaa_view_admin_as_update_view.
  • Enhancement/Compatibility: Fix compatibility issue with MetaSlider block preview (JSON/AJAX requests) #117
  • Compatibility: Fixed issues with capability filters overwriting available capabilities.
  • Compatibility: Remove redundant canonical tag. #119
  • Compatibility: WordPress 5.7 UI.
  • Fixed: Missing textdomain parameter.
  • Refactor: Added action logs.
  • Refactor: Enhance view type classes.

Detailed info: PR on GitHub

1.8.6

  • Compatibility: WordPress 5.4 apply_shortcodes() function. #111
  • Compatibility: Add Google Site Kit capabilities. #110
  • Compatibility: User Role Editor capability filter format. #112
  • Enhancement: Always show force-ajax-users setting to optionally prevent query.

Detailed info: PR on GitHub

1.8.5

  • Compatibility: CSS compatibility for WP 5.3
  • Compatibility: Roles are now translated in all cases since WP 5.2.
  • Enhancement: JS performance.
  • Enhancement: Enhance AJAX checks.

Detailed info: PR on GitHub

1.8.4

  • Enhancement: Role Manager: Reload when in a user view and the user’s role has been modified. #105
  • Compatibility: WordPress 5.2 admin bar arrow icon update. WP Core #37513
  • Compatibility: Dark Mode (Github)
  • Fix: Role Defaults: Only return screen setting overwrite if found. #104
  • API: Added API method is_view_active(). (Documentation)

Detailed info: PR on GitHub

1.8.3

  • Compatibility: Users always have the exists capability. Go to issue
  • Compatibility: WordPress 4.9.6 privacy capabilities.
  • API: Added several API methods & enhancements.

Detailed info: PR on GitHub

1.8.2

  • Enhancement/Fix: Support AJAX search in the Role Defaults module. #100
  • Enhancement: Add support for X-Redirect-By header since WordPress 5.0. #42313
  • Enhancement: Improve uninstall script.
  • Enhancement: Use latest WPCS v1.1 update and fix code standard notices.
  • UI: Change the default top level node text to “View As” (same as Facebook uses).
  • Updated: Screenshots

Detailed info: PR on GitHub

1.8.1

  • Feature: Support searching users by multiple user columns like email, url, etc. #95
  • Feature: User setting to force AJAX search for users. #96
  • Feature: New filter: view_admin_as_user_ajax_search to force AJAX search for user at all times.
  • Fix: Prevent “form changed” popup which showed in various pages. #93
  • Enhancement: Improve Pods Framework compatibility when in a view.
  • Enhancement: Improve getting view data on load.

Detailed info: PR on GitHub

1.8

  • Feature: View combinations UI. #18
  • Feature/Enhancement: Limit user query to max 100 users for performance. Switch to AJAX search if there are more users than this limit. #19
  • Accessibility: New filter: view_admin_as_user_query_limit to change the limit used to query users.
  • Accessibility: New filters: vaa_admin_bar_view_title_role & vaa_admin_bar_view_title_user & vaa_admin_bar_view_title_locale to change the titles for role, users and languages.
  • Accessibility: New filter: vaa_admin_bar_view_title_user_show_roles to remove the roles from user nodes.
  • Accessibility: New filter: view_admin_as_full_access_capabilities for single site installations to change the capabilities required to gain full access to this plugin.
  • Enhancement: Use a class autoloader.
  • Enhancement: Stop using the rel attribute for view type data.
  • Enhancement: Access validation logic.
  • Compatibility: Patch Yoast SEO compatibility. Yoast SEO #9365
  • Refactoring: Action/Filter hook manager class. #77
  • Refactoring: Refactor all view types as separate modules. #84
  • Fix: Use prop instead of attr for checked attributes in checkbox inputs.
  • Updated/Added: Screenshots.

Detailed info: PR on GitHub

Older versions

Complete changelog