• Resolved Benjamin Pick

    (@benjamin4)


    Hi,

    I am the developer of the plugin “Geolocation IP Detection” …
    https://www.ads-software.com/plugins/geoip-detect/

    In my recent version 4.0.0 I upgraded the Maxmind Lib “geoip2/geoip2” to its latest version (2.11.0) and it broke on wordpress installations that have wordfence as well, as you seem to be using an older version of that lib at the same time:

    https://www.ads-software.com/support/topic/4-0-0-bricks-wordpress/#post-14124932

    So for now, I reverted that change (4.0.1) but I wonder, how do we avoid such incompabilities in the long term? Because at some point some plugin will upgrade that lib and the story will start again.

    I saw you had a similar problem 2 years ago:
    https://www.ads-software.com/support/topic/uncaught-error-class-maxminddbreader-not-found/

    and I had a similiar incompatibility with WooCommerce 1 year ago:
    https://github.com/woocommerce/woocommerce/issues/25370

    The problem is that composer doesn’t seem to handle this kind of version duplicity well (maybe that has improved on composer 2? But even then, the plugin code depends on a certain lib version.)

    Basically I see the following long-term options:
    a) We could make a list of WordPress plugins that use the Maxmind lib (this would help to test such kind of maxmind lib updates better), trying to make all these plugin authors aware of this issue
    b) We could approach Maxmind telling them to never change function signatures of the API, or at least only do it for major version of their library (this would help for most cases, but not for the update I had with WooCommerce as somehow a call between 2 maxmind libs went wrong)
    c) We keep it as is and basically never update the Maxmind lib again (obviously not great), except if there are security updates from Maxmind (then every one of these plugins has to upgrade).

    I would be very interested to hear your thoughts on this!

Viewing 10 replies - 1 through 10 (of 10 total)
  • Thread Starter Benjamin Pick

    (@benjamin4)

    Oh there is also

    d) reducing the number of API signatures that the plugin is depending on, by not extending their classes and instead wrapping their objects etc. (doesn’t solve all the problems but reduces the likelehood of breakage)

    • This reply was modified 3 years, 8 months ago by Benjamin Pick. Reason: format
    Matt

    (@braquopronos)

    I got crash also on one WP

    Plugin Support wfpeter

    (@wfpeter)

    Hi @benjamin4, thanks for bringing this to our attention.

    We are planning on adding a prefix to the namespace in a future release, and if you do the same, we can likely avoid conflicts with other plugins too. This has been scheduled into our development plan, however I cannot comment on precise delivery dates here on the forums.

    Thanks,

    Peter.

    @wfpeter @benjamin4 @lanceadam

    This has happened again and has affected me. Not a fatal error, but still an issue.

    Does this mean GeoLocation IP Detection has made the suggested changes above and Wordfence hasn’t? I’m not a developer, so I may not be reading the code correctly.

    See:

    `My site uses GEOIp maxmind libraries and is reporting a conflict with Wordfence.

    Geolocation IP Detection: Error: Old Maxmind Libraries detected.
    Apparently, there is another plugin installed that also uses the Maxmind libraries, but their version of these libraries is outdated.

    These files have been found to be loaded from another plugin: /wp-content/plugins/wordfence/vendor/geoip2/geoip2/src/Database/Reader.php , /wp-content/plugins/wordfence/vendor/maxmind-db/reader/src/MaxMind/Db/Reader.php

    Please disable that plugin, update that plugin or use a different data source in Geolocation IP Detection. Until then, the lookup for Maxmind sources is disabled.`

    My message deleted the link to the support topic I mentioned, but lanceadam has posted about this:

    https://www.ads-software.com/support/topic/old-maxmind-libraries-detected/

    Thread Starter Benjamin Pick

    (@benjamin4)

    What my plugin is doing is checking whole wordpress install if there are other plugins that are using the Maxmind libraries as well, and if so, check via MD5 if their plugin is using the same version of the files as my plugin.

    The reason for this is that every month or so I get bug report that somehow the Maxmind source is not working, and some users don’t know which other plugin is also using the Maxmind libraries because they don’t use that feature. These notice should reduce the debugging effort of these cases, and alert to this issue pro-actively (because the problem can arise anytime one of the plugins decides to update their files).

    Maybe I should make these notices less visible (trying to show them only in case of error, and on a “troubleshooting” page)?

    Hi Ben,

    I’m ok with the notice, my primary issue is that maxmind source is also disabled. My site rely’s on maxmind for Geolocation IP Detection. I’ve had to disable wordfence to allow Geolocation IP Detection to function correctly.

    The issue is reported as part of the notice, ie.

    > Until then, the lookup for Maxmind sources is disabled.

    Thread Starter Benjamin Pick

    (@benjamin4)

    The automatic deactivation has been removed in the Hotfix update 4.2.1 now.

    Thanks for the quick fix and your responsiveness! All good now in 4.2.2!

    buzibuzi

    (@buzibuzi)

    Hi, do you have a fix for this or can you suggest a temporary “dirty” solution ?
    Thanks

Viewing 10 replies - 1 through 10 (of 10 total)
  • The topic ‘Maxmind Lib incompabilities (Meta-Ticket)’ is closed to new replies.