WP-Hide has launched the easiest way to completely hide your WordPress core files, login page, theme and plugins paths from being shown on front side. This is a huge improvement over Site Security, since no one will know whether you are running or not a WordPress. It also provides a simple way to clean up html by removing all WordPress fingerprints.
No file and directory change!
No file and directory will be changed anywhere. Everything is processed virtually. The plugin code uses URL rewrite techniques and WordPress filters to apply all internal functionality and features. Everything is done automatically without user intervention required at all.
Real hide of WordPress core files and plugins
The plugin not only allows you to change default URLs of you WordPress, but it also hides/blocks such defaults. Other similar plugins, just change the slugs, but the defaults are still accessible, obviously revealing WordPress as CMS.
You can change the default WordPress login URL from wp-admin and wp-login.php to something totally arbitrary. No one will ever know where to try to guess a login and hack into your site. It becomes totally invisible.
Full plugin documentation available at WordPress Hide and Security Enhancer Documentation
When testing with WordPress theme and plugins detector services/sites, any setting change may not reflect right away on their reports, since they use cache. So, you may want to check again later, or try a different inner URL. Homepage URL usage is not mandatory.
Being the best content management system, widely used, WordPress is susceptible to a large range of hacking attacks including brute-force, SQL injections, XSS, XSRF etc. Despite the fact the WordPress core is a very secure code maintained by a team of professional enthusiast, the additional plugins and themes make ita vulnerable spot for every website. In many cases, those are created by pseudo-developers who do not follow the best coding practices or simply do not own the experience to create a secure plugin.
Statistics reveal that every day new vulnerabilities are discovered, many affecting hundreds of thousands of WordPress websites.
Over 99,9% of hacked WordPress websites are target of automated malware scripts, which search for certain WordPress fingerprints. This plugin hides or replaces those traces, making the hacking boots attacks useless.
It works well with custom WordPress directory structures,e.g. custom plugins, themes, and upload folders.
Once configured, you need to clear server cache data and/or any cache plugins (e.g. W3 Cache), for a new html data to be created. If you use CDN this should be cache clear as well.
Main plugin functionality:
- Customizes Admin URL
- Blocks default admin URL
- Blocks any direct folder access to completely hide the structure
- Customize wp-login.php filename
- Blocks default wp-login.php
- Blocks default wp-signup.php
- Blocks XML-RPC API
- Creates New XML-RPC paths
- Adjusts theme URL
- Creates New child Theme URL
- Changes theme style file name
- Cleans any headers for theme style file
- Customizes wp-include
- Blocks default wp-include paths
- Blocks default wp-content
- Customizes plugins URL
- Changes Individual plugin URL
- Blocks default plugins paths
- Creates New upload URL
- Blocks default upload URL
- Removes WordPress version
- Blocks Meta Generator
- Removes pingback tag
- Removes wlwmanifest Meta
- Removes rsd_link Meta
- Removes wpemoji
and many more.
No other plugin functionality will be blocked or interfered in any way by WP-Hide
This plugin allows to change the default Admin URL from wp-login.php and wp-admin to something else. All original links turn the default theme to “404 Not Found” page, as if nothing exists there. Besides the huge security advantage, the WP-Hide plugin saves lots of server processing time by reducing php code and MySQL usage since brute-force attacks target the weakURL.
Important: Compared to all other similar plugins which mainly use redirects, this plugin turns a default theme to“404 error” page for all blocked URL functionalities, without revealing the link existence at all.
Since version 1.2, WP-Hide change individual plugin URLs and made them unrecognizable. For example,the change of the default WooCommerce plugin URL and its dependencies from domain.com/wp-content/plugins/woocommerce/ into domain.com/ecommerce/cdn/ or anything customized.
**Hide -> Scan
- Exhaustive system security examination with analysis and improvements guidance and fixes
Hide -> Rewrite > Theme
- New Theme Path – Changes default theme path
- New Style File Path – Changes default style file name and path
- Remove description header from Style file – Replaces any WordPress metadata information (like theme name, version etc.,) from style file
- Child – New Theme Path – Changes default child theme path
- Child – New Style File Path – Changes child theme style-sheet file path and name
- Child – Remove description header from Style file – Replaces any WordPress metadata information (like theme name, version etc.,) from style file
Hide -> Rewrite > WP includes
- New Include Path – Changes default wp-include path/URL
- Block wp-include URL – Blocks default wp-include URL
Hide -> Rewrite > WP content
- New Content Path – Change default wp-content path/URL
- Block wp-content URL – Blocks the default content URL
Hide -> Rewrite > Plugins
- New Plugin Path – Changes default wp-content/plugins path/URL
- Block plugin URL – Blocks default wp-content/plugins URL
- New path / URL for Every Active Plugin
- Customize path and name for any active plugins
Hide -> Rewrite > Uploads
- New Upload Path – Changes default media files path/URL
- Block upload URL – Blocks default media files URL
Hide -> Rewrite > Comments
- New wp-comments-post.php Path
- Block wp-comments-post.php
Hide -> Rewrite > Author
- New Author Path
- Block default path
Hide -> Rewrite > Search
- New Search Path
- Block default path
Hide -> Rewrite > XML-RPC
- New XML-RPC Path – Changes default XML-RPC path / URL
- Block default xmlrpc.php – Blocks default XML-RPC URL
- Disable XML-RPC authentication – Filters whether XML-RPC methods require authentication
- Remove pingback – Removes pingback link tag from theme
Hide -> Rewrite > JSON REST
- Clean the REST API response
- Disable JSON REST V1 service – Disables an API service for WordPress which is active by default
- Disable JSON REST V2 service – Disables an API service for WordPress which is active by default
- Block any JSON REST calls – Any call for JSON REST API service will be blocked
- Disable output the REST API link tag into page header
- Disable JSON REST WP RSD endpoint from XML-RPC responses
- Disable Sends a Link header for the REST API
Hide -> Rewrite > Root Files
- Block license.txt – Blocks access to license.txt root file
- Block readme.html – Blocks access to readme.html root file
- Block wp-activate.php – Blocks access to wp-activate.php file
- Block wp-cron.php – Blocks outside access to wp-cron.php file
- Block wp-signup.php – Blocks default wp-signup.php file
- Block other wp-*.php files – Blocks other wp-.php files within WordPress Root
Hide -> Rewrite > URL Slash
- URL’s add Slash – Add a slash to any links without it. This disguisesthe existence of a file, folder or a wrong URL, which will all be slashed.
Hide -> General / Html > Meta
- Remove WordPress Generator Meta
- Remove Other Generator Meta
- Remove Shortlink Meta
- Remove DNS Prefetch
- Remove Resource Hints
- Remove wlwmanifest Meta
- Remove feed_links Meta
- Disable output the REST API link tag into page header
- Remove rsd_link Meta
- Remove adjacent_posts_rel Meta
- Remove profile link
- Remove canonical link
Hide -> General / Emulate CMS
- Emulate CMS
Hide -> General / Html > Admin Bar
- Remove WordPress Admin Bar for specified urser roles
Hide -> General / Feed
- Remove feed|rdf|rss|rss2|atom links
Hide -> General / Robots.txt
- Disable admin URL within Robots.txt
Hide -> General / Html > Emoji
- Disable Emoji
- Disable TinyMC Emoji
Hide -> General / Html > Styles
- Remove Version
- Remove ID from link tags
Hide -> General / Html > Scripts
- Remove Version
Hide -> General / Html > Oembed
- Remove Oembed
Hide -> General / Html > Headers
- Remove Link Header
- Remove X-Powered-By Header
- Remove Server Header
- Remove X-Pingback Header
Hide -> General / Html > HTML
- Remove HTML Comments
- Remove general classes from body tag
- Remove ID from Menu items
- Remove class from Menu items
- Remove general classes from post
- Remove general classes from images
Hide -> General / Html > User Interactions
* Disable Mouse right click
* Disable Text Selection
* Disable Copy
* Disable Cut
* Disable Paste
* Disable Print
* Disable Print Screen
* Disable Developer Tools
* Disable View Source
* Disable Drag / Drop
Hide -> Admin > wp-login.php
- New wp-login.php – Maps a new wp-login.php instead of the default one
- Block default wp-login.php – Blocks default wp-login.php file from being accessible
Hide -> Admin > Admin URL
- New Admin URL – Creates a new admin URL instead of the default ”/wp-admin”. This also applies for admin-ajax.php calls
- Block default Admin Url – Blocks default admin URL and files from being accessible
Settings -> CDN
- CDN Url – Sets-up CDN if applied. Some providers replace site assets with custom URLs.
Security -> Headers
HTTP Response Headers are a powerful tool to Harden Your Website Security.
* Cross-Origin-Embedder-Policy (COEP)
* Cross-Origin-Opener-Policy (COOP)
* Cross-Origin-Resource-Policy (CORP)
* X-Frame-Options (XFO)
This free version works with Apache and IIS server types. For all server types, check with WP Hide PRO
This is a basic version that can hide everything for basic sites, example https://demo.wp-hide.com/. When using complex plugins and themes, the WP Hide PRO may be required. We provide free assistance to hide everything on your site, along with the commercial product.
Anything wrong with this plugin on your site? Just use the forum or get in touch with us at Contact and we’ll check it out.
Plugin homepage at WordPress Hide and Security Enhancer
This plugin is developed by Nsp-Code
Please help and translate this plugin to your language at https://translate.wordpress.org/projects/wp-plugins/wp-hide-security-enhancer
You are kindly asked to promote this plugin if it comes up to your expectations via an article on your site or any other place. If you liked this code/WP-Hide or if it helped with your project, why not leave a 5 star review on this board.
- Install the plugin through the WordPress plugins interface or upload the package to
- Activate the plugin through the ‘Plugins’ screen in WordPress.
- Use the WP Hide menu screen to configure the plugin.
Feel free to contact us at email@example.com for fast support.
Does the plugin change anything on my server?
No files and directories will be changed on your server, since everything is processed virtually. The plugin code use URL rewrite techniques and WordPress filters to apply all internal functionalities and features.
Since I have no PHP knowledge at all, is this plugin for me?
There is no requirement for php knowledge. All plugin features and functionalities are applied automatically, controlled through a descriptive admin interface.
Is there any demo I can check?
Can I use the plugin on my Nginx server?
If the server runs full-stack Nginx, the free plugin can’t generate the required format Nginx rewrite rules. It works with Apache, LiteSpeed, IIS, Nginx as a reverse proxy and compatible.
Can I still update WordPress, my plugins and themes?
Everything works as before, no functionality is being broken. You can run updates at any time.
Does the plugin affect the SEO aspects of my website?
Does the plugin work with my site cache?
Yes, the plugin works with any cache plugin deployed on your site.
What are HTTP Security Headers?
HTTP Response Headers are a powerful tool to Harden Your Website Security. The plugin provides an easy way to add Security Response Headers through a graphical interface. No additional codding and file editing is necessary.
What servers this plugin can work with?
This free code/WP-Hide can work with Apache, IIS server types and any other set-up which rely on .htaccess usage.
For all other cases, check the PRO version at WP Hide PRO
How to make it work with my OpenLiteSpeed server?
There are few things to consider when you run on litespeed servers:
Ensure the liteserveractually processes the .htaccess file, where the rewrite data is being saved. Check with the following topic regarding this issue Post
If you use Litespeed Cache plugin, in the Optimization Settings area, disable the CSS / JS Minify
If your litespeed server requires to place the rewrite lines in a different file,e.g. config file or interface, consider upgrading to PRO version which includes a Setup page where you can get the rewrite code WP Hide PRO.
How to use on my Bitnami setup?
As default, on Bitnami LAMP set-ups, the system will not process the .htaccess file, so none of the rewrites will work. You can change this behavior by updating the main config file located at /opt/bitnami/apps/APPNAME/conf/httpd-app.conf , update the line
Restart the Apache service through SSH
sudo /opt/bitnami/ctlscript.sh restart
More details can be found at Bitnami Default .Htaccess
.htaccess file writing error – Unable to write custom rules to your .htaccess. Is this file writable?
I’m seeing this error “Unable to write custom rules to your .htaccess. Is this file writable”? What does it mean?
The error appears when the plugin is not able to write to .htaccess file located in your WordPress root directory. You can try the followings to make a fix:
Check if your .htaccess file is writable. This can be different from server to server, but usually require rw-rw-r– / 0664. Also ensure the file owner is the same group as php.
Sometimes the other codes wrongly use the flush_rules() which hijack the default filters for rewrite. Try to disable the other plugins and theme to figure out which ones produce the issue.
De-activate and RE-activate the plugin, apparently worked for some users.
Create a backup of .htaccess, then delete it from the server. Go to Settings > Permalinks > update once, this should create the file again on the WordPress root. If so, try to change any WP Hide options which will update the .htaccess content accordingly.
Something is wrong, what can I do? How can I recover my site?
- There will be no harm.
- Go to admin and change some of the plugin options to see which one causes the problem. Then report it to the forum or get in touch with us to fix it.
- If you can’t log in to admin, use the Recovery Link which has been sent to your e-mail. This will reset the login to default.
If you can’t find the recovery link or none of the above worked, delete the plugin from your wp-content/plugins directory. Then remove any lines in your .htaccess file between:
BEGIN WP Hide & Security Enhancer
END WP Hide & Security Enhancer
At this point, the site should run as before. If for some reason still not working, you missed something, please get in touch with us at firstname.lastname@example.org and we’ll fix it for you in no time!
The Recovery Link can be used to reset all plugin options and restore the site to the default state.
The link should be entered into the browser URL bar. After the operation is completed, a system message will show “The plugin options have been reset successfully”.
If the message does not show, there is a cache on your site that prevents the code to run. Locate your cache data, usually at /wp-content/cache/ and remove the files. Then re-load the recovery link.
What to do if I can’t find a functionality that I’m looking for?
Please get in touch with us and we’ll do our best to include it inthe next version.
Contributors and Developers
“WP Hide & Security Enhancer” is open source software. The following people have contributed to this plugin.Contributors
- Use transient for domain_get_ip to avoid execution delays with certain hosts.
- Separate options for Copy / Cut / Paste into the User Interactions interface for better control over the options
- Few Typos fix
- Compatibility updates for TranslatePress – Multilingual
- New filter wph/components/components_run/ignore_component which allows selective disabling for specific components to apply on the front site
- Set minimum required WordPress version as 4.0
- Set minimum required PHP version as 5.4
- Relocate the plugins_themes_compatibility prior module components initialization.
- Avoid looping with certain 3rd codes by caching the home url.
- HTML Comments removal regex updates.
- Compatibility update for qTranslate-XT plugin, when using the option redirect to language and customizing the default login url through WP Hide
- Use regex patterns for Scan – Replacements, for better accuracy in the identification of the fingerprints proposed to be changed.
- Deprecated Expect-CT.
- Remove the Expect-CT from the recommended headers.
- Suppress the option to block the Developer Tools / Inspect when page/post preview.
- Add to cache clear for Autoptimize, Perfmatters, Breeze, Site Ground Cache, when flushing the caches.
- Site Ground Cachepress plugin compatibility update
- WordPress compatibility check for 6.2
- WordPress compatibility tag update.
- Decrease the Scan progress background AJAX update, to avoid time-outs on slow connections.
- New Screenshot for better pre-visualization of the actual interface.
- Fix: Scan Admin component, Fix button URL.
- New Security Headers component – Referrer-Policy.
- Check the post meta and option value if serialized ( double serialization ), before reversing the URLs.
- Code improvements.
- Updated translation PO file.
- Replaced the deprecated Feature-Policy with Permissions-Policy security header.
- Fix: Scan disable redirects when testing firewall, to ensure correct results
- Fix count() error for not countable variable.
- PO language file updates
- Add additional description for potentially dangerous files found within WordPress root.
- Typo fix for “Dangerous Files”
- Fix: Undefined variable $site_score within render_overview()
- Fix: Divided by zero when calculating the overall scan progress
- Fix: Wrong remote_html variable
- New feature – Security Scan.
- Security Scan dashboard widget
- Inform on possible LiteSpeed service restart if use such system.
- Check if HTTP_USER_AGENT environment variable exists before making comparison.
- Fix Oxigen compatibility when using the HTML Minify.
- Fix: Cache Enable static call.
- New component Headers -> Remove Server Header.
- Prevent output of “document.addEventListener” unless an user-interaction option is active.
- Add X-XSS-Protection into the headers list, to avoid reporting as not used as security header.
- Code Improvements and clean-up.
- PO language file update.
- Ignore the “Disable Developer Tools” on iPhone
- WordPress 6.1 compatibility tag
- Fix: Security headers progress comparison step.
- Slight css changes
- Improved Disable Developer Tools feature, by returning an empty page.
- W3 Total Cache – implements support for Push CDN and custom folders
- Compatibility fix with JCH Optimize.
- Ignore invalid SSL certificate when testing rewrites, to allow local instances.
- Fix: static to public functions for a2-optimized compatibility class.
- Fix: use preg_match to ensure the HTML data is valid and avoid faulty code with multiple head tags.
- Slight text changes within some options, for better explanations.
- New options interface – User Interactions: Disable Mouse right click, Disable Text Selection, Disable Copy / Paste, Disable Print, Disable Print Screen, Disable Developer Tools, Disable View Source, Disable Drag / Drop
- Better accessibility for additional details regarding each of the options.
- Improved progress score calculation for Headers.
- A2 Optimized WP – compatibility fix.
- WordPress 6.0.2 tag compatibility update
- Fix CDN option external help page URL.
- Improved server environment rewrite test checking routines.
- Separate rewrite tests for static files and PHP files. This avoids reporting issues for servers not supporting rewrites for php-files.
- Add a new button to reset the current page options.
- Use regex to sanitize the URL arguments
- Relocated the Reset All Settings button to the bottom of the interface.
- Compatibility for Super Page Cache for Cloudflare
- Slight layout improvements and changes.
- WordPress 6.0.1 compatibilit tag
- Change the advanced_notice class within the interfaces to avoid issues caused by 3rd theme.
- Do not remove comments when json request
- WordPress 6.0 compatibilit tag
- When checking and calculating the the Headers protection score, ignore the SSL verification for the domain, to allow usage of invalid certificates.
- Check if set headers are actually passed-through on the front side, as some servers may block that.
- Set WP_ROCKET_WHITE_LABEL_FOOTPRINT to remove the footer comment for WP Rocket, when active
- New Security Functionality – Headers. HTTP Response Headers are a powerful tool to Harden Your Website Security.
- Security Headers – Cross-Origin-Embedder-Policy (COEP), Cross-Origin-Opener-Policy (COOP), Cross-Origin-Resource-Policy (CORP), X-Content-Type-Options, X-Download-Options, X-Frame-Options (XFO), X-Permitted-Cross-Domain-Policies, X-XSS-Protection.
- Security Headers – Protection Level graph
- Security Headers – Sample Setup
- Security Headers – Recovery functionality
- Styles and layout improvements
- Code clean-up
- Fix: Append URL arguments to login URL, if exists
- Run on revision posts, to match URLs and revert to default WordPress ( e.g. when using Gutenberg editor )
- Require a .php for the customization of the default wp-login.php to avoid cookie issues on password change area.
- WooCommerce 5.9 compatibility check and tag.
- Fix: If Emulate CMS active, ensure the buffer is an HTML content
- New functionality, block wp-json for everyone or non-logged-in users.
- Fix Emulate CMS documentation url.
- Removed Twitter share.
- New plugin feature: Emulate CMS
- Update PO language file
- Skip comment removal when admin dashboard.
- Fix: Ignore comment removal when Gutenberg JSON call for blocks, to avoid formatting issues.
- Ensure compatibility with PHP 8.0
- Update PO language file
- Update documentation URLs within the plugin interfaces, with the non-www domain wp-hide.com
- Include the “Clean the REST API response” within Sample Setup.
- New option for JSON REST module – “Clean the REST API response”
- Relocated Feed tab to Rewrite module
- Output the help title only if there’s an help section available through the module settings
- Fix undefined $found_issues
- WordPress 5.8 compatibility tag
- Add dashboard and cpanel to system reserved to avoid permalinks conflicts
- LiteSpeed Cache compatibility update
- WP-Optimize compatibility update
- Update compatibility file for TranslatePress – Multilingual
- Fix attachment_url_to_postid
- Fix undefined get_metadata_raw
- Confirmation page for Recovery link
- Use home_url() instead site_url() for recovery links to ensure the format is correct for WordPress instances using own directory
- Trigger the login URL change e-mail at shutdown instead init
- Compatibility with TranslatePress – Multilingual
- Fix undefined notice
- Fix meta Uncaught TypeError: count(): Argument
- Slight code improvements
- Improved description for Test Rewrite procedure, when the server fails to provide a valid response, rewrite engine is not active or the custom urls are not allowd.
- Fixed Undefined Property Notice
- Server Environment Check to ensure there are no rewrite issues and the plugin can be safely deployed.
- Interactive feedback with hints and explanations for environment issues.
- Improved UI
- Clear fusion cache when plugin options changed if avada active
- Fix New Search Path replacement to include an end slash, to avoid catch wrong urls
- Check and tag for WordPress 5.7
- Fix: Add slash for “New Search Path” to avoid wrong replacements with urls containing the new search slug.
- Reverse URLs when saving a options, to avoid custom urls to be writted within the database.
- Check if string before making a replacement on metadata
- Compatibility file for Oxigen editor, when using Signatures
- Simple Firewall compatibility file update – check if FernleafSystems\Wordpress\Plugin\Shield\Controller\Controller class exists before apply
- Update Compatibility file with Oxygen editor, for image with link wrapper
- WordPress 5.6 compatibility tag update
- Compatibility file with Oxygen editor
- Fix: Check the replacements for update_post_metadata method on text and array types.
- Reverse URLs when saving a meta data field, to avoid custom urls to be writted within the database.
- Trigger a system notice when deployed on MultiSite, as not being compatible.
- Don’t run _init_remove_html_new_lines when AJAX call to avoid front side processing errors.
- WP Rocket compatibility file updates, to works with combined CSS assets
- Shield Security compatibility update, to works with version 10 and up.
- Prevent nottices and errors when attempt to rite on .htaccess file.
- New filter wph/components/wp_oembed_add_discovery_links to allow disabling the Remove Oembed – wp_oembed_add_discovery_links
- New filter wph/components/wp_oembed_add_host_js to allow disabling the Remove Oembed – wp_oembed_add_host_js
- New compatibility file for wePOS plugin
- New compatibility file for Asset CleanUp Pro Page Speed Booster plugin
- Compatibility with Hyper Cache
- Update JSON REST service disable, remove the json_enabled as being deprecated, rely on rest_authentication_errors filter
- Fix WooCommerce Update Database link when changing the default /wp-admin/ slug
- Fix password forget return URL
- Remove callback for Compatibility file for Shield Security within new-admin module
- Fix: Remove callback for Compatibility file for Shield Security within custom login module
- Compatibility file fix for Shield Security
- WordPress 5.5.1 compatibility tag
- Ignore CDN value check for domain name similitude
- LiteSpeed guide on Setup interface
- New functionality – Disable mouse right click
- Compatibility file – JobBoardWP
- Compatibility WP-Optimize – Clean, Compress, Cache
- WordPress 505 compatibility tag
- Avoid using domain name as replacement for any option, or might conclude to wrong replacements within the outputted HTML or wrong reversed urls.
- Add system reserved words as ‘wp’, ‘admin’, ‘admin-ajax.php’
- Slight General code improvements
- Clean cookie for the new custom slug, if set.
- Integration with WP-Optimize – Clean, Compress, Cache
- WP Job Manager – compatibility update
- New Setup interface with helps and hints on how to use the plugin.
- New Sample Setup, which deploy a basic set-up of plugin options
- Remove internal wp_mail and rely on WordPress core
- Improved FAQ area
- Updated base language file
- Purge cache for Fast Velocity Minify plugin, when clearing internal cache
- Return new admin slug when calling admin_url() and if default admin is customized
- Use no-protocol when loading the files, to ensure they are being loaded over current domain protocol
- BuddyPress compatibility file update
- Elementor compatibility file update
- ShortPixel Adaptive Images compatibility file update
- WooCommerce compatibility file update
- WP Rocket compatibility file update
- New compatibility file for Fast Velocity Minify
- New compatibility file for LiteSpeed Cache
- New compatibility file for Swift Performance
- New compatibility file for WP Speed of Light
- New filter wp-hide/content_urls_replacement
- Compatibility with Ultimate Member, user picture upload fix
- Updated compatibility with W3 Cache, using postprocessorRequire option
- Fluentform compatibility updates
- Outputs the whole stack of errors for $wp_filesystem if exists
- Typo fix in Uploads module
- Updated procedure for server type identification
- Add new type text/plain for filterable content
- Add server_nginx_config to main class, to be used within other modules
- Updated rewrite quantifier for IIS from .+ to .*
- Ignore wp-content block if agent is LiteSpeed-Image
- Updated is_filterable_content_type method, return TRUE if no Content-Type header found
- Fix readme demo site protocol
- Fix “undefined method WPH_functions::get_site_module_saved_value()” when content type is text/xml
- Check for filterable buffer content type, before doing replacements, to prevent erroneously changes
- Update only URLs on XML content type
- Updated plugin demo site URL on readme file
- Compatibility update for ShortPixel Image Optimizer plugin
- Notice possible issue for Cron block on certain servers
- New admin interfaces skin.
- Relocated plugin assets within a different folder for better organisator.
- Updated mu-loader module
- Add help and hints for each options for easier understanding.
- Allow same base slug to be used for individual plugins
- Updated language file
- Check if environment file is not available and outputs admin messages
- Environment class with relocated environment json, to avoid security scanners false reports.
- Cache Enabler plugin compatibility module
- WoodMart theme compatibility
- Compatibility module for WP Smush and WP Smush PRO plugins
- Add the new filter available for WP Rocket to change css content
- WebARX compatibility module update
- W3 Cache module update
- Ensure base slug (e.g. base_slug/slug ) is not being used for another option to prevent rewrite conflicts
- Return correct home path when using own directory for WordPress and hosting account use the same slug in the path.
- Relocated get_default_variables() function on a higher priority execution level, to get default system details.
- Switched Yes / No options selection, to outputs first No then Yes ( more logical )
- Add reserved option names to avoid conflicts e.g. wp
- Always clear any code plugin cache when plugin update
- Easy Digital Downloads compatibility
- Elementor plugin compatibility
- Fusion Builder plugin compatibility
- Divi theme compatibility updates
- WP Fastest Cache plugin compatibility updates
- Check if ob_gzhandler and zlib.output_compression before using ‘ob_gzhandler’ output buffering handler
- Autoptimize css/js cache and minify compatibility
- Wp Hummingbird and WP Hummingbird PRO assets cache compatibility
- New functionality: Remove Link Header
- Fix: Call for invalid method WP_Error::has_errors()
- Fix: Attempt to clear Opcache if API not being restricted
- Allow internal cron jobs to run even if wp-cron.php is blocked.
- Check with wp_filesystem for any errors and output the messages, before attempt to write any content
- Trigger site cache clear on settings changed or code update
- Slight css updates
- Mark block option in red text for better visibility and user awareness
- Fix: Keep double quote at the start of the replacements when doing JSON matches to avoid replacing strings for other domains
- Fix: Run compatibility pachage for “ShortPixel Adaptive Images” only when plugin is active
- Use current site prefix when retreiving ‘user_roles’
- Fix BBPress menus by calling directly the wp_user_roles option ratter get_roles()
- Possible login conflict notices when using WebArx, WPS Hide Login
- New action wp-hide/admin_notices when plugin admin notices
- Return updated url when calling admin_url instead replaced when buffer outputs to ensure compatibility with specific plugins
- Compatibility module for ShortPixel Adaptive Image plugin
- Add support for texarea fields within plugin options interface
- Fixed urls for minified files when using WP Rocket cache plugin
- Filter remove fix
- Fix log-in page when using Wp Rocket cache
- Fix admin dashboard replacements when using Wp Rocket cache
- Fix Wp Rocket cache when using Minify and Concatenation
- New functionality – Remove Admin Bar for specified roles
- Module block structure extend to support ‘callback_arguments’ to passThrough additional data to processing function
- Redirect the default non-pretty-url search url to customized one
- New component: Rewrite Author
- New component: Rewrite Search
- Show recovery link on top of page to ensure everyone can save the link to use if something goe wrong.
- Send recovery code to site admin e-mail
- Minor Code adjustments
- Send new login url to site admin e-mail, to ensure user can recover access to dashboard if forget new slug
- Removed unused methods within WPH_module_rewrite_new_include_path component
- Fix: Undefined method for WooCommerce compatibility module
- Allow rewrite for images within admin, as being reversed to default when saving the post
- Compatibility re-structure, use a general module
- Compatibility fix for Shield Security wp-simple-firewall
- Removed the upload_dir filtering as produce some issues on specific environment, possible incompatibilities will be post-processed within General compatibility module
- Filter the post content on save_post action, to reverse any custom slugs like media urls, to preserve backward compatibility, in case plugin disable
- Ensure wp-simple-firewall run once when called from multiple components
- Update for Rewrite Slash component, use a rewrite conditional to ensure the code is not trigger for POST method
- Fix JSON encoded urls when using SSL
- Remove _relative_domain_url_replacements_ssl_sq and _relative_domain_url_replacements_ssl_dq replacements for buffer as being integrated to other variables
- Relocated upload_dir() to general functions.php to catch new content and uploads slugs.
- Use full domain url for new wp-admin slug, instead relative to avoid wrong replacements for 3rd urls
- Use full domain url for new wp-login.php, instead relative to avoid wrong replacements for 3rd urls
- Typos fix for CDN texts
- Additional description for “Block any JSON REST calls” option to prevent Gutenberg block
- Updated rewrite for URL Slash to include a second conditional, to not trigger on POST calls
- Add trailingslashit to plugins slug to be used for replacements to avoid wrong (partial) slug changes
- Fixed upload rewrite by using default_variables[‘upload_url’]
- WordPrss 5.0 compatibility check
- Updated po language file
- CDN support when using custom urls
- Moved the action replacement for wp_redirect_admin_locations at _init_admin_url()
- Trigger the action replacement for wp_redirect_admin_locations only if new admin slug exists
- Preserve absolute paths when doing relative replacements
- Populate upload_dir() data with new url if apply
- When doing reset, empty all options before fill in existing with default to ensure deprecated data is not being held anymore
- Do not redirect to new admin url unless rewrite_rules_applied()
- Generate no rewrite rules if there’s no options / reset
- Removed any passed through variables when calling the do_action(‘wph/settings_changed’) as the function can take no argument.
- Re-generate a new write_check_string on settings change to ensure if no .htacccess / web.config file is writable, it trigger correct error and flag the disable_filters variable.
- Reset confirmation message update to better inform the admin upon the procedure to follow.
- WPEngine environment check, as they do not support Apache rewrite out of the box
- Strip off protocol and any www prefix for site_url and home_url to ensure accurate comparing
- Fixed redirect url when saving the options and WordPress deployed in subfolder
- Fixed redirect url when reset all options and WordPress deployed in subfolder
- Improved compatibility for WordPress subfolder install
- Fixed some rewrite lines when WordPress installed in a path and subfolder
- Replaced the internal variable permalinks_not_applied to more intuitive custom_permalinks_applied
- Restart the buffering if flushed out, mainly used for footer when updating plugins and themes
- Add textdomain for multiple untranslated texts
- Updated PO language file
- Fixed textdomain for couple texts
- Add text to textdomain
- Updated MU Loader, if there’s no plugin active avoid to receive any notice.
- Allow new wp-login.php
- PRO version available
- Check if there’s a ‘message’ key for arguments set through wp_mail filter
- Updated po language file
- WPML compatibility when use different domains for each language
- Do not apply the admin/login replacements if permalinks where not applied.
- Language Po file update
- Minify replaces ‘Remove new line carriage’
- Options for Minify to compress different components
- Fixed conflict with Shield Security
- PHP 7.2 compatibility
- WooCommerce downloadables fix when using custom slug for uploads
- Include support for admin_url() along with admin-ajax.php
- Fixed redirect link after user register.
- Use get_rewrite_base and get_rewrite_to_base for all modules to apply correct site path and any WordPress subdirectory install
- WordPress subdirectory install compatibility fix
- Improved router file processor for WordPress subdirectory installs
- Rewrite changes for many components
- Rewrite update for admin and login url
- Typos fix
- Compatibility for diferent environments, when WordPress deployed in a domain root, a subdirectory, or it’s own folder https://codex.wordpress.org/Giving_WordPress_Its_Own_Directory
- Fixed rewrite ens slashes for wp-login.php and wp-admin components
- Fixed hardcoded wp-register.php within rewrite – root files component
- Updated components to rewrite_base / rewrite_to system
- Improved components: Rewrite – WP Includes, Rewrite – WP Content, Rewrite – Plugins, Rewrite – Uploads, Rewrite – Comments, Rewrite – Root Files, Admin – wp-login.php, Admin – Admin Url
- Typo fix environemnt to environment
- New Component – Remove Shortlink Meta
- New Component – Remove new line carriage
- Apply relative paths change on styles only if main theme / child theme rewrite slug is not empty
- Improved interface errors and warnings transient structure
- Use ABSPATH and Environemnt data to create file path for file processing, instead just ABSPATH, for better compatibility
- Prevent the wp-register.php redirect to new login page when using block
- Prepare plugin for Composer package
- URL Slash description update
- xml_rpc_path add php_extension_required validation
- File processor use ABSPATH instead DOCUMENT_ROOT environment variable to avoid different paths on certain systems
- Allow path structure to be used for New Theme Path and Child – New Theme Path
- Media Galery src images fix
- Use separate variables for holding replacements to avoid key overwrite
- Add replacements for urls which does not contain explicit protocol e.g. http: or https:
- Avada cache URLs replacements support
- Fix processing_order for specific root files
- Ignore wp-register.php when blocking other wp-* files
- Fixed wp-register.php block
- Check for replacements on url encoded links
- Show message notices on General/HTML -> Html for options which may interfere with themes.
- sanitize_file_path_name fix when slug include a file type extension
- Prevent redirect to new url when accessing links through www
- New component Feeds
- Windows – Global file process rewrite rules update
- If no server type identification possible, try to check for .htaccess file
- Improved .htaccess search mod, Use preg_grep for identify the begin and end of WordPress rules
- Output notice when no supported server was found
- Use separate block of rules for .htaccess file, outside of WordPress lines
- Improved server htaccess support check
- Moved WPH_CACHE_PATH constant declaration from mu loader to wph class
- Use shutdown hock instead wp_loaded when plugin inline updated
- Use FS_CHMOD_FILE for $wp_filesystem->put_contents
- Fixed default wp-content block
- Updated compatibility with WP Fastest Cache
- Fixed wp-content replacement
- Replace the file-process file remove update
- New component : Robots.txt to control the outputed data
- Check if any environment variable has changed before Update static environment file
- Improved Default constants map
- File-processing check WordPress wp-load.php down the path, for custom install directory.
- Templates style clean
- Use cache for cleaned styles files
- Set HTTP_MOD_REWRITE environment variable through mod_rewrite
- Separate rewrite rules from WordPress and use distinct block with specific marker
- Add relative .htaccess file manipulation to avoid accessing permissions when WordPress installed within a subfolder.
- Updated .po language file
- Tags update
- Replaced “Remove description header from Style file” and “Child – Remove description header from Style file” functionality
- Security improvments
- Fix: Allow only css files to be processed through the router to prevent other types from being displayed arbitrary.
- Mu-loader updated version
- Environment allowed path to limit css files processing
- Include _get_plugin_data_markup_translate ratter WordPress method
- Fix: replacement_exists returned wrong response since not using priority keys
- Fix: Add media replacement, use correct replacement_exists function call
- Router check for client HTTP_ACCEPT_ENCODING type to start ob_start using ob_gzhandler or not.
- Update urls dynamically within stylesheets files e.g. include ‘../theme-name’
- Use trailingslashit for theme / child new urls to make sure it match full url instead partial theme name (e.g. main-theme and main-theme-child)
- Block wp-register.php
- get_home_path rely on DIRECTORY_SEPARATOR for better compatibility
- Check if plugin slug actually exists within all plugins list on re_plugin_path component
- Fix: Use of undefined constant WPH_VERSION
- Fix: Child theme settings not showing up
- Use register_theme_directory if empty $wp_theme_directories
- Plugin Options validation improvements for unique slug
- General / Html > Meta -> new option Remove DNS Prefetch
- New component – Comments
- Fix: Updated admin urls on plugin / theme / core update page
- fix: WP Rocket url replacements for non cached pages
- Regex patterns updates for better performance and compatibility
- Fix: WP Rocket – support HTML Optimization, including Inline CSS and Inline JS
- Fix – Create mu-plugins folder if not exists
- WP Rocket plugin compatibility module
- Plugin loader component through mu-plugins for earlier processing and environment manage
- Fix: Plugins Update iframe styles src
- Fix: WordPress Core Update redirect url
- WP Fastest Cache plug in compatibility improvements
- Sanitize Admin Url for not using extension (e.g. .php) as it confuse the server upon the headers to sent
- Fix: replacements links when using custom directory for WordPress core files
- Fix: child theme path fix when changing style filename
- New Theme Path – help resource link fix
- Changed from DOMDocument to preg_replace for better compatibility with themes and plugins
- Improved execution speed
- Fixed PHP Notice: Undefined variable: dom
- W3 Total Cache – Page Cache compatibility fix
- Canonical tag replacement improvements
- Pingback tag replacement improvements
- Fix custom Background Images for body on themes which support that feature
- Post-process on options interface save for unique slugs on any text inputs to prevent conflicts.
- Processing Order change for new_theme_child_path to occur before new_theme_path
- New COmponent General -> Oembed
- Remove Oembed tags from header
- Remove Remove Resource Hints tags from header
- rewrite rules update to match only non base, from (.*) to (.+)
- wph-throw-404 improvements
- BuddyPress conflict handle for uploaded gravatars
- Admin Style changes
- BuddyPress Conflict Class handler
- Separate WordPress meta Generator and Other Meta Generator
- Process Location value within sent Headers list if exists
- Replacements for https and http urls relative to domain
- Add replacements for relative paths to cover WordPress installs within a folder.
- Use untralingslashit when creating theme and child theme url replacements
- Fix for Call to a member function is_404() on a non-object within wp_redirect
See full list of changelogs at https://wp-hide.com/plugin-changelogs/