• Resolved mc001

    (@mc001)


    We’ve just upgraded WP from 6.0.3 to 6.1.1 (PHP 8.1) and we’re now seeing this kind of error message in the debug.log file when the NADI plugin tries to sync AD to WP, with sensitive data obfuscated:

    [24-Nov-2022 11:54:42 UTC] Cron reschedule event error for hook: crontrol_cron_job, Error code: could_not_set, Error message: The cron event list could not be saved., Data: {“schedule”:”daily”,”args”:{“code”:” $postData = http_build_query( \r\n array(\r\n ‘next_ad_int-task’ => ‘sync-to-wordpress’,\r\n ‘auth-code’ => ‘xxxxxxxxxxx’\r\n )\r\n );\r\n $data_len = strlen($postData);\r\n $opts = array(\r\n ‘http’ => array( \r\n ‘method’ => ‘POST’,\r\n\t\t ‘header’ => \”Content-Type: application\/x-www-form-urlencoded\\r\\nConnection: close\\r\\nContent-Length: $data_len\\r\\n\”,\r\n ‘content’ => $postData\r\n )\r\n );\r\n $context = stream_context_create($opts);\r\n $result = file_get_contents(‘http:\/\/AAA.BBB.COM\/wp-admin\/admin.php’, false, $context);\r\n”,”name”:”AD Sync to WP”},”interval”:86400}`

    In fact, there appears to be two identical “PHP Cron (AD Sync to WP)” jobs listed in the cron list), neither of which we can delete. Any help with the issue would be much appreciated.

Viewing 7 replies - 1 through 7 (of 7 total)
  • Plugin Author schakko

    (@schakko)

    Hm, NADI does not register its own cronjobs, so I assume that you are using a 3rd party plug-in like wp-crontrol (https://active-directory-wp.com/docs/Usage/How_to_add_a_cron_job_via_Wp_Control.html) which has then be configured to execute the cron job.
    As you might have conclude from https://www.ads-software.com/support/topic/cron-unschedule-event-error-for-hook/#post-16185568 this seems to be a bug in either WordPress 6.1.1 or wp-crontrol.

    Plugin Author schakko

    (@schakko)

    FYI: I’ve just checked the sample in our documentation against the latest NADI, WordPress and wp-crontrol version and it is working fine. Are there any other issues logged?

    Thread Starter mc001

    (@mc001)

    Hi,
    Thanks for replying so promptly. Yes, another NADI related error has shown up, namely:

    PHP Fatal error: Uncaught TypeError: ldap_get_entries(): Argument #2 ($result) must be of type LDAP\Result, bool given in /var/www/html/wp-content/plugins/next-active-directory-integration/vendor/adLDAP/adLDAP.php:1048

    Looking at where the error takes place, it’s at:


    // Non-Paged version
    $sr=ldap_search($this->_conn,$this->_base_dn,$filter,$fields);
    $entries = ldap_get_entries($this->_conn, $sr);

    According to the PHP manual pages, in 8.1 ldap_get_entries now expects an LDAP\Result instance as second argument; previously, a resource was expected. However, ldap_search only returns an LDAP\Result if it succeeds, whereas it will return False (boolean) on failure. This is probably the bool alluded to in the error message. Hence, I think the plugin needs to handle such a case more gracefully by checking $sr before passing it to ldap_get_entries. Would you agree?

    Plugin Author schakko

    (@schakko)

    @mc001 Yes, I came to the same conclusion. I’ve tracked this issue in https://github.com/NeosIT/active-directory-integration2/issues/166 and created a patch for this.
    Can you check out https://github.com/NeosIT/active-directory-integration2/tree/bugfix/166-ldap_get_entries-expects-ldapresult-instance-as-second-parameter and try it with that version?

    Thread Starter mc001

    (@mc001)

    OK, I’ve installed the test version from github. At first it failed to load as the vendor subdirectory was mostly empty and missing required files such as autoload.php. Once I copied that directory (and only that directory) from the previous version (2.3.5) then it loaded fine. I should add that I kept the new adLDAP directory in vendor, otherwise the required changes wouldn’t have been picked up. So far I haven’t seen the ldap_get_entries error being reported, just the cron job ones, which looks increasingly like a problem in WP core.

    • This reply was modified 1 year, 12 months ago by mc001.
    Plugin Author schakko

    (@schakko)

    @mc001 Thank you for the response, I forgot to mention that you have to copy the vendor files :-/

    Good, that the new adLdap version fixes the issues. I can only suggest that you switch from WP Crontrol to a “real” Linux cronjob or a Windows scheduled task.

    Thread Starter mc001

    (@mc001)

    For completeness, and in case anyone stumbles on this thread while experiencing the same issue, I was able to get rid of the cron errors by directly editing the “cron” value in the “wp_options” MySQL table and resetting it to the previous value prior to upgrading WP to 6.1.1. This got rid of most of the user defined cron jobs, but none of the core ones, and the former were simple to add back in. The point is that NADI is now happily sync’ing AD -> WP. My suspicion is that the database entry got corrupted during the WP upgrade, but I have no definitive proof.

Viewing 7 replies - 1 through 7 (of 7 total)
  • The topic ‘WP 6.1.1 problem’ is closed to new replies.