• Resolved B.

    (@bandonrandon)


    Currently this plugin requires standard WordPress file locations to correctly create the backup. This can cause problems if DUPLICATOR_WPROOTPATH and other constanance are in different locations.

    I have created a patch which does two main things:

    1) Wraps the Define statements in if to allow being overwritten in the wp-config.php file for non-standard locations

    2) Updates duplicator.php to always get the correct path on activation based on get_home_path() instead of ABSPATH

    You’ll find the full patch here: https://gist.github.com/BandonRandon/67d79c9298dd412c3818403b48e0a4d7

    Please merge this into the next version as it should help prevent plugin path conflict.

    https://www.ads-software.com/plugins/duplicator/

Viewing 5 replies - 1 through 5 (of 5 total)
  • Sounds good… I’d prefer not to have an “if check” for every single constant wouldn’t it be cleaner to check for just for one of them and either define or not define at all?

    Just to verify your use case: you have the wp-config.php in say a directory outside of the wproot?

    Thanks

    Thread Starter B.

    (@bandonrandon)

    I’d prefer not to have an “if check” for every single constant wouldn’t it be cleaner to check for just for one of them and either define or not define at all?

    If I understand this question we shouldn’t entirely check for just one of them. For example in our case (explained more below) We are only defining DUPLICATOR_WPROOTPATH in wp-config and letting the plugin’s define.php take care of things from there.

    However, let’s say that I wanted to change the name of wp-snapshots I could modify just DUPLICATOR_SSDIR_NAME while leaving everything else the same.

    As an end user it would be much more complicated to have to set multiple constants just to change a couple of them. To use our case as an example again, we’d then have to copy over all the other //PATH CONSTANTS resulting in duplicate code between wp-config.php and define.php

    I do agree that this doesn’t look the cleanest, There may be a way for you to add a setting screen option instead if that would feel cleaner to you. This method just seemed the simplest. I’ll also be the first to point out that, really for our use case only the //PATH CONSTANTS need the check. I just though it would be nice to allow users to overwrite the other settings as well by setting a constant. Feel free to remove the checks around anything outside of Path Constants, just know that without the check if a user tries to define these themselves they will have a fatal.

    Just to verify your use case: you have the wp-config.php in say a directory outside of the wproot?

    Correct, our setup is a bit unique. We have thousands of WordPress site-site installs that all share the same core files. These files live in a _wp_ directory that is not accessible or writable by individual sites.

    Each site then has its own wp-content folder and wp-config.php file inside of /htdocs/site-name/ which can be fully controlled or modified by the site.

    So in our case what we did was after adding the if check defined:

    define('DUPLICATOR_WPROOTPATH', str_replace('\\', '/', $ SERVER['DOCUMENT ROOT'] . '/') );

    In the local wp-config.php which allowed us to set the document root for wp-content to /htdocs/ instead of /path/to/shared-wp-core/ (which are not writable)

    My goal with this patch was to create a way for the paths to not just work with our setup, but with any unique WordPress install setup.

    The duplicator.php file has been updated to match yours on git. Since this is an edge case usage of the plugin I would prefer to take it slow with allowing end users to update the global constants. I added the check for DUPLICATOR_WPROOTPATH and we can add others as needed.

    Being such a heavily used plugin its best to see how these changes slowly evolve otherwise we end up supporting all kinds of scenarios and trying to help people cleanup things that we were unable to anticipate. All the code is in git, if you could test and let me know if that helps solve your particular setup then I’ll merge it up-to the WP repository.

    Thxs

    Thread Starter B.

    (@bandonrandon)

    Hi Cory,

    Just tested the latest version from GitHub and works as expected with allowing a custom WordPress path root to be set.

    I also apologize for not doing a PR from GitHub, I failed to find it while searching the first time so I did a SVN patch from Trunk.

    As a heads up, the user I was helping mentioned the same problem was true with the pro version of the plugin.

    Thanks for pulling in the patch!

    No Problem… Its been folded into both lines and should be available with the next release…

    Thanks

Viewing 5 replies - 1 through 5 (of 5 total)
  • The topic ‘Correctly handle non-standard content paths [ has patch ]’ is closed to new replies.